/* ═══════════════════════════════════════════════════════════
   Sannarse atleta · v4
   Cabinet Grotesk + Switzer (Fontshare) · cyan Sannarse
   Editorial · less cards · "todo incluido" hero message
   ═══════════════════════════════════════════════════════════ */

:root{
  --bg:#0B0B0F;
  --bg-2:#101015;
  --bg-3:#16161D;
  --surface:#1A1A22;
  --surface-2:#22222E;
  --line:rgba(255,255,255,0.07);
  --line-strong:rgba(255,255,255,0.14);

  --text:#F5F5F4;
  --text-2:#A3A3AD;
  --text-3:#65656F;

  --accent:#00D4E5;          /* cyan eléctrico Sannarse */
  --accent-2:#00B5C5;
  --accent-glow:rgba(0,212,229,0.22);
  --accent-faint:rgba(0,212,229,0.06);
  --accent-warm:#FF6B35;      /* naranja maratón · usar con cuidado */

  --display:'Cabinet Grotesk','Inter Tight',-apple-system,sans-serif;
  --sans:'Switzer','Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --serif:'PP Editorial New','Times New Roman',serif;

  --hd-1:clamp(2.8rem,7.5vw,7rem);
  --hd-2:clamp(2.2rem,5vw,4.4rem);
  --hd-xl:clamp(3rem,8vw,7rem);
  --body:clamp(1rem,1.4vw,1.125rem);

  --container:min(94vw,1280px);
  --section-pad:clamp(5rem,10vw,9rem);

  --t-fast:0.2s cubic-bezier(.4,0,.2,1);
  --t-base:0.4s cubic-bezier(.4,0,.2,1);
  --t-slow:0.85s cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);font-size:var(--body);line-height:1.55;
  background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  font-feature-settings:'ss01','cv11';
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:var(--bg)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
}

.cursor,.cursor-dot{
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:9999;
  border-radius:50%;
  transform:translate(-50%,-50%);
  mix-blend-mode:difference;
  transition:transform 0.15s cubic-bezier(.4,0,.2,1);
}
.cursor{width:36px;height:36px;border:1.5px solid var(--accent);transition-duration:0.4s}
.cursor-dot{width:6px;height:6px;background:var(--accent)}
.cursor.hover{transform:translate(-50%,-50%) scale(1.8);background:var(--accent);opacity:0.25}
@media (max-width:900px){.cursor,.cursor-dot{display:none}}

.container{width:var(--container);margin:0 auto}
section{padding:var(--section-pad) 0;position:relative}
em{font-style:italic;font-family:var(--display);font-weight:500}

/* ─────────── Section heads ─── */
.section-head{margin-bottom:clamp(3rem,7vw,5.5rem);max-width:920px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

.section-tag{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-family:var(--sans);
  font-size:0.78rem;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--text-3);
  padding:0.5rem 1rem;
  border:1px solid var(--line);
  border-radius:99px;
  margin-bottom:1.5rem;
  background:rgba(255,255,255,0.02);
  backdrop-filter:blur(10px);
}
.tag-dot{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 12px var(--accent);
  animation:dot-pulse 2s ease-in-out infinite;
}
@keyframes dot-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.7)}}

.section-title{
  font-family:var(--display);
  font-size:var(--hd-2);font-weight:700;
  line-height:1.02;letter-spacing:-0.025em;
  color:var(--text);
}
.section-title em{
  font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--accent);
  letter-spacing:-0.03em;
}
.section-lead{
  margin-top:1.25rem;font-size:clamp(1.05rem,1.6vw,1.25rem);
  color:var(--text-2);max-width:62ch;line-height:1.5;
  font-weight:400;
}
.section-head.center .section-lead{margin-left:auto;margin-right:auto}

/* ─────────── Buttons ─── */
.btn{
  display:inline-flex;align-items:center;gap:0.65rem;
  padding:0.95rem 1.6rem;
  font-family:var(--sans);
  font-size:0.95rem;font-weight:600;
  border-radius:99px;
  transition:all var(--t-base);
  position:relative;white-space:nowrap;
  letter-spacing:-0.005em;
}
.btn-primary{
  background:var(--accent);color:var(--bg);font-weight:700;
  box-shadow:0 1px 0 rgba(255,255,255,0.2) inset;
}
.btn-primary:hover{
  background:#22DEEE;
  transform:translateY(-2px);
  box-shadow:0 16px 48px var(--accent-glow);
}
.btn-primary svg{transition:transform var(--t-base)}
.btn-primary:hover svg{transform:translateX(5px)}
.btn-ghost{
  border:1.5px solid var(--line-strong);color:var(--text);
  background:rgba(255,255,255,0.02);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{
  border-color:var(--accent);color:var(--accent);
  transform:translateY(-2px);
}
.btn-lg{padding:1.1rem 1.9rem;font-size:1rem}
.btn-xl{padding:1.4rem 2.5rem;font-size:1.15rem;font-weight:700}

.reveal,.reveal-line{
  opacity:0;transform:translateY(28px);
  transition:opacity var(--t-slow),transform var(--t-slow);
}
.reveal-line{transform:translateY(40px)}
.reveal.is-visible,.reveal-line.is-visible{
  opacity:1;transform:translateY(0);
}

/* ─────────── Nav ─── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.25rem 0;
  background:rgba(11,11,15,0.4);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border-bottom:1px solid transparent;
  transition:border-color var(--t-base),padding var(--t-base),background var(--t-base);
}
.nav.scrolled{border-bottom-color:var(--line);padding:0.85rem 0;background:rgba(11,11,15,0.85)}
.nav-inner{
  width:var(--container);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.nav-logo{display:flex;align-items:center;gap:0.65rem}
.logo-mark{
  width:28px;height:28px;border-radius:8px;
  background:var(--accent);position:relative;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 24px var(--accent-glow);
  overflow:hidden;
}
.logo-pulse{
  position:absolute;inset:0;
  background:radial-gradient(circle at center,#FFFFFF 0%,transparent 60%);
  opacity:0.6;animation:logo-pulse 3s ease-in-out infinite;
}
@keyframes logo-pulse{
  0%,100%{transform:scale(0.7);opacity:0.4}
  50%{transform:scale(1);opacity:0.8}
}
.logo-text{
  display:flex;flex-direction:column;justify-content:center;
  line-height:1;
}
.logo-brand{
  font-family:var(--display);font-weight:800;font-size:1.4rem;
  letter-spacing:-0.045em;color:var(--text);
  font-style:italic;
}
.logo-by{
  font-family:var(--sans);font-weight:500;
  font-size:0.62rem;letter-spacing:0.06em;
  color:var(--text-3);text-transform:lowercase;
  margin-top:0.15rem;
}
.nav-links{display:flex;gap:2rem}
.nav-links a{
  font-size:0.9rem;font-weight:500;color:var(--text-2);
  transition:color var(--t-fast);position:relative;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;
  width:0;height:1px;background:var(--accent);
  transition:width var(--t-base);
}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  padding:0.6rem 1.2rem;
  background:var(--accent);color:var(--bg);
  border-radius:99px;
  font-size:0.85rem;font-weight:700;
  transition:all var(--t-base);
  letter-spacing:-0.005em;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 30px var(--accent-glow)}
@media (max-width:1100px){.nav-links{display:none}}
@media (max-width:780px){.logo-text{font-size:1rem}}

/* ═══════════════════════════════════════════════════════════
   HERO
   ═══════════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;height:100svh;
  display:flex;align-items:center;
  padding-top:7rem;padding-bottom:5rem;
  position:relative;overflow:hidden;
}
.hero-media{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-media img,.hero-media picture{
  width:100%;height:100%;
  object-fit:cover;object-position:center 35%;
  filter:contrast(1.05) saturate(1.05) brightness(0.9);
  will-change:transform;
}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(11,11,15,0.5) 0%,rgba(11,11,15,0.7) 50%,rgba(11,11,15,0.97) 100%),
    linear-gradient(90deg,rgba(11,11,15,0.85) 0%,rgba(11,11,15,0.4) 65%,transparent 100%);
}
.hero-inner{
  width:var(--container);margin:0 auto;
  position:relative;z-index:1;
  max-width:1100px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:0.6rem;
  padding:0.5rem 1rem;
  border:1px solid var(--line);
  border-radius:99px;
  font-size:0.78rem;font-weight:500;letter-spacing:0.12em;
  color:var(--text-2);text-transform:uppercase;
  margin-bottom:2rem;
  background:rgba(0,0,0,0.4);
  backdrop-filter:blur(10px);
}
.dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 14px var(--accent);
  animation:dot-pulse 2s ease-in-out infinite;
}

.hero-title{
  font-family:var(--display);
  font-size:var(--hd-1);
  font-weight:800;
  line-height:0.94;
  letter-spacing:-0.04em;
  margin-bottom:2rem;
  color:var(--text);
}
.hero-title .line{display:block;overflow:hidden;padding-bottom:0.05em}
.hero-title .line-inner{
  display:block;transform:translateY(110%);
  transition:transform 1s cubic-bezier(.16,1,.3,1);
}
.hero.loaded .hero-title .line-inner{transform:translateY(0)}
.hero-title .line:nth-child(1) .line-inner{transition-delay:0.1s}
.hero-title .line:nth-child(2) .line-inner{transition-delay:0.2s}
.hero-title .line:nth-child(3) .line-inner{transition-delay:0.3s}
.hero-title .line:nth-child(4) .line-inner{transition-delay:0.4s}

.hero-title em{
  font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--accent);
  letter-spacing:-0.045em;
}

.hero-sub{
  font-size:clamp(1.1rem,1.7vw,1.4rem);
  color:var(--text-2);
  max-width:60ch;line-height:1.5;
  margin-bottom:2.5rem;
  font-weight:400;
}
.hero-sub strong{color:var(--text);font-weight:600}

.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:3rem}

.hero-foot{
  display:flex;align-items:center;gap:1.25rem;
  padding-top:2rem;
  border-top:1px solid var(--line);
  max-width:480px;
}
.hero-foot-num{
  font-family:var(--display);
  font-size:clamp(2rem,3.5vw,3rem);font-weight:700;
  letter-spacing:-0.03em;
  line-height:1;
  color:var(--accent);
}
.hero-foot-num span{
  font-size:0.4em;font-weight:500;color:var(--text-3);margin-left:0.15em;
}
.hero-foot-text{
  font-size:0.85rem;color:var(--text-3);line-height:1.4;
}

.hero-scroll{
  position:absolute;bottom:2rem;right:2rem;
  display:flex;flex-direction:column;align-items:center;gap:0.6rem;
  font-size:0.72rem;letter-spacing:0.25em;
  color:var(--text-2);text-transform:uppercase;
  z-index:2;
}
.scroll-line{
  width:1px;height:60px;
  background:linear-gradient(to bottom,var(--text-3),transparent);
  position:relative;overflow:hidden;
}
.scroll-line::after{
  content:'';position:absolute;top:-100%;left:0;width:100%;height:50%;
  background:var(--accent);
  animation:scroll-pulse 2.2s ease-in-out infinite;
}
@keyframes scroll-pulse{0%{top:-100%}100%{top:200%}}
@media (max-width:780px){.hero-scroll{display:none}}

/* ═══════════════════════════════════════════════════════════
   MARQUEE
   ═══════════════════════════════════════════════════════════ */
.marquee{
  background:var(--bg);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;
  padding:1.5rem 0;
}
.marquee-track{
  display:inline-flex;align-items:center;gap:2.5rem;
  white-space:nowrap;
  animation:marquee 35s linear infinite;
  font-family:var(--display);
  font-size:clamp(1.5rem,3.5vw,2.6rem);
  font-weight:500;font-style:italic;
  letter-spacing:-0.01em;
  color:var(--text);
}
.marquee-track span{flex-shrink:0}
.marquee-slash{color:var(--accent);font-weight:300;font-style:normal}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.marquee:hover .marquee-track{animation-play-state:paused}

/* ═══════════════════════════════════════════════════════════
   MANIFIESTO
   ═══════════════════════════════════════════════════════════ */
.manifiesto{background:var(--bg);padding:clamp(5rem,10vw,9rem) 0}
.manifiesto-grid{
  max-width:1000px;margin:0 auto;
  display:flex;flex-direction:column;gap:1.5rem;
}
.manifiesto-tag{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-size:0.78rem;font-weight:500;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--text-3);
  padding:0.5rem 1rem;border:1px solid var(--line);
  border-radius:99px;background:rgba(255,255,255,0.02);
  align-self:flex-start;
}
.manifiesto-title{
  font-family:var(--display);
  font-size:clamp(2.2rem,5.5vw,5rem);
  font-weight:700;
  line-height:1.02;letter-spacing:-0.03em;
  color:var(--text);
}
.manifiesto-title em{
  font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--accent);
  letter-spacing:-0.04em;
}
.manifiesto-text{
  font-size:clamp(1.15rem,1.9vw,1.45rem);
  color:var(--text-2);
  line-height:1.55;
  max-width:62ch;
  margin-top:1rem;
}
.manifiesto-text strong{color:var(--accent);font-weight:600}

/* ═══════════════════════════════════════════════════════════
   INCLUYE
   ═══════════════════════════════════════════════════════════ */
.incluye{
  background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  position:relative;overflow:hidden;
}
.incluye-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
}
.incluye-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(to right,rgba(255,255,255,0.03) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(255,255,255,0.03) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 50%,black 30%,transparent 80%);
}
.incluye-glow{
  position:absolute;
  top:30%;left:50%;transform:translate(-50%,-50%);
  width:80vw;height:60vh;
  background:radial-gradient(ellipse at center,var(--accent-faint) 0%,transparent 60%);
  filter:blur(60px);
  animation:incluye-glow-pulse 10s ease-in-out infinite;
}
@keyframes incluye-glow-pulse{
  0%,100%{opacity:0.5;transform:translate(-50%,-50%) scale(1)}
  50%{opacity:0.9;transform:translate(-50%,-50%) scale(1.15)}
}
.incluye .container{position:relative;z-index:1}
.incluye-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin-top:3rem;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
.incluye-block{
  padding:2.5rem 2rem;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:rgba(26,26,34,0.4);
  backdrop-filter:blur(8px);
  transition:background var(--t-base),transform var(--t-base),box-shadow var(--t-base);
  position:relative;overflow:hidden;
  transform-style:preserve-3d;
  cursor:default;
}
.incluye-block::before{
  content:'';position:absolute;
  top:0;left:0;width:100%;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--accent) 50%,transparent 100%);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform 0.5s cubic-bezier(.16,1,.3,1);
}
.incluye-block::after{
  content:attr(data-num);
  position:absolute;
  bottom:-1.5rem;right:-1rem;
  font-family:var(--display);
  font-size:9rem;font-weight:900;
  color:rgba(255,255,255,0.02);
  letter-spacing:-0.05em;
  pointer-events:none;
  transition:color var(--t-base),transform var(--t-base);
  line-height:0.8;
}
.incluye-block:hover{
  background:var(--surface);
  transform:translateY(-4px);
  box-shadow:0 20px 60px rgba(0,212,229,0.08);
}
.incluye-block:hover::before{transform:scaleX(1)}
.incluye-block:hover::after{
  color:rgba(0,212,229,0.06);
  transform:translate(-0.5rem,-0.5rem);
}
.incluye-block:hover .incluye-num{
  color:#7BFFEF;
  transform:translateX(0.5rem);
}
.incluye-block:hover h3{transform:translateX(0.25rem)}
@media (max-width:1100px){.incluye-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:680px){.incluye-grid{grid-template-columns:1fr}}

.incluye-num{
  font-family:var(--display);
  font-size:0.95rem;font-weight:700;letter-spacing:0.06em;
  color:var(--accent);
  margin-bottom:1.25rem;
  transition:color var(--t-base),transform var(--t-base);
  display:inline-block;
}
.incluye-block h3{
  transition:transform var(--t-base);
}
.incluye-block h3{
  font-family:var(--display);
  font-size:clamp(1.4rem,2.2vw,1.85rem);
  font-weight:700;letter-spacing:-0.02em;
  color:var(--text);
  margin-bottom:0.5rem;line-height:1.1;
}
.incluye-by{
  display:block;
  font-size:0.78rem;color:var(--text-3);
  font-style:italic;margin-bottom:1rem;
}
.incluye-intro{
  font-size:0.95rem;color:var(--text-2);
  line-height:1.55;
  margin-top:0.25rem;margin-bottom:0.5rem;
  max-width:38ch;
}
.incluye-block ul{
  display:flex;flex-direction:column;gap:0.55rem;
  margin-top:1rem;
  padding-top:1rem;
  border-top:1px solid var(--line);
}
.incluye-block ul li{
  padding-left:1.25rem;position:relative;
  color:var(--text-2);font-size:0.95rem;line-height:1.45;
  opacity:0;transform:translateX(-12px);
  transition:opacity 0.5s cubic-bezier(.16,1,.3,1),transform 0.5s cubic-bezier(.16,1,.3,1),color var(--t-fast);
}
.incluye-block.is-visible ul li{opacity:1;transform:translateX(0)}
.incluye-block.is-visible ul li:nth-child(1){transition-delay:0.3s}
.incluye-block.is-visible ul li:nth-child(2){transition-delay:0.38s}
.incluye-block.is-visible ul li:nth-child(3){transition-delay:0.46s}
.incluye-block.is-visible ul li:nth-child(4){transition-delay:0.54s}
.incluye-block.is-visible ul li:nth-child(5){transition-delay:0.62s}
.incluye-block.is-visible ul li:nth-child(6){transition-delay:0.70s}
.incluye-block ul li::before{
  content:'';position:absolute;left:0;top:0.55em;
  width:8px;height:1px;background:var(--accent);
  transition:width var(--t-fast),background var(--t-fast);
}
.incluye-block ul li:hover{color:var(--text)}
.incluye-block ul li:hover::before{width:14px;background:#7BFFEF}

/* Marquee secundario de servicios */
.incluye-marquee{
  background:var(--bg);
  border-top:1px solid var(--line);
  overflow:hidden;
  padding:1.4rem 0;
  margin-top:0;position:relative;
}
.incluye-marquee::before,
.incluye-marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none;
}
.incluye-marquee::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.incluye-marquee::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.incluye-marquee-track{
  display:inline-flex;align-items:center;gap:1.5rem;
  white-space:nowrap;
  animation:incluye-marquee 60s linear infinite;
  font-family:var(--sans);
  font-size:0.95rem;font-weight:500;
  color:var(--text-2);
  letter-spacing:0;
}
.incluye-marquee-track span{flex-shrink:0}
.incluye-marquee-track .m-dot{
  color:var(--accent);font-weight:700;
  font-size:1.2rem;line-height:1;
}
@keyframes incluye-marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.incluye-marquee:hover .incluye-marquee-track{animation-play-state:paused}

.incluye-foot{
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
  margin-top:3rem;padding-top:3rem;
  border-top:1px solid var(--line);
}
.incluye-foot-num{
  font-family:var(--display);
  font-size:clamp(4rem,9vw,8rem);
  font-weight:800;
  line-height:0.9;letter-spacing:-0.05em;
  color:var(--accent);
  background:linear-gradient(135deg,var(--accent) 0%,#7BFFEF 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.incluye-foot-text{
  font-size:clamp(1rem,1.5vw,1.2rem);
  color:var(--text-2);max-width:30ch;line-height:1.4;
}

/* ═══════════════════════════════════════════════════════════
   PLANES
   ═══════════════════════════════════════════════════════════ */
.planes{background:var(--bg)}
.planes-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;
  margin-top:3rem;
}
@media (max-width:880px){.planes-grid{grid-template-columns:1fr}}

.plan-card{
  position:relative;
  padding:2.75rem 2.5rem;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:24px;
  transition:all var(--t-base);
  display:flex;flex-direction:column;gap:1.25rem;
}
.plan-card:hover{border-color:var(--line-strong);background:var(--surface-2)}
.plan-card-featured{
  border-color:var(--accent);
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
  box-shadow:0 20px 60px var(--accent-faint);
}
.plan-badge{
  position:absolute;top:1.5rem;right:1.5rem;
  padding:0.35rem 0.85rem;
  background:var(--accent);color:var(--bg);
  font-size:0.7rem;font-weight:700;letter-spacing:0.12em;
  border-radius:99px;text-transform:uppercase;
}
.plan-head h3{
  font-family:var(--display);
  font-size:clamp(1.6rem,2.4vw,2.1rem);
  font-weight:700;letter-spacing:-0.025em;
  color:var(--text);
}
.plan-head p{
  margin-top:0.4rem;
  color:var(--text-3);font-size:0.92rem;
}
.plan-amount{
  display:flex;align-items:flex-start;
  font-family:var(--display);font-weight:800;
  letter-spacing:-0.045em;color:var(--text);
  line-height:1;margin-top:0.5rem;
}
.plan-currency{
  font-size:1.6rem;margin-top:0.6rem;margin-right:0.2rem;
  color:var(--accent);font-weight:500;
}
.plan-value{
  font-size:clamp(3.4rem,6.8vw,5.2rem);
  background:linear-gradient(135deg,var(--accent) 0%,#7BFFEF 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  font-variant-numeric:tabular-nums;
}
.plan-cycle{color:var(--text-2);font-size:0.95rem;margin-top:0.4rem}
.plan-cta{margin-top:1rem}
.plan-divider{height:1px;background:var(--line);margin:0.5rem 0}
.plan-list{display:flex;flex-direction:column;gap:0.65rem}
.plan-list li{
  display:flex;align-items:flex-start;gap:0.65rem;
  color:var(--text-2);font-size:0.95rem;line-height:1.45;
  padding-left:0;
}
.plan-list li::before{
  content:'→';color:var(--accent);font-weight:700;flex-shrink:0;
}
.plan-list li.plus::before{content:'+';color:var(--accent);font-weight:800}
.plan-list li.plus{color:var(--text);font-weight:500}

.plan-foot{
  text-align:center;margin-top:2rem;
  color:var(--text-3);font-size:0.9rem;
  font-style:italic;
}

/* ═══════════════════════════════════════════════════════════
   REFERENCIA · una sola consulta de fisiatra
   ═══════════════════════════════════════════════════════════ */
.referencia{
  background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.referencia-grid{
  display:grid;grid-template-columns:1.2fr 0.8fr;
  gap:4rem;align-items:center;
}
@media (max-width:980px){.referencia-grid{grid-template-columns:1fr;gap:3rem}}

.referencia-text .section-title{margin-top:1rem}
.referencia-sub{
  margin-top:1.5rem;
  font-size:clamp(1.05rem,1.5vw,1.2rem);
  color:var(--text-2);line-height:1.55;
  max-width:54ch;
}
.referencia-strong{
  margin-top:1.25rem;
  font-size:clamp(1.05rem,1.5vw,1.2rem);
  color:var(--text);line-height:1.55;
  max-width:54ch;font-weight:500;
}

.referencia-card{
  padding:3rem 2.5rem;
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--accent);
  border-radius:24px;
  text-align:center;
  position:relative;overflow:hidden;
  box-shadow:0 20px 80px var(--accent-faint);
}
.referencia-card::before{
  content:'';position:absolute;
  top:-50%;left:-50%;width:200%;height:200%;
  background:radial-gradient(ellipse at center,var(--accent-faint) 0%,transparent 60%);
  pointer-events:none;
}
.referencia-card > *{position:relative;z-index:1}
.ref-num{
  font-family:var(--display);font-weight:800;
  font-size:clamp(2.4rem,5vw,3.8rem);
  letter-spacing:-0.045em;line-height:1;
  color:var(--text-3);
  font-variant-numeric:tabular-nums;
}
.ref-num-good{
  color:var(--accent);
  background:linear-gradient(135deg,var(--accent) 0%,#7BFFEF 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  font-style:italic;font-weight:500;
}
.ref-label{
  margin-top:0.85rem;
  font-size:0.92rem;color:var(--text-2);line-height:1.45;
  max-width:38ch;margin-left:auto;margin-right:auto;
}
.ref-divider{
  width:40px;height:1px;background:var(--line-strong);
  margin:1.75rem auto;
}
.ref-vs{
  font-family:var(--display);font-style:italic;font-weight:500;
  font-size:1.05rem;color:var(--text-3);
  letter-spacing:0.05em;
}

.comparativo{
  background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.compare-table{
  margin-top:3rem;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:18px;overflow:hidden;
}
.compare-row{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:1rem;
  padding:1rem 1.5rem;
  border-bottom:1px solid var(--line);
  align-items:center;
}
.compare-row:last-child{border-bottom:0}
.compare-head{
  background:var(--bg-3);
  font-size:0.78rem;font-weight:700;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--text-3);
}
.compare-row > div{font-size:0.95rem;color:var(--text-2)}
.compare-row .num{
  text-align:right;font-variant-numeric:tabular-nums;
  font-weight:500;
}
.compare-row .num.included{
  color:var(--accent);font-weight:600;text-transform:uppercase;
  font-size:0.82rem;letter-spacing:0.05em;
}
.compare-row.total{
  background:var(--bg-3);
  font-size:1.05rem;
  border-top:2px solid var(--line-strong);
}
.compare-row.total > div{color:var(--text)}
.compare-row.foot{
  background:var(--bg-2);
  border-top:1px solid var(--line);
}
.compare-row.foot > div{color:var(--text-3)}
.big-num{
  color:var(--accent);
  font-family:var(--display);font-weight:800;
  font-size:1.15em;letter-spacing:-0.02em;
}
@media (max-width:780px){
  .compare-row{grid-template-columns:1.4fr 1fr 1fr;padding:0.85rem 1rem;gap:0.5rem}
  .compare-row > div{font-size:0.85rem}
}

.compare-extra{
  margin-top:3rem;padding:2rem;
  background:rgba(0,212,229,0.04);
  border:1px solid rgba(0,212,229,0.16);
  border-radius:18px;
}
.compare-extra h3{
  font-family:var(--display);
  font-size:clamp(1.3rem,2vw,1.7rem);font-weight:700;
  letter-spacing:-0.02em;
  margin-bottom:1rem;color:var(--text);
}
.compare-extra h3 em{
  font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--accent);
}
.compare-extra ul{display:flex;flex-direction:column;gap:0.7rem}
.compare-extra li{
  padding-left:1.5rem;position:relative;
  color:var(--text-2);line-height:1.5;font-size:0.95rem;
}
.compare-extra li::before{
  content:'+';position:absolute;left:0;
  color:var(--accent);font-weight:700;font-size:1.2em;
}

/* ═══════════════════════════════════════════════════════════
   FUNCIONA
   ═══════════════════════════════════════════════════════════ */
.funciona{background:var(--bg)}
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;margin-top:3rem;
  border-top:1px solid var(--line);
  border-left:1px solid var(--line);
}
@media (max-width:880px){.steps{grid-template-columns:1fr}}
.step{
  padding:2.5rem 2rem;
  border-right:1px solid var(--line);
  border-bottom:1px solid var(--line);
  transition:background var(--t-base);
  display:flex;gap:1.5rem;align-items:flex-start;
}
.step:hover{background:var(--bg-2)}
.step-num{
  font-family:var(--display);
  font-size:2.5rem;font-weight:800;
  color:var(--accent);
  line-height:0.9;letter-spacing:-0.03em;
  flex-shrink:0;
  background:linear-gradient(135deg,var(--accent) 0%,#7BFFEF 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.step-body h3{
  font-family:var(--display);
  font-size:1.4rem;font-weight:700;
  letter-spacing:-0.02em;
  margin-bottom:0.5rem;color:var(--text);
}
.step-body p{color:var(--text-2);line-height:1.55;font-size:0.95rem}

/* ═══════════════════════════════════════════════════════════
   SANNARSE (PRODUCTO) + ALIADOS
   ═══════════════════════════════════════════════════════════ */
.aliados{
  background:var(--bg-2);
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}

/* Brand block · Sannarse como producto */
.brand-block{
  max-width:880px;margin:0 auto;
  padding:4rem 3rem;
  background:linear-gradient(135deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--accent);
  border-radius:28px;
  text-align:center;
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  box-shadow:0 20px 80px var(--accent-faint);
}
.brand-block::before{
  content:'';position:absolute;
  top:-40%;left:50%;transform:translateX(-50%);
  width:80%;height:80%;
  background:radial-gradient(ellipse at center,var(--accent-faint) 0%,transparent 60%);
  pointer-events:none;
}
.brand-block > *{position:relative;z-index:1}
.brand-mark{
  width:80px;height:80px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-3);border-radius:20px;
  border:1px solid var(--accent);
  box-shadow:0 0 40px var(--accent-faint);
}
.brand-mark span{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent) 0%,#7BFFEF 100%);
  box-shadow:0 0 24px var(--accent-glow);
}
.brand-block .section-tag{margin-bottom:0.5rem}
.brand-title{
  font-family:var(--display);
  font-size:clamp(2.4rem,5vw,4rem);
  font-weight:800;
  letter-spacing:-0.04em;
  color:var(--text);
  line-height:1;
}
.brand-text{
  color:var(--text-2);font-size:clamp(1rem,1.4vw,1.15rem);
  line-height:1.55;max-width:58ch;
}
.brand-text-soft{
  color:var(--text-3);font-size:clamp(0.92rem,1.2vw,1.02rem);
  line-height:1.55;max-width:58ch;
  font-style:italic;
  margin-top:-0.5rem;
}
.brand-link{
  font-size:0.9rem;color:var(--accent);font-weight:700;
  letter-spacing:0.02em;
  margin-top:0.5rem;
  transition:opacity var(--t-fast);
}
.brand-link:hover{opacity:0.7}

/* Aliados row */
.aliados-block{
  max-width:880px;margin:4rem auto 0;
  text-align:center;
}
.aliados-block .section-tag{margin-bottom:1.5rem;display:inline-flex}
.aliados-row{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;
  margin-top:1rem;text-align:left;
}
@media (max-width:680px){.aliados-row{grid-template-columns:1fr}}
.aliado-pill{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1.25rem 1.5rem;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:16px;
  transition:all var(--t-base);
}
.aliado-pill:hover{border-color:var(--line-strong);background:var(--surface-2)}
.aliado-pill-mark{
  width:36px;height:36px;border-radius:50%;flex-shrink:0;
  background:var(--bg-3);
  position:relative;margin-top:0.2rem;
}
.aliado-pill-mark::after{
  content:'';position:absolute;inset:6px;border-radius:50%;
}
.aliado-pill-mark-nm::after{
  background:linear-gradient(135deg,#FF6B35 0%,#FFB800 100%);
  box-shadow:0 0 12px rgba(255,107,53,0.4);
}
.aliado-pill-mark-hiki::after{
  background:linear-gradient(135deg,#A78BFA 0%,#8B5CF6 100%);
  box-shadow:0 0 12px rgba(167,139,250,0.4);
}
.aliado-pill h4{
  font-family:var(--display);
  font-size:1.05rem;font-weight:700;
  letter-spacing:-0.015em;color:var(--text);
  margin-bottom:0.3rem;
}
.aliado-pill p{
  font-size:0.85rem;color:var(--text-2);
  line-height:1.45;margin-bottom:0.5rem;
}
.aliado-pill-link{
  font-size:0.78rem;color:var(--accent);font-weight:600;
  transition:opacity var(--t-fast);
}
.aliado-pill-link:hover{opacity:0.7}

/* ═══════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════ */
.faq{background:var(--bg)}
.faq-list{margin-top:3rem;max-width:880px}
.faq-item{border-top:1px solid var(--line);padding:0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{
  list-style:none;padding:1.85rem 0;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  font-family:var(--display);
  font-size:clamp(1.1rem,1.7vw,1.35rem);
  font-weight:600;letter-spacing:-0.02em;color:var(--text);
  transition:color var(--t-fast);
}
.faq-item summary:hover{color:var(--accent)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-family:var(--display);
  font-size:1.6rem;font-weight:300;
  color:var(--accent);
  transition:transform var(--t-base);flex-shrink:0;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{
  padding:0 0 1.85rem;max-width:62ch;
  color:var(--text-2);line-height:1.65;font-size:1rem;
}

/* ═══════════════════════════════════════════════════════════
   CTA FINAL
   ═══════════════════════════════════════════════════════════ */
.cta-final{
  position:relative;overflow:hidden;
  padding:clamp(6rem,12vw,10rem) 0;
  text-align:center;
}
.cta-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.cta-bg img{
  width:100%;height:100%;object-fit:cover;object-position:center;
  filter:contrast(1.1) saturate(1.1) brightness(0.7);
  will-change:transform;
}
.cta-overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,11,15,0.7) 0%,rgba(11,11,15,0.5) 50%,rgba(11,11,15,0.85) 100%);
}
.cta-inner{
  position:relative;z-index:1;
  width:var(--container);margin:0 auto;
}
.cta-title{
  font-family:var(--display);
  font-size:clamp(3rem,9vw,8rem);
  font-weight:800;line-height:0.95;letter-spacing:-0.045em;
  margin-bottom:1.5rem;color:var(--text);
}
.cta-title em{
  font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--accent);letter-spacing:-0.05em;
}
.cta-sub{
  font-size:clamp(1.1rem,1.7vw,1.4rem);
  color:var(--text-2);margin-bottom:3rem;
}

/* ═══════════════════════════════════════════════════════════
   CONTACTO
   ═══════════════════════════════════════════════════════════ */
.contacto{
  background:var(--bg-2);
  border-top:1px solid var(--line);
  position:relative;overflow:hidden;
}
.contacto::before{
  content:'';position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:120%;height:200%;
  background:radial-gradient(ellipse at center,var(--accent-faint) 0%,transparent 50%);
  pointer-events:none;
}
.contacto-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:0.9fr 1.1fr;
  gap:5rem;align-items:start;
}
@media (max-width:980px){.contacto-grid{grid-template-columns:1fr;gap:3rem}}

.contacto-meta{display:flex;flex-direction:column;gap:0.75rem;margin-top:2rem}
.contacto-meta li{display:flex;align-items:center;gap:0.65rem;color:var(--text-2);font-size:0.95rem}
.check{color:var(--accent);font-weight:700;flex-shrink:0;font-size:0.95rem}

.form{
  display:flex;flex-direction:column;gap:1.25rem;
  padding:2.5rem;
  background:var(--surface);border:1px solid var(--line);border-radius:20px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
@media (max-width:600px){.form-row{grid-template-columns:1fr}}

.form-field{display:flex;flex-direction:column;gap:0.5rem}
.form-label{font-size:0.85rem;font-weight:600;color:var(--text-2)}
.form-field input,.form-field select{
  width:100%;padding:0.9rem 1rem;
  background:var(--bg-3);border:1px solid var(--line);
  border-radius:10px;
  font-family:inherit;font-size:0.95rem;color:var(--text);
  transition:border-color var(--t-fast),background var(--t-fast);
}
.form-field input:focus,.form-field select:focus{
  outline:none;border-color:var(--accent);background:var(--surface-2);
}
.form-field input::placeholder{color:var(--text-3)}

.radio-group{display:grid;grid-template-columns:repeat(2,1fr);gap:0.75rem;margin-top:0.5rem}
@media (max-width:600px){.radio-group{grid-template-columns:1fr}}
.radio-card{
  position:relative;padding:1rem;
  background:var(--bg-3);border:1px solid var(--line);
  border-radius:12px;cursor:pointer;
  display:flex;flex-direction:column;gap:0.25rem;
  transition:all var(--t-fast);
}
.radio-card:hover{border-color:var(--line-strong)}
.radio-card input{position:absolute;opacity:0;pointer-events:none}
.radio-card:has(input:checked){border-color:var(--accent);background:var(--accent-faint)}
.radio-title{font-size:0.95rem;font-weight:700;color:var(--text)}
.radio-sub{font-size:0.8rem;color:var(--accent);line-height:1.3;font-weight:600}

.form-check{display:flex;align-items:flex-start;gap:0.6rem;font-size:0.85rem;color:var(--text-2);line-height:1.5}
.form-check input{width:18px;height:18px;accent-color:var(--accent);flex-shrink:0;margin-top:0.15em}
.link{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

.form-submit{justify-content:center;width:100%;margin-top:0.5rem}

.form-success{
  text-align:center;padding:2rem;
  background:var(--accent-faint);border:1px solid var(--accent);border-radius:14px;
}
.form-success h3{color:var(--accent);font-size:1.4rem;margin-bottom:0.5rem;font-family:var(--display);font-weight:700}
.form-success p{color:var(--text)}

/* ═══════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════ */
.footer{background:var(--bg);border-top:1px solid var(--line);padding:4rem 0 2rem}
.footer-grid{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:3rem;
  padding-bottom:3rem;border-bottom:1px solid var(--line);
}
@media (max-width:880px){
  .footer-grid{grid-template-columns:repeat(2,1fr);gap:2rem}
  .footer-brand{grid-column:1 / -1}
}
.footer-logo{
  font-family:var(--display);font-weight:800;
  font-size:2rem;letter-spacing:-0.045em;
  font-style:italic;
  color:var(--text);
  line-height:1;
}
.footer-by{
  font-size:0.78rem;color:var(--text-3);
  margin-top:0.4rem;margin-bottom:1rem;
  letter-spacing:0.04em;
}
.footer-em{
  font-family:var(--display);font-style:italic;font-weight:500;
  color:var(--accent);
}
.footer-brand p{color:var(--text-2);font-size:0.95rem;line-height:1.5;max-width:32ch}
.footer-col h4{
  font-size:0.78rem;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--text-3);margin-bottom:1rem;
}
.footer-col ul{display:flex;flex-direction:column;gap:0.55rem}
.footer-col li{font-size:0.9rem;color:var(--text-2)}
.footer-col a{transition:color var(--t-fast)}
.footer-col a:hover{color:var(--accent)}
.footer-base{
  padding-top:2rem;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:1rem;
  font-size:0.82rem;color:var(--text-3);
}

:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
