/* ===========================================================
   FÚTBOLCRM — landing v2
   inversive hierarchy · less copy · scroll-driven motion · ROI math
   =========================================================== */

:root{
  --bg:#050B14;
  --bg-2:#0A1320;
  --bg-3:#11203A;
  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.14);
  --ink:#F5F7FA;
  --ink-soft:#B7C2D4;
  --ink-muted:#6B7A93;
  --accent:#00E47C;
  --accent-2:#00B065;
  --blue:#4F8AFF;
  --gold:#FFC93C;
  --hot:#FF5A4E;
  --serif:'Fraunces', Georgia, serif;
  --sans:'Inter Tight', system-ui, sans-serif;
  --mono:'JetBrains Mono', monospace;
  --radius:14px;
  --radius-lg:22px;
  --maxw:1320px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:16px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{padding:140px 0;position:relative}
@media (max-width:760px){section{padding:90px 0}}

/* ---------- type ---------- */
h1,h2,h3,h4,h5{font-family:var(--serif);font-weight:400;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(48px,7.2vw,108px);line-height:.96;letter-spacing:-.04em}
h2{font-size:clamp(36px,5vw,72px);line-height:1;letter-spacing:-.035em}
h3{font-size:clamp(22px,2vw,28px);line-height:1.1}
h4{font-size:18px;font-weight:500;letter-spacing:-.01em;font-family:var(--sans)}
.serif{font-family:var(--serif);font-style:italic;font-weight:400}
.accent{color:var(--accent)}
.mono{font-family:var(--mono);font-weight:400}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);margin-bottom:24px
}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent);display:block}

.brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.01em;font-size:15px}
.brand .mark{
  width:32px;height:32px;border-radius:7px;
  display:grid;place-items:center;color:#001a0e;
  overflow:hidden;flex-shrink:0;
}
.brand .mark img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- nav (floating island) ---------- */
.nav{
  position:fixed;top:16px;left:16px;right:16px;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:32px;
  padding:10px 14px 10px 18px;
  background:rgba(10,19,32,.82);
  backdrop-filter:blur(28px) saturate(160%);-webkit-backdrop-filter:blur(28px) saturate(160%);
  border:1px solid var(--line-2);
  border-radius:99px;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.02);
  transition:top .3s ease, padding .3s ease, background .3s ease, max-width .3s ease;
  max-width:1400px;margin:0 auto;
  overflow:hidden;
}
.nav.scrolled{
  top:12px;
  padding:8px 12px 8px 16px;
  background:rgba(10,19,32,.94);
  box-shadow:0 24px 60px -20px rgba(0,0,0,.7), 0 0 0 1px rgba(0,228,124,.08);
}
.nav .brand .mark svg{width:16px;height:16px}
.nav .brand .mark img{width:32px;height:32px}
.nav ul{list-style:none;display:flex;gap:28px;justify-content:center}
.nav ul a{
  font-size:13px;color:var(--ink-soft);transition:.2s;
  position:relative;padding:6px 0
}
.nav ul a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s
}
.nav ul a:hover{color:var(--ink)}
.nav ul a:hover::after,.nav ul a.active::after{transform:scaleX(1)}
.nav ul a.active{color:var(--ink)}

.nav-ctas{display:flex;gap:10px;align-items:center}
.nav-secondary{
  padding:9px 16px;border-radius:99px;
  border:1px solid var(--line-2);color:var(--ink);
  font-weight:500;font-size:13px;transition:.2s
}
.nav-secondary:hover{border-color:var(--ink-soft);background:rgba(255,255,255,.04)}
.nav-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 18px;border-radius:99px;
  background:var(--accent);color:#001a0e;font-weight:600;font-size:13px;
  box-shadow:0 0 0 0 rgba(0,228,124,.6);
  transition:transform .2s, box-shadow .3s
}
.nav-primary:hover{transform:translateY(-1px);box-shadow:0 8px 24px -8px rgba(0,228,124,.6)}
.nav-primary .arr{transition:transform .2s}
.nav-primary:hover .arr{transform:translateX(3px)}

.nav-progress{
  position:absolute;bottom:0;left:0;height:2px;width:0;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transition:width .1s linear;
  border-radius:99px;opacity:.85
}
@media (max-width:980px){
  .nav{
    top:12px;left:12px;right:12px;
    grid-template-columns:auto auto;gap:12px;
    padding:8px 8px 8px 14px
  }
  .nav ul{display:none}
  .nav-secondary{display:none}
}

/* ---------- sticky CTA bar ---------- */
.sticky-cta{
  position:fixed;left:50%;bottom:24px;transform:translate(-50%,140%);
  z-index:48;
  background:rgba(10,19,32,.95);
  border:1px solid var(--line-2);
  border-radius:99px;
  box-shadow:0 20px 60px -20px rgba(0,0,0,.6), 0 0 0 1px rgba(0,228,124,.15);
  backdrop-filter:blur(20px);
  transition:transform .5s cubic-bezier(.2,.9,.2,1), opacity .4s;
  opacity:0;
  pointer-events:none;
  max-width:calc(100vw - 32px)
}
.sticky-cta.show{transform:translate(-50%,0);opacity:1;pointer-events:auto}
.sticky-inner{display:flex;align-items:center;gap:24px;padding:10px 14px 10px 24px}
.sticky-text{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--ink-soft)}
.sticky-text b{color:var(--ink);font-weight:600}
.sticky-text .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.6s infinite;flex-shrink:0}
.sticky-actions{display:flex;gap:8px;align-items:center}
.btn-mini{
  padding:9px 16px;border-radius:99px;font-weight:600;font-size:13px;
  display:inline-flex;align-items:center;gap:6px;transition:.2s
}
.btn-mini.ghost{color:var(--ink-soft);border:1px solid var(--line-2)}
.btn-mini.ghost:hover{color:var(--ink);border-color:var(--ink-soft)}
.btn-mini.primary{background:var(--accent);color:#001a0e}
.btn-mini.primary:hover{transform:translateY(-1px);background:#33ed95}
.btn-mini .arr{transition:transform .2s}
.btn-mini:hover .arr{transform:translateX(3px)}
@media (max-width:760px){
  .sticky-text{display:none}
  .sticky-cta{bottom:16px}
}

/* ---------- hero ---------- */
.hero{
  min-height:100vh;
  padding:160px 0 100px;
  position:relative;
  display:flex;align-items:center;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.hero-bg .hero-blob{
  position:absolute;
  bottom:-20%;
  right:-12%;
  width:min(560px,50vw);
  height:min(560px,50vw);
  z-index:0;
  pointer-events:none;
  opacity:.45;
  mix-blend-mode:screen;
  filter:blur(.5px)
}
@media (max-width:1100px){
  .hero-bg .hero-blob{
    right:-18%;
    bottom:-25%;
    width:min(420px,55vw);
    height:min(420px,55vw);
    opacity:.35
  }
}
@media (max-width:720px){
  .hero-bg .hero-blob{display:none}
}
.hero-bg .grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px,transparent 1px),
    linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,#000 30%,transparent 90%);
  opacity:.5
}
.hero-bg .glow{display:none}
.hero-bg .g1{width:600px;height:600px;background:#0F4830;top:-200px;left:-100px}
.hero-bg .g2{width:500px;height:500px;background:#1B2C5C;bottom:-200px;right:-100px}

.hero .wrap{position:relative;z-index:2}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:99px;
  background:rgba(0,228,124,.08);border:1px solid rgba(0,228,124,.25);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  margin-bottom:32px
}
.hero-tag .pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.6)}}

.hero h1 .word{display:inline-block;animation:wordIn .9s cubic-bezier(.2,.8,.2,1) forwards}
.hero h1 .word:nth-child(1){animation-delay:.1s}
.hero h1 .word:nth-child(2){animation-delay:.2s}
.hero h1 .word:nth-child(3){animation-delay:.3s}
.hero h1 .word:nth-child(4){animation-delay:.4s}
.hero h1 .word:nth-child(5){animation-delay:.5s}
.hero h1 .word:nth-child(6){animation-delay:.6s}
.hero h1 .word:nth-child(7){animation-delay:.7s}
.hero h1 .word:nth-child(8){animation-delay:.8s}
@keyframes wordIn{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}

.hero-sub{
  font-size:clamp(18px,1.4vw,22px);
  color:var(--ink-soft);
  max-width:640px;
  margin:32px 0 44px;
  line-height:1.45;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:99px;font-weight:600;font-size:15px;letter-spacing:-.005em;
  transition:transform .2s, background .2s
}
.btn-primary{background:var(--accent);color:#001a0e}
.btn-primary:hover{transform:translateY(-2px);background:#33ed95}
.btn-ghost{border:1px solid var(--line-2);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink-soft)}
.btn .arr{transition:transform .2s}
.btn:hover .arr{transform:translateX(4px)}

/* hero pitch viz */
.hero-viz{
  position:absolute;right:-5%;top:50%;transform:translateY(-50%);
  width:55%;max-width:780px;aspect-ratio:1;
  z-index:1;pointer-events:none;
  animation:fadeUp 1.4s ease 1.2s forwards;
}
@media (max-width:1100px){.hero-viz{display:none}}
.hero-viz svg{width:100%;height:100%}
.hero-viz .pitch-line{stroke:rgba(0,228,124,.25);stroke-width:1.2;fill:none}
.hero-viz .pitch-fill{fill:rgba(0,228,124,.02)}
.hero-viz .player{fill:var(--accent);animation:playerMove 4s ease-in-out infinite}
.hero-viz .player.r{fill:var(--hot)}
.hero-viz .player.p2{animation-delay:.3s}
.hero-viz .player.p3{animation-delay:.6s}
.hero-viz .player.p4{animation-delay:.9s}
.hero-viz .player.p5{animation-delay:1.2s}
.hero-viz .player.p6{animation-delay:1.5s}
@keyframes playerMove{0%,100%{transform:translate(0,0)}50%{transform:translate(0,-4px)}}
.hero-viz .ball{fill:#fff;animation:ballOrbit 16s linear infinite;transform-origin:50% 50%;transform-box:fill-box}
@keyframes ballOrbit{to{transform:rotate(360deg)}}

/* hero meta strip */
.hero-meta{
  display:flex;gap:0;align-items:stretch;
  margin-top:80px;
  border-top:1px solid var(--line);
  padding-top:32px;
  animation:fadeUp .9s ease 1.4s forwards
}
.hero-meta > div{flex:1;padding-right:32px}
.hero-meta > div + div{padding-left:32px;border-left:1px solid var(--line)}
.hero-meta .k{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:8px}
.hero-meta .v{font-family:var(--serif);font-size:clamp(20px,1.8vw,26px);line-height:1.15;color:var(--ink);text-wrap:balance}
.hero-meta .v em{color:var(--accent);font-style:italic;font-weight:400}

/* ---------- section heads ---------- */
.head{max-width:880px;margin-bottom:80px}
.head h2{margin-bottom:0}
.head .lead{margin-top:24px;font-size:clamp(18px,1.4vw,22px);color:var(--ink-soft);line-height:1.45;max-width:680px;text-wrap:pretty}

/* ---------- inversive grid: claim-first cards ---------- */
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
@media (max-width:980px){.inv-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.inv-grid{grid-template-columns:1fr}}
.inv-cell{
  background:var(--bg);padding:36px 32px;display:flex;flex-direction:column;gap:14px;
  position:relative;min-height:240px;transition:background .3s
}
.inv-cell:hover{background:var(--bg-2)}
.inv-cell .tag{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted)}
.inv-cell .claim{font-family:var(--serif);font-size:clamp(22px,1.8vw,28px);line-height:1.15;letter-spacing:-.015em;color:var(--ink);text-wrap:pretty;flex:1}
.inv-cell .claim em{font-style:italic;color:var(--accent)}
.inv-cell .foot{font-family:var(--mono);font-size:12px;color:var(--ink-soft);padding-top:14px;border-top:1px solid var(--line);display:flex;justify-content:space-between}
.inv-cell .foot span{color:var(--ink-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px}

/* ---------- ROI calculator ---------- */
.roi-section{background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}
.roi-stage{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;
  padding:56px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);
  position:relative;overflow:hidden
}
@media (max-width:980px){.roi-stage{grid-template-columns:1fr;padding:36px;gap:36px}}
.roi-stage::before{
  content:"";position:absolute;top:-50%;right:-30%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,228,124,.08),transparent 60%);
  pointer-events:none
}
.roi-controls h3{margin-bottom:8px}
.roi-controls p{color:var(--ink-soft);font-size:14px;margin-bottom:32px;max-width:420px}
.roi-knob{margin-bottom:28px}
.roi-knob .label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}
.roi-knob .label .k{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}
.roi-knob .label .v{font-family:var(--serif);font-size:24px;color:var(--accent);font-weight:400}
.roi-knob input[type="range"]{
  -webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:99px;
  background:rgba(255,255,255,.08);outline:none
}
.roi-knob input[type="range"]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--accent);cursor:pointer;
  box-shadow:0 0 0 4px rgba(0,228,124,.18);transition:.2s
}
.roi-knob input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.15)}
.roi-knob input[type="range"]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--accent);cursor:pointer;border:0}

.roi-result{position:relative;z-index:1}
.roi-result .label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:14px}
.roi-result .big{font-family:var(--serif);font-size:clamp(56px,6vw,96px);line-height:.95;letter-spacing:-.04em;color:var(--accent);font-feature-settings:"tnum";margin-bottom:8px}
.roi-result .big small{font-size:.4em;color:var(--ink-muted);font-family:var(--mono)}
.roi-result .sub{font-family:var(--serif);font-size:clamp(20px,1.8vw,26px);color:var(--ink);line-height:1.25;margin-bottom:32px;text-wrap:pretty}
.roi-result .sub em{font-style:italic;color:var(--accent)}
.roi-breakdown{border-top:1px solid var(--line);padding-top:24px;display:flex;flex-direction:column;gap:14px}
.roi-line{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:13px;color:var(--ink-soft)}
.roi-line .v{color:var(--ink);font-feature-settings:"tnum"}
.roi-line.gain .v{color:var(--accent)}
.roi-line.cost .v{color:var(--hot)}
.roi-line.subtotal{padding-top:12px;margin-top:2px;border-top:1px dashed var(--line);font-size:12px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em}
.roi-line.subtotal .v{color:var(--ink);font-size:14px;font-weight:600}
.roi-line.net{padding-top:14px;border-top:1px solid var(--line);font-size:14px;color:var(--ink);margin-top:4px}
.roi-line.net .v{font-size:18px;color:var(--accent);font-weight:600}

.roi-callouts{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px}
@media (max-width:760px){.roi-callouts{grid-template-columns:1fr}}
.roi-callout{padding:28px;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg)}
.roi-callout .n{font-family:var(--serif);font-size:48px;color:var(--accent);line-height:1;margin-bottom:12px;font-feature-settings:"tnum"}
.roi-callout p{font-size:14px;color:var(--ink-soft);line-height:1.4;text-wrap:pretty}
.roi-callout p b{color:var(--ink)}

/* ---------- modules ---------- */
.modules{display:grid;grid-template-columns:repeat(12,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.module{
  grid-column:span 4;background:var(--bg);padding:36px 32px;
  display:flex;flex-direction:column;gap:20px;min-height:280px;
  transition:background .3s, transform .3s;
  position:relative;overflow:hidden
}
.module.lg{grid-column:span 6}
@media (max-width:980px){.module,.module.lg{grid-column:span 6}}
@media (max-width:640px){.module,.module.lg{grid-column:span 12}}

/* module SUMMARY — visual diagram of the 4 pillars */
.module-summary{
  background:linear-gradient(180deg, rgba(0,228,124,.04), rgba(10,22,40,0));
  display:flex;flex-direction:column;
}
.ms-diagram{
  position:relative;flex:1;min-height:200px;margin:8px 0 14px;
  display:grid;place-items:center;
}
.ms-core{
  position:relative;z-index:2;
  width:128px;height:128px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, rgba(0,228,124,.22), rgba(0,228,124,.04) 70%);
  border:1px solid rgba(0,228,124,.45);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  box-shadow:0 0 24px rgba(0,228,124,.15), inset 0 0 18px rgba(0,228,124,.08);
}
.ms-core::before{
  content:"";position:absolute;inset:-10px;border-radius:50%;
  border:1px dashed rgba(0,228,124,.25);
  animation:msSpin 18s linear infinite;
}
@keyframes msSpin{to{transform:rotate(360deg)}}
.ms-core-k{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:5px}
.ms-core-v{font-family:var(--serif);font-size:13px;line-height:1.2;color:var(--ink);font-style:italic}
.ms-orbit{position:absolute;inset:0;pointer-events:none}
.ms-pill{
  position:absolute;font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  padding:5px 10px;border-radius:999px;color:var(--ink);
  background:rgba(17,32,58,.85);border:1px solid var(--line);
  white-space:nowrap;
  animation:msFloat 5s ease-in-out infinite;
}
.ms-pill::before{
  content:"";position:absolute;width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 8px rgba(0,228,124,.7);
  left:-3px;top:50%;transform:translateY(-50%);
}
.ms-pill.p1{top:8%;left:6%}
.ms-pill.p2{top:8%;right:6%;animation-delay:.6s}
.ms-pill.p3{bottom:8%;left:6%;animation-delay:1.2s}
.ms-pill.p4{bottom:8%;right:6%;animation-delay:1.8s}
@keyframes msFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.module:hover{background:var(--bg-2)}
.module:hover .mod-glow{opacity:1}
.mod-glow{position:absolute;inset:-1px;border-radius:inherit;opacity:0;transition:.4s;pointer-events:none;
  background:radial-gradient(ellipse at top right,rgba(0,228,124,.08),transparent 60%)}
.module .num{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--ink-muted);text-transform:uppercase}
.module h3{font-family:var(--serif);font-size:clamp(28px,2.4vw,38px);line-height:1.05;letter-spacing:-.02em}
.module h3 em{font-style:italic;color:var(--accent)}
.module .desc{font-size:14px;color:var(--ink-soft);line-height:1.45;flex:1}
.module .feat{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em;padding-top:18px;border-top:1px solid var(--line)}
.module .feat .ai{color:var(--accent)}

/* ---------- competitive radar / table ---------- */
.compete{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media (max-width:980px){.compete{grid-template-columns:1fr}}
.compete-claim h3{font-family:var(--serif);font-size:clamp(28px,2.6vw,42px);line-height:1.1;margin-bottom:24px}
.compete-claim h3 em{font-style:italic;color:var(--accent)}
.compete-claim p{color:var(--ink-soft);font-size:15px;line-height:1.5;margin-bottom:20px;max-width:480px}
.compete-bars{display:flex;flex-direction:column;gap:14px;border-top:1px solid var(--line);padding-top:8px}
.bar-row{display:grid;grid-template-columns:140px 1fr 56px;align-items:center;gap:16px;padding:10px 0;border-bottom:1px solid var(--line)}
.bar-row .name{font-size:13px;color:var(--ink-soft);font-weight:500}
.bar-row.us .name{color:var(--accent);font-weight:600;font-family:var(--serif);font-size:16px;font-style:italic}
.bar-track{height:8px;border-radius:99px;background:rgba(255,255,255,.05);overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:99px;background:var(--ink-muted);width:0;transition:width 1.4s cubic-bezier(.2,.9,.2,1) .2s}
.bar-row.us .bar-fill{background:linear-gradient(90deg,var(--accent-2),var(--accent))}
.bar-row .pct{font-family:var(--mono);font-size:12px;color:var(--ink-muted);text-align:right}
.bar-row.us .pct{color:var(--accent)}

/* ---------- ai band ---------- */
.ai-band{
  margin-top:80px;
  padding:48px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,rgba(0,228,124,.08),rgba(79,138,255,.06));
  border:1px solid rgba(0,228,124,.2);
  display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center
}
@media (max-width:880px){.ai-band{grid-template-columns:1fr}}
.ai-band .pill{padding:8px 14px;border-radius:99px;background:var(--accent);color:#001a0e;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;justify-self:start}
.ai-band h3{font-family:var(--serif);font-size:clamp(24px,2.2vw,34px);line-height:1.1;text-wrap:pretty}
.ai-band h3 em{font-style:italic;color:var(--accent)}

/* ---------- precios ---------- */
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:stretch}
@media (max-width:1080px){.pricing{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.pricing{grid-template-columns:1fr}}
.tier{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:32px 28px;display:flex;flex-direction:column;gap:18px;
  transition:.3s;position:relative
}
.tier:hover{transform:translateY(-4px);border-color:var(--line-2)}
.tier.popular{border-color:var(--accent);background:linear-gradient(180deg,var(--bg-2),var(--bg))}
.tier.popular::before{
  content:"Recomendado";position:absolute;top:-11px;left:24px;
  padding:4px 12px;border-radius:99px;background:var(--accent);color:#001a0e;
  font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;font-weight:600
}
.tier .name{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted)}
.tier .who{font-family:var(--serif);font-size:24px;line-height:1.1;color:var(--ink);text-wrap:pretty;min-height:54px}
.tier .who em{font-style:italic;color:var(--accent)}
.tier .price{display:flex;align-items:baseline;gap:6px;padding:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tier .price .num{font-family:var(--serif);font-size:42px;line-height:1;letter-spacing:-.03em;color:var(--ink)}
.tier .price .num.custom{font-size:28px;color:var(--accent)}
.tier .price .per{font-family:var(--mono);font-size:11px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em}
.tier .roi{font-family:var(--mono);font-size:11px;color:var(--accent);letter-spacing:.05em}
.tier .feats{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:8px;flex:1}
.tier .feats li{font-size:13px;color:var(--ink-soft);display:flex;gap:8px;align-items:flex-start;line-height:1.4}
.tier .feats li::before{content:"";width:14px;height:14px;background:var(--accent);clip-path:polygon(15% 50%,40% 75%,90% 20%,90% 35%,40% 90%,15% 65%);flex-shrink:0;margin-top:3px}
.tier .feats li.no{opacity:.4}
.tier .feats li.no::before{background:var(--ink-muted);clip-path:polygon(20% 0,100% 80%,80% 100%,0 20%)}
.tier .cta{width:100%;text-align:center;padding:14px;border-radius:99px;font-weight:600;font-size:14px;transition:.2s}
.tier .cta-primary{background:var(--accent);color:#001a0e}
.tier .cta-ghost{border:1px solid var(--line-2);color:var(--ink)}
.tier .cta-primary:hover,.tier .cta-ghost:hover{transform:translateY(-1px)}

/* ---------- comparison strip ---------- */
.savings{
  margin-top:48px;padding:36px 40px;border-radius:var(--radius-lg);
  background:linear-gradient(90deg,rgba(0,228,124,.05),transparent);
  border:1px solid rgba(0,228,124,.15);
  display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center
}
@media (max-width:760px){.savings{grid-template-columns:1fr}}
.savings .label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.savings .text{font-family:var(--serif);font-size:clamp(20px,2vw,28px);line-height:1.2;text-wrap:pretty}
.savings .text em{font-style:italic;color:var(--accent)}
.savings .num{font-family:var(--serif);font-size:clamp(40px,4vw,64px);color:var(--accent);line-height:1;letter-spacing:-.03em}

/* ---------- timeline ---------- */
.timeline{position:relative;padding-left:32px}
.timeline::before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:var(--line)}
.tl-fill{position:absolute;left:8px;top:8px;width:2px;background:linear-gradient(180deg,var(--accent),var(--accent-2));height:0;transition:height 1.6s ease}
.tl-section.in .tl-fill{height:calc(100% - 16px)}
.tl-row{display:grid;grid-template-columns:140px 1fr;gap:32px;padding:32px 0;border-bottom:1px solid var(--line);position:relative}
.tl-row::before{content:"";position:absolute;left:-32px;top:42px;width:18px;height:18px;border-radius:50%;background:var(--bg);border:2px solid var(--line);transition:.3s}
.tl-row.in::before{border-color:var(--accent);box-shadow:0 0 0 4px rgba(0,228,124,.18)}
.tl-row .when{font-family:var(--mono);font-size:13px;color:var(--ink-muted);letter-spacing:.05em}
.tl-row.in .when{color:var(--accent)}
.tl-row .what h4{font-family:var(--serif);font-size:clamp(22px,2vw,30px);line-height:1.15;font-weight:400;letter-spacing:-.02em;margin-bottom:8px}
.tl-row .what h4 em{font-style:italic;color:var(--accent)}
.tl-row .what p{color:var(--ink-soft);font-size:14px;line-height:1.45;max-width:540px}

/* ---------- DAFO grid ---------- */
.dafo{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
@media (max-width:760px){.dafo{grid-template-columns:1fr}}
.dafo-cell{padding:36px 32px;background:var(--bg);display:flex;flex-direction:column;gap:14px;min-height:280px}
.dafo-cell .tag{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.dafo-cell.s .tag{color:var(--accent)}
.dafo-cell.w .tag{color:var(--hot)}
.dafo-cell.o .tag{color:var(--blue)}
.dafo-cell.t .tag{color:var(--gold)}
.dafo-cell .claim{font-family:var(--serif);font-size:clamp(22px,1.9vw,28px);line-height:1.15;letter-spacing:-.015em;color:var(--ink);text-wrap:pretty}
.dafo-cell .claim em{font-style:italic}
.dafo-cell.s .claim em{color:var(--accent)}
.dafo-cell.w .claim em{color:var(--hot)}
.dafo-cell.o .claim em{color:var(--blue)}
.dafo-cell.t .claim em{color:var(--gold)}
.dafo-cell ul{list-style:none;display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:18px;border-top:1px solid var(--line)}
.dafo-cell li{font-size:13px;color:var(--ink-soft);display:flex;gap:8px}
.dafo-cell li::before{content:"·";color:currentColor;flex-shrink:0;font-weight:700}

/* ---------- final CTA ---------- */
.final{
  padding:120px 0 140px;text-align:center;
  background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(0,228,124,.1),transparent 70%)
}
.final h2{font-size:clamp(48px,8vw,128px);line-height:.95;letter-spacing:-.04em;max-width:1100px;margin:0 auto;text-wrap:balance}
.final h2 em{font-style:italic;color:var(--accent)}
.final p{font-size:18px;color:var(--ink-soft);margin:32px auto 40px;max-width:540px;text-wrap:pretty}
.final .cta-row{justify-content:center}

/* ---------- footer ---------- */
footer{padding:80px 0 32px;border-top:1px solid var(--line);font-size:13px;color:var(--ink-muted);background:var(--bg);position:relative;z-index:3}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:48px;align-items:flex-start;padding-bottom:56px;border-bottom:1px solid var(--line)}
.foot-mark{font-family:var(--serif);font-size:24px;color:var(--ink);letter-spacing:-.02em;margin-bottom:16px}
.foot-tag{font-size:14px;line-height:1.55;color:var(--ink-soft);margin-bottom:20px;max-width:340px}
.foot-meta{display:flex;flex-wrap:wrap;gap:8px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted)}
.foot-h{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:18px}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-col a{color:var(--ink-soft);font-size:14px;text-decoration:none;transition:color .2s}
.foot-col a:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;padding-top:32px}
.foot-badges{display:flex;flex-wrap:wrap;gap:6px}
.foot-badges span{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);padding:5px 10px;border:1px solid var(--line);border-radius:99px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}.foot-brand{grid-column:1/-1}.foot-bottom{flex-direction:column;align-items:flex-start}}

/* ---------- reveals ---------- */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s cubic-bezier(.2,.8,.2,1), transform 1s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal-stagger > *{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.2,.8,.2,1), transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal-stagger.in > *{opacity:1;transform:translateY(0)}
.reveal-stagger.in > *:nth-child(1){transition-delay:.05s}
.reveal-stagger.in > *:nth-child(2){transition-delay:.12s}
.reveal-stagger.in > *:nth-child(3){transition-delay:.19s}
.reveal-stagger.in > *:nth-child(4){transition-delay:.26s}
.reveal-stagger.in > *:nth-child(5){transition-delay:.33s}
.reveal-stagger.in > *:nth-child(6){transition-delay:.4s}
.reveal-stagger.in > *:nth-child(7){transition-delay:.47s}
.reveal-stagger.in > *:nth-child(8){transition-delay:.54s}

/* magnetic ball drift on scroll (uses CSS vars set by JS) */
.parallax{will-change:transform;transform:translate3d(0,calc(var(--py,0) * 1px),0)}

/* ---------- ball cursor ---------- */
@media (hover:hover) and (pointer:fine){
  .ball-cursor, .ball-cursor * { cursor:none !important }
  .ball-cursor a, .ball-cursor button, .ball-cursor input, .ball-cursor select, .ball-cursor textarea, .ball-cursor label{cursor:none !important}
}
.cursor-ball{
  position:fixed;top:0;left:0;
  width:36px;height:36px;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%) rotate(0deg);
  transition:width .2s cubic-bezier(.2,.9,.2,1), height .2s cubic-bezier(.2,.9,.2,1), opacity .2s;
  filter:
    drop-shadow(0 6px 14px rgba(0,0,0,.45))
    drop-shadow(0 2px 4px rgba(0,0,0,.35))
}
  transform:translate(-50%,-50%) rotate(0deg);
  transition:width .15s, height .15s, opacity .2s;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))
}
.cursor-ball svg{width:100%;height:100%;display:block}
.cursor-ball.hover{width:50px;height:50px}
/* nota: .spin animation eliminada — sobrescribía transform y mandaba el cursor a la esquina.
   La rotación se aplica desde JS basada en la velocidad del cursor (tick()). */
.cursor-trail{
  position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;
  background:rgba(0,228,124,.4);pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);transition:opacity .3s;
  filter:blur(2px)
}
@media (hover:none),(pointer:coarse){
  .cursor-ball,.cursor-trail{display:none}
  .ball-cursor,.ball-cursor *{cursor:auto !important}
}

/* inv grid: 4 cols on widescreen for new 4-cell layout */
.inv-grid{grid-template-columns:repeat(4,1fr) !important}
@media (max-width:1080px){.inv-grid{grid-template-columns:repeat(2,1fr) !important}}
@media (max-width:560px){.inv-grid{grid-template-columns:1fr !important}}

/* hero rank stripe */
.hero-rank{
  display:inline-flex;align-items:center;gap:14px;
  padding:8px 16px 8px 8px;border-radius:99px;
  background:rgba(255,255,255,.04);border:1px solid var(--line-2);
  margin-bottom:32px;
  animation:fadeUp .8s ease .3s forwards
}
.hero-rank .rank-num{
  display:inline-grid;place-items:center;
  width:30px;height:30px;border-radius:50%;
  background:var(--accent);color:#001a0e;
  font-family:var(--serif);font-size:15px;font-weight:600;font-style:italic;
  letter-spacing:-.02em
}
.hero-rank .rank-txt{font-size:13px;color:var(--ink-soft)}
.hero-rank .rank-txt b{color:var(--ink);font-weight:600}

/* ============================================================
   CONTACT — form-led funnel
   ============================================================ */
.contact{
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 50%,var(--bg) 100%);
  position:relative;overflow:hidden
}
.contact::before{
  content:"";position:absolute;top:10%;left:-20%;width:700px;height:700px;
  background:radial-gradient(circle,rgba(0,228,124,.12),transparent 60%);
  pointer-events:none;filter:blur(40px)
}
.contact::after{
  content:"";position:absolute;bottom:-10%;right:-20%;width:600px;height:600px;
  background:radial-gradient(circle,rgba(79,138,255,.08),transparent 60%);
  pointer-events:none;filter:blur(40px)
}
.contact .wrap{position:relative;z-index:1}

.contact-grid{
  display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:start;
}
@media (max-width:1080px){.contact-grid{grid-template-columns:1fr;gap:56px}}

.contact-left h2{margin:0 0 28px;text-wrap:balance}
.contact-left h2 em,.contact-left h2 .accent{font-style:italic}
.contact-lead{font-size:clamp(17px,1.3vw,20px);color:var(--ink-soft);line-height:1.5;max-width:480px;margin-bottom:48px;text-wrap:pretty}

.contact-steps{display:flex;flex-direction:column;gap:4px;margin-bottom:48px;border-left:1px solid var(--line);padding-left:0}
.cstep{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
  padding:18px 0 18px 24px;position:relative;
  border-bottom:1px solid var(--line)
}
.cstep:last-child{border-bottom:0}
.cstep::before{
  content:"";position:absolute;left:-5px;top:28px;width:9px;height:9px;border-radius:50%;
  background:var(--bg);border:2px solid var(--line);transition:.3s
}
.cstep:hover::before{border-color:var(--accent);box-shadow:0 0 0 4px rgba(0,228,124,.18)}
.cstep .n{
  font-family:var(--mono);font-size:11px;color:var(--ink-muted);letter-spacing:.1em;
  padding-top:4px;font-weight:500
}
.cstep b{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--ink);letter-spacing:-.01em;display:block;margin-bottom:4px}
.cstep p{font-size:13px;color:var(--ink-soft);line-height:1.4;margin:0}

.contact-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.trust-item{padding:20px 16px;background:var(--bg-2);text-align:center}
.trust-item .ti-num{font-family:var(--serif);font-size:32px;line-height:1;color:var(--accent);margin-bottom:6px;letter-spacing:-.02em}
.trust-item .ti-num small{font-size:.45em;color:var(--ink-muted);font-family:var(--mono);margin-left:2px}
.trust-item .ti-txt{font-size:11px;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.1em;font-family:var(--mono)}

/* form */
.form{
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius-lg);
  padding:40px;display:flex;flex-direction:column;gap:18px;
  position:relative;
  box-shadow:0 40px 80px -40px rgba(0,0,0,.5);
}
@media (max-width:640px){.form{padding:28px}}
.form-head{margin-bottom:8px}
.form-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 12px;border-radius:99px;
  background:rgba(0,228,124,.1);border:1px solid rgba(0,228,124,.25);
  font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  margin-bottom:14px
}
.form-tag .pulse{width:5px;height:5px;border-radius:50%;background:var(--accent);animation:pulse 1.6s infinite}
.form-head h3{font-size:clamp(26px,2.4vw,34px);line-height:1.1;letter-spacing:-.02em;margin:0}

.form-row{display:grid;gap:14px}
.form-row.two{grid-template-columns:1fr 1fr}
@media (max-width:520px){.form-row.two{grid-template-columns:1fr}}

.field{display:flex;flex-direction:column;gap:6px}
.field > span{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted)}
.field > span em{font-style:normal;text-transform:none;letter-spacing:0;color:var(--ink-muted);opacity:.7}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:15px;color:var(--ink);
  background:var(--bg);border:1px solid var(--line);
  padding:12px 14px;border-radius:10px;
  transition:.2s;outline:none;width:100%
}
.field textarea{resize:vertical;min-height:80px;font-family:var(--sans)}
.field select{
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%236B7A93' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:right 14px center;background-size:12px;padding-right:38px
}
.field input:focus,.field select:focus,.field textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,228,124,.15);background:var(--bg-2)
}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-muted);opacity:.6}

.radios{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}
.radios label{position:relative;cursor:pointer}
.radios input{position:absolute;opacity:0;pointer-events:none}
.radios span{
  display:inline-block;padding:8px 14px;border-radius:99px;
  border:1px solid var(--line);font-size:13px;color:var(--ink-soft);
  transition:.2s
}
.radios label:hover span{border-color:var(--line-2);color:var(--ink)}
.radios input:checked + span{
  background:var(--accent);color:#001a0e;border-color:var(--accent);font-weight:600
}
.radios-2col{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.radios-2col label{display:block}
.radios-2col span{display:block;padding:14px 16px;border-radius:12px;font-size:13px;line-height:1.4;text-align:left}
.radios-2col span b{display:block;color:var(--ink);font-weight:600;font-size:14px;margin-bottom:2px}
.radios-2col input:checked + span b{color:#001a0e}
.radio-wide{grid-column:1/-1}
@media (max-width:640px){.radios-2col{grid-template-columns:1fr}}

.check{display:flex;gap:10px;align-items:flex-start;font-size:12px;color:var(--ink-soft);line-height:1.45;cursor:pointer}
.check input{
  appearance:none;-webkit-appearance:none;
  width:16px;height:16px;border-radius:4px;border:1px solid var(--line-2);
  background:var(--bg);flex-shrink:0;margin-top:2px;cursor:pointer;position:relative;transition:.2s
}
.check input:checked{background:var(--accent);border-color:var(--accent)}
.check input:checked::after{
  content:"";position:absolute;left:4px;top:1px;width:5px;height:9px;
  border:solid #001a0e;border-width:0 2px 2px 0;transform:rotate(45deg)
}
.check a{color:var(--accent);text-decoration:underline}

.form-submit{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:18px 28px;border-radius:99px;
  background:var(--accent);color:#001a0e;font-weight:600;font-size:15px;
  cursor:pointer;transition:.2s;margin-top:8px;
  box-shadow:0 0 0 0 rgba(0,228,124,.6)
}
.form-submit:hover{transform:translateY(-2px);background:#33ed95;box-shadow:0 12px 32px -8px rgba(0,228,124,.5)}
.form-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}
.form-submit .arr{transition:transform .2s}
.form-submit:hover .arr{transform:translateX(4px)}

/* success state */
.form-success{
  display:none;position:absolute;inset:0;
  background:var(--bg-2);border-radius:var(--radius-lg);
  flex-direction:column;align-items:center;justify-content:center;text-align:center;
  padding:48px;gap:18px;
  animation:successIn .6s cubic-bezier(.2,.9,.2,1)
}
.form.sent .form-success{display:flex}
@keyframes successIn{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.success-icon{
  width:72px;height:72px;border-radius:50%;
  background:rgba(0,228,124,.15);border:2px solid var(--accent);
  color:var(--accent);
  display:grid;place-items:center
}
.success-icon svg{width:32px;height:32px}
.form-success h4{font-size:28px;line-height:1.15;font-weight:400;letter-spacing:-.02em;margin:0;text-wrap:balance}
.form-success p{color:var(--ink-soft);font-size:14px;max-width:380px;line-height:1.5;text-wrap:pretty}

/* counter mono helper */
[data-count]{font-feature-settings:"tnum"}

/* prevent horizontal overflow */
html,body{overflow-x:hidden;max-width:100vw}

/* ============================================================
   SPATIAL DESIGN — optimized
   ============================================================ */

/* HEATMAP CANVAS — cursor leaves heat trail, fades over time */
.heatmap{
  position:fixed;inset:0;
  width:100vw;height:100vh;
  z-index:1;
  pointer-events:none;
  mix-blend-mode:screen;
  opacity:.55
}
@media (hover:none),(pointer:coarse),(prefers-reduced-motion:reduce){.heatmap{display:none}}

/* keep content above grain/spotlight */
.nav,header,section,footer,.sticky-cta{position:relative;z-index:3}
.nav{z-index:50}
.sticky-cta{z-index:48}
/* cursor: must remain position:fixed (set in its own block above) */
.cursor-ball{z-index:9999 !important}
.cursor-trail{z-index:9998 !important}

/* ============================================================
   TYPOGRAPHY RIGGING — letters fall in with physics
   ============================================================ */
/* keep H1 visible if JS fails: only hide letters when rigging is applied */
.hero h1 .rig-letter{
  display:inline-block;
  opacity:1;
  will-change:transform,opacity
}
/* hidden state ONLY while rigging is staged AND not yet rigged */
.hero h1.rig-staged:not(.rigged) .rig-letter{
  opacity:0;
  transform:translate3d(var(--dx,0),20px,0) rotate(var(--rot,0));
  transition:transform .8s cubic-bezier(.2,.8,.2,1) var(--delay,0s),
             opacity .6s ease var(--delay,0s)
}
.hero h1.rigged .rig-letter{
  transform:translate3d(0,0,0) rotate(0deg);
  opacity:1
}
.hero h1 .rig-letter.wobble{
  animation:letterWobble .55s cubic-bezier(.36,.07,.19,.97);
}
@keyframes letterWobble{
  0%,100%{ transform:translate3d(0,0,0) rotate(0deg) scaleY(1) }
  20%{ transform:translate3d(0,-6px,0) rotate(-6deg) scaleY(1.08) }
  45%{ transform:translate3d(0,2px,0) rotate(4deg) scaleY(.95) }
  70%{ transform:translate3d(0,-2px,0) rotate(-2deg) scaleY(1.02) }
}

/* ============================================================
   AUDIO TOGGLE in nav (removed)
   ============================================================ */

/* Single shared hover-light pseudo — uses ::after to avoid clashing with ::before badges */
.module,.tier,.inv-cell,.roi-callout{position:relative;isolation:isolate}
.module::after,.tier::after,.inv-cell::after,.roi-callout::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(
    260px circle at var(--mx,50%) var(--my,50%),
    rgba(0,228,124,.10),
    transparent 50%
  );
  opacity:0;transition:opacity .25s;
  z-index:0
}
.module:hover::after,.tier:hover::after,.inv-cell:hover::after,.roi-callout:hover::after{opacity:1}
.module > *,.tier > *,.inv-cell > *,.roi-callout > *{position:relative;z-index:1}

/* mobile: skip hover effects entirely */
@media (hover:none),(pointer:coarse){
  .module::after,.tier::after,.inv-cell::after,.roi-callout::after{display:none}
}

/* HERO PROOF BADGE */
.hero-proof{
  display:inline-flex;align-items:center;gap:12px;
  padding:10px 16px 10px 14px;border-radius:999px;
  background:rgba(0,228,124,.06);border:1px solid rgba(0,228,124,.25);
  font-size:13px;line-height:1.4;color:var(--ink);
  margin-bottom:36px;max-width:640px;
}
.hero-proof .hp-dot{
  width:7px;height:7px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 12px rgba(0,228,124,.7);flex-shrink:0;
  animation:hpDot 2s ease-in-out infinite;
}
.hero-proof .hp-text b{color:var(--accent);font-weight:600}
@keyframes hpDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
@media (max-width:640px){.hero-proof{font-size:12px;padding:8px 14px 8px 12px;margin-bottom:24px}}

/* HERO MOCKUP — full product preview */
.hero-mock{
  position:absolute;
  right:-20px;bottom:-60px;
  width:320px;
  z-index:4;
  transform:rotate(-3deg);
  transition:transform .5s cubic-bezier(.2,.9,.2,1);
  display:none
}
@media (min-width:1180px){.hero-mock{display:block}}
.hero-mock:hover{transform:rotate(-3deg) translateY(-6px)}
.hero-mock-card{
  background:rgba(17,32,58,.85);
  border:1px solid rgba(255,255,255,.1);
  border-radius:18px;
  padding:18px;
  box-shadow:
    0 30px 60px -20px rgba(0,0,0,.6),
    0 0 0 1px rgba(255,255,255,.04)
}
.hero-mock-card h5{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:14px}
.hero-mock-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px}
.hero-mock-row:last-child{border-bottom:0}
.hero-mock-row .lbl{color:var(--ink-soft)}
.hero-mock-row .val{color:var(--accent);font-family:var(--mono);font-feature-settings:"tnum"}
.hero-mock-row .val.up::before{content:"↑ ";color:var(--accent)}

/* expanded mockup card internals */
.hmc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.hmc-tabs{display:flex;gap:4px}
.hmc-tab{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);padding:5px 10px;border-radius:6px}
.hmc-tab.active{color:var(--accent);background:rgba(0,228,124,.1)}
.hmc-pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent)}
.hmc-pill .pulse{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:hpDot 1.6s ease-in-out infinite}
.hmc-kpis{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.hmc-kpi{display:flex;flex-direction:column;gap:3px}
.hmc-k{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted)}
.hmc-v{font-family:var(--serif);font-size:24px;line-height:1;color:var(--ink);letter-spacing:-.02em}
.hmc-d{font-family:var(--mono);font-size:11px}
.hmc-d.up{color:var(--accent)}
.hmc-d.up::before{content:"↑ "}
.hmc-chart{height:60px;margin:6px 0 14px;border-radius:6px;overflow:hidden}
.hmc-chart svg{width:100%;height:100%}
.hmc-rows{display:flex;flex-direction:column}
.hmc-row{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:7px 0;border-top:1px solid var(--line);font-size:12px}
.hmc-row .rdot{width:6px;height:6px;border-radius:50%}
.hmc-row .rdot.ok{background:var(--accent);box-shadow:0 0 6px rgba(0,228,124,.6)}
.hmc-row .rdot.wait{background:#FFB347}
.hmc-row .rl{color:var(--ink-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hmc-row .rv{color:var(--ink);font-family:var(--mono);font-feature-settings:"tnum"}

.hero-mock-chip{
  position:absolute;left:-40px;bottom:-30px;
  background:rgba(10,22,40,.92);border:1px solid rgba(0,228,124,.3);
  border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:12px;
  box-shadow:0 16px 40px rgba(0,0,0,.45);
  animation:floatChip 5s ease-in-out infinite;
}
.hero-mock-chip .chip-ico{width:32px;height:32px;display:grid;place-items:center;border-radius:9px;background:rgba(0,228,124,.12);color:var(--accent)}
.hero-mock-chip .chip-ico svg{width:18px;height:18px}
.hero-mock-chip .chip-body{display:flex;flex-direction:column}
.hero-mock-chip .chip-k{font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}
.hero-mock-chip .chip-v{font-size:13px;color:var(--ink);line-height:1.3}
@keyframes floatChip{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}

/* hero z-stack */
.hero h1, .hero-sub, .hero .cta-row, .hero-meta{position:relative;z-index:5}

/* ============================================================
   MOBILE — comprehensive pass
   ============================================================ */
@media (max-width:760px){
  body{font-size:15px}
  .wrap{padding:0 20px}
  section{padding:80px 0}

  /* type scaling */
  h1{font-size:clamp(40px,11vw,56px);line-height:1}
  h2{font-size:clamp(30px,8vw,44px);line-height:1.02}
  .head{margin-bottom:48px}
  .head .lead{font-size:16px;margin-top:18px}

  /* hero */
  .hero{min-height:auto;padding:120px 0 64px}
  .hero-sub{font-size:16px;margin:24px 0 32px;line-height:1.5}
  .hero-meta{
    flex-direction:column;
    gap:0;margin-top:48px;padding-top:24px
  }
  .hero-meta > div{padding:18px 0;flex:none}
  .hero-meta > div + div{padding:18px 0;border-left:0;border-top:1px solid var(--line)}
  .hero-meta .v{font-size:18px}
  .cta-row{flex-direction:column;align-items:stretch;gap:10px}
  .cta-row .btn{justify-content:center;width:100%}

  /* eyebrow nudges */
  .eyebrow{margin-bottom:16px;font-size:10px}

  /* inv cells */
  .inv-cell{padding:28px 22px;min-height:auto;gap:12px}
  .inv-cell .claim{font-size:20px;line-height:1.2}

  /* roi */
  .roi-stage{padding:28px 22px;gap:32px}
  .roi-controls h3{font-size:22px}
  .roi-controls p{margin-bottom:24px}
  .roi-knob{margin-bottom:22px}
  .roi-knob .label .v{font-size:18px}
  .roi-result .big{font-size:64px}
  .roi-result .sub{font-size:17px}
  .roi-line{font-size:12px}
  .roi-callout{padding:22px}
  .roi-callout .n{font-size:38px}
  .roi-callouts{margin-top:32px}

  /* modules */
  .module,.module.lg{padding:28px 22px;min-height:auto;gap:14px}
  .module h3{font-size:24px}
  .module .desc{font-size:13px}

  /* compete */
  .compete{gap:24px}
  .compete-bars{gap:8px}
  .bar-row{grid-template-columns:96px 1fr 44px;gap:10px;padding:8px 0}
  .bar-row .name{font-size:12px}
  .bar-row.us .name{font-size:14px}
  .bar-row .pct{font-size:11px}

  /* ai band */
  .ai-band{padding:28px 22px;gap:18px;margin-top:48px}
  .ai-band h3{font-size:20px}

  /* precios */
  .tier{padding:26px 22px;gap:14px}
  .tier .who{font-size:20px;min-height:auto}
  .tier .price .num{font-size:36px}

  /* savings strip */
  .savings{padding:24px 22px;gap:14px;text-align:left;margin-top:32px}
  .savings .num{font-size:42px;justify-self:flex-start}
  .savings .text{font-size:18px}

  /* contact */
  .contact-grid{gap:40px}
  .contact-left h2{margin-bottom:18px}
  .contact-lead{font-size:16px;margin-bottom:32px}
  .contact-steps{margin-bottom:32px}
  .cstep{grid-template-columns:auto 1fr;gap:14px;padding:14px 0 14px 18px}
  .cstep::before{top:22px}
  .cstep b{font-size:16px}
  .cstep p{font-size:12px}
  .contact-trust .ti-num{font-size:26px}
  .contact-trust .ti-txt{font-size:10px}

  /* form */
  .form{padding:24px 20px;gap:14px;border-radius:18px}
  .form-head h3{font-size:24px}
  .form-tag{font-size:9px;padding:5px 10px;margin-bottom:10px}
  .field input,.field select,.field textarea{font-size:16px;padding:12px 12px} /* 16px prevents iOS zoom */
  .radios span{padding:7px 12px;font-size:12px}
  .form-submit{padding:16px 20px;font-size:14px}
  .check{font-size:11px}

  /* nav primary CTA tightens */
  .nav-primary{padding:9px 14px;font-size:12px}
  .nav-primary .arr{display:none}
  .brand span:last-child{display:none} /* logo only on mobile */

  /* footer */
  .footer-grid{grid-template-columns:1fr;gap:32px;padding-bottom:32px}
  .foot-tag{max-width:none}

  /* final CTA section */
  .final{padding:80px 0 100px}
}

/* extra-small phones */
@media (max-width:400px){
  .wrap{padding:0 16px}
  h1{font-size:36px}
  .hero{padding:110px 0 56px}
  .nav{top:8px;left:8px;right:8px}
  .form{padding:20px 16px}
  .roi-stage{padding:24px 18px}
  .module,.module.lg,.tier,.inv-cell{padding:22px 18px}
  .roi-result .big{font-size:48px}
  .roi-result .sub{font-size:15px}
}

/* sticky CTA: stacked on mobile */
@media (max-width:540px){
  .sticky-cta{
    left:8px;right:8px;bottom:8px;
    transform:translate(0,200%);
    width:auto;max-width:none;
    border-radius:99px
  }
  .sticky-cta.show{transform:translate(0,0)}
  .sticky-inner{padding:6px 6px 6px 16px;gap:8px;justify-content:space-between}
  .sticky-text{display:none}
  .sticky-actions{flex:1;justify-content:space-between;width:100%;gap:6px}
  .btn-mini{padding:10px 14px;font-size:12px;flex:1;justify-content:center;white-space:nowrap}
}

/* tablet portrait tweaks */
@media (min-width:761px) and (max-width:1080px){
  .hero h1{font-size:clamp(56px,8vw,84px)}
  .roi-stage{padding:40px}
  .pricing{grid-template-columns:repeat(2,1fr);gap:14px}
}

/* ============================================================
   IMPLEMENTACIÓN — 3-phase timeline
   ============================================================ */
#implementacion .timeline{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  margin-top:56px;position:relative;
}
#implementacion .timeline::before{
  content:"";position:absolute;top:54px;left:5%;right:5%;height:1px;
  background:linear-gradient(90deg,transparent,var(--line) 12%,var(--line) 88%,transparent);
  z-index:0;
}
@media (max-width:880px){
  #implementacion .timeline{grid-template-columns:1fr;gap:14px}
  #implementacion .timeline::before{display:none}
}
.phase{
  position:relative;background:var(--bg-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:28px 26px 26px;
  transition:transform .35s ease,border-color .35s ease,background .35s ease;
}
.phase::before{
  content:"";position:absolute;top:46px;left:50%;width:16px;height:16px;
  border-radius:50%;background:var(--bg);border:1px solid var(--accent);
  transform:translateX(-50%);box-shadow:0 0 0 4px var(--bg-2);
}
.phase::after{
  content:"";position:absolute;top:50px;left:50%;width:8px;height:8px;
  border-radius:50%;background:var(--accent);
  transform:translate(-50%,0);box-shadow:0 0 12px rgba(0,228,124,.6);
}
@media (max-width:880px){.phase::before,.phase::after{display:none}}
.phase:hover{border-color:rgba(0,228,124,.35);transform:translateY(-2px);background:#0E1A2D}
.phase-head{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:48px;font-family:var(--mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;
}
.phase-head .day{color:var(--accent)}
.phase-head .phase-num{color:var(--ink-muted)}
.phase h3{
  font-family:var(--serif);font-weight:400;font-size:clamp(22px,1.8vw,28px);
  line-height:1.15;margin:0 0 12px;letter-spacing:-.01em;
}
.phase h3 em{font-style:italic;color:var(--accent)}
.phase p{
  color:var(--ink-soft);line-height:1.55;font-size:14.5px;
  margin:0 0 16px;text-wrap:pretty;
}
.phase-list{
  list-style:none;padding:0;margin:0;
  border-top:1px solid var(--line);padding-top:14px;
}
.phase-list li{
  font-size:13px;color:var(--ink);font-family:var(--mono);
  padding:5px 0 5px 18px;position:relative;
}
.phase-list li::before{
  content:"";position:absolute;left:0;top:11px;width:8px;height:1px;
  background:var(--accent);
}

/* ============================================================
   SEGURIDAD — 3-card grid + propiedad band
   ============================================================ */
.security-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
  margin-top:48px;
}
@media (max-width:980px){.security-grid{grid-template-columns:1fr;gap:14px}}
.sec-card{
  background:var(--bg);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:32px 28px 28px;
  position:relative;transition:transform .35s ease,border-color .35s ease,background .35s ease;
  overflow:hidden;
}
.sec-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(180px circle at var(--mx,50%) var(--my,50%),rgba(0,228,124,.06),transparent 60%);
  opacity:0;transition:opacity .3s ease;
}
.sec-card:hover{border-color:rgba(0,228,124,.3);transform:translateY(-2px);background:#0C1B30}
.sec-card:hover::after{opacity:1}
.sec-icon{
  width:52px;height:52px;display:grid;place-items:center;
  border:1px solid var(--line);border-radius:14px;color:var(--accent);
  margin-bottom:22px;background:rgba(0,228,124,.04);
}
.sec-icon svg{width:26px;height:26px}
.sec-card h3{
  font-family:var(--serif);font-weight:400;font-size:clamp(22px,1.8vw,28px);
  letter-spacing:-.01em;margin:0 0 12px;line-height:1.15;
}
.sec-card p{
  color:var(--ink-soft);line-height:1.55;font-size:14.5px;
  margin:0 0 18px;text-wrap:pretty;
}
.sec-card p em{font-style:italic;color:var(--accent)}
.sec-foot{
  border-top:1px solid var(--line);padding-top:14px;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-muted);
}
.security-band{
  margin-top:40px;padding:32px 40px;
  border:1px solid var(--line);border-radius:var(--radius-lg);
  background:linear-gradient(90deg,rgba(79,138,255,.05),transparent);
  display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;
}
@media (max-width:760px){.security-band{grid-template-columns:1fr;padding:24px 22px}}
.security-band .label{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--accent-blue,#4F8AFF);display:block;margin-bottom:10px;
}
.security-band p{
  font-family:var(--serif);font-size:clamp(18px,1.6vw,22px);line-height:1.35;
  color:var(--ink);margin:0;text-wrap:pretty;
}
.security-band p em{font-style:italic;color:var(--accent)}
.security-stamp{
  font-family:var(--serif);font-size:clamp(28px,3vw,42px);
  color:var(--accent);line-height:1;letter-spacing:-.02em;white-space:nowrap;
}

/* ============================================================
   FAQ — accordion
   ============================================================ */
.faq-list{
  margin-top:48px;max-width:920px;margin-left:auto;margin-right:auto;
  border-top:1px solid var(--line);
}
.faq-item{
  border-bottom:1px solid var(--line);
  transition:background .25s ease;
}
.faq-item[open]{background:rgba(0,228,124,.025)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:24px 6px;
  display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;
  transition:color .25s ease;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover .q-text{color:var(--accent)}
.q-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  color:var(--ink-muted);min-width:24px;
}
.q-text{
  font-family:var(--serif);font-size:clamp(18px,1.5vw,22px);
  font-weight:400;line-height:1.35;color:var(--ink);
  letter-spacing:-.005em;transition:color .25s ease;text-wrap:balance;
}
.q-toggle{
  width:24px;height:24px;position:relative;flex-shrink:0;
}
.q-toggle::before,.q-toggle::after{
  content:"";position:absolute;background:var(--ink);top:50%;left:50%;
  transition:transform .3s ease,background .25s ease;
}
.q-toggle::before{width:14px;height:1px;transform:translate(-50%,-50%)}
.q-toggle::after{width:1px;height:14px;transform:translate(-50%,-50%)}
.faq-item[open] .q-toggle::before{background:var(--accent)}
.faq-item[open] .q-toggle::after{transform:translate(-50%,-50%) scaleY(0);background:var(--accent)}
.faq-body{
  padding:0 6px 28px 54px;animation:faqOpen .35s ease both;
}
.faq-body p{
  color:var(--ink-soft);line-height:1.6;font-size:15px;
  margin:0;text-wrap:pretty;max-width:680px;
}
.faq-body p em{font-style:italic;color:var(--accent)}
@keyframes faqOpen{
  from{opacity:0;transform:translateY(-4px)}
  to{opacity:1;transform:translateY(0)}
}
@media (max-width:640px){
  .faq-item summary{grid-template-columns:1fr auto;gap:14px;padding:20px 4px}
  .q-num{display:none}
  .faq-body{padding:0 4px 22px 0}
}

/* ---------- seven-axes (competence map) ---------- */
.seven-axes{
  list-style:none;padding:0;margin:24px 0 18px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:8px 14px;
  border-top:1px solid var(--line);padding-top:18px
}
.seven-axes li{
  display:flex;align-items:baseline;gap:10px;
  font-size:13px;color:var(--ink-soft);line-height:1.4
}
.seven-axes .ax-n{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;
  color:var(--accent);font-weight:600;flex-shrink:0
}
.compete-source{
  margin-top:18px;color:var(--ink-muted);font-size:12px;line-height:1.5;
  font-family:var(--mono);max-width:520px
}
@media (max-width:680px){.seven-axes{grid-template-columns:1fr}}

/* ---------- revenue-share card (post-pricing) ---------- */
.rev-share{margin-top:48px}
.rs-card{
  position:relative;overflow:hidden;
  padding:48px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg,rgba(0,228,124,.08),rgba(0,228,124,.02));
  border:1px solid rgba(0,228,124,.22);
  display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center
}
.rs-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 90% 30%,rgba(0,228,124,.18),transparent 55%);
  pointer-events:none
}
.rs-left{position:relative;z-index:1}
.rs-label{
  display:inline-block;font-family:var(--mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  margin-bottom:16px
}
.rs-left h3{
  font-family:var(--serif);font-size:clamp(28px,3vw,40px);
  line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin-bottom:18px;
  text-wrap:balance
}
.rs-left h3 em{font-style:italic;color:var(--accent)}
.rs-left p{
  color:var(--ink-soft);font-size:15px;line-height:1.6;
  max-width:560px;margin-bottom:24px
}
.rs-right{position:relative;z-index:1;text-align:right}
.rs-num{
  font-family:var(--serif);font-size:clamp(72px,9vw,128px);
  line-height:.9;letter-spacing:-.04em;color:var(--accent)
}
.rs-num-sub{
  font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-muted);margin-top:8px
}
@media (max-width:760px){
  .rs-card{grid-template-columns:1fr;gap:24px;padding:32px 24px}
  .rs-right{text-align:left}
}

/* hide deprecated sticky cta if any html still references it */
.sticky-cta{display:none !important}

/* ============================================
   MARKETING UPGRADES — added 2026-04-27
   ============================================ */

/* hero trust strip */
.hero-trust{
  display:flex;flex-wrap:wrap;align-items:center;gap:14px;
  margin-top:28px;padding-top:24px;
  border-top:1px solid var(--line);
  font-size:13px;color:var(--ink-muted);
  letter-spacing:.01em;
}
.hero-trust .ht-item{display:inline-flex;align-items:center;gap:8px}
.hero-trust .ht-item small{opacity:.7;font-weight:400}
.hero-trust .ht-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(0,228,124,.12);
}
.hero-trust .ht-sep{opacity:.4}
@media (max-width:760px){
  .hero-trust{font-size:12px;gap:10px}
  .hero-trust .ht-sep{display:none}
}

/* coste de no hacer nada */
.cost-inaction{background:linear-gradient(180deg, var(--bg) 0%, rgba(255,80,80,0.04) 100%)}
.cost-grid{
  display:grid;grid-template-columns:repeat(4, 1fr);
  gap:20px;margin-top:48px;
}
.cost-cell{
  position:relative;padding:32px 24px;
  background:var(--bg-2);border:1px solid var(--line);
  border-radius:16px;
  transition:transform .3s ease, border-color .3s ease;
}
.cost-cell:hover{transform:translateY(-4px);border-color:rgba(255,80,80,.4)}
.cost-cell .cost-num{
  font-family:var(--serif);font-size:42px;line-height:1;
  color:#ff6b6b;letter-spacing:-.02em;font-weight:500;
  margin-bottom:12px;
}
.cost-cell .cost-tag{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink);font-weight:600;margin-bottom:14px;
  padding-bottom:14px;border-bottom:1px solid var(--line);
}
.cost-cell p{font-size:14px;color:var(--ink-muted);line-height:1.55;margin:0}

.cost-total{
  display:grid;grid-template-columns:1fr auto;align-items:center;
  gap:32px;margin-top:48px;padding:40px 48px;
  background:linear-gradient(135deg, rgba(255,80,80,.08), rgba(255,80,80,.02));
  border:1px solid rgba(255,80,80,.25);border-radius:20px;
}
.cost-total .ct-label{
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink-muted);font-weight:600;
}
.cost-total .ct-num{
  font-family:var(--serif);font-size:72px;line-height:1;
  color:#ff5050;letter-spacing:-.03em;font-weight:500;
  margin:8px 0 16px;
}
.cost-total .ct-note{font-size:14px;color:var(--ink-muted);max-width:560px;margin:0;line-height:1.5}
.cost-total .ct-note em{color:var(--ink);font-style:italic;font-family:var(--serif)}
.cost-total .ct-cta{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 28px;border-radius:999px;
  background:var(--ink);color:var(--bg);
  font-weight:600;font-size:14px;text-decoration:none;
  white-space:nowrap;transition:transform .2s ease;
}
.cost-total .ct-cta:hover{transform:translateX(4px)}
.cost-total .ct-cta .arr{font-family:var(--serif)}
@media (max-width:980px){
  .cost-grid{grid-template-columns:repeat(2,1fr)}
  .cost-total{grid-template-columns:1fr;padding:32px 24px}
  .cost-total .ct-num{font-size:56px}
}
@media (max-width:540px){
  .cost-grid{grid-template-columns:1fr}
}

/* prueba social */
.social-proof .sp-eyebrow{
  display:inline-block;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);font-weight:600;
  margin-bottom:16px;
}
.logo-strip{
  display:grid;grid-template-columns:repeat(6,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  border-radius:16px;overflow:hidden;margin-top:48px;
}
.logo-cell{
  background:var(--bg-2);padding:28px 20px;
  display:flex;flex-direction:column;align-items:center;
  gap:12px;text-align:center;
  transition:background .25s ease;
}
.logo-cell:hover{background:var(--bg)}
.logo-mark{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg, var(--accent), rgba(0,228,124,.4));
  color:#0a1628;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;font-size:18px;
  letter-spacing:.02em;
}
.logo-name{font-size:11px;color:var(--ink-muted);line-height:1.4;letter-spacing:.04em}

.testimony{
  margin-top:64px;padding:48px;
  background:var(--bg);border:1px solid var(--line);border-radius:20px;
  display:grid;grid-template-columns:2fr 1fr;gap:48px;align-items:center;
}
.testimony blockquote{margin:0;padding:0;border:none}
.testimony blockquote p{
  font-family:var(--serif);font-size:24px;line-height:1.45;
  color:var(--ink);font-style:italic;margin:0 0 24px;
  letter-spacing:-.005em;
}
.testimony blockquote footer{
  display:flex;align-items:center;gap:16px;
  font-size:13px;color:var(--ink-muted);
}
.t-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg, #2a3a55, #0d1822);
  color:var(--ink);font-family:var(--serif);font-size:14px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);font-weight:500;
}
.t-meta b{color:var(--ink);font-weight:600;display:block;margin-bottom:4px}
.t-meta span{font-size:11px;letter-spacing:.02em;line-height:1.4;display:block;max-width:340px}

.t-stats{
  display:flex;flex-direction:column;gap:20px;
  padding-left:48px;border-left:1px solid var(--line);
}
.t-stats > div{display:flex;flex-direction:column;gap:4px}
.t-stats b{
  font-family:var(--serif);font-size:32px;line-height:1;
  color:var(--accent);font-weight:500;letter-spacing:-.02em;
}
.t-stats span{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-muted)}

@media (max-width:980px){
  .logo-strip{grid-template-columns:repeat(3,1fr)}
  .testimony{grid-template-columns:1fr;padding:32px 24px;gap:32px}
  .testimony blockquote p{font-size:20px}
  .t-stats{flex-direction:row;flex-wrap:wrap;padding-left:0;padding-top:24px;border-left:none;border-top:1px solid var(--line);gap:24px}
}
@media (max-width:540px){
  .logo-strip{grid-template-columns:repeat(2,1fr)}
}

/* popular badge en pricing */
.tier .popular-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg, var(--accent), #00c46a);
  color:#0a1628;font-size:11px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:6px 16px;border-radius:999px;white-space:nowrap;
  box-shadow:0 4px 16px rgba(0,228,124,.3);
  z-index:2;
}
.tier.popular{position:relative}

/* floating CTA — canal humano */
.float-cta{
  position:fixed;bottom:24px;right:24px;
  display:flex;align-items:center;gap:14px;
  padding:14px 22px 14px 16px;
  background:var(--ink);color:var(--bg);
  border-radius:999px;text-decoration:none;
  box-shadow:0 12px 36px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.06);
  z-index:90;
  transition:transform .25s ease, box-shadow .25s ease;
  opacity:0;transform:translateY(20px);pointer-events:none;
}
.float-cta.show{opacity:1;transform:translateY(0);pointer-events:auto}
.float-cta:hover{transform:translateY(-4px);box-shadow:0 18px 44px rgba(0,0,0,.5), 0 0 0 1px var(--accent)}
.float-cta .fc-icon{
  width:36px;height:36px;border-radius:50%;
  background:var(--accent);color:#0a1628;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.float-cta .fc-icon svg{width:18px;height:18px}
.float-cta .fc-text{display:flex;flex-direction:column;line-height:1.2}
.float-cta .fc-text b{font-size:13px;font-weight:600}
.float-cta .fc-text small{font-size:11px;opacity:.6;letter-spacing:.03em}
@media (max-width:540px){
  .float-cta{bottom:16px;right:16px;padding:12px 16px 12px 12px}
  .float-cta .fc-text small{display:none}
  .float-cta .fc-text b{font-size:12px}
}

/* ============================================
   SECTION-CTAs (closing each selling moment)
   ============================================ */
.section-cta{
  margin-top:64px;
  display:grid;grid-template-columns:1fr auto;gap:48px;
  align-items:center;
  padding:36px 48px;
  background:linear-gradient(135deg, rgba(0,228,124,.08), rgba(0,228,124,.02));
  border:1px solid rgba(0,228,124,.25);
  border-radius:20px;
  position:relative;overflow:hidden;
}
.section-cta::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(600px circle at var(--mx,80%) var(--my,50%), rgba(0,228,124,.06), transparent 60%);
  pointer-events:none;
}
.section-cta.sc-light{
  background:linear-gradient(135deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border-color:rgba(255,255,255,.12);
}
.sc-text .sc-eyebrow{
  display:inline-block;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:10px;
}
.section-cta.sc-light .sc-eyebrow{color:rgba(255,255,255,.55)}
.sc-text h3{
  font-family:var(--serif);font-size:32px;line-height:1.15;
  color:var(--ink);margin:0 0 10px;letter-spacing:-.01em;font-weight:500;
}
.sc-text h3 em{font-style:italic;color:var(--accent)}
.section-cta.sc-light h3 em{color:#fff}
.sc-text p{font-size:15px;color:var(--ink-muted);margin:0;max-width:560px;line-height:1.55}

.sc-btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 28px;border-radius:999px;
  background:var(--accent);color:#0a1628;
  font-weight:700;font-size:14px;text-decoration:none;
  white-space:nowrap;letter-spacing:.01em;
  transition:transform .25s ease, box-shadow .25s ease;
  box-shadow:0 8px 24px rgba(0,228,124,.25);
}
.sc-btn:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,228,124,.4)}
.sc-btn .arr{font-family:var(--serif);font-size:18px;font-weight:400}
.section-cta.sc-light .sc-btn{background:#fff;color:#0a1628;box-shadow:0 8px 24px rgba(0,0,0,.3)}

@media (max-width:760px){
  .section-cta{grid-template-columns:1fr;gap:24px;padding:28px 24px}
  .sc-text h3{font-size:24px}
  .sc-btn{justify-content:center;padding:16px 24px}
}

/* form pulse on CTA prefill */
@keyframes pulseOnce{
  0%{box-shadow:0 0 0 0 rgba(0,228,124,.55)}
  100%{box-shadow:0 0 0 18px rgba(0,228,124,0)}
}
.form-head.pulse-once{
  animation:pulseOnce .9s ease-out;
  border-radius:8px;
}

/* coste-inacción · cluster de CTAs (primario al form + secundario al simulador) */
.ct-actions{display:flex;flex-direction:column;gap:14px;align-items:flex-end}
.ct-cta.ct-cta-primary{
  background:var(--accent);color:#0a1628;
  box-shadow:0 8px 24px rgba(0,228,124,.3);
}
.ct-cta.ct-cta-primary:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(0,228,124,.45)}
.ct-cta-link{
  font-size:13px;color:rgba(255,255,255,.55);text-decoration:none;
  letter-spacing:.02em;
  transition:color .25s ease;
}
.ct-cta-link:hover{color:var(--accent)}
@media (max-width:980px){
  .ct-actions{align-items:stretch}
  .ct-cta-link{text-align:center}
}

/* ============================================
   POST-DECLUTTER (home minimalista)
   ============================================ */

/* ROI microstrip — sustituye los 3 callouts grandes */
.roi-microstrip {
  display:flex; flex-wrap:wrap; gap:16px; align-items:center; justify-content:center;
  margin-top:48px; padding:20px 24px;
  background:var(--bg-2); border:1px solid var(--line); border-radius:14px;
  font-size:14px; color:var(--ink-muted); letter-spacing:.01em;
}
.roi-microstrip b { color:var(--accent); font-weight:700; font-family:var(--serif); font-size:18px; font-style:italic; margin-right:4px; }
.roi-microstrip .rms-sep { opacity:.4; }
@media (max-width:600px){
  .roi-microstrip{flex-direction:column;align-items:flex-start;gap:8px}
  .roi-microstrip .rms-sep{display:none}
}

/* Platform strip — resumen compacto de los 4 pilares + 3 agentes */
#plataforma { padding: 96px 0; }
.platform-strip {
  display:grid; grid-template-columns:1fr 1fr; gap:24px;
  margin-top:48px;
}
.ps-col {
  background:var(--bg-2); border:1px solid var(--line); border-radius:18px;
  padding:32px;
}
.ps-tag {
  display:inline-block; font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); font-weight:700; margin-bottom:18px;
  padding:5px 12px; border-radius:999px; background:rgba(0,228,124,.1); border:1px solid rgba(0,228,124,.25);
}
.ps-list { list-style:none; padding:0; margin:0; }
.ps-list li {
  font-size:14px; line-height:1.55; color:var(--ink); padding:10px 0;
  border-bottom:1px solid var(--line);
}
.ps-list li:last-child { border-bottom:0; }
.ps-list li b { font-weight:600; color:var(--ink); }

.platform-trust {
  display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:14px;
  margin-top:32px; padding-top:24px;
  border-top:1px solid var(--line);
  font-size:13px; color:var(--ink-muted);
}
.platform-trust .pt-item b { color:var(--ink); font-weight:600; }
.platform-trust .pt-sep { opacity:.4; }

.platform-cta { margin-top:32px; text-align:center; }

@media (max-width:760px){
  .platform-strip { grid-template-columns:1fr; gap:16px; }
  .ps-col { padding:24px; }
  .platform-trust { gap:10px; font-size:12px; }
  .platform-trust .pt-sep{display:none}
}

/* Pricing-more link */
.pricing-more {
  text-align:center; margin-top:36px; font-size:14px; color:var(--ink-muted);
}
.pricing-more a { color:var(--accent); font-weight:600; text-decoration:none; }
.pricing-more a:hover { text-decoration:underline; }

/* Cost-grid simplified — sin párrafo descriptivo */
.cost-grid .cost-cell p { display:none; }
.cost-grid .cost-cell { padding:24px 22px; }

/* Quitar background especial de coste-inaccion ya que ahora es la sección de problema */
#problema.cost-inaction { background: var(--bg); }
