/* ============================================================
   PORTFOLIO LDG · UDEM — Sistema de diseño «Cuarto Oscuro»
   Reconstrucción limpia (ver PRD.md). Compartido por todas las páginas.
   ============================================================ */

:root{
  /* color — monocromo sobre negro; único acento = morado del hero */
  --bg:#000000;
  --surface:#0B0B0B;
  --surface-2:#141414;
  --ink:#EFEFEF;
  --ink-soft:#A0A0A0;                  /* subido de #8E8E8E para pasar AA sobre superficies #141414 */
  --on-accent:#0B0B0B;                 /* texto sobre el acento morado (claro) */
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.18);
  --accent:hsl(280 90% 75%);          /* morado del scroll-de-verbos */
  --accent-deep:hsl(280 85% 62%);
  --warn:hsl(8 78% 66%);              /* coral de alerta/error, legible sobre negro */

  /* tipografía */
  --disp:"Anton","Arial Narrow",sans-serif;
  --sans:"Atkinson Hyperlegible",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --serif:"Spectral",Georgia,serif;

  /* escala / ritmo */
  --t-mono:.72rem;
  --ease:cubic-bezier(.22,1,.36,1);
  --gut:clamp(18px,4.5vw,64px);
  --maxw:1240px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{color-scheme:dark only;scroll-behavior:smooth;font-size:16px;scrollbar-color:var(--accent) transparent;overflow-x:clip}
body{
  background:var(--bg);color:var(--ink);
  font-family:var(--sans);line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit}
img{display:block;max-width:100%}

/* ---- foco visible global (accesibilidad · outline morado sobre negro) ---- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,
textarea:focus-visible,[tabindex]:focus-visible,[role="button"]:focus-visible{
  outline:2px solid var(--accent);outline-offset:2px;border-radius:6px}
::selection{background:var(--accent);color:var(--on-accent)}

/* ---- fondo: resplandor + retícula + grano (inyectado por bg-noise.js) ---- */
#bgfx{position:fixed;inset:0;z-index:-1;background:#000;pointer-events:none;overflow:hidden}
.bgfx-glow{position:absolute;inset:0;background:radial-gradient(circle 520px at 50% 165px, rgba(168,85,247,.13), transparent 66%)}
.bgfx-grid{position:absolute;inset:0;
  background-image:linear-gradient(to right, rgba(255,255,255,.028) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.028) 1px, transparent 1px);
  background-size:22px 24px}
.bgfx-noise{position:absolute;inset:0;width:100vw;height:100vh;image-rendering:pixelated;opacity:.9}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;width:100%;padding:0 var(--gut)}
.section{padding:clamp(64px,11vh,140px) 0;position:relative}
.sec-head{display:flex;align-items:baseline;gap:16px;margin-bottom:28px}
.sec-no{font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.16em;color:var(--ink-soft);border:1px solid var(--line-2);padding:3px 8px;border-radius:3px}
.sec-head h2{font-family:var(--disp);font-weight:400;text-transform:uppercase;font-size:clamp(1.9rem,4.4vw,3.3rem);letter-spacing:-.01em;line-height:1.02}
.sec-sub{margin-top:6px;font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}

/* ---- utilidades ---- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.mono-label{font-family:var(--mono);font-size:var(--t-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}

/* ---- footer común (port a vainilla del footer-section · footer.js) ---- */
.site-footer{position:relative;border-top:1px solid var(--line-2);margin-top:clamp(48px,8vh,110px);overflow:hidden}
.site-footer__inner{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,7vw,80px) var(--gut) clamp(30px,4vw,42px)}
.site-footer__grid{display:grid;grid-template-columns:1.5fr 1fr 1.2fr 1fr;gap:clamp(30px,5vw,56px)}

/* resplandor morado detrás del bloque newsletter (eco del fondo) */
.foot-glow{position:absolute;top:-30px;left:clamp(18px,4.5vw,64px);width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle, rgba(168,85,247,.16), transparent 68%);filter:blur(22px);pointer-events:none;z-index:0}

.foot-col{position:relative;z-index:1;min-width:0}
.foot-col h3{font-family:var(--mono);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:16px}

/* newsletter */
.foot-news h2{font-family:var(--disp);font-weight:400;font-size:clamp(1.6rem,3vw,2.2rem);line-height:1.02;letter-spacing:-.01em;text-transform:uppercase;margin-bottom:12px}
.foot-news p{color:var(--ink-soft);font-size:.9rem;max-width:34ch;margin-bottom:20px}
.foot-form{position:relative;max-width:340px}
.foot-form input{width:100%;height:46px;padding:0 54px 0 16px;background:var(--surface-2);border:1px solid var(--line);border-radius:14px;color:var(--ink);font-family:var(--sans);font-size:.92rem;outline:none;transition:border-color .2s var(--ease)}
.foot-form input:focus{border-color:var(--line-2)}
.foot-form input::placeholder{color:var(--ink-soft)}
.foot-form button{position:absolute;right:6px;top:6px;width:34px;height:34px;display:grid;place-items:center;border:0;border-radius:10px;
  background:var(--accent);color:#0B0B0B;cursor:pointer;transition:transform .25s var(--ease),background .25s var(--ease)}
.foot-form button:hover{transform:scale(1.06);background:var(--accent-deep)}
.foot-form button svg{width:16px;height:16px}
.foot-note{display:block;margin-top:10px;font-family:var(--mono);font-size:.58rem;letter-spacing:.04em;color:var(--ink-soft);opacity:0;transform:translateY(-3px);transition:opacity .3s var(--ease),transform .3s var(--ease)}
.foot-note.is-on{opacity:1;transform:none}
.foot-note.is-error{color:var(--warn)}

/* enlaces de navegación */
.foot-links{display:flex;flex-direction:column;gap:11px}
.foot-links a{font-size:.9rem;color:var(--ink-soft);text-decoration:none;width:fit-content;transition:color .25s var(--ease)}
.foot-links a:hover{color:var(--accent)}

/* contacto */
.foot-contact{font-style:normal;font-size:.85rem;color:var(--ink-soft);line-height:1.75}
.foot-contact a{color:var(--ink);text-decoration:none;transition:color .25s var(--ease)}
.foot-contact a:hover{color:var(--accent)}

/* redes */
.foot-social{display:flex;flex-wrap:wrap;gap:10px}
.foot-social a{position:relative;width:40px;height:40px;display:grid;place-items:center;border-radius:50%;
  border:1px solid var(--line-2);color:var(--ink-soft);
  transition:color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.foot-social a:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-3px)}
.foot-social svg{width:17px;height:17px}
.foot-social a::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--surface-2);border:1px solid var(--line-2);color:var(--ink);font-family:var(--mono);font-size:.52rem;letter-spacing:.06em;
  padding:5px 8px;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}
.foot-social a:hover::after{opacity:1;transform:translateX(-50%) translateY(0)}

/* barra inferior: colofón + legales */
.site-footer__bar{border-top:1px solid var(--line);max-width:var(--maxw);margin:0 auto;
  padding:20px var(--gut);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px}
.site-footer__bar p{font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;color:var(--ink-soft)}
.foot-legal{display:flex;flex-wrap:wrap;gap:18px}
.foot-legal a{font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color .25s var(--ease)}
.foot-legal a:hover{color:var(--accent)}

@media (max-width:900px){
  .site-footer__grid{grid-template-columns:1fr 1fr;gap:38px}
  .foot-news{grid-column:1 / -1}
}
@media (max-width:560px){
  .site-footer{margin-top:32px}
  .site-footer__inner{padding:36px var(--gut) 24px}
  .site-footer__grid{grid-template-columns:1fr;gap:26px}
  .site-footer__bar{flex-direction:column;align-items:flex-start;padding-top:18px;padding-bottom:18px}
  .foot-glow{width:180px;height:180px}
}

/* ============================================================
   CARD-FAN — carrusel en abanico (card-fan.js + GSAP)
   ============================================================ */
.proy-fan-wrap{display:flex;flex-direction:column;align-items:center;margin-top:36px}
.proy-fan{position:relative;width:100%;max-width:80rem;margin:0 auto;height:clamp(20rem,56vh,34rem)}
.fan-card{
  position:absolute;left:50%;top:50%;
  width:clamp(8.5rem,20vw,14rem);aspect-ratio:400/560;
  border-radius:16px;overflow:hidden;cursor:pointer;text-decoration:none;
  background:var(--surface-2);box-shadow:0 24px 60px rgba(0,0,0,.55);
  will-change:transform,opacity;
}
.fan-card img{width:100%;height:100%;object-fit:cover;display:block}
.fan-nav{display:flex;align-items:center;gap:16px;margin-top:24px}
.fan-arrow{width:42px;height:42px;display:grid;place-items:center;border-radius:50%;
  border:1.5px solid var(--line-2);background:rgba(255,255,255,.05);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
  color:var(--ink-soft);cursor:pointer;transition:color .3s var(--ease),border-color .3s var(--ease)}
.fan-arrow:hover{color:var(--ink);border-color:rgba(255,255,255,.35)}
.fan-arrow svg{width:18px;height:18px}
.fan-dots{display:flex;align-items:center;gap:8px}
.fan-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.18);transition:all .3s var(--ease)}
.fan-dot.is-on{background:var(--ink);transform:scale(1.3)}
@media (prefers-reduced-motion:reduce){.proy-fan{height:auto;display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.fan-card{position:static;transform:none!important}}

/* ============================================================
   DIRECTORIO DE EQUIPO (Alto Desempeño) — lista + buscador + cajón
   ============================================================ */
.teamdir{position:relative;width:100%;max-width:460px;margin:36px auto 0;background:var(--surface);
  border:1px solid var(--line-2);border-radius:32px;overflow:hidden;min-height:540px}
.teamdir-main{padding:28px 28px 0}
.teamdir-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.teamdir-head h3{font-family:var(--sans);font-size:1.02rem;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}
.teamdir-count{font-family:var(--mono);font-size:.62rem;background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);padding:3px 8px;border-radius:20px}
.td-search{position:relative;margin-bottom:12px}
.td-search > svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--ink-soft);pointer-events:none}
.td-search input{width:100%;height:44px;padding:0 14px 0 40px;background:var(--surface-2);border:1px solid transparent;border-radius:14px;color:var(--ink);font-family:var(--sans);font-size:.92rem;outline:none;transition:border-color .2s var(--ease)}
.td-search input:focus{border-color:var(--line-2)}
.td-search input::placeholder{color:var(--ink-soft)}
.td-list{display:flex;flex-direction:column}
.td-item{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--line)}
.td-item:last-child{border-bottom:0}
.td-item.is-hidden{display:none}
.td-avatar{position:relative;flex-shrink:0}
.td-avatar img{width:46px;height:46px;border-radius:50%;object-fit:cover;filter:grayscale(.35);transition:filter .3s var(--ease)}
.td-item:hover .td-avatar img{filter:grayscale(0)}
.td-star{position:absolute;bottom:-1px;right:-1px;width:15px;height:15px;border-radius:50%;background:var(--surface);display:grid;place-items:center}
.td-star::after{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent)}
.td-info{flex:1;min-width:0}
.td-info h5{font-family:var(--sans);font-size:.96rem;font-weight:600;letter-spacing:-.01em;line-height:1.1;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.td-info p{font-family:var(--mono);font-size:.62rem;letter-spacing:.06em;color:var(--ink-soft)}
.td-badge{display:inline-flex;align-items:center;gap:5px;flex-shrink:0;padding:5px 10px;border-radius:20px;border:1px solid var(--line-2);color:var(--ink-soft);font-family:var(--mono);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase}
.td-badge svg{width:11px;height:11px}
/* cajón expandible */
.teamdir-drawer{position:absolute;left:20px;bottom:20px;width:calc(100% - 40px);height:68px;
  background:var(--surface-2);border:1px solid var(--line-2);border-radius:24px;overflow:hidden;cursor:pointer;
  display:flex;flex-direction:column;z-index:5;
  transition:height .45s var(--ease),width .45s var(--ease),left .45s var(--ease),bottom .45s var(--ease),border-radius .45s var(--ease)}
.teamdir.is-expanded .teamdir-drawer{height:calc(100% - 20px);width:calc(100% - 20px);left:10px;bottom:10px;border-radius:28px;cursor:default}
.teamdir-bar{display:flex;align-items:center;justify-content:space-between;padding:0 13px;height:68px;flex-shrink:0}
.teamdir.is-expanded .teamdir-bar{border-bottom:1px solid var(--line)}
.teamdir-bar-left{display:flex;align-items:center;gap:12px}
.teamdir-bar-icon{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line-2);display:grid;place-items:center;color:var(--ink-soft)}
.teamdir-bar-icon svg{width:20px;height:20px}
.teamdir-bar-left h4{font-size:.92rem;font-weight:600;line-height:1}
.teamdir-bar-left p{font-family:var(--mono);font-size:.58rem;color:var(--ink-soft);margin-top:5px}
.teamdir-avatars{display:flex}
.teamdir-avatars img,.teamdir-avatars .more{width:38px;height:38px;border-radius:50%;margin-left:-12px;border:2px solid var(--surface-2);object-fit:cover}
.teamdir-avatars .more{background:var(--surface);display:grid;place-items:center;font-family:var(--mono);font-size:.6rem;color:var(--ink-soft)}
.teamdir.is-expanded .teamdir-avatars{display:none}
.teamdir-close{display:none;width:36px;height:36px;border-radius:12px;border:0;background:var(--surface);color:var(--ink-soft);cursor:pointer;align-items:center;justify-content:center}
.teamdir-close svg{width:18px;height:18px}
.teamdir.is-expanded .teamdir-close{display:flex}
.teamdir-drawer-body{flex:1;overflow-y:auto;opacity:0;pointer-events:none;transition:opacity .3s var(--ease) .12s;padding:0 18px 14px}
.teamdir.is-expanded .teamdir-drawer-body{opacity:1;pointer-events:auto}
.teamdir-drawer-body .td-search{margin-top:14px}

/* ============================================================
   MENÚ DOCK DE ÍCONOS — inyectado por dock-fun.js
   Una sola línea siempre (íconos compactos), motion elástico,
   etiqueta como tooltip, grupo Comunidad en popover. Cada ítem navega.
   ============================================================ */
.fdock{position:fixed;left:50%;top:18px;transform:translateX(-50%);z-index:1200}
.fdock-glass{display:flex;align-items:center;gap:4px;padding:7px;border-radius:30px;
  background:rgba(20,20,20,.6);-webkit-backdrop-filter:blur(14px) saturate(1.2);backdrop-filter:blur(14px) saturate(1.2);
  border:1px solid var(--line-2);box-shadow:0 8px 30px rgba(0,0,0,.45)}
.fdock-item{position:relative;display:flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:50%;border:0;background:transparent;cursor:pointer;color:var(--ink-soft);
  text-decoration:none;transition:transform .34s cubic-bezier(.34,1.56,.64,1),background .25s var(--ease),color .25s var(--ease)}
.fdock-ico{display:grid;place-items:center}
.fdock-ico svg{width:21px;height:21px;display:block}
/* etiqueta tipo tooltip — no afecta el ancho, así nunca hay 2 líneas */
.fdock-label{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(4px);
  font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap;
  color:var(--ink);background:rgba(18,18,18,.92);border:1px solid var(--line-2);border-radius:8px;padding:4px 8px;
  opacity:0;pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}
.fdock-item:hover,.fdock-item:focus-visible{color:var(--ink);background:rgba(255,255,255,.1);
  transform:translateY(-7px) scale(1.12);outline:none}
.fdock-item:hover .fdock-label,.fdock-item:focus-visible .fdock-label{opacity:1;transform:translateX(-50%) translateY(0)}
.fdock-item:active{transform:translateY(-3px) scale(1.05)}
.fdock-item.is-current{color:var(--accent)}
.fdock-item.is-current::after{content:"";position:absolute;bottom:5px;left:50%;transform:translateX(-50%);
  width:4px;height:4px;border-radius:50%;background:var(--accent)}
.fdock-sep{width:1px;height:24px;background:var(--line-2);margin:0 3px;flex:none}
/* popover Comunidad */
.fdock-sub{position:absolute;top:calc(100% + 12px);right:0;display:flex;flex-direction:column;gap:2px;
  min-width:176px;padding:7px;border-radius:16px;background:rgba(18,18,18,.85);
  -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--line-2);
  box-shadow:0 14px 36px rgba(0,0,0,.5);opacity:0;pointer-events:none;transform:translateY(-6px) scale(.97);
  transform-origin:top right;transition:opacity .22s var(--ease),transform .28s cubic-bezier(.34,1.56,.64,1)}
.fdock.is-open .fdock-sub{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
.fdock-subitem{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:11px;color:var(--ink-soft);
  text-decoration:none;font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;
  transition:background .2s var(--ease),color .2s var(--ease)}
.fdock-subitem .fdock-ico svg{width:17px;height:17px}
.fdock-subitem:hover,.fdock-subitem:focus-visible{background:rgba(255,255,255,.1);color:var(--ink);outline:none}
.fdock-subitem.is-current{color:var(--accent)}

@media (max-width:560px){ .fdock{top:12px} .fdock-glass{gap:2px;padding:6px} .fdock-item{width:42px;height:42px} }

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .fdock-item,.fdock-sub{transition:opacity .2s var(--ease)}
  .fdock-item:hover,.fdock-item:focus-visible{transform:none}
}

/* ============================================================
   RITMO MÓVIL — espaciados compactos en pantallas chicas.
   Va al FINAL para ganar la cascada sobre las bases de cada
   componente (.proy-fan, .teamdir… definidas más arriba).
   En desktop/tablet se mantienen los clamp generosos de arriba.
   ============================================================ */
@media (max-width:560px){
  .section{padding:clamp(44px,11vw,60px) 0}
  .sec-head{margin-bottom:16px}
  .sec-sub{margin-top:4px}
  .proy-fan-wrap{margin-top:8px}
  .fan-nav{margin-top:8px}
  .teamdir{margin-top:20px}
}
/* sube el abanico para cerrar el vacío interno superior (~141px);
   solo con movimiento permitido — en reduced-motion el abanico es
   un grid en flujo normal y no debe treparse sobre el subtítulo. */
@media (max-width:560px) and (prefers-reduced-motion:no-preference){
  .proy-fan{margin-top:-96px}
}

/* ============================================================
   SCROLL-EXPAND HERO — port fiel de ScrollExpandMedia (21st.dev).
   Lógica (scroll hijack) en assets/scroll-expand.js → escribe --se-prog / --se-tx.
   ============================================================ */
.se{position:relative}
.se-stage{position:relative;height:100dvh;display:grid;place-items:center;overflow:hidden}
/* fondo (cartel) que se desvanece conforme el media se expande */
.se-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  filter:blur(5px) brightness(.5);transform:scale(1.06);
  opacity:calc(1 - var(--se-prog,0));will-change:opacity}
.se-bg::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.3)}
/* caja del media: arranca chica (retrato 300×400) y crece a casi pantalla completa */
.se-media{position:relative;z-index:1;container-type:size;--se-wadd:1250px;--se-hadd:400px;
  width:min(95vw, calc(300px + var(--se-prog,0) * var(--se-wadd)));
  height:min(85vh, calc(400px + var(--se-prog,0) * var(--se-hadd)));
  border-radius:16px;overflow:hidden;box-shadow:0 0 50px rgba(0,0,0,.45);
  background:var(--surface-2);will-change:width,height}
.se-media video,.se-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0;pointer-events:none}
/* el iframe (Vimeo) no acepta object-fit: lo escalamos para cubrir la caja sin barras grises */
.se-media iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:max(100cqw, 177.78cqh);height:max(100cqh, 56.25cqw);border:0;pointer-events:none}
.se-veil{position:absolute;inset:0;background:#000;pointer-events:none;opacity:calc(.5 - var(--se-prog,0) * .3)}
/* título que se parte en dos y se desliza a los lados al expandir */
.se-titles{position:absolute;z-index:2;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:6px;text-align:center;pointer-events:none}
.se-titles h2{margin:0;font-family:var(--sans);font-weight:800;line-height:1.04;letter-spacing:-.02em;
  font-size:clamp(2.2rem,7vw,4.6rem);color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.7),0 1px 4px rgba(0,0,0,.6)}
.se-t1{transform:translateX(calc(var(--se-tx,0) * -1vw));will-change:transform}
.se-t2{transform:translateX(calc(var(--se-tx,0) * 1vw));will-change:transform}
/* invitación a scrollear (se desvanece al expandir) */
.se-meta{position:absolute;z-index:2;left:50%;bottom:8%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;
  opacity:calc(1 - var(--se-prog,0) * 1.7)}
.se-meta .se-hint{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft)}

@media (max-width:767px){ .se-media{--se-wadd:650px;--se-hadd:200px} }

@media (prefers-reduced-motion:reduce){
  .se-stage{height:auto;padding:16vh 0 8vh}
  .se-media{margin:0 auto;width:min(95vw,1080px);height:auto;aspect-ratio:16/9}
  .se-media iframe{position:relative;top:auto;left:auto;transform:none;width:100%;height:100%}
  .se-titles{position:relative;margin-bottom:6vh}
  .se-t1,.se-t2{transform:none}
  .se-meta{display:none}
}

/* ============================================================
   EQUIPO ALTO DESEMPEÑO — CARRUSEL horizontal de retratos (cards
   diseñadas con el nombre incrustado). Una sola fila → página corta.
   Auto-avance + flechas + swipe en assets/equipo-carousel.js.
   ============================================================ */
.equipo-rail{position:relative;margin-top:26px}
.equipo-track{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:4px 2px 14px;scrollbar-width:none;-ms-overflow-style:none}
.equipo-track::-webkit-scrollbar{display:none}
.equipo-card{flex:0 0 auto;width:clamp(180px,42vw,228px);scroll-snap-align:start;
  position:relative;margin:0;border-radius:14px;overflow:hidden;aspect-ratio:1;
  background:var(--surface-2);border:1px solid var(--line);
  transition:transform .4s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease)}
.equipo-card img{width:100%;height:100%;object-fit:cover;display:block}
.equipo-card:hover{transform:translateY(-5px);border-color:var(--line-2);box-shadow:0 16px 40px rgba(0,0,0,.5)}
/* mentora: anillo de acento sutil para distinguirla */
.equipo-card.is-mentor{border-color:color-mix(in srgb,var(--accent) 55%,transparent);
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 32%,transparent)}
/* flechas */
.equipo-nav{position:absolute;top:calc(50% - 7px);transform:translateY(-50%);z-index:5;
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;cursor:pointer;
  background:rgba(18,18,18,.72);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid var(--line-2);color:var(--ink);
  transition:background .25s var(--ease),color .25s var(--ease),transform .25s var(--ease)}
.equipo-nav svg{width:20px;height:20px}
.equipo-nav.prev{left:-8px}
.equipo-nav.next{right:-8px}
.equipo-nav:hover{background:var(--accent);color:var(--on-accent);transform:translateY(-50%) scale(1.08)}
.equipo-nav:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
@media (max-width:560px){ .equipo-nav{display:none} }   /* en móvil: swipe nativo */
