/* ============================================================
   BILINGU — Pitch Deck por diapositivas
   Slides a pantalla completa · slider lateral · animaciones por slide
   Identidad visual real de la app de Bilingu
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,500&display=swap');

:root {
  --b-50:#F4F1FE; --b-100:#EBE5FD; --b-200:#D9CCFB; --b-300:#BEA6F7;
  --b-400:#9E76F1; --b-500:#8350EA; --b-600:#6E39E1; --b-700:#5E2DC5;
  --b-800:#4E26A3; --b-900:#412185; --b-950:#2A1459;
  --accent:#7738FF; --brand-dark:#8D64E8;
  --teal-300:#4fd1c5; --green:#22C55E; --red:#FF6B6B; --gold:#FFD66B;
  --ink:#201F1F; --ink-soft:#5b5766; --paper:#f8fafc; --white:#fff;
  --radius:16px; --radius-lg:24px;
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow-md:0 4px 12px rgba(0,0,0,.08);
  --shadow-lg:0 10px 30px rgba(0,0,0,.12);
  --shadow-xl:0 20px 60px rgba(42,20,89,.18);
  --glow:0 0 60px rgba(131,80,234,.45);
  --ease:cubic-bezier(.22,1,.36,1);
}

* { box-sizing:border-box; margin:0; padding:0; }
html,body { height:100%; }
body {
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,sans-serif;
  color:var(--ink); background:var(--b-950); line-height:1.4;
  -webkit-font-smoothing:antialiased; overflow:hidden;
}
img { max-width:100%; display:block; }

/* ============================================================
   Deck + Slides
   ============================================================ */
/* Lienzo fijo 16:9 (estilo PPT/PDF) — se escala entero para caber en cualquier pantalla */
#viewport { position:fixed; inset:0; overflow:hidden; background:#140a2c; }
#stage { position:absolute; top:50%; left:50%; width:1280px; height:720px; transform-origin:center center; overflow:hidden; box-shadow:0 30px 90px rgba(0,0,0,.5); }

#deck { position:absolute; inset:0; overflow:hidden; }
.slide {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  padding:54px 76px 54px 64px;   /* el slider lateral ya no reserva ancho (es un popover al hover) */
  opacity:0; visibility:hidden;
  transform:translateX(60px) scale(.98);
  transition:opacity .55s var(--ease), transform .65s var(--ease), visibility .55s;
  overflow:hidden;
}
.slide.active   { opacity:1; visibility:visible; transform:none; z-index:2; }
.slide.left     { transform:translateX(-60px) scale(.98); }   /* ya vista (sale a la izq) */
.slide--cover   { padding:0; }
.slide-inner { width:100%; max-width:1024px; max-height:100%; }

/* backgrounds */
.section--dark  { background:radial-gradient(120% 130% at 80% 0%, var(--b-500) 0%, var(--b-700) 50%, var(--b-950) 100%); color:#fff; }
.section--deep  { background:radial-gradient(120% 120% at 50% 0%, var(--b-700) 0%, var(--b-950) 100%); color:#fff; }
.section--paper { background:var(--paper); color:var(--ink); }
.section--soft  { background:linear-gradient(180deg,#fff 0%, var(--b-50) 100%); color:var(--ink); }

/* ============================================================
   Typography
   ============================================================ */
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:var(--b-600); background:var(--b-100); padding:8px 16px; border-radius:999px; margin-bottom:20px;
}
.section--dark .eyebrow, .section--deep .eyebrow { color:#fff; background:rgba(255,255,255,.14); }
h1,h2,h3 { line-height:1.06; letter-spacing:-.02em; font-weight:800; }
.title { font-size:48px; margin-bottom:16px; }
.lead { font-size:20px; color:var(--ink-soft); max-width:760px; font-weight:500; }
.section--dark .lead, .section--deep .lead { color:rgba(255,255,255,.84); }
.hl { color:var(--b-600); }
.section--dark .hl, .section--deep .hl { color:var(--gold); }
mark.ph { background:rgba(234,144,16,.18); color:#EA9010; font-weight:700; padding:0 8px; border-radius:6px; white-space:nowrap; }
.section--dark mark.ph, .section--deep mark.ph { background:rgba(255,214,107,.22); color:var(--gold); }

/* ============================================================
   Per-element entrance animations (replay on slide enter)
   ============================================================ */
.anim { opacity:0; transform:translateY(26px); }
.anim--left  { transform:translateX(-40px); }
.anim--right { transform:translateX(40px); }
.anim--scale { transform:scale(.85); }
.anim--pop   { transform:scale(.6); }
.anim--down  { transform:translateY(-26px); }
.anim--lateral { transform:translateX(90px); }   /* aparición lateral (desde la derecha) */
.slide.active .anim {
  opacity:1; transform:none;
  transition:opacity .7s var(--ease), transform .8s var(--ease);
  transition-delay:calc(var(--i,0) * .11s + .12s);
}
.slide.active .anim--pop { transition-timing-function:cubic-bezier(.34,1.56,.64,1); }
@media (prefers-reduced-motion: reduce) {
  .slide { transition:opacity .3s; transform:none !important; }
  .anim { opacity:1 !important; transform:none !important; }
}

/* ============================================================
   Lateral slider (rail)
   ============================================================ */
#rail {
  position:absolute; right:26px; top:0; bottom:0; z-index:300;
  display:flex; align-items:center; justify-content:flex-end; pointer-events:none;
}
/* Popover de títulos: oculto por defecto, aparece (integrado) al pasar por encima del rail */
#rail .labels {
  position:absolute; right:30px; top:50%; transform:translateY(-50%) translateX(12px);
  display:flex; flex-direction:column; gap:5px; align-items:flex-end; text-align:right;
  padding:16px 20px; border-radius:18px;
  background:rgba(20,10,44,.62); backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.14); box-shadow:0 24px 60px rgba(0,0,0,.42);
  opacity:0; pointer-events:none;
  transition:opacity .26s var(--ease), transform .34s var(--ease);
}
#rail:hover .labels { opacity:1; transform:translateY(-50%) translateX(0); pointer-events:auto; }
#rail .labels button {
  background:none; border:0; cursor:pointer; font-family:inherit; white-space:nowrap;
  font-size:13px; font-weight:700; letter-spacing:.02em;
  color:rgba(255,255,255,.55); padding:3px 0; display:flex; gap:10px; align-items:center; justify-content:flex-end;
  transition:color .2s, transform .2s;
}
#rail .labels button .n { font-variant-numeric:tabular-nums; opacity:.55; font-size:11px; min-width:16px; }
#rail .labels button:hover { color:#fff; transform:translateX(-3px); }
#rail .labels button.on { color:#fff; }
#rail .labels button.on .n { opacity:1; color:var(--accent); }

#rail .track {
  position:relative; width:6px; height:520px;
  background:rgba(255,255,255,.22); border-radius:999px; pointer-events:auto; cursor:pointer;
}
/* zona de hover ampliada alrededor de la barra para abrir el popover con facilidad */
#rail .track::before { content:""; position:absolute; top:-18px; bottom:-18px; left:-40px; right:-18px; }
#rail .track .fill {
  position:absolute; top:0; left:0; right:0; height:0;
  background:linear-gradient(180deg,var(--accent),var(--teal-300)); border-radius:999px;
  transition:height .5s var(--ease);
}
#rail .track .thumb {
  position:absolute; left:50%; top:0; width:20px; height:20px; border-radius:50%;
  background:#fff; box-shadow:0 4px 14px rgba(0,0,0,.35); transform:translate(-50%,-50%);
  transition:top .5s var(--ease); cursor:grab;
}
#rail .track .thumb:active { cursor:grabbing; }
#rail .track .thumb::after {
  content:""; position:absolute; inset:5px; border-radius:50%; background:var(--b-600);
}
/* light-theme rail */
#rail.light .labels { background:rgba(255,255,255,.86); border-color:rgba(110,57,225,.16); box-shadow:0 24px 60px rgba(60,40,110,.2); }
#rail.light .labels button { color:rgba(60,40,110,.5); }
#rail.light .labels button:hover, #rail.light .labels button.on { color:var(--b-700); }
#rail.light .labels button.on .n { color:var(--b-600); }
#rail.light .track { background:rgba(110,57,225,.22); }
#rail.light .track .thumb { box-shadow:0 4px 14px rgba(110,57,225,.35); }

/* ============================================================
   Bottom controls
   ============================================================ */
#hud {
  position:absolute; left:0; right:0; bottom:0; z-index:300;
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 40px; pointer-events:none;
}
#hud .logo { height:26px; pointer-events:auto; margin-left:40px; }
#hud .right { display:flex; align-items:center; gap:14px; pointer-events:auto; }
#hud .count { font-size:14px; font-weight:700; color:#fff; opacity:.85; font-variant-numeric:tabular-nums; }
#hud .count .cur { font-size:18px; }
.navbtn {
  width:46px; height:46px; border-radius:50%; border:0; cursor:pointer;
  display:grid; place-items:center; font-size:20px; color:#fff;
  background:rgba(255,255,255,.14); backdrop-filter:blur(8px);
  transition:background .2s, transform .15s;
}
.navbtn:hover { background:rgba(255,255,255,.28); }
.navbtn:active { transform:scale(.92); }
.navbtn:disabled { opacity:.25; cursor:default; }
/* light theme hud */
#hud.light .count { color:var(--b-800); }
#hud.light .navbtn { background:rgba(110,57,225,.12); color:var(--b-700); }
#hud.light .navbtn:hover { background:rgba(110,57,225,.22); }
/* logo: blanco en fondos oscuros, lila en fondos claros */
#hud .logo--lila { display:none; }
#hud.light .logo--white { display:none; }
#hud.light .logo--lila { display:inline-block; }
/* override: forzar logo blanco en slides claras con zona oscura abajo-izq (p.ej. slide 2) */
#hud.light.logo-white .logo--white { display:inline-block; }
#hud.light.logo-white .logo--lila { display:none; }

/* top progress */
#bar { position:absolute; top:0; left:0; height:4px; width:0; z-index:320;
  background:linear-gradient(90deg,var(--accent),var(--teal-300)); transition:width .5s var(--ease); }

/* ============================================================
   COVER slide (portada · layout home bilingu.com: texto izq · partners der)
   ============================================================ */
/* portada: lienzo fijo 1280×720 · texto izq + partners der, columnas separadas */
.cover { position:relative; width:1280px; max-width:none; height:720px; }
.cover .copy { position:absolute; left:76px; top:50%; transform:translateY(-50%); width:372px; z-index:3; text-align:left; }
.cover .logo { height:48px; filter:brightness(0) invert(1); margin-bottom:30px; }
.cover .kicker { display:inline-block; font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:20px; }
.cover .badge {
  display:inline-flex; align-items:center; gap:9px; font-size:13px; font-weight:700; color:#fff;
  background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.26);
  padding:8px 16px; border-radius:999px; margin-bottom:24px;
}
.cover .badge .stars { color:var(--gold); letter-spacing:1px; }
.cover h1 { font-size:54px; line-height:1.04; letter-spacing:-.03em; font-weight:800; }
.cover h1 .grad { color:#fff; }
.cover h1 .muted { color:rgba(255,255,255,.5); font-weight:700; }
.cover .sub { font-size:20px; color:rgba(255,255,255,.82); font-weight:500; margin-top:20px; max-width:400px; }
.cover .credit { margin-top:30px; font-size:15px; color:rgba(255,255,255,.72); font-weight:600; }
.cover .credit b { color:#fff; }
/* partners: columna derecha, anclados abajo, separados del texto */
.cover .art { position:absolute; right:24px; bottom:0; z-index:1; display:flex; align-items:flex-end; }
.cover .group { height:auto; width:auto; max-height:660px; max-width:880px; object-fit:contain; object-position:bottom; filter:brightness(.93) saturate(1.03) drop-shadow(0 24px 44px rgba(0,0,0,.34)); }
/* aparición fluida y simpática (una sola vez, luego se queda quieto) */
.slide.active .cover .group { animation:partners-in 1.1s cubic-bezier(.22,1.12,.36,1) both; animation-delay:.18s; }
@keyframes partners-in {
  0%   { opacity:0; transform:translateY(64px) scale(.92); }
  60%  { opacity:1; }
  100% { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(34,197,94,.6);} 70%{box-shadow:0 0 0 12px rgba(34,197,94,0);} 100%{box-shadow:0 0 0 0 rgba(34,197,94,0);} }

/* ============================================================
   Timeline (compact, 3 cols)
   ============================================================ */
/* Slide "Quién soy": Adrià recortado (sin marco), entra desde abajo a la izq · texto a la der */
.slide--intro { padding:0; }
.intro { position:relative; width:1280px; max-width:none; height:720px; }
.intro .copy { position:absolute; left:452px; right:auto; top:50%; transform:translateY(-50%); width:740px; z-index:2; text-align:left; }
.intro .photo { position:absolute; left:0; bottom:0; z-index:1; display:flex; align-items:flex-end; }
.intro .adria-cut { height:600px; width:auto; max-width:520px; object-fit:contain; object-position:bottom; filter:drop-shadow(0 14px 26px rgba(60,40,110,.16)); }
/* entra desde abajo, una sola vez */
.intro .adria-cut { opacity:0; transform:translateY(80px); }
.slide.active .intro .adria-cut { opacity:1; transform:none; transition:opacity .85s var(--ease), transform 1.05s cubic-bezier(.22,1,.36,1); transition-delay:.2s; }

/* Slide con vídeo de fondo (Gonnafit) */
.slide--video { padding:0; background:#0a0420; color:#fff; }
.video-bg { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; background:#0a0420; }
.video-bg iframe { position:absolute; top:50%; left:50%; width:100%; height:100%;
  transform:translate(-50%,-50%) scale(1.35); /* overscan para ocultar UI de YouTube */
  border:0; pointer-events:none; }
.video-scrim { position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(90deg, rgba(8,3,24,.9) 0%, rgba(8,3,24,.6) 42%, rgba(8,3,24,.18) 78%, rgba(8,3,24,.05) 100%),
             linear-gradient(0deg, rgba(8,3,24,.7) 0%, rgba(8,3,24,0) 46%); }
.video-content { position:absolute; z-index:2; inset:0; padding:54px 84px; display:flex; flex-direction:column; justify-content:space-between; text-align:left; }
.video-content > div:last-child { max-width:620px; }
.slide--video .eyebrow { color:#fff; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.18); }
.slide--video .title { color:#fff; }
.slide--video .hl { color:var(--gold); }
.slide--video .lead { color:rgba(255,255,255,.88); }
/* pill de logo (también la usa Cuideo, con su propio scope) */
.hero-pill { display:inline-flex; align-items:center; background:#fff; border-radius:999px; padding:9px 18px; box-shadow:0 8px 22px rgba(0,0,0,.3); margin-bottom:18px; }
.hero-pill img { height:24px; width:auto; }
.vchips { display:flex; gap:12px; margin-top:26px; flex-wrap:wrap; }
.vchip { background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.24); backdrop-filter:blur(8px);
  padding:10px 16px; border-radius:999px; font-size:14px; font-weight:600; color:#fff; }

/* Mensajes secuenciados sobre el vídeo (Gonnafit) */
.gseq { position:absolute; z-index:2; left:64px; top:50%; transform:translateY(-50%); max-width:660px; text-align:left; }
.gseq .g-tag, .gseq .msg { opacity:0; }
.slide.active .gseq .g-tag, .slide.active .gseq .msg {
  animation:msg-in .85s cubic-bezier(.22,1,.36,1) both; animation-delay:var(--delay,0s);
}
@keyframes msg-in { from { opacity:0; transform:translateY(28px); filter:blur(7px); } to { opacity:1; transform:none; filter:blur(0); } }
.gseq .g-tag { display:inline-block; font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  color:#fff; background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.2); padding:8px 16px; border-radius:999px; margin-bottom:22px; }
.gseq .msg--big { font-size:68px; font-weight:800; line-height:1.0; letter-spacing:-.03em; color:#fff; }
.gseq .msg--big .hl { color:var(--gold); }
.gseq .msg--sub { font-size:25px; font-weight:600; color:rgba(255,255,255,.92); margin-top:18px; max-width:560px; line-height:1.32; }
.gseq .warn-row { display:flex; gap:14px; margin-top:26px; flex-wrap:wrap; }
.gseq .msg--warn { display:inline-flex; align-items:center; gap:10px; font-size:20px; font-weight:700; color:#fff;
  background:rgba(255,107,107,.16); border:1px solid rgba(255,107,107,.55); backdrop-filter:blur(8px);
  padding:11px 20px; border-radius:999px; }
.gseq .msg--warn .ic { color:#FF6B6B; font-size:22px; line-height:1; }

/* mini-timeline del background */
/* subtítulo + timeline horizontal (slide Quién soy) */
.intro .subt { font-size:18px; font-weight:600; color:var(--ink-soft); margin-top:14px; line-height:1.4; }
/* antesala a Cuideo (slide presentación) — fondo crema como las slides de Cuideo */
.slide--intro.intro--cream { background:#F6F2E9; }
.intro .tease { font-size:20px; font-weight:600; color:#16324A; line-height:1.4; margin-top:28px; }
.intro .tease b { font-weight:800; }
/* tarjeta de experiencia (captura LinkedIn de Cuideo) */
.intro .li-card { width:608px; max-width:100%; margin-top:16px; }
.intro .li-card img { width:100%; height:auto; display:block; border-radius:14px; filter:drop-shadow(0 18px 40px rgba(22,50,74,.16)); }
/* "A continuación" con el estilo del breadcrumb (cnav) para conectar con la sección Cuideo */
.intro .next { display:flex; align-items:center; gap:22px; margin-top:32px; }
.intro .next-lbl { font-size:12px; font-weight:800; letter-spacing:.08em; text-transform:uppercase; color:rgba(22,50,74,.5); }
.intro .nstep { display:flex; gap:24px; }
.intro .nstep span { display:flex; align-items:center; gap:9px; font-size:14px; font-weight:800; letter-spacing:.03em; text-transform:uppercase; color:#16324A; }
.intro .nstep .num { width:24px; height:24px; border-radius:50%; background:#F2B705; color:#16324A; display:grid; place-items:center; font-size:12px; font-weight:800; }
.htl { position:relative; display:flex; align-items:flex-start; justify-content:flex-start; gap:40px; margin-top:36px; }
.htl .node { flex:0 0 auto; width:180px; display:flex; flex-direction:column; align-items:center; text-align:center; position:relative; }
.htl .node:not(:first-child)::before { content:""; position:absolute; top:32px; left:-40px; width:40px; height:3px; background:#e4e0ee; z-index:0; }
.htl .badge { position:relative; z-index:1; width:180px; height:66px; background:#fff; border:1px solid #e4e0ee; border-radius:16px;
  display:flex; align-items:center; justify-content:center; box-shadow:0 8px 22px rgba(60,40,110,.1); }
.htl .badge img { max-height:30px; max-width:142px; width:auto; height:auto; }
.htl .badge img.big-logo { max-height:38px; max-width:152px; }
.htl .hnm { font-size:23px; font-weight:800; color:var(--ink); margin-top:16px; letter-spacing:-.01em; }
.htl .yrs { font-size:16px; font-weight:800; color:var(--ink); margin-top:10px; background:#fff; border:1px solid #e4e0ee; padding:5px 14px; border-radius:999px; }
.htl .node.now .badge { border-color:var(--b-300); box-shadow:0 10px 26px rgba(110,57,225,.18); }
.htl .node.now .yrs { color:var(--b-700); border-color:var(--b-300); }

.tl3 { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:30px; }
.tl3 .card { background:#fff; border:1px solid var(--b-100); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); position:relative; }
.tl3 .card.now { background:var(--b-600); color:#fff; box-shadow:var(--glow); }
.tl3 .ic { width:46px; height:46px; border-radius:14px; background:var(--b-100); display:grid; place-items:center; font-size:24px; margin-bottom:14px; }
.tl3 .card.now .ic { background:rgba(255,255,255,.2); }
.tl3 .yr { font-size:13px; font-weight:800; color:var(--b-600); letter-spacing:.03em; }
.tl3 .card.now .yr { color:var(--gold); }
.tl3 h3 { font-size:19px; margin:3px 0 8px; }
.tl3 p { font-size:14px; color:var(--ink-soft); }
.tl3 .card.now p { color:rgba(255,255,255,.9); }

/* ============================================================
   Stat / KPI cards
   ============================================================ */
.stat-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:36px; }
.stat { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); border-radius:var(--radius); padding:26px 22px; backdrop-filter:blur(6px); }
.section--paper .stat, .section--soft .stat { background:#fff; border:1px solid var(--b-100); box-shadow:var(--shadow-sm); }
.stat .num { font-size:42px; font-weight:800; letter-spacing:-.02em; }
.section--paper .stat .num, .section--soft .stat .num { color:var(--b-600); }
.stat .lbl { font-size:14px; font-weight:600; opacity:.82; margin-top:6px; }
.note { margin-top:22px; font-size:13px; opacity:.62; font-style:italic; }

/* ============================================================
   Team
   ============================================================ */
.team-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-top:36px; }
.person { background:#fff; border-radius:var(--radius-lg); padding:28px; box-shadow:var(--shadow-lg); border:1px solid var(--b-100); display:flex; gap:20px; align-items:flex-start; }
.person .ava { width:84px; height:84px; border-radius:22px; display:grid; place-items:center; font-size:38px; flex:0 0 auto; box-shadow:var(--shadow-md); }
.person h3 { font-size:22px; }
.person .role { font-size:13px; font-weight:700; color:var(--b-600); margin:4px 0 10px; text-transform:uppercase; letter-spacing:.04em; }
.person p { color:var(--ink-soft); font-size:15px; }
.tandem-badge { display:inline-flex; align-items:center; gap:10px; margin-top:24px; background:var(--b-600); color:#fff; padding:13px 22px; border-radius:999px; font-weight:700; box-shadow:var(--glow); }

/* ============================================================
   Solution
   ============================================================ */
.partners-row { display:flex; gap:0; justify-content:center; margin:26px 0; flex-wrap:wrap; }
.partner-chip { text-align:center; margin:0 -10px; transition:transform .35s var(--ease); }
.partner-chip:hover { transform:translateY(-8px) scale(1.05); z-index:5; }
.partner-chip img { width:120px; height:120px; border-radius:50%; object-fit:cover; border:5px solid #fff; box-shadow:var(--shadow-lg); background:var(--b-100); }
.partner-chip .nm { font-size:14px; font-weight:700; margin-top:8px; }
.partner-chip .lg { font-size:13px; color:var(--ink-soft); }

.feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:8px; }
.feat { background:#fff; border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); border:1px solid var(--b-100); transition:transform .35s var(--ease),box-shadow .35s var(--ease); }
.feat:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.feat .ico { width:48px; height:48px; border-radius:14px; background:var(--b-100); display:grid; place-items:center; font-size:24px; margin-bottom:14px; }
.feat h3 { font-size:19px; margin-bottom:7px; color:var(--ink); }
.feat p { color:var(--ink-soft); font-size:14px; }

/* ============================================================
   Market channels
   ============================================================ */
.channels { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-top:36px; }
.channel { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius); padding:22px 16px; text-align:center; position:relative; }
.channel .ico { font-size:32px; margin-bottom:10px; }
.channel h4 { font-size:16px; margin-bottom:6px; }
.channel p { font-size:13px; opacity:.75; }
.channel.redzone { border-color:rgba(255,107,107,.5); background:rgba(255,107,107,.1); }
.channel.win { border-color:rgba(154,255,198,.5); background:rgba(154,255,198,.08); }
.channel .tag { position:absolute; top:-10px; left:50%; transform:translateX(-50%); font-size:11px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; background:var(--red); color:#fff; padding:3px 10px; border-radius:999px; }

/* ocean (red ocean) */
.ocean-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:36px; align-items:center; margin-top:30px; }
.bigstat { font-size:108px; font-weight:800; letter-spacing:-.04em; line-height:.95; color:var(--red); }
.bigstat small { display:block; font-size:17px; font-weight:600; color:rgba(255,255,255,.8); letter-spacing:0; margin-top:8px; }
.mkt-split { list-style:none; margin-top:22px; display:flex; flex-direction:column; gap:11px; }
.mkt-split li { display:flex; align-items:baseline; gap:16px; padding-top:11px; border-top:1px solid rgba(255,255,255,.16); }
.mkt-split b { font-size:30px; font-weight:800; letter-spacing:-.02em; color:var(--gold); flex:0 0 auto; min-width:90px; }
.mkt-split span { font-size:13.5px; font-weight:600; color:rgba(255,255,255,.78); line-height:1.35; }
.contrast-card { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18); border-radius:var(--radius-lg); padding:26px; }
.contrast-card ul { list-style:none; }
.contrast-card li { display:flex; gap:12px; padding:9px 0; border-bottom:1px solid rgba(255,255,255,.1); font-size:15px; }
.contrast-card li:last-child { border:0; }
.contrast-card li .x { color:var(--red); font-weight:800; }

/* insight split */
.split { display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:32px; }
.split-card { border-radius:var(--radius-lg); padding:30px; }
.split-card.red { background:#fff; border:2px dashed #FFB4B4; }
.split-card.blue { background:var(--b-600); color:#fff; box-shadow:var(--glow); }
.split-card h3 { font-size:21px; margin-bottom:6px; }
.split-card .k { font-size:13px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; margin-bottom:12px; }
.split-card.red .k { color:var(--red); }
.split-card.blue .k { color:var(--gold); }
.split-card p { font-size:15px; }
.split-card.red p { color:var(--ink-soft); }
.split-card.blue p { color:rgba(255,255,255,.9); }
.flow { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:28px; }
.flow .node { background:#fff; border:1px solid var(--b-100); border-radius:14px; padding:14px 20px; font-weight:700; box-shadow:var(--shadow-sm); font-size:15px; }
.flow .node.hot { background:var(--b-600); color:#fff; box-shadow:var(--glow); }
.flow .arrow { color:var(--b-400); font-size:24px; font-weight:800; }

/* traction */
.quote-row { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:36px; }
.qcard { background:#fff; border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-md); border-left:4px solid var(--green); }
.qcard .qbig { font-size:34px; font-weight:800; color:var(--b-600); }
.qcard p { color:var(--ink-soft); font-size:14px; margin-top:6px; }

/* model */
.model-grid { display:grid; grid-template-columns:1fr 1fr; gap:36px; align-items:center; margin-top:36px; }
.price-card { background:linear-gradient(160deg,var(--b-600),var(--b-800)); color:#fff; border-radius:var(--radius-lg); padding:32px; box-shadow:var(--shadow-xl); text-align:center; }
.price-card .pl { font-size:15px; opacity:.85; }
.price-card .pv { font-size:60px; font-weight:800; letter-spacing:-.03em; }
.price-card .pv span { font-size:22px; opacity:.8; }
.price-card .per { font-size:14px; opacity:.8; margin-top:4px; }
.price-card hr { border:0; border-top:1px solid rgba(255,255,255,.2); margin:20px 0; }
.seat-row { display:flex; justify-content:space-between; font-size:14px; padding:7px 0; }
.model-points { list-style:none; }
.model-points li { display:flex; gap:14px; align-items:flex-start; padding:13px 0; border-bottom:1px solid var(--b-100); }
.model-points li .ck { width:28px; height:28px; flex:0 0 auto; border-radius:50%; background:var(--b-100); color:var(--b-600); display:grid; place-items:center; font-weight:800; }
.model-points li b { display:block; font-size:16px; }
.model-points li span { color:var(--ink-soft); font-size:14px; }

/* funnel */
.funnel { display:flex; flex-direction:column; align-items:center; gap:12px; margin-top:30px; }
.funnel .layer { border-radius:var(--radius); padding:20px 26px; text-align:center; color:#fff; box-shadow:var(--shadow-md); display:flex; flex-direction:column; gap:3px; }
.funnel .layer .ln { font-size:13px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; opacity:.9; }
.funnel .layer .lv { font-size:34px; font-weight:800; }
.funnel .layer .ld { font-size:13px; opacity:.85; }
.funnel .l1 { width:100%; max-width:740px; background:var(--b-400); }
.funnel .l2 { width:80%; max-width:600px; background:var(--b-600); }
.funnel .l3 { width:58%; max-width:440px; background:var(--b-800); }

/* cockpit */
.cockpit { margin-top:30px; background:rgba(10,4,30,.55); border:1px solid rgba(255,255,255,.14); border-radius:var(--radius-lg); padding:26px; backdrop-filter:blur(8px); box-shadow:var(--shadow-xl); }
.cockpit .live { display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#9affc6; margin-bottom:18px; }
.cockpit .live .dot { width:9px; height:9px; border-radius:50%; background:var(--green); animation:pulse 1.8s infinite; }
.kpi-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
.kpi { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:var(--radius); padding:20px; }
.kpi .kl { font-size:13px; opacity:.7; font-weight:600; }
.kpi .kv { font-size:34px; font-weight:800; letter-spacing:-.02em; margin-top:6px; background:linear-gradient(100deg,#fff,#BEA6F7); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.kpi .kt { font-size:12px; color:#9affc6; font-weight:700; margin-top:6px; }
.geo { margin-top:22px; display:grid; grid-template-columns:repeat(2,1fr); gap:8px 30px; }
.geo .country { display:flex; flex-direction:column; }
.geo .country .top { display:grid; grid-template-columns:30px 1fr auto; gap:12px; align-items:center; }
.geo .fl { font-size:22px; }
.geo .nm { font-size:14px; font-weight:600; }
.geo .bar { height:8px; background:rgba(255,255,255,.12); border-radius:999px; overflow:hidden; margin-top:3px; }
.geo .bar i { display:block; height:100%; width:0; background:linear-gradient(90deg,var(--accent),var(--teal-300)); border-radius:999px; transition:width 1.3s var(--ease); }
.geo .pct { font-size:13px; font-weight:700; color:#BEA6F7; }

/* closing */
.closing { text-align:center; }
.closing .logo { height:44px; margin:0 auto 24px; filter:brightness(0) invert(1); }
.closing h2 { font-size:62px; }
.cta-row { display:flex; gap:16px; justify-content:center; margin-top:32px; flex-wrap:wrap; }
.btn3d { font-size:16px; font-weight:700; padding:0 26px; height:54px; display:inline-flex; align-items:center; gap:10px; border-radius:var(--radius); text-decoration:none; transition:transform .12s ease,box-shadow .12s ease; border:0; cursor:pointer; }
.btn3d.primary { background:#fff; color:var(--b-700); box-shadow:0 4px 0 0 #c9b8f0; }
.btn3d.ghost { background:rgba(255,255,255,.12); color:#fff; box-shadow:0 4px 0 0 rgba(255,255,255,.18); }
.btn3d:active { transform:translateY(4px); box-shadow:0 0 0 0 #c9b8f0; }
.closing .foot { margin-top:46px; font-size:14px; color:rgba(255,255,255,.65); }

/* decorative blobs */
.blob { position:absolute; border-radius:50%; filter:blur(60px); opacity:.5; z-index:0; pointer-events:none; }

/* hint */
#hint { position:absolute; left:50%; bottom:18px; transform:translateX(-50%); z-index:310; font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.55); transition:opacity .5s; pointer-events:none; }
#hint.light { color:rgba(60,40,110,.55); }
#hint.gone { opacity:0; }

/* ============================================================
   Sección CUIDEO (integrada) — tema crema / azul marino / amarillo
   ============================================================ */
.cuideo{--cu-navy:#16324A;--cu-cream:#F6F2E9;--cu-yellow:#F2B705;--cu-soft:#5d7180;--cu-line:rgba(22,50,74,.12);--cu-gray:#cdc7ba}
.slide.cuideo{display:block;padding:0}
.cuideo.cu-cream{background:var(--cu-cream);color:var(--cu-navy)}
.cuideo .chl{color:var(--cu-yellow)}
@keyframes cuFade{to{opacity:1}}

/* hero (vídeo) */
.cuideo .cuideo-heroscrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(0deg,rgba(8,3,24,.92) 0%,rgba(8,3,24,.2) 36%,rgba(8,3,24,0) 58%,rgba(8,3,24,.28) 100%)}
.cuideo .cu-hero{position:absolute;inset:0;z-index:2;padding:54px 84px;display:flex;flex-direction:column;justify-content:space-between}
.cuideo .hero-pill{display:inline-flex;align-items:center;background:#fff;border-radius:999px;padding:9px 18px;box-shadow:0 8px 22px rgba(0,0,0,.3)}
.cuideo .hero-pill img{height:24px}

/* logo en píldora (igual que la slide de vídeo) para las slides crema */
.cuideo .cu-logopill{position:absolute;top:54px;left:84px;z-index:6}
.cuideo .cnav-top{position:absolute;top:58px;left:50%;transform:translateX(-50%);z-index:6}
.cuideo .cu-logopill .hero-pill{box-shadow:0 8px 22px rgba(22,50,74,.18)}

/* breadcrumb + logo (slides crema) */
.cuideo .chead{position:absolute;top:40px;left:84px;right:84px;display:flex;align-items:center;justify-content:space-between;z-index:6}
.cuideo .cnav{display:flex;gap:24px;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:rgba(22,50,74,.42)}
.cuideo .cnav span{display:flex;align-items:center;gap:8px}
.cuideo .cnav .num{width:20px;height:20px;border-radius:50%;background:rgba(22,50,74,.1);color:rgba(22,50,74,.5);display:grid;place-items:center;font-size:11px;font-weight:800}
.cuideo .cnav span.on{color:var(--cu-navy)}
.cuideo .cnav span.on .num{background:var(--cu-yellow);color:var(--cu-navy)}
.cuideo .clogo{height:28px}
.cuideo .ceyebrow{display:inline-block;font-size:14px;font-weight:800;letter-spacing:.02em;color:var(--cu-soft);margin-bottom:8px}

/* MARCA */
.cuideo.cu-brand{display:flex;flex-direction:column;justify-content:center;padding:100px 84px 56px}
.cuideo.cu-brand h1{font-size:38px;font-weight:800;letter-spacing:-.02em;color:var(--cu-navy);line-height:1.05}
.cuideo .b-sub{font-size:16px;color:var(--cu-soft);font-weight:500;margin-top:6px;max-width:680px}
.cuideo .legend{display:flex;gap:20px;margin-top:12px;font-size:12.5px;font-weight:700;color:var(--cu-navy)}
.cuideo .legend i{display:inline-block;width:13px;height:13px;border-radius:4px;margin-right:6px;vertical-align:-2px}
.cuideo .brand-grid{display:grid;grid-template-columns:1.05fr .85fr;gap:54px;align-items:center;margin-top:22px}
.cuideo .bchart{display:flex;align-items:flex-end;gap:6px;height:336px;border-bottom:2px solid var(--cu-line)}
.cuideo .bgroup{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;max-width:62px}
.cuideo .pair{display:flex;align-items:flex-end;justify-content:center;gap:4px;width:100%;height:100%}
.cuideo .barwrap{display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%}
.cuideo .gval{font-size:16px;font-weight:800;color:var(--cu-navy);margin-bottom:6px;opacity:0;white-space:nowrap}
.slide.cuideo.active .gval{animation:cuFade .5s var(--ease) forwards;animation-delay:1s}
.cuideo .ybar{width:26px;background:var(--cu-yellow);border-radius:6px 6px 0 0;height:0;transition:height .85s var(--ease);transition-delay:var(--d,0s)}
.cuideo .ybar.gry{width:18px;background:var(--cu-gray)}
.slide.cuideo.active .ybar{height:var(--h)}
.cuideo .gyr{font-size:11px;font-weight:700;color:var(--cu-soft);margin-top:7px}
.cuideo .kpis{display:grid;grid-template-columns:1fr 1fr;gap:26px 30px}
.cuideo .kpi .n{font-size:40px;font-weight:800;letter-spacing:-.02em;color:var(--cu-navy);line-height:1}
.cuideo .kpi .n.y{color:var(--cu-yellow)}
.cuideo .kpi .l{font-size:15px;font-weight:800;color:var(--cu-navy);margin-top:5px}
.cuideo .kpi .d{font-size:12.5px;color:var(--cu-soft);font-weight:500}

/* EQUIPO */
.cuideo.cu-team{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:82px 84px 44px}
.cuideo .team-head{margin-bottom:26px}
.cuideo .team-head h1{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--cu-navy);line-height:1.06}
.cuideo .team-head .t-sub{font-size:17px;color:var(--cu-soft);font-weight:600;margin-top:7px}
.cuideo .team-hero{position:relative;align-self:center}
.cuideo .team-hero .big{position:relative;z-index:1;border-radius:20px;overflow:hidden;border:4px solid #fff;box-shadow:0 26px 56px rgba(22,50,74,.28)}
.cuideo .team-hero .big img{width:1060px;height:auto;display:block}
.cuideo .team-hero .inset{position:absolute;z-index:3;top:-52px;left:-44px;border-radius:14px;overflow:hidden;border:4px solid #fff;box-shadow:0 18px 38px rgba(22,50,74,.4)}
.cuideo .team-hero .inset img{width:182px;height:122px;object-fit:cover;display:block}
.cuideo .team-hero .inset .ic{position:absolute;left:0;right:0;bottom:0;padding:15px 8px 6px;text-align:center;font-size:12px;font-weight:800;color:#fff;background:linear-gradient(0deg,rgba(16,39,57,.92),transparent)}
.cuideo .team-hero .inset .ic b{color:var(--cu-yellow)}

/* ECONOMICS */
.cuideo.cu-eco{display:flex;align-items:center;padding:84px 84px 44px}
.cuideo .eco2{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center;width:100%}
.cuideo .eco2 h1{font-size:34px;font-weight:800;letter-spacing:-.02em;color:var(--cu-navy);line-height:1.06;margin-bottom:18px}
.cuideo .fchart{display:flex;align-items:flex-end;gap:6px;height:344px;border-bottom:2px solid var(--cu-line);margin-bottom:30px}
.cuideo .fbar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;height:100%;position:relative}
.cuideo .fcol{width:100%;max-width:36px;background:var(--cu-yellow);border-radius:6px 6px 0 0;height:0;transition:height .9s var(--ease);transition-delay:var(--d,0s)}
.slide.cuideo.active .fcol{height:var(--h)}
.cuideo .fbar.today .fcol{background:var(--cu-navy)}
.cuideo .ftop{font-size:17px;font-weight:800;color:var(--cu-navy);margin-bottom:6px;opacity:0;white-space:nowrap}
.slide.cuideo.active .fbar.today .ftop{animation:cuFade .6s var(--ease) forwards;animation-delay:1.1s}
.cuideo .fyr{position:absolute;bottom:-24px;left:0;right:0;text-align:center;font-size:11px;font-weight:700;color:var(--cu-soft)}
.cuideo .fbar.today .fyr{color:var(--cu-navy);font-weight:800}
.cuideo .eright{display:flex;flex-direction:column}
.cuideo .estats{display:flex;flex-direction:column;gap:18px}
.cuideo .cstat .ck{display:flex;align-items:center;gap:9px;font-size:17px;font-weight:800;color:var(--cu-navy)}
.cuideo .cstat .ck .dot{width:10px;height:10px;border-radius:50%;background:var(--cu-yellow);flex:0 0 auto}
.cuideo .cstat .ck .cy{color:var(--cu-yellow)}
.cuideo .cstat .cd{font-size:13px;color:var(--cu-soft);font-weight:500;margin-left:19px}
.cuideo .conf2{margin-top:24px;padding-top:22px;border-top:1px solid var(--cu-line)}
.cuideo .conf2 .ct{font-size:15px;color:var(--cu-soft);font-weight:600}
.cuideo .conf2 .bigins{font-size:44px;font-weight:800;color:var(--cu-navy);letter-spacing:-.02em;line-height:1;margin:4px 0 16px}
.cuideo .conf2 .bigins [data-count]{color:var(--cu-yellow)}
.cuideo .clogos{display:flex;gap:11px;align-items:center;flex-wrap:wrap}
.cuideo .lchip{background:#fff;border-radius:12px;height:50px;padding:0 16px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 24px rgba(22,50,74,.14)}
.cuideo .lchip img{height:22px;width:auto}
.cuideo .lchip.txt{font-weight:800;font-size:17px;color:#0a4a8f}
.cuideo .lmore{align-self:center;font-size:14px;font-weight:700;color:var(--cu-soft);margin-left:4px}

/* KPIS (mix marca + facturación) */
.cuideo.cu-kpis{display:flex;flex-direction:column;justify-content:center;padding:104px 80px 46px}
.cuideo .kpis-head{margin-bottom:22px}
.cuideo .kpis-head h1{font-size:32px;font-weight:800;letter-spacing:-.02em;color:var(--cu-navy);line-height:1.05;margin-top:2px}
.cuideo .kpis-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.cuideo .kcol{display:flex;flex-direction:column;min-width:0}
.cuideo .kct{font-size:20px;font-weight:800;letter-spacing:-.01em;color:var(--cu-navy);line-height:1.1}
.cuideo .klegend{min-height:30px;display:flex;align-items:center;margin:8px 0 2px}
.cuideo .klegend .legend{margin-top:0}
.cuideo.cu-kpis .bchart,.cuideo.cu-kpis .fchart{height:250px;margin-bottom:36px}
/* años del gráfico de marca bajo la línea base (como facturación) → barras, línea y años al mismo nivel */
.cuideo.cu-kpis .bgroup{position:relative}
.cuideo.cu-kpis .gyr{position:absolute;left:0;right:0;bottom:-24px;margin-top:0}
.cuideo .kdata{display:flex;gap:34px;margin-top:8px}
.cuideo .kd{display:flex;flex-direction:column}
.cuideo .kd b{font-size:30px;font-weight:800;color:var(--cu-navy);letter-spacing:-.02em;line-height:1}
.cuideo .kd b.y{color:var(--cu-yellow)}
.cuideo .kd span{font-size:12.5px;color:var(--cu-soft);font-weight:600;margin-top:5px;max-width:200px;line-height:1.3}

/* ============================================================
   Slide "Mi background" — pantalla intro/agenda de etapas (centrada)
   ============================================================ */
.slide--bg { }
.bgintro { width:100%; max-width:1000px; margin:0 auto; display:flex; flex-direction:column; align-items:center; text-align:center; }
.bg-head { display:flex; align-items:center; gap:34px; margin-bottom:52px; }
.bg-ava { width:180px; height:180px; border-radius:50%; overflow:hidden; border:6px solid #fff; box-shadow:0 18px 44px rgba(60,40,110,.22); flex:0 0 auto; background:var(--b-100); }
.bg-ava img { width:100%; height:100%; object-fit:cover; object-position:50% 14%; }
.bg-text { text-align:left; }
.bg-text .eyebrow { margin-bottom:12px; }
.bg-text h2 { font-size:52px; font-weight:800; letter-spacing:-.03em; color:var(--b-600); line-height:1.0; }
.bg-text .subt { font-size:17px; font-weight:600; color:var(--ink-soft); margin-top:10px; }
.htl--center { width:780px; max-width:100%; margin:0 auto; }
/* estados de etapa en la agenda */
/* selección (al hacer clic → .sel): se resalta la etapa y el resto se apagan en gris */
.htl .badge { transition:border-color .22s var(--ease), box-shadow .22s var(--ease), transform .22s var(--ease), filter .22s var(--ease); }
.htl .hnm, .htl .yrs { transition:color .22s var(--ease), border-color .22s var(--ease); }
/* la atenuación ocurre de golpe (sin escalonar) y rápida: anula el retardo de la animación de entrada */
.htl.sel .node { transition:opacity .22s var(--ease) 0s; }
.htl.sel .node.up .badge { border-color:var(--b-400); box-shadow:0 0 0 4px rgba(110,57,225,.18), 0 14px 30px rgba(110,57,225,.22); transform:translateY(-6px); }
.htl.sel .node.up .hnm { color:var(--b-700); }
.htl.sel .node.up .yrs { color:var(--b-700); border-color:var(--b-300); }
/* el resto, apagadas en gris */
.htl.sel .node:not(.up) { opacity:.38; }
.htl.sel .node:not(.up) .badge { filter:grayscale(1); box-shadow:0 4px 12px rgba(0,0,0,.05); }

/* ============================================================
   Telón de presentación de Bilingu (slide 10)
   ============================================================ */
.bili-cover { display:flex; align-items:center; justify-content:center; text-align:center; color:#fff; padding:0; }
.bili-intro { display:flex; flex-direction:column; align-items:center; }
.bili-pre { font-size:30px; font-weight:600; color:rgba(255,255,255,.88); letter-spacing:.005em; margin-bottom:30px; }
/* logo: barrido (wipe) izq→der + leve subida y glow */
.bili-logo-wrap { position:relative; display:inline-block; }
.bili-logo-wrap::after { /* glow detrás del logo */
  content:""; position:absolute; left:50%; top:50%; width:140%; height:260%; transform:translate(-50%,-50%) scale(.6);
  background:radial-gradient(closest-side, rgba(255,255,255,.28), transparent 70%); z-index:-1; opacity:0;
}
.bili-logo { height:128px; width:auto; transform:scale(.97);
  -webkit-mask-image:linear-gradient(90deg,#000 50%,transparent 50%); -webkit-mask-size:215% 100%; -webkit-mask-position:100% 0; -webkit-mask-repeat:no-repeat;
          mask-image:linear-gradient(90deg,#000 50%,transparent 50%);         mask-size:215% 100%;         mask-position:100% 0;         mask-repeat:no-repeat; }
.slide.active .bili-logo { animation:biliWipe 1.05s cubic-bezier(.4,0,.12,1) .5s forwards; }
.slide.active .bili-logo-wrap::after { animation:biliGlow 1.2s var(--ease) .7s forwards; }
@keyframes biliWipe {
  from { -webkit-mask-position:100% 0; mask-position:100% 0; transform:scale(.97); }
  to   { -webkit-mask-position:0% 0;   mask-position:0% 0;   transform:scale(1); }
}
@keyframes biliGlow { 0%{opacity:0} 55%{opacity:1} 100%{opacity:.5} }
@media (prefers-reduced-motion: reduce) {
  .bili-logo { -webkit-mask:none; mask:none; transform:none; animation:none; }
}

/* ============================================================
   Slide Equipo fundador (foto Adrià + Carlos)
   ============================================================ */
.slide.team2 { padding:54px 76px 54px 80px; }
.team2-inner { width:100%; max-width:1140px; display:flex; align-items:center; gap:60px; }
.team2-copy { flex:0 0 38%; }
.team2-copy .lead { margin-bottom:18px; }
.team2-note-wrap { position:relative; margin-top:48px; }
.team2-carlos-arrow { position:absolute; inset:0; width:100%; height:100%;
  color:var(--b-400); overflow:visible; pointer-events:none; z-index:3; }
.team2-note { font-size:17px; font-weight:500; color:var(--ink-soft); line-height:1.5; max-width:400px;
  padding-left:16px; border-left:3px solid var(--b-300); }
.team2-note b { font-weight:800; color:var(--b-700); }
.team2-photo { flex:1; position:relative; }
.team2-photo img { width:100%; height:auto; display:block; border-radius:22px; border:5px solid #fff;
  box-shadow:0 26px 60px rgba(60,40,110,.28); }
.team2-photo .tag { position:absolute; bottom:18px; display:flex; flex-direction:column;
  background:rgba(255,255,255,.96); backdrop-filter:blur(8px); border-radius:14px; padding:10px 16px;
  box-shadow:0 10px 26px rgba(60,40,110,.22); text-align:left; }
.team2-photo .tag b { font-size:17px; font-weight:800; color:var(--ink); letter-spacing:-.01em; line-height:1.1; }
.team2-photo .tag span { font-size:12.5px; font-weight:700; color:var(--b-600); margin-top:2px; }
.team2-photo .tag-l { left:18px; }
.team2-photo .tag-r { right:18px; }
