/* ═══════════════════════════════════════════════════════════════
   subpage-base.css — Tema oscuro unificado para subpáginas v2
   Cargá DESPUÉS del CSS específico de cada página para que
   los overrides ganen la cascada.
═══════════════════════════════════════════════════════════════ */

/* ── Variables del tema ── */
:root{
  --teal:#17D6C7;--teal-d:#0FBFB3;--teal-dk:#0A9990;
  --blue:#2295D9;--blue-d:#1A78C0;
  --bg:#06101E;--bg-2:#081525;--bg-card:rgba(8,21,37,.92);
  --t1:rgba(255,255,255,.95);--t2:rgba(255,255,255,.78);
  --t3:rgba(255,255,255,.52);--t4:rgba(255,255,255,.32);
  --bd:rgba(255,255,255,.08);--bd-md:rgba(255,255,255,.14);
  --glass:rgba(255,255,255,.055);--glass-md:rgba(255,255,255,.095);
  --grad:linear-gradient(135deg,#17D6C7 0%,#2295D9 100%);
  --grad-text:linear-gradient(135deg,#17D6C7 0%,#5BAEE8 55%,#2295D9 100%);
  --inner:1220px;
  --radius:10px;--radius-lg:16px;--radius-xl:24px;
  --ease:cubic-bezier(.16,1,.3,1);
  --sec-py:96px;
}

/* ── Base ── */
html{color-scheme:dark;scroll-behavior:smooth;}
html,body{
  background:#06101E !important;
  color:rgba(255,255,255,.92) !important;
  font-family:'IBM Plex Sans','Space Grotesk',system-ui,sans-serif !important;
  -webkit-font-smoothing:antialiased;
}

/* ── Header ── */
#main-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:72px;display:flex;align-items:center;justify-content:space-between;
  padding:0 40px;
  background:rgba(6,16,30,.92);
  border-bottom:1px solid rgba(23,214,199,.12);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:background .3s,border-color .3s;
}
#main-header.scrolled{
  background:rgba(4,10,20,.96);
  border-bottom-color:rgba(23,214,199,.18);
}
.logo-wrap{display:flex;align-items:center;}
.logo-wrap img{height:50px;width:auto;display:block;}
#main-header nav{flex:1;display:flex;justify-content:center;}
.desktop-nav{list-style:none;display:none;align-items:center;gap:2px;}
.desktop-nav li a{
  font-family:'IBM Plex Sans',sans-serif;
  font-size:14px;font-weight:500;
  color:rgba(255,255,255,.7);
  padding:7px 14px;border-radius:8px;
  transition:color .2s,background .2s;
  white-space:nowrap;
}
.desktop-nav li a:hover{color:#fff;background:rgba(255,255,255,.07);}
@media(min-width:768px){.desktop-nav{display:flex;}.hamburger{display:none!important;}}
.nav-cta-btn{
  font-family:'IBM Plex Sans',sans-serif;
  font-size:13px;font-weight:600;
  color:#06101E;background:var(--teal);
  padding:9px 20px;border-radius:100px;
  transition:background .2s,transform .2s;
  white-space:nowrap;
}
.nav-cta-btn:hover{background:var(--teal-d);transform:translateY(-1px);}
.header-right{display:flex;align-items:center;gap:12px;}
.hamburger{
  cursor:pointer;background:none;border:none;
  display:flex;flex-direction:column;gap:5px;
  padding:10px;position:relative;z-index:201;
  min-width:44px;min-height:44px;align-items:center;justify-content:center;
}
.hamburger span{display:block;width:24px;height:2px;background:rgba(255,255,255,.85);border-radius:2px;transition:.3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

/* ── Nav drawer ── */
.nav-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.55);
  z-index:198;opacity:0;visibility:hidden;
  transition:opacity .35s,visibility .35s;
  backdrop-filter:blur(4px);
}
.nav-overlay.open{opacity:1;visibility:visible;}
.nav-drawer{
  position:fixed;top:0;right:-280px;width:280px;height:100vh;
  background:rgba(4,10,20,.97);backdrop-filter:blur(20px);
  z-index:199;transition:right .35s var(--ease);
  padding:88px 24px 40px;display:flex;flex-direction:column;gap:8px;
}
.nav-drawer.open{right:0;}
.nav-drawer ul{list-style:none;display:flex;flex-direction:column;gap:4px;}
.nav-drawer ul li a{
  display:block;font-size:15px;font-weight:500;
  color:rgba(255,255,255,.7);padding:11px 14px;border-radius:8px;
  transition:color .2s,background .2s;
}
.nav-drawer ul li a:hover{background:rgba(23,214,199,.12);color:var(--teal);}
.drawer-cta{
  display:block;margin-top:16px;padding:13px 20px;
  background:var(--teal);color:#06101E;
  font-size:14px;font-weight:600;border-radius:8px;text-align:center;
  transition:background .2s;
}
.drawer-cta:hover{background:var(--teal-d);}
.drawer-social{display:flex;gap:12px;margin-top:24px;}
.hero-social-btn{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.07);color:rgba(255,255,255,.65);
  border:1px solid rgba(255,255,255,.12);
  transition:background .2s,color .2s,border-color .2s;
}
.hero-social-btn:hover{background:rgba(23,214,199,.15);color:var(--teal);border-color:rgba(23,214,199,.3);}

/* ── Breadcrumb ── */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:rgba(255,255,255,.4);margin-bottom:28px;}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .2s;}
.breadcrumb a:hover{color:var(--teal);}
.breadcrumb-sep{color:rgba(255,255,255,.2);}

/* ── Secciones de contenido ── */
.section,section:not(.svc-hero):not(.cta-section){
  background:#06101E !important;
}
.section-inner,.svc-hero-inner{max-width:1160px;margin:0 auto;}
.svc-hero-inner{position:relative;z-index:1;}

/* Typography */
.sec-h2,h2,h3{
  color:rgba(255,255,255,.95) !important;
  font-family:'Space Grotesk','IBM Plex Sans',sans-serif !important;
}
.sec-h2 em,h2 em,h3 em{
  font-family:'IBM Plex Sans',sans-serif !important;
  font-style:italic;font-weight:300;
  background:var(--grad-text);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.sec-lead,p:not(.feature-title):not(.ind-title){
  color:rgba(255,255,255,.58) !important;
}
.feature-title,.step-label,.ind-title{
  color:rgba(255,255,255,.92) !important;
}
.feature-desc,.step-desc{
  color:rgba(255,255,255,.55) !important;
}

/* Cards oscuras */
.feature-card,.step-card,.steps-wrap,.steps-inner,
.faq-item,.quiz-card,.contact-block{
  background:rgba(8,21,37,.92) !important;
  border-color:rgba(255,255,255,.1) !important;
}
.feature-card:hover,.step-card:hover{
  border-color:rgba(23,214,199,.25) !important;
  box-shadow:0 8px 32px rgba(23,214,199,.1) !important;
}

/* Brand cards — fondo blanco igual que la home */
.brand-card{
  background:#fff !important;
  border-color:rgba(100,116,139,.16) !important;
}
.brand-card span{
  font-size:12px;
  color:#475569 !important;
  -webkit-text-fill-color:#475569 !important;
}

/* Steps connector — centralizado, aplica a TODAS las subpáginas */
.steps-grid{position:relative;}
.steps-grid::before{
  content:'';position:absolute;top:28px;left:28px;
  width:calc(33.33%);height:1px;
  background:linear-gradient(90deg,#17D6C7,transparent);
  pointer-events:none;
}
.steps-grid::after{
  content:'';position:absolute;top:28px;left:calc(33.33% + 28px);
  width:calc(33.33%);height:1px;
  background:linear-gradient(90deg,rgba(23,214,199,.3),transparent);
  pointer-events:none;
}
@media(max-width:600px){
  .steps-grid::before,.steps-grid::after{display:none;}
}
.step-connector{background:rgba(255,255,255,.08) !important;}

/* ── Footer — mismo layout que la home ── */
footer img{height:38px !important;width:auto !important;max-width:none !important;flex-shrink:0;object-fit:contain;}
footer{
  background:#030b14 !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  padding:36px 40px !important;
  display:flex !important;align-items:center !important;justify-content:space-between !important;
  flex-direction:row !important;flex-wrap:wrap !important;gap:20px !important;
}
.footer-contact{display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.footer-contact-item{
  display:flex;align-items:center;gap:8px;
  font-size:13px;color:rgba(255,255,255,.32) !important;
}
.footer-contact-item svg{width:14px;height:14px;flex-shrink:0;stroke:rgba(255,255,255,.32);}
.footer-contact-item a{color:rgba(255,255,255,.32) !important;transition:color .2s;}
.footer-contact-item a:hover{color:var(--teal) !important;}
.footer-bottom{display:flex;align-items:center;gap:24px;flex-shrink:0;}
.footer-copy{font-size:12px;color:rgba(255,255,255,.32) !important;white-space:nowrap;}
.footer-links{display:flex;gap:16px;}
.footer-links a{font-size:12px;color:rgba(255,255,255,.32) !important;transition:color .2s;}
.footer-links a:hover{color:rgba(255,255,255,.78) !important;}

/* ── Botones CTA unificados (pill — igual que la home) ── */
.btn-primary,.btn-ghost,.svc-hero-cta,
a.btn-primary,a.btn-ghost{
  border-radius:100px !important;
}

/* ── Legal modals ── */
.legal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.7);
  z-index:9000;display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
.legal-overlay.open{opacity:1;visibility:visible;}
.legal-modal{
  background:rgba(8,21,37,.98);border:1px solid rgba(255,255,255,.12);
  border-radius:16px;padding:36px;max-width:560px;width:90%;max-height:80vh;overflow-y:auto;
}
.legal-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;}
.legal-modal-header h3{font-size:18px;font-weight:700;color:rgba(255,255,255,.95);}
.legal-modal-close{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.5);transition:color .2s;padding:4px;}
.legal-modal-close:hover{color:#fff;}
.legal-modal-body h4{font-size:14px;font-weight:600;color:rgba(255,255,255,.8);margin:20px 0 8px;}
.legal-modal-body h4:first-child{margin-top:0;}
.legal-modal-body p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.7;}
.legal-modal-body a{color:var(--teal);}

/* ── WA float ── */
.wa-btn{
  position:fixed;bottom:28px;right:28px;z-index:500;
  width:52px;height:52px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 20px rgba(37,211,102,.4);
  opacity:0;transform:translateY(10px);
  transition:opacity .3s,transform .3s,background .2s;
  pointer-events:none;
}
.wa-btn.visible{opacity:1;transform:translateY(0);pointer-events:auto;}
.wa-btn:hover{background:#1db954;}
.wa-btn svg{width:26px;height:26px;}
.wa-tooltip{
  position:absolute;right:60px;
  background:rgba(4,10,20,.95);color:rgba(255,255,255,.9);
  font-size:12px;font-weight:500;white-space:nowrap;
  padding:6px 12px;border-radius:6px;
  opacity:0;pointer-events:none;transition:opacity .2s;
  border:1px solid rgba(255,255,255,.1);
}
.wa-btn:hover .wa-tooltip{opacity:1;}

/* ── Animate on scroll ── */
.animate,.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s;}
.animate.in,.reveal.in{opacity:1;transform:translateY(0);}

/* ── Responsive ── */
@media(max-width:900px){
  #main-header{padding:0 20px;}
  .section,section{padding-left:20px!important;padding-right:20px!important;}
  footer{padding:32px 20px !important;}
  .feature-grid{grid-template-columns:1fr 1fr !important;}
}
@media(max-width:600px){
  footer{flex-direction:column !important;align-items:flex-start !important;}
  .feature-grid{grid-template-columns:1fr !important;}
  .steps-grid{grid-template-columns:1fr !important;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px;}
}
