/* =============================================================
   NEXAFLOW STUDIO — Hoja de estilos compartida (páginas de sector/servicio/zona)
   Reutiliza la identidad de la home: Syne + DM Sans · dark #080809 · lima #c8ff41 · aqua #3dffc0
   ============================================================= */
:root{
  --bg:#080809; --bg-2:#0c0c0e; --surface:#111114; --surface-2:#18181c;
  --white:#eeeef5; --muted:rgba(238,238,245,.5); --muted-2:rgba(238,238,245,.28);
  --lime:#c8ff41; --lime-dim:rgba(200,255,65,.12); --lime-glow:rgba(200,255,65,.25); --lime-border:rgba(200,255,65,.2);
  --aqua:#3dffc0; --aqua-dim:rgba(61,255,192,.1);
  --border:rgba(255,255,255,.07); --border-2:rgba(255,255,255,.12);
  --ease:cubic-bezier(.22,1,.36,1);
  --coral:#e8673a;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--white);
  font-family:'DM Sans',sans-serif; font-weight:300;
  line-height:1.7; overflow-x:hidden; max-width:100%;
  -webkit-font-smoothing:antialiased;
}
/* Mobile safety: never let text or images blow out their container */
p,h1,h2,h3,h4,h5,h6,span,a,li,small,b,strong,div{overflow-wrap:break-word;word-wrap:break-word}
img,video,iframe{max-width:100%;height:auto}
::selection{background:var(--lime);color:#080809}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1280px;margin:0 auto;padding:0 40px}
.label{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:500;display:inline-flex;align-items:center;gap:10px;
}
.label::before{content:'';width:24px;height:1px;background:var(--lime);display:inline-block}
h1,h2,h3{font-family:'Syne',sans-serif;font-weight:800;line-height:1.02;letter-spacing:-.02em}
em{font-style:normal;color:var(--lime)}

/* ====== CURSOR ====== */
#cr,#cr2{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;border-radius:50%;
  transform:translate(-50%,-50%);will-change:transform;display:none}
#cr{width:7px;height:7px;background:var(--lime);mix-blend-mode:exclusion;transition:width .25s,height .25s}
#cr2{width:38px;height:38px;border:1.5px solid var(--lime-border);transition:width .25s,height .25s,border-color .25s}
@media (hover:hover) and (pointer:fine){ #cr,#cr2{display:block} }
body.cursor-on{cursor:none}
body.cursor-on a,body.cursor-on button{cursor:none}

/* ====== NAV ====== */
nav#nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:22px 0;transition:padding .4s var(--ease),background .4s,border-color .4s;border-bottom:1px solid transparent}
nav#nav.solid{padding:14px 0;background:rgba(8,8,9,.72);backdrop-filter:blur(18px) saturate(1.4);-webkit-backdrop-filter:blur(18px) saturate(1.4);border-bottom:1px solid var(--border)}
/* iOS fix: drop the nav filter while the mobile menu is open (belt-and-suspenders; the panel is also relocated to <body> via JS) */
body.nav-open nav#nav,body.nav-open nav#nav.solid{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:transparent!important;border-bottom-color:transparent!important}
.nav-in{display:flex;align-items:center;justify-content:space-between}
.nav-backdrop{position:fixed;inset:0;background:rgba(4,4,6,.62);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .35s var(--ease),visibility .35s;z-index:205;pointer-events:none}
.nav-backdrop.show{opacity:1;visibility:visible;pointer-events:auto}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{position:relative;width:46px;height:46px;flex-shrink:0;display:grid;place-items:center;transition:width .4s var(--ease),height .4s var(--ease),filter .4s var(--ease)}
.logo-mark img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 4px 14px rgba(0,0,0,.55))}
.logo:hover .logo-mark{filter:drop-shadow(0 6px 22px var(--lime-glow))}
nav.solid .logo-mark{width:40px;height:40px}
.logo-word{font-family:'Syne';font-weight:800;font-size:19px;letter-spacing:-.02em;line-height:1;color:var(--white)}
.logo-word span{color:var(--lime)}
@media (max-width:520px){.logo-word{display:none}}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links .nl{font-size:14px;color:var(--muted);font-weight:400;transition:color .25s}
.nav-links .nl:hover,.nav-links .nl[aria-current="page"]{color:var(--white)}
.nav-cta{font-family:'Syne';font-weight:700;font-size:13.5px;color:#080809;background:var(--lime);padding:12px 22px;min-height:44px;border-radius:100px;display:inline-flex;align-items:center;gap:7px;transition:transform .3s var(--ease),box-shadow .3s;position:relative;overflow:hidden;border:none;cursor:pointer}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--lime-glow)}
.hamb{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:10px;min-width:44px;min-height:44px;align-items:center;justify-content:center;position:relative;z-index:1001}
.hamb span{width:22px;height:2px;background:var(--white);border-radius:2px;transition:transform .3s var(--ease),opacity .25s var(--ease)}
.hamb.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamb.active span:nth-child(2){opacity:0}
.hamb.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* hide FAB when mobile drawer is open so it doesn't sit on top of menu */
body.nav-open .fab-wa{opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s var(--ease),visibility .25s}

/* ====== BUTTONS ====== */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:9px;font-family:'Syne';font-weight:800;font-size:15px;padding:15px 26px;border-radius:100px;border:none;transition:transform .3s var(--ease),box-shadow .3s;cursor:pointer}
.btn span{position:relative;z-index:2}
.btn::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.22);transform:translateX(-101%);transition:transform .35s var(--ease);z-index:1}
.btn:hover::before{transform:translateX(0)}
.btn-main{background:var(--lime);color:#080809}
.btn-main:hover{transform:translateY(-2px);box-shadow:0 16px 48px var(--lime-glow)}
.btn-ghost{background:rgba(255,255,255,.02);color:var(--muted);border:1px solid var(--border-2);backdrop-filter:blur(8px);font-family:'DM Sans';font-weight:500}
.btn-ghost::before{background:rgba(255,255,255,.06)}
.btn-ghost:hover{color:var(--white);transform:translateY(-2px)}

/* ====== BREADCRUMB ====== */
.crumbs{padding-top:104px}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:9px;font-size:12.5px;color:var(--muted)}
.crumbs li{display:flex;align-items:center;gap:9px}
.crumbs li::after{content:'/';color:var(--muted-2)}
.crumbs li:last-child::after{content:none}
.crumbs a{color:var(--muted);transition:color .25s}
.crumbs a:hover{color:var(--lime)}
.crumbs li[aria-current]{color:var(--white)}

/* ====== SECTOR HERO ====== */
.shero{position:relative;overflow:hidden;padding:38px 0 96px}
.shero-glow{position:absolute;top:-10%;right:-8%;width:680px;height:620px;border-radius:50%;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse,rgba(200,255,65,.08) 0%,transparent 62%)}
.shero-glow.two{top:30%;left:-12%;right:auto;width:520px;height:520px;background:radial-gradient(ellipse,rgba(61,255,192,.05) 0%,transparent 62%)}
.shero .wrap{position:relative;z-index:1}
.shero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:64px;align-items:center}
.shero-pill{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;color:var(--white);font-weight:400;padding:8px 16px;border-radius:100px;border:1px solid var(--border-2);background:rgba(255,255,255,.04)}
.shero-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--aqua);box-shadow:0 0 10px var(--aqua);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.shero h1{font-size:clamp(36px,4.6vw,62px);margin:24px 0 0;letter-spacing:-.025em;line-height:1.04;text-wrap:balance}
.shero h1 em{color:var(--lime)}
.shero-sub{font-size:clamp(16px,1.45vw,19px);color:rgba(238,238,245,.72);max-width:520px;margin-top:24px}
.shero-ctas{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap}
.shero-meta{display:flex;gap:30px;flex-wrap:wrap;margin-top:42px}
.shero-meta div{display:flex;flex-direction:column;gap:4px;max-width:160px}
.shero-meta b{font-family:'Syne';font-weight:800;font-size:17px;color:var(--lime);line-height:1.1}
.shero-meta span{font-size:12.5px;color:var(--muted);letter-spacing:.01em;line-height:1.4}
/* hero visual */
.shero-visual{position:relative}
.shero-frame{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--border-2);box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 80px rgba(200,255,65,.05)}
.shero-frame image-slot{display:block;width:100%;aspect-ratio:4/5}
.shero-frame .v-ovl{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 55%,rgba(8,8,9,.5) 100%)}
.fbadge{position:absolute;display:inline-flex;align-items:center;gap:8px;font-size:12.5px;font-weight:500;padding:9px 14px;border-radius:12px;background:rgba(12,12,14,.74);backdrop-filter:blur(14px);border:1px solid var(--border-2);box-shadow:0 10px 30px rgba(0,0,0,.4);z-index:3;white-space:nowrap}
.fbadge .d{width:7px;height:7px;border-radius:50%}
.fb1{top:22px;right:-16px;animation:floatY 5s ease-in-out infinite}
.fb2{bottom:26px;left:-20px;animation:floatY 6s ease-in-out infinite .8s}
.fb1 .d{background:var(--aqua);box-shadow:0 0 8px var(--aqua)}
.fb2 .d{background:var(--lime);box-shadow:0 0 8px var(--lime)}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* ====== SECTION SHELL ====== */
section.block{padding:118px 0;position:relative}
section.tight{padding:88px 0}
.sec-head{max-width:720px;margin-bottom:60px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(34px,4.2vw,56px);margin:20px 0 16px;letter-spacing:-.02em;line-height:1.05;text-wrap:balance}
.sec-head h2 em{color:var(--lime)}
.sec-head p{font-size:17px;color:var(--muted);max-width:560px}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* ====== PROBLEM GRID ====== */
.prob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.prob-card{position:relative;border:1px solid var(--border);border-radius:18px;padding:28px 26px 30px;background:linear-gradient(180deg,rgba(255,255,255,.028),rgba(255,255,255,.008));transition:transform .4s var(--ease),border-color .4s}
.prob-card:hover{transform:translateY(-4px);border-color:var(--border-2)}
.prob-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(232,103,58,.12);border:1px solid rgba(232,103,58,.25);color:var(--coral);margin-bottom:18px}
.prob-ic svg{width:22px;height:22px}
.prob-card h4{font-family:'Syne';font-weight:700;font-size:18px;line-height:1.15;margin-bottom:9px;letter-spacing:-.01em}
.prob-card p{font-size:14px;color:var(--muted);line-height:1.55}

/* ====== SOLUTION / SPLIT ====== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split.rev .split-media{order:-1}
.split-copy h2{font-size:clamp(30px,3.6vw,46px);margin:18px 0 16px;letter-spacing:-.02em;line-height:1.06}
.split-copy h2 em{color:var(--lime)}
.split-copy>p{font-size:16.5px;color:var(--muted);max-width:480px;margin-bottom:26px}
.sol-list{display:flex;flex-direction:column;gap:16px}
.sol-list div{display:flex;gap:15px;align-items:flex-start}
.sol-list .ck{width:30px;height:30px;border-radius:9px;flex-shrink:0;display:grid;place-items:center;background:var(--lime-dim);border:1px solid var(--lime-border);color:var(--lime);font-size:14px;margin-top:2px}
.sol-list b{font-family:'Syne';font-weight:700;font-size:15.5px;display:block;margin-bottom:2px}
.sol-list small{font-size:14px;color:var(--muted);font-weight:300;line-height:1.5}
.split-media{position:relative;border-radius:22px;overflow:hidden;border:1px solid var(--border);box-shadow:0 40px 100px rgba(0,0,0,.5)}
.split-media image-slot{display:block;width:100%;aspect-ratio:5/4}
.split-media .v-ovl{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,transparent 50%,rgba(8,8,9,.5) 100%)}

/* ====== BENEFITS (why-card style) ====== */
.ben-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ben-card{position:relative;border:1px solid var(--border);border-radius:22px;padding:0;overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.012));backdrop-filter:blur(16px);
  transition:transform .45s var(--ease),border-color .45s,box-shadow .45s}
.ben-card::after{content:'';position:absolute;inset:0;border-radius:22px;background:radial-gradient(120% 80% at 50% 0%,rgba(200,255,65,.07),transparent 60%);opacity:0;transition:opacity .45s var(--ease);pointer-events:none;z-index:1}
.ben-card:hover{transform:translateY(-7px);border-color:var(--lime-border);box-shadow:0 18px 50px -20px rgba(0,0,0,.55)}
.ben-card:hover::after{opacity:1}
.ben-card:hover .ben-ic{background:var(--lime);color:#080809;box-shadow:0 0 26px var(--lime-glow);border-color:var(--lime)}
/* media banner */
.ben-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#0a0a0c}
.ben-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s var(--ease),filter .6s var(--ease);filter:saturate(.92) brightness(.86)}
.ben-card:hover .ben-media img{transform:scale(1.07);filter:saturate(1.05) brightness(.95)}
.ben-media::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,9,0) 35%,rgba(8,8,9,.55) 78%,rgba(8,8,9,.98) 100%);pointer-events:none;transition:opacity .45s}
.ben-media::before{content:'';position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 110%,rgba(200,255,65,.12),transparent 55%);opacity:0;transition:opacity .5s var(--ease);pointer-events:none;z-index:1}
.ben-card:hover .ben-media::before{opacity:1}
.ben-body{position:relative;padding:24px 26px 30px;z-index:2}
.ben-num{font-family:'Syne';font-weight:800;font-size:12px;letter-spacing:.16em;color:var(--lime);opacity:.7;display:block;margin-bottom:14px}
.ben-ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;background:rgba(15,15,18,.85);border:1px solid var(--lime-border);color:var(--lime);margin-top:-50px;margin-bottom:18px;position:relative;z-index:3;transition:background .45s,color .45s,box-shadow .45s,border-color .45s,transform .45s;backdrop-filter:blur(8px)}
.ben-card:hover .ben-ic{transform:translateY(-2px)}
.ben-ic svg{width:24px;height:24px}
.ben-card h4{font-family:'Syne';font-weight:700;font-size:20px;line-height:1.15;letter-spacing:-.015em;margin-bottom:10px}
.ben-card p{font-size:13.5px;color:var(--muted);line-height:1.55}

/* ====== PROCESS ====== */
.proc{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:step}
.proc-step{position:relative;padding:30px 24px 32px;border:1px solid var(--border);border-radius:18px;background:var(--surface);transition:.4s var(--ease)}
.proc-step:hover{border-color:var(--lime-border);transform:translateY(-4px)}
.proc-step .pn{font-family:'Syne';font-weight:800;font-size:34px;color:var(--lime);line-height:1;display:block;margin-bottom:16px;opacity:.9}
.proc-step h4{font-family:'Syne';font-weight:700;font-size:18px;margin-bottom:8px;letter-spacing:-.01em}
.proc-step p{font-size:13.5px;color:var(--muted);line-height:1.55}

/* ====== CINE BAND ====== */
.cine{position:relative;min-height:480px;display:flex;align-items:flex-end;overflow:hidden;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cine-bg{position:absolute;inset:0;z-index:0}
.cine-bg image-slot,.cine-bg img{width:100%;height:100%;object-fit:cover}
.cine-bg::after{content:'';position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(8,8,9,.5) 0%,rgba(8,8,9,.12) 38%,rgba(8,8,9,.85) 100%),
  linear-gradient(90deg,rgba(8,8,9,.8) 0%,rgba(8,8,9,.2) 55%,transparent 100%)}
.cine .wrap{position:relative;z-index:2;width:100%;padding-top:90px;padding-bottom:60px}
.cine-copy{max-width:680px}
.cine-copy h2{font-family:'Syne';font-weight:800;font-size:clamp(30px,4.2vw,54px);line-height:1.05;letter-spacing:-.025em;text-wrap:balance}
.cine-copy h2 em{color:var(--lime)}
.cine-copy p{font-size:17px;color:rgba(238,238,245,.74);max-width:500px;margin-top:18px;line-height:1.55}

/* ====== FAQ ACCORDION ====== */
.faq-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:54px;align-items:start}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--border);border-radius:16px;background:var(--surface);overflow:hidden;transition:border-color .35s}
.faq-item.open{border-color:var(--lime-border)}
.faq-q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;text-align:left;background:none;border:none;color:var(--white);font-family:'Syne';font-weight:700;font-size:16.5px;letter-spacing:-.01em;padding:22px 24px;cursor:pointer;line-height:1.3}
.faq-q .fic{width:30px;height:30px;border-radius:50%;border:1px solid var(--border-2);display:grid;place-items:center;flex-shrink:0;font-size:18px;color:var(--lime);transition:.35s var(--ease)}
.faq-item.open .fic{background:var(--lime);color:#080809;border-color:var(--lime);transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-a p{font-size:14.5px;color:var(--muted);line-height:1.65;padding:0 24px 22px}

/* ====== SOCIAL PROOF (placeholder) ====== */
.proof-band{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.proof-card{position:relative;border:1px solid var(--border);border-radius:20px;padding:34px;background:var(--surface)}
.proof-quote{font-family:'Syne';font-weight:700;font-size:clamp(19px,2vw,24px);line-height:1.35;letter-spacing:-.01em;color:var(--white)}
.proof-quote em{color:var(--lime)}
.proof-by{display:flex;align-items:center;gap:14px;margin-top:24px}
.proof-by image-slot{width:48px;height:48px;flex-shrink:0}
.proof-by b{font-family:'Syne';font-weight:700;font-size:14.5px;display:block}
.proof-by small{font-size:12.5px;color:var(--muted)}
.ph-tag{position:absolute;top:16px;right:16px;font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);border:1px dashed var(--border-2);border-radius:100px;padding:4px 10px;font-weight:600}
.proof-card.is-ph{border-style:dashed;border-color:var(--border-2);background:linear-gradient(180deg,rgba(255,255,255,.02),transparent)}

/* ====== MICRO-CTA BAND ====== */
.mcta{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-2)}
.mcta-in{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:34px 0;flex-wrap:wrap}
.mcta-in .mt{font-family:'Syne';font-weight:700;font-size:clamp(20px,2.4vw,28px);max-width:640px;letter-spacing:-.01em}
.mcta-in .mt em{color:var(--lime)}
.mcta-actions{display:flex;gap:10px;flex-wrap:wrap}
.chip-cta{font-size:13.5px;font-weight:500;color:var(--muted);border:1px solid var(--border-2);background:rgba(255,255,255,.02);padding:11px 18px;border-radius:100px;cursor:pointer;transition:.3s var(--ease);display:inline-flex;align-items:center;gap:7px}
.chip-cta:hover{color:var(--white);border-color:var(--lime-border);background:var(--surface-2);transform:translateY(-2px)}
.chip-cta.solid{background:var(--lime);color:#080809;border-color:var(--lime);font-family:'Syne';font-weight:700}
.chip-cta.solid:hover{box-shadow:0 12px 32px var(--lime-glow)}

/* ====== INTERNAL LINKS / RELATED ====== */
.rel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.rel-card{border:1px solid var(--border);border-radius:18px;padding:26px;background:var(--surface);transition:.4s var(--ease);display:flex;flex-direction:column;gap:8px}
.rel-card:hover{border-color:var(--lime-border);transform:translateY(-4px);background:var(--surface-2)}
.rel-card .rk{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--lime);font-weight:600}
.rel-card h4{font-family:'Syne';font-weight:700;font-size:19px;letter-spacing:-.01em}
.rel-card p{font-size:13.5px;color:var(--muted);line-height:1.5}
.rel-card .go{margin-top:auto;padding-top:12px;font-size:13px;color:var(--white);display:inline-flex;align-items:center;gap:7px;font-weight:500}
.rel-card:hover .go{color:var(--lime)}

/* ====== CTA / CONTACT (reuse) ====== */
#contacto{position:relative;overflow:hidden}
.cf-head{text-align:center;max-width:780px;margin:0 auto 54px}
.cf-head .cta-badge{margin-bottom:20px}
.cf-head h2{font-family:'Syne';font-weight:800;font-size:clamp(32px,4.6vw,58px);line-height:1.04;letter-spacing:-.02em}
.cf-head h2 em{color:var(--lime)}
.cf-head p{font-size:17px;color:var(--muted);max-width:520px;margin:18px auto 0}
.cta-badge{display:inline-flex;align-items:center;gap:9px;font-size:12.5px;color:var(--lime);background:var(--lime-dim);border:1px solid var(--lime-border);padding:8px 18px;border-radius:100px;font-weight:500}
.cta-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 10px var(--lime);animation:pulse 2s infinite}
.cf-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:60px;align-items:start}
.cf-left h2{font-size:clamp(30px,3.6vw,46px);margin:18px 0 16px;letter-spacing:-.02em}
.cf-left h2 em{color:var(--lime)}
.cf-left p{font-size:16px;color:var(--muted);max-width:440px;margin-bottom:26px}
.cf-trust{display:flex;flex-direction:column;gap:12px;margin-top:24px}
.cf-trust div{display:flex;align-items:center;gap:11px;font-size:14.5px;color:var(--white);font-weight:300}
.cf-trust div .ck{width:22px;height:22px;border-radius:50%;background:var(--lime-dim);border:1px solid var(--lime-border);color:var(--lime);display:grid;place-items:center;font-size:12px;flex-shrink:0}
.cf-direct{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.cf-dlink{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:14px;border:1px solid var(--border);background:var(--surface);transition:.3s var(--ease)}
.cf-dlink:hover{border-color:var(--lime-border);background:var(--surface-2);transform:translateX(3px)}
.cf-dlink .ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex-shrink:0}
.cf-dlink .ico svg{width:19px;height:19px}
.cf-dlink b{font-family:'Syne';font-weight:700;font-size:14.5px;display:block}
.cf-dlink small{font-size:12.5px;color:var(--muted)}
.cf-dlink.wa .ico{background:rgba(37,211,102,.14);color:#25d366}
.cf-dlink.ig .ico{background:linear-gradient(45deg,rgba(225,48,108,.18),rgba(253,200,75,.18));color:#e1306c}
.cf-dlink.em .ico{background:var(--lime-dim);color:var(--lime)}
.cf-form{background:var(--surface);border:1px solid var(--border-2);border-radius:24px;padding:34px;box-shadow:0 40px 100px rgba(0,0,0,.4)}
.cf-form .fr{margin-bottom:16px}
.cf-form label{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:500;margin-bottom:8px}
.cf-form input,.cf-form textarea{width:100%;background:var(--bg-2);border:1px solid var(--border-2);border-radius:12px;padding:14px 16px;color:var(--white);font-family:'DM Sans';font-size:15px;font-weight:300;transition:.25s;resize:vertical}
.cf-form input:focus,.cf-form textarea:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px var(--lime-dim)}
.cf-form input::placeholder,.cf-form textarea::placeholder{color:var(--muted-2)}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cf-consent{display:flex;gap:11px;align-items:flex-start;margin:6px 0 18px;font-size:12.5px;color:var(--muted);line-height:1.5}
.cf-consent input{width:auto;margin-top:3px;accent-color:var(--lime);flex-shrink:0}
.cf-consent a{color:var(--lime);text-decoration:underline;text-underline-offset:2px}
.cf-submit{width:100%;justify-content:center;font-size:16px;padding:16px}
.cf-submit:disabled{opacity:.6;cursor:not-allowed}
.cf-note{text-align:center;font-size:12px;color:var(--muted-2);margin-top:14px}
.cf-ok{display:none;text-align:center;padding:30px 10px}
.cf-ok.show{display:block}
.cf-ok .okic{width:60px;height:60px;border-radius:50%;background:var(--lime);color:#080809;display:grid;place-items:center;font-size:28px;margin:0 auto 18px;box-shadow:0 0 30px var(--lime-glow)}
.cf-ok h3{font-size:24px;margin-bottom:10px}
.cf-ok p{font-size:15px;color:var(--muted);max-width:340px;margin:0 auto}

/* ====== FOOTER ====== */
footer{border-top:1px solid var(--border);padding:80px 0 36px;background:var(--bg-2)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:54px}
.foot-tag{font-size:15px;color:var(--muted);max-width:280px;margin-top:20px}
.foot-col h5{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);font-weight:600;margin-bottom:18px;font-family:'DM Sans'}
.foot-col a,.foot-col p{display:block;font-size:14.5px;color:var(--muted);margin-bottom:11px;transition:color .25s}
.foot-col a:hover{color:var(--lime)}
.foot-soc{display:flex;gap:12px}
.foot-soc a{width:44px;height:44px;border-radius:12px;border:1px solid var(--border-2);display:grid;place-items:center;color:var(--muted);transition:.3s}
.foot-soc a:hover{color:#080809;background:var(--lime);border-color:var(--lime);transform:translateY(-3px)}
.foot-bot{display:flex;align-items:center;justify-content:space-between;padding-top:30px;border-top:1px solid var(--border);font-size:13px;color:var(--muted-2);flex-wrap:wrap;gap:14px}
.foot-legal{display:flex;gap:20px;flex-wrap:wrap}
.foot-legal a{font-size:13px;color:var(--muted-2);transition:color .25s}
.foot-bot a:hover{color:var(--lime)}

/* ====== MODAL ====== */
#modal{display:none;position:fixed;inset:0;z-index:1000;align-items:center;justify-content:center;padding:24px}
#modal.open{display:flex}
.modal-bd{position:absolute;inset:0;background:rgba(4,4,6,.72);backdrop-filter:blur(8px);opacity:0;transition:opacity .25s}
#modal.show .modal-bd{opacity:1}
#modal-box{position:relative;z-index:2;width:100%;max-width:480px;background:var(--surface);border:1px solid var(--border-2);border-radius:24px;padding:36px;box-shadow:0 50px 120px rgba(0,0,0,.7);opacity:0;transform:scale(.96) translateY(10px);transition:opacity .25s var(--ease),transform .25s var(--ease)}
#modal.show #modal-box{opacity:1;transform:none}
.modal-x{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;border:1px solid var(--border-2);background:none;color:var(--muted);font-size:18px;cursor:pointer;display:grid;place-items:center;transition:.25s}
.modal-x:hover{color:var(--white);border-color:var(--white)}
#modal-box h3{font-size:26px;margin-bottom:10px}
#modal-box .m-sub{font-size:14.5px;color:var(--muted);margin-bottom:26px}
.m-opts{display:flex;flex-direction:column;gap:10px}
.m-opt{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:14px;border:1px solid var(--border);background:var(--bg-2);transition:.25s var(--ease);cursor:pointer}
.m-opt:hover{border-color:var(--lime-border);background:var(--surface-2);transform:translateX(3px)}
.m-opt .ico{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;flex-shrink:0;background:rgba(255,255,255,.04)}
.m-opt .ico svg{width:20px;height:20px}
.m-opt .mt{flex:1}
.m-opt .mt b{font-family:'Syne';font-weight:700;font-size:15px;display:block}
.m-opt .mt small{font-size:12.5px;color:var(--muted);font-weight:300}
.m-opt .ar{color:var(--muted-2);transition:.25s}
.m-opt:hover .ar{color:var(--lime);transform:translateX(3px)}
.m-wa .ico{background:rgba(37,211,102,.14);color:#25d366}
.m-ig .ico{background:linear-gradient(45deg,rgba(225,48,108,.18),rgba(253,200,75,.18));color:#e1306c}
.m-gm .ico{background:rgba(234,67,53,.14);color:#ea4335}
.m-ol .ico{background:rgba(0,120,212,.14);color:#3b82f6}
.m-ml .ico{color:var(--lime);background:var(--lime-dim)}
.m-foot{text-align:center;font-size:12px;color:var(--muted-2);margin-top:22px}

/* ====== COOKIE BANNER ====== */
#cookie{position:fixed;left:20px;bottom:20px;z-index:800;max-width:420px;background:var(--surface);border:1px solid var(--border-2);border-radius:16px;padding:20px 22px;box-shadow:0 30px 70px rgba(0,0,0,.6);transform:translateY(140%);transition:transform .5s var(--ease)}
#cookie.show{transform:none}
#cookie p{font-size:13px;color:var(--muted);line-height:1.6;margin-bottom:14px}
#cookie p a{color:var(--lime);text-decoration:underline;text-underline-offset:2px}
#cookie .ck-row{display:flex;gap:10px;align-items:center}
#cookie button{font-family:'Syne';font-weight:700;font-size:13px;padding:10px 18px;border-radius:100px;border:none;cursor:pointer;background:var(--lime);color:#080809;transition:.25s}
#cookie button:hover{box-shadow:0 8px 24px var(--lime-glow)}
#cookie a.ck-link{font-size:12.5px;color:var(--muted)}

/* ====== DECOR RAYS (como #porque en la home) ====== */
.sec-rays{position:absolute;top:-12%;right:-6%;width:62%;max-width:880px;opacity:.42;pointer-events:none;z-index:0;
  -webkit-mask-image:radial-gradient(120% 100% at 78% 30%,#000 0%,transparent 70%);mask-image:radial-gradient(120% 100% at 78% 30%,#000 0%,transparent 70%)}
section.has-rays{overflow:hidden}
section.has-rays .wrap{position:relative;z-index:1}
@media (max-width:980px){.sec-rays{width:90%;opacity:.3}}

/* ====== CONTACT BG (como #cta en la home) ====== */
.contact-bg{position:absolute;inset:0;z-index:0;opacity:.16}
.contact-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.5)}
.contact-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:600px;border-radius:50%;background:radial-gradient(ellipse,rgba(200,255,65,.055) 0%,transparent 65%);pointer-events:none;z-index:1}
#contacto .wrap{position:relative;z-index:2}

/* ====== FONDOS SUTILES DE SECCIÓN ====== */
.sec-bg{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.sec-bg img{width:100%;height:100%;object-fit:cover;opacity:.11;filter:saturate(.85) brightness(.72)}
.sec-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,#080809 0%,rgba(8,8,9,.2) 32%,rgba(8,8,9,.2) 68%,#080809 100%)}
.sec-bg.soft img{opacity:.08}
/* foto protagonista de fondo (hero) */
.sec-bg.photo{pointer-events:auto}
.sec-bg.photo image-slot{display:block;width:100%;height:100%;opacity:.3;filter:brightness(.62) saturate(.85)}
.sec-bg.photo::after{pointer-events:none;background:linear-gradient(90deg,#080809 0%,rgba(8,8,9,.72) 42%,rgba(8,8,9,.22) 100%),linear-gradient(180deg,rgba(8,8,9,.65) 0%,transparent 35%,transparent 68%,#080809 100%)}
.shero-grid.solo{grid-template-columns:1fr}
.shero-grid.solo .shero-copy{max-width:730px}
.has-bg{position:relative}
.has-bg>.wrap{position:relative;z-index:1}

/* ====== HERO STAT ROW (glass) ====== */
.stat-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:44px}
.stat-chip{display:flex;flex-direction:column;gap:3px;padding:16px 22px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--border-2);backdrop-filter:blur(14px);min-width:140px}
.stat-chip b{font-family:'Syne';font-weight:800;font-size:22px;color:var(--white);line-height:1}
.stat-chip b em{color:var(--lime)}
.stat-chip span{font-size:12px;color:var(--muted);letter-spacing:.01em}

/* ====== SERVICE CARDS (con imagen) ====== */
.svc2-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc2-grid .feat{grid-column:span 1}
.svc2-card{position:relative;border:1px solid var(--border);border-radius:20px;overflow:hidden;background:var(--surface);display:flex;flex-direction:column;transition:transform .45s var(--ease),border-color .45s;text-decoration:none}
.svc2-card:hover{transform:translateY(-6px);border-color:var(--lime-border)}
.svc2-img{position:relative;aspect-ratio:16/10;overflow:hidden}
.svc2-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);opacity:.92}
.svc2-card:hover .svc2-img img{transform:scale(1.05)}
.svc2-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(8,8,9,.55) 100%)}
.svc2-tag{position:absolute;top:14px;left:14px;z-index:2;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:var(--lime);background:rgba(8,8,9,.6);backdrop-filter:blur(8px);border:1px solid var(--lime-border);padding:6px 12px;border-radius:100px}
.svc2-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.svc2-body h3{font-family:'Syne';font-weight:700;font-size:21px;letter-spacing:-.015em;margin-bottom:9px}
.svc2-body p{font-size:14px;color:var(--muted);line-height:1.55;margin-bottom:16px}
.svc2-body .res{margin-top:auto;display:flex;align-items:center;gap:9px;font-size:13px;color:var(--white);font-weight:500}
.svc2-body .res .rd{width:7px;height:7px;border-radius:50%;background:var(--lime);box-shadow:0 0 8px var(--lime);flex-shrink:0}
@media (max-width:960px){.svc2-grid{grid-template-columns:1fr}}

/* ====== ZONAS (chips) ====== */
.zona-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.zona-chips span{font-size:13.5px;font-weight:500;color:var(--white);border:1px solid var(--border-2);background:rgba(255,255,255,.03);padding:9px 16px;border-radius:100px;transition:.3s var(--ease)}
.zona-chips span:hover{border-color:var(--lime-border);color:var(--lime)}
.zona-chips span.main{background:var(--lime);color:#080809;border-color:var(--lime);font-family:'Syne';font-weight:700}

/* ====== FLOATING WHATSAPP ====== */
.fab-wa{position:fixed;right:22px;bottom:22px;z-index:700;width:60px;height:60px;border-radius:50%;background:#25d366;display:grid;place-items:center;box-shadow:0 14px 38px rgba(37,211,102,.42);transition:transform .3s var(--ease),box-shadow .3s;animation:fabIn .5s var(--ease) .8s both}
.fab-wa svg{width:30px;height:30px;color:#fff}
.fab-wa:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 18px 48px rgba(37,211,102,.55)}
.fab-wa::after{content:'';position:absolute;inset:0;border-radius:50%;border:2px solid #25d366;animation:fabPulse 2.4s ease-out infinite;pointer-events:none}
@keyframes fabIn{from{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}
@keyframes fabPulse{0%{transform:scale(1);opacity:.6}100%{transform:scale(1.7);opacity:0}}
@media (max-width:600px){.fab-wa{width:54px;height:54px;right:16px;bottom:16px}.fab-wa svg{width:27px;height:27px}}

/* ====== REVEAL ====== */
.rv,.rv-l,.rv-s{opacity:0;transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv{transform:translateY(34px)}
.rv-l{transform:translateX(-40px)}
.rv-s{transform:scale(.94)}
.rv.vis,.rv-l.vis,.rv-s.vis{opacity:1;transform:none}

/* ====== RESPONSIVE ====== */
@media (max-width:1080px){
  .ben-grid{grid-template-columns:1fr 1fr}
  .proc{grid-template-columns:1fr 1fr}
  .ben-media{aspect-ratio:16/9}
}
@media (max-width:960px){
  .wrap{padding:0 24px}
  .nav-links{position:fixed;top:0;right:0;bottom:0;width:84%;max-width:340px;background:#0c0c0e;border-left:1px solid var(--border);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:6px;padding:96px 28px 32px;transform:translateX(105%);transition:transform .42s var(--ease);z-index:1000;overflow-y:auto;box-shadow:-30px 0 60px rgba(0,0,0,.35);isolation:isolate;-webkit-transform:translateX(105%);will-change:transform}
  .nav-links.open{transform:translateX(0);-webkit-transform:translateX(0)}
  .nav-links .nl{font-size:18px;color:var(--white);padding:14px 4px;min-height:48px;display:flex;align-items:center;border-bottom:1px solid var(--border);width:100%}
  .nav-links .nl:last-of-type{border-bottom:none}
  .nav-links .nav-cta{margin-top:18px;width:100%;justify-content:center;padding:15px 22px;min-height:50px;font-size:15px}
  .hamb{display:flex;z-index:220}
  .shero-grid{grid-template-columns:1fr;gap:48px}
  .shero-visual{max-width:440px}
  .prob-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:40px}
  .split.rev .split-media{order:0}
  .faq-grid{grid-template-columns:1fr;gap:34px}
  .proof-band{grid-template-columns:1fr}
  .rel-grid{grid-template-columns:1fr}
  .cf-grid{grid-template-columns:1fr;gap:40px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .mcta-in{flex-direction:column;align-items:flex-start;gap:20px}
  section.block{padding:80px 0}
}
@media (max-width:600px){
  .wrap{padding:0 18px}
  .crumbs{padding-top:92px}
  .ben-grid{grid-template-columns:1fr}
  .proc{grid-template-columns:1fr}
  .shero-meta{gap:20px}
  .shero h1{font-size:clamp(30px,7.6vw,40px)}
  .shero-pill{font-size:11.5px;padding:7px 13px;max-width:100%}
  .shero-sub{font-size:15.5px}
  .cf-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  #cookie{left:12px;right:12px;bottom:12px;max-width:none}
  .shero-ctas .btn{width:100%;justify-content:center;min-height:50px}
  .btn{font-size:14.5px;padding:14px 22px;min-height:48px}
  .sec-head h2,.cine-copy h2,.cf-head h2,.cf-left h2{font-size:clamp(26px,6.5vw,36px) !important;line-height:1.08}
}
