/* =========================================================
   REGULATIS — Amber Gold Edition
   Paleta dorada · glassmorphism · animaciones
   ========================================================= */

:root{
  /* Fondo cálido casi negro */
  --bg:        #0c0a05;
  --bg-2:      #14110a;
  --bg-soft:   #1b1609;

  /* Dorados / ámbar */
  --gold:      #FFD24A;
  --gold-2:    #F5B301;
  --gold-deep: #B97e07;
  --amber:     #FF9D2F;
  --cream:     #FFF3C4;

  /* Texto */
  --text:      #F7F1E2;
  --muted:     #b3a888;
  --line:      rgba(255,210,74,.14);

  /* Glass */
  --glass:     rgba(255,236,180,.05);
  --glass-2:   rgba(255,236,180,.08);
  --glass-bd:  rgba(255,221,130,.16);

  --radius:    22px;
  --radius-lg: 30px;
  --shadow:    0 30px 80px -30px rgba(0,0,0,.8);
  --glow:      0 0 60px -10px rgba(255,201,60,.55);

  --maxw: 1160px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; scrollbar-gutter:stable; }
body{
  font-family:"Inter",system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
h1,h2,h3,h4{ font-family:"Sora",sans-serif; line-height:1.05; letter-spacing:-.02em; }
::selection{ background:var(--gold); color:#1a1300; }

/* Accesibilidad: foco visible para teclado */
:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; border-radius:6px; }

/* ---------- Utilidades de color ---------- */
.grad{
  background:linear-gradient(105deg,var(--cream),var(--gold) 40%,var(--amber));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.muted{ color:var(--muted); }

/* =========================================================
   FONDOS ANIMADOS
   ========================================================= */
.bg-aurora{ position:fixed; inset:0; z-index:-3; overflow:hidden; }
.aurora{
  position:absolute; border-radius:50%; filter:blur(90px); opacity:.5;
  mix-blend-mode:screen; animation:drift 22s ease-in-out infinite;
}
.a1{ width:55vw; height:55vw; left:-10vw; top:-10vw;
     background:radial-gradient(circle,#F5B301,transparent 65%); }
.a2{ width:48vw; height:48vw; right:-12vw; top:18vh;
     background:radial-gradient(circle,#FF9D2F,transparent 65%); animation-delay:-7s; }
.a3{ width:50vw; height:50vw; left:25vw; bottom:-20vh;
     background:radial-gradient(circle,#FFD24A,transparent 65%); animation-delay:-13s; }

.bg-grid{
  position:fixed; inset:0; z-index:-2; pointer-events:none; opacity:.5;
  background:
    linear-gradient(rgba(255,210,74,.04) 1px,transparent 1px) 0 0/64px 64px,
    linear-gradient(90deg,rgba(255,210,74,.04) 1px,transparent 1px) 0 0/64px 64px,
    radial-gradient(circle at 50% 0%, transparent 55%, var(--bg) 90%);
  -webkit-mask-image:radial-gradient(circle at 50% 30%, #000 30%, transparent 80%);
          mask-image:radial-gradient(circle at 50% 30%, #000 30%, transparent 80%);
}

/* Glow del cursor */
.cursor-glow{
  position:fixed; width:380px; height:380px; border-radius:50%; z-index:-1;
  pointer-events:none; transform:translate(-50%,-50%); transition:opacity .4s;
  background:radial-gradient(circle,rgba(255,201,60,.12),transparent 60%);
  opacity:0;
}

/* Barra de progreso de scroll */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0%; z-index:100;
  background:linear-gradient(90deg,var(--gold-2),var(--gold),var(--cream));
  box-shadow:0 0 18px rgba(255,201,60,.7);
}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:90;
  transition:all .4s var(--ease);
}
.nav__inner{
  max-width:var(--maxw); margin:0 auto; padding:18px 26px;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.nav.is-stuck .nav__inner{
  margin-top:10px; padding:12px 22px; border-radius:60px;
  background:rgba(20,16,8,.65); backdrop-filter:blur(18px);
  border:1px solid var(--glass-bd); box-shadow:var(--shadow);
  max-width:calc(var(--maxw) - 40px);
}
.brand{ display:flex; align-items:center; gap:10px; font-family:"Sora"; font-weight:700; }
.brand__dot{
  width:14px; height:14px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--cream),var(--gold-2));
  box-shadow:var(--glow); animation:pulse 3s ease-in-out infinite;
}
.nav__links{ display:flex; gap:26px; font-size:.92rem; }
.nav__links a{ color:var(--muted); transition:color .25s; position:relative; }
.nav__links a:hover{ color:var(--text); }
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--gold); transition:width .3s var(--ease);
}
.nav__links a:hover::after{ width:100%; }

/* =========================================================
   BOTONES / PILLS
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; gap:8px; font-weight:600;
  padding:11px 20px; border-radius:40px; font-size:.92rem; cursor:pointer;
  transition:transform .25s var(--ease), box-shadow .25s, background .25s;
}
.btn span{ transition:transform .25s var(--ease); }
.btn:hover span{ transform:translateX(4px); }
.btn--ghost{ border:1px solid var(--glass-bd); background:var(--glass); color:var(--text); }
.btn--ghost:hover{ background:var(--glass-2); }
.btn--solid{
  background:linear-gradient(105deg,var(--gold),var(--amber));
  color:#1a1300; box-shadow:var(--glow);
}
.btn--solid:hover{ transform:translateY(-3px); box-shadow:0 0 80px -8px rgba(255,201,60,.8); }

.pill{
  display:inline-flex; align-items:center; padding:6px 14px; border-radius:30px;
  font-size:.78rem; letter-spacing:.04em; border:1px solid var(--glass-bd);
  background:var(--glass); color:var(--muted);
}
.pill--gold{ background:linear-gradient(105deg,var(--gold),var(--amber)); color:#1a1300; border:none; font-weight:600; }

/* =========================================================
   LAYOUT GENERAL
   ========================================================= */
.section{
  position:relative; max-width:var(--maxw); margin:0 auto;
  padding:120px 26px;
}
.section--center{ text-align:center; }
.h2{ font-size:clamp(2rem,5vw,3.6rem); font-weight:700; margin-bottom:18px; }
.h2--left{ text-align:left; max-width:820px; font-size:clamp(1.6rem,3.4vw,2.6rem); }
.lead{ color:var(--muted); max-width:560px; margin:0 auto 50px; font-size:1.05rem; }
.kicker{
  display:inline-block; color:var(--gold); font-size:.82rem; letter-spacing:.18em;
  text-transform:uppercase; margin-bottom:18px; font-weight:600;
}
.hint{ color:var(--muted); font-size:.85rem; margin-top:36px; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100vh; display:flex; flex-direction:column;
  justify-content:center; padding:150px 26px 90px; max-width:var(--maxw); margin:0 auto;
}
.hero__meta{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  position:absolute; top:96px; left:26px; right:26px;
}
.hero__credit{ color:var(--muted); font-size:.82rem; text-align:center; }
.hero__stage{ position:relative; display:flex; flex-direction:column; align-items:center; }
.hero__title{
  font-size:clamp(3rem,12vw,8.5rem); font-weight:800; text-align:center;
  position:relative; z-index:3; pointer-events:none;
  margin-bottom:clamp(1rem,2.5vw,2.5rem); /* gap real: el título queda ARRIBA del orbe, no encimado */
  text-shadow:0 20px 80px rgba(0,0,0,.6);
}
.hero__title .word{
  display:inline-block; opacity:0; transform:translateY(40px);
  animation:wordIn .9s var(--ease) forwards; animation-delay:calc(var(--i) * .12s + .2s);
}
.hero__title .word:first-child{ color:var(--text); }

/* Orbe */
.orb-wrap{ position:relative; margin-top:0; z-index:2; }
.orb{
  position:relative; width:min(42vw,380px); height:min(42vw,380px);
  display:grid; place-items:center; animation:float 7s ease-in-out infinite;
}
.orb__core{
  position:absolute; inset:8%; border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#FFE9A3,#F5B301 45%,#9c6a06 80%);
  box-shadow:0 0 120px 10px rgba(255,180,40,.55), inset 0 0 80px rgba(255,255,255,.25);
  animation:pulse 5s ease-in-out infinite;
}
.orb__ring{
  position:absolute; inset:0; border-radius:50%;
  border:1px solid rgba(255,221,130,.35); animation:spin 18s linear infinite;
}
.orb__ring--2{ inset:-9%; border-style:dashed; border-color:rgba(255,221,130,.18);
  animation-duration:30s; animation-direction:reverse; }
.iso-logo{ position:relative; width:42%; z-index:2; filter:drop-shadow(0 14px 30px rgba(0,0,0,.5));
  animation:float 5s ease-in-out infinite .6s; }

.spark{
  position:absolute; width:10px; height:10px; border-radius:50%;
  background:radial-gradient(circle,var(--cream),var(--gold-2));
  box-shadow:0 0 16px var(--gold); animation:float 6s ease-in-out infinite;
}
.s1{ top:6%; left:14%; animation-delay:-1s; }
.s2{ top:20%; right:8%; width:7px; height:7px; animation-delay:-3s; }
.s3{ bottom:14%; left:6%; width:6px; height:6px; animation-delay:-2s; }
.s4{ bottom:8%; right:18%; animation-delay:-4s; }

/* Tarjetas flotantes */
.float-card{
  position:absolute; z-index:4; padding:14px 18px; border-radius:18px;
  background:var(--glass-2); backdrop-filter:blur(16px);
  border:1px solid var(--glass-bd); box-shadow:var(--shadow);
  display:flex; gap:12px; align-items:center; animation:float 6s ease-in-out infinite;
}
.float-card__icon{
  display:grid; place-items:center; width:36px; height:36px; border-radius:11px;
  background:linear-gradient(135deg,var(--gold),var(--amber)); color:#1a1300; font-size:1.1rem;
}
.float-card strong{ display:block; font-family:"Sora"; font-size:.95rem; }
.float-card small{ color:var(--muted); font-size:.78rem; }
.float-card--tl{ left:2%; top:46%; animation-delay:-2s; }
.float-card--br{ right:1%; bottom:6%; flex-direction:column; align-items:flex-start; gap:10px; }
.float-card__head{ display:flex; gap:12px; align-items:center; }
.chips{ display:flex; flex-wrap:wrap; gap:6px; }
.chip{ font-size:.72rem; padding:4px 10px; border-radius:20px;
  border:1px solid var(--glass-bd); background:var(--glass); }

.hero__scroll{ display:flex; flex-direction:column; align-items:center; gap:10px;
  position:absolute; left:50%; bottom:30px; transform:translateX(-50%);
  color:var(--muted); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; }
.hero__mouse{ width:22px; height:36px; border:1px solid var(--glass-bd); border-radius:14px;
  display:grid; justify-items:center; padding-top:6px; }
.hero__mouse i{ width:4px; height:8px; border-radius:4px; background:var(--gold);
  animation:scrollDot 1.6s ease-in-out infinite; }

/* =========================================================
   LAPTOP / TABLET MOCKUPS (CSS)
   ========================================================= */
.laptop{ position:relative; width:min(720px,92%); margin:20px auto 0; }
.laptop__screen{
  border-radius:16px 16px 0 0; padding:12px; background:#0a0803;
  border:2px solid rgba(255,221,130,.18); border-bottom:none; aspect-ratio:16/10; overflow:hidden;
}
.laptop__base{
  height:18px; border-radius:0 0 16px 16px;
  background:linear-gradient(#3a2f12,#1a1408);
  border:2px solid rgba(255,221,130,.18); position:relative;
}
.laptop__base::after{ content:""; position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:80px; height:5px; border-radius:0 0 8px 8px; background:rgba(255,221,130,.2); }
.laptop__glow{ position:absolute; inset:auto 10% -30px; height:120px; filter:blur(50px); z-index:-1;
  background:radial-gradient(ellipse,rgba(255,180,40,.5),transparent 70%); }

.tablet{ position:relative; width:min(420px,90%); }
.tablet__screen{ border-radius:22px; padding:14px; background:#0a0803;
  border:2px solid rgba(255,221,130,.18); aspect-ratio:4/3; overflow:hidden; }
.tablet__glow{ position:absolute; inset:auto 10% -24px; height:90px; filter:blur(44px); z-index:-1;
  background:radial-gradient(ellipse,rgba(255,180,40,.45),transparent 70%); }

/* UI fake dentro de mockups */
.ui{ display:flex; height:100%; gap:10px; background:linear-gradient(160deg,#15110a,#0d0a05);
  border-radius:10px; padding:10px; font-size:0; }
.ui__side{ width:46px; display:flex; flex-direction:column; gap:8px; }
.ui__logo{ width:24px; height:24px; border-radius:7px; background:linear-gradient(135deg,var(--gold),var(--amber)); }
.ui__nav{ height:9px; border-radius:5px; background:rgba(255,221,130,.1); }
.ui__nav.on{ background:linear-gradient(90deg,var(--gold),var(--amber)); }
.ui__main{ flex:1; display:flex; flex-direction:column; gap:8px; }
.ui__bar{ display:flex; justify-content:space-between; align-items:center; }
.ui__crumb{ font-size:9px; color:var(--muted); font-family:"Inter"; }
.ui__avatar{ width:18px; height:18px; border-radius:50%; background:linear-gradient(135deg,var(--gold),var(--amber)); }
.ui__row{ display:flex; gap:8px; align-items:center; font-size:9px; color:var(--text); font-family:"Inter"; }
.ui__row span{ width:6px; height:6px; border-radius:50%; background:var(--gold); }
.ui__q{ height:14px; border-radius:6px; background:rgba(255,221,130,.07);
  border:1px solid rgba(255,221,130,.08); }
.ui__q.wide{ background:linear-gradient(90deg,rgba(255,201,60,.18),rgba(255,221,130,.05)); }
.ui--compact .ui__cols{ display:flex; gap:8px; height:100%; }
.ui__col{ flex:1; display:flex; flex-direction:column; gap:7px; }
.ui__col span{ height:13px; border-radius:5px; background:rgba(255,221,130,.07); }
.ui__col span.on{ background:linear-gradient(90deg,var(--gold),var(--amber)); }
.ui--mini{ height:70px; display:flex; flex-direction:row; gap:6px; padding:8px; }
.ui--mini span{ flex:1; border-radius:5px; background:rgba(255,221,130,.08); }
.ui--mini.hot span:nth-child(2){ background:linear-gradient(180deg,var(--gold),var(--amber)); }

/* =========================================================
   OVERVIEW
   ========================================================= */
.overview__grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:60px; align-items:center; }
.overview__lead{ font-size:1.5rem; font-family:"Sora"; line-height:1.4; margin:8px 0 26px; font-weight:400; }
.tags{ display:flex; flex-wrap:wrap; gap:10px; }
.tag{ padding:9px 18px; border-radius:30px; border:1px solid var(--glass-bd);
  background:var(--glass); font-size:.88rem; transition:all .3s var(--ease); cursor:default; }
.tag:hover, .tag.is-on{ background:linear-gradient(105deg,var(--gold),var(--amber));
  color:#1a1300; border-color:transparent; transform:translateY(-2px); }
.overview__visual{ position:relative; height:340px; }
.glass-tile{
  position:absolute; border-radius:20px; background:var(--glass-2); backdrop-filter:blur(14px);
  border:1px solid var(--glass-bd); display:grid; place-items:center; font-size:1.6rem;
  color:var(--gold); box-shadow:var(--shadow); animation:float 7s ease-in-out infinite;
}
.gt1{ width:90px; height:90px; top:0; left:6%; animation-delay:-1s; }
.gt2{ width:70px; height:70px; bottom:8%; left:0; animation-delay:-3s; }
.gt3{ width:62%; height:78%; right:0; top:12%; overflow:hidden; }
.gt3.portrait{ padding:0; }
.gt3 img{ width:100%; height:100%; object-fit:cover; filter:saturate(.85) contrast(1.05) sepia(.18); }
.gt3.noimg{ background:linear-gradient(135deg,var(--gold-deep),var(--bg-soft)); }
.gt3.noimg::after{ content:"PERSONA"; font-family:"Sora"; font-size:.8rem; letter-spacing:.2em; color:var(--cream); }

/* =========================================================
   PROCESS TIMELINE
   ========================================================= */
.timeline{ display:grid; grid-template-columns:repeat(6,1fr); gap:16px; margin-top:50px; }
.tl-card{
  position:relative; padding:24px 18px; border-radius:var(--radius); min-height:230px;
  background:var(--glass); border:1px solid var(--glass-bd);
  display:flex; flex-direction:column; transition:transform .35s var(--ease), box-shadow .35s;
}
.tl-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.tl-card--hot{ background:linear-gradient(165deg,rgba(255,201,60,.22),rgba(255,157,47,.08)); }
.tl-num{ font-family:"Sora"; font-size:.8rem; color:var(--gold); margin-bottom:auto; opacity:.8; }
.tl-card h3{ font-size:1.05rem; margin:40px 0 12px; }
.tl-card p{ font-size:.85rem; color:var(--muted); }

/* =========================================================
   PERSONA ANALYSIS
   ========================================================= */
.persona__stage{ position:relative; min-height:520px; margin-top:40px;
  display:flex; align-items:center; justify-content:center; }
.bubble{
  position:absolute; border:none; cursor:pointer; background:none; padding:0;
  width:74px; height:74px; border-radius:50%; animation:float 7s ease-in-out infinite;
  transition:transform .3s var(--ease); z-index:3;
}
.bubble img{ width:100%; height:100%; border-radius:50%; object-fit:cover;
  border:2px solid var(--glass-bd); box-shadow:0 10px 30px rgba(0,0,0,.5); }
.bubble img.noimg{ visibility:hidden; }
.bubble::after{ /* fallback dorado si no carga la imagen */
  content:""; position:absolute; inset:0; border-radius:50%; z-index:-1;
  background:linear-gradient(135deg,var(--gold-deep),var(--bg-soft)); }
.bubble__tag{ position:absolute; left:50%; bottom:-26px; transform:translateX(-50%);
  white-space:nowrap; font-size:.7rem; color:var(--muted);
  background:rgba(20,16,8,.8); padding:3px 10px; border-radius:20px;
  border:1px solid var(--glass-bd); opacity:0; transition:opacity .3s; }
.bubble:hover{ transform:scale(1.12); }
.bubble:hover .bubble__tag{ opacity:1; }
.bubble.is-active img{ border-color:var(--gold); box-shadow:0 0 30px rgba(255,201,60,.7); }
.b1{ top:4%;  left:14%; animation-delay:-1s; }
.b2{ top:2%;  right:18%; animation-delay:-3s; }
.b3{ bottom:30%; left:6%; animation-delay:-2s; }
.b4{ top:30%; right:6%; animation-delay:-4s; }
.bubble--main{ position:relative; width:120px; height:120px; margin-bottom:300px; z-index:5; }
.bubble--main img{ border-color:var(--gold); box-shadow:0 0 40px rgba(255,201,60,.6); }

.persona-card{
  position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:min(720px,94%); padding:30px 34px; border-radius:var(--radius-lg);
  background:linear-gradient(160deg,rgba(255,201,60,.14),var(--glass));
  border:1px solid var(--glass-bd); backdrop-filter:blur(18px); box-shadow:var(--shadow);
  text-align:left;
}
.persona-card__head{ display:flex; align-items:center; gap:14px; margin-bottom:20px; }
.persona-card__head strong{ font-family:"Sora"; font-size:1.3rem; }
.persona-card__row{ display:grid; grid-template-columns:120px 1fr; gap:18px; padding:12px 0;
  border-top:1px solid var(--line); }
.persona-card__label{ color:var(--gold); font-weight:600; font-size:.9rem; }
.persona-card__row p{ color:var(--muted); font-size:.92rem; }

/* =========================================================
   NAV DEMO / PALETTE
   ========================================================= */
.nav-demo{ display:flex; gap:30px; align-items:center; justify-content:center; flex-wrap:wrap; margin-top:30px; }
.palette-card{ padding:24px; border-radius:var(--radius); background:var(--glass);
  border:1px solid var(--glass-bd); text-align:left; box-shadow:var(--shadow);
  animation:float 8s ease-in-out infinite; }
.swatches{ display:flex; gap:8px; margin:14px 0 10px; }
.swatches span{ width:34px; height:48px; border-radius:10px; background:var(--c);
  border:1px solid rgba(255,255,255,.08); }

/* =========================================================
   USER FLOW
   ========================================================= */
.flow{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:50px; }
.flow-node{ padding:22px; border-radius:var(--radius); background:var(--glass);
  border:1px solid var(--glass-bd); transition:transform .3s var(--ease), box-shadow .3s; position:relative; }
.flow-node:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--gold-deep); }
.flow-node--accent{ background:linear-gradient(160deg,rgba(255,201,60,.18),rgba(255,157,47,.05)); }
.flow-node h4{ font-size:1.05rem; margin-bottom:14px; padding-bottom:14px; border-bottom:1px solid var(--line); }
.flow-node ul{ list-style:none; display:flex; flex-direction:column; gap:8px; }
.flow-node li{ color:var(--muted); font-size:.88rem; padding-left:18px; position:relative; }
.flow-node li::before{ content:"›"; position:absolute; left:0; color:var(--gold); }

/* =========================================================
   A/B TESTING
   ========================================================= */
.ab{ display:grid; grid-template-columns:1fr 1fr; gap:24px; max-width:880px; margin:50px auto 0; }
.ab-card{ padding:24px; border-radius:var(--radius-lg); background:var(--glass);
  border:1px solid var(--glass-bd); text-align:left; transition:transform .35s var(--ease); }
.ab-card:hover{ transform:translateY(-6px); }
.ab-card--win{ background:linear-gradient(160deg,rgba(255,201,60,.2),rgba(255,157,47,.06));
  border-color:var(--gold-deep); box-shadow:var(--glow); }
.ab-card__tag{ display:inline-block; font-size:.78rem; padding:5px 14px; border-radius:20px;
  background:var(--glass-2); border:1px solid var(--glass-bd); margin-bottom:16px; }
.ab-card__tag--win{ background:linear-gradient(105deg,var(--gold),var(--amber)); color:#1a1300; border:none; font-weight:600; }
.ab-card__stats{ display:flex; gap:30px; margin-top:18px; }
.ab-card__stats > div{ flex:1; }
.ab-card__stats span{ display:block; font-size:.78rem; margin-bottom:4px; }
.ab-card__stats b{ font-family:"Sora"; font-size:1.8rem; }
.progress{ height:7px; border-radius:6px; background:rgba(255,221,130,.1); margin-top:10px; overflow:hidden; }
.progress i{ display:block; height:100%; width:0; border-radius:6px;
  background:linear-gradient(90deg,var(--gold-2),var(--gold),var(--cream));
  transition:width 1.4s var(--ease); }

/* =========================================================
   CTA / FOOTER
   ========================================================= */
.cta{ position:relative; text-align:center; padding:140px 26px; overflow:hidden; }
.cta__orb{ position:absolute; left:50%; top:40%; transform:translate(-50%,-50%);
  width:520px; height:520px; border-radius:50%; z-index:-1; filter:blur(20px);
  background:radial-gradient(circle,rgba(255,180,40,.3),transparent 60%);
  animation:pulse 6s ease-in-out infinite; }
.footer{ max-width:var(--maxw); margin:0 auto; padding:40px 26px; display:flex;
  justify-content:space-between; gap:16px; flex-wrap:wrap; border-top:1px solid var(--line);
  font-size:.85rem; color:var(--muted); }

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
[data-reveal]{ opacity:0; transform:translateY(36px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
[data-reveal].in{ opacity:1; transform:none; }

/* =========================================================
   KEYFRAMES
   ========================================================= */
@keyframes float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-16px); } }
@keyframes drift{ 0%,100%{ transform:translate(0,0) scale(1); } 33%{ transform:translate(4%,3%) scale(1.08); }
  66%{ transform:translate(-3%,-2%) scale(.96); } }
@keyframes pulse{ 0%,100%{ transform:scale(1); opacity:1; } 50%{ transform:scale(1.05); opacity:.85; } }
@keyframes spin{ to{ transform:rotate(360deg); } }
@keyframes wordIn{ to{ opacity:1; transform:none; } }
@keyframes scrollDot{ 0%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(10px); opacity:0; } 100%{ opacity:0; } }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .nav__links{ display:none; }
  .overview__grid{ grid-template-columns:1fr; }
  .overview__visual{ height:300px; }
  .timeline{ grid-template-columns:repeat(2,1fr); }
  .flow{ grid-template-columns:1fr; }
  .ab{ grid-template-columns:1fr; }
  .hero__meta{ display:none; }
  .float-card--tl{ left:-2%; top:54%; transform:scale(.85); }
  .float-card--br{ right:-2%; transform:scale(.85); }
  .persona-card__row{ grid-template-columns:1fr; gap:4px; }
  .bubble{ width:56px; height:56px; }
  .bubble--main{ width:90px; height:90px; }
}
@media (max-width:560px){
  .section{ padding:80px 20px; }
  .timeline{ grid-template-columns:1fr; }
  .hero__title{ font-size:clamp(3rem,20vw,5rem); margin-bottom:0; }
  /* En móvil las tarjetas flotantes tapan el orbe: las ocultamos */
  .float-card{ display:none; }
  .orb{ width:78vw; height:78vw; margin-top:10px; }
  .nav__cta{ display:none; }
  .ab-card__stats{ gap:18px; }
  .persona__stage{ min-height:600px; }
}

/* Accesibilidad: respeta reduce motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.01ms !important; }
  [data-reveal]{ opacity:1; transform:none; }
}

/* =========================================================
   COMPONENTES EDÉN (manzana, árbol, pitch, interactivos)
   ========================================================= */

/* Logo árbol (nav) — quieto, sin animación */
.brand__tree{ width:34px; height:34px;
  filter:drop-shadow(0 0 10px rgba(255,201,60,.55)); }

/* Manzana (orbe hero) */
.apple-logo{ position:relative; width:48%; z-index:2;
  filter:drop-shadow(0 18px 34px rgba(80,45,2,.55)); animation:float 5s ease-in-out infinite .6s; }

/* Hero: tamaños + pitch */
.hero__title{ font-size:clamp(2.6rem,11vw,7.5rem); margin-bottom:clamp(.8rem,2vw,2rem); }
.orb{ width:min(40vw,340px); height:min(40vw,340px); }
.hero__pitch{ max-width:700px; margin:38px auto 0; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:18px; position:relative; z-index:5; }
.hero__pitch-title{ font-family:"Sora"; font-size:clamp(1.3rem,2.6vw,2rem); font-weight:600; line-height:1.25; }
.hero__pitch-sub{ color:var(--muted); max-width:560px; }
.hero__scroll{ position:static; transform:none; margin:34px auto 0; }

/* Tarjetas de valor (expandibles) */
.value-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px;
  max-width:980px; margin:50px auto 60px; text-align:left; }
.value-card{ position:relative; padding:26px 22px; border-radius:var(--radius);
  background:var(--glass); border:1px solid var(--glass-bd); color:var(--text);
  cursor:pointer; font:inherit; overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s, background .35s; }
.value-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.value-card.open{ background:linear-gradient(160deg,rgba(255,201,60,.16),var(--glass)); }
.value-card__num{ font-family:"Sora"; color:var(--gold); font-size:.85rem; opacity:.8; }
.value-card h3{ font-size:1.1rem; margin:12px 0 10px; }
.value-card p{ color:var(--muted); font-size:.9rem; }
.value-card .more{ max-height:0; opacity:0; overflow:hidden; color:var(--muted); font-size:.88rem;
  transition:max-height .45s var(--ease), opacity .35s, margin .35s, padding .35s; }
.value-card.open .more{ max-height:220px; opacity:1; margin-top:14px; padding-top:14px; border-top:1px solid var(--line); }
.value-card__toggle{ position:absolute; top:22px; right:22px; width:26px; height:26px; border-radius:50%;
  display:grid; place-items:center; background:var(--glass-2); border:1px solid var(--glass-bd);
  color:var(--gold); font-size:1.1rem; line-height:1; }

/* Metodología: cards expandibles */
.tl-card{ cursor:pointer; }
.tl-card .more{ max-height:0; opacity:0; overflow:hidden; color:var(--muted); font-size:.82rem;
  transition:max-height .45s var(--ease), opacity .35s, margin .35s, padding .35s; }
.tl-card.open .more{ max-height:220px; opacity:1; margin-top:12px; padding-top:12px; border-top:1px solid var(--line); }
.tl-card.open{ background:linear-gradient(165deg,rgba(255,201,60,.22),rgba(255,157,47,.08)); }

/* Burbujas de servicio (iconos) */
.bubble--svc{ display:grid; place-items:center;
  background:linear-gradient(160deg,var(--glass-2),rgba(255,201,60,.06));
  border:1px solid var(--glass-bd); backdrop-filter:blur(10px); box-shadow:0 10px 30px rgba(0,0,0,.45); }
.bubble--svc::after{ display:none; }
.bubble--svc svg{ width:48%; height:48%; fill:none; stroke:var(--gold); stroke-width:2;
  stroke-linecap:round; stroke-linejoin:round; transition:stroke .3s, fill .3s; }
.bubble--svc svg circle{ fill:var(--gold); stroke:none; }
.bubble--svc.is-active{ background:linear-gradient(160deg,rgba(255,201,60,.4),rgba(255,157,47,.14));
  box-shadow:0 0 32px rgba(255,201,60,.6); border-color:var(--gold); }
.bubble--svc.is-active svg{ stroke:#1a1300; }
.bubble--svc.is-active svg circle{ fill:#1a1300; }

/* Marca central (árbol) */
.bubble--brand{ display:grid; place-items:center; cursor:default; }
.bubble--brand::after{ display:none; }
.bubble--brand svg{ width:80%; height:80%; filter:drop-shadow(0 0 18px rgba(255,201,60,.5)); }

/* KPI card */
.kpi-card{ min-width:250px; }
.kpi-list{ list-style:none; display:flex; flex-direction:column; gap:14px; margin-top:14px; }
.kpi-list li{ display:flex; align-items:baseline; gap:12px; }
.kpi-list b{ font-family:"Sora"; font-size:1.6rem; color:var(--gold); min-width:96px; }
.kpi-list small{ color:var(--muted); }

/* Tile con árbol */
.tree-tile{ display:grid; place-items:center;
  background:linear-gradient(135deg,rgba(255,201,60,.12),var(--glass)); }
.tree-tile svg{ width:64%; filter:drop-shadow(0 0 16px rgba(255,201,60,.4)); }

/* Pie de tarjeta de resultados */
.ab-card__foot{ margin-top:16px; color:var(--muted); font-size:.9rem; }
.ab-card__foot b{ color:var(--gold); }

/* =========================================================
   FOUNDER / QUIÉN ESTÁ DETRÁS
   ========================================================= */
.founder__grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:center; }
.founder__intro{ color:var(--muted); font-size:1.05rem; margin:6px 0 32px; max-width:520px; }

/* Trayectoria interactiva */
.cv-timeline{ position:relative; display:flex; flex-direction:column; gap:14px; padding-left:28px; }
.cv-timeline::before{ content:""; position:absolute; left:7px; top:10px; bottom:10px; width:2px;
  background:linear-gradient(var(--gold),transparent); opacity:.4; }
.cv-item{ position:relative; text-align:left; background:var(--glass); border:1px solid var(--glass-bd);
  border-radius:16px; padding:16px 18px; cursor:pointer; font:inherit; color:var(--text); overflow:hidden;
  transition:transform .3s var(--ease), background .3s, box-shadow .3s; }
.cv-item:hover{ transform:translateX(4px); box-shadow:var(--shadow); }
.cv-dot{ position:absolute; left:-28px; top:20px; width:14px; height:14px; border-radius:50%;
  background:radial-gradient(circle at 30% 30%,var(--cream),var(--gold-2)); box-shadow:var(--glow); }
.cv-year{ font-family:"Sora"; color:var(--gold); font-size:.8rem; letter-spacing:.04em; }
.cv-item h4{ font-size:1.02rem; margin-top:4px; }
.cv-item .more{ max-height:0; opacity:0; overflow:hidden; color:var(--muted); font-size:.88rem;
  transition:max-height .5s var(--ease), opacity .35s, margin .35s, padding .35s; }
.cv-item.open .more{ max-height:280px; opacity:1; margin-top:12px; padding-top:12px; border-top:1px solid var(--line); }
.cv-item.open{ background:linear-gradient(160deg,rgba(255,201,60,.16),var(--glass)); }
.cv-item--now .cv-dot{ animation:pulse 2.4s ease-in-out infinite; }

/* Retrato */
.founder__photo{ position:relative; display:grid; place-items:center; min-height:440px; }
.founder__photo img{ position:relative; z-index:2; width:100%; max-width:430px; border-radius:24px;
  filter:grayscale(1) contrast(1.06) sepia(.55) saturate(1.5) hue-rotate(-12deg) brightness(1.03);
  -webkit-mask-image:radial-gradient(ellipse 78% 88% at 50% 42%, #000 52%, transparent 92%);
          mask-image:radial-gradient(ellipse 78% 88% at 50% 42%, #000 52%, transparent 92%);
  animation:float 7s ease-in-out infinite; }
.founder__ring{ position:absolute; width:min(92%,430px); aspect-ratio:1; border-radius:50%;
  border:1px dashed rgba(255,221,130,.25); animation:spin 26s linear infinite; }
.founder__glow{ position:absolute; width:70%; height:70%; border-radius:50%; filter:blur(55px);
  background:radial-gradient(circle,rgba(255,180,40,.42),transparent 65%); animation:pulse 5s ease-in-out infinite; }
.founder__label{ position:absolute; bottom:5%; left:50%; transform:translateX(-50%); z-index:3; text-align:center;
  background:rgba(20,16,8,.72); backdrop-filter:blur(12px); border:1px solid var(--glass-bd);
  border-radius:16px; padding:10px 24px; white-space:nowrap; box-shadow:var(--shadow); }
.founder__label strong{ font-family:"Sora"; display:block; font-size:1.05rem; }
.founder__label small{ color:var(--muted); font-size:.78rem; }
/* fallback sin imagen */
.founder__photo.noimg::after{ content:"Guardá tu foto en  assets/founder.png"; z-index:2; max-width:280px;
  text-align:center; color:var(--muted); font-size:.85rem; padding:60px 40px; border:1px dashed var(--glass-bd);
  border-radius:24px; background:var(--glass); }

/* =========================================================
   SERVICIOS: campo de burbujas arriba + tarjeta CENTRADA estable
   ========================================================= */
.persona__stage{ display:flex; flex-direction:column; align-items:center; gap:38px;
  min-height:auto; margin-top:40px; }
.bubble-field{ position:relative; width:100%; max-width:680px; height:280px; margin:0 auto; }
.bubble-field .b1{ top:2%;  left:5%;   right:auto; bottom:auto; }
.bubble-field .b2{ top:8%;  right:6%;  left:auto;  bottom:auto; }
.bubble-field .b3{ bottom:4%; left:15%; top:auto;  right:auto; }
.bubble-field .b4{ bottom:0;  right:17%; top:auto; left:auto; }
/* árbol central, centrado y con float que respeta el centrado */
.bubble-field .bubble--main{ position:absolute; left:50%; top:50%; margin:0;
  transform:translate(-50%,-50%); animation:brandFloat 6s ease-in-out infinite; }
@keyframes brandFloat{
  0%,100%{ transform:translate(-50%,-50%); }
  50%{ transform:translate(-50%,calc(-50% - 12px)); }
}
/* tarjeta de servicio: en flujo, siempre centrada */
.persona-card{ position:static; left:auto; bottom:auto; transform:none;
  width:min(760px,100%); margin:0 auto; }

/* =========================================================
   CASOS / TRABAJOS
   ========================================================= */
.casos-metrics{ display:flex; flex-wrap:wrap; gap:40px; margin:26px 0 48px; }
.casos-metrics > div{ min-width:140px; }
.casos-metrics b{ font-family:"Sora"; font-size:2.6rem; color:var(--gold); display:block; line-height:1; }
.casos-metrics small{ color:var(--muted); font-size:.9rem; }

.casos-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.caso{ position:relative; background:var(--glass); border:1px solid var(--glass-bd);
  border-radius:var(--radius); overflow:hidden; cursor:pointer;
  transition:transform .35s var(--ease), box-shadow .35s, border-color .35s; }
.caso:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:var(--gold-deep); }
.caso--feature{ grid-column:1 / -1; display:grid; grid-template-columns:1.05fr .95fr; align-items:stretch;
  background:linear-gradient(160deg,rgba(255,201,60,.14),var(--glass)); }
.caso__media{ position:relative; aspect-ratio:16/10; overflow:hidden;
  background:linear-gradient(135deg,var(--bg-soft),#241a08); }
.caso--feature .caso__media{ aspect-ratio:auto; min-height:280px; }
.caso__media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.caso:hover .caso__media img{ transform:scale(1.05); }
.caso__media.noimg::after{ content:"⤢  " attr(data-ph); position:absolute; inset:0; display:grid;
  place-items:center; color:var(--muted); font-size:.82rem; letter-spacing:.02em;
  background:repeating-linear-gradient(45deg,rgba(255,201,60,.04),rgba(255,201,60,.04) 12px,transparent 12px,transparent 24px); }
.caso__body{ padding:26px; display:flex; flex-direction:column; gap:8px; }
.caso--feature .caso__body{ justify-content:center; gap:10px; }
.caso__badge{ align-self:flex-start; font-size:.72rem; padding:5px 12px; border-radius:20px;
  background:var(--glass-2); border:1px solid var(--glass-bd); color:var(--muted); }
.caso__badge--soon{ background:linear-gradient(105deg,var(--gold),var(--amber)); color:#1a1300; border:none; font-weight:600; }
.caso__body h3{ font-size:1.25rem; }
.caso--feature .caso__body h3{ font-size:1.7rem; }
.caso__body p{ color:var(--muted); font-size:.92rem; }
.caso__client{ display:flex; align-items:center; gap:10px; font-size:.85rem; color:var(--text); }
.caso__logo{ width:30px; height:30px; border-radius:8px; overflow:hidden; display:grid; place-items:center;
  background:var(--glass-2); border:1px solid var(--glass-bd); }
.caso__logo img{ width:100%; height:100%; object-fit:cover; }
.caso__logo.noimg::after{ content:"◆"; color:var(--gold); font-size:.8rem; }
.caso__result{ color:var(--gold); font-size:.86rem; font-weight:600; margin-top:2px; }
.caso .more{ max-height:0; opacity:0; overflow:hidden; color:var(--muted); font-size:.88rem;
  transition:max-height .5s var(--ease), opacity .35s, margin .35s, padding .35s; }
.caso.open .more{ max-height:260px; opacity:1; margin-top:10px; padding-top:12px; border-top:1px solid var(--line); }
.caso__expand{ color:var(--gold); font-size:.85rem; font-weight:600; margin-top:6px; align-self:flex-start; }
.caso__link{ color:var(--gold); font-size:.88rem; font-weight:600; margin-top:6px; align-self:flex-start; }
.caso__link:hover{ text-decoration:underline; }

.casos-logos{ margin-top:54px; text-align:center; }
.casos-logos__title{ display:block; color:var(--muted); font-size:.82rem; letter-spacing:.12em;
  text-transform:uppercase; margin-bottom:20px; }
.logo-strip{ display:flex; flex-wrap:wrap; justify-content:center; gap:16px; }
.logo-strip span{ padding:12px 24px; border-radius:14px; background:var(--glass); border:1px solid var(--glass-bd);
  color:var(--muted); font-size:.85rem; transition:all .3s var(--ease); }
.logo-strip span:hover{ color:var(--text); border-color:var(--gold-deep); transform:translateY(-3px); }

/* Responsive de los nuevos componentes */
@media (max-width:900px){
  .value-cards{ grid-template-columns:1fr; max-width:480px; }
  .kpi-card{ width:100%; }
  .founder__grid{ grid-template-columns:1fr; gap:40px; }
  .founder__photo{ order:-1; min-height:360px; }
  .bubble-field{ max-width:420px; height:240px; }
  .casos-grid{ grid-template-columns:1fr; }
  .caso--feature{ grid-template-columns:1fr; }
}

/* Founder sin foto: columna de trayectoria a la derecha */
.founder__cv{ width:100%; }

/* Caso con logo (no screenshot): logo centrado sobre degradado */
.caso__media--logo{ display:grid; place-items:center; padding:24px;
  background:linear-gradient(135deg,#241a08,var(--bg-soft)); }
.caso__media--logo img{ width:auto; height:auto; max-width:78%; max-height:78%; object-fit:contain; }

/* Caso "próximamente": atenuado */
.caso--soon{ opacity:.72; }
.caso--soon:hover{ opacity:1; }

/* Tira de logos: imágenes reales */
.logo-strip__img{ display:inline-flex; align-items:center; justify-content:center; padding:12px 22px; }
.logo-strip__img img{ height:26px; width:auto; display:block; object-fit:contain; opacity:.9; }
.logo-strip__img.noimg{ display:none; }
.casos-sectores{ margin-top:18px; color:var(--muted); font-size:.85rem; }
.casos-sectores b{ color:var(--text); font-weight:600; }

/* Capturas reales dentro de los mockups (laptop/tablet) */
.laptop__screen .screen-shot, .tablet__screen .screen-shot{
  width:100%; height:100%; object-fit:cover; object-position:top center;
  border-radius:8px; display:block; }

/* CTA final: WhatsApp + Email */
.cta__actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta__contact{ margin-top:22px; color:var(--muted); font-size:.92rem;
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap; align-items:center; }
.cta__contact a{ color:var(--gold); }
.cta__contact a:hover{ text-decoration:underline; }

/* =========================================================
   LOGO NAV (img original + respaldo SVG) · MENÚ MÓVIL · SCROLL-SPY
   ========================================================= */
.brand__logo{ width:36px; height:36px; display:inline-grid; place-items:center; }
.brand__img{ width:36px; height:36px; object-fit:contain; }
.brand__logo .brand__tree{ display:none; }       /* respaldo oculto si la img carga */
.brand__logo.noimg .brand__tree{ display:block; }

/* Hamburguesa */
.nav__burger{ display:none; width:44px; height:44px; padding:0; cursor:pointer;
  border:1px solid var(--glass-bd); background:var(--glass); border-radius:12px;
  flex-direction:column; align-items:center; justify-content:center; gap:5px; }
.nav__burger span{ display:block; width:20px; height:2px; border-radius:2px; background:var(--text);
  transition:transform .3s var(--ease), opacity .3s; }
.nav__burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.open span:nth-child(2){ opacity:0; }
.nav__burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* Overlay menú móvil */
.mobile-menu{ position:fixed; inset:0; z-index:95; display:grid; place-items:center;
  background:rgba(10,8,4,.97); backdrop-filter:blur(16px);
  opacity:0; pointer-events:none; transition:opacity .35s var(--ease); }
.mobile-menu.open{ opacity:1; pointer-events:auto; }
.mobile-menu__links{ display:flex; flex-direction:column; align-items:center; gap:26px; }
.mobile-menu__links a{ font-family:"Sora"; font-size:1.6rem; color:var(--muted); transition:color .25s; }
.mobile-menu__links a.active, .mobile-menu__links a:hover{ color:var(--text); }
.mobile-menu__cta{ margin-top:14px; font-size:1rem !important; color:#1a1300 !important; }
body.menu-open{ overflow:hidden; }

/* Link activo (scroll-spy) */
.nav__links a.active{ color:var(--text); }
.nav__links a.active::after{ width:100%; }

@media (max-width:900px){
  .nav__burger{ display:flex; }
  .nav__cta{ display:none; }   /* en móvil el CTA vive dentro del overlay */
}
