/* =====================================================================
   CACTUS — clon del lenguaje SuperHi adaptado a la marca
   Binario: azul eléctrico #1800D8  ·  ice #EEEEFF  ·  acento mint #A1FFC7
   Tipo: Manrope en TODO. Alaca SOLO en el logotipo (cactus).
   Profundidad: bordes inset 1px (sin sombras). Tipo grande. Split sticky.
   ===================================================================== */

@font-face {
  font-family: 'Alaca';
  src: url('../fonts/plasebo-studio-alaca-regular.otf') format('opentype');
  font-weight: 400; font-display: swap;
}

:root {
  --blue:   #1800D8;      /* cobalt voltage → azul Cactus */
  --ice:    #EEEEFF;      /* ice white → tinte Cactus (= fondo de página y de la botonera en modo azul) */
  --mist:   #5a5cff;      /* tono medio, fills suaves */
  --mint:   #A1FFC7;      /* acento de marca */
  --pitch:  #06002b;

  --logo: 'Alaca', sans-serif;
  --sans: 'Manrope', -apple-system, 'Helvetica Neue', Arial, sans-serif;

  --maxw: 1440px;
  --pad: clamp(20px, 4vw, 64px);
  --nav-h: 68px;
  --ease: cubic-bezier(.22, 1, .36, 1);

  /* botones: lenguaje brutalista editorial (caja de línea fina + sombra dura
     desplazada al interactuar; el color de la sombra = el de la línea según modo) */
  --btnsh: var(--blue);   /* sombra dura de los botones de LÍNEA (modo azul) */
  --pillsh: var(--mint);  /* sombra dura del CTA RELLENO (acento; el único lleno) */
  --press: 5px;           /* desplazamiento de la sombra */

  /* escala SuperHi (16/18/24/32/42/56/85) llevada a clamp grande */
  --t-display: clamp(2.6rem, 5.4vw, 5.3rem);   /* ~85px */
  --t-lg:      clamp(2rem, 3.6vw, 3.5rem);     /* ~56px */
  --t-md:      clamp(1.6rem, 2.6vw, 2.6rem);   /* ~42px */
  --t-sm:      clamp(1.4rem, 2vw, 2rem);       /* ~32px */
  --t-body:    clamp(1.15rem, 1.4vw, 1.5rem);  /* 18→24px */
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%;
  /* el scroll se detiene al inicio de cada sección (suave: solo al acercarse).
     Dentro de cada sección se scrollea libre por el contenido alto de la derecha. */
  scroll-snap-type: y proximity; }
body {
  font-family: var(--sans); font-weight: 400;
  background: var(--ice); color: var(--blue);
  font-size: var(--t-body); line-height: 1.4;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
.u { /* énfasis sin subrayado: solo peso */
  font-weight: 600;
}
::selection { background: var(--mint); color: var(--blue); }

/* ============ FONDO CONMUTABLE: azul sólido (def.) ↔ degradado dinámico ============
   .bgfx = capa fija con degradado-malla en gama azul/violeta (oscuro → texto blanco
   siempre legible, como el viaje de color). En modo .bg-grad los bloques azules se
   vuelven transparentes y dejan ver esta malla, que DERIVA con el scroll (--gp, lo
   actualiza el JS) y respira despacio. Los bloques claros (ice) se mantienen → cero
   riesgo de contraste. El usuario conmuta con el control de arriba a la derecha. */
.bgfx {
  position: fixed; inset: -8%; z-index: -1; pointer-events: none;
  opacity: 0; transition: opacity .6s var(--ease);
  /* viaje SOLO en familia azul → TEAL/petróleo (sin verde menta): se mantiene oscuro y
     saturado de arriba abajo, así el texto blanco se lee siempre (no hay tramo claro). */
  --gpc: calc(var(--gp, 0) * 100%);
  background:
    radial-gradient(50% 46% at calc(20% + var(--gp,0) * 24%) calc(18% + var(--gp,0) * 30%),
      color-mix(in oklab, #3a4fd6, #1a7d9c var(--gpc)) 0%, transparent 60%),
    radial-gradient(48% 46% at calc(82% - var(--gp,0) * 26%) calc(84% - var(--gp,0) * 24%),
      color-mix(in oklab, #1d0f8f, #0e5f7a var(--gpc)) 0%, transparent 62%),
    linear-gradient(160deg,
      color-mix(in oklab, #1800D8, #0e5c7a var(--gpc)) 0%,
      color-mix(in oklab, #16109a, #105a78 var(--gpc)) 55%,
      color-mix(in oklab, #0f2e8f, #0d4f6b var(--gpc)) 100%);
  animation: bgbreathe 24s ease-in-out infinite alternate;
  will-change: transform;
}
html.bg-grad .bgfx { opacity: 1; }
@keyframes bgbreathe {
  from { transform: translate3d(0, 0, 0) scale(1); }
  to   { transform: translate3d(-2%, 1.6%, 0) scale(1.06); }
}
/* MODO DEGRADADO (Opción 2): se eliminan TODOS los bloques y separaciones —cada
   sección es transparente y deja ver el degradado continuo de .bgfx (azul→verde)— y
   el texto se maqueta encima en blanco (ice). Misma composición, sin recuadros. */
html.bg-grad { color: var(--ice); }
html.bg-grad .hero,
html.bg-grad .marquee,
html.bg-grad .banner,
html.bg-grad .duo__pin,
html.bg-grad .duo__flow { background: transparent !important; color: var(--ice); }
/* CIERRE + PIE: TRANSPARENTES en modo degradado (lo pidió el cliente). El degradado de
   .bgfx (fijo, azul→teal) llega hasta el final de la página y el pie se FUSIONA con él:
   sin fondo propio, solo texto blanco (ice) + acentos verde menta. */
html.bg-grad .closing,
html.bg-grad .footer {
  background: transparent !important;
  color: var(--ice);
}
html.bg-grad .hero__eyebrow,
html.bg-grad .hero__word,
html.bg-grad .closing__kicker,
html.bg-grad .closing__big { color: var(--ice); }
html.bg-grad .marquee { border-color: rgba(238, 238, 255, .22); }
/* botonera: SIEMPRE clara (fondo ice, texto azul) en LOS DOS modos —azul y degradado—
   (lo pidió el cliente). No se invierte sobre el degradado: la nav fija en ice da un
   contraste constante sea cual sea el fondo que quede detrás. */
html.bg-grad { --btnsh: var(--ice); --pillsh: var(--blue); }   /* sombras al invertir el fondo */
html.bg-grad .pill { background: var(--mint); color: var(--blue); border-color: var(--mint); }
/* transición suave del color de fondo/texto al conmutar de modo */
html.bg-grad .duo__pin, html.bg-grad .duo__flow, html.bg-grad .closing, html.bg-grad .closing__big,
html.bg-grad .closing__kicker, html.bg-grad .footer,
html.bg-grad .pill { transition: color .35s var(--ease), background-color .35s var(--ease); }
/* (Se eliminó el "tramo final claro": el degradado ya no llega a verde menta; se queda
   en azul→teal oscuro de arriba abajo, así que el texto blanco se lee siempre.) */

/* conmutador (2 swatches) arriba a la derecha */
/* dos círculos pequeños, sin caja ni líneas: el activo va a opacidad/tamaño plenos,
   el inactivo más tenue y pequeño (indica la selección sin recuadros ni bordes). */
/* SIEMPRE en el mismo sitio (arriba-dcha, fijo): z-index por encima de los overlays
   (.zine/.work 200 · lectores 220) para que se vea igual en index, listados y lectores. */
.bgtoggle { position: fixed; top: 26px; right: var(--pad); z-index: 240;
  display: flex; gap: 11px; background: none; border: 0; padding: 0; }
.bgtoggle__sw { width: 16px; height: 16px; border-radius: 50%; border: 0; padding: 0; cursor: pointer;
  opacity: .4; transform: scale(.86);
  transition: opacity .3s var(--ease), transform .3s var(--ease); }
.bgtoggle__sw:hover { opacity: .8; }
.bgtoggle__sw[aria-pressed="true"] { opacity: 1; transform: scale(1); }
.bgtoggle__sw[data-bg="solid"] { background: var(--blue); }
.bgtoggle__sw[data-bg="grad"] { background: linear-gradient(135deg, #1800D8, #0e5c7a 65%, #2ec5dd); }
/* sobre los lectores en modo degradado el swatch azul necesita un aro para no perderse */
html.bg-grad .bgtoggle__sw[data-bg="solid"] { box-shadow: 0 0 0 1px rgba(238,238,255,.5); }

/* botonera de secciones dentro de los overlays (listados): saltar de sección en 1 clic.
   En proyecto/noticia DESPLEGADOS no aparece (ahí manda el ←). */
.overlay-nav { display: flex; align-items: center; gap: clamp(14px, 2.2vw, 32px); }
.overlay-nav a { font-size: var(--t-body); font-weight: 600; letter-spacing: -.01em; color: currentColor; opacity: .5; transition: opacity .25s var(--ease); }
.overlay-nav a:hover { opacity: 1; }
/* sección ACTUAL marcada con subrayado de acento (mint), en cada contexto */
.nav__links a.is-current, .overlay-nav a.is-current {
  opacity: 1; text-decoration: underline; text-decoration-color: var(--mint);
  text-underline-offset: 6px; text-decoration-thickness: 2px; }
@media (max-width: 560px) {
  .overlay-nav { gap: 14px; }
  .overlay-nav a { font-size: clamp(14px, 4vw, 17px); }
}
@media (prefers-reduced-motion: reduce) {
  .bgfx { animation: none; }
  /* descanso sin pin ni deslizamiento: las 3 frases, apiladas y estáticas */
  .banner { height: auto; }
  .banner__sticky { position: static; height: auto; display: block; overflow: visible;
    -webkit-mask-image: none; mask-image: none; padding: clamp(60px, 12vh, 140px) var(--pad); }
  .banner__track { display: block; transform: none !important; padding: 0; }
  .banner__phrase { white-space: normal; margin: 0 auto clamp(20px, 3.6vh, 42px); max-width: 26ch; }
}

/* ============ NAV ============ */
.nav {
  position: fixed; inset: 0 0 auto 0; height: var(--nav-h); z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--pad);
  background: transparent;
  /* oculta en la primera pantalla; aparece al hacer scroll */
  transform: translateY(-100%); opacity: 0; pointer-events: none;
  transition: transform .55s var(--ease), opacity .4s var(--ease), background .4s var(--ease), box-shadow .4s var(--ease);
}
.nav.is-solid { transform: none; opacity: 1; pointer-events: auto; background: var(--ice); }
/* reserva a la derecha para no solaparse con el conmutador de fondo (esquina sup. dcha.) */
.nav.is-solid { padding-right: calc(var(--pad) + 84px); }
.nav.is-solid .nav__brand, .nav.is-solid .nav__links a { color: var(--blue); }
.nav.is-solid .nav__cta { background: var(--blue); color: var(--ice) !important; }
/* Decimos/Hacemos son páginas propias (sin hero): la botonera está SIEMPRE visible
   y sólida desde el primer pintado (el JS además fija .is-solid para el modo degradado). */
body.sub .nav { transform: none; opacity: 1; pointer-events: auto; background: var(--ice);
  padding-right: calc(var(--pad) + 84px); }
.nav__brand { font-family: var(--logo); font-size: 32px; line-height: 1; color: var(--blue); }
.nav__links { display: flex; align-items: center; gap: clamp(14px, 2vw, 30px); }
.nav__links a { font-size: 19px; font-weight: 600; color: var(--blue); transition: opacity .25s; }
.nav__links a:hover { opacity: .6; }
.nav__cta { background: none; color: var(--blue) !important; padding: 8px 18px; border-radius: 0;
  border: 1.5px solid var(--blue);
  transition: transform .16s var(--ease), box-shadow .16s var(--ease); }
.nav__cta:hover { opacity: 1 !important; transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--blue); }
.nav__cta:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--blue); }
@media (max-width: 760px) { .nav__links a:not(.nav__cta) { display: none; } }


/* ============ HERO ============ */
.hero {
  min-height: 100svh; background: var(--ice);
  padding: clamp(20px, 4vh, 44px) clamp(18px, 2.4vw, 36px) clamp(24px, 4vh, 52px);
  display: flex; flex-direction: column; justify-content: space-between;
}
.hero__eyebrow { font-size: clamp(13px, 1.1vw, 16px); font-weight: 500; color: var(--blue); letter-spacing: .01em; }
.hero__word {
  font-family: var(--logo); font-weight: 400;
  font-size: 30vw; line-height: .82; letter-spacing: -.085em; color: var(--blue);
  text-align: center; white-space: nowrap; margin: 0; user-select: none; will-change: transform;
  /* el letter-spacing negativo deja un hueco tras la última letra y descentra ópticamente
     el bloque hacia la derecha; este padding-right (= |letter-spacing|) lo recentra. */
  padding-right: .085em;
}
/* .ltr = capa de INTERACCIÓN (muelle magnético con el ratón, vía JS: translate+rotate).
   .ltr__in = capa de CARGA (fade letra a letra). Separadas para que no choquen. */
.hero__word .ltr { display: inline-block; line-height: .8; will-change: transform; }
.hero__word .ltr__in { display: inline-block; }
.js .hero__word .ltr__in { opacity: 0; transform: translateY(.1em); }
/* fade letra a letra, de izquierda a derecha */
body.is-ready .hero__word .ltr__in { animation: letterFade .6s var(--ease) forwards; }
.hero__word .ltr:nth-child(1) .ltr__in { animation-delay: .10s; }
.hero__word .ltr:nth-child(2) .ltr__in { animation-delay: .22s; }
.hero__word .ltr:nth-child(3) .ltr__in { animation-delay: .34s; }
.hero__word .ltr:nth-child(4) .ltr__in { animation-delay: .46s; }
.hero__word .ltr:nth-child(5) .ltr__in { animation-delay: .58s; }
.hero__word .ltr:nth-child(6) .ltr__in { animation-delay: .70s; }
@keyframes letterFade { to { opacity: 1; transform: none; } }


/* ============ MARQUEE ============ */
.marquee { background: var(--blue); color: var(--ice); overflow: hidden; padding: clamp(16px, 2.2vw, 30px) 0; border-block: 1px solid var(--blue); }
.marquee__track { display: inline-flex; align-items: center; gap: 36px; white-space: nowrap; animation: scrollx 28s linear infinite; will-change: transform; }
.marquee__track span { font-size: clamp(1.6rem, 3vw, 3rem); font-weight: 500; }
.marquee__track .dot { color: var(--mint); font-size: .7em; }
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes scrollx { to { transform: translateX(-50%); } }

/* ============ DUO · split sticky ============ */
.duo { display: grid; grid-template-columns: 1fr 1fr; align-items: start;
  scroll-snap-align: start; }       /* punto de parada al comenzar la sección */

.duo__pin {
  position: sticky; top: 0; align-self: start;
  min-height: 100svh; padding: clamp(40px, 6vw, 96px) var(--pad);
  display: flex; flex-direction: column; justify-content: center; gap: 18px;
  overflow: hidden;
}
.duo__flow {
  min-height: 100svh; padding: clamp(80px, 12vh, 180px) var(--pad);
  display: flex; flex-direction: column; gap: clamp(40px, 6vh, 80px);
}
/* binario: qué lado es azul */
.duo--blueleft .duo__pin  { background: var(--blue); color: var(--ice); }
.duo--blueleft .duo__flow { background: var(--ice);  color: var(--blue); }
.duo--iceleft  .duo__pin  { background: var(--ice);  color: var(--blue); }
.duo--iceleft  .duo__flow { background: var(--blue); color: var(--ice); }

/* VIAJE DE COLOR (azul→verde): los bloques azules reciben su trozo del
   degradado global vía main.js (inline). Cuando el color se aclara (verde),
   el texto pasa a azul oscuro. Los bloques ice se quedan planos (brutalismo). */
.marquee, .duo__pin, .duo__flow, .banner { transition: background .4s linear; }

.duo__num {
  font-family: var(--sans); font-weight: 400; font-size: clamp(5rem, 13vw, 13rem);
  line-height: .8; color: transparent; -webkit-text-stroke: 2px currentColor;
  opacity: .55; will-change: transform; letter-spacing: -.02em;
}
.duo__kicker { font-size: clamp(15px, 1.2vw, 18px); font-weight: 600; letter-spacing: .02em; opacity: .8; }
.duo__display { font-size: var(--t-display); font-weight: 500; line-height: .98; letter-spacing: -.02em; text-wrap: balance; }

/* contenido del flow · DOS niveles y nada más:
   nivel 1 = .lead / titulines de lista ; nivel 2 = cuerpo (p) */
.duo__flow p { max-width: 28ch; font-size: var(--t-md); font-weight: 500; line-height: 1.2; letter-spacing: -.02em; }
.lead { max-width: 17ch; font-size: var(--t-lg); font-weight: 600; line-height: 1; letter-spacing: -.03em; }
/* destino de "Sentimos": el comienzo del CONTENIDO (no el hero), con holgura bajo el nav */
#contenido { scroll-margin-top: calc(var(--nav-h) + 28px); }
.flow__item p + p,
.flow__item .lead + p { margin-top: clamp(22px, 2.8vh, 36px); }

/* lista numerada: numeral grande en mint, sin círculo */
.numlist { list-style: none; display: flex; flex-direction: column; gap: clamp(28px, 4vh, 48px); }
.numlist__item { display: grid; grid-template-columns: auto 1fr; gap: clamp(16px, 2vw, 28px); align-items: start; }
.numlist__n {
  font-family: var(--sans); font-size: var(--t-lg); font-weight: 600;
  line-height: 1; color: var(--mint); min-width: 1.1em;
}
.numlist__item h3 { font-size: var(--t-lg); font-weight: 600; line-height: 1; letter-spacing: -.03em; margin-bottom: 12px; }
.numlist__item p { max-width: 26ch; }

/* bloques de producción (no clicables): separadores por línea, sin caja */
.arrowblock { display: block; padding: clamp(22px, 2.6vw, 34px) 0; border-top: 1px solid currentColor; }
.arrowblock:last-child { border-bottom: 1px solid currentColor; }
.arrowblock h3 { font-size: var(--t-lg); font-weight: 600; line-height: 1; letter-spacing: -.03em; margin-bottom: 14px; }

/* ============ BANNER ============ */
/* DESCANSO DE LECTURA (ref. itsoffbrand): sección alta (track de scroll) con un panel
   fijo; dentro, una PISTA horizontal de frases que se desliza —entrando por la derecha—
   conforme scrolleas. Sin fondo propio → es una pausa, no un bloque. El color lo hereda
   del modo (azul en op.1, blanco en op.2). Tamaño contenido (una línea por frase). */
.banner { position: relative; height: 300vh; background: none; padding: 0; }
.banner__sticky { position: sticky; top: 0; height: 100vh; display: flex; align-items: center; overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 26%, #000 74%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0, #000 26%, #000 74%, transparent 100%); }
.banner__track { display: flex; flex-wrap: nowrap; align-items: center; gap: 7vw; padding: 0 52vw; will-change: transform; }
.banner__phrase { flex: 0 0 auto; white-space: normal; text-align: center; text-wrap: balance; margin: 0;
  font-size: var(--t-display); font-weight: 500; line-height: .98; letter-spacing: -.02em; }
/* cada frase en DOS líneas: la 2ª parte (destacada) baja de línea, como el cierre */
.banner__phrase .u { display: block; font-weight: 600; }

/* ============ CLOSING ============ */
.closing { background: var(--ice); color: var(--blue); text-align: center; padding: clamp(90px, 18vh, 240px) var(--pad); }
.closing__kicker { font-size: clamp(15px, 1.2vw, 18px); font-weight: 600; opacity: .7; margin-bottom: 24px; }
.closing__big { font-size: var(--t-display); font-weight: 500; line-height: .98; letter-spacing: -.02em; max-width: 16ch; margin: 0 auto 44px; text-wrap: balance; }
.pill { display: inline-block; background: var(--blue); color: var(--ice); border: 2px solid var(--blue);
  font-size: var(--t-body); font-weight: 600; padding: 16px 36px; border-radius: 0;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease), background-color .3s var(--ease), color .3s var(--ease); }
.pill:hover { transform: translate(-3px, -3px); box-shadow: var(--press) var(--press) 0 0 var(--pillsh); }
.pill:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--pillsh); }

/* ============ FOCO ACCESIBLE (teclado) ============
   navegación por tab con el MISMO lenguaje de marca: marco + sombra dura desplazada.
   :focus-visible solo se activa con teclado (no al hacer click con ratón). */
.zine__chip:focus-visible, .ask__chip:focus-visible, .ask__btn:focus-visible, .ask__close:focus-visible,
.work__close:focus-visible, .work__back:focus-visible, .zine__close:focus-visible, .zine__back:focus-visible,
.work__totop:focus-visible, .zine__totop:focus-visible, .totop:focus-visible {
  outline: none; transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.pill:focus-visible { outline: none; transform: translate(-3px, -3px); box-shadow: var(--press) var(--press) 0 0 var(--pillsh); }
.nav__cta:focus-visible { outline: none; transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--blue); }
/* enlaces de texto (nav, pie, listas): aro fino visible solo con teclado */
a:focus-visible, .work__more button:focus-visible, .zine__more button:focus-visible {
  outline: 2px solid var(--btnsh); outline-offset: 3px; border-radius: 1px; }

/* ============ FOOTER ============ */
.footer { background: var(--blue); color: var(--ice); padding: clamp(56px, 8vh, 96px) var(--pad) 32px; }
.footer__grid { display: grid; grid-template-columns: 1.2fr 2fr; gap: 48px; align-items: start; max-width: var(--maxw); margin: 0 auto; }
.footer__slogan { font-size: var(--t-md); font-weight: 500; line-height: 1.05; max-width: 14ch; }
.footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.footer__cols h5 { font-size: 13px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--mint); margin-bottom: 12px; }
.footer__cols p { font-size: 17px; line-height: 1.8; opacity: .82; }
.footer__cols a:hover { color: var(--mint); }
.footer__meta { text-align: center; font-size: 14px; opacity: .7; margin-top: clamp(40px, 7vh, 80px); }

/* ============ REVEALS ============ */
/* genérico: sube y aparece (banner, cierre…) */
.js [data-reveal] { opacity: 0; transform: translateY(40px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.js [data-reveal].in { opacity: 1; transform: none; }

/* Revelado por LÍNEAS (ref. dashdigital): el JS parte cada texto en renglones,
   cada uno con su máscara (.ln) y su interior animable (.ln__i). El retardo por
   línea (--d) y el desplazamiento (--x) los fija el JS para la cascada. */
.ln { display: block; overflow: hidden; }
.ln__i { display: block; will-change: transform; }
/* hueco para descendentes (g, y, p): la máscara no los recorta en reposo */
.js .duo__kicker .ln, .js .duo__display .ln, .js .duo__flow .ln { padding-bottom: .16em; margin-bottom: -.16em; }

/* IZQUIERDA · cada línea SUBE desde abajo, escalonada */
.js .duo__pin[data-reveal] { opacity: 1; transform: none; }      /* el contenedor no se mueve */
.js .duo__pin .ln__i { transform: translateY(115%); transition: transform 1.5s var(--ease); transition-delay: var(--d, 0s); }
.js .duo__pin.in .ln__i { transform: none; }

/* DERECHA · cada línea ENTRA DESDE LA DERECHA, escalonada (cascada) */
.js .duo__flow [data-reveal] { opacity: 1; transform: none; }
.js .duo__flow .ln__i { transform: translateX(var(--x, 60px)); opacity: 0; transition: transform 1.5s var(--ease), opacity .9s var(--ease); transition-delay: var(--d, 0s); }
.js .duo__flow [data-reveal].in .ln__i { transform: none; opacity: 1; }

/* tras un resize ya revelado: recoloco sin volver a animar */
.js .is-settled .ln__i { transition: none !important; transform: none !important; opacity: 1 !important; }

/* ============ RESPONSIVE ============ */
@media (max-width: 860px) {
  .duo { grid-template-columns: 1fr; }
  .duo__pin { position: static; min-height: auto; padding-block: clamp(56px, 12vh, 96px); }
  .duo__flow { min-height: auto; padding-block: clamp(56px, 10vh, 96px); }
  .footer__grid { grid-template-columns: 1fr; }
  .footer__cols { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .footer__cols { grid-template-columns: 1fr; }
  .numlist__item { grid-template-columns: 1fr; gap: 12px; }
}
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
  .js .hero__word .ltr__in { opacity: 1 !important; transform: none !important; }
  .js [data-reveal] { opacity: 1 !important; transform: none !important; }
  .js .ln__i { transform: none !important; opacity: 1 !important; }
  .marquee__track { animation: none !important; }
}

/* ============ CURSOR (blob verde, mix-blend multiply) ============ */
.cursor {
  position: fixed; top: 0; left: 0; width: 64px; height: 64px;
  border-radius: 50%; background: var(--mint);
  mix-blend-mode: multiply; pointer-events: none; z-index: 9999;
  will-change: transform; opacity: 0;
  transition: opacity .3s ease, width .25s var(--ease), height .25s var(--ease);
}
.cursor.is-active { opacity: 1; }
/* crece al pasar sobre enlaces/botones */
.cursor.is-hover { width: 110px; height: 110px; }
/* dejamos VISIBLE la flecha nativa del sistema (punta exacta) + el blob detrás */
@media (hover: none), (pointer: coarse) { .cursor { display: none; } }

/* ============ TRABAJOS · overlay portfolio (ref. itsoffbrand) ============ */
/* tonos placeholder de marca (mientras no haya imágenes reales) */
.tone-0 { --ph: #1800D8; --pht: #EEEEFF; }
.tone-1 { --ph: #3D5BFF; --pht: #EEEEFF; }
.tone-2 { --ph: #06002b; --pht: #EEEEFF; }
.tone-3 { --ph: #A1FFC7; --pht: #1800D8; }

/* Hacemos = PÁGINA propia (antes overlay): flujo normal bajo la botonera fija */
.work {
  position: relative; z-index: 1;
  background: var(--ice); color: var(--blue);
  display: flex; flex-direction: column; gap: clamp(18px, 3vh, 40px);
  min-height: 100vh;
  padding: calc(var(--nav-h) + clamp(20px, 4vw, 56px)) clamp(20px, 4vw, 56px) clamp(40px, 8vh, 90px);
}
/* bloqueo de scroll del fondo mientras se lee un proyecto/entrada a pantalla completa */
body.reading { overflow: hidden; }
/* al leer (ficha/entrada/formulario en panel fijo a pantalla completa, por debajo de la
   botonera), en modo degradado el panel es transparente para dejar ver el mismo .bgfx;
   ocultamos lo que queda detrás para que NO se transparente el listado ni el index. */
body.reading .work__list, body.reading .work__mini,
body.reading .zine__filter, body.reading .zine__list,
body.reading .hero, body.reading .marquee, body.reading main,
body.reading .footer, body.reading .totop { visibility: hidden; }
/* …pero el panel que se está leyendo (vive DENTRO de <main> en las subpáginas) y su
   cortina SÍ se ven: anulan el visibility heredado de su contenedor oculto. */
body.reading .work__detail, body.reading .zine__reader, body.reading .ask,
body.reading .work__curtain, body.reading .zine__curtain,
body.reading .ask__curtain { visibility: visible; }

.work__eyebrow { font-size: var(--t-body); font-weight: 600; letter-spacing: -.01em; }
/* botones del overlay ✕/← redondos (ghost), coherentes con el botón "↑"; el aro usa
   currentColor (azul en modo claro, ice en degradado) y al hover aparece el aro mint. */
.work__close, .work__back {
  appearance: none; -webkit-appearance: none; cursor: pointer; padding: 0; flex: 0 0 auto;
  width: 44px; height: 44px; border-radius: 0; display: grid; place-items: center;
  background: none; border: 1px solid currentColor; color: var(--blue);
  font-size: 19px; font-weight: 500; line-height: 1;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease), color .3s var(--ease); }
.work__close { margin-left: auto; }
.work__close:hover, .work__back:hover { transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.work__close:active, .work__back:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--btnsh); }

.work__list { list-style: none; }
.work__row {
  display: grid; grid-template-columns: auto 1fr auto; align-items: baseline;
  gap: clamp(16px, 2.5vw, 40px);
  padding: clamp(10px, 1.5vh, 22px) 0; border-bottom: 1px solid var(--blue);
  cursor: pointer; overflow: hidden;
}
.work__n { font-size: var(--t-body); font-weight: 600; opacity: .5; font-variant-numeric: tabular-nums; }
.work__name { font-size: var(--t-md); font-weight: 600; line-height: 1; letter-spacing: -.03em; }
.work__cat { font-size: var(--t-body); opacity: .55; white-space: nowrap; text-align: right; }
/* hover: la activa se resalta, el resto baja */
.work__list.has-hover .work__row { opacity: .3; transition: opacity .3s var(--ease); }
.work__list.has-hover .work__row.is-active { opacity: 1; }
/* entrada en cascada al abrir (máscara por fila) */
.js .work__row > * { transform: translateY(120%); transition: transform 1.3s var(--ease); transition-delay: var(--d, 0s); }
.js .work__list.is-revealed .work__row > * { transform: none; }

/* miniatura que sigue al cursor */
.work__mini { position: fixed; top: 0; left: 0; z-index: 10000; pointer-events: none;
  width: clamp(190px, 19vw, 300px); aspect-ratio: 4 / 3; will-change: transform; }
.work__mini__img { position: absolute; inset: 0; display: grid; place-items: center;
  background-color: var(--ph, var(--blue)); color: var(--pht, var(--ice));
  background-size: cover; background-position: center; filter: grayscale(1) contrast(1.12) brightness(1.02);
  font-size: clamp(2.4rem, 4vw, 4rem); font-weight: 600; letter-spacing: -.03em;
  opacity: 0; transform: scale(.92); transition: opacity .35s var(--ease), transform .45s var(--ease); }
.work__mini.is-on .work__mini__img { opacity: 1; transform: scale(1); }

/* ficha de detalle: página de proyecto larga (ref. itsoffbrand), entra con cortina */
/* ficha de proyecto: panel fijo a pantalla completa POR DEBAJO de la botonera (z<nav) */
.work__detail { position: fixed; inset: 0; z-index: 90; display: none;
  background: var(--ice); color: var(--blue);
  overflow-y: auto; padding: calc(var(--nav-h) + clamp(20px, 4vw, 56px)) clamp(20px, 4vw, 56px) 0; }
.work__detail.is-open { display: block; }
.work__detail__bar { display: flex; align-items: center; justify-content: space-between;
  padding-bottom: clamp(18px, 2.6vh, 32px); }

/* flecha "volver arriba": fija a la derecha; acompaña al scrollear la ficha y, al
   pulsar, vuelve al principio del proyecto. Aparece solo cuando hay scroll. */
.work__totop, .zine__totop, .totop {
  position: fixed; right: clamp(20px, 4vw, 56px); bottom: clamp(20px, 4vw, 56px); z-index: 230;
  width: 56px; height: 56px; border-radius: 0; display: grid; place-items: center;
  appearance: none; -webkit-appearance: none; background: var(--ice); color: var(--blue);
  border: 1.5px solid var(--blue); cursor: pointer; font-size: 24px; line-height: 1;
  opacity: 0; transform: translateY(12px); pointer-events: none;
  transition: opacity .4s var(--ease), transform .4s var(--ease), box-shadow .16s var(--ease);
}
html.bg-grad .work__totop, html.bg-grad .zine__totop, html.bg-grad .totop {
  background: var(--blue); color: var(--ice); border-color: var(--ice); }
.totop { z-index: 115; }  /* el del index va por debajo del overlay de Trabajos */
.work__totop.is-on, .zine__totop.is-on, .totop.is-on { opacity: 1; transform: none; pointer-events: auto; }
.work__totop:hover, .zine__totop:hover, .totop:hover { box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.work__totop:active, .zine__totop:active, .totop:active { box-shadow: 2px 2px 0 0 var(--btnsh); }
/* el botón del index se oculta cuando el overlay de Trabajos está abierto */
body.work-open .totop { opacity: 0 !important; pointer-events: none !important; }

/* cortina de entrada (wipe vertical) */
.work__curtain, .zine__curtain { position: fixed; inset: 0; z-index: 10001; background: var(--blue);
  transform: translateY(100%); pointer-events: none; }
.work__curtain.wipe, .zine__curtain.wipe { animation: curtainWipe 1.45s var(--ease) forwards; }
@keyframes curtainWipe {
  0% { transform: translateY(100%); } 42% { transform: translateY(0); }
  58% { transform: translateY(0); } 100% { transform: translateY(-100%); }
}

/* cada caso, como página larga scrolleable */
.work__cases { max-width: var(--maxw); margin: 0 auto; width: 100%; }
.work__case { display: none; flex-direction: column; gap: clamp(48px, 9vh, 130px); padding-block: clamp(40px, 7vh, 96px); }
.work__case.is-active { display: flex; }
.case__top { display: flex; flex-direction: column; gap: clamp(20px, 3vh, 40px); }
/* kicker (lo inyecta el JS desde la categoría) — misma lógica que el duo__kicker del index */
.case__kicker { font-size: clamp(15px, 1.2vw, 18px); font-weight: 600; letter-spacing: .02em; opacity: .6; margin-bottom: clamp(10px, 1.4vh, 16px); }
/* título a la escala display del index (peso 500), con revelado por líneas */
.case__title { font-size: var(--t-display); font-weight: 500; line-height: .98; letter-spacing: -.02em; max-width: 15ch; }
.case__meta { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(16px, 2vw, 32px);
  border-top: 1px solid var(--blue); padding-top: clamp(18px, 2.4vh, 28px); }
.case__meta dt { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; opacity: .55; margin-bottom: 6px; }
.case__meta dd { font-size: var(--t-body); line-height: 1.3; }
.case__hero { width: 100%; aspect-ratio: 16 / 9; }
.case__qa { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 80px); }
.case__qa h3 { font-size: clamp(15px, 1.2vw, 18px); font-weight: 600; letter-spacing: .02em; opacity: .55; margin-bottom: 14px; }
/* reto/objetivo = enunciados (nivel 1, peso fuerte), como el .lead del index */
.case__qa p { font-size: var(--t-md); font-weight: 600; line-height: 1.1; letter-spacing: -.025em; }
/* editorial = cuerpo (nivel 2) en una columna y a la escala grande del index (sin texto pequeño) */
.case__editorial { display: flex; flex-direction: column; gap: clamp(20px, 2.6vh, 34px); max-width: 40ch; }
.case__editorial p { font-size: var(--t-sm); font-weight: 500; line-height: 1.25; letter-spacing: -.015em; }
.case__caption { font-size: var(--t-md); font-weight: 500; line-height: 1.08; letter-spacing: -.02em; max-width: 22ch; }

/* ---- FOTOS: B/N fundido con el fondo (blend), a todo color al hover ----
   B/N por filtro grayscale+contraste y, además, blend ADAPTATIVO con el fondo:
   · modo claro → multiply (los blancos se funden con el ice → look editorial)
   · modo degradado → screen (los negros se funden → la foto flota luminosa)
   Al hover: blend normal + color → la foto se "solidifica" con marco a todo color. */
.case__hero, .case__shot {
  position: relative; overflow: hidden;
  background-color: var(--ice); background-size: cover; background-position: center;
  filter: grayscale(1) contrast(1.12) brightness(1.02);
  mix-blend-mode: multiply;
}
/* el blend NO cambia en hover (cambiarlo daba un salto): solo se funde B/N→color,
   lento y suave, manteniendo la foto integrada con el fondo en ambos estados. */
.case__hero:hover, .case__shot:hover { filter: grayscale(0) contrast(1) brightness(1); }
html.bg-grad .case__hero, html.bg-grad .case__shot { mix-blend-mode: screen; }

/* galería: variantes de composición por proyecto */
.case__gallery { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(12px, 1.5vw, 24px); }
.case__shot { aspect-ratio: 4 / 5; }
.case__gallery--solo { grid-template-columns: 1fr; }
.case__gallery--solo .case__shot { aspect-ratio: 16 / 9; }
.case__gallery--portrait { grid-template-columns: 1fr; max-width: 62%; }
.case__gallery--portrait .case__shot { aspect-ratio: 4 / 5; }
.case__gallery--trio { grid-template-columns: repeat(3, 1fr); }
.case__gallery--trio .case__shot { aspect-ratio: 3 / 4; }
.case__gallery--mosaic .case__shot--wide { grid-column: 1 / -1; aspect-ratio: 16 / 9; }

/* vídeo como pieza protagonista (proyecto audiovisual) */
.case__hero--video { background-color: var(--pitch); filter: none; mix-blend-mode: normal; }
.case__hero--video::after { display: none; }
.case__hero--video iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

/* "Más trabajos" al final */
/* "Más trabajos": azul suave (--mist) y hairlines tenues → se lee como secundario,
   menos nítido que el contenido real. Al pasar el ratón vuelve al azul pleno. */
.work__more { border-top: 1px solid rgba(90,92,255,.22); padding: clamp(28px, 5vh, 56px) 0 clamp(40px, 8vh, 100px);
  max-width: var(--maxw); margin: 0 auto; width: 100%; }
.work__more__h { font-size: var(--t-body); font-weight: 600; color: var(--mist); opacity: .5; margin-bottom: 18px; }
.work__more ul { list-style: none; }
.work__more button { display: block; width: 100%; text-align: left; color: rgba(90,92,255,.55);
  appearance: none; -webkit-appearance: none; background: none; border: 0; cursor: pointer;
  font-size: var(--t-sm); font-weight: 600; letter-spacing: -.03em; line-height: 1;
  padding: clamp(10px, 1.4vh, 18px) 0; border-bottom: 1px solid rgba(90,92,255,.22);
  transition: color .3s var(--ease); }
.work__more li:first-child button { border-top: 1px solid rgba(90,92,255,.22); }
.work__more button:hover { color: var(--blue); }

/* ===== TRABAJOS unificado con el modo degradado =====
   En modo .bg-grad el overlay y las fichas dejan el ice plano y se asientan sobre el
   mismo azul→verde (fondo fijo, opaco para tapar el contenido del index), con el texto
   en blanco y los hairlines/acentos en ice translúcido. En modo azul, todo intacto. */
/* listado + ficha TRANSPARENTES → dejan ver el degradado ANIMADO de .bgfx, idéntico al
   index (antes llevaban un degradado estático propio, que se veía distinto al del resto). */
html.bg-grad .work,
html.bg-grad .work__detail { background: transparent; color: var(--ice); }
html.bg-grad .work__close, html.bg-grad .work__back { color: var(--ice); }
html.bg-grad .work__top { border-bottom-color: rgba(238, 238, 255, .28); }
html.bg-grad .work__row { border-bottom-color: rgba(238, 238, 255, .22); }
html.bg-grad .case__meta { border-top-color: rgba(238, 238, 255, .3); }
/* "Más trabajos" como secundario sobre el degradado (ice translúcido) */
html.bg-grad .work__more { border-top-color: rgba(238, 238, 255, .22); }
html.bg-grad .work__more__h { color: rgba(238, 238, 255, .6); }
html.bg-grad .work__more button { color: rgba(238, 238, 255, .55); border-bottom-color: rgba(238, 238, 255, .22); }
html.bg-grad .work__more li:first-child button { border-top-color: rgba(238, 238, 255, .22); }
html.bg-grad .work__more button:hover { color: var(--ice); }

/* revelados por scroll dentro de la ficha (texto sube / imágenes escalan) — sutil y elegante */
.js [data-r], .js [data-ri] { opacity: 0; }
.js [data-r] { transform: translateY(40px); transition: opacity 1.2s var(--ease), transform 1.3s var(--ease); }
.js [data-ri] { transform: scale(1.03); transition: opacity 1.4s var(--ease), transform 1.6s var(--ease), filter 1.4s var(--ease); }
.js [data-r].r-in, .js [data-ri].r-in { opacity: 1; transform: none; }

/* título de ficha / entrada: revelado por LÍNEAS como el index (el h2 queda fijo; suben las líneas con máscara) */
.js .case__title[data-r], .js .zine__atitle[data-r] { opacity: 1; transform: none; transition: none; }
.js .case__title .ln, .js .zine__atitle .ln { padding-bottom: .14em; margin-bottom: -.14em; }
.js .case__title .ln__i, .js .zine__atitle .ln__i { transform: translateY(115%); transition: transform 1.5s var(--ease); transition-delay: var(--d, 0s); }
.js .case__title.is-split-in .ln__i, .js .zine__atitle.is-split-in .ln__i { transform: none; }

@media (max-width: 860px) {
  .work__row { grid-template-columns: auto 1fr; }
  .work__cat { display: none; }
  .work__name { font-size: var(--t-sm); }
  .case__qa, .case__editorial, .case__gallery, .case__meta { grid-template-columns: 1fr; }
  .case__gallery--portrait { max-width: 100%; }
  .case__gallery--mosaic .case__shot--wide { grid-column: auto; }
}
@media (prefers-reduced-motion: reduce) {
  .js .work__row > *, .js .zine__row > * { transform: none !important; }
  .work__mini, .work__curtain, .zine__curtain, .ask__curtain { display: none; }
  .js [data-r], .js [data-ri] { opacity: 1 !important; transform: none !important; }
}

/* ============ DECIMOS · overlay magazine (lector editorial, sin fotos) ============
   Mismo lenguaje que "Hacemos" en clave editorial: listado tipo bitácora con filtro de
   categorías y lector interno de medida cómoda. Funciona en ambos modos de fondo. */
/* Decimos = PÁGINA propia (antes overlay): flujo normal bajo la botonera fija */
.zine {
  position: relative; z-index: 1;
  background: var(--ice); color: var(--blue);
  display: flex; flex-direction: column; gap: clamp(14px, 2.4vh, 30px);
  min-height: 100vh;
  padding: calc(var(--nav-h) + clamp(20px, 4vw, 56px)) clamp(20px, 4vw, 56px) clamp(40px, 8vh, 90px);
}
.zine__eyebrow { font-size: var(--t-body); font-weight: 600; letter-spacing: -.01em; }
.zine__close, .zine__back {
  appearance: none; -webkit-appearance: none; cursor: pointer; padding: 0; flex: 0 0 auto;
  width: 44px; height: 44px; border-radius: 0; display: grid; place-items: center;
  background: none; border: 1px solid currentColor; color: var(--blue);
  font-size: 19px; font-weight: 500; line-height: 1;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease), color .3s var(--ease); }
.zine__close { margin-left: auto; }
.zine__close:hover, .zine__back:hover { transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.zine__close:active, .zine__back:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--btnsh); }

/* filtro de categorías (chips: aro al inactivo, relleno al activo; sin caja pesada) */
.zine__filter { display: flex; flex-wrap: wrap; gap: clamp(8px, 1vw, 14px); }
.zine__chip {
  appearance: none; -webkit-appearance: none; cursor: pointer; font-family: inherit;
  background: none; border: 1.5px solid rgba(24, 0, 216, .3); color: var(--blue);
  font-size: clamp(13px, 1vw, 15px); font-weight: 600; letter-spacing: -.01em;
  padding: 8px 18px; border-radius: 0; opacity: .7;
  transition: opacity .3s var(--ease), transform .16s var(--ease), box-shadow .16s var(--ease), border-color .3s var(--ease), background .3s var(--ease), color .3s var(--ease); }
.zine__chip:hover { opacity: 1; border-color: var(--blue); transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.zine__chip:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--btnsh); }
.zine__chip.is-on { opacity: 1; border-color: var(--blue); border-width: 2px; background: rgba(24, 0, 216, .08);
  color: var(--blue); transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }

/* listado tipo bitácora */
.zine__list { list-style: none; }
.zine__row {
  display: grid; grid-template-columns: clamp(58px, 7vw, 100px) 1fr auto; align-items: baseline;
  gap: clamp(16px, 2.5vw, 44px);
  padding: clamp(14px, 2.2vh, 30px) 0; border-bottom: 1px solid var(--blue);
  cursor: pointer; overflow: hidden; }
.zine__row:first-child { border-top: 1px solid var(--blue); }
.zine__date { display: flex; flex-direction: column; line-height: 1; }
.zine__day { font-size: var(--t-md); font-weight: 700; letter-spacing: -.04em; font-variant-numeric: tabular-nums; }
.zine__my { font-size: 12px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; opacity: .5; margin-top: 7px; }
.zine__main { display: flex; flex-direction: column; gap: 9px; }
.zine__title { font-size: var(--t-sm); font-weight: 600; line-height: 1.02; letter-spacing: -.03em; }
.zine__dek { font-size: var(--t-body); font-weight: 400; line-height: 1.28; opacity: .62; max-width: 54ch; }
.zine__cat { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; opacity: .5; white-space: nowrap; text-align: right; }
/* hover: la activa se resalta, el resto baja (como Hacemos, pero sin miniatura) */
.zine__list.has-hover .zine__row { opacity: .35; transition: opacity .3s var(--ease); }
.zine__list.has-hover .zine__row.is-active { opacity: 1; }
.zine__row.is-hidden { display: none; }
/* entrada en cascada al abrir / al filtrar (máscara por fila) */
.js .zine__row > * { transform: translateY(120%); transition: transform 1.2s var(--ease); transition-delay: var(--d, 0s); }
.js .zine__list.is-revealed .zine__row > * { transform: none; }

/* lector editorial: la entrada se lee completa aquí dentro (entra con cortina) */
/* lector de noticia: panel fijo a pantalla completa POR DEBAJO de la botonera (z<nav) */
.zine__reader { position: fixed; inset: 0; z-index: 90; display: none;
  background: var(--ice); color: var(--blue);
  overflow-y: auto; padding: calc(var(--nav-h) + clamp(20px, 4vw, 56px)) clamp(20px, 4vw, 56px) 0; }
.zine__reader.is-open { display: block; }
/* barra del lector: conmutador de fondo a la izquierda · botón ← a la derecha */
.zine__reader__bar { display: flex; align-items: center; justify-content: space-between;
  padding-bottom: clamp(18px, 2.6vh, 32px); }

.zine__articles { max-width: 1080px; margin: 0 auto; width: 100%; }
.zine__article { display: none; flex-direction: column;
  padding-block: clamp(24px, 5vh, 64px) clamp(40px, 8vh, 96px); }
.zine__article.is-active { display: flex; }
/* cabecera editorial a UNA columna (maquetación anterior): título arriba · meta debajo */
.zine__head { display: flex; flex-direction: column; gap: clamp(14px, 2vh, 22px);
  padding-bottom: clamp(24px, 4vh, 46px); border-bottom: 1px solid currentColor;
  margin-bottom: clamp(34px, 6vh, 72px); }
.zine__atitle { font-size: var(--t-lg); font-weight: 600; line-height: 1.12; letter-spacing: -.03em; }
.zine__meta { display: flex; flex-direction: column; gap: 12px; }
.zine__kicker { font-size: clamp(13px, 1vw, 16px); font-weight: 600; letter-spacing: .12em; text-transform: uppercase; opacity: .55; }
.zine__byline { font-size: var(--t-body); opacity: .65; }
.zine__byline a { font-weight: 600; opacity: 1; border-bottom: 1px solid currentColor; transition: color .3s var(--ease); }
.zine__byline a:hover { color: var(--mist); }
/* …y el cuerpo a UNA sola columna cómoda, alineado bajo el título */
.zine__body { display: flex; flex-direction: column; gap: clamp(18px, 2.4vh, 30px); max-width: 64ch; }
.zine__body p { font-size: clamp(1.15rem, 1.4vw, 1.4rem); font-weight: 400; line-height: 1.55; letter-spacing: -.01em; }
.zine__lead { font-size: clamp(1.45rem, 2vw, 2rem) !important; font-weight: 600; line-height: 1.22; letter-spacing: -.02em; max-width: 32ch; }
.zine__body h3 { font-size: var(--t-sm); font-weight: 600; line-height: 1.04; letter-spacing: -.03em; margin-top: clamp(22px, 4vh, 52px); }
.zine__body h4 { font-size: var(--t-body); font-weight: 700; letter-spacing: -.01em; margin-top: clamp(10px, 2vh, 22px); }
.zine__ul { padding-left: 1.1em; display: flex; flex-direction: column; gap: 12px; }
.zine__ul li { font-size: clamp(1.05rem, 1.3vw, 1.28rem); line-height: 1.5; }
.zine__ul li::marker { color: var(--mint); }
.zine__aside { border-left: 3px solid var(--mint); padding-left: 20px; }
.zine__sign { opacity: .6; font-style: italic; }

/* "Seguir leyendo": entradas relacionadas al final (mismo patrón secundario que "Más trabajos") */
.zine__more { border-top: 1px solid rgba(90, 92, 255, .22); padding: clamp(28px, 5vh, 56px) 0 clamp(40px, 8vh, 90px);
  max-width: 1080px; margin: 0 auto; width: 100%; }
.zine__more__h { font-size: var(--t-body); font-weight: 600; color: var(--mist); opacity: .5; margin-bottom: 18px; }
.zine__more ul { list-style: none; }
.zine__more button { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: baseline; width: 100%; text-align: left;
  color: rgba(90, 92, 255, .6); appearance: none; -webkit-appearance: none; background: none; border: 0; cursor: pointer;
  font-family: inherit; font-size: var(--t-sm); font-weight: 600; letter-spacing: -.03em; line-height: 1.05;
  padding: clamp(12px, 1.6vh, 20px) 0; border-bottom: 1px solid rgba(90, 92, 255, .22); transition: color .3s var(--ease); }
.zine__more li:first-child button { border-top: 1px solid rgba(90, 92, 255, .22); }
.zine__more button:hover { color: var(--blue); }
.zine__more__cat { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; opacity: .6; white-space: nowrap; }

/* pie repetible (cierre + footer) clonado al final de los lectores: a sangre completa
   aunque el lector tenga padding lateral */
.pie { margin-top: clamp(40px, 8vh, 110px); }
.work__detail .pie, .zine__reader .pie {
  margin-left: calc(-1 * clamp(20px, 4vw, 56px)); margin-right: calc(-1 * clamp(20px, 4vw, 56px)); }

/* ===== DECIMOS unificado con el modo degradado (igual que Hacemos) =====
   listado + lector TRANSPARENTES → dejan ver el degradado animado de .bgfx (idéntico). */
html.bg-grad .zine,
html.bg-grad .zine__reader { background: transparent; color: var(--ice); }
html.bg-grad .zine__close, html.bg-grad .zine__back { color: var(--ice); }
html.bg-grad .zine__top { border-bottom-color: rgba(238, 238, 255, .28); }
html.bg-grad .zine__row, html.bg-grad .zine__row:first-child { border-color: rgba(238, 238, 255, .22); }
html.bg-grad .zine__chip { border-color: rgba(238, 238, 255, .32); color: var(--ice); }
html.bg-grad .zine__chip.is-on { background: rgba(238, 238, 255, .12); color: var(--ice); border-color: var(--ice); }
html.bg-grad .zine__byline a:hover { color: var(--mint); }
html.bg-grad .zine__aside { border-left-color: var(--mint); }
html.bg-grad .zine__more { border-top-color: rgba(238, 238, 255, .22); }
html.bg-grad .zine__more__h { color: rgba(238, 238, 255, .6); }
html.bg-grad .zine__more button { color: rgba(238, 238, 255, .55); border-bottom-color: rgba(238, 238, 255, .22); }
html.bg-grad .zine__more li:first-child button { border-top-color: rgba(238, 238, 255, .22); }
html.bg-grad .zine__more button:hover { color: var(--ice); }

@media (max-width: 860px) {
  .zine__row { grid-template-columns: auto 1fr; }
  .zine__cat { display: none; }
  .zine__more button { grid-template-columns: 1fr; gap: 5px; }
  .zine__more__cat { display: none; }
}

/* ============ CONTACTO · formulario conversacional (ref. itsoffbrand/contact) ============
   UNA pregunta cada vez, tipo grande, sin cajas: el panel ocupa toda la pantalla POR DEBAJO
   de la botonera (z<nav) y entra con la MISMA cortina que las fichas. Igual que los demás
   paneles, en modo degradado es transparente → deja ver el .bgfx (tratamiento idéntico). */
.ask { position: fixed; inset: 0; z-index: 90; display: none;
  background: var(--ice); color: var(--blue); overflow-y: auto; }
.ask.is-open { display: block; }
html.bg-grad .ask { background: transparent; color: var(--ice); }

.ask__panel { min-height: 100%; max-width: var(--maxw); margin: 0 auto; width: 100%;
  display: flex; flex-direction: column;
  padding: calc(var(--nav-h) + clamp(20px, 4vw, 56px)) clamp(20px, 4vw, 56px) clamp(40px, 8vh, 90px); }

.ask__bar { display: flex; align-items: center; justify-content: space-between; }
.ask__eyebrow { font-size: var(--t-body); font-weight: 600; letter-spacing: -.01em; }
/* ✕ angular ghost, igual que ←/✕ de las fichas */
.ask__close {
  appearance: none; -webkit-appearance: none; cursor: pointer; padding: 0; flex: 0 0 auto;
  width: 44px; height: 44px; border-radius: 0; display: grid; place-items: center;
  background: none; border: 1px solid currentColor; color: currentColor;
  font-size: 19px; font-weight: 500; line-height: 1;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease); }
.ask__close:hover { transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.ask__close:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--btnsh); }

/* barra de progreso (fina, sin caja) */
.ask__progress { height: 2px; background: rgba(24, 0, 216, .16); margin-top: clamp(20px, 3vh, 34px); }
html.bg-grad .ask__progress { background: rgba(238, 238, 255, .22); }
.ask__progress__fill { display: block; height: 100%; width: 0; background: var(--blue);
  transition: width .5s var(--ease); }
html.bg-grad .ask__progress__fill { background: var(--mint); }

/* pasos: solo el activo, centrado en el alto disponible, tipo grande */
.ask__form { flex: 1 1 auto; display: flex; align-items: center; }
.ask__step { display: none; flex-direction: column; gap: clamp(18px, 3vh, 38px);
  width: 100%; padding-block: clamp(20px, 5vh, 60px); }
.ask__step.is-active { display: flex; animation: askIn .6s var(--ease) both; }
@keyframes askIn { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: none; } }
.ask__n { font-size: 13px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; opacity: .5; }
.ask__q { font-size: var(--t-lg); font-weight: 600; line-height: 1.0; letter-spacing: -.03em; max-width: 20ch; }
.ask__hint { font-size: var(--t-body); opacity: .6; margin-top: -10px; }

/* campos: sin caja, solo línea inferior; grandes */
.ask__input { font-family: inherit; font-size: var(--t-md); font-weight: 500; color: inherit;
  background: none; border: 0; border-bottom: 1px solid currentColor; border-radius: 0;
  padding: 10px 2px; width: 100%; max-width: 30ch; letter-spacing: -.02em; }
.ask__input::placeholder { color: currentColor; opacity: .38; }
.ask__input:focus { outline: none; border-bottom-color: var(--mint); border-bottom-width: 2px; }
.ask__area { max-width: 46ch; resize: vertical; line-height: 1.25; font-size: var(--t-sm); }

/* chips angulares (single = exclusiva, multi = varias) */
.ask__chips { display: flex; flex-wrap: wrap; gap: clamp(8px, 1vw, 14px); max-width: 62ch; }
.ask__chip { appearance: none; -webkit-appearance: none; cursor: pointer; font-family: inherit;
  background: none; border: 1.5px solid currentColor; color: inherit; border-radius: 0;
  font-size: clamp(14px, 1.1vw, 17px); font-weight: 600; letter-spacing: -.01em; padding: 10px 20px;
  opacity: .68; transition: opacity .25s var(--ease), transform .16s var(--ease), box-shadow .16s var(--ease), background .25s var(--ease), color .25s var(--ease); }
.ask__chip:hover { opacity: 1; transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.ask__chip:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--btnsh); }
.ask__chip.is-sel { opacity: 1; border-width: 2px; background: rgba(24, 0, 216, .08);
  transform: translate(-2px, -2px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
html.bg-grad .ask__chip.is-sel { background: rgba(238, 238, 255, .12); color: var(--ice); border-color: var(--ice); }

/* pie de cada paso: ← atrás (texto) · Siguiente/Enviar (botón angular) */
.ask__foot { display: flex; align-items: center; gap: 22px; margin-top: clamp(10px, 2vh, 26px); }
.ask__btn { appearance: none; -webkit-appearance: none; cursor: pointer; font-family: inherit;
  border: 2px solid var(--blue); border-radius: 0; background: none; color: var(--blue);
  font-size: var(--t-body); font-weight: 600; padding: 12px 30px;
  transition: transform .16s var(--ease), box-shadow .16s var(--ease), background-color .3s var(--ease), color .3s var(--ease); }
.ask__btn:hover { transform: translate(-3px, -3px); box-shadow: var(--press) var(--press) 0 0 var(--btnsh); }
.ask__btn:active { transform: translate(0, 0); box-shadow: 2px 2px 0 0 var(--btnsh); }
html.bg-grad .ask__btn { background: none; color: var(--ice); border-color: var(--ice); }
.ask__link { appearance: none; background: none; border: 0; cursor: pointer; font-family: inherit;
  color: inherit; opacity: .55; font-size: var(--t-body); font-weight: 600; padding: 8px 0;
  transition: opacity .25s var(--ease); }
.ask__link:hover { opacity: 1; }

/* resumen final */
.ask__sum { display: flex; flex-direction: column; gap: 0; max-width: 64ch; width: 100%; }
.ask__sum div { display: grid; grid-template-columns: clamp(110px, 16vw, 200px) 1fr; gap: 24px;
  align-items: baseline; padding: 14px 0; border-bottom: 1px solid currentColor; }
.ask__sum dt { font-size: 13px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; opacity: .55; }
.ask__sum dd { font-size: var(--t-body); font-weight: 500; line-height: 1.3; }

/* pantalla "Gracias": al enviar se oculta el formulario y se muestra esto */
.ask.is-done .ask__form, .ask.is-done .ask__progress { display: none; }
.ask__done { flex-direction: column; gap: clamp(16px, 2.4vh, 30px); max-width: 34ch;
  padding-block: clamp(40px, 10vh, 120px); }
.ask__done:not([hidden]) { display: flex; }
.ask__donep { font-size: var(--t-body); line-height: 1.55; opacity: .82; max-width: 42ch; }
.ask__donep a { font-weight: 600; border-bottom: 1px solid currentColor; }

/* aviso de campo obligatorio: pequeño temblor */
@keyframes askShake { 0%, 100% { transform: translateX(0); } 20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); } 60% { transform: translateX(-4px); } 80% { transform: translateX(4px); } }
.ask--shake { animation: askShake .4s var(--ease); }

/* cortina de entrada (misma que las fichas) */
.ask__curtain { position: fixed; inset: 0; z-index: 10001; background: var(--blue);
  transform: translateY(100%); pointer-events: none; }
.ask__curtain.wipe { animation: curtainWipe 1.45s var(--ease) forwards; }

@media (max-width: 560px) {
  .ask__sum div { grid-template-columns: 1fr; gap: 4px; }
  .ask__foot { flex-wrap: wrap; gap: 14px; }
}
