/* ============================================================
   SPOT COLLECTION REFORMA — main.css v5
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@200;300;400;500&display=swap');

/* ── TOKENS ── */
:root {
  --cream:       #F5F3EE;
  --cream-cool:  #F1F2F0;
  --ink:         #221f1c;
  --muted:       #767974;
  --line:        #D6D9D4;
  --white:       #FFFFFF;

  --vida:        #A25436;
  --vida-glow:   rgba(162,84,54,0.28);
  --vida-light:  rgba(162,84,54,0.12);
  --vida-strong: #8E452A;
  --vida-soft:   #BD785E;

  --valor:       #697A6A;
  --valor-glow:  rgba(105,122,106,0.26);
  --valor-light: rgba(105,122,106,0.12);
  --valor-strong:#556657;
  --valor-soft:  #879587;

  --route-accent:        #8A8479;
  --route-accent-strong: #6D655D;
  --route-accent-soft:   #B2A69B;
  --route-accent-glow:   rgba(138,132,121,0.18);
  --surface-bg:          var(--cream);
  --surface-line:        #D8D5CF;
  --nav-bg:              rgba(245,243,238,0.72);
  --nav-bg-scrolled:     rgba(245,243,238,0.94);

  --font-serif:  'Cormorant Garamond', Georgia, serif;
  --font-sans:   'Jost', system-ui, sans-serif;

  --nav-h:       58px;
  --sticky-h:    76px;
  --ease:        cubic-bezier(0.4,0,0.2,1);

  /* Animaciones +35% */
  --dur:         1.08s;
  --move:        30px;
}

body.route-vida,
#root.state-vida{
  --route-accent:        var(--vida);
  --route-accent-strong: var(--vida-strong);
  --route-accent-soft:   var(--vida-soft);
  --route-accent-glow:   rgba(162,84,54,0.18);
  --surface-bg:          var(--cream);
  --surface-line:        #D8D5CF;
  --nav-bg:              rgba(245,243,238,0.72);
  --nav-bg-scrolled:     rgba(245,243,238,0.94);
}

body.route-valor,
#root.state-valor{
  --route-accent:        var(--valor);
  --route-accent-strong: var(--valor-strong);
  --route-accent-soft:   var(--valor-soft);
  --route-accent-glow:   rgba(105,122,106,0.16);
  --surface-bg:          var(--cream-cool);
  --surface-line:        #D6D9D4;
  --nav-bg:              rgba(241,242,240,0.74);
  --nav-bg-scrolled:     rgba(241,242,240,0.94);
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; -webkit-font-smoothing:antialiased; }
html { font-size:20px; scroll-behavior:smooth; -webkit-overflow-scrolling:touch; scrollbar-gutter:stable; }
body { background:var(--surface-bg); color:var(--ink); font-family:var(--font-sans); font-weight:300; overflow-x:hidden; }

/* ── CURSOR BLANCO — desktop ── */
@media (hover:hover) and (pointer:fine) {
  html.has-custom-cursor,
  html.has-custom-cursor body,
  html.has-custom-cursor * { cursor:none !important; }
  .cursor-dot {
    position:fixed; width:6px; height:6px; background:#ffffff;
    border-radius:50%; pointer-events:none; z-index:99999;
    transform:translate(-50%,-50%);
    box-shadow:0 0 0 1px rgba(0,0,0,.14),0 0 10px rgba(255,255,255,.18);
    mix-blend-mode:difference;
  }
  .cursor-ring {
    position:fixed; width:36px; height:36px;
    border:2.25px solid rgba(255,255,255,0.85); border-radius:50%;
    pointer-events:none; z-index:99998;
    transform:translate(-50%,-50%);
    box-shadow:0 0 0 1px rgba(0,0,0,.16),0 0 14px rgba(255,255,255,.08);
    mix-blend-mode:difference;
    transition:width .4s var(--ease),height .4s var(--ease),border-color .4s var(--ease);
  }
  .cursor-ring.hovering { width:52px; height:52px; border-color:rgba(255,255,255,1); }
}

/* ══════════════════════════════════════════════
   NAV — MOBILE FIRST
   Mobile: selector centrado, hamburger abs derecha
   ══════════════════════════════════════════════ */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:var(--nav-h);
  display:flex; align-items:center; justify-content:center;
  padding:0 16px;
  background:var(--nav-bg);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:0.5px solid transparent;
  transition:border-color .4s var(--ease),background .4s var(--ease);
}
.nav.scrolled { border-bottom-color:var(--surface-line); background:var(--nav-bg-scrolled); }

/* Logo — solo desktop */
.nav-logo {
  display:none;
  font-family:var(--font-serif); font-size:14px; font-weight:400;
  letter-spacing:0.06em; color:var(--ink); text-decoration:none;
  transition:opacity .25s; flex-shrink:0; white-space:nowrap;
}
.nav-logo:hover { opacity:0.55; }

/* Selector de ruta — centrado */
.nav-selector {
  display:flex; align-items:center; gap:2px;
  background:rgba(20,20,18,0.08);
  border:0.5px solid rgba(20,20,18,0.1);
  border-radius:40px; padding:4px;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.nav-sel-item { position:relative; }

.sel-btn {
  font-family:var(--font-sans); font-size:11px; font-weight:500;
  letter-spacing:0.08em; text-transform:uppercase;
  padding:7px 14px; border-radius:32px;
  color:var(--muted); background:transparent; border:none;
  display:flex; align-items:center; gap:4px; white-space:nowrap;
  transition:color .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease);
}
.nav-selector .sel-btn {
  pointer-events:auto;
}
/* Chevron — oculto en mobile */
.sel-chevron { display:none; font-size:10px; transition:transform .25s var(--ease); }

.sel-btn.sel-vida.active  { background:var(--vida);  color:#F5F3EE; box-shadow:0 2px 12px var(--vida-glow); }
.sel-btn.sel-valor.active { background:var(--valor); color:#F5F3EE; box-shadow:0 2px 12px var(--valor-glow); }

/* Submenú — solo desktop con JS click */
.sel-submenu {
  display:none; /* oculto en mobile; JS lo controla en desktop */
}
.sel-sub-divider { display:none; }

/* Derecha: hamburger posicionado absoluto en mobile */
.nav-right {
  position:absolute; right:16px; top:50%; transform:translateY(-50%);
  display:flex; align-items:center; gap:8px;
}

/* CTA superior — visible en mobile, más ligero que el sticky */
.nav-cta-sm {
  --nav-cta-bg: rgba(245,243,238,0.56);
  --nav-cta-border: rgba(20,20,18,0.12);
  --nav-cta-color: var(--muted);
  display:none;
  align-items:center;
  justify-content:center;
  font-family:var(--font-sans);
  font-size:8.5px;
  font-weight:500;
  letter-spacing:0.08em;
  text-transform:uppercase;
  padding:7px 10px;
  border-radius:999px;
  border:0.5px solid var(--nav-cta-border);
  background:var(--nav-cta-bg);
  color:var(--nav-cta-color);
  text-decoration:none;
  transition:background .25s,border-color .25s,color .25s,opacity .25s;
}
#root.state-vida .nav-cta-sm,
.nav-cta-sm[data-route="vida"] {
  --nav-cta-bg: rgba(162,84,54,0.08);
  --nav-cta-border: rgba(162,84,54,0.18);
  --nav-cta-color: #7f4229;
}
#root.state-valor .nav-cta-sm,
.nav-cta-sm[data-route="valor"] {
  --nav-cta-bg: rgba(105,122,106,0.08);
  --nav-cta-border: rgba(105,122,106,0.18);
  --nav-cta-color: #556657;
}

/* Hamburger */
.nav-hamburger {
  width:36px; height:36px;
  display:flex; flex-direction:column; justify-content:center; align-items:center; gap:5px;
  border:none; background:none; -webkit-tap-highlight-color:transparent;
}
.nav-hamburger span { display:block; height:1px; background:var(--ink); transition:all .35s var(--ease); }
.nav-hamburger span:nth-child(1) { width:20px; }
.nav-hamburger span:nth-child(2) { width:13px; }
.nav-hamburger.open span:nth-child(1) { width:18px; transform:translateY(6px) rotate(45deg); }
.nav-hamburger.open span:nth-child(2) { width:18px; transform:translateY(-0.5px) rotate(-45deg); }

/* ══════════════════════════════════════════════
   MENÚ MÓVIL
   ══════════════════════════════════════════════ */
.mobile-menu {
  position:fixed; inset:0; z-index:190;
  background:var(--surface-bg);
  display:flex; flex-direction:column;
  padding:calc(var(--nav-h) + 24px) 28px calc(var(--sticky-h) + 24px);
  overflow-y:auto;
  clip-path:circle(0% at calc(100% - 34px) 29px);
  transition:clip-path .65s cubic-bezier(0.4,0,0.2,1);
  pointer-events:none;
}
.mobile-menu.open { clip-path:circle(150% at calc(100% - 34px) 29px); pointer-events:all; }

.mobile-menu-header { margin-bottom:28px; padding-bottom:24px; border-bottom:0.5px solid var(--surface-line); }
.mobile-menu-brand {
  display:block;
  font-family:var(--font-serif); font-size:26px; font-weight:300;
  letter-spacing:0.01em; color:var(--ink); line-height:1.15; margin-bottom:16px;
}
.mm-header-cta {
  --mm-cta-bg: transparent;
  --mm-cta-border: var(--line);
  --mm-cta-color: var(--ink);
  display:inline-flex; align-items:center;
  font-family:var(--font-sans); font-size:10px; font-weight:500;
  letter-spacing:0.12em; text-transform:uppercase;
  color:var(--mm-cta-color); text-decoration:none;
  padding:10px 20px; border-radius:40px; border:0.5px solid var(--mm-cta-border);
  background:var(--mm-cta-bg);
  transition:background .25s,color .25s,border-color .25s;
}
.mm-header-cta:hover { background:var(--ink); color:var(--cream); }
#root.state-vida .mm-header-cta,
.mm-header-cta[data-route="vida"] {
  --mm-cta-bg: rgba(162,84,54,0.10);
  --mm-cta-border: rgba(162,84,54,0.18);
  --mm-cta-color: #7f4229;
}
#root.state-valor .mm-header-cta,
.mm-header-cta[data-route="valor"] {
  --mm-cta-bg: rgba(105,122,106,0.10);
  --mm-cta-border: rgba(105,122,106,0.18);
  --mm-cta-color: #556657;
}

@media(max-width:1023px){
  .mobile-menu-header{
    display:flex;
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:24px;
    margin-bottom:38px;
    padding-bottom:30px;
  }
  .mobile-menu-brand{
    margin-bottom:0;
    max-width:none;
    white-space:nowrap;
  }
  .mm-header-cta{
    align-self:center;
  }
}

.mm-route-block { margin-bottom:28px; }
.mm-route-header {
  display:flex; align-items:center; gap:10px; margin-bottom:12px;
  cursor:pointer; user-select:none;
}
.mm-route-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.mm-route-label { font-size:9px; font-weight:500; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); flex:1; }
.mm-route-toggle { font-size:14px; color:var(--muted); transition:transform .3s var(--ease); }
.mm-route-block.collapsed .mm-route-toggle { transform:rotate(-90deg); }

.mm-route-links {
  list-style:none; display:flex; flex-direction:column; gap:2px;
  max-height:400px; overflow:hidden;
  transition:max-height .4s var(--ease),opacity .35s var(--ease);
  opacity:1;
}
.mm-route-block.collapsed .mm-route-links { max-height:0; opacity:0; }

.mm-link {
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--font-serif); font-size:22px; font-weight:300;
  color:var(--ink); text-decoration:none;
  padding:7px 0; border-bottom:0.5px solid transparent; letter-spacing:0.01em;
  transition:color .2s,border-color .2s;
}
.mm-link span { font-family:var(--font-sans); font-size:13px; color:var(--muted); transition:transform .2s,color .2s; }
.mm-link:hover { color:var(--muted); border-bottom-color:var(--line); }
.mm-link:hover span { transform:translateX(4px); color:var(--ink); }

/* ══════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════ */
.hero {
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:flex-start;
  padding-top:calc(var(--nav-h) + 20px);
  padding-left:20px; padding-right:20px;
  padding-bottom:calc(var(--sticky-h) + 20px + env(safe-area-inset-bottom));
  overflow:hidden;
  z-index:30;
}

.hero-video-wrap { position:absolute; inset:0; overflow:hidden; }
.hero-video {
  width:100%; height:100%; object-fit:cover; object-position:center;
  filter:brightness(0.52) saturate(0.82); transition:filter 1.2s var(--ease);
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom,rgba(20,20,18,.22) 0%,rgba(20,20,18,.06) 30%,rgba(20,20,18,.56) 72%,rgba(20,20,18,.90) 100%);
  transition:background 1s var(--ease);
}
.state-vida .hero-overlay {
  background:linear-gradient(to bottom,rgba(20,20,18,.15) 0%,rgba(20,20,18,.04) 30%,rgba(162,84,54,.16) 65%,rgba(20,20,18,.90) 100%);
}
.state-valor .hero-overlay {
  background:linear-gradient(to bottom,rgba(20,20,18,.15) 0%,rgba(20,20,18,.04) 30%,rgba(105,122,106,.20) 65%,rgba(20,20,18,.92) 100%);
}
.hero::after{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:0;
  bottom:0;
  height:100%;
  z-index:1;
  opacity:0;
  pointer-events:none;
  transform:translateY(100%);
  background:linear-gradient(
    180deg,
    rgba(20,20,18,0) 0%,
    rgba(20,20,18,.06) 16%,
    rgba(20,20,18,.20) 38%,
    rgba(20,20,18,.60) 100%
  );
  transition:
    opacity 2s cubic-bezier(.22,.61,.36,1),
    transform 2s cubic-bezier(.22,.61,.36,1),
    background 2s cubic-bezier(.22,.61,.36,1);
}
.hero-route-logo{
  display:none;
  position:absolute;
  left:50%;
  top:50%;
  z-index:2;
  width:min(148px,18vw);
  opacity:0;
  transform:translate3d(-50%,-50%,0) scale(.92);
  pointer-events:none;
  transition:opacity 1.36s cubic-bezier(.22,1,.36,1), transform 1.36s cubic-bezier(.22,1,.36,1);
  mix-blend-mode:screen;
}
.hero-route-logo img{
  display:block;
  width:100%;
  height:auto;
  opacity:.78;
  filter:drop-shadow(0 10px 28px rgba(20,20,18,.16));
}
.scr-root.route-transition .hero::after{
  opacity:1;
  transform:translateY(0);
}
.scr-root.route-transition .hero-route-logo{
  display:none;
  opacity:.74;
  transform:translate3d(-50%,-50%,0) scale(1);
}
.scr-root.route-transition.state-vida .hero::after{
  background:linear-gradient(
    180deg,
    rgba(162,84,54,0) 0%,
    rgba(162,84,54,.06) 16%,
    rgba(162,84,54,.20) 34%,
    rgba(162,84,54,.60) 100%
  );
}
.scr-root.route-transition.state-valor .hero::after{
  background:linear-gradient(
    180deg,
    rgba(105,122,106,0) 0%,
    rgba(105,122,106,.06) 16%,
    rgba(105,122,106,.20) 34%,
    rgba(105,122,106,.60) 100%
  );
}

.hero-content { position:relative; z-index:2; display:flex; flex-direction:column; flex:1; }

/* EYEBROW — horizontal, arriba del headline */
.hero-eyebrow {
  display:flex; align-items:center; gap:12px;
  margin-bottom:20px;
  opacity:0; transform:translateY(var(--move));
  animation:fadeUp var(--dur) 0.27s var(--ease) forwards;
}
.eyebrow-line { width:24px; height:0.5px; background:rgba(245,243,238,0.4); flex-shrink:0; }
.eyebrow-text {
  font-size:9px; /* +10% de 8px → 8.8 → 9px */
  font-weight:400; letter-spacing:0.18em; text-transform:uppercase;
  color:rgba(245,243,238,0.55); /* un poco más visible también */
  writing-mode:horizontal-tb;
}

/* Headline */
.hero-headline {
  font-family:var(--font-serif); font-weight:300;
  font-size:clamp(56px,15vw,76px);
  line-height:0.95; letter-spacing:-0.01em; color:#F5F3EE;
  margin-bottom:18px;
  opacity:0; transform:translateY(var(--move));
  animation:fadeUp var(--dur) 0.45s var(--ease) forwards;
}
/* Wrappers de máscara */
.hero-headline .line-wrap { display:block; overflow:hidden; }
.hero-headline .line-inner { display:block; }

.hero-headline em { display:block; font-style:italic; color:rgba(245,243,238,0.42); transition:color .8s var(--ease); }
.state-vida  .hero-headline em { color:var(--vida); }
.state-valor .hero-headline em { color:var(--valor); }

.hero-divider {
  width:32px; height:0.5px; background:rgba(245,243,238,.25); margin-bottom:16px;
  opacity:0; animation:fadeIn .81s .72s var(--ease) forwards;
}

/* Subtexto neutro — wrappers para animación de máscara */
.hero-sub {
  font-size:clamp(13px,3.5vw,15px); font-weight:300;
  letter-spacing:0.04em; line-height:1.7; color:rgba(245,243,238,.5);
  margin-bottom:24px;
  opacity:0; transform:translateY(var(--move));
  animation:fadeUp var(--dur) 0.72s var(--ease) forwards;
}
/* Líneas del subtexto con máscara */
.hero-sub .line-wrap  { display:block; overflow:hidden; }
.hero-sub .line-inner { display:block; }

.state-vida .hero-sub, .state-valor .hero-sub { display:none; }

/* Statements — 2 líneas máximo, con wrappers de máscara */
.hero-statement {
  font-family:var(--font-serif); font-size:clamp(16px,4.5vw,21px);
  font-weight:300; line-height:1.55; color:rgba(245,243,238,.85);
  border-left:1px solid rgba(245,243,238,.2);
  padding-left:16px; margin-bottom:24px;
  min-height:3.2em;
  display:none;
}
/* Líneas del statement con máscara */
.hero-statement .line-wrap  { display:block; overflow:hidden; }
.hero-statement .line-inner { display:block; }

.state-vida  .hero-statement.for-vida  { display:block; border-left-color:var(--vida); }
.state-valor .hero-statement.for-valor { display:block; border-left-color:rgba(105,122,106,.5); }

/* Animación exit/enter del statement igual que el headline */
.hero-statement.exit .line-inner {
  transform:translateY(-105%); opacity:0;
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.hero-statement.enter .line-wrap { overflow:hidden; }
.hero-statement.enter .line-inner { animation:lineReveal .6s var(--ease) both; }
.hero-statement.enter .line-inner:nth-child(1) { animation-delay:0.05s; }
.hero-statement.enter .line-inner:nth-child(2) { animation-delay:0.13s; }

/* ── BOTONES DE RUTA EN HERO ──
   Mobile: columna, con margen horizontal (+30% aire = 15% cada lado)
   Desktop: fila horizontal centrada, estilizados
   Texto SIEMPRE blanco (activo) o gris (inactivo)
   Solo contorno/sombra/fondo cambian de color
── */
.hero-selector {
  margin-top:auto;
  display:flex; flex-direction:column; gap:14px;
  padding:0 15%;
  margin-bottom:32px;
  opacity:1; transform:none;
  animation:none;
  position:relative;
  z-index:5;
  pointer-events:auto;
}
.hero-selector::before,
.hero-selector::after{
  content:'';
  position:absolute;
  left:50%;
  transform:translateX(-50%);
  width:1px;
  height:44px;
  background:rgba(245,243,238,.18);
  transition:width .52s var(--ease), height .52s var(--ease), opacity .42s var(--ease), transform .52s var(--ease);
  pointer-events:none;
}
.hero-selector::before{ top:-52px; }
.hero-selector::after{ bottom:-50px; }

.hero-route-btn {
  pointer-events:auto;
  display:grid;
  place-items:center;
  align-content:center;
  justify-items:center;
  gap:3px;
  min-height:48px;
  padding:7px 18px;
  border-radius:999px;
  border:0.5px solid rgba(255,255,255,0.11);
  background:linear-gradient(180deg,rgba(255,255,255,0.042) 0%,rgba(255,255,255,0.014) 100%);
  background-color:rgba(255,255,255,0.014);
  backdrop-filter:blur(18px) saturate(114%); -webkit-backdrop-filter:blur(18px) saturate(114%);
  text-align:center; position:relative; overflow:hidden;
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.06), 0 8px 18px rgba(20,20,18,0.035);
  transform:translateZ(0);
  will-change:transform, opacity, backdrop-filter;
  transition:border-color .42s var(--ease),box-shadow .42s var(--ease),background-color .42s var(--ease),transform .52s var(--ease),opacity .42s var(--ease),padding .52s var(--ease),min-height .52s var(--ease),filter .42s var(--ease),flex-basis .52s var(--ease),max-width .52s var(--ease);
  -webkit-tap-highlight-color:transparent;
  width:100%;
  isolation:isolate;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
}
.hero-route-btn:active { transform:scale(0.98); }
.hero-route-btn::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:
    linear-gradient(180deg,rgba(255,255,255,0.058) 0%,rgba(255,255,255,0.012) 100%),
    radial-gradient(circle at 50% 0%,rgba(255,255,255,0.04),transparent 62%);
  opacity:.72;
  pointer-events:none;
  z-index:0;
  transition:opacity .42s var(--ease),background .42s var(--ease);
}
.hero-route-btn > span {
  position:relative;
  z-index:1;
  display:block;
  width:100%;
  text-align:center;
  margin-inline:auto;
  justify-self:center;
}
.hero-route-btn:nth-child(1){ opacity:0; transform:translateY(var(--move)) translateZ(0); animation:fadeUp .9s 1.04s var(--ease) forwards; }
.hero-route-btn:nth-child(2){ opacity:0; transform:translateY(var(--move)) translateZ(0); animation:fadeUp .9s 1.14s var(--ease) forwards; }

.scr-root.state-neutral.hero-return-ready .hero-eyebrow,
.scr-root.state-neutral.hero-return-ready .hero-headline,
.scr-root.state-neutral.hero-return-ready .hero-divider,
.scr-root.state-neutral.hero-return-ready .hero-sub,
.scr-root.state-neutral.hero-return-ready .hero-route-btn{
  opacity:1 !important;
  transform:translateY(0) translateZ(0) !important;
  animation:none !important;
  filter:none !important;
}

.scr-root.state-neutral.hero-return-ready .hero-headline .line-inner,
.scr-root.state-neutral.hero-return-ready .hero-sub .line-inner,
.scr-root.state-neutral.hero-return-ready .hero-statement .line-inner{
  opacity:1 !important;
  transform:translateY(0) !important;
  animation:none !important;
}

/* Texto: BLANCO cuando activo, GRIS cuando inactivo — nunca cambia de color */
.hrb-label {
  display:block;
  width:100%;
  font-family:var(--font-sans); font-size:11px; font-weight:500;
  letter-spacing:0.1em; text-transform:uppercase;
  color:rgba(255,255,255,0.6);
  transition:color .4s var(--ease);
  text-align:center;
  line-height:1.02;
  white-space:nowrap;
  align-self:center;
  margin-inline:auto;
}
.hrb-desc {
  display:block;
  width:100%;
  font-family:var(--font-serif); font-size:14px;
  font-style:italic; font-weight:300;
  color:rgba(255,255,255,0.28);
  max-height:1.4em;
  overflow:hidden;
  transform:translateY(0);
  transition:color .4s var(--ease), max-height .42s var(--ease), opacity .32s var(--ease), transform .42s var(--ease), margin .42s var(--ease);
  text-align:center;
  line-height:1.05;
  white-space:nowrap;
  align-self:center;
  margin-inline:auto;
}
.hrb-extra {
  display:block;
  width:100%;
  max-height:0;
  opacity:0;
  overflow:hidden;
  font-family:var(--font-sans);
  font-size:10px;
  font-weight:400;
  letter-spacing:0.035em;
  line-height:1.15;
  color:rgba(255,255,255,0.58);
  transform:translateY(8px);
  transition:max-height .48s var(--ease),opacity .32s var(--ease),transform .48s var(--ease),margin-top .48s var(--ease);
}

/* ACTIVO: texto blanco, contorno y sombra con color acento */
.hero-route-btn.active-vida {
  background:linear-gradient(180deg,rgba(162,84,54,0.14) 0%,rgba(162,84,54,0.08) 100%);
  border-color:var(--vida);
  box-shadow:0 4px 20px rgba(162,84,54,0.18);
}
.hero-route-btn.active-vida .hrb-label { color:rgba(255,255,255,0.95); }
.hero-route-btn.active-vida .hrb-desc  { color:rgba(255,255,255,0.65); }

.hero-route-btn.active-valor {
  background:linear-gradient(180deg,rgba(105,122,106,0.16) 0%,rgba(105,122,106,0.08) 100%);
  border-color:rgba(105,122,106,0.5);
  box-shadow:0 4px 20px rgba(105,122,106,0.18);
}
.hero-route-btn.active-valor .hrb-label { color:rgba(255,255,255,0.95); }
.hero-route-btn.active-valor .hrb-desc  { color:rgba(255,255,255,0.65); }

.scr-root.hero-route-previewing .hero-selector {
  gap:24px;
}
.scr-root.hero-route-previewing .hero-route-btn {
  opacity:.44;
  transform:scale(.94);
  filter:saturate(.82);
}
.scr-root.preview-vida #hero-btn-vida,
.scr-root.preview-valor #hero-btn-valor {
  opacity:1;
  transform:scale(1.02);
  filter:none;
  min-height:64px;
  padding-top:10px;
  padding-bottom:10px;
  border-color:rgba(255,255,255,0.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.12), 0 12px 28px rgba(20,20,18,0.08);
}
.scr-root.preview-vida #hero-btn-vida{
  transform:translateY(-8px) scale(1.03);
}
.scr-root.preview-vida #hero-btn-valor{
  transform:translateY(14px) scale(.9);
}
.scr-root.preview-valor #hero-btn-valor{
  transform:translateY(8px) scale(1.03);
}
.scr-root.preview-valor #hero-btn-vida{
  transform:translateY(-14px) scale(.9);
}
.scr-root.preview-vida #hero-btn-valor .hrb-desc,
.scr-root.preview-valor #hero-btn-vida .hrb-desc{
  max-height:0;
  opacity:0;
  transform:translateY(-8px);
  margin-top:-2px;
}
.scr-root.preview-vida #hero-btn-vida .hrb-extra,
.scr-root.preview-valor #hero-btn-valor .hrb-extra {
  max-height:2.7em;
  opacity:1;
  margin-top:2px;
  transform:translateY(0);
}
.scr-root.preview-vida .hero-selector::before{
  height:16px;
  transform:translateX(-50%);
}
.scr-root.preview-vida .hero-selector::after{
  height:40px;
  transform:translateX(-50%);
}
.scr-root.preview-valor .hero-selector::before{
  height:40px;
  transform:translateX(-50%);
}
.scr-root.preview-valor .hero-selector::after{
  height:16px;
  transform:translateX(-50%);
}

/* Indicador de scroll hacia abajo */
.hrb-hint,
.hrb-hint-line,
.hrb-hint-text,
.hrb-hint-arrow { display:none !important; }

/* Scroll cue — ANTES de los botones, centrado */
.hero-scroll-cue {
  display:flex; justify-content:center;
  margin-bottom:8px;
  opacity:0; animation:fadeIn 1.35s 1.89s var(--ease) forwards;
}
.hero-scroll-cue-bottom{
  margin-top:2px;
  margin-bottom:0;
  animation-delay:2.02s;
}
.scroll-bar {
  width:0.5px; height:22px;
  background:rgba(245,243,238,.15);
  position:relative; overflow:hidden;
  transition:height .52s var(--ease),opacity .42s var(--ease),background-color .42s var(--ease);
}
.scroll-bar::after {
  content:''; position:absolute; top:-100%; left:0; width:100%; height:60%;
  background:rgba(245,243,238,.7);
  animation:scrollDrop 1.8s 2.16s ease-in-out infinite;
}
.scr-root.hero-route-previewing .hero-scroll-cue .scroll-bar {
  height:14px;
  opacity:.46;
}
.scr-root.hero-route-previewing .hero-scroll-cue-bottom .scroll-bar {
  height:34px;
  opacity:.92;
}

/* En móvil solo vive el sistema de líneas del selector.
   Las barras de scroll cue duplicaban las verticales y se encimaban. */
.hero-scroll-cue,
.hero-scroll-cue-bottom{
  display:none;
}

/* ══════════════════════════════════════════════
   STICKY CTA
   Se mantiene visible en mobile y desktop para que el CTA
   acompañe todo el recorrido, incluido el motor inmersivo.
   ══════════════════════════════════════════════ */
.sticky-cta {
  position:fixed; bottom:0; left:0; right:0; z-index:150;
  padding-top:12px;
  padding-bottom:calc(12px + env(safe-area-inset-bottom));
  padding-left:15%;
  padding-right:15%;
  background:transparent;
  display:block;
  pointer-events:all;
}
.sticky-cta-btn {
  display:block;
  width:100%;
  font-family:var(--font-sans); font-size:11px; font-weight:500;
  letter-spacing:0.12em; text-transform:uppercase;
  padding:16px; border-radius:40px;
  border:0.5px solid rgba(255,255,255,0.25);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  background:rgba(255,255,255,0.12); color:rgba(255,255,255,0.9);
  transition:background .3s var(--ease),border-color .3s var(--ease),color .3s var(--ease);
  -webkit-tap-highlight-color:transparent;
  text-align:center;
}
.sticky-cta-btn:active { transform:scale(0.98); opacity:.85; }
.state-vida  .sticky-cta-btn { background:var(--vida);  border-color:var(--vida);  color:#F5F3EE; }
.state-valor .sticky-cta-btn { background:var(--valor); border-color:var(--valor); color:#F5F3EE; }

/* ══════════════════════════════════════════════
   SECCIONES DE CONTENIDO
   ══════════════════════════════════════════════ */
.route-section { display:none; }
.state-vida  .route-section.for-vida  { display:block; }
.state-valor .route-section.for-valor { display:block; }

.reveal {
  opacity:0; transform:translateY(var(--move));
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal.delay-1 { transition-delay:.1s; }
.reveal.delay-2 { transition-delay:.22s; }
.reveal.delay-3 { transition-delay:.36s; }

/* ══════════════════════════════════════════════
   ANIMACIONES
   ══════════════════════════════════════════════ */
@keyframes fadeUp  { from{opacity:0;transform:translateY(var(--move))} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }
@keyframes scrollDrop { 0%{top:-100%} 100%{top:200%} }
@keyframes bounceDown { 0%,100%{transform:translateY(0)} 50%{transform:translateY(4px)} }
@keyframes routeFadeIn { from{opacity:0;transform:translateY(14px)} to{opacity:1;transform:translateY(0)} }

/* Animación de máscara por línea — AMBOS formatos (mobile y desktop) */
.hero-headline .line-wrap { display:block; overflow:hidden; }
.hero-headline .line-inner { display:block; }

.hero-headline.exit .line-inner {
  transform:translateY(-105%); opacity:0;
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.hero-headline.enter .line-wrap { overflow:hidden; }
.hero-headline.enter .line-inner { animation:lineReveal .6s var(--ease) both; }
.hero-headline.enter .line-inner:nth-child(1) { animation-delay:0s; }
.hero-headline.enter .line-inner:nth-child(2) { animation-delay:.08s; }
.hero-headline.enter .line-inner:nth-child(3) { animation-delay:.16s; }
@keyframes lineReveal { from{transform:translateY(105%);opacity:0} to{transform:translateY(0);opacity:1} }

/* Anti-recorte visual: conserva las animaciones de máscara y evita cortar descendentes. */
.hero-headline .line-wrap,
.hero-sub .line-wrap,
.hero-statement .line-wrap {
  padding-bottom:.12em;
  margin-bottom:-.12em;
}

/* ══════════════════════════════════════════════
   TABLET 640px+
   ══════════════════════════════════════════════ */
@media (min-width:640px) {
  :root { --nav-h:64px; }
  .hero { padding-left:32px; padding-right:32px; }
  .hero-selector { padding:0 10%; gap:14px; }
  .hero-route-btn { min-height:50px; padding:7px 20px; gap:3px; }
}

/* ══════════════════════════════════════════════
   DESKTOP 1024px+
   ══════════════════════════════════════════════ */
@media (min-width:1024px) {
  :root { --nav-h:72px; }
  html { font-size:16px; }

  /* ── Nav desktop ── */
  .nav { justify-content:space-between; padding:0 60px; }
  .nav-logo { display:block; }
  .nav-hamburger { display:none !important; }
  .nav-cta-sm {
    display:flex !important;
    font-family:var(--font-sans); font-size:10px; font-weight:500;
    letter-spacing:0.1em; text-transform:uppercase;
    padding:8px 18px; border-radius:40px;
    border:0.5px solid var(--nav-cta-border);
    color:var(--nav-cta-color);
    background:var(--nav-cta-bg);
    transition:color .25s,border-color .25s,background .25s;
  }
  #root.state-vida .nav-cta-sm,
  .nav-cta-sm[data-route="vida"] {
    --nav-cta-bg: rgba(162,84,54,0.08);
    --nav-cta-border: rgba(162,84,54,0.16);
    --nav-cta-color: #7f4229;
  }
  #root.state-valor .nav-cta-sm,
  .nav-cta-sm[data-route="valor"] {
    --nav-cta-bg: rgba(105,122,106,0.08);
    --nav-cta-border: rgba(105,122,106,0.15);
    --nav-cta-color: #556657;
  }
  .nav-cta-sm:hover { color:var(--ink); border-color:var(--ink); }
  .nav-right { position:static; transform:none; }

  /* Selector absolutamente centrado */
  .nav-selector { position:absolute; left:50%; transform:translateX(-50%); }

  /* Chevron visible en desktop */
  .sel-chevron { display:inline; }
  .nav-sel-item:hover .sel-chevron { transform:rotate(90deg); }

  /* ── Submenús desktop ──
     Solo aparecen en el ítem cuyo botón tiene clase .active
     Controlado por JS (clase .submenu-open en nav-sel-item)
     NO se activan por hover — evita el problema de desaparecer
  ── */
  .sel-submenu {
    display:block;
    position:absolute; top:calc(100% + 14px); left:50%;
    transform:translateX(-50%) translateY(-6px);
    min-width:230px;
    background:rgba(245,243,238,0.97);
    backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
    border:0.5px solid var(--line); border-radius:12px;
    padding:6px 0; list-style:none;
    opacity:0; pointer-events:none;
    transition:opacity .25s var(--ease),transform .25s var(--ease);
    box-shadow:0 8px 32px rgba(20,20,18,.1); z-index:300;
  }
  .sel-submenu::before {
    content:''; position:absolute; top:-5px; left:50%;
    width:10px; height:10px; background:rgba(245,243,238,0.97);
    border-left:0.5px solid var(--line); border-top:0.5px solid var(--line);
    transform:translateX(-50%) rotate(45deg);
  }

  /* Solo abierto cuando el nav-sel-item tiene .submenu-open */
  .nav-sel-item.submenu-open .sel-submenu {
    opacity:1; pointer-events:all; transform:translateX(-50%) translateY(0);
  }

  .sel-sub-divider { display:block; height:0.5px; background:var(--line); margin:4px 0; }
  .sel-sub-item {
    display:flex; align-items:center; justify-content:space-between;
    padding:10px 20px; font-size:12px; font-weight:300;
    color:var(--ink); text-decoration:none; letter-spacing:.02em;
    transition:background .2s;
  }
  .sel-sub-item:hover { background:rgba(20,20,18,.04); }
  .sel-sub-item span { color:var(--muted); font-size:10px; transition:transform .2s,color .2s; }
  .sel-sub-item:hover span { transform:translateX(3px); color:var(--ink); }

  /* ── Hero desktop ── */
  .hero {
    justify-content:center; /* centrado vertical en desktop */
    padding-left:80px; padding-right:80px; padding-bottom:80px;
    padding-top:var(--nav-h);
  }
  .hero-content { justify-content:center; }

  .hero-headline { font-size:clamp(72px,8vw,108px); }

  /* Statement: altura fija = sin desfase entre rutas */
  .hero-statement {
    min-height:2.8em;
    margin-bottom:40px; /* más espacio antes de los botones */
  }

  /* Botones: desktop desacoplado de mobile; líneas pegadas a cada botón */
  .hero-selector {
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    align-items:center;
    justify-content:center;
    column-gap:32px;
    row-gap:0;
    max-width:1120px;
    width:min(1120px,100%);
    margin:0 auto;
    padding:0;
    margin-top:16px;
    margin-bottom:8px;
    transform:translateY(80px);
  }
  .hero-selector::before,
  .hero-selector::after{
    display:none;
  }
  .hero-route-btn {
    --hero-btn-width:360px;
    --hero-btn-height:52px;
    --hero-btn-pad-y:7px;
    --hero-btn-tail:156px;
    width:min(var(--hero-btn-width),100%);
    min-height:var(--hero-btn-height);
    max-width:none;
    padding:var(--hero-btn-pad-y) 24px;
    border-radius:999px;
    gap:3px;
    background:linear-gradient(180deg,rgba(255,255,255,0.055) 0%,rgba(255,255,255,0.016) 100%);
    background-color:rgba(255,255,255,0.016);
    transform:translateX(0);
    overflow:visible;
    transition:border-color .42s var(--ease),box-shadow .42s var(--ease),background-color .42s var(--ease),transform .52s var(--ease),opacity .42s var(--ease),padding .52s var(--ease),min-height .52s var(--ease),width .52s var(--ease),filter .42s var(--ease);
  }
  #hero-btn-vida{
    justify-self:end;
    transform-origin:right center;
  }
  #hero-btn-valor{
    justify-self:start;
    transform-origin:left center;
  }
  .hero-route-btn::before {
    background:
      linear-gradient(180deg,rgba(255,255,255,0.07) 0%,rgba(255,255,255,0.014) 100%),
      radial-gradient(circle at 50% 0%,rgba(255,255,255,0.042),transparent 64%);
    opacity:.74;
  }
  .hero-route-btn::after{
    content:'';
    position:absolute;
    top:50%;
    height:1px;
    width:var(--hero-btn-tail);
    background:rgba(245,243,238,.22);
    border-radius:999px;
    transform:translateY(-50%);
    transition:width .42s var(--ease),opacity .32s var(--ease);
    pointer-events:none;
  }
  #hero-btn-vida::after{
    right:calc(100% + 18px);
  }
  #hero-btn-valor::after{
    left:calc(100% + 18px);
  }
  .hrb-label {
    font-size:11px;
    text-align:center;
    line-height:1.02;
  }
  .hrb-desc {
    font-size:15px;
    flex:none;
    text-align:center;
    white-space:nowrap;
    overflow:hidden;
    line-height:1.03;
  }
  .hrb-extra {
    font-size:10px;
    letter-spacing:0.03em;
    white-space:nowrap;
  }
  .scr-root.hero-route-previewing .hero-selector {
    column-gap:40px;
  }
  .scr-root.hero-route-previewing .hero-route-btn {
    opacity:.44;
    filter:saturate(.82);
  }
  .scr-root.preview-vida #hero-btn-vida,
  .scr-root.preview-valor #hero-btn-valor {
    --hero-btn-width:448px;
    --hero-btn-height:64px;
    --hero-btn-pad-y:10px;
    --hero-btn-tail:84px;
    opacity:1;
    filter:none;
    border-color:rgba(255,255,255,0.24);
    box-shadow:inset 0 1px 0 rgba(255,255,255,0.12), 0 12px 28px rgba(20,20,18,0.08);
  }
  .scr-root.preview-vida #hero-btn-vida{
    transform:translateX(-10px);
  }
  .scr-root.preview-vida #hero-btn-valor{
    --hero-btn-width:224px;
    --hero-btn-height:40px;
    --hero-btn-pad-y:5px;
    --hero-btn-tail:228px;
    transform:translateX(26px);
  }
  .scr-root.preview-valor #hero-btn-valor{
    transform:translateX(10px);
  }
  .scr-root.preview-valor #hero-btn-vida{
    --hero-btn-width:224px;
    --hero-btn-height:40px;
    --hero-btn-pad-y:5px;
    --hero-btn-tail:228px;
    transform:translateX(-26px);
  }
  .scr-root.preview-vida #hero-btn-valor .hrb-desc,
  .scr-root.preview-valor #hero-btn-vida .hrb-desc{
    max-height:0;
    opacity:0;
    transform:translateY(-8px);
    margin-top:-2px;
  }
  .scr-root.preview-vida #hero-btn-vida .hrb-extra,
  .scr-root.preview-valor #hero-btn-valor .hrb-extra{
    max-height:2.7em;
    opacity:1;
    margin-top:2px;
    transform:translateY(0);
  }
  .scr-root:not(.state-neutral) .hero-route-btn{
    animation:none;
  }
  .scr-root:not(.state-neutral):not(.hero-route-previewing) .hero-route-btn{
    opacity:1;
    transform:translateX(0);
  }

  /* En desktop no deben aparecer las líneas verticales del scroll cue */
  .hero-scroll-cue,
  .hero-scroll-cue-bottom{
    display:none;
  }

  /* Scroll cue: flujo normal antes de los botones */
  .hero-scroll-cue {
    position:static;
    margin-bottom:8px;
    margin-top:0;
  }
  .hero-scroll-cue-bottom{
    margin-top:2px;
    margin-bottom:0;
  }
  .scroll-bar { height:26px; }

  /* Sin sticky inferior en desktop */
  #sticky-cta,
  .sticky-cta,
  #root .sticky-cta,
  .scr-root .sticky-cta,
  #root .sticky-cta .sticky-cta-btn {
    display:none !important;
    visibility:hidden !important;
    opacity:0 !important;
    pointer-events:none !important;
  }
}

/* ── XL ── */
@media (min-width:1440px) {
  .nav  { padding:0 60px; }
  .hero { padding-left:96px; padding-right:96px; }
  .hero-scroll-cue { right:96px; }
}

@media (max-width:900px) {
  .hero-route-logo { width:min(104px,28vw); }
}
