/* Vestro home v2 — wodniack-tier choreography. Tokens from ../styles.css.
   Flood levels: body[data-flood="1"] dose · "2" flood moments · "3" duotone. */

html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

.col { max-width: 1280px; margin: 0 auto; padding: 0 24px; }

.display {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; letter-spacing: -0.01em; line-height: 0.98;
  margin: 0; color: var(--text-primary);
}

/* ── duotone flood (F3): whole page accent + ink ─────────── */
body[data-flood="3"] {
  --surface-page: var(--accent);
  --surface-panel: color-mix(in srgb, var(--accent) 86%, black);
  --surface-raise: color-mix(in srgb, var(--accent) 78%, black);
  --text-primary: var(--accent-ink);
  --text-secondary: color-mix(in srgb, var(--accent-ink) 72%, var(--accent));
  --line: color-mix(in srgb, var(--accent-ink) 26%, transparent);
  --line-strong: color-mix(in srgb, var(--accent-ink) 50%, transparent);
  background: var(--surface-page);
}
body[data-flood="3"] .cta.primary { background: var(--accent-ink); color: var(--accent); border-color: var(--accent-ink); }

/* ── loader ──────────────────────────────────────────────── */
.loader {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  transition: transform 460ms var(--ease-inout);
}
.loader.hide { transform: translateY(-100%); }
.loader.off { display: none; }
.loader .ld-stage { display: flex; flex-direction: column; align-items: center; gap: 20px; }
.loader .ld-word {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; font-size: 72px; letter-spacing: .02em;
  color: var(--accent-ink); line-height: 1;
}
.loader .ld-strip { display: flex; align-items: flex-end; gap: 4px; height: 56px; }
.loader .ld-strip span { width: 9px; height: 6px; background: color-mix(in srgb, var(--accent-ink) 35%, transparent); }
.loader .ld-letter { display: inline-block; }
.loader .ld-num { font-family: var(--font-mono); font-size: 14px; letter-spacing: var(--tracking-caps); color: var(--accent-ink); }
.loader .ld-bar-track { width: 260px; }
.loader .ld-bar { height: 3px; background: var(--accent-ink); width: 0%; }
.loader .gslice { position: absolute; left: 0; width: 100%; background: var(--accent); transition: transform 260ms var(--ease-inout); z-index: 2; }
.loader.glitch .ld-stage { opacity: 0; }

/* ── condensing sticky nav ───────────────────────────────── */
.topbar {
  position: sticky; top: 0; z-index: 1000;
  background: var(--surface-page); border-bottom: 1px solid var(--line);
  transition: transform 320ms var(--ease-inout);
}
.topbar.hidden { transform: translateY(-101%); }
.topbar .in { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 18px 24px; max-width: 1280px; margin: 0 auto; transition: padding 240ms var(--ease-out); }
.topbar.condensed .in { padding: 8px 24px; }
.wm {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; letter-spacing: .04em; font-size: 18px;
  color: var(--text-primary); text-decoration: none; line-height: 1;
  transition: font-size 240ms var(--ease-out);
}
.topbar.condensed .wm { font-size: 14px; }
.wm em { font-style: normal; color: var(--accent); }
body[data-flood="3"] .wm em { color: var(--text-primary); }
.topbar nav { display: flex; gap: 24px; }
.topbar nav a { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); text-decoration: none; transition: color var(--dur-fast) var(--ease-out); }
.topbar nav a:hover { color: var(--text-primary); }
.topbar .right { display: flex; align-items: center; gap: 16px; }
.nav-meter { font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); display: inline-flex; gap: 8px; align-items: center; white-space: nowrap; }
.nav-meter .dot { color: var(--success); }
.nav-meter .dot.warn { color: var(--accent); }
.theme-btn { background: none; border: 1px solid var(--line-strong); border-radius: 2px; color: var(--text-primary); font-size: 13px; padding: 4px 9px; cursor: pointer; line-height: 1; }
.theme-btn:hover { background: var(--surface-panel); }

/* ── hero ────────────────────────────────────────────────── */
.hero { position: relative; height: calc(100vh - 61px); min-height: 560px; overflow: hidden; border-bottom: 1px solid var(--line); }
.hero canvas { position: absolute; inset: 0; width: 100%; height: 100%; cursor: crosshair; }
body[data-flood="2"] .hero, body[data-flood="3"] .hero { background: var(--accent); }
.hero-meta {
  position: absolute; top: 20px; left: 24px; right: 24px;
  display: flex; justify-content: space-between; pointer-events: none;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--hero-ink-dim);
}
.hero-type { position: absolute; left: 24px; right: 24px; bottom: 28px; pointer-events: none; display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; }
.hero-type h1 { font-size: clamp(44px, 6.4vw, 100px); color: var(--hero-ink); }
.hero-type h1 .fx { color: var(--success); }
body[data-flood="2"] .hero-type h1 .fx, body[data-flood="3"] .hero-type h1 .fx { color: var(--hero-ink); text-decoration: underline; text-decoration-thickness: 0.06em; text-underline-offset: 0.08em; }
.hero-sub { font-family: var(--font-mono); font-size: 12px; line-height: 1.7; color: var(--hero-ink-dim); max-width: 300px; text-align: right; }
/* hero ink adapts: graphite site = paper ink; flooded hero = accent-ink */
.hero { --hero-ink: var(--text-primary); --hero-ink-dim: var(--text-secondary); --hero-span-a: var(--accent); --hero-span-b: var(--hot); --hero-bg: var(--surface-page); }
body[data-flood="2"] .hero, body[data-flood="3"] .hero { --hero-bg: var(--accent); --hero-ink: var(--accent-ink); --hero-ink-dim: color-mix(in srgb, var(--accent-ink) 70%, var(--accent)); --hero-span-a: var(--accent-ink); --hero-span-b: color-mix(in srgb, var(--accent-ink) 55%, var(--accent)); }
.scroll-hint { position: absolute; left: 50%; bottom: 8px; transform: translateX(-50%); font-family: var(--font-mono); font-size: 9px; letter-spacing: .2em; color: var(--hero-ink-dim); text-transform: uppercase; }

/* ── type band (marquee) ─────────────────────────────────── */
.band { overflow: hidden; border-bottom: 1px solid var(--line); padding: 18px 0; background: var(--surface-page); }
body[data-flood="2"] .band { background: var(--accent); }
.band .track { display: flex; gap: 64px; width: max-content; animation: bandmove 28s linear infinite; }
.band span {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; font-size: 56px; line-height: 1; white-space: nowrap;
  color: var(--text-primary);
}
body[data-flood="2"] .band span { color: var(--accent-ink); }
.band span em { font-style: normal; color: var(--accent); }
body[data-flood="2"] .band span em, body[data-flood="3"] .band span em { color: inherit; opacity: .45; }
@keyframes bandmove { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .band .track { animation: none; } }

/* ── section scaffolding + grid wall ─────────────────────── */
.sec { padding: 110px 0 0; }
.sec-label { display: flex; align-items: center; gap: 14px; font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.sec-label::before { content: "▪"; color: var(--accent); }
body[data-flood="3"] .sec-label::before { color: var(--text-primary); }
.sec-label::after { content: ""; flex: 1; height: 1px; background: var(--line); }
.gridwall {
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 160px 110px;
}
.pill {
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--line-strong); border-radius: 999px;
  background: var(--surface-panel);
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; font-size: 20px; letter-spacing: .06em;
  color: var(--text-primary); padding: 14px 30px;
}

/* reveal choreography */
@media (prefers-reduced-motion: no-preference) {
  .rv { opacity: 0; transform: translateY(28px); transition: opacity 600ms var(--ease-out), transform 600ms var(--ease-out); }
  .rv.in { opacity: 1; transform: none; }
  .rv2 { transition-delay: 90ms; }
  .rv3 { transition-delay: 180ms; }
  .clipline { display: block; overflow: hidden; }
  .clipline > span { display: block; transform: translateY(110%); transition: transform 700ms var(--ease-out); }
  .in .clipline > span { transform: none; }
  .clipline:nth-child(2) > span { transition-delay: 80ms; }
  .clipline:nth-child(3) > span { transition-delay: 160ms; }
}

/* ── pinned work rail ────────────────────────────────────── */
.work-sec { position: relative; }
.work-pin { position: relative; height: 320vh; }
.work-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; display: flex; flex-direction: column; justify-content: center; }
.work-head { display: flex; align-items: center; justify-content: space-between; padding: 90px 24px 20px; }
.work-progress { font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); letter-spacing: var(--tracking-caps); }
.rail { display: flex; gap: 20px; padding: 12px 24px 32px; will-change: transform; align-items: stretch; }
.rail-card {
  flex: 0 0 420px; background: var(--surface-panel);
  border: 1px solid var(--line); border-radius: var(--radius-2);
  display: flex; flex-direction: column; overflow: hidden;
  transition: background var(--dur-fast) var(--ease-out);
}
.rail-card:hover { background: var(--surface-raise); }
.rail-img { height: 190px; border-bottom: 1px solid var(--line); position: relative; flex-shrink: 0; }
.rail-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.rail-img.ph { display: flex; align-items: center; justify-content: center; background:
  repeating-linear-gradient(135deg, transparent 0 14px, var(--line) 14px 15px); }
.rail-img.ph span { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); background: var(--surface-panel); border: 1px solid var(--line); padding: 6px 12px; }
.rail-body { padding: 20px 22px 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.rail-idx { font-family: var(--font-mono); font-size: 13px; color: var(--accent); }
body[data-flood="3"] .rail-idx { color: var(--text-primary); }
.rail-title { font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: 24px; line-height: 1; margin: 0; color: var(--text-primary); }
.rail-meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); color: var(--text-secondary); }
.rail-sum { font-size: 13px; line-height: 1.55; color: var(--text-secondary); margin: 0; flex: 1; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.rail-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.rail-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono); color: var(--text-secondary); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; white-space: nowrap; }
.rail-badge { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; border-radius: 2px; padding: 4px 8px; align-self: flex-start; }
.rail-badge.fixed { color: var(--success); border: 1px solid var(--success); background: var(--success-soft); }
.rail-badge.pending { color: var(--text-secondary); border: 1px solid var(--line-strong); }
/* reduced-motion / fallback: plain horizontal scroll */
body.no-pin .work-pin { height: auto; }
body.no-pin .work-sticky { position: static; height: auto; }
body.no-pin .rail { overflow-x: auto; }

/* ── services ────────────────────────────────────────────── */
.svc-rows { margin-top: 36px; border-top: 1px solid var(--line-strong); }
.svc-row {
  display: grid; grid-template-columns: 120px 1.2fr 1fr; gap: 40px; align-items: baseline;
  padding: 44px 0; border-bottom: 1px solid var(--line);
  transition: background var(--dur-fast) var(--ease-out), padding var(--dur-base) var(--ease-out);
}
.svc-row:hover { background: var(--accent-soft); padding-left: 16px; }
.svc-row .n { font-family: var(--font-display); font-stretch: 125%; font-weight: 800; font-size: 52px; color: var(--accent); line-height: 1; }
body[data-flood="3"] .svc-row .n { color: var(--text-primary); }
.svc-row h3 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(24px, 2.6vw, 38px); line-height: 1.02; color: var(--text-primary); }
.svc-row p { margin: 0; font-size: 14px; line-height: 1.65; color: var(--text-secondary); }
.svc-note { font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); margin-top: 24px; display: block; }

/* ── big stat moment ─────────────────────────────────────── */
.about-burst { position: relative; text-align: center; padding: 130px 24px 60px; overflow: hidden; }
.about-burst .burst { position: absolute; inset: 0; pointer-events: none; }
.about-burst h2 { font-size: clamp(56px, 9vw, 150px); position: relative; }
.about-burst .cap { font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); position: relative; margin-top: 18px; display: block; }

/* ── cases ───────────────────────────────────────────────── */
.case-card { border: 1px solid var(--line); border-radius: var(--radius-2); margin-top: 32px; overflow: hidden; background: var(--surface-page); }
.case-meta { display: grid; grid-template-columns: repeat(5, 1fr); border-bottom: 1px solid var(--line); background: var(--surface-panel); }
.case-meta > div { padding: 14px 18px; border-left: 1px solid var(--line); min-width: 0; }
.case-meta > div:first-child { border-left: none; }
.case-meta .k { display: block; font-family: var(--font-mono); font-size: 9px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); margin-bottom: 5px; }
.case-meta .k::before { content: "▪ "; color: var(--accent); }
body[data-flood="3"] .case-meta .k::before { color: var(--text-primary); }
.case-meta .v { font-family: var(--font-mono); font-size: 12px; color: var(--text-primary); overflow-wrap: break-word; }
.case-body { padding: 32px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; }
.case-body h3 { margin: 0 0 16px; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: 30px; line-height: 1.02; color: var(--text-primary); }
.case-body p { margin: 0; font-size: 15px; line-height: 1.65; color: var(--text-secondary); }
.case-side { display: flex; flex-direction: column; gap: 14px; }
.case-side .stat { font-family: var(--font-mono); font-size: 13px; color: var(--success); border: 1px solid var(--success); background: var(--success-soft); border-radius: 2px; padding: 10px 14px; }
.case-side .stat.none { color: var(--text-secondary); border-color: var(--line-strong); background: transparent; font-style: italic; }
.case-link { display: inline-flex; align-items: baseline; gap: 8px; align-self: flex-start; font-family: var(--font-mono); font-size: 13px; color: var(--text-primary); text-decoration: none; border-bottom: 1px solid var(--line); padding-bottom: 2px; transition: border-color var(--dur-fast) var(--ease-out); }
.case-link:hover { border-color: var(--text-primary); }
.case-link:hover .arr { transform: translateX(4px); }
.case-link .arr { display: inline-block; transition: transform var(--dur-fast) var(--ease-out); }

/* ── about ───────────────────────────────────────────────── */
.about-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; margin-top: 36px; }
.about-grid p { margin: 0 0 14px; font-size: 16px; line-height: 1.65; color: var(--text-primary); }
.about-grid p.dim { color: var(--text-secondary); font-size: 14px; }
.about-stats { display: flex; gap: 48px; }
.stat-big { display: flex; flex-direction: column; gap: 8px; }
.stat-big b { font-family: var(--font-mono); font-weight: 600; font-size: 48px; line-height: 1; color: var(--text-primary); }
.stat-big span { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.client-row { display: flex; gap: 40px; margin-top: 40px; flex-wrap: wrap; }
.client-row a { font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); text-decoration: none; border-bottom: 1px solid var(--line); padding-bottom: 2px; }
.client-row a:hover { color: var(--text-primary); border-color: var(--text-primary); }

/* ── contact flood wall ──────────────────────────────────── */
.contact { margin-top: 120px; padding: 130px 0; position: relative; overflow: hidden; }
body[data-flood="1"] .contact { border-top: 1px solid var(--line); }
body[data-flood="2"] .contact, body[data-flood="3"] .contact { background: var(--accent); }
.contact .col { position: relative; }
.contact canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.contact { --c-ink: var(--text-primary); --c-dim: var(--text-secondary); }
body[data-flood="2"] .contact, body[data-flood="3"] .contact { --c-ink: var(--accent-ink); --c-dim: color-mix(in srgb, var(--accent-ink) 70%, var(--accent)); }
.contact .sec-label { color: var(--c-dim); }
.contact h2 { font-size: clamp(44px, 6vw, 92px); color: var(--c-ink); margin-top: 28px; }
.contact-row { display: flex; align-items: center; gap: 24px; margin-top: 40px; flex-wrap: wrap; }
.contact-note { font-family: var(--font-mono); font-size: 12px; color: var(--c-dim); }
body[data-flood="2"] .contact .cta.primary, body[data-flood="3"] .contact .cta.primary { background: var(--accent-ink); color: var(--accent); border-color: var(--accent-ink); }

/* ── CTAs ────────────────────────────────────────────────── */
.cta {
  display: inline-flex; align-items: center; gap: 10px; padding: 15px 26px;
  font-family: var(--font-mono); font-size: 13px; font-weight: 500;
  letter-spacing: var(--tracking-caps); text-transform: uppercase;
  border-radius: 2px; text-decoration: none; cursor: pointer;
  transition: filter var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out);
  will-change: transform;
}
.cta.primary { background: var(--accent); color: var(--accent-ink); border: 1px solid transparent; }
.cta.primary:hover { filter: brightness(1.08); }
.cta.ghost { background: transparent; color: var(--text-primary); border: 1px solid var(--line-strong); }
.cta.ghost:hover { background: var(--surface-panel); }
.cta:active { transform: translateY(1px); }

/* ── footer ──────────────────────────────────────────────── */
.footer { border-top: 1px solid var(--line); padding: 32px 0 90px; }
.footer-grid { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; align-items: baseline; }
.footer a { font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); text-decoration: none; letter-spacing: var(--tracking-mono); }
.footer a:hover { color: var(--text-primary); }
.footer .tiny { font-family: var(--font-mono); font-size: 10px; color: var(--text-secondary); }
.ticks { display: flex; justify-content: space-between; align-items: flex-end; padding: 0 0 24px; }
.ticks span { width: 1px; height: 6px; background: var(--line-strong); }
.ticks span.h { height: 12px; background: var(--accent); }
body[data-flood="3"] .ticks span.h { background: var(--text-primary); }

/* ── fixed chips: meter + crosshair ──────────────────────── */
.meter-chip { position: fixed; left: 16px; bottom: 16px; z-index: 9000; background: var(--surface-panel); border: 1px solid var(--line); border-radius: 2px; padding: 7px 12px; font-family: var(--font-mono); font-size: 11px; color: var(--text-secondary); display: flex; gap: 8px; align-items: center; }
.meter-chip .dot { color: var(--success); }
.meter-chip .dot.warn { color: var(--accent); }
.xhair { position: fixed; left: 0; top: 0; z-index: 9500; pointer-events: none; width: 36px; height: 36px; margin: -18px 0 0 -18px; opacity: 0; transition: opacity 240ms var(--ease-out); }
.xhair::before, .xhair::after { content: ""; position: absolute; background: var(--accent); }
body[data-flood="3"] .xhair::before, body[data-flood="3"] .xhair::after { background: var(--text-primary); }
.xhair::before { left: 50%; top: 6px; bottom: 6px; width: 1px; }
.xhair::after { top: 50%; left: 6px; right: 6px; height: 1px; }
.xhair .ring { position: absolute; inset: 0; border: 1px solid var(--line-strong); border-radius: 50%; transition: transform 200ms var(--ease-out); }
.xhair.on { opacity: 1; }
.xhair.mag .ring { transform: scale(1.5); }
@media (hover: none), (prefers-reduced-motion: reduce) { .xhair { display: none !important; } }

/* ── customizer ──────────────────────────────────────────── */
.cz-toggle {
  position: fixed; right: 16px; bottom: 16px; z-index: 9600;
  background: var(--surface-panel); border: 1px solid var(--line-strong); border-radius: 2px;
  color: var(--text-primary); font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--tracking-caps); text-transform: uppercase;
  padding: 9px 14px; cursor: pointer; display: inline-flex; gap: 8px; align-items: center;
}
.cz-toggle .sw { width: 9px; height: 9px; background: var(--accent); display: inline-block; }
.cz {
  position: fixed; right: 16px; bottom: 60px; z-index: 9600; width: 270px;
  background: var(--surface-panel); border: 1px solid var(--line-strong); border-radius: 4px;
  padding: 16px; display: none; flex-direction: column; gap: 14px;
  box-shadow: var(--shadow-overlay);
}
.cz.open { display: flex; }
.cz h5 { margin: 0; font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-primary); font-weight: 500; display: flex; justify-content: space-between; }
.cz h5 small { color: var(--text-secondary); font-weight: 400; letter-spacing: var(--tracking-mono); text-transform: none; }
.cz .group { display: flex; flex-direction: column; gap: 7px; }
.cz .glabel { font-family: var(--font-mono); font-size: 9px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.cz .swatches { display: flex; gap: 6px; flex-wrap: wrap; }
.cz .sw-btn { width: 30px; height: 26px; border: 1px solid var(--line); border-radius: 2px; cursor: pointer; padding: 0; position: relative; }
.cz .sw-btn.sel { outline: 2px solid var(--text-primary); outline-offset: 1px; }
.cz .segs { display: flex; gap: 4px; }
.cz .seg { flex: 1; background: none; border: 1px solid var(--line); border-radius: 2px; color: var(--text-secondary); font-family: var(--font-mono); font-size: 10px; letter-spacing: .04em; padding: 6px 4px; cursor: pointer; white-space: nowrap; }
.cz .seg.sel { border-color: var(--accent); color: var(--text-primary); background: var(--accent-soft); }
body[data-flood="3"] .cz .seg.sel { border-color: var(--text-primary); background: transparent; }
.cz .replay-loader { background: none; border: 1px solid var(--line-strong); border-radius: 2px; color: var(--accent); font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; padding: 7px; cursor: pointer; }
body[data-flood="3"] .cz .replay-loader { color: var(--text-primary); }

@media (max-width: 980px) {
  .svc-row { grid-template-columns: 64px 1fr; }
  .svc-row p { grid-column: 2; }
  .case-body { grid-template-columns: 1fr; gap: 24px; }
  .case-meta { grid-template-columns: repeat(2, 1fr); }
  .about-grid { grid-template-columns: 1fr; }
  .band span { font-size: 36px; }
  .hero-sub { display: none; }
}


/* ════ revision 3: profile grid, letter wall, outlined services, reports ════ */

/* profile / id card (elliot-style mono columns) */
.profile-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
  border-top: 1px solid var(--line-strong); padding-top: 28px;
}
.pcol { display: flex; flex-direction: column; gap: 8px; font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-mono); color: var(--text-primary); line-height: 1.5; }
.pcol .pk { font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }
body[data-flood="3"] .pcol .pk { color: var(--text-primary); }
.pcol b { font-weight: 600; }
.pcol .dim { color: var(--text-secondary); }
.pcol a { color: var(--text-primary); text-decoration: none; border-bottom: 1px solid var(--line); padding-bottom: 1px; align-self: flex-start; }
.pcol a:hover { border-color: var(--text-primary); }
@media (max-width: 980px) { .profile-grid { grid-template-columns: repeat(2, 1fr); } }

/* work letter wall */
.work-sec { position: relative; }
body[data-flood="3"] .work-sec { background: var(--accent-ink); }
.letterwall { position: absolute; inset: 0; overflow: hidden; pointer-events: none; display: flex; flex-direction: column; justify-content: space-between; padding: 4vh 0; }
.lw-row {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; font-size: 13vh; line-height: 1; white-space: nowrap;
  color: transparent; -webkit-text-stroke: 1px var(--line-strong);
  opacity: 0.5; will-change: transform;
}
body[data-flood="3"] .lw-row { -webkit-text-stroke: 1px color-mix(in srgb, var(--accent) 50%, transparent); }
.work-sticky { position: relative; z-index: 1; }

/* services: outlined giant type rows that fill on hover */
.svc-row {
  grid-template-columns: 90px 1.5fr 1fr 60px; gap: 32px; align-items: center;
  padding: 52px 0; cursor: default;
}
.svc-row:hover { background: transparent; padding-left: 16px; }
.svc-row h3 {
  font-size: clamp(34px, 3.6vw, 56px);
  color: transparent; -webkit-text-stroke: 1.2px var(--text-primary);
  transition: color var(--dur-base) var(--ease-out);
}
.svc-row:hover h3 { color: var(--text-primary); }
.svc-row p { opacity: 0.65; transition: opacity var(--dur-base) var(--ease-out); }
.svc-row:hover p { opacity: 1; }
.svc-row .go {
  font-family: var(--font-mono); font-size: 28px; color: var(--text-secondary);
  transition: transform var(--dur-base) var(--ease-out), color var(--dur-fast) var(--ease-out);
  justify-self: end;
}
.svc-row:hover .go { transform: translate(4px, -4px); color: var(--accent); }
body[data-flood="3"] .svc-row:hover .go { color: var(--text-primary); }

/* engagement reports: alternating media rows */
.report {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 48px; align-items: center;
  padding: 56px 0; border-bottom: 1px solid var(--line);
}
.report.flip .report-info { order: 2; }
.report.flip .report-media { order: 1; }
.report-info { display: flex; flex-direction: column; gap: 14px; }
.report-idx { font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-caps); color: var(--accent); }
body[data-flood="3"] .report-idx { color: var(--text-primary); }
.report-info h3 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(26px, 2.8vw, 40px); line-height: 1.02; color: var(--text-primary); }
.report-meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.report-info p { margin: 0; font-size: 15px; line-height: 1.65; color: var(--text-secondary); max-width: 560px; }
.report-stat { font-family: var(--font-mono); font-size: 12px; font-style: italic; color: var(--text-secondary); border: 1px solid var(--line-strong); border-radius: 2px; padding: 8px 12px; align-self: flex-start; }
.report-media { border: 1px solid var(--line-strong); overflow: hidden; }
.report-media img { width: 100%; height: 100%; max-height: 320px; object-fit: cover; display: block; transition: transform 600ms var(--ease-out); }
.report:hover .report-media img { transform: scale(1.03); }
@media (max-width: 980px) { .report { grid-template-columns: 1fr; } .report.flip .report-info { order: 0; } .report.flip .report-media { order: 0; } }

/* directional reveals */
@media (prefers-reduced-motion: no-preference) {
  .rv-l, .rv-r { opacity: 0; transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out); }
  .rv-l { transform: translateX(-48px); }
  .rv-r { transform: translateX(48px); }
  .rv-l.in, .rv-r.in { opacity: 1; transform: none; }
}


/* ════ tweaks: energy / density / crt ════ */
:root { --band-dur: 28s; }
.band .track { animation-duration: var(--band-dur); }

body[data-density="tight"] .sec { padding-top: 56px; }
body[data-density="tight"] .hero-type h1 { font-size: clamp(36px, 5vw, 76px); }
body[data-density="tight"] .svc-row { padding: 30px 0; }
body[data-density="tight"] .report { padding: 32px 0; }
body[data-density="tight"] .band span { font-size: 38px; }
body[data-density="tight"] .rail-card { flex-basis: 360px; }
body[data-density="tight"] .rail-img { height: 150px; }

body[data-density="air"] .sec { padding-top: 170px; }
body[data-density="air"] .hero-type h1 { font-size: clamp(52px, 8vw, 128px); }
body[data-density="air"] .svc-row { padding: 76px 0; }
body[data-density="air"] .report { padding: 90px 0; }
body[data-density="air"] .rail-card { flex-basis: 500px; }
body[data-density="air"] .rail-img { height: 230px; }

.crt-overlay { position: fixed; inset: 0; z-index: 9400; pointer-events: none; display: none; }
body[data-crt="1"] .crt-overlay {
  display: block;
  background:
    radial-gradient(ellipse at center, transparent 58%, rgba(0,0,0,0.32) 100%),
    repeating-linear-gradient(0deg, rgba(0,0,0,0.16) 0 1px, transparent 1px 3px);
}
body[data-crt="1"] .hero canvas, body[data-crt="1"] .band, body[data-crt="1"] .display { filter: saturate(1.15) contrast(1.04); }


/* ════ revision 4: crawl about, work world, sticky stacks, contact letters ════ */

/* customizer moves bottom-left so the Tweaks panel never covers it */
.cz-toggle { right: 16px; left: auto; }
.cz { right: 16px; left: auto; bottom: 60px; }
.cz .segs.wrap { flex-wrap: wrap; }
.cz .segs.wrap .seg { flex: 0 0 calc(33% - 4px); }

/* ── about crawl (perspective) ── */
.crawl-stage { perspective: 620px; overflow: hidden; padding: 40px 0 8px; }
.crawl-inner {
  max-width: 980px; margin: 0 auto; text-align: center;
  display: flex; flex-direction: column; gap: 34px;
  transform-origin: 50% 100%;
  will-change: transform;
}
.cl { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; letter-spacing: -0.01em; line-height: 0.98; color: var(--text-primary); }
.cl.xl { font-size: clamp(64px, 9vw, 150px); }
.cl.md { font-size: clamp(30px, 3.6vw, 54px); }
.cl.sm { font-family: var(--font-mono); font-weight: 500; font-size: clamp(12px, 1.1vw, 15px); letter-spacing: var(--tracking-caps); color: var(--text-secondary); }
.cl .adot { color: var(--accent); }
body[data-flood="3"] .cl .adot { color: var(--text-primary); }
.cl.dim { opacity: 0.75; }
@media (prefers-reduced-motion: reduce) { .crawl-inner { transform: none !important; } }

/* ── staggered profile blocks with uncover reveal ── */
.profile-stagger { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-top: 72px; }
.pblock {
  grid-column: var(--gc); grid-row: var(--gr);
  transform: translateY(var(--off, 0px));
  display: flex; flex-direction: column; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-mono);
  color: var(--text-primary); line-height: 1.5;
  border-top: 1px solid var(--line-strong); padding-top: 14px;
}
.pblock .pk { font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); margin-bottom: 4px; }
body[data-flood="3"] .pblock .pk { color: var(--text-primary); }
.pblock b { font-weight: 600; }
.pblock .dim { color: var(--text-secondary); }
.pblock a { color: var(--text-primary); text-decoration: none; border-bottom: 1px solid var(--line); padding-bottom: 1px; align-self: flex-start; }
.pblock a:hover { border-color: var(--text-primary); }
@media (prefers-reduced-motion: no-preference) {
  .uncover { clip-path: inset(0 100% 0 0); transition: clip-path 900ms var(--ease-out); }
  .uncover.in { clip-path: inset(0 0 0 0); }
  .uncover.u2 { transition-delay: 120ms; }
  .uncover.u3 { transition-delay: 200ms; }
  .uncover.u4 { transition-delay: 320ms; }
}
@media (max-width: 980px) {
  .profile-stagger { grid-template-columns: 1fr; }
  .pblock { grid-column: 1; grid-row: auto; transform: none; }
}

/* ── tick divider between worlds ── */
.tickline { display: flex; justify-content: space-between; align-items: flex-end; padding: 0 24px 2px; border-bottom: 1px solid var(--line); max-width: 1280px; margin: 96px auto 0; }
.tickline span { width: 1px; height: 6px; background: var(--line-strong); }
.tickline span.h { height: 12px; background: var(--accent); }
body[data-flood="3"] .tickline span.h { background: var(--text-primary); }

/* ── work world: full-screen scroll slides ── */
.ww { position: relative; margin-top: 96px; }
.ww-pin { position: relative; }
.ww-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; }
.ww-slides { position: absolute; inset: 0; }
.ww-slide { position: absolute; inset: 0; will-change: clip-path; }
.ww-media { position: absolute; inset: 0; background: var(--surface-panel); }
.ww-media img { width: 100%; height: 100%; object-fit: cover; display: block; will-change: transform; }
.ww-media::after { content: ""; position: absolute; inset: 0; background: color-mix(in srgb, var(--graphite) 34%, transparent); }
.ww-info {
  position: absolute; left: 32px; bottom: 36px; z-index: 2;
  width: min(560px, calc(100% - 64px));
  background: var(--surface-panel); border: 1px solid var(--line-strong);
  padding: 26px 28px; display: flex; flex-direction: column; gap: 12px;
}
.ww-idx { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); }
body[data-flood="3"] .ww-idx { color: var(--text-primary); }
.ww-info h3 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(28px, 3vw, 44px); line-height: 1; color: var(--text-primary); }
.ww-info p { margin: 0; font-size: 14px; line-height: 1.6; color: var(--text-secondary); }
.ww-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.ww-tags span { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono); color: var(--text-secondary); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; }
.ww-badge { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; border-radius: 2px; padding: 4px 8px; align-self: flex-start; }
.ww-badge.fixed { color: var(--success); border: 1px solid var(--success); background: var(--success-soft); }
.ww-badge.pending { color: var(--text-secondary); border: 1px solid var(--line-strong); background: var(--surface-panel); }
.ww-chrome { position: absolute; top: 0; left: 0; right: 0; z-index: 3; display: flex; justify-content: space-between; align-items: center; padding: 22px 32px; pointer-events: none; }
.ww-prog { font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-caps); color: var(--text-primary); background: var(--surface-panel); border: 1px solid var(--line); padding: 6px 12px; }
body[data-art="mono"] .ww-media img, body[data-art="mono"] .stk-media img { filter: grayscale(1) contrast(1.12); }
/* reduced motion fallback: plain stacked blocks */
body.no-pin .ww-sticky { position: static; height: auto; overflow: visible; }
body.no-pin .ww-slides { position: static; }
body.no-pin .ww-slide { position: relative; height: 70vh; clip-path: none !important; margin-bottom: 16px; }
body.no-pin .ww-chrome { display: none; }

/* ── sticky stacks (services + reports) ── */
.stack { margin-top: 36px; }
.stack-card {
  position: sticky; top: calc(96px + var(--i) * 56px);
  background: var(--surface-panel); border: 1px solid var(--line-strong);
  margin-bottom: 28px; padding: 40px 44px; min-height: 38vh;
  display: flex; gap: 40px; align-items: flex-start;
  will-change: transform;
}
.stk-n { font-family: var(--font-display); font-stretch: 125%; font-weight: 800; font-size: 64px; line-height: 1; color: var(--accent); flex-shrink: 0; }
body[data-flood="3"] .stk-n { color: var(--text-primary); }
.stk-main { display: flex; flex-direction: column; gap: 14px; flex: 1; }
.stk-main h3 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(28px, 3.2vw, 48px); line-height: 1; color: var(--text-primary); }
.stk-main p { margin: 0; font-size: 15px; line-height: 1.65; color: var(--text-secondary); max-width: 640px; }
.stk-go { font-family: var(--font-mono); font-size: 30px; color: var(--text-secondary); margin-left: auto; transition: transform var(--dur-base) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.stack-card:hover .stk-go { transform: translate(4px, -4px); color: var(--accent); }
.stack-card.media { padding: 0; overflow: hidden; gap: 0; }
.stack-card.media .stk-media { flex: 0 0 44%; align-self: stretch; border-right: 1px solid var(--line-strong); }
.stack-card.media .stk-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.stack-card.media .stk-main { padding: 36px 40px; }
@media (max-width: 980px) {
  .stack-card { flex-direction: column; gap: 16px; padding: 28px; }
  .stack-card.media { flex-direction: column; }
  .stack-card.media .stk-media { flex-basis: 200px; border-right: none; border-bottom: 1px solid var(--line-strong); width: 100%; }
}

/* ── contact letter-fill ── */
.contact-big { cursor: default; }
.contact-big .lt {
  display: inline-block; white-space: pre;
  color: transparent; -webkit-text-stroke: 1.2px var(--c-ink);
  transition: color 180ms var(--ease-out), transform 220ms var(--ease-out);
  will-change: transform;
}
.contact-big .lt.lit { color: var(--c-ink); }
@media (prefers-reduced-motion: reduce) { .contact-big .lt { color: var(--c-ink); transform: none !important; } }

/* crosshair tweak toggle */
body[data-cursor="0"] .xhair { display: none !important; }


/* ════ revision 5: about lede + awards, window world, flatten crawl, GO circle ════ */

/* packets/insights readability on flooded hero */
body[data-flood="2"] .hero, body[data-flood="3"] .hero {
  --hero-ink-dim: color-mix(in srgb, var(--accent-ink) 80%, var(--accent));
}

/* ── about lede ── */
.about-lede { max-width: 880px; margin-top: 40px; display: flex; flex-direction: column; gap: 28px; }
.lede-big { margin: 0; font-size: clamp(22px, 2.2vw, 32px); line-height: 1.45; color: var(--text-primary); font-weight: 500; text-wrap: pretty; }
.lede-big.dim { color: var(--text-secondary); font-weight: 400; font-size: clamp(17px, 1.6vw, 22px); }

/* ── awards windows with sliding cover ── */
.awards { margin-top: 72px; border-top: 1px solid var(--line-strong); }
.awards-bar {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--accent-ink); background: var(--text-primary);
  padding: 8px 14px;
}
body[data-flood="3"] .awards-bar { background: var(--text-primary); color: var(--accent); }
.award { position: relative; overflow: hidden; border-bottom: 1px solid var(--line); }
.award-in {
  display: flex; align-items: baseline; gap: 28px; padding: 34px 14px;
  transition: transform var(--dur-base) var(--ease-out), padding var(--dur-base) var(--ease-out);
  position: relative;
}
.a-year { font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); width: 90px; flex-shrink: 0; }
body[data-flood="3"] .a-year { color: var(--text-primary); }
.award-in h3 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(22px, 2.4vw, 36px); line-height: 1.05; color: var(--text-primary); }
.award:hover .award-in { transform: translateX(10px); }
.award-in::before, .award-in::after {
  content: "✦"; position: absolute; font-size: 18px; color: var(--accent);
  opacity: 0; transform: scale(0.4) rotate(-30deg);
  transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.award-in::before { right: 56px; top: 14px; }
.award-in::after { right: 22px; bottom: 14px; font-size: 13px; }
.award:hover .award-in::before, .award:hover .award-in::after { opacity: 1; transform: scale(1) rotate(0deg); }
body[data-flood="3"] .award-in::before, body[data-flood="3"] .award-in::after { color: var(--text-primary); }
.award-cover { position: absolute; inset: 0; background: var(--text-primary); z-index: 2; }
@media (prefers-reduced-motion: no-preference) {
  .award-cover { transition: transform 900ms var(--ease-inout); }
  .award.in .award-cover { transform: translateX(101%); }
  .award:nth-child(3) .award-cover { transition-delay: 100ms; }
  .award:nth-child(4) .award-cover { transition-delay: 200ms; }
  .award:nth-child(5) .award-cover { transition-delay: 300ms; }
}
@media (prefers-reduced-motion: reduce) { .award-cover { display: none; } }

/* ── work: the window world ── */
.wk { position: relative; margin-top: 110px; }
.wk-pin { position: relative; }
.wk-stage {
  position: sticky; top: 0; height: 100vh; overflow: hidden;
  --wk-ink: var(--text-secondary);
  background-image: linear-gradient(color-mix(in srgb, var(--wk-ink) 32%, transparent) 1px, transparent 1px),
                    linear-gradient(90deg, color-mix(in srgb, var(--wk-ink) 32%, transparent) 1px, transparent 1px);
  background-size: 160px 110px;
}
body[data-flood="2"] .wk-stage, body[data-flood="3"] .wk-stage {
  background-color: var(--accent);
  --wk-ink: var(--accent-ink);
}
.wk-window {
  position: absolute; inset: 0;
  background: color-mix(in srgb, var(--accent-ink) 94%, var(--accent));
  transform-origin: 50% 42%;
  overflow: hidden;
  will-change: transform;
  display: flex; align-items: center; justify-content: center;
}
.wk-letters {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 0;
  pointer-events: none;
}
.wk-row {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  font-size: 21vh; line-height: 0.82; letter-spacing: 0.02em;
  color: var(--accent); white-space: nowrap; will-change: transform;
}
body[data-flood="1"] .wk-row { color: var(--text-primary); }
.wk-fly { position: absolute; inset: 0; }
.wk-card {
  position: absolute; left: 50%; top: 50%; margin: 0;
  width: min(46vw, 720px); transform: translate(-50%, -50%);
  will-change: transform; opacity: 0;
}
.wk-card img {
  width: 100%; aspect-ratio: 460 / 215; object-fit: cover; display: block;
  border: 1px solid color-mix(in srgb, var(--accent) 50%, transparent);
}
body[data-art="mono"] .wk-card img { filter: grayscale(1) contrast(1.12); }
.wk-card figcaption {
  margin-top: 10px; font-family: var(--font-mono); font-size: 11px;
  letter-spacing: var(--tracking-caps); text-transform: uppercase;
  color: var(--accent);
}
body[data-flood="1"] .wk-card figcaption { color: var(--text-primary); }
/* reduced-motion: flat list */
body.no-pin .wk-stage { position: static; height: auto; }
body.no-pin .wk-window { position: static; transform: none !important; border-radius: 0 !important; padding: 48px 24px; display: block; }
body.no-pin .wk-letters { display: none; }
body.no-pin .wk-fly { position: static; display: flex; flex-direction: column; gap: 32px; }
body.no-pin .wk-card { position: static; transform: none !important; opacity: 1 !important; width: min(80vw, 720px); margin: 0 auto; }
body.no-pin .ww-chrome { display: none; }

/* ── track record: crawl that flattens onto the wall ── */
.flat { position: relative; }
.flat-stage {
  height: 160vh; perspective: 540px; overflow: clip;
  display: flex; align-items: flex-end; justify-content: center;
  padding-bottom: 8vh;
}
.flat-inner {
  text-align: center; display: flex; flex-direction: column; gap: 30px;
  transform-origin: 50% 100%;
  will-change: transform;
  padding-bottom: 6vh;
}
@media (prefers-reduced-motion: reduce) { .flat-inner { transform: none !important; } }

/* ── contact: GO circle ── */
.go-sec {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  margin-top: 110px; padding: 10vh 24px; position: relative;
}
body[data-flood="2"] .go-sec, body[data-flood="3"] .go-sec {
  background-color: var(--accent);
  background-image: linear-gradient(color-mix(in srgb, var(--accent-ink) 30%, transparent) 1px, transparent 1px),
                    linear-gradient(90deg, color-mix(in srgb, var(--accent-ink) 30%, transparent) 1px, transparent 1px);
}
.go-circle {
  --go-bg: var(--text-primary);
  --go-ink: var(--surface-page);
  width: 140px; height: 140px; border-radius: 50%;
  background: var(--go-bg); color: var(--go-ink);
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
  transition: width 700ms var(--ease-inout), height 700ms var(--ease-inout);
  will-change: width, height;
}
body[data-flood="2"] .go-circle, body[data-flood="3"] .go-circle {
  --go-bg: color-mix(in srgb, var(--accent-ink) 94%, var(--accent));
  --go-ink: var(--accent);
}
.go-label {
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  font-size: 30px; letter-spacing: 0.04em; color: var(--go-ink);
  transition: opacity 240ms var(--ease-out), transform 400ms var(--ease-out);
}
.go-circle.open { width: min(88vw, 86vh); height: min(88vw, 86vh); }
.go-circle.open .go-label { opacity: 0; transform: scale(2.4); }
.go-content {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 22px; text-align: center;
  opacity: 0; transform: translateY(14px); pointer-events: none;
  transition: opacity 360ms var(--ease-out) 240ms, transform 360ms var(--ease-out) 240ms;
  padding: 10%;
}
.go-circle.open .go-content { opacity: 1; transform: none; pointer-events: auto; }
.go-kicker { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--go-ink); opacity: 0.7; }
.go-content h2 { margin: 0; font-size: clamp(28px, 4.4vw, 56px); color: var(--go-ink); }
.go-cta.cta.primary { background: var(--go-ink); color: var(--go-bg); border-color: var(--go-ink); }
.go-note { font-family: var(--font-mono); font-size: 11px; color: var(--go-ink); opacity: 0.7; }
@media (prefers-reduced-motion: reduce) {
  .go-circle { width: min(88vw, 86vh); height: min(88vw, 86vh); }
  .go-label { display: none; }
  .go-content { opacity: 1; transform: none; pointer-events: auto; }
}


/* ════ revision 6: bytelines, awards grid, split window, pinned flatten, PING ════ */

/* hero mechanics contrast on flooded backgrounds */
body[data-flood="2"] .hero, body[data-flood="3"] .hero {
  --hero-ink-dim: color-mix(in srgb, var(--accent-ink) 88%, var(--accent));
}

/* ── byteline stitches ── */
.byteline {
  display: flex; align-items: center; gap: 20px; overflow: hidden;
  white-space: nowrap; padding: 5px 12px;
  border-top: 1px solid var(--line-strong); border-bottom: 1px solid var(--line-strong);
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em;
  color: var(--text-secondary); margin-top: 110px;
}
.byteline .bits { color: var(--text-primary); flex-shrink: 0; }
.byteline .fill { opacity: 0.45; flex-shrink: 0; }
.byteline::before { content: "▸"; color: var(--accent); }
body[data-flood="3"] .byteline::before { color: var(--text-primary); }
.wk + .byteline, .flat + .byteline { margin-top: 0; }

/* ── awards grid ── */
.awards { margin-top: 72px; border-top: none; }
.awards-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px; }
.award {
  position: relative; overflow: hidden; border: 1px solid var(--line-strong);
  border-bottom: 1px solid var(--line-strong);
  background: var(--surface-panel); padding: 22px 24px 18px;
  display: flex; flex-direction: column; gap: 12px; min-height: 170px;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.award:hover { border-color: var(--accent); }
body[data-flood="3"] .award:hover { border-color: var(--text-primary); }
.award-hatch {
  height: 10px; margin: -22px -24px 4px;
  background: repeating-linear-gradient(45deg, var(--line-strong) 0 1px, transparent 1px 7px);
}
.a-idx { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); }
body[data-flood="3"] .a-idx { color: var(--text-primary); }
.award h3 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(18px, 1.8vw, 26px); line-height: 1.05; color: var(--text-primary); flex: 1; }
.award .a-year { position: absolute; right: 24px; top: 26px; width: auto; font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.a-bars { display: flex; align-items: flex-end; gap: 3px; height: 22px; }
.a-bars span { width: 5px; background: var(--text-secondary); opacity: 0.5; height: 30%; transform-origin: bottom; transition: transform 320ms var(--ease-out), background 320ms var(--ease-out), opacity 320ms var(--ease-out); }
.a-bars span:nth-child(1) { height: 40%; } .a-bars span:nth-child(2) { height: 65%; }
.a-bars span:nth-child(3) { height: 30%; } .a-bars span:nth-child(4) { height: 80%; }
.a-bars span:nth-child(5) { height: 50%; } .a-bars span:nth-child(6) { height: 95%; }
.a-bars span:nth-child(7) { height: 38%; }
.award:hover .a-bars span { background: var(--accent); opacity: 1; transform: scaleY(1.9); }
body[data-flood="3"] .award:hover .a-bars span { background: var(--text-primary); }
.award:hover .a-bars span:nth-child(2n) { transition-delay: 60ms; }
.award:hover .a-bars span:nth-child(3n) { transition-delay: 120ms; }
@media (max-width: 980px) { .awards-grid { grid-template-columns: 1fr; } }

/* ── work window: split-open, dots, foreground letters ── */
.wk-window {
  border-radius: 0 !important;
  background:
    radial-gradient(color-mix(in srgb, var(--accent) 38%, transparent) 1px, transparent 1.5px) 0 0 / 26px 26px,
    color-mix(in srgb, var(--accent-ink) 94%, var(--accent));
  transform: none;
  will-change: clip-path;
}
body[data-flood="1"] .wk-window {
  background:
    radial-gradient(color-mix(in srgb, var(--slate) 45%, transparent) 1px, transparent 1.5px) 0 0 / 26px 26px,
    var(--surface-panel);
}
.wk-row { will-change: transform, opacity; }
.wk-front { position: absolute; inset: 0; pointer-events: none; z-index: 3; }
.wk-front span {
  position: absolute;
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  font-size: 34vh; line-height: 1; color: var(--accent);
  will-change: transform; opacity: 0.92;
}
body[data-flood="1"] .wk-front span { color: var(--text-primary); }
.wk-card { z-index: 2; width: min(36vw, 560px); }
.ww-chrome.bottom { top: auto; bottom: 0; justify-content: flex-end; padding: 0 24px 20px; }
.wk-clients {
  display: flex; gap: 36px; align-items: baseline; flex-wrap: wrap;
  padding: 28px 24px 0;
}
.wk-clients-label { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.wk-clients a { font-family: var(--font-mono); font-size: 12px; color: var(--text-primary); text-decoration: none; border-bottom: 1px solid var(--line); padding-bottom: 2px; }
.wk-clients a:hover { border-color: var(--text-primary); }

/* ── pinned flatten crawl with radial burst ── */
.flat { margin-top: 0; }
.flat-pin { position: relative; height: 460vh; }
.flat-stage {
  position: sticky; top: 0; height: 100vh; overflow: hidden;
  perspective: 480px;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
  background-image: repeating-conic-gradient(from 0deg at 50% 18%, var(--line-strong) 0deg 0.3deg, transparent 0.3deg 5.4deg);
}
body[data-flood="2"] .flat-stage, body[data-flood="3"] .flat-stage {
  background-color: var(--accent);
  background-image: repeating-conic-gradient(from 0deg at 50% 18%, color-mix(in srgb, var(--accent-ink) 55%, transparent) 0deg 0.3deg, transparent 0.3deg 5.4deg);
}
body[data-flood="2"] .flat-stage .cl, body[data-flood="3"] .flat-stage .cl { color: var(--accent-ink); }
body[data-flood="2"] .flat-stage .cl.sm, body[data-flood="3"] .flat-stage .cl.sm { color: color-mix(in srgb, var(--accent-ink) 75%, var(--accent)); }
body[data-flood="2"] .flat-stage .cl .adot, body[data-flood="3"] .flat-stage .cl .adot { color: var(--accent-ink); }
.flat-inner { gap: 40px; transform-origin: 50% 85%; padding-bottom: 0; }
body.no-pin .flat-pin { height: auto; }
body.no-pin .flat-stage { position: static; height: auto; padding: 80px 24px; }

/* ── PING contact ── */
.go-sec { position: relative; overflow: hidden; }
.go-sec.gridwall { background-image: none; }
.go-grid {
  position: absolute; inset: -6%;
  transition: transform 900ms var(--ease-inout);
  will-change: transform;
}
body[data-flood="2"] .go-sec, body[data-flood="3"] .go-sec { background-color: var(--accent); }
body[data-flood="2"] .go-grid, body[data-flood="3"] .go-grid {
  background-image: linear-gradient(color-mix(in srgb, var(--accent-ink) 30%, transparent) 1px, transparent 1px),
                    linear-gradient(90deg, color-mix(in srgb, var(--accent-ink) 30%, transparent) 1px, transparent 1px);
}
#contact.open .go-grid { transform: scale(1.14) rotate(1.2deg); }
.go-circle { z-index: 2; }
.ping-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid var(--go-ink); opacity: 0;
  pointer-events: none;
}
@media (prefers-reduced-motion: no-preference) {
  .go-circle:not(.open) .ping-ring { animation: pingring 2.6s var(--ease-out) infinite; }
  .go-circle:not(.open) .ping-ring.r2 { animation-delay: 1.3s; }
}
@keyframes pingring {
  0% { transform: scale(1); opacity: 0.7; }
  100% { transform: scale(2.6); opacity: 0; }
}
.go-circle.open .ping-ring { display: none; }


/* ════ revision 7: seam dividers, TITLES window, hover cards, stretch wall, terminal ping ════ */

/* ── seam dividers (replaces byte strip) ── */
.byteline { gap: 16px; padding: 7px 16px; font-size: 9px; }
.byteline::before { content: ""; display: none; }
.seam-label { color: var(--text-primary); letter-spacing: var(--tracking-caps); text-transform: uppercase; flex-shrink: 0; transition: opacity 300ms var(--ease-out); }
.seam-label::before { content: "▪ "; color: var(--accent); }
body[data-flood="3"] .seam-label::before { color: var(--text-primary); }
.seam-track {
  position: relative; flex: 1; height: 8px; overflow: hidden;
  background-image: repeating-linear-gradient(90deg, var(--line-strong) 0 1px, transparent 1px 14px);
  background-position: 0 100%; background-size: 100% 5px; background-repeat: no-repeat;
}
.seam-pulse { position: absolute; top: 0; bottom: 0; width: 54px; background: var(--accent); }
body[data-flood="3"] .seam-pulse { background: var(--text-primary); }
@media (prefers-reduced-motion: no-preference) { .seam-pulse { animation: seampulse 5.2s linear infinite; } }
@keyframes seampulse { from { left: -60px; } to { left: 100%; } }
.seam-frame { color: var(--text-secondary); flex-shrink: 0; font-variant-numeric: tabular-nums; }

/* ── work window v3 ── */
.wk-window { background: color-mix(in srgb, var(--accent-ink) 94%, var(--accent)); }
body[data-flood="1"] .wk-window { background: var(--surface-panel); }
.wk-canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.wk-letters { z-index: 1; gap: 2.2vh; }
.wk-letters .wk-row { opacity: 0; }
.wk-row { font-size: 19vh; letter-spacing: 0.05em; color: color-mix(in srgb, var(--accent) 44%, transparent); }
body[data-flood="1"] .wk-row { color: color-mix(in srgb, var(--text-primary) 38%, transparent); }
.wk-front {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 2.2vh;
  z-index: 3; pointer-events: none;
}
.wk-front span { position: static; font-size: inherit; line-height: inherit; opacity: 1; will-change: auto; }
.wk-front .wk-row { color: var(--accent); opacity: 0; }
body[data-flood="1"] .wk-front .wk-row { color: var(--text-primary); }
.wk-front .h { visibility: hidden; }
.wk-fly { pointer-events: none; z-index: 2; }
.wk-card { pointer-events: auto; width: min(34vw, 540px); }
.wk-card figcaption { font-size: 13px; color: var(--accent); letter-spacing: var(--tracking-mono); text-transform: none; }
body[data-flood="1"] .wk-card figcaption { color: var(--text-primary); }
.wk-card img { transition: transform var(--dur-base) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.wk-card:hover img { transform: scale(1.02); border-color: var(--accent); }
.wk-hover {
  position: absolute; left: 0; right: 0; top: calc(100% + 14px);
  background: var(--surface-panel); border: 1px solid var(--accent);
  padding: 14px 16px; font-size: 13px; line-height: 1.55; color: var(--text-primary);
  opacity: 0; transform: translateY(8px); pointer-events: none; z-index: 6;
  transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.wk-card:hover .wk-hover { opacity: 1; transform: none; }
.wk-card.text .wk-tcard {
  aspect-ratio: 460 / 215; border: 1px solid var(--accent);
  background: var(--surface-panel);
  display: flex; flex-direction: column; justify-content: center; gap: 10px;
  padding: 28px;
}
.wk-card.text .t-k { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); }
.wk-card.text h4 { margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800; text-transform: uppercase; font-size: clamp(26px, 2.6vw, 40px); color: var(--text-primary); }
.wk-card.text a { font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); text-decoration: none; border-bottom: 1px solid var(--line); align-self: flex-start; padding-bottom: 2px; }
.wk-card.text a:hover { color: var(--text-primary); border-color: var(--text-primary); }
body.no-pin .wk-letters .wk-row { opacity: 1 !important; }
body.no-pin .wk-front, body.no-pin .wk-canvas { display: none; }

/* ── track record: taller, stretch off the floor ── */
.flat-stage { perspective: 300px; }
.flat-inner { gap: 7vh; transform-origin: 50% 100%; }
.flat-inner .cl.xl { font-size: clamp(90px, 13vw, 215px); line-height: 0.92; }
.flat-inner .cl.md { font-size: clamp(34px, 4vw, 64px); }
.flat-inner .cl.sm { font-size: clamp(13px, 1.2vw, 17px); }

/* ── contact: terminal ping over mechanic canvas ── */
.go-sec { --co-ink: var(--text-secondary); --co-strong: var(--text-primary); }
body[data-flood="2"] .go-sec, body[data-flood="3"] .go-sec {
  --co-ink: color-mix(in srgb, var(--accent-ink) 82%, var(--accent));
  --co-strong: var(--accent-ink);
}
#contact-canvas { position: absolute; inset: 0; width: 100%; height: 100%; }
.term {
  position: relative; z-index: 2;
  width: 250px; height: 64px;
  background: color-mix(in srgb, var(--accent-ink) 94%, var(--accent));
  border: 1px solid var(--line-strong);
  border-radius: var(--radius-2); cursor: pointer; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  transition: width 650ms var(--ease-inout), height 650ms var(--ease-inout), border-color var(--dur-fast) var(--ease-out);
  will-change: width, height;
}
body[data-flood="1"] .term { background: var(--surface-panel); }
.term:hover { border-color: var(--accent); }
.term-chip {
  font-family: var(--font-mono); font-size: 14px; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--accent); white-space: nowrap;
  transition: opacity 200ms var(--ease-out);
  display: inline-flex; gap: 10px; align-items: center;
}
body[data-flood="1"] .term-chip { color: var(--text-primary); }
.t-play, .t-cursor { font-style: normal; }
@media (prefers-reduced-motion: no-preference) { .t-cursor { animation: tblink 1.1s steps(2) infinite; } }
@keyframes tblink { 50% { opacity: 0; } }
.term.open { width: min(880px, 92vw); height: min(540px, 82vh); cursor: default; }
.term.open .term-chip { opacity: 0; }
.term-body {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  opacity: 0; pointer-events: none;
  transition: opacity 320ms var(--ease-out) 260ms;
}
.term.open .term-body { opacity: 1; pointer-events: auto; }
.term-bar {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 18px; border-bottom: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono);
  color: var(--text-secondary);
}
.t-dots { letter-spacing: 4px; color: var(--accent); }
.term-lines {
  flex: 1; display: flex; flex-direction: column; gap: 18px;
  align-items: flex-start; justify-content: center; padding: 32px 44px;
}
.t-line { font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-mono); }
.t-line.dim { color: var(--text-secondary); }
.t-line.ok { color: var(--success); }
.term-lines h2 { margin: 0; font-size: clamp(28px, 4vw, 52px); color: var(--accent); }
body[data-flood="1"] .term-lines h2 { color: var(--text-primary); }
.term-lines .cta { align-self: flex-start; }
@media (prefers-reduced-motion: reduce) {
  .term { width: min(880px, 92vw); height: min(540px, 82vh); }
  .term-chip { display: none; }
  .term-body { opacity: 1; pointer-events: auto; }
}


/* ════ revision 8: seam cubes, spaced TITLES window, taller cards, road fold, contact shockwave ════ */

/* seam: code labels + stepped cube with ghosting */
.seam-label { text-transform: none; letter-spacing: 0.06em; }
.seam-track { height: 12px; background-size: 100% 7px; }
.seam-pulse { width: 9px; height: 9px; top: 1px; left: 0; animation: none; }
@media (prefers-reduced-motion: no-preference) {
  .seam-pulse { animation: seamstep 20.7s steps(46, end) infinite; }
}
.seam-pulse.ghost { opacity: 0.26; }
@keyframes seamstep { from { left: 0; } to { left: calc(100% - 9px); } }

/* work window: quiet hatch + drifting scanline, no borrowed dots */
.wk-window {
  background:
    repeating-linear-gradient(45deg, color-mix(in srgb, var(--accent) 8%, transparent) 0 1px, transparent 1px 110px),
    color-mix(in srgb, var(--accent-ink) 95%, var(--accent));
}
body[data-flood="1"] .wk-window {
  background:
    repeating-linear-gradient(45deg, color-mix(in srgb, var(--slate) 16%, transparent) 0 1px, transparent 1px 110px),
    var(--surface-panel);
}
.wk-window::before {
  content: ""; position: absolute; left: 0; right: 0; height: 18vh; top: -20vh; z-index: 0;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--accent) 7%, transparent), transparent);
}
@media (prefers-reduced-motion: no-preference) { .wk-window::before { animation: wkscan 9s linear infinite; } }
@keyframes wkscan { from { transform: translateY(0); } to { transform: translateY(140vh); } }

/* single spaced TITLES row with motif separators */
.wk-big {
  position: absolute; inset: 0; z-index: 1; padding: 0 5vw;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  font-size: 23vh; line-height: 1; text-transform: uppercase;
  color: color-mix(in srgb, var(--accent) 42%, transparent);
  will-change: transform, opacity;
}
body[data-flood="1"] .wk-big { color: color-mix(in srgb, var(--text-primary) 36%, transparent); }
.wk-big i { font-style: normal; font-family: var(--font-mono); font-size: 3.4vh; color: var(--accent); opacity: 0.75; }
body[data-flood="1"] .wk-big i { color: var(--text-primary); }
.wk-big.front { z-index: 3; pointer-events: none; color: var(--accent); }
body[data-flood="1"] .wk-big.front { color: var(--text-primary); }
.wk-big .h { visibility: hidden; }
body.no-pin .wk-big { position: static; transform: none !important; opacity: 1 !important; font-size: 10vh; }
body.no-pin .wk-big.front { display: none; }

/* taller card panels + explicit hover hint */
.wk-card {
  width: min(30vw, 470px);
  background: var(--surface-panel);
  border: 1px solid var(--line-strong);
  padding: 10px 10px 0;
}
.wk-card img { aspect-ratio: 16 / 10; object-fit: cover; width: 100%; display: block; border: none; }
.wk-card figcaption { padding: 12px 6px 14px; }
.wk-card:not(.text)::after {
  content: "+ details";
  position: absolute; right: 16px; top: 16px; z-index: 2;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--accent-ink);
  background: var(--accent); padding: 4px 8px;
}
.wk-card.text { padding: 10px; }
.wk-card.text .wk-tcard { aspect-ratio: auto; min-height: 34vh; border: 1px dashed var(--accent); }

/* track record: radial road over the fold onto a grid floor */
.flat-stage { perspective: 700px; }
.flat-sun {
  position: absolute; left: 50%; top: 16vh; width: 72px; height: 72px;
  transform: translate(-50%, -50%); color: var(--text-primary); z-index: 2;
}
body[data-flood="2"] .flat-sun, body[data-flood="3"] .flat-sun { color: var(--accent-ink); }
.flat-road { position: absolute; inset: 0; z-index: 1; }
.fl-line {
  position: absolute; left: 50%; top: 0; margin: 0;
  font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; line-height: 0.86; white-space: nowrap;
  font-size: clamp(110px, 16vw, 280px);
  transform-origin: 50% 100%; will-change: transform, opacity;
  color: var(--text-primary); opacity: 0;
}
.fl-line .adot { color: var(--accent); }
.fl-sm { font-family: var(--font-mono); font-weight: 500; font-size: clamp(14px, 1.4vw, 20px); letter-spacing: var(--tracking-caps); line-height: 1.4; }
body[data-flood="2"] .fl-line, body[data-flood="3"] .fl-line { color: var(--accent-ink); }
body[data-flood="2"] .fl-line .adot, body[data-flood="3"] .fl-line .adot { color: var(--accent-ink); }
.flat-floor {
  position: absolute; left: -30%; right: -30%; top: 74vh; height: 70vh; z-index: 0;
  transform-origin: 50% 0; transform: rotateX(56deg);
  color: var(--line-strong);
  background-image:
    linear-gradient(color-mix(in srgb, currentColor 60%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, currentColor 60%, transparent) 1px, transparent 1px);
  background-size: 96px 96px;
}
body.no-pin .fl-line { position: static; transform: none !important; opacity: 1 !important; font-size: clamp(40px, 7vw, 110px); }
body.no-pin .flat-floor, body.no-pin .flat-sun { display: none; }


/* ════ revision 9: snake seams, stacked TITLES, sharp frame, fold-only crawl, sonar contact ════ */

/* seam snake: segments follow each other tick by tick */
.seam-pulse { animation-duration: 13.8s; }
@media (prefers-reduced-motion: no-preference) {
  .seam-pulse { animation: seamstep 13.8s steps(46, end) infinite; }
}

/* work window: sharp edges, outline frame, quiet horizontal tracks, no scanline */
.wk-window {
  background-image: repeating-linear-gradient(180deg, color-mix(in srgb, var(--accent) 10%, transparent) 0 1px, transparent 1px 16vh);
  background-color: color-mix(in srgb, var(--accent-ink) 95%, var(--accent));
}
body[data-flood="1"] .wk-window {
  background-image: repeating-linear-gradient(180deg, color-mix(in srgb, var(--slate) 22%, transparent) 0 1px, transparent 1px 16vh);
  background-color: var(--surface-panel);
}
.wk-window::before { content: none; }
.wk-frame {
  position: absolute; z-index: 4; pointer-events: none;
  border: 1px solid var(--accent);
  inset: 28% 30%;
  transition: opacity 240ms var(--ease-out);
}
body[data-flood="1"] .wk-frame { border-color: var(--line-strong); }
.wk-bigs { position: absolute; inset: 0; z-index: 1; }
.wk-bigs .wk-big { will-change: transform, opacity; }

/* bigger cards, tighter cadence */
.wk-card { width: min(38vw, 600px); }
.wk-card img { aspect-ratio: 16 / 9; }

/* track record: one block, only the flex point moves */
.flat-stage { perspective: 900px; }
.flat-sun { display: none; }
.flat-inner {
  position: absolute; left: 50%; top: 13vh; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 1.2vh;
  width: max-content; padding: 0;
}
.fl-line {
  position: relative; left: auto; top: auto; opacity: 1;
  transform-origin: 50% 100%;
  font-size: clamp(80px, 12vw, 200px);
}
.fl-sm { font-size: clamp(13px, 1.3vw, 19px); }
.flat-floor { top: 78vh; }
body.no-pin .fl-line { transform: none !important; }

/* contact: full-section canvas */
.go-sec { min-height: 100vh; }

/* no-pin fallbacks for the work window */
body.no-pin .wk-bigs, body.no-pin .wk-big.front, body.no-pin .wk-frame { display: none; }
body.no-pin .wk-window { clip-path: none !important; }
body.no-pin .wk-card { position: relative; left: auto; top: auto; transform: none !important; opacity: 1 !important; margin: 16px auto; }


/* ════ revision 10: tick-aligned snake, top-entry titles, road crawl v3 ════ */

/* seam snake: JS-driven, aligned to the 14px tick grid */
.seam-pulse { animation: none !important; transition: left 150ms var(--ease-out); left: 0; width: 9px; }

/* track record road */
.flat-inner { position: absolute; inset: 0; transform: none; display: block; padding: 0; }
.fl-line {
  position: absolute; left: 50%; top: 0; opacity: 0;
  transform-origin: 50% 100%;
  font-size: clamp(80px, 11.5vw, 185px); line-height: 0.9; white-space: nowrap;
  will-change: transform, opacity;
}
.fl-sm { font-size: clamp(13px, 1.3vw, 19px); }
.flat-dot {
  position: absolute; left: 50%; top: 18vh; width: 20px; height: 20px;
  transform: translate(-50%, -50%); border: 2px solid var(--text-primary);
  border-radius: 50%; z-index: 1;
}
.flat-dot::after {
  content: ""; position: absolute; inset: 5px; border-radius: 50%;
  background: var(--accent);
}
body[data-flood="2"] .flat-dot, body[data-flood="3"] .flat-dot { border-color: var(--accent-ink); }
body[data-flood="2"] .flat-dot::after, body[data-flood="3"] .flat-dot::after { background: var(--accent-ink); }
body.no-pin .flat-dot { display: none; }
body.no-pin .fl-line { position: relative; left: auto; opacity: 1 !important; }


/* rev10.1: no-overlap road — smaller cap */
.fl-line { font-size: clamp(64px, 9.5vw, 148px); }


/* ════ revision 11: stable seams, aligned window grid, rope cards, centered road ════ */

/* seam: fixed label width — no more layout shove when text swaps */
.seam-label { width: 232px; flex: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.seam-pulse { transition: left 330ms var(--ease-inout); }

/* window grid = outer grid (160x110), same origin → lines align */
.wk-window {
  background-image:
    linear-gradient(color-mix(in srgb, var(--accent) 18%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--accent) 18%, transparent) 1px, transparent 1px);
  background-size: 160px 110px;
  background-position: 0 0;
}
body[data-flood="1"] .wk-window {
  background-image:
    linear-gradient(color-mix(in srgb, var(--slate) 30%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--slate) 30%, transparent) 1px, transparent 1px);
  background-size: 160px 110px;
}

/* road: container was max-content — lines sat off-screen left */
.flat-inner { width: auto; }


/* ════ revision 12: seam styles, h-lines window, stronger rope, contiguous road ════ */
.seam-label { width: 180px; }
.seam-frame { width: 150px; text-align: right; flex: none; }
.seam-eat { position: absolute; top: 0; bottom: 0; left: 0; width: 0; }
.seam-track[data-seam="s1"] .seam-eat { display: none; }
.seam-track[data-seam="s2"] .seam-pulse, .seam-track[data-seam="s3"] .seam-pulse { display: none; }
.seam-track[data-seam="s2"] .seam-pulse.head {
  display: block; width: 13px; height: 13px; top: 0; border-radius: 50%;
  opacity: 1 !important; background: var(--hot);
}
.seam-track[data-seam="s2"] .seam-pulse.head.mouth { clip-path: polygon(0 0, 100% 0, 100% 35%, 35% 50%, 100% 65%, 100% 100%, 0 100%); }
.seam-track[data-seam="s2"] .seam-eat { display: block; background: var(--surface-page); }
.seam-track[data-seam="s3"] .seam-eat { display: block; background: var(--accent); height: 5px; top: auto; bottom: 0; transition: width 440ms linear; }

/* window: horizontal tracks only, aligned to the outer 110px rows */
.wk-window, body[data-flood="1"] .wk-window {
  background-image: linear-gradient(color-mix(in srgb, var(--accent) 18%, transparent) 1px, transparent 1px);
  background-size: 160px 110px;
}
body[data-flood="1"] .wk-window {
  background-image: linear-gradient(color-mix(in srgb, var(--slate) 30%, transparent) 1px, transparent 1px);
}


/* ════ revision 13: flow/commits/bar seams, glitch letters, benchmark track record ════ */

/* s1 FLOW: dots glide start→end in smooth cascade (firefox-loader motion, linear) */
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s1"] .seam-pulse {
    animation: seamflow 4.6s cubic-bezier(0.45, 0, 0.55, 1) infinite !important;
    opacity: 0.9 !important; transition: none;
  }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(2) { animation-delay: -0.17s; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(3) { animation-delay: -0.34s; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(4) { animation-delay: -0.51s; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(5) { animation-delay: -0.68s; }
}
@keyframes seamflow { from { left: -10px; } to { left: 100%; } }

/* s2 COMMITS: accent squares land tick by tick, filling the row */
.seam-track[data-seam="s2"] .seam-pulse { display: none !important; }
.seam-track[data-seam="s2"] .seam-eat {
  display: block; top: 0; bottom: 0;
  background: repeating-linear-gradient(90deg, var(--accent) 0 9px, transparent 9px 14px);
}

/* s3 BAR: ascii-block compile bar with blinking caret at the fill edge */
.seam-track[data-seam="s3"] .seam-eat {
  display: block; height: 8px; top: 2px; bottom: auto;
  background: repeating-linear-gradient(90deg, var(--accent) 0 5px, color-mix(in srgb, var(--accent) 35%, transparent) 5px 7px);
  border-right: 9px solid var(--hot);
  transition: width 460ms linear;
}
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s3"] .seam-eat { animation: caretblink 1s steps(2) infinite; }
}
@keyframes caretblink { 50% { border-right-color: transparent; } }

/* benchmark track record */
.flat-stage, body[data-flood="2"] .flat-stage, body[data-flood="3"] .flat-stage { background-image: none; perspective: none; }
.bm-bars { position: absolute; left: 0; right: 0; bottom: 0; height: 56vh; display: flex; align-items: flex-end; gap: 3px; padding: 0 24px; }
.bm-bars i { flex: 1; background: var(--slate); opacity: 0.35; height: 4%; }
.bm-bars i.hot { background: var(--accent); opacity: 0.9; }
.bm-bars i.hot.ok { background: var(--success); }
body[data-flood="2"] .bm-bars i, body[data-flood="3"] .bm-bars i { background: var(--accent-ink); opacity: 0.3; }
body[data-flood="2"] .bm-bars i.hot, body[data-flood="3"] .bm-bars i.hot { opacity: 0.95; background: var(--hot); }
body[data-flood="2"] .bm-bars i.hot.ok, body[data-flood="3"] .bm-bars i.hot.ok { background: var(--success); }
.bm-budget { position: absolute; left: 0; right: 0; bottom: 38vh; border-top: 1px dashed var(--line-strong); }
.bm-budget span { position: absolute; right: 24px; top: 6px; font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.bm-stat { position: absolute; left: 50%; top: 24vh; transform: translateX(-50%); text-align: center; display: flex; flex-direction: column; gap: 2vh; align-items: center; opacity: 0; will-change: transform, opacity; }
.bm-num { font-family: var(--font-display); font-stretch: 125%; font-weight: 800; font-size: clamp(140px, 21vw, 330px); line-height: 0.9; color: var(--text-primary); }
.bm-label { font-family: var(--font-mono); font-size: clamp(13px, 1.3vw, 18px); letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.bm-pass { font-family: var(--font-mono); font-size: 13px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--success); border: 1px solid var(--success); background: var(--success-soft); padding: 6px 12px; opacity: 0; transform: rotate(-4deg); transition: opacity 240ms var(--ease-out); }
.bm-caption { position: absolute; left: 50%; transform: translateX(-50%); bottom: 4vh; margin: 0; font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); white-space: nowrap; }
body[data-flood="2"] .bm-num, body[data-flood="3"] .bm-num { color: var(--accent-ink); }
body[data-flood="2"] .bm-label, body[data-flood="3"] .bm-label,
body[data-flood="2"] .bm-caption, body[data-flood="3"] .bm-caption { color: color-mix(in srgb, var(--accent-ink) 75%, var(--accent)); }
body.no-pin .bm-stat { position: relative; left: auto; top: auto; transform: none !important; opacity: 1 !important; margin: 48px auto; }
body.no-pin .bm-bars, body.no-pin .bm-budget { display: none; }


/* ════ revision 14: cascade flow, fading commits, scanner bar, typewriter, wbg picker ════ */

/* s1 FLOW: real cascade — wide stagger + hard easing so dots chase each other */
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s1"] .seam-pulse {
    animation: seamflow 5.4s cubic-bezier(0.8, 0, 0.2, 1) infinite !important;
  }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(2) { animation-delay: -0.42s !important; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(3) { animation-delay: -0.84s !important; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(4) { animation-delay: -1.26s !important; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(5) { animation-delay: -1.68s !important; }
}

/* s2 COMMITS: a square lands on the current tick and fades into history */
.seam-track[data-seam="s2"] .seam-eat { display: none; }
.seam-drop {
  position: absolute; width: 9px; height: 9px; top: 1px;
  background: var(--accent);
  animation: seamfade 2.4s linear forwards;
}
@keyframes seamfade { to { opacity: 0; } }

/* s3 SCANNER: soft accent sweep, back and forth */
.seam-track[data-seam="s3"] .seam-eat {
  display: block; width: 64px !important; height: 8px; top: 2px; bottom: auto;
  border-right: none; transition: none;
  background: linear-gradient(90deg, transparent, var(--accent));
}
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s3"] .seam-eat { animation: seamscan 3.2s ease-in-out infinite alternate; }
}
@keyframes seamscan { from { left: 0; } to { left: calc(100% - 64px); } }

/* typewriter letters: instant snap to/from the clip edge */
.wk-big span, .wk-big i { transition: transform 130ms var(--ease-out); }

/* window background patterns (picked in customizer) */
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image: radial-gradient(9px 2px at 50% 50%, color-mix(in srgb, var(--accent) 38%, transparent) 99%, transparent);
  background-size: 46px 72px;
}
body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image: radial-gradient(9px 2px at 50% 50%, color-mix(in srgb, var(--slate) 55%, transparent) 99%, transparent);
}
#wk-window[data-wbg="w3"], body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image: radial-gradient(2.2px 2.2px at 50% 50%, color-mix(in srgb, var(--accent) 40%, transparent) 99%, transparent);
  background-size: 52px 52px;
}
body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image: radial-gradient(2.2px 2.2px at 50% 50%, color-mix(in srgb, var(--slate) 58%, transparent) 99%, transparent);
}

/* benchmark: status line; caption gone */
.bm-status {
  position: absolute; left: 24px; top: 96px;
  font-family: var(--font-mono); font-size: 13px; letter-spacing: var(--tracking-mono);
  color: var(--text-secondary);
}
.bm-status.done { color: var(--success); }
body[data-flood="2"] .bm-status, body[data-flood="3"] .bm-status { color: color-mix(in srgb, var(--accent-ink) 75%, var(--accent)); }
body[data-flood="2"] .bm-status.done, body[data-flood="3"] .bm-status.done { color: var(--accent-ink); }
body.no-pin .bm-status { position: static; display: block; padding: 24px; }


/* ════ revision 15: seam polish + new styles, thin patterns, drop-through letters, typed log ════ */

/* flow: slower, blends in and out at the ends */
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s1"] .seam-pulse {
    animation: seamflow 7s cubic-bezier(0.8, 0, 0.2, 1) infinite !important;
  }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(2) { animation-delay: -0.55s !important; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(3) { animation-delay: -1.1s !important; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(4) { animation-delay: -1.65s !important; }
  .seam-track[data-seam="s1"] .seam-pulse:nth-child(5) { animation-delay: -2.2s !important; }
}
@keyframes seamflow {
  0% { left: -10px; opacity: 0; }
  12% { opacity: 0.9; }
  88% { opacity: 0.9; }
  100% { left: 100%; opacity: 0; }
}

/* commits: faster, and they blend in at the front like they fade at the back */
.seam-drop { animation: seamfade 1.8s linear forwards; }
@keyframes seamfade { 0% { opacity: 0; } 14% { opacity: 1; } 100% { opacity: 0; } }

/* scanner: full cycle with flipping tail, squashed at ends, stretched mid-flight */
.seam-track[data-seam="s3"] .seam-eat { animation: seamscan2 6.4s ease-in-out infinite; transform-origin: 50% 50%; }
@keyframes seamscan2 {
  0%   { left: 0; transform: scaleX(0.4); }
  14%  { transform: scaleX(1.3); }
  42%  { transform: scaleX(1.3); }
  50%  { left: calc(100% - 64px); transform: scaleX(0.4); }
  64%  { transform: scaleX(-1.3); }
  92%  { transform: scaleX(-1.3); }
  100% { left: 0; transform: scaleX(-0.4); }
}

/* s4 GLYPHS: dim mono bitstream drifting left */
.seam-glyphs {
  display: none; position: absolute; inset: 0; overflow: hidden; white-space: nowrap;
  font-family: var(--font-mono); font-size: 9px; line-height: 12px;
  letter-spacing: 0.3em; color: var(--accent); opacity: 0.85;
}
.seam-glyphs i { font-style: normal; display: inline-block; }
.seam-track[data-seam="s4"] .seam-glyphs { display: block; }
.seam-track[data-seam="s4"] .seam-pulse, .seam-track[data-seam="s4"] .seam-eat { display: none !important; }
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s4"] .seam-glyphs i { animation: seamdrift 16s linear infinite; }
}
@keyframes seamdrift { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* s5 PING: sonar blips on random ticks */
.seam-track[data-seam="s5"] .seam-pulse, .seam-track[data-seam="s5"] .seam-eat { display: none !important; }
.seam-ping {
  position: absolute; top: 50%; width: 14px; height: 14px; margin: -7px 0 0 -7px;
  border: 1px solid var(--accent); border-radius: 50%;
  animation: seamping 1.6s var(--ease-out) forwards;
}
.seam-ping::after { content: ""; position: absolute; inset: 4.5px; background: var(--accent); border-radius: 50%; }
@keyframes seamping { 0% { transform: scale(0.3); opacity: 1; } 100% { transform: scale(1.9); opacity: 0; } }

/* window patterns: dashes thinner + sparser; w3 = plus marks (two-layer cross) */
#wk-window[data-wbg="w2"] {
  background-image: radial-gradient(6px 1.1px at 50% 50%, color-mix(in srgb, var(--accent) 34%, transparent) 99%, transparent);
  background-size: 72px 96px;
}
body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image: radial-gradient(6px 1.1px at 50% 50%, color-mix(in srgb, var(--slate) 50%, transparent) 99%, transparent);
  background-size: 72px 96px;
}
#wk-window[data-wbg="w3"] {
  background-image:
    radial-gradient(5px 1.1px at 50% 50%, color-mix(in srgb, var(--accent) 38%, transparent) 99%, transparent),
    radial-gradient(1.1px 5px at 50% 50%, color-mix(in srgb, var(--accent) 38%, transparent) 99%, transparent);
  background-size: 72px 72px;
}
body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image:
    radial-gradient(5px 1.1px at 50% 50%, color-mix(in srgb, var(--slate) 55%, transparent) 99%, transparent),
    radial-gradient(1.1px 5px at 50% 50%, color-mix(in srgb, var(--slate) 55%, transparent) 99%, transparent);
  background-size: 72px 72px;
}

/* benchmark typed log */
.bm-log {
  position: absolute; left: 24px; top: 96px;
  display: flex; flex-direction: column; gap: 7px;
  font-family: var(--font-mono); font-size: 13px; letter-spacing: var(--tracking-mono);
  color: var(--text-secondary);
}
.bm-log .ln { min-height: 16px; }
.bm-log .ln.done { color: var(--success); }
@media (prefers-reduced-motion: no-preference) {
  .bm-log .ln.typing::after { content: "▍"; animation: tblink 1s steps(2) infinite; }
}
body[data-flood="2"] .bm-log, body[data-flood="3"] .bm-log { color: color-mix(in srgb, var(--accent-ink) 75%, var(--accent)); }
body[data-flood="2"] .bm-log .ln.done, body[data-flood="3"] .bm-log .ln.done { color: var(--accent-ink); }
body.no-pin .bm-log { position: static; padding: 24px; }


/* ════ revision 16: softer flow, corner/ruler patterns, linux log ════ */

/* flow: softer ink */
.seam-track[data-seam="s1"] .seam-pulse { background: color-mix(in srgb, var(--accent) 62%, transparent); }
@keyframes seamflow {
  0% { left: -10px; opacity: 0; }
  12% { opacity: 0.65; }
  88% { opacity: 0.65; }
  100% { left: 100%; opacity: 0; }
}

/* w2 CORNERS: blueprint registration L-marks at each cell corner */
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(8px 1.2px at 8px 1px, color-mix(in srgb, var(--accent) 38%, transparent) 99%, transparent),
    radial-gradient(1.2px 8px at 1px 8px, color-mix(in srgb, var(--accent) 38%, transparent) 99%, transparent);
  background-size: 110px 110px;
}
body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(8px 1.2px at 8px 1px, color-mix(in srgb, var(--slate) 55%, transparent) 99%, transparent),
    radial-gradient(1.2px 8px at 1px 8px, color-mix(in srgb, var(--slate) 55%, transparent) 99%, transparent);
}

/* w3 RULER: rows of fine vertical ticks */
#wk-window[data-wbg="w3"], body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image: radial-gradient(1.1px 5px at 50% 50%, color-mix(in srgb, var(--accent) 36%, transparent) 99%, transparent);
  background-size: 34px 110px;
}
body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image: radial-gradient(1.1px 5px at 50% 50%, color-mix(in srgb, var(--slate) 52%, transparent) 99%, transparent);
}


/* ════ revision 17: spinner/blink/pulse seams, 5 new window patterns, synced benchmark ════ */

/* s4 SPIN: braille terminal spinner */
.seam-spin {
  display: none; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  font-family: var(--font-mono); font-size: 13px; font-style: normal; color: var(--accent);
}
.seam-track[data-seam="s4"] .seam-spin { display: block; }
.seam-track[data-seam="s4"] .seam-glyphs { display: none; }
.seam-track[data-seam="s4"] .seam-pulse, .seam-track[data-seam="s4"] .seam-eat { display: none !important; }

/* s5 BLINK: terminal ellipsis — three dots light up in turn */
.seam-track[data-seam="s5"] .seam-pulse {
  display: block !important; width: 9px; height: 9px; top: 1px;
  background: var(--accent); opacity: 0.15 !important;
}
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s5"] .seam-pulse { animation: seamblink 1.5s steps(1) infinite !important; }
}
.seam-track[data-seam="s5"] .seam-pulse:nth-child(1) { left: calc(50% - 30px) !important; animation-delay: 0s !important; }
.seam-track[data-seam="s5"] .seam-pulse:nth-child(2) { left: calc(50% - 9px) !important; animation-delay: 0.25s !important; }
.seam-track[data-seam="s5"] .seam-pulse:nth-child(3) { left: calc(50% + 12px) !important; animation-delay: 0.5s !important; }
.seam-track[data-seam="s5"] .seam-pulse:nth-child(n+4) { display: none !important; }
.seam-track[data-seam="s5"] .seam-eat, .seam-track[data-seam="s5"] .seam-glyphs { display: none !important; }
@keyframes seamblink { 0% { opacity: 0.15; } 20% { opacity: 1; } 75% { opacity: 1; } 76% { opacity: 0.15; } }

/* s6 PULSE: ECG trace sweeping the seam */
.seam-track[data-seam="s6"] .seam-pulse, .seam-track[data-seam="s6"] .seam-glyphs { display: none !important; }
.seam-track[data-seam="s6"] .seam-eat {
  display: block; width: 100% !important; top: 0; bottom: 0; height: auto;
  border: none; opacity: 0.85; transition: none;
  background: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='12'><polyline points='0,6 58,6 68,1.5 78,10.5 88,6 160,6' fill='none' stroke='%238A93A5' stroke-opacity='0.9' stroke-width='1.4'/></svg>") repeat-x 0 50% / 160px 12px;
}
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s6"] .seam-eat { animation: seamecg 5.5s linear infinite; }
}
@keyframes seamecg { from { background-position: 0 50%; } to { background-position: -160px 50%; } }

/* ── window patterns v3 — move only with scroll ── */
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(10px 1.6px at 30px 40px, color-mix(in srgb, var(--accent) 34%, transparent) 99%, transparent),
    radial-gradient(14px 1.6px at 120px 130px, color-mix(in srgb, var(--accent) 30%, transparent) 99%, transparent),
    radial-gradient(8px 1.6px at 220px 80px, color-mix(in srgb, var(--accent) 36%, transparent) 99%, transparent),
    radial-gradient(12px 1.6px at 70px 205px, color-mix(in srgb, var(--accent) 28%, transparent) 99%, transparent),
    radial-gradient(9px 1.6px at 190px 175px, color-mix(in srgb, var(--accent) 32%, transparent) 99%, transparent);
  background-size: 280px 260px;
}
body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(10px 1.6px at 30px 40px, color-mix(in srgb, var(--slate) 50%, transparent) 99%, transparent),
    radial-gradient(14px 1.6px at 120px 130px, color-mix(in srgb, var(--slate) 44%, transparent) 99%, transparent),
    radial-gradient(8px 1.6px at 220px 80px, color-mix(in srgb, var(--slate) 52%, transparent) 99%, transparent),
    radial-gradient(12px 1.6px at 70px 205px, color-mix(in srgb, var(--slate) 42%, transparent) 99%, transparent),
    radial-gradient(9px 1.6px at 190px 175px, color-mix(in srgb, var(--slate) 47%, transparent) 99%, transparent);
  background-size: 280px 260px;
}
#wk-window[data-wbg="w3"], body[data-flood="1"] #wk-window[data-wbg="w3"] { background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='110'><g fill='%238A93A5' fill-opacity='0.32'><rect x='6' y='48' width='3' height='14'/><rect x='16' y='40' width='3' height='30'/><rect x='26' y='52' width='3' height='8'/><rect x='36' y='34' width='3' height='42'/><rect x='46' y='46' width='3' height='18'/><rect x='56' y='51' width='3' height='10'/><rect x='66' y='42' width='3' height='26'/><rect x='76' y='49' width='3' height='12'/><rect x='86' y='38' width='3' height='34'/><rect x='96' y='50' width='3' height='11'/><rect x='106' y='44' width='3' height='22'/><rect x='116' y='52' width='3' height='8'/><rect x='126' y='36' width='3' height='38'/><rect x='136' y='47' width='3' height='16'/><rect x='146' y='51' width='3' height='9'/></g></svg>"); background-size: 160px 110px; }
#wk-window[data-wbg="w4"], body[data-flood="1"] #wk-window[data-wbg="w4"] { background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='220' height='160'><g stroke='%238A93A5' stroke-opacity='0.30' fill='none' stroke-width='1'><path d='M10 30 H80 V90 H150'/><path d='M40 140 V100 H120'/><path d='M180 20 V70 H210'/></g><g fill='%238A93A5' fill-opacity='0.45'><rect x='77' y='27' width='6' height='6'/><rect x='147' y='87' width='6' height='6'/><rect x='117' y='97' width='6' height='6'/><rect x='177' y='17' width='6' height='6'/></g></svg>"); background-size: 220px 160px; }
#wk-window[data-wbg="w5"], body[data-flood="1"] #wk-window[data-wbg="w5"] { background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='180'><g fill='%238A93A5' fill-opacity='0.35' font-family='monospace' font-size='12'><text x='20' y='40'>{ }</text><text x='150' y='80'>&lt;/&gt;</text><text x='60' y='130'>;</text><text x='190' y='150'>=&gt;</text><text x='110' y='30'>::</text></g></svg>"); background-size: 240px 180px; }
#wk-window[data-wbg="w6"], body[data-flood="1"] #wk-window[data-wbg="w6"] {
  background-image: linear-gradient(180deg, color-mix(in srgb, var(--accent) 6%, transparent) 0 55px, transparent 55px 110px);
  background-size: 100% 110px;
}
body[data-flood="1"] #wk-window[data-wbg="w6"] {
  background-image: linear-gradient(180deg, color-mix(in srgb, var(--slate) 12%, transparent) 0 55px, transparent 55px 110px);
}

/* benchmark: axis scaffold visible before any data */
.bm-bars {
  border-bottom: 1px solid var(--line-strong);
  background-image: radial-gradient(1px 4px at 50% calc(100% - 2px), var(--line-strong) 99%, transparent);
  background-size: 55px 100%;
}


/* ════ revision 18: accent ECG, quiet window patterns, benchmark activation ════ */

/* pulse: accent-colored via mask, longer non-repetitive trace */
.seam-track[data-seam="s6"] .seam-eat {
  background: var(--accent); opacity: 0.8;
  -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='340' height='12'><polyline points='0,6 40,6 50,2 58,10 66,6 120,6 128,4 134,8 140,6 210,6 222,1 232,11 240,6 340,6' fill='none' stroke='white' stroke-width='1.4'/></svg>") repeat-x 0 50% / 340px 12px;
  mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='340' height='12'><polyline points='0,6 40,6 50,2 58,10 66,6 120,6 128,4 134,8 140,6 210,6 222,1 232,11 240,6 340,6' fill='none' stroke='white' stroke-width='1.4'/></svg>") repeat-x 0 50% / 340px 12px;
}
@media (prefers-reduced-motion: no-preference) {
  .seam-track[data-seam="s6"] .seam-eat { animation: seamecg2 7s linear infinite; }
}
@keyframes seamecg2 {
  from { -webkit-mask-position: 0 50%; mask-position: 0 50%; }
  to { -webkit-mask-position: -340px 50%; mask-position: -340px 50%; }
}

/* w2 SPANS: a few faint profiler spans, sparse, scroll-driven */
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(26px 1px at 70px 90px, color-mix(in srgb, var(--accent) 22%, transparent) 99%, transparent),
    radial-gradient(42px 1px at 300px 240px, color-mix(in srgb, var(--accent) 18%, transparent) 99%, transparent),
    radial-gradient(18px 1px at 190px 350px, color-mix(in srgb, var(--accent) 20%, transparent) 99%, transparent);
  background-size: 440px 400px;
}
body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(26px 1px at 70px 90px, color-mix(in srgb, var(--slate) 36%, transparent) 99%, transparent),
    radial-gradient(42px 1px at 300px 240px, color-mix(in srgb, var(--slate) 30%, transparent) 99%, transparent),
    radial-gradient(18px 1px at 190px 350px, color-mix(in srgb, var(--slate) 33%, transparent) 99%, transparent);
  background-size: 440px 400px;
}

/* w3 SCOPE: one quiet viewfinder cross, nothing tiled */
#wk-window[data-wbg="w3"], body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image:
    linear-gradient(90deg, transparent calc(50% - 0.5px), color-mix(in srgb, var(--accent) 14%, transparent) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
    linear-gradient(180deg, transparent calc(50% - 0.5px), color-mix(in srgb, var(--accent) 14%, transparent) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px));
  background-size: 100% 100%;
}
body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image:
    linear-gradient(90deg, transparent calc(50% - 0.5px), color-mix(in srgb, var(--slate) 26%, transparent) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px)),
    linear-gradient(180deg, transparent calc(50% - 0.5px), color-mix(in srgb, var(--slate) 26%, transparent) calc(50% - 0.5px) calc(50% + 0.5px), transparent calc(50% + 0.5px));
}

/* w4 DEPTH: plain vignette, edges fall away */
#wk-window[data-wbg="w4"], body[data-flood="1"] #wk-window[data-wbg="w4"] {
  background-image: radial-gradient(130% 130% at 50% 50%, transparent 55%, rgba(0, 0, 0, 0.30) 100%);
  background-size: 100% 100%;
}

/* benchmark: calibration scrubber sweeps the axis until data starts */
.bm-scrub {
  position: absolute; bottom: 0; width: 1px; height: 56vh; left: 3%;
  background: var(--line-strong); opacity: 0; transition: opacity 400ms var(--ease-out);
}
@media (prefers-reduced-motion: no-preference) {
  .bm-scrub.on { opacity: 1; animation: bmscrub 3.2s ease-in-out infinite alternate; }
}
@keyframes bmscrub { from { left: 3%; } to { left: 97%; } }


/* ════ revision 19: varied pulse, endpoint-flip scan, dim commits, build/cursor seams,
       packet-lane window, idle benchmark ════ */

/* commits: quieter */
.seam-drop { width: 7px; height: 7px; top: 2px; }
@keyframes seamfade { 0% { opacity: 0; } 14% { opacity: 0.55; } 100% { opacity: 0; } }

/* scan: tail flips only at the endpoints, while fully compressed */
@keyframes seamscan2 {
  0%    { left: 0; transform: scaleX(0.08); }
  10%   { transform: scaleX(1.25); }
  42%   { transform: scaleX(1.25); }
  50%   { left: calc(100% - 64px); transform: scaleX(0.06); }
  50.5% { left: calc(100% - 64px); transform: scaleX(-0.06); }
  60%   { transform: scaleX(-1.25); }
  92%   { transform: scaleX(-1.25); }
  100%  { left: 0; transform: scaleX(-0.08); }
}

/* pulse: longer, varied beats */
.seam-track[data-seam="s6"] .seam-eat {
  -webkit-mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='560' height='12'><polyline points='0,6 50,6 60,2.5 68,9.5 76,6 150,6 158,4.5 164,7.5 170,6 260,6 270,0.5 282,11.5 292,6 380,6 388,4 394,8 400,6 470,6 480,2 490,10 500,6 560,6' fill='none' stroke='white' stroke-width='1.4'/></svg>") repeat-x 0 50% / 560px 12px;
  mask: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='560' height='12'><polyline points='0,6 50,6 60,2.5 68,9.5 76,6 150,6 158,4.5 164,7.5 170,6 260,6 270,0.5 282,11.5 292,6 380,6 388,4 394,8 400,6 470,6 480,2 490,10 500,6 560,6' fill='none' stroke='white' stroke-width='1.4'/></svg>") repeat-x 0 50% / 560px 12px;
}
@keyframes seamecg2 {
  from { -webkit-mask-position: 0 50%; mask-position: 0 50%; }
  to { -webkit-mask-position: -560px 50%; mask-position: -560px 50%; }
}

/* s7 BUILD: stages fill one by one, current stage blinking */
.seam-build { display: none; position: absolute; top: 2px; width: 8px; height: 8px; background: var(--accent); opacity: 0.16; }
.seam-track[data-seam="s7"] .seam-build { display: block; }
.seam-track[data-seam="s7"] .seam-pulse, .seam-track[data-seam="s7"] .seam-eat, .seam-track[data-seam="s7"] .seam-glyphs { display: none !important; }
.seam-build.fill { opacity: 0.8; }
@media (prefers-reduced-motion: no-preference) {
  .seam-build.cur { animation: seamblink2 0.6s steps(2) infinite; }
}
@keyframes seamblink2 { 50% { opacity: 0.8; } }

/* s8 CURSOR: a caret types its way across, leaving a thin line */
.seam-cursor { display: none; position: absolute; top: 1px; width: 7px; height: 10px; background: var(--accent); transition: left 240ms var(--ease-out); }
.seam-track[data-seam="s8"] .seam-cursor { display: block; }
.seam-track[data-seam="s8"] .seam-pulse, .seam-track[data-seam="s8"] .seam-glyphs { display: none !important; }
.seam-track[data-seam="s8"] .seam-eat {
  display: block; height: 1px; top: 50%; bottom: auto; border: none;
  background: color-mix(in srgb, var(--accent) 45%, transparent);
  transition: width 240ms var(--ease-out);
}
@media (prefers-reduced-motion: no-preference) {
  .seam-cursor { animation: seamblink2 0.9s steps(2) infinite; }
}

/* w2 PACKETS: profiler lanes — dashes of varied width in distinct tracks */
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(22px 1.4px at 60px 55px, color-mix(in srgb, var(--accent) 26%, transparent) 99%, transparent),
    radial-gradient(34px 1.4px at 260px 55px, color-mix(in srgb, var(--accent) 20%, transparent) 99%, transparent),
    radial-gradient(16px 1.4px at 170px 120px, color-mix(in srgb, var(--accent) 24%, transparent) 99%, transparent),
    radial-gradient(40px 1.4px at 380px 120px, color-mix(in srgb, var(--accent) 18%, transparent) 99%, transparent),
    radial-gradient(28px 1.4px at 100px 185px, color-mix(in srgb, var(--accent) 22%, transparent) 99%, transparent),
    radial-gradient(18px 1.4px at 330px 250px, color-mix(in srgb, var(--accent) 25%, transparent) 99%, transparent),
    radial-gradient(30px 1.4px at 210px 315px, color-mix(in srgb, var(--accent) 19%, transparent) 99%, transparent);
  background-size: 460px 370px;
}
body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image:
    radial-gradient(22px 1.4px at 60px 55px, color-mix(in srgb, var(--slate) 42%, transparent) 99%, transparent),
    radial-gradient(34px 1.4px at 260px 55px, color-mix(in srgb, var(--slate) 33%, transparent) 99%, transparent),
    radial-gradient(16px 1.4px at 170px 120px, color-mix(in srgb, var(--slate) 38%, transparent) 99%, transparent),
    radial-gradient(40px 1.4px at 380px 120px, color-mix(in srgb, var(--slate) 30%, transparent) 99%, transparent),
    radial-gradient(28px 1.4px at 100px 185px, color-mix(in srgb, var(--slate) 36%, transparent) 99%, transparent),
    radial-gradient(18px 1.4px at 330px 250px, color-mix(in srgb, var(--slate) 40%, transparent) 99%, transparent),
    radial-gradient(30px 1.4px at 210px 315px, color-mix(in srgb, var(--slate) 32%, transparent) 99%, transparent);
  background-size: 460px 370px;
}

/* w3 TRACE: one meandering frame-time line, scroll-driven */
#wk-window[data-wbg="w3"], body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='900' height='200'><polyline points='0,120 60,118 90,60 120,130 180,110 260,115 300,40 340,140 420,120 520,118 560,80 600,125 700,115 780,50 820,130 900,120' fill='none' stroke='%238A93A5' stroke-opacity='0.28' stroke-width='1.2'/></svg>");
  background-size: 900px 200px;
  background-repeat: repeat-x;
}

/* w4 BUDGET: two dashed threshold lines */
#wk-window[data-wbg="w4"], body[data-flood="1"] #wk-window[data-wbg="w4"] {
  background-image:
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--accent) 22%, transparent) 0 8px, transparent 8px 22px),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--accent) 14%, transparent) 0 8px, transparent 8px 22px);
  background-size: 100% 1px, 100% 1px;
  background-position: 0 34%, 0 67%;
  background-repeat: no-repeat;
}
body[data-flood="1"] #wk-window[data-wbg="w4"] {
  background-image:
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--slate) 38%, transparent) 0 8px, transparent 8px 22px),
    repeating-linear-gradient(90deg, color-mix(in srgb, var(--slate) 26%, transparent) 0 8px, transparent 8px 22px);
}


/* ════ revision 20: per-style seam backgrounds, crisp packets, signal wave, moving budget ════ */

/* seam track background adapts to the loader style */
.seam-track[data-seam="s3"], .seam-track[data-seam="s6"] {
  background-image: linear-gradient(var(--line-strong), var(--line-strong));
  background-size: 100% 1px; background-position: 0 50%; background-repeat: no-repeat;
}
.seam-track[data-seam="s7"], .seam-track[data-seam="s8"] { background-image: none; }
/* build: empty rack slots that come online */
.seam-track[data-seam="s7"] .seam-build {
  background: transparent; opacity: 0.7;
  border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent);
}
.seam-track[data-seam="s7"] .seam-build.fill { background: var(--accent); border-color: var(--accent); opacity: 0.85; }
.seam-track[data-seam="s7"] .seam-build.cur { border-color: var(--accent); }

/* w2 PACKETS: crisp rect dashes in lanes, drawn from scratch */
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] {
  background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='460' height='370'><g fill='%238A93A5' fill-opacity='0.30'><rect x='36' y='50' width='28' height='2'/><rect x='250' y='50' width='44' height='2'/><rect x='150' y='114' width='18' height='2'/><rect x='360' y='114' width='34' height='2'/><rect x='80' y='178' width='38' height='2'/><rect x='300' y='178' width='22' height='2'/><rect x='10' y='242' width='20' height='2'/><rect x='190' y='242' width='30' height='2'/><rect x='120' y='306' width='24' height='2'/><rect x='330' y='306' width='40' height='2'/></g></svg>");
  background-size: 460px 370px;
}

/* w3 SIGNAL: digital square wave */
#wk-window[data-wbg="w3"], body[data-flood="1"] #wk-window[data-wbg="w3"] {
  background-image: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='720' height='160'><polyline points='0,100 60,100 60,60 140,60 140,100 220,100 220,60 260,60 260,100 380,100 380,60 460,60 460,100 540,100 540,60 600,60 600,100 720,100' fill='none' stroke='%238A93A5' stroke-opacity='0.30' stroke-width='1.4'/></svg>");
  background-size: 720px 160px;
  background-repeat: repeat-x;
}


/* ════ revision 21: canvas packet lanes, wrapping budget ════ */
.wk-bgcanvas { display: none; position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
#wk-window[data-wbg="w2"] .wk-bgcanvas { display: block; }
#wk-window[data-wbg="w2"], body[data-flood="1"] #wk-window[data-wbg="w2"] { background-image: none; }
/* budget: tile horizontally so the lines wrap instead of scrolling away */
#wk-window[data-wbg="w4"], body[data-flood="1"] #wk-window[data-wbg="w4"] {
  background-repeat: repeat-x, repeat-x;
  background-size: 660px 1px, 660px 1px;
}


/* ════ revision 23: posts section (services/reports removed), packets locked ════ */
.post-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 36px; }
.post {
  background: var(--surface-panel); border: 1px solid var(--line-strong);
  padding: 28px; min-height: 260px;
  display: flex; flex-direction: column; gap: 14px;
  transition: background var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
  cursor: pointer;
}
.post:hover { background: var(--surface-raise); border-color: var(--accent); }
body[data-flood="3"] .post:hover { border-color: var(--text-primary); }
.p-idx { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--accent); }
body[data-flood="3"] .p-idx { color: var(--text-primary); }
.post h3 {
  margin: 0; font-family: var(--font-display); font-stretch: 125%; font-weight: 800;
  text-transform: uppercase; font-size: clamp(20px, 1.9vw, 30px); line-height: 1.05;
  color: var(--text-secondary); font-style: italic;
}
.post p { margin: 0; font-size: var(--text-sm); line-height: 1.6; color: var(--text-secondary); flex: 1; font-style: italic; }
.p-meta { font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); color: var(--text-secondary); }
.p-link { font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-primary); display: inline-flex; gap: 8px; }
.p-link i { font-style: normal; transition: transform var(--dur-fast) var(--ease-out); }
.post:hover .p-link i { transform: translateX(4px); }
@media (max-width: 980px) { .post-grid { grid-template-columns: 1fr; } }


/* ════ revision 24: text pass — skills panels, real posts, wider seam labels ════ */
.seam-label { width: 330px; }
.wk-hover p { margin: 0 0 10px; }
.wk-skills { border-top: 1px solid var(--line); padding-top: 10px; display: flex; flex-wrap: wrap; gap: 6px; }
.wk-skills b { width: 100%; font-family: var(--font-mono); font-weight: 500; font-size: 9px; letter-spacing: var(--tracking-caps); text-transform: uppercase; color: var(--text-secondary); }
.wk-skills span { font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono); color: var(--text-secondary); border: 1px solid var(--line); border-radius: 999px; padding: 3px 9px; }
.wk-card.text::after {
  content: "+ details"; position: absolute; right: 16px; top: 16px; z-index: 2;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-caps);
  text-transform: uppercase; color: var(--accent-ink); background: var(--accent); padding: 4px 8px;
}
.post h3 { color: var(--text-primary); font-style: normal; }
.post p { font-style: normal; }
a.p-link { text-decoration: none; align-self: flex-start; }


/* ════ revision 25: about typewriter + langbars + off-clock + hero headline picker ════ */
.tw.typing::after { content: "▍"; color: var(--accent); margin-left: 1px; animation: twcar 0.8s steps(2) infinite; }
@keyframes twcar { 50% { opacity: 0; } }

.langbars { display: flex; flex-wrap: wrap; gap: 24px; margin-top: 14px; }
.lb { display: flex; align-items: center; gap: 10px; font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-mono); color: var(--text-secondary); }
.lb-k { width: 22px; color: var(--text-primary); }
.lb-track { width: 124px; height: 6px; background: var(--panel); border: 1px solid var(--line); position: relative; overflow: hidden; }
.lb-track i { position: absolute; inset: 0 auto 0 0; background: var(--accent); display: block; }
.lb-v { color: var(--text-secondary); }

.offclock-toggle { display: inline-block; margin-top: 28px; background: none; border: 1px solid var(--line); color: var(--text-secondary); font-family: var(--font-mono); font-size: 12px; letter-spacing: var(--tracking-mono); padding: 8px 14px; cursor: pointer; transition: color 0.2s, border-color 0.2s; }
.offclock-toggle:hover { color: var(--accent); border-color: var(--accent); }
.offclock { display: flex; flex-direction: column; gap: 7px; margin-top: 14px; font-family: var(--font-mono); font-size: 13px; color: var(--text-secondary); letter-spacing: var(--tracking-mono); }
.offclock[hidden] { display: none; }
.oc-line { opacity: 0; transform: translateY(6px); animation: ocIn 0.5s var(--ease-out) forwards; }
.offclock .oc-line:nth-child(2) { animation-delay: 0.08s; }
@keyframes ocIn { to { opacity: 1; transform: none; } }
.now-game { color: var(--accent); transition: opacity 0.18s ease; }

.hero-opts { display: flex; flex-direction: column; gap: 5px; }
.hero-opt { text-align: left; background: var(--panel); border: 1px solid var(--line); color: var(--text-secondary); font-family: var(--font-mono); font-size: 10px; letter-spacing: var(--tracking-mono); padding: 6px 9px; line-height: 1.3; cursor: pointer; transition: color 0.15s, border-color 0.15s; }
.hero-opt:hover { color: var(--text-primary); border-color: var(--line-strong); }
.hero-opt.sel { border-color: var(--accent); color: var(--accent); }
@media (prefers-reduced-motion: reduce) { .tw.typing::after { display: none; } .now-game { transition: none; } }


/* ════ revision 26: clear language chips + off-clock console window + game wall ════ */
.langs { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 16px; }
.lang { display: flex; align-items: baseline; gap: 10px; border: 1px solid var(--line); padding: 8px 14px; }
.lang b { font-family: var(--font-mono); font-weight: 600; font-size: 13px; color: var(--text-primary); letter-spacing: var(--tracking-mono); }
.lang-lvl { font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); }
.lang-cef { font-family: var(--font-mono); font-size: 10px; color: var(--accent); border: 1px solid var(--line); padding: 1px 6px; letter-spacing: var(--tracking-caps); }

.oc-win { margin-top: 16px; border: 1px solid var(--line-strong); background: var(--panel); max-width: 580px; font-family: var(--font-mono); box-shadow: var(--shadow-card, 0 18px 40px -24px rgba(0,0,0,0.6)); }
.oc-win[hidden] { display: none; }
.oc-bar { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-bottom: 1px solid var(--line); }
.oc-dots { display: flex; gap: 5px; }
.oc-dots i { width: 9px; height: 9px; border-radius: 50%; background: var(--line-strong); display: block; }
.oc-dots i:first-child { background: var(--accent); }
.oc-title { font-size: 11px; color: var(--text-secondary); letter-spacing: var(--tracking-mono); }
.oc-body { padding: 14px 16px; display: flex; flex-direction: column; gap: 8px; }
.oc-body .oc-line { font-size: 13px; color: var(--text-primary); letter-spacing: var(--tracking-mono); opacity: 0; transform: translateY(6px); animation: ocIn 0.45s var(--ease-out) forwards; }
.oc-body .oc-line.dim { color: var(--text-secondary); }
.oc-body .oc-line:nth-child(2) { animation-delay: 0.05s; }
.oc-body .oc-line:nth-child(3) { animation-delay: 0.1s; }
.oc-body .oc-line:nth-child(4) { animation-delay: 0.15s; }
.oc-line b { color: var(--accent); font-weight: 500; margin-right: 6px; }
.oc-games { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; opacity: 0; transform: translateY(6px); animation: ocIn 0.45s var(--ease-out) 0.2s forwards; }
.oc-game { font-size: 12px; color: var(--text-secondary); border: 1px solid var(--line); padding: 4px 10px; letter-spacing: var(--tracking-mono); transition: opacity 0.35s ease, color 0.35s ease, border-color 0.35s ease; }
.oc-game.swap { opacity: 0; transform: translateY(-3px); }
@media (prefers-reduced-motion: reduce) { .oc-game { transition: none; } .oc-body .oc-line, .oc-games { animation: none; opacity: 1; transform: none; } }


/* ════ revision 28: language cover-wipe gated on typewriter + pinned current game ════ */
/* reserve the language-row height from the start so revealing it never pushes the awards below.
   space is held via visibility (keeps layout); the cover-wipe still plays on reveal. */
.langs { display: flex; visibility: hidden; }
.langs.revealed { visibility: visible; }
.lang { position: relative; overflow: hidden; }
.lang-cover { position: absolute; inset: 0; background: var(--text-primary); transform: scaleX(1); transform-origin: right; transition: transform 0.55s var(--ease-out); z-index: 3; }
.langs.revealed .lang-cover { transform: scaleX(0); }
.langs.revealed .lang:nth-child(2) .lang-cover { transition-delay: 0.08s; }
.langs.revealed .lang:nth-child(3) .lang-cover { transition-delay: 0.16s; }
.offclock-toggle { transition: opacity 0.4s var(--ease-out), transform 0.4s var(--ease-out), color 0.2s, border-color 0.2s; }
.offclock-toggle.pt-hide { opacity: 0; transform: translateY(6px); pointer-events: none; }
.oc-game.cur { color: var(--accent); border-color: var(--accent); }
@media (prefers-reduced-motion: reduce) { .lang-cover { display: none; } .offclock-toggle.pt-hide { opacity: 1; transform: none; } }


/* ════ revision 29: image cards for Aduto + Locazi, 3-shot Android gallery ════ */
.wk-card.gallery .wk-gallery { position: absolute; inset: 0; display: flex; gap: 2px; background: var(--graphite, #0c0f14); }
.wk-card.gallery .wk-gallery img { flex: 1; min-width: 0; height: 100%; object-fit: cover; object-position: center top; }
.wk-card.gallery:hover .wk-gallery { filter: brightness(0.4); }
@media (prefers-reduced-motion: reduce) { .wk-card.gallery:hover .wk-gallery { transition: none; } }


/* ════ revision 30: in-view trailer cards ════ */
.wk-vid { position: relative; display: block; width: 100%; aspect-ratio: 16 / 9; background: #06080b; overflow: hidden; }
.wk-poster { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; transition: opacity 0.4s ease; }
.wk-play { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); width: 52px; height: 52px; border: 1px solid rgba(255,255,255,0.75); border-radius: 50%; display: grid; place-items: center; transition: opacity 0.4s ease, background 0.2s ease; pointer-events: none; }
.wk-play::after { content: ""; border-left: 12px solid rgba(255,255,255,0.92); border-top: 8px solid transparent; border-bottom: 8px solid transparent; margin-left: 3px; }
.wk-vmount { position: absolute; inset: 0; pointer-events: none; }
.wk-vmount iframe { width: 100%; height: 100%; border: 0; display: block; }
.wk-card.playing .wk-poster, .wk-card.playing .wk-play { opacity: 0; }
.wk-hlink { display: inline-block; margin: 0 0 12px; font-family: var(--font-mono); font-size: 11px; letter-spacing: var(--tracking-mono); color: var(--accent); text-decoration: none; }
.wk-hlink:hover { text-decoration: underline; }
@media (prefers-reduced-motion: reduce) { .wk-poster, .wk-play { transition: none; } }


/* ════ revision 32: <video> trailer mounts + click-to-YouTube ════ */
.wk-mp4 { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.4s ease; }
.wk-card.playing .wk-mp4 { opacity: 1; }
.wk-vlink { position: absolute; inset: 0; z-index: 2; display: block; }
.wk-vid:hover .wk-play { background: rgba(0,0,0,0.35); }
@media (prefers-reduced-motion: reduce) { .wk-mp4 { transition: none; } }


/* ════════════════════════════════════════════════════════════════════
   v1-FIXED PASS — detail-panel clamp, light-mode hardening, benchmark,
   and full mobile responsive. Appended last so it wins on equal specificity.
   ════════════════════════════════════════════════════════════════════ */

/* ── FIX 1: work detail panel never leaves the viewport ── */
.wk-card.flip-up .wk-hover { top: auto; bottom: calc(100% + 14px); }
.wk-card.tap-open .wk-hover { opacity: 1 !important; pointer-events: auto; }
/* tablet (pinned, no hover): show the detail in place */
@media (hover: none) and (min-width: 761px) { .wk-card.tap-open .wk-hover { transform: none !important; } }
/* flip-to-back reveal for tapped detail (mobile + tablet) */
@keyframes wkflip {
  from { opacity: 0; transform: translate(-50%, -50%) perspective(900px) rotateY(82deg); }
  to   { opacity: 1; transform: translate(-50%, -50%) perspective(900px) rotateY(0deg); }
}
/* in-place card flip (mobile): the detail is the back face, turned over where the card sits */
@keyframes wkflip2 {
  from { opacity: 0; transform: perspective(900px) rotateY(88deg); }
  to   { opacity: 1; transform: perspective(900px) rotateY(0deg); }
}
.wk-hover { max-width: min(92vw, 560px); max-height: 76vh; overflow-y: auto; overscroll-behavior: contain; }

/* ── FIX 2: light-mode hardening (paper engineering report) ── */
html[data-theme="light"] .cz,
html[data-theme="light"] .meter-chip,
html[data-theme="light"] .oc-win,
html[data-theme="light"] .wk-hover,
html[data-theme="light"] .post { border-color: var(--line-strong); }
html[data-theme="light"] .topbar { border-bottom-color: var(--line-strong); }
html[data-theme="light"] .wk-skills span,
html[data-theme="light"] .lang { border-color: var(--line-strong); }
html[data-theme="light"] .scroll-hint { color: var(--text-primary); opacity: .6; }
html[data-theme="light"] .cz-toggle { border-color: var(--line-strong); }

/* ── FIX 6: mobile responsive pass (≤760 collapses pinned scroll-rooms) ── */
body.no-pin { overflow-x: hidden; }
body.no-pin .wk-stage { position: static; height: auto; overflow: visible; display: block; padding: 56px 18px; background-image: none; }
body.no-pin .wk-window { position: static; height: auto; clip-path: none !important; background-image: none !important; }
body.no-pin .wk-bgcanvas, body.no-pin .wk-frame, body.no-pin .wk-bigs { display: none !important; }
body.no-pin .wk-fly { position: static; display: flex; flex-direction: column; gap: 26px; }
body.no-pin .wk-card { position: relative !important; left: auto !important; top: auto !important; transform: none !important; opacity: 1 !important; width: 100%; max-width: 560px; margin: 0 auto; }
body.no-pin .wk-card .wk-hover { position: static; opacity: 1; transform: none; margin: 12px 0 0; max-height: none; border: 1px solid var(--line-strong); }
body.no-pin .wk-card.flip-up .wk-hover { bottom: auto; }

body.no-pin .flat-pin { height: auto; }
body.no-pin .flat-stage { position: static; height: auto; overflow: visible; display: block; padding: 64px 22px; perspective: none; background-image: none; }
body.no-pin .flat-stage .flat-inner { transform: none !important; }
body.no-pin .bm-bars, body.no-pin .bm-log { display: none !important; }
body.no-pin .bm-stat { position: static; transform: none !important; opacity: 1 !important; text-align: center; margin: 0 auto 30px; max-width: 540px; display: flex; flex-direction: column; gap: 8px; }
body.no-pin .bm-pass { opacity: 1 !important; }

@media (max-width: 760px) {
  .topbar .in { padding: 12px 16px; gap: 12px; }
  .topbar nav { gap: 13px; }
  .topbar nav a { font-size: 10px; }
  .topbar .right .nav-meter { display: none; }
  .wm { font-size: 17px; }

  .hero { height: calc(100svh - 54px); min-height: 460px; }
  .hero-type { left: 16px; right: 16px; bottom: 20px; }
  .hero-type h1 { font-size: clamp(34px, 11vw, 60px); }

  .sec.col, #about, #posts { padding-left: 18px; padding-right: 18px; }
  .lede-big { font-size: clamp(17px, 4.6vw, 22px); }
  .about-term { max-width: 100%; }
  .awards-grid { grid-template-columns: 1fr; }
  .oc-win { max-width: 100%; }
  .langs { gap: 8px; }

  .post-grid { grid-template-columns: 1fr; }

  .go-sec { min-height: 88svh; padding: 8vh 16px; margin-top: 70px; }

  .footer-grid { grid-template-columns: 1fr; gap: 10px; }

  .cz { width: min(92vw, 340px); max-height: 68vh; overflow-y: auto; left: 12px; right: auto; bottom: 60px; }
  .cz-toggle { bottom: 12px; left: 12px; }
  .meter-chip { right: 12px; bottom: 12px; }

  .byteline { height: 64px; }
}

@media (max-width: 430px) {
  .topbar nav { gap: 10px; }
  .topbar nav a { font-size: 9px; letter-spacing: .12em; }
  .hero-type h1 { font-size: clamp(30px, 12vw, 52px); }
}

@media (hover: none) and (min-width: 761px) {
  .wk-card .wk-play { opacity: 1; }
}

/* ── mobile, scroll-choreography KEPT (work + benchmark stay pinned, sized for portrait) ── */
@media (max-width: 760px) {
  /* WORK window: one card reads at a time; shrink the giant TITLES word + separators to fit */
  .wk-card { width: min(80vw, 420px) !important; }
  .wk-card img { aspect-ratio: 16 / 10; }
  .wk-card figcaption { font-size: 12px; padding: 10px 6px 12px; }
  .wk-big { font-size: 12.5vw !important; padding: 0 6vw !important; }
  .wk-big i { font-size: 2.4vh !important; }
  /* shrink the window background pattern hard so it never swamps the small pre-entry rectangle */
  .wk-window, body[data-flood="1"] .wk-window { background-size: 34px 26vh !important; background-position: 0 5vh !important; }
  /* taps open the detail panel — kill the YouTube link overlay that was stealing taps */
  .wk-card .wk-vlink { display: none !important; }
  .wk-card { cursor: pointer; }
  /* mobile: two states only — front (thumb/video) ↔ back (details), toggled by tapping the whole card.
     keep the "+ details" hint badge from desktop; neutralize sticky touch-:hover so no stray
     popover ever appears under the card (that was the "second panel" bug). */
  .wk-card .wk-hover {
    position: absolute; inset: 0; top: 0; z-index: 5; margin: 0;
    width: auto; max-width: none; max-height: 100%; overflow-y: auto;
    opacity: 0; pointer-events: none; transition: none;
    box-shadow: 0 24px 60px -28px rgba(0,0,0,0.7);
  }
  .wk-card:hover .wk-hover { opacity: 0; }
  .wk-card.tap-open .wk-hover { opacity: 1 !important; pointer-events: auto; animation: wkflip2 0.44s var(--ease-out) both; }
  .wk-card.tap-open > img, .wk-card.tap-open > .wk-vid, .wk-card.tap-open > figcaption { opacity: 0; transition: opacity 0.18s ease; }
  .wk-card.tap-open::after { opacity: 0; }   /* hide the hint badge while flipped to details */

  /* BENCHMARK: keep the pinned count-up + dwell, scale the number and dock the log/bars */
  .bm-num { font-size: clamp(72px, 30vw, 150px) !important; }
  .bm-label { font-size: 12px !important; padding: 0 16px; max-width: 88vw; }
  .bm-stat { top: 40vh; gap: 2.4vh; }   /* lower on phone so the big number clears the log */
  .bm-pass { font-size: 11px; }
  .bm-log { top: 44px; left: 14px; right: 14px; font-size: 10px; gap: 5px; }
  .bm-bars { height: 34vh; padding: 0 12px; gap: 2px; }
  .bm-budget { bottom: 26vh; }
  .bm-caption { font-size: 9px; bottom: 3vh; padding: 0 16px; }
}
