/* =============================================
   Editora Galaxia C.A. — Landing Page Styles
   ============================================= */

*{margin:0;padding:0;box-sizing:border-box;}
:root{
  --magenta:#e91e8c;
  --cyan:#00aeef;
  --yellow:#f7e000;
  --blue:#1a3fa0;
  --dark:#0d1b2a;
  --light:#f8f9ff;
  --white:#ffffff;
  --muted:#5a6070;
}
html{scroll-behavior:smooth;}
body{font-family:'Raleway',sans-serif;background:var(--light);color:var(--dark);overflow-x:hidden;}

/* ---- NAV ---- */
nav{
  display:flex;justify-content:space-between;align-items:center;
  padding:1rem 2.5rem;
  background:rgba(255,255,255,0.97);
  border-bottom:3px solid var(--cyan);
  position:sticky;top:0;z-index:100;
}
.nav-logo img{height:52px;width:auto;object-fit:contain;}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{text-decoration:none;font-size:.85rem;font-weight:600;color:var(--muted);letter-spacing:.05em;transition:color .2s;}
.nav-links a:hover{color:var(--magenta);}
.nav-cta{
  background:var(--magenta);color:#fff;
  border:none;padding:.5rem 1.4rem;
  border-radius:50px;font-size:.85rem;font-weight:700;
  cursor:pointer;transition:background .2s;font-family:'Raleway',sans-serif;
}
.nav-cta:hover{background:var(--blue);}

/* ---- HERO ---- */
.hero{
  min-height:92vh;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#0d1b2a 0%,#1a3fa0 55%,#0d1b2a 100%);
  position:relative;overflow:hidden;
  padding:4rem 2rem;text-align:center;
}
.hero-bg-circles{position:absolute;inset:0;pointer-events:none;}
.circle{position:absolute;border-radius:50%;opacity:.18;}
.c1{width:500px;height:500px;background:var(--magenta);top:-120px;left:-140px;}
.c2{width:350px;height:350px;background:var(--cyan);bottom:-80px;right:-80px;}
.c3{width:220px;height:220px;background:var(--yellow);bottom:100px;left:35%;}
.hero-content{position:relative;z-index:1;max-width:720px;}
.hero-badge{
  display:inline-block;
  background:rgba(247,224,0,.12);
  border:1px solid rgba(247,224,0,.5);
  color:var(--yellow);
  font-size:.75rem;font-weight:700;letter-spacing:.14em;
  padding:.35rem 1.1rem;border-radius:50px;margin-bottom:1.5rem;
  text-transform:uppercase;
}
.hero h1{
  font-family:'Nunito',sans-serif;
  font-size:clamp(2.2rem,6vw,4rem);
  font-weight:900;color:#fff;line-height:1.1;
  margin-bottom:1.25rem;
}
.hero h1 .accent{color:var(--cyan);}
.hero h1 .accent2{color:var(--magenta);}
.hero p{color:rgba(255,255,255,.72);font-size:1.05rem;line-height:1.7;margin-bottom:2rem;}
.hero-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}
.btn-primary{
  background:var(--magenta);color:#fff;
  padding:.85rem 2.1rem;border-radius:50px;
  font-weight:700;font-size:.95rem;
  text-decoration:none;border:2px solid var(--magenta);
  transition:all .2s;
}
.btn-primary:hover{background:transparent;color:var(--magenta);}
.btn-secondary{
  background:transparent;color:#fff;
  padding:.85rem 2.1rem;border-radius:50px;
  font-weight:600;font-size:.95rem;
  text-decoration:none;border:2px solid rgba(255,255,255,.35);
  transition:all .2s;
}
.btn-secondary:hover{border-color:#fff;}

/* ---- SHARED ---- */
section{padding:5rem 2rem;}
.container{max-width:1100px;margin:0 auto;}
.section-label{font-size:.75rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--magenta);margin-bottom:.4rem;}
.section-title{font-family:'Nunito',sans-serif;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:900;color:var(--dark);margin-bottom:1rem;line-height:1.2;}
.section-sub{color:var(--muted);font-size:1rem;line-height:1.7;max-width:560px;}
.section-center{text-align:center;}
.section-center .section-sub{margin:0 auto;}

/* ---- SERVICIOS ---- */
.services{background:var(--white);}
.services-header{margin-bottom:3rem;}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:1.25rem;}
.service-card{
  background:var(--light);border-radius:16px;
  padding:1.75rem 1.25rem;text-align:center;
  border:2px solid transparent;transition:all .25s;
}
.service-card:hover{border-color:var(--cyan);transform:translateY(-5px);box-shadow:0 14px 36px rgba(0,174,239,.13);}
.service-icon{
  width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;font-size:1.7rem;
}
.service-card h3{font-family:'Nunito',sans-serif;font-size:1rem;font-weight:800;color:var(--dark);margin-bottom:.4rem;}
.service-card p{font-size:.82rem;color:var(--muted);line-height:1.5;}

/* ---- PROCESO ---- */
.process{background:linear-gradient(135deg,#f8f9ff 0%,#e6eeff 100%);}
.process-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1.5rem;position:relative;margin-top:3rem;
}
.process-steps::before{
  content:'';position:absolute;
  top:38px;left:calc(12.5% + 10px);right:calc(12.5% + 10px);
  height:2px;
  background:linear-gradient(90deg,var(--magenta),var(--cyan));
  z-index:0;
}
.step{text-align:center;position:relative;z-index:1;}
.step-num{
  width:76px;height:76px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.1rem;font-size:1.6rem;
  background:var(--white);
  box-shadow:0 4px 20px rgba(0,0,0,.1);
  border:3px solid var(--white);
}
.step-badge{
  position:absolute;top:-4px;right:calc(50% - 42px);
  width:22px;height:22px;border-radius:50%;
  background:var(--magenta);color:#fff;
  font-size:.7rem;font-weight:900;
  display:flex;align-items:center;justify-content:center;
}
.step h4{font-family:'Nunito',sans-serif;font-size:.95rem;font-weight:800;color:var(--dark);margin-bottom:.4rem;}
.step p{font-size:.8rem;color:var(--muted);line-height:1.5;}

/* ---- GALERÍA ---- */
.gallery{background:linear-gradient(135deg,#0d1b2a 0%,#1a3fa0 100%);padding-bottom:5rem;}
.gallery .section-title{color:#fff;}
.gallery .section-label{color:var(--cyan);}
.gallery .section-sub{color:rgba(255,255,255,.6);}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2.5rem;}
.gallery-item{border-radius:16px;aspect-ratio:4/3;position:relative;overflow:hidden;cursor:pointer;}
.gallery-item:hover{transform:scale(1.02);transition:transform .3s;}
.gallery-item:hover .gallery-overlay{opacity:1;}
.gallery-overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s;gap:.4rem;
}
.gallery-overlay span{color:#fff;font-weight:700;font-size:.95rem;}
.gallery-overlay small{color:rgba(255,255,255,.7);font-size:.75rem;}
.gallery-note{text-align:center;margin-top:1.5rem;color:rgba(255,255,255,.4);font-size:.78rem;font-style:italic;}

/* ---- WHY ---- */
.why{background:var(--white);}
.why-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.why-list{list-style:none;margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem;}
.why-list li{
  display:flex;align-items:flex-start;gap:.85rem;
  background:var(--light);padding:1rem 1.25rem;border-radius:12px;
  box-shadow:0 2px 12px rgba(0,0,0,.04);
}
.why-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0;margin-top:2px;}
.why-list li h4{font-size:.95rem;font-weight:700;color:var(--dark);margin-bottom:.2rem;}
.why-list li p{font-size:.82rem;color:var(--muted);line-height:1.5;}
.why-visual{background:var(--blue);border-radius:24px;padding:2.5rem;text-align:center;color:#fff;}
.why-visual .big{font-family:'Nunito',sans-serif;font-size:4rem;font-weight:900;color:var(--cyan);}
.why-visual .big-sub{font-size:.9rem;color:rgba(255,255,255,.65);margin-top:.2rem;}
.why-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.75rem;}
.stat{background:rgba(255,255,255,.08);border-radius:12px;padding:1.1rem;}
.stat .n{font-family:'Nunito',sans-serif;font-size:2rem;font-weight:900;}
.stat .l{font-size:.78rem;color:rgba(255,255,255,.55);margin-top:.2rem;}

/* ---- TESTIMONIOS ---- */
.testimonials{background:var(--light);}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2.5rem;}
.testi-card{
  background:var(--white);border-radius:20px;padding:2rem;
  box-shadow:0 4px 24px rgba(0,0,0,.06);
  position:relative;border:2px solid transparent;transition:border-color .2s;
}
.testi-card:hover{border-color:var(--cyan);}
.testi-card::before{
  content:'"';
  font-family:'Nunito',sans-serif;font-size:6rem;
  color:var(--cyan);opacity:.12;
  position:absolute;top:-1rem;left:1.5rem;line-height:1;
}
.stars{color:var(--yellow);font-size:1rem;margin-bottom:1rem;letter-spacing:.1em;}
.testi-text{font-size:.88rem;color:var(--muted);line-height:1.75;margin-bottom:1.25rem;}
.testi-author{display:flex;align-items:center;gap:.75rem;}
.testi-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.testi-name{font-weight:700;font-size:.9rem;color:var(--dark);}
.testi-company{font-size:.76rem;color:var(--muted);margin-top:.1rem;}

/* ---- FAQ ---- */
.faq{background:var(--white);}
.faq-list{margin-top:2.5rem;display:flex;flex-direction:column;gap:.75rem;max-width:760px;margin-left:auto;margin-right:auto;}
details.faq-item{background:var(--light);border-radius:14px;overflow:hidden;border:2px solid transparent;transition:border-color .2s;}
details.faq-item[open]{border-color:var(--cyan);}
details.faq-item summary{
  padding:1.25rem 1.5rem;cursor:pointer;
  font-weight:700;font-size:.95rem;color:var(--dark);
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
details.faq-item summary::-webkit-details-marker{display:none;}
details.faq-item summary::after{content:'+';font-size:1.5rem;color:var(--magenta);flex-shrink:0;transition:transform .25s;line-height:1;}
details.faq-item[open] summary::after{transform:rotate(45deg);}
details.faq-item .faq-body{padding:0 1.5rem 1.25rem;font-size:.88rem;color:var(--muted);line-height:1.7;}

/* ---- CONTACTO ---- */
.contact{background:var(--dark);}
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.contact .section-title{color:#fff;}
.contact .section-sub{color:rgba(255,255,255,.6);}
.contact .section-label{color:var(--cyan);}
.wa-btn{
  display:inline-flex;align-items:center;gap:.75rem;
  background:#25D366;color:#fff;
  padding:1rem 2rem;border-radius:50px;
  font-weight:700;font-size:1rem;
  text-decoration:none;margin-top:1.75rem;
  transition:all .2s;box-shadow:0 8px 24px rgba(37,211,102,.3);
}
.wa-btn:hover{transform:translateY(-3px);box-shadow:0 14px 36px rgba(37,211,102,.4);}
.contact-info{display:flex;flex-direction:column;gap:.85rem;margin-top:1.5rem;}
.info-row{display:flex;align-items:center;gap:.75rem;color:rgba(255,255,255,.65);font-size:.9rem;}
.contact-card{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2rem;}
.contact-card h3{color:#fff;font-family:'Nunito',sans-serif;font-size:1.15rem;font-weight:800;margin-bottom:1.25rem;}
.form-row{display:flex;flex-direction:column;gap:.75rem;}
.form-row input,.form-row textarea,.form-row select{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.15);
  border-radius:10px;padding:.75rem 1rem;
  color:#fff;font-family:'Raleway',sans-serif;font-size:.9rem;
  outline:none;transition:border .2s;width:100%;
}
.form-row input::placeholder,.form-row textarea::placeholder{color:rgba(255,255,255,.35);}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{border-color:var(--cyan);}
.form-row select option{background:#1a2a40;color:#fff;}
.form-row textarea{resize:vertical;min-height:90px;}
.form-submit{
  background:var(--magenta);color:#fff;border:none;
  padding:.85rem;border-radius:50px;
  font-family:'Raleway',sans-serif;font-weight:700;font-size:.95rem;
  cursor:pointer;transition:background .2s;width:100%;margin-top:.25rem;
}
.form-submit:hover{background:#c01070;}

/* ---- FOOTER ---- */
footer{background:#06101a;text-align:center;padding:2rem;color:rgba(255,255,255,.4);font-size:.82rem;border-top:2px solid var(--blue);}
footer .footer-inner{max-width:1100px;margin:0 auto;}
footer .footer-social{display:flex;justify-content:center;gap:1rem;margin-bottom:1rem;}
footer .footer-social a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.08);color:rgba(255,255,255,.5);
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;font-size:1rem;transition:all .2s;
}
footer .footer-social a:hover{background:var(--cyan);color:#fff;}
footer span{color:var(--cyan);}

/* ---- RESPONSIVE ---- */
@media(max-width:900px){
  .process-steps{grid-template-columns:repeat(2,1fr);}
  .process-steps::before{display:none;}
  .gallery-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  nav{padding:1rem 1.25rem;}
  .nav-links{display:none;}
  .why-inner,.contact-inner{grid-template-columns:1fr;}
  .hero h1{font-size:2rem;}
}
@media(max-width:480px){
  .gallery-grid{grid-template-columns:1fr 1fr;}
  .process-steps{grid-template-columns:1fr 1fr;}
}
