/* paper-chapter.css — dos secciones de la home sobre PAPEL (chapter claro):
   "cómo trabajamos." (4 pasos numerados) + "works." (mosaico visual-first).
   Tokens de papel hardcodeados (no dependen del tema) para el contraste editorial. */

/* ── scroll-reveal: el contenido sube y aparece al entrar al viewport ───────
   Da la sensación interactiva/orgánica (no "forzada"). Lo activa un
   IntersectionObserver en la home; en reduced-motion todo nace visible. */
.sreveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease-out, ease-out), transform .8s var(--ease-out, ease-out); }
.sreveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .sreveal, .sreveal.in { opacity: 1; transform: none; transition: none; } }

.paper-chapter {
  position: relative; z-index: 1;
  background: var(--bg); color: var(--fg);
}
.paper-inner { max-width: 1200px; margin: 0 auto; padding: clamp(72px, 12vh, 150px) clamp(20px, 5vw, 56px); }

/* ── la persona detrás (conexión + confianza) ─────────────────────────────
   Un momento humano de UNA pantalla tras todo el viaje: foto profesional +
   mensaje directo de Rubén. Sin camino ni pasos — calma editorial sobre la
   galaxia (vidrio esmerilado), coherente con el resto del flujo. */
.person-section { position: relative; z-index: 1; min-height: 100vh; min-height: 100svh; display: flex; align-items: center; padding: clamp(70px, 9vh, 96px) clamp(20px, 5vw, 56px) clamp(40px, 6vh, 64px); }
.person-inner {
  max-width: 1080px; margin: 0 auto; width: 100%;
  display: grid; grid-template-columns: 0.74fr 1fr; gap: clamp(30px, 4vw, 64px);
  align-items: center;
}
@media (max-width: 860px) { .person-inner { grid-template-columns: 1fr; gap: 24px; max-width: 420px; } }

/* foto */
.person-photo-col { display: flex; flex-direction: column; gap: 11px; }
.person-frame {
  position: relative; padding: 9px;
  background: rgba(9, 9, 14, 0.6); -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px);
  border: 1px solid color-mix(in srgb, var(--paper) 12%, transparent);
  overflow: hidden;
}
/* backdrop de matriz de puntos detrás del morph (textura de la casa) */
.person-frame::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(circle, color-mix(in srgb, var(--paper) 22%, transparent) 0.6px, transparent 1.4px);
  background-size: 13px 13px; opacity: 0.16;
  -webkit-mask-image: radial-gradient(120% 100% at 50% 42%, #000 35%, transparent 78%);
  mask-image: radial-gradient(120% 100% at 50% 42%, #000 35%, transparent 78%);
}
/* scanline sutil que recorre el marco (terminal vibe) */
.person-frame::after {
  content: ""; position: absolute; left: 0; right: 0; height: 16%; z-index: 2; pointer-events: none;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--cat-sienna) 16%, transparent), transparent);
  animation: personScan 5.5s linear infinite;
}
@keyframes personScan { 0% { top: -16%; } 100% { top: 100%; } }
@media (prefers-reduced-motion: reduce) { .person-frame::after { animation: none; opacity: 0; } }
.person-frame > * { position: relative; z-index: 1; }
.person-slot { display: block; width: 100%; aspect-ratio: 4 / 5; object-fit: cover; object-position: 50% 36%; }
canvas.person-ascii { object-fit: unset; background: #0b0b10; }
.pf-corner { position: absolute; width: 16px; height: 16px; z-index: 2; pointer-events: none; }
.pf-corner.tl { top: -1px; left: -1px; border-top: 2px solid var(--cat-sienna); border-left: 2px solid var(--cat-sienna); }
.pf-corner.br { bottom: -1px; right: -1px; border-bottom: 2px solid var(--cat-sienna); border-right: 2px solid var(--cat-sienna); }
.person-badge {
  position: absolute; left: 18px; bottom: 18px; z-index: 3;
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 11px; background: rgba(8, 8, 12, 0.72); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid color-mix(in srgb, var(--paper) 14%, transparent);
  font-family: var(--type-family-workhorse); font-weight: 600; font-size: 10.5px;
  letter-spacing: 0.14em; text-transform: uppercase; color: color-mix(in srgb, var(--paper) 78%, transparent);
}
.pb-dot {
  width: 7px; height: 7px; border-radius: 50%; background: var(--cat-verde); flex: none;
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--cat-verde) 70%, transparent);
  animation: personOnline 2.4s var(--ease-out, ease-out) infinite;
}
@keyframes personOnline { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--cat-verde) 60%, transparent); } 70%, 100% { box-shadow: 0 0 0 7px transparent; } }
@media (prefers-reduced-motion: reduce) { .pb-dot { animation: none; } }
.person-cap { display: flex; flex-direction: column; gap: 2px; margin: 0; }
.pc-name { font-family: var(--type-family-workhorse); font-weight: 700; font-size: clamp(15px, 1.5vw, 18px); color: var(--fg); letter-spacing: -0.01em; }
.pc-role { font-family: var(--type-family-workhorse); font-weight: 500; font-size: 12px; letter-spacing: 0.06em; text-transform: lowercase; color: var(--mute); }

/* contenido */
.person-content { display: flex; flex-direction: column; align-items: flex-start; }
.person-title {
  font-family: var(--type-family-workhorse); font-weight: 900;
  font-size: clamp(26px, 3.4vw, 44px); line-height: 1.0; letter-spacing: -0.035em;
  color: var(--fg); margin: clamp(10px, 1.6vh, 16px) 0 0; max-width: 17ch; text-wrap: balance;
}
.person-body {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(14px, 1.4vw, 17px); line-height: 1.45; color: var(--mute);
  margin: clamp(10px, 1.6vh, 16px) 0 0; max-width: 44ch; text-wrap: pretty;
}
.person-trust { list-style: none; margin: clamp(14px, 2vh, 20px) 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 7px 18px; }
.person-trust li {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--type-family-workhorse); font-weight: 600; font-size: clamp(12px, 1.2vw, 14px);
  letter-spacing: 0.01em; color: color-mix(in srgb, var(--fg) 82%, transparent);
}
.pt-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--cat-sienna); flex: none; box-shadow: 0 0 9px 1px color-mix(in srgb, var(--cat-sienna) 55%, transparent); }
.person-cta { margin-top: clamp(16px, 2.4vh, 26px); }

/* ── consola de proceso sincronizada con el dot-morph ── */
.proc-sync { margin: clamp(14px, 2vh, 20px) 0 0; }
.ps-steps { list-style: none; margin: 0 0 9px; padding: 0; display: flex; flex-wrap: wrap; align-items: center; gap: 5px 13px; }
.ps-step {
  display: inline-flex; align-items: center; gap: 8px; opacity: 0.4;
  transition: opacity .35s var(--ease-out, ease-out);
  font-family: var(--type-family-workhorse); font-weight: 700;
  font-size: clamp(12px, 1.2vw, 14px); letter-spacing: 0.01em; text-transform: lowercase;
  color: color-mix(in srgb, var(--fg) 88%, transparent);
}
.ps-step .ps-bullet {
  width: 8px; height: 8px; border-radius: 50%; background: color-mix(in srgb, var(--fg) 40%, transparent);
  transform: scale(0.75); transition: background .35s var(--ease-out), transform .35s var(--ease-out), box-shadow .35s var(--ease-out);
}
.ps-step.on { opacity: 1; }
.ps-step.on .ps-bullet { background: var(--c); transform: scale(1.15); box-shadow: 0 0 12px 1px color-mix(in srgb, var(--c) 65%, transparent); }
.ps-step.on .ps-label { color: var(--c); }
.ps-sep { width: 14px; height: 1px; background: color-mix(in srgb, var(--fg) 22%, transparent); margin-left: 5px; }
.ps-desc {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(12.5px, 1.3vw, 15px); line-height: 1.4;
  color: color-mix(in srgb, var(--fg) 70%, transparent);
  margin: 0; min-height: 2.7em; max-width: 44ch;
  border-left: 2px solid color-mix(in srgb, var(--c, var(--mute)) 70%, transparent); padding-left: 12px;
  transition: border-color .35s var(--ease-out);
}
.person-flowhint {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(13px, 1.3vw, 15px); line-height: 1.45; color: var(--mute);
  margin: clamp(18px, 2.6vh, 26px) 0 0; max-width: 42ch;
}
canvas.person-morph { object-fit: unset; background: #0b0b10; display: block; width: 100%; height: 100%; aspect-ratio: 4 / 5; }

/* ── cómo trabajamos, como un pequeño paso dentro de la sección ── */
.person-flow { margin: clamp(20px, 3vh, 30px) 0 0; }
.pf-lead {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(13px, 1.3vw, 15px); line-height: 1.45; color: var(--mute);
  margin: 0 0 12px; max-width: 44ch;
}
.pf-steps {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 18px;
}
.pf-step {
  display: inline-flex; align-items: center; gap: 8px; position: relative;
  font-family: var(--type-family-workhorse); font-weight: 700;
  font-size: clamp(13px, 1.3vw, 15px); letter-spacing: 0.01em; text-transform: lowercase;
  color: color-mix(in srgb, var(--fg) 88%, transparent);
}
.pf-step .pf-bullet {
  width: 7px; height: 7px; border-radius: 50%; background: var(--c, var(--cat-sienna)); flex: none;
  box-shadow: 0 0 9px 1px color-mix(in srgb, var(--c, var(--cat-sienna)) 60%, transparent);
}
.pf-step:not(:last-child)::after {
  content: ""; width: 12px; height: 1px; margin-left: 4px;
  background: color-mix(in srgb, var(--fg) 26%, transparent);
}

.pc-eyebrow {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mute); display: inline-flex; align-items: center; gap: .8em;
}
.pc-eyebrow .pip { width: 5px; height: 5px; border-radius: 50%; background: var(--cat-sienna); }
.pc-title {
  font-family: var(--type-family-workhorse); font-weight: 900;
  font-size: clamp(34px, 6vw, 76px); line-height: .98; letter-spacing: -0.035em;
  color: var(--fg); margin: clamp(14px, 2.4vh, 26px) 0 0;
}
.pc-title .dot { color: var(--cat-sienna); }

/* ── la estación: llegamos del recorrido por el ecosistema y acoplamos ──────
   Reencuadra "cómo trabajamos" como una bahía de trabajo: lead de llegada +
   barra de acople (HUD) sobre los módulos del proceso. */
.proc-arrival {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(15px, 1.5vw, 19px); line-height: 1.5; color: var(--mute);
  margin: clamp(14px, 2vh, 22px) 0 0; max-width: 46ch; text-wrap: pretty;
}
.proc-dock {
  margin-top: clamp(26px, 4vh, 44px);
  display: flex; align-items: center; gap: clamp(10px, 1.4vw, 18px); flex-wrap: wrap;
  padding: 13px clamp(16px, 2vw, 22px);
  background: color-mix(in srgb, var(--cat-yellow) 9%, rgba(9, 9, 14, 0.6));
  -webkit-backdrop-filter: blur(12px); backdrop-filter: blur(12px);
  border: 1px solid color-mix(in srgb, var(--paper) 12%, transparent);
  font-family: var(--type-family-workhorse); font-weight: 600;
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
}
.pd-id { color: var(--paper); }
.pd-sep { width: 5px; height: 5px; border-radius: 50%; background: color-mix(in srgb, var(--paper) 40%, transparent); flex: none; }
.pd-bay { color: color-mix(in srgb, var(--paper) 58%, transparent); }
.pd-status { margin-left: auto; display: inline-flex; align-items: center; gap: 8px; color: var(--cat-verde); }
.pd-dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--cat-verde); flex: none;
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--cat-verde) 70%, transparent);
  animation: dockPulse 2.4s var(--ease-out, ease-out) infinite;
}
@keyframes dockPulse {
  0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--cat-verde) 60%, transparent); }
  70%, 100% { box-shadow: 0 0 0 7px transparent; }
}
@media (prefers-reduced-motion: reduce) { .pd-dot { animation: none; } }
/* etiqueta de módulo en la pestaña de cada paso (vocabulario de estación) */
.proc-bay {
  margin-left: auto; font-family: var(--type-family-workhorse); font-weight: 600;
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase;
  color: color-mix(in srgb, var(--on) 42%, transparent); font-variant-numeric: tabular-nums;
}
.proc-bay + .proc-arrow { margin-left: clamp(10px, 1.4vw, 18px); }
@media (max-width: 620px) { .proc-bay { display: none; } }

/* ── cómo trabajamos · los 4 pasos como TARJETAS de servicio (sobre papel) ── */
/* ── cómo trabajamos · 4 pasos como STACK que se apila al SCROLL ────────── */
/* Vidrio oscuro esmerilado sobre la galaxia (mismo lenguaje que works/quote):
   el color de categoría es un ACENTO (lavado tenue + pestaña + bullet), no un
   relleno sólido — así las 3 secciones comparten la atmósfera del espacio. */
.proc-stack { position: relative; margin-top: clamp(30px, 5vh, 60px); --proc-nav: 80px; --proc-tab: 56px; }
.proc-card {
  position: sticky; top: calc(var(--proc-nav) + var(--i) * var(--proc-tab));
  z-index: var(--z, 1); isolation: isolate;
  background: color-mix(in srgb, var(--cat, var(--cat-azure)) 12%, rgba(9, 9, 14, 0.74));
  -webkit-backdrop-filter: blur(16px) saturate(1.1); backdrop-filter: blur(16px) saturate(1.1);
  color: var(--on);
  --on: var(--paper); --on-soft: color-mix(in srgb, var(--paper) 64%, transparent);
}
.proc-card.ink-on-fill { --on: var(--paper); --on-soft: color-mix(in srgb, var(--paper) 64%, transparent); }
/* borde de PUNTOS en los 4 lados (lenguaje del punto) */
.proc-card::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 3;
  --edge: color-mix(in srgb, var(--on) 30%, transparent);
  background:
    radial-gradient(circle, var(--edge) 1px, transparent 1.7px) left top / 9px 1px repeat-x,
    radial-gradient(circle, var(--edge) 1px, transparent 1.7px) left bottom / 9px 1px repeat-x,
    radial-gradient(circle, var(--edge) 1px, transparent 1.7px) left top / 1px 9px repeat-y,
    radial-gradient(circle, var(--edge) 1px, transparent 1.7px) right top / 1px 9px repeat-y;
}
.proc-tab {
  position: relative; z-index: 2; height: var(--proc-tab);
  display: flex; align-items: center; gap: 13px; padding: 0 clamp(18px, 2.4vw, 30px);
  background: color-mix(in srgb, var(--cat) 32%, rgba(8, 8, 12, 0.5));
  border-bottom: 1px solid color-mix(in srgb, var(--on) 16%, transparent);
}
.proc-num { font-family: var(--type-family-workhorse); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; color: var(--on-soft); font-variant-numeric: tabular-nums; }
.proc-bullet { width: 10px; height: 10px; border-radius: 50%; background: var(--on); flex: none; transition: transform .28s var(--ease-stand, ease-out); }
.proc-card:hover .proc-bullet { transform: scale(1.2); }
.proc-label { font-family: var(--type-family-workhorse); font-weight: 600; font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--on); }
.proc-arrow { margin-left: auto; color: var(--on-soft); display: inline-flex; }
.proc-body {
  position: relative; z-index: 1; overflow: hidden;
  min-height: clamp(380px, 62vh, 600px);
  display: grid; grid-template-columns: 1.15fr .85fr; gap: clamp(24px, 4vw, 56px);
  align-items: center; padding: clamp(34px, 6vh, 64px) clamp(20px, 2.8vw, 40px);
}
.proc-content { position: relative; z-index: 1; display: flex; flex-direction: column; gap: clamp(14px, 2vh, 22px); }
.proc-name { font-family: var(--type-family-workhorse); font-weight: 900; font-size: clamp(40px, 6vw, 82px); line-height: .94; letter-spacing: -0.04em; color: var(--on); margin: 0; }
.proc-desc { font-family: var(--type-family-workhorse); font-weight: 500; font-size: clamp(17px, 1.7vw, 22px); line-height: 1.45; color: var(--on-soft); margin: 0; max-width: 28ch; text-wrap: balance; }
/* numeral índice gigante (estructural, no relleno) — usa el espacio del cuerpo */
.proc-figure {
  justify-self: end; align-self: center;
  font-family: var(--type-family-workhorse); font-weight: 900;
  font-size: clamp(120px, 22vw, 300px); line-height: .8; letter-spacing: -0.06em;
  color: transparent; -webkit-text-stroke: 2px color-mix(in srgb, var(--on) 32%, transparent);
  font-variant-numeric: tabular-nums; user-select: none;
}
@media (max-width: 760px) {
  .proc-stack { --proc-nav: 72px; --proc-tab: 52px; }
  .proc-body { grid-template-columns: 1fr; min-height: clamp(320px, 58vh, 520px); align-content: center; gap: clamp(8px, 3vh, 20px); }
  .proc-figure { display: none; }
}

/* ── works · reel de clientes reales (monocromo en reposo → color al hover) ── */
.works-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.works-count {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mute);
  display: inline-flex; align-items: center; min-height: 32px;
}
.works-grid {
  margin-top: clamp(34px, 6vh, 72px);
  display: grid; grid-template-columns: repeat(auto-fill, minmax(min(210px, 100%), 1fr));
  gap: clamp(12px, 1.4vw, 20px);
}
.work { display: block; text-decoration: none; color: inherit; }
.work-link { display: block; text-decoration: none; color: inherit; cursor: pointer; }
.work-frame {
  position: relative; overflow: hidden;
  background: color-mix(in srgb, var(--wcat, var(--paper)) 4%, rgba(9, 9, 14, 0.66));
  -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
  border: 1px solid color-mix(in srgb, var(--wcat, var(--paper)) 20%, transparent);
  aspect-ratio: 3 / 4;
  transition: border-color .45s var(--ease-out);
}
.work:hover .work-frame {
  border-color: color-mix(in srgb, var(--wcat, var(--paper)) 60%, transparent);
}
.work-media, .work-frame image-slot, .work-frame video {
  position: absolute; inset: 0; width: 100%; height: 100%; display: block;
  object-fit: cover;
  transition: transform .6s var(--ease-out);
}
.work:hover .work-media, .work:hover .work-frame image-slot, .work:hover .work-frame video {
  transform: scale(1.035);
}
/* veil siempre presente (legibilidad editorial): gradiente arriba+abajo */
.work-veil {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: clamp(14px, 1.5vw, 20px);
  background:
    linear-gradient(to bottom, color-mix(in srgb, var(--ink) 46%, transparent), transparent 26%),
    linear-gradient(to top, color-mix(in srgb, var(--ink) 78%, transparent), transparent 54%);
}
.work-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 10px; }
.work-cat {
  font-family: var(--type-family-workhorse); font-weight: 600;
  font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--paper); display: inline-flex; align-items: center; gap: .6em;
}
.work-cat .pip { width: 6px; height: 6px; border-radius: 50%; background: var(--wcat, var(--cat-sienna)); flex: none; }
.work-year {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: color-mix(in srgb, var(--paper) 62%, transparent); white-space: nowrap;
}
.work-bot { display: flex; }
.work-title {
  font-family: var(--type-family-workhorse); font-weight: 900;
  font-size: clamp(21px, 2.1vw, 30px); line-height: 1.02; letter-spacing: -0.03em;
  color: var(--paper); margin: 0; text-wrap: balance;
}

/* ── lead capture (papel, una columna, foco total) ──────────────────────── */
.lead { position: relative; z-index: 1; background: var(--bg); color: var(--fg); }
.lead-inner { max-width: 620px; margin: 0 auto; padding: clamp(64px, 11vh, 140px) clamp(20px, 5vw, 56px) clamp(72px, 13vh, 160px); }
.lead .pc-title .dot { color: var(--form-accent); }
.lead .pc-eyebrow .pip { background: var(--form-accent); }
.lead-form { margin-top: clamp(32px, 6vh, 64px); display: flex; flex-direction: column; gap: clamp(20px, 3vh, 28px); }
.lead-cta { margin-top: clamp(8px, 1.5vh, 16px); }
/* el CTA toma el color de la categoría elegida */
.lead .rmd-btn--dotted:not(:hover) { background-color: var(--form-accent) !important; color: var(--paper) !important; }
.lead.ink-cta .rmd-btn--dotted:not(:hover) { color: var(--ink) !important; }
.lead-sent { margin-top: clamp(32px, 6vh, 56px); border-top: 0; }
.lead-sent-h { font-family: var(--type-family-workhorse); font-weight: 900; font-size: clamp(24px, 3.4vw, 40px); letter-spacing: -0.03em; color: var(--fg); margin: 0; }
.lead-sent-d { font-family: var(--type-family-workhorse); font-weight: 500; font-size: clamp(16px, 1.7vw, 20px); line-height: 1.5; color: var(--mute); margin: .6em 0 0; max-width: 42ch; }

/* ── step 2E · cotización (único lugar con precios) ──────────────────────── */
.lead.lead--quote .lead-inner, .lead:has(.quote) .lead-inner { max-width: 1080px; }
.quote-tag { display: inline-flex; }
.quote-h { font-family: var(--type-family-workhorse); font-weight: 900; font-size: clamp(28px, 4.6vw, 56px); line-height: 1.02; letter-spacing: -0.035em; color: var(--fg); margin: clamp(16px, 2.4vh, 26px) 0 0; max-width: 18ch; }
.quote-h .dot { color: var(--cat-sienna); }
.quote-sub { font-family: var(--type-family-workhorse); font-weight: 500; font-size: clamp(15px, 1.6vw, 19px); color: var(--mute); margin: .7em 0 0; }
.quote-group { margin-top: clamp(34px, 6vh, 64px); }
.quote-cat { font-family: var(--type-family-workhorse); font-weight: 500; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); display: inline-flex; align-items: center; gap: .7em; margin: 0 0 clamp(14px, 2vh, 22px); }
.quote-cat .pip { width: 6px; height: 6px; border-radius: 50%; background: var(--qc); }
.quote-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(248px, 1fr)); gap: clamp(14px, 1.6vw, 22px); }
.quote-card { background: rgba(11, 11, 17, 0.68); -webkit-backdrop-filter: blur(14px); backdrop-filter: blur(14px); border: 1px solid color-mix(in srgb, var(--paper) 12%, transparent); border-radius: 0; padding: clamp(20px, 2.4vw, 30px); display: flex; flex-direction: column; }
.qc-top { display: flex; align-items: center; gap: .6em; }
.qc-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--qc); flex: none; }
.qc-name { font-family: var(--type-family-workhorse); font-weight: 700; font-size: clamp(16px, 1.5vw, 19px); letter-spacing: 0.02em; color: var(--fg); }
.quote-card .dot-divider { --dot-ink: color-mix(in srgb, var(--fg) 22%, transparent); margin: clamp(14px, 2vh, 18px) 0; }
.qc-price { display: flex; align-items: baseline; gap: .4em; }
.qc-amt { font-family: var(--type-family-workhorse); font-weight: 900; font-size: clamp(30px, 3.6vw, 46px); line-height: 1; letter-spacing: -0.035em; color: var(--fg); }
.qc-unit { font-family: var(--type-family-workhorse); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mute); }
.qc-time { font-family: var(--type-family-workhorse); font-weight: 600; font-size: 13px; letter-spacing: 0.02em; color: var(--qc); margin: .7em 0 0; }
.qc-desc { font-family: var(--type-family-workhorse); font-weight: 500; font-size: 14px; line-height: 1.45; color: var(--mute); margin: .5em 0 0; }
.quote-cta { margin-top: clamp(36px, 6vh, 72px); display: flex; align-items: center; gap: clamp(20px, 3vw, 34px); flex-wrap: wrap; }
.quote-quiet { font-family: var(--type-family-workhorse); font-weight: 500; font-size: 13px; letter-spacing: 0.04em; color: var(--mute); text-decoration: underline; text-underline-offset: 5px; text-decoration-color: color-mix(in srgb, var(--mute) 45%, transparent); }
.quote-quiet:hover { color: var(--fg); }

/* ── footer (SIEMPRE oscuro, ink) — vidrio sobre el final de la galaxia ──── */
.site-footer { position: relative; z-index: 1; background: color-mix(in srgb, var(--ink-surface) 78%, transparent); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px); color: var(--paper); overflow: hidden; border-top: 1px solid color-mix(in srgb, var(--paper) 9%, transparent); }
.footer-inner { container-type: inline-size; max-width: 1280px; margin: 0 auto; padding: clamp(48px, 8vh, 96px) clamp(20px, 5vw, 56px) max(clamp(28px, 4vh, 44px), env(safe-area-inset-bottom)); will-change: transform, clip-path, opacity; }
.footer-links { display: flex; flex-wrap: wrap; gap: clamp(18px, 2.6vw, 40px); }
.footer-link { font-family: var(--type-family-workhorse); font-weight: 500; font-size: 13px; letter-spacing: 0.04em; color: var(--mute-2, #9a958c); text-decoration: none; transition: color .2s var(--ease-out); }
.footer-link:hover { color: var(--paper); }
.footer-clock { margin-top: clamp(40px, 7vh, 88px); color: var(--paper); font-size: clamp(34px, 6.5vw, 92px); }
.footer-clock :is(.rmd-clock, time, span) { letter-spacing: -0.02em; }
.footer-wm {
  font-family: var(--wordmark-family); font-weight: 400;
  font-size: min(210px, 12.2cqi); line-height: .9; letter-spacing: -0.03em;
  color: var(--paper); margin: clamp(20px, 4vh, 44px) 0 0;
  display: flex; align-items: baseline; white-space: nowrap;
}
.footer-dot { width: .1em; height: .1em; border-radius: 50%; background: var(--cat-sienna); display: inline-block; align-self: flex-end; margin: 0 .005em .12em; }
.footer-bottom { margin-top: clamp(28px, 4vh, 48px); display: flex; align-items: center; justify-content: space-between; gap: 18px; flex-wrap: wrap; }
.footer-copy, .footer-tag { font-family: var(--type-family-workhorse); font-weight: 500; font-size: 12px; letter-spacing: 0.06em; color: var(--mute-2, #9a958c); display: inline-flex; align-items: center; }
.footer-cdot { width: 5px; height: 5px; border-radius: 50%; background: var(--cat-sienna); display: inline-block; margin-left: .5em; }

@media (max-width: 760px) {
  .footer-clock { font-size: clamp(30px, 11vw, 64px); }
  .quote-quiet { min-height: 44px; display: inline-flex; align-items: center; }
  .works-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .work .work-media, .work .work-frame video { filter: none; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   CÓMO TRABAJAMOS · momento scroll-scrubbed guiado (te llevo de la mano)
   El proceso es el protagonista: sección alta + sticky que se fija; al bajar,
   el morph ASCII te lleva del rostro → elige → cotiza → ejecuta → entrega,
   con una sola voz que cambia por etapa. Mismo lenguaje que manifiesto/galaxia.
   ═════════════════════════════════════════════════════════════════════════ */
.proc2 { position: relative; z-index: 1; }
/* textura dot-matrix tenue por detrás de toda la sección (atmósfera de la casa) */
.proc2::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image: radial-gradient(circle, color-mix(in srgb, var(--paper) 18%, transparent) 0.6px, transparent 1.5px);
  background-size: 16px 16px; opacity: 0.05;
}
.proc2-inner {
  position: relative; z-index: 1; max-width: 760px; margin: 0 auto;
  --pl: clamp(42px, 9vw, 70px);
  padding: clamp(70px, 11vh, 130px) clamp(20px, 5vw, 56px) clamp(40px, 8vh, 90px);
}
/* columna izquierda — el morph se queda fijo mientras el caminito pasa */
.proc2-media {
  position: sticky; top: 0; height: 100vh; height: 100svh;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: clamp(16px, 3vh, 30px); text-align: center;
}
.proc-kicker {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(11px, 1.1vw, 13px); letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--mute); display: inline-flex; align-items: center; gap: .8em;
  margin: 0 0 clamp(6px, 1.4vh, 16px); padding-left: var(--pl);
}
.proc-kicker .pip { width: 5px; height: 5px; border-radius: 50%; background: var(--cat-sienna); }
/* etiqueta dinámica bajo el morph: "paso 0X / 04 · elige" en color de categoría */
.proc-now { display: none; }

/* el morph — protagonista, grande y centrado */
.proc-stage { position: relative; width: 100%; max-width: min(46vh, 430px); aspect-ratio: 1 / 1; margin: 0 auto; }
.proc-stage canvas.person-morph {
  position: absolute; inset: 0; width: 100%; height: 100%;
  aspect-ratio: auto; background: transparent; object-fit: unset;
  -webkit-mask-image: radial-gradient(closest-side, #000 90%, transparent 100%);
  mask-image: radial-gradient(closest-side, #000 90%, transparent 100%);
}
/* sat\u00e9lite "en l\u00ednea" orbitando el icono \u2014 gui\u00f1o al tema galaxia.
   El anillo gira; el sat\u00e9lite va montado en \u00e9l y su etiqueta contra-rota
   para quedarse siempre legible. */
.proc-orbit {
  position: absolute; left: 50%; top: 50%; width: 112%; aspect-ratio: 1 / 1;
  transform: translate(-50%, -50%); border-radius: 50%; z-index: 4; pointer-events: none;
  border: 1px dashed color-mix(in srgb, var(--paper) 9%, transparent);
  animation: procOrbit 19s linear infinite;
}
.proc-sat {
  position: absolute; top: 0; left: 50%; transform: translate(-50%, -50%);
  display: inline-flex; align-items: center; gap: 8px;
  animation: procOrbitCounter 19s linear infinite;
}
.proc-sat-rock {
  width: 11px; height: 11px; border-radius: 50%; flex: none;
  background: radial-gradient(circle at 34% 30%, var(--cat-verde), color-mix(in srgb, var(--cat-verde) 50%, #05060a));
  box-shadow: 0 0 13px 2px color-mix(in srgb, var(--cat-verde) 55%, transparent);
}
.proc-sat-tag {
  font-family: var(--type-family-workhorse); font-weight: 600; font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase; white-space: nowrap;
  color: color-mix(in srgb, var(--paper) 74%, transparent);
  background: rgba(8, 8, 12, 0.5); padding: 3px 8px;
  -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px);
  border: 1px solid color-mix(in srgb, var(--paper) 10%, transparent);
}
@keyframes procOrbit { to { transform: translate(-50%, -50%) rotate(360deg); } }
@keyframes procOrbitCounter { to { transform: translate(-50%, -50%) rotate(-360deg); } }
@media (prefers-reduced-motion: reduce) {
  .proc-orbit, .proc-sat { animation: none; }
}

/* ═══ el caminito vector: timeline vertical con bead que viaja ═══ */
.proc2-timeline {
  position: relative; --gutter: clamp(9px, 1.4vw, 15px);
  padding: clamp(28px, 5vh, 56px) 0 clamp(40px, 10vh, 110px) var(--pl);
}
/* línea vertical punteada que conecta los pasos (el caminito) */
.proc-svg { position: absolute; left: 0; top: 0; pointer-events: none; z-index: 0; overflow: visible; }
.proc-svg-track { stroke: color-mix(in srgb, var(--fg) 26%, transparent); stroke-width: 2; stroke-linecap: round; fill: none; }
.proc-svg-draw { stroke-width: 4.5; stroke-linecap: round; stroke-linejoin: round; fill: none; }
.proc-bead {
  position: absolute; top: 0; left: 0; width: 15px; height: 15px; border-radius: 50%;
  transform: translate(-50%, -50%); background: var(--cat-sienna); z-index: 2; border: 3px solid #07070b;
}
@media (prefers-reduced-motion: no-preference) { .proc-bead { transition: background .4s var(--ease-out, ease-out); } }

.proc-row { position: relative; padding: clamp(26px, 5vh, 56px) 0; }
.proc-row::before {                 /* divisor dot-matrix arriba de cada paso (no en el intro) */
  content: ""; position: absolute; top: 0; left: 0; right: 0; height: 8px;
  background: radial-gradient(circle, color-mix(in srgb, var(--fg) 32%, transparent) 1px, transparent 1.7px) 0 50% / 9px 9px repeat-x;
  -webkit-mask-image: linear-gradient(90deg, #000 76%, transparent); mask-image: linear-gradient(90deg, #000 76%, transparent);
}
.proc-row--intro::before { display: none; }

/* nodo sobre la línea, alineado con el número */
.pr-node {
  position: absolute; left: calc(var(--gutter) - var(--pl)); top: clamp(40px, 6.5vh, 70px);
  width: 11px; height: 11px; border-radius: 50%; transform: translate(-50%, -50%); z-index: 1;
  background: color-mix(in srgb, var(--fg) 26%, #07070b); border: 1px solid color-mix(in srgb, var(--fg) 20%, transparent);
  transition: background .4s var(--ease-out, ease-out), box-shadow .4s var(--ease-out, ease-out), transform .4s var(--ease-out, ease-out);
}
.proc-row.reached .pr-node { background: var(--c); border-color: transparent; box-shadow: 0 0 14px 2px color-mix(in srgb, var(--c) 55%, transparent); }
.proc-row.on .pr-node { transform: translate(-50%, -50%) scale(1.3); }
/* colisión: doble anillo expansivo + flash radial + pop al llegar el bead */
.pr-node::after {
  content: ""; position: absolute; inset: -2px; border-radius: 50%;
  border: 2px solid var(--c); opacity: 0; transform: scale(1); pointer-events: none;
}
.pr-node::before {
  content: ""; position: absolute; inset: -8px; border-radius: 50%; opacity: 0; pointer-events: none;
  background: radial-gradient(circle, color-mix(in srgb, var(--c) 70%, transparent) 0%, transparent 68%);
}
.pr-node.hit::after { animation: nodeRipple .72s var(--ease-out, cubic-bezier(.4,0,.2,1)); }
.pr-node.hit::before { animation: nodeFlash .56s var(--ease-out, cubic-bezier(.4,0,.2,1)); }
.pr-node.hit { animation: nodePop .5s var(--ease-out, cubic-bezier(.34,1.56,.64,1)); }
@keyframes nodeRipple { 0% { opacity: .9; transform: scale(1); } 100% { opacity: 0; transform: scale(6); } }
@keyframes nodeFlash { 0% { opacity: .95; transform: scale(.5); } 100% { opacity: 0; transform: scale(3.4); } }
@keyframes nodePop {
  0% { transform: translate(-50%, -50%) scale(1); box-shadow: 0 0 0 0 color-mix(in srgb, var(--c) 85%, transparent); }
  30% { transform: translate(-50%, -50%) scale(2.1); box-shadow: 0 0 34px 9px color-mix(in srgb, var(--c) 80%, transparent); }
  100% { transform: translate(-50%, -50%) scale(1.3); box-shadow: 0 0 14px 2px color-mix(in srgb, var(--c) 55%, transparent); }
}
/* el impacto SACUDE el paso para invitar a leerlo: heading + número reaccionan */
.proc-row.impact .pr-title { animation: titleJolt .58s var(--ease-out, cubic-bezier(.34,1.56,.64,1)); }
.proc-row.impact .pr-num { animation: numKick .56s var(--ease-out, cubic-bezier(.34,1.56,.64,1)); }
.proc-row.impact .pr-idx { animation: idxFade .6s var(--ease-out, ease-out); }
@keyframes titleJolt {
  0% { transform: translateX(0) scale(1); text-shadow: 0 0 0 transparent; }
  22% { transform: translateX(10px) scale(1.045); text-shadow: 0 0 26px color-mix(in srgb, var(--c) 65%, transparent); }
  55% { transform: translateX(-3px) scale(1.01); }
  100% { transform: translateX(0) scale(1); text-shadow: 0 0 0 transparent; }
}
.proc-row--alt.impact .pr-title { animation: titleJoltAlt .58s var(--ease-out, cubic-bezier(.34,1.56,.64,1)); }
@keyframes titleJoltAlt {
  0% { transform: translateX(0) scale(1); text-shadow: 0 0 0 transparent; }
  22% { transform: translateX(-10px) scale(1.045); text-shadow: 0 0 26px color-mix(in srgb, var(--c) 65%, transparent); }
  55% { transform: translateX(3px) scale(1.01); }
  100% { transform: translateX(0) scale(1); text-shadow: 0 0 0 transparent; }
}
@keyframes numKick {
  0% { transform: translateY(0) scale(1); }
  28% { transform: translateY(-10px) scale(1.06); }
  100% { transform: translateY(0) scale(1); }
}
@keyframes idxFade { 0% { opacity: .3; } 40% { opacity: 1; } 100% { opacity: 1; } }
@media (prefers-reduced-motion: reduce) {
  .pr-node.hit, .pr-node.hit::after, .pr-node.hit::before,
  .proc-row.impact .pr-title, .proc-row.impact .pr-num, .proc-row.impact .pr-idx { animation: none; }
}

.pr-num {
  display: block; font-family: var(--type-family-workhorse); font-weight: 900; line-height: .9;
  font-size: clamp(40px, 6vw, 72px); letter-spacing: -0.04em; font-variant-numeric: tabular-nums;
  color: color-mix(in srgb, var(--fg) 24%, transparent); transition: color .4s var(--ease-out, ease-out);
}
.proc-row.reached .pr-num { color: var(--c); }
.pr-idx {
  font-family: var(--type-family-workhorse); font-weight: 600; margin: clamp(6px, 1.2vh, 12px) 0 0;
  font-size: clamp(11px, 1.1vw, 13.5px); letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--mute); font-variant-numeric: tabular-nums;
}
.pr-idx b { color: var(--c); font-weight: 700; }
.pr-idx .pr-sep { color: color-mix(in srgb, var(--fg) 28%, transparent); }
.pr-idx .pr-label { color: var(--c); }
.pr-title {
  font-family: var(--type-family-workhorse); font-weight: 900;
  font-size: clamp(27px, 3.5vw, 44px); line-height: 1.0; letter-spacing: -0.035em;
  color: var(--fg); margin: clamp(8px, 1.4vh, 14px) 0 0; text-wrap: balance;
}
.pr-dot { display: inline-block; width: .15em; height: .15em; border-radius: 50%; background: var(--c); margin-left: .05em; vertical-align: baseline; }
.pr-desc {
  font-family: var(--type-family-workhorse); font-weight: 500;
  font-size: clamp(15px, 1.5vw, 18px); line-height: 1.5; color: var(--mute);
  margin: clamp(10px, 1.6vh, 16px) 0 0; max-width: 46ch; text-wrap: pretty;
}
.pr-signoff {
  font-family: var(--type-family-workhorse); font-weight: 600; margin: clamp(12px, 2vh, 20px) 0 0;
  font-size: clamp(11px, 1.1vw, 13px); letter-spacing: 0.08em; color: color-mix(in srgb, var(--cat-sienna) 86%, var(--fg));
}
.proc2-cta { margin-top: clamp(30px, 5vh, 56px); display: flex; justify-content: center; }

/* el morph respira un poco más grande en este layout de columna */
.proc-stage { max-width: min(40vh, 380px); }

/* ── responsive: una columna; el morph se vuelve banda fija arriba ── */
@media (max-width: 600px) {
  .proc2-inner { --pl: clamp(34px, 10vw, 52px); padding-top: clamp(54px, 9vh, 90px); }
  .proc2-timeline { padding-top: clamp(20px, 4vh, 40px); padding-bottom: clamp(40px, 9vh, 90px); }
  .pr-num { font-size: clamp(34px, 12vw, 54px); }
  .pr-title { font-size: clamp(24px, 6.4vw, 34px); }
}

/* móvil/tablet: el frame completo del proceso, REALMENTE centrado — la
   columna (caminito + texto) se ajusta a su contenido y se centra, dejando
   márgenes iguales a cada lado (no la ilusión de un bloque casi full-width) */
@media (max-width: 860px) {
  .proc2-inner { max-width: 100%; }
  .proc2-timeline { width: -moz-fit-content; width: fit-content; max-width: 100%; margin-left: auto; margin-right: auto; }
  .proc-kicker { display: flex; padding-left: 0; justify-content: center; }
  .pr-title { max-width: 16ch; }
  .pr-desc { max-width: 26ch; }
}

/* ── desktop: ancho completo, línea al centro, pasos alternando lados ── */
@media (min-width: 861px) {
  .proc2-inner { max-width: min(1320px, 94vw); }
  .proc-kicker { display: flex; justify-content: center; padding-left: 0; margin-bottom: clamp(12px, 2.4vh, 26px); }
  .proc2-timeline { padding-left: 0; }
  .proc-row { display: grid; grid-template-columns: 1fr 1fr; column-gap: clamp(210px, 24vw, 340px); align-items: start; }
  .proc-row > * { grid-column: 2; }
  .proc-row--alt > * { grid-column: 1; text-align: right; }
  .proc-row > .pr-node, .proc-row--alt > .pr-node { grid-column: auto; left: 50%; }
  .pr-node { top: clamp(46px, 6vh, 74px); }
  .pr-title, .pr-desc { max-width: 40ch; }
  .proc-row--alt .pr-desc { margin-left: auto; }
  .proc2-cta { display: flex; justify-content: center; margin-top: clamp(40px, 7vh, 80px); }
}
