/* =========================================================================
   CodingFreaks Overlays — showcase site  ·  "BROADCAST RUNDOWN"
   ------------------------------------------------------------------------
   A typography-led, image-led redesign. NO gradients, NO card grid.
   Two flat surfaces alternate for editorial rhythm:
     · PAPER  (#EDEAE2)  warm off-white, the dominant "catalog" surface
     · ON-AIR (#0E0E10)  warm near-black, the live/broadcast moments
   One electric accent (lime #E6EF00). Space Mono carries the "typed into
   chat" vernacular (!commands, indices, tags, meta) — the signature motif.
   Plain CSS, no build step.
   ========================================================================= */

/* ---- Tokens -------------------------------------------------------------- */
:root {
  /* Surfaces (flat, never gradients) */
  --paper:      #edeae2;   /* dominant warm off-white */
  --paper-2:    #e4e0d6;   /* slightly deeper paper for insets */
  --ink:        #0e0e10;   /* on-air near-black, warm */
  --ink-2:      #17171a;   /* raised on dark */

  /* Brand accent + ink text */
  --lime:       #e6ef00;
  --lime-ink:   #5c6200;   /* dark lime: readable as text/graphics on the light paper surface (>=4.5:1) */
  --on-paper:   #16151a;   /* near-black text on paper */
  --on-ink:     #f4f2ea;   /* bone text on dark */
  --muted:      #63615a;   /* warm grey, secondary on paper (>=4.5:1 on paper + paper-2) */
  --muted-ink:  #8d8a82;   /* warm grey, secondary on dark */
  --rule:       #cdc8bb;   /* hairline on paper */
  --rule-ink:   #2a2a2e;   /* hairline on dark */

  /* Type */
  --display: 'Space Grotesk', system-ui, sans-serif;
  --mono:    'Space Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;
  --body:    'Hanken Grotesk', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  /* Fluid type scale */
  --t-hero:   clamp(54px, 12.5vw, 155px);
  --t-xl:     clamp(38px, 7.5vw, 104px);
  --t-l:      clamp(30px, 4.6vw, 58px);
  --t-m:      clamp(22px, 2.8vw, 34px);
  --t-body:   clamp(16px, 1.05vw, 20px);   /* readable copy: 16px floor, 18-20px on 2K+ */
  --t-label:  clamp(16px, 0.9vw, 18px);    /* mono labels/meta/nav/eyebrows: 16px floor */
  --t-mono:   clamp(16px, 0.9vw, 18px);
  --t-tag:    clamp(16px, 0.9vw, 18px);

  --maxw: 1280px;
  --gutter: clamp(20px, 5vw, 72px);
  --accent: var(--lime);   /* per-game override set inline */
}

/* ---- Reset -------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: no-preference) { html { scroll-behavior: smooth; } }
body {
  font-family: var(--body);
  background: var(--paper);
  color: var(--on-paper);
  line-height: 1.6;
  font-size: var(--t-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; background: none; border: 0; }
ul { list-style: none; padding: 0; }
::selection { background: var(--lime); color: var(--ink); }

h1, h2, h3, h4 {
  font-family: var(--display); font-weight: 700;
  line-height: 0.96; letter-spacing: -0.03em;
}

/* keyboard focus, visible everywhere */
/* focus ring is surface-aware: dark on paper, lime on dark, ink on the lime band — each clears 3:1 */
:focus-visible { outline: 3px solid var(--on-paper); outline-offset: 3px; border-radius: 2px; }
.onair :focus-visible, .topbar :focus-visible, .panel.dark :focus-visible, .detail-hero :focus-visible { outline-color: var(--lime); }
.custom-band :focus-visible { outline-color: var(--ink); }

/* skip-to-content link, visible only when focused */
.skip-link { position: absolute; left: -9999px; top: 0; z-index: 200; }
.skip-link:focus { left: var(--gutter); top: 8px; background: var(--lime); color: var(--ink); padding: 10px 16px; font-family: var(--mono); font-weight: 700; font-size: var(--t-label); text-transform: uppercase; }

/* ---- Layout helpers ----------------------------------------------------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.onair { background: var(--ink); color: var(--on-ink); }
.onair h1, .onair h2, .onair h3, .onair h4 { color: var(--on-ink); }

/* the mono "vernacular" label — chat-command typeface, tracked + boxed tick */
.tag {
  font-family: var(--mono); font-size: var(--t-tag); font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted);
  display: inline-flex; align-items: center; gap: 10px;
}
.onair .tag { color: var(--muted-ink); }
.tag::before {
  content: ""; width: 8px; height: 8px; background: var(--lime);
  flex: none; display: inline-block;
}

/* ---- Buttons (flat, sharp, no shadow) ----------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-weight: 700; font-size: var(--t-label);
  letter-spacing: 0.04em; text-transform: uppercase;
  padding: 15px 22px; border: 1.5px solid transparent;
  transition: transform .18s cubic-bezier(.2,.7,.2,1), background .18s, color .18s, border-color .18s;
}
.btn .arr { transition: transform .22s cubic-bezier(.2,.7,.2,1); }
.btn:hover .arr { transform: translateX(5px); }
.btn:active { transform: translateY(1px); }

.btn-fill   { background: var(--lime); color: var(--ink); }
.btn-fill:hover { background: var(--ink); color: var(--lime); }

.btn-ink    { background: var(--ink); color: var(--paper); }
.btn-ink:hover { background: var(--lime); color: var(--ink); }

.btn-line   { background: transparent; color: var(--on-paper); border-color: var(--on-paper); }
.btn-line:hover { background: var(--on-paper); color: var(--paper); }
.onair .btn-line { color: var(--on-ink); border-color: #3a3a40; }
.onair .btn-line:hover { background: var(--on-ink); color: var(--ink); border-color: var(--on-ink); }

/* =========================================================================
   TOP BAR
   ========================================================================= */
.topbar {
  position: sticky; top: 0; z-index: 80;
  background: var(--ink); color: var(--on-ink);
  border-bottom: 1px solid var(--rule-ink);
}
.topbar .wrap { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 20px; }
.brand { display: flex; flex-direction: column; align-items: start; gap: 0; font-family: var(--display); }
.brand .mark { font-size: 19px; font-weight: 700; letter-spacing: -0.02em; color: var(--on-ink); }
.brand .mark b { color: var(--lime); font-weight: 700; }
/* Light wordmark variant (white text) for the dark top bar / footer.
   Use codingfreaks-logo.svg (dark) only on light surfaces. */
.brand-logo { height: 30px; width: auto; display: block; }
.brand .sub {
  font-family: var(--mono); font-size: 13px; font-weight: 700; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--muted-ink);
}
.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a {
  font-family: var(--mono); font-size: var(--t-label); font-weight: 400; letter-spacing: 0.03em;
  text-transform: uppercase; color: var(--on-ink); opacity: 0.74; transition: opacity .18s, color .18s;
}
.nav-links a:hover { opacity: 1; color: var(--lime); }
.nav-right { display: flex; align-items: center; gap: 16px; }
.topbar .btn { padding: 11px 18px; font-size: var(--t-label); }
.nav-toggle { display: none; font-size: 22px; line-height: 1; color: var(--on-ink); width: 40px; height: 40px; }

/* =========================================================================
   HERO  (on-air) — command line + kinetic statement
   ========================================================================= */
.hero { position: relative; overflow: hidden; padding-block: clamp(48px, 9vw, 120px) clamp(40px, 7vw, 84px); }
.hero .wrap { position: relative; z-index: 2; }
.hero-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: clamp(28px, 5vw, 60px); }
.hero-pills { display: flex; flex-wrap: wrap; gap: 8px; }
.hero-pills span {
  font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--on-ink); border: 1px solid var(--rule-ink); padding: 8px 14px;
}
.hero-pills b { color: var(--lime); font-weight: 700; }

.hero h1 {
  font-size: var(--t-hero); text-transform: uppercase; letter-spacing: -0.045em;
  color: var(--on-ink);
}
.hero h1 .line { display: block; overflow: hidden; }
.hero h1 .word { display: inline-block; }
.hero h1 .stroke {
  color: transparent; -webkit-text-stroke: 1.4px var(--muted-ink);
}
.hero h1 em { font-style: normal; color: var(--lime); position: relative; }
.hero-sub {
  font-family: var(--mono); font-size: clamp(16px, 1.7vw, 22px); letter-spacing: 0.01em;
  color: var(--on-ink); margin-top: clamp(20px, 3vw, 34px); max-width: 44ch;
}
.hero-sub b { color: var(--lime); font-weight: 700; }

.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: clamp(26px, 3.4vw, 38px); }

/* live command-line demo */
.cmd {
  margin-top: clamp(34px, 5vw, 56px);
  border: 1px solid var(--rule-ink); max-width: 640px;
  font-family: var(--mono); background: var(--ink-2);
}
.cmd-head {
  display: flex; align-items: center; gap: 10px; padding: 10px 14px;
  border-bottom: 1px solid var(--rule-ink); font-size: var(--t-label); letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--muted-ink);
}
.cmd-head .lights { display: inline-flex; gap: 6px; }
.cmd-head .lights i { width: 9px; height: 9px; border-radius: 50%; background: #34343a; display: inline-block; }
.cmd-head .lights i:first-child { background: var(--lime); }
.cmd-head .who { margin-left: auto; }
.cmd-body { padding: 18px 16px 20px; }
.cmd-line { display: flex; align-items: baseline; gap: 10px; font-size: clamp(16px, 2.2vw, 24px); }
.cmd-line .prompt { color: var(--lime); }
.cmd-line .typed { color: var(--on-ink); white-space: pre; }
.cmd-line .caret { width: 11px; height: 1.1em; background: var(--lime); display: inline-block; transform: translateY(0.12em); animation: caret 1s steps(2,end) infinite; }
@keyframes caret { 50% { opacity: 0; } }
.cmd-out {
  margin-top: 14px; font-size: var(--t-mono); color: var(--muted-ink);
  display: flex; align-items: center; gap: 10px; min-height: 1.3em;
}
.cmd-out .ok { color: var(--lime); }
.cmd-out .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--lime); flex: none; }

/* =========================================================================
   BOTS MARQUEE  (paper, between two rules)
   ========================================================================= */
.ticker { border-block: 1px solid var(--on-paper); padding-block: clamp(16px, 2.4vw, 26px); overflow: hidden; }
.ticker-label {
  font-family: var(--mono); font-size: var(--t-tag); letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--muted); padding-inline: var(--gutter); margin-bottom: 14px;
}
.marquee { display: flex; gap: 0; width: max-content; will-change: transform; }
.marquee-track { display: flex; align-items: center; }
.marquee-track span {
  font-family: var(--display); font-weight: 700; font-size: clamp(26px, 4.6vw, 64px);
  letter-spacing: -0.02em; text-transform: uppercase; color: var(--on-paper);
  white-space: nowrap; padding-inline: clamp(20px, 3vw, 44px);
}
.marquee-track span.muted { color: transparent; -webkit-text-stroke: 1.2px var(--muted); }
.marquee-track .sep { color: var(--lime-ink); -webkit-text-stroke: 0; }

/* =========================================================================
   OFFER  — Fertige vs Custom diptych + Anpassbar facts (no cards)
   ========================================================================= */
.offer { padding-block: clamp(56px, 8vw, 110px); }
.offer-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: clamp(32px, 4vw, 52px); }
.offer-head h2 { font-size: var(--t-xl); text-transform: uppercase; max-width: 16ch; }
.offer-head h2 em { font-style: normal; color: transparent; -webkit-text-stroke: 1.4px var(--on-paper); }
.offer-head p { font-family: var(--mono); font-size: var(--t-label); color: var(--muted); max-width: 34ch; }

.diptych { display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--on-paper); }
.panel { position: relative; padding: clamp(28px, 3.6vw, 52px); min-height: clamp(300px, 38vw, 460px); display: flex; flex-direction: column; }
.panel + .panel { border-left: 1px solid var(--on-paper); }
.panel.dark { background: var(--ink); color: var(--on-ink); }
.panel .pn { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.panel.dark .pn { color: var(--muted-ink); }
.panel h3 { font-size: var(--t-l); text-transform: uppercase; margin-top: 16px; letter-spacing: -0.03em; }
.panel.dark h3 { color: var(--on-ink); }
.panel.dark h3 em { font-style: normal; color: var(--lime); }
.panel .lead { font-family: var(--mono); font-size: var(--t-body); color: var(--muted); margin-top: 14px; max-width: 34ch; }
.panel.dark .lead { color: var(--muted-ink); }
.panel ul { margin-top: auto; padding-top: 28px; display: flex; flex-direction: column; }
.panel li {
  display: flex; align-items: center; gap: 14px; padding: 13px 0;
  border-top: 1px solid var(--rule); font-size: var(--t-body); font-weight: 500;
  transition: padding-left .2s ease, color .2s ease;
}
.panel.dark li { border-color: var(--rule-ink); color: var(--on-ink); }
.panel li::before { content: counter(li,decimal-leading-zero); counter-increment: li; font-family: var(--mono); font-size: var(--t-label); color: var(--lime-ink); flex: none; }
.panel.dark li::before { color: var(--lime); }
.panel ul { counter-reset: li; }
.panel li:hover { padding-left: 8px; }
.panel .pcta { margin-top: 24px; }
.panel .big-num {
  position: absolute; top: clamp(20px,2.5vw,40px); right: clamp(20px,2.5vw,40px);
  font-family: var(--display); font-weight: 700; font-size: clamp(60px, 9vw, 140px);
  line-height: 0.8; color: transparent; -webkit-text-stroke: 1.5px var(--rule); pointer-events: none;
}
.panel.dark .big-num { -webkit-text-stroke-color: var(--rule-ink); }

/* anpassbar facts row */
.facts { display: grid; grid-template-columns: repeat(3, 1fr); border: 1px solid var(--on-paper); border-top: 0; }
.fact { padding: clamp(22px, 2.6vw, 36px); }
.fact + .fact { border-left: 1px solid var(--on-paper); }
.fact .k { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--lime-ink); }
.fact .v { font-family: var(--display); font-weight: 700; font-size: clamp(20px, 2.4vw, 30px); margin-top: 12px; letter-spacing: -0.02em; }
.fact .d { font-family: var(--mono); font-size: var(--t-body); color: var(--muted); margin-top: 8px; }

/* =========================================================================
   GAMES INDEX  — the signature: big rundown rows + cursor-follow preview
   ========================================================================= */
.index { padding-block: clamp(56px, 8vw, 104px); position: relative; }
.index-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: clamp(26px, 3vw, 40px); }
.index-head h2 { font-size: var(--t-xl); text-transform: uppercase; }
.index-head h2 .count { color: var(--muted); -webkit-text-stroke: 0; }

.filters { display: flex; flex-wrap: wrap; gap: 8px; }
.filters .chip {
  font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.04em; text-transform: uppercase;
  padding: 8px 14px; border: 1px solid var(--rule); color: var(--muted); transition: all .16s;
}
.filters .chip:hover { color: var(--on-paper); border-color: var(--on-paper); }
.filters .chip.active { background: var(--on-paper); color: var(--paper); border-color: var(--on-paper); }

/* the list */
.rundown { border-top: 1px solid var(--on-paper); }
.row {
  --accent: var(--lime);
  position: relative; display: grid;
  grid-template-columns: clamp(46px,6vw,84px) 1fr auto clamp(40px,5vw,64px);
  align-items: center; gap: clamp(14px, 2vw, 32px);
  padding: clamp(16px, 2.1vw, 26px) 0;
  border-bottom: 1px solid var(--rule);
  transition: padding-left .28s cubic-bezier(.2,.7,.2,1), background .2s;
}
.row::after { /* lime sweep on hover (consistent contrast; per-game colour lives in dot + preview) */
  content: ""; position: absolute; left: 0; top: 0; bottom: -1px; width: 0;
  background: var(--lime); z-index: -1; transition: width .3s cubic-bezier(.2,.7,.2,1);
}
.row:hover, .row:focus-visible { padding-left: clamp(14px, 2vw, 28px); }
.row:hover::after, .row:focus-visible::after { width: 100%; }
.row:hover .r-num, .row:hover .r-meta, .row:hover .r-arr { color: var(--ink); }
.row:hover .r-name { color: var(--ink); }
.row:hover .r-dot { background: var(--ink); }
.r-num { font-family: var(--mono); font-size: clamp(16px,1.1vw,18px); color: var(--muted); }
.r-name { display: flex; align-items: center; gap: 16px; min-width: 0; }
.r-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--accent); flex: none; transition: background .2s; }
.r-name .nm {
  font-family: var(--display); font-weight: 700; letter-spacing: -0.03em; text-transform: uppercase;
  font-size: clamp(24px, 4.4vw, 56px); line-height: 0.92; color: var(--on-paper);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: color .2s;
}
.r-meta {
  font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.02em; text-transform: uppercase;
  color: var(--muted); text-align: right; transition: color .2s; white-space: nowrap;
  display: flex; gap: 10px; justify-content: flex-end;
}
.r-meta .sep { opacity: 0.4; }
.r-arr { font-family: var(--display); font-size: clamp(22px,2.6vw,32px); color: var(--muted); text-align: right; transition: color .2s, transform .22s; }
.row:hover .r-arr { transform: translateX(4px); }

/* hide tagline meta on smaller screens so big names get full width */
@media (max-width: 900px) {
  .r-meta { display: none; }
  .row { grid-template-columns: 38px 1fr 34px; }
}

/* cursor-follow preview (desktop pointer only) */
.preview {
  position: fixed; top: 0; left: 0; z-index: 60; width: 360px; max-width: 40vw;
  aspect-ratio: 16 / 9; pointer-events: none; opacity: 0;
  transition: opacity .22s ease; will-change: transform; /* JS owns transform (cursor-follow lerp) */
  border: 1px solid var(--ink); overflow: hidden; background: var(--ink);
}
.preview.on { opacity: 1; }
.preview .pv {
  position: absolute; inset: 0; display: none; place-items: center; flex-direction: column; gap: 10px;
  text-align: center;
}
.preview .pv.show { display: grid; }
.preview .pv .pv-title { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(20px,2vw,30px); letter-spacing: -0.02em; color: var(--ink); }
.preview .pv .pv-tag { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.08em; text-transform: uppercase; color: rgba(0,0,0,0.55); }
.preview .pv img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
@media (hover: none) { .preview { display: none; } }

/* =========================================================================
   STEPS  (on-air) — real 3-step sequence
   ========================================================================= */
.steps { padding-block: clamp(56px, 8vw, 104px); }
.steps .wrap > .tag { margin-bottom: clamp(28px,4vw,44px); }
.step-grid { display: grid; grid-template-columns: repeat(3, 1fr); }
.step { padding: clamp(24px,3vw,40px) clamp(20px,2.4vw,36px); border-left: 1px solid var(--rule-ink); }
.step:first-child { border-left: 0; padding-left: 0; }
.step .sn { font-family: var(--mono); font-size: var(--t-label); color: var(--lime); letter-spacing: 0.12em; }
.step h3 { font-size: var(--t-m); text-transform: uppercase; margin-top: 16px; color: var(--on-ink); letter-spacing: -0.02em; }
.step p { font-family: var(--mono); font-size: var(--t-body); color: var(--muted-ink); margin-top: 12px; max-width: 30ch; }
.step code { color: var(--lime); }

/* =========================================================================
   CUSTOM CTA  (paper, lime block)
   ========================================================================= */
.custom { padding-block: clamp(56px, 8vw, 104px); }
.custom-band { background: var(--lime); color: var(--ink); padding: clamp(34px, 5vw, 72px); }
.custom-band .tag { color: rgba(0,0,0,0.55); }
.custom-band .tag::before { background: var(--ink); }
.custom-band h2 { font-size: var(--t-xl); text-transform: uppercase; color: var(--ink); margin-top: 18px; max-width: 16ch; }
.custom-band h2 em { font-style: normal; color: transparent; -webkit-text-stroke: 1.6px var(--ink); }
.custom-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(24px,4vw,56px); align-items: end; }
.custom-list { display: flex; flex-direction: column; }
.custom-list li { display: flex; align-items: center; gap: 14px; padding: 13px 0; border-top: 1px solid rgba(0,0,0,0.18); font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.02em; text-transform: uppercase; }
.custom-list li::before { content: "→"; color: var(--ink); }
.custom-cta { display: flex; flex-direction: column; gap: 14px; }
.custom-cta .note { font-family: var(--mono); font-size: var(--t-label); color: rgba(0,0,0,0.6); }
.custom-band .btn-ink:hover { background: var(--paper); color: var(--ink); }

/* =========================================================================
   SUPPORT  (paper strip)
   ========================================================================= */
.support { padding-block: clamp(48px, 6vw, 84px); border-top: 1px solid var(--rule); }
.support .wrap { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; }
.support h2 { font-size: var(--t-l); text-transform: uppercase; max-width: 18ch; }
.support h2 em { font-style: normal; color: var(--muted); }
.support p { font-family: var(--mono); font-size: var(--t-body); color: var(--muted); margin-top: 14px; max-width: 46ch; }

/* =========================================================================
   FOOTER  (on-air)
   ========================================================================= */
.foot { padding-block: clamp(44px, 5vw, 72px) 28px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; }
.foot .brand .mark { font-size: 24px; }
.foot .brand-logo { height: 46px; }
.foot-grid p { font-family: var(--mono); font-size: var(--t-body); color: var(--muted-ink); margin-top: 16px; max-width: 40ch; line-height: 1.7; }
.foot-col h4 { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-ink); font-weight: 700; margin-bottom: 16px; }
.foot-col a { display: block; font-size: var(--t-body); color: var(--on-ink); opacity: 0.8; padding: 6px 0; transition: opacity .18s, color .18s; }
.foot-col a:hover { opacity: 1; color: var(--lime); }
.foot-bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; margin-top: clamp(36px,5vw,60px); padding-top: 24px; border-top: 1px solid var(--rule-ink); font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.04em; text-transform: uppercase; color: var(--muted-ink); }
.foot-bottom a { color: var(--lime); }

/* =========================================================================
   GAME DETAIL PAGE
   ========================================================================= */
.detail-hero { background: var(--ink); color: var(--on-ink); padding-block: clamp(32px,5vw,64px) clamp(40px,6vw,80px); } /* --accent inherits the per-game value set on #detail-root */
.breadcrumb { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.05em; text-transform: uppercase; color: var(--muted-ink); margin-bottom: clamp(24px,3vw,40px); }
.breadcrumb a:hover { color: var(--lime); }
.breadcrumb .sep { margin: 0 10px; opacity: 0.5; }
.detail-top { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: clamp(28px,4vw,56px); align-items: center;
  --accent-ink: color-mix(in srgb, var(--accent) 68%, var(--on-ink)); } /* lighten per-game accent so it clears 4.5:1 on the dark hero */
.detail-info .d-cat { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent-ink); display: inline-flex; align-items: center; gap: 10px; }
.detail-info .d-cat::before { content: ""; width: 9px; height: 9px; background: var(--accent-ink); }
.detail-info h1 { font-size: var(--t-xl); text-transform: uppercase; margin-top: 18px; color: var(--on-ink); }
.detail-info .tagline { font-family: var(--mono); font-size: clamp(16px,1.7vw,22px); color: var(--accent-ink); margin-top: 18px; max-width: 40ch; }
.detail-info .desc { font-size: var(--t-body); color: var(--muted-ink); margin-top: 18px; max-width: 54ch; line-height: 1.7; }
.detail-meta { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.detail-meta .mp { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.04em; text-transform: uppercase; color: var(--on-ink); border: 1px solid var(--rule-ink); padding: 8px 14px; }
.detail-actions { display: flex; gap: 12px; margin-top: 30px; flex-wrap: wrap; }
.detail-media { border: 1px solid var(--accent-ink); aspect-ratio: 16/9; overflow: hidden; position: relative; background: var(--ink-2); display: grid; place-items: center; }
.detail-media img, .detail-media video { width: 100%; height: 100%; object-fit: cover; }
.detail-media .ph { text-align: center; }
.detail-media .ph .big { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(28px,4vw,52px); letter-spacing: -0.02em; color: var(--accent-ink); }
.detail-media .ph small { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted-ink); display: block; margin-top: 12px; }

/* Hero collage: up to three shots in one 16:9 box. The accent shows through the
   thin gaps as hairline rules, tying it to the per-game accent. */
.detail-media.collage { place-items: stretch; gap: 3px; background: var(--accent-ink); }
.detail-media.collage.cells-1 { grid-template-columns: 1fr; }
.detail-media.collage.cells-2 { grid-template-columns: 1fr 1fr; }
.detail-media.collage.cells-3 { grid-template-columns: 1.66fr 1fr; grid-template-rows: 1fr 1fr; }
.detail-media.collage.cells-3 .cm-cell:first-child { grid-row: 1 / 3; }
.detail-media .cm-cell { position: relative; overflow: hidden; background: var(--ink-2); display: grid; place-items: center; margin: 0; min-width: 0; min-height: 0; }
.detail-media .cm-cell img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.detail-media .cm-cell .ph { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted-ink); }

.detail-body { padding-block: clamp(44px,6vw,80px); }
.detail-grid { display: grid; grid-template-columns: 1fr 320px; gap: clamp(32px,5vw,64px); align-items: start; }
.detail-main > section { margin-bottom: clamp(40px,6vw,68px); }
.block-title { font-family: var(--display); font-size: var(--t-l); text-transform: uppercase; margin-bottom: 6px; }
.block-sub { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); margin-bottom: 28px; }

.feat-list { display: grid; grid-template-columns: 1fr; border-top: 1px solid var(--rule); }
.feat-item { display: flex; gap: 16px; align-items: baseline; padding: 15px 0; border-bottom: 1px solid var(--rule); font-size: var(--t-body); }
.feat-item .fn { font-family: var(--mono); font-size: var(--t-label); color: var(--muted); flex: none; }

.rules { counter-reset: rl; border-top: 1px solid var(--rule); }
.rule-step { display: grid; grid-template-columns: clamp(40px,5vw,64px) 1fr; gap: clamp(16px,2vw,28px); padding: 18px 0; border-bottom: 1px solid var(--rule); align-items: baseline; }
.rule-step .n { font-family: var(--display); font-weight: 700; font-size: clamp(22px,3vw,38px); color: transparent; -webkit-text-stroke: 1.2px color-mix(in srgb, var(--accent) 60%, var(--on-paper)); line-height: 0.9; }
.rule-step .txt { font-size: var(--t-body); color: var(--on-paper); }

.cmd-table { width: 100%; border-collapse: collapse; border-top: 1px solid var(--on-paper); }
.cmd-table th { text-align: left; font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); padding: 14px 14px 14px 0; border-bottom: 1px solid var(--rule); }
.cmd-table td { padding: 16px 14px 16px 0; border-bottom: 1px solid var(--rule); font-size: var(--t-body); color: var(--on-paper); vertical-align: top; }
.cmd-table code { font-family: var(--mono); font-weight: 700; color: var(--on-paper); background: var(--paper-2); padding: 3px 8px; white-space: nowrap; }
.cmd-table .who { font-family: var(--mono); font-size: var(--t-label); text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); white-space: nowrap; }

.gallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px,1fr)); gap: 12px; }
.shot { aspect-ratio: 16/9; border: 1px solid var(--rule); overflow: hidden; background: var(--paper-2); display: grid; place-items: center; }
.shot .ph { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
.shot img { width: 100%; height: 100%; object-fit: cover; }

.detail-aside { position: sticky; top: 84px; display: flex; flex-direction: column; gap: 28px; }
.aside-block h4 { font-family: var(--mono); font-size: var(--t-label); letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; }
.spec-row { display: flex; justify-content: space-between; gap: 12px; padding: 13px 0; border-top: 1px solid var(--rule); font-size: var(--t-body); }
.spec-row:first-of-type { border-top: 0; }
.spec-row .k { font-family: var(--mono); font-size: var(--t-label); text-transform: uppercase; letter-spacing: 0.04em; color: var(--muted); }
.spec-row .v { font-weight: 600; text-align: right; }
.settings-list { display: flex; flex-direction: column; }
.setting { padding: 12px 0; border-top: 1px solid var(--rule); }
.setting:first-child { border-top: 0; }
.setting code { font-family: var(--mono); font-weight: 700; color: var(--on-paper); font-size: var(--t-label); }
.setting p { font-family: var(--mono); font-size: var(--t-body); color: var(--muted); margin-top: 7px; }
.aside-cta { display: block; text-align: center; justify-content: center; }

.related { padding-block: clamp(44px,6vw,80px); border-top: 1px solid var(--rule); }
.related .rundown { border-top: 1px solid var(--on-paper); margin-top: clamp(20px,3vw,36px); }

/* =========================================================================
   REVEAL (fallback when GSAP absent) + reduced motion
   ========================================================================= */
.reveal { opacity: 0; transform: translateY(18px); }
.reveal.in { opacity: 1; transform: none; transition: opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1); }
.no-gsap .reveal { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; }
  .marquee { animation: none !important; transform: none !important; }
  .cmd-line .caret { animation: none; }
  /* neutralise interaction motion (incl. on keyboard focus) but keep the state swap instant */
  .row, .row::after, .r-arr, .btn, .btn .arr, .panel li { transition: none !important; }
  .row:hover, .row:focus-visible { padding-left: 0 !important; }
  .preview { transition: none !important; }
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 1000px) {
  .detail-top { grid-template-columns: 1fr; }
  .detail-grid { grid-template-columns: 1fr; }
  .detail-aside { position: static; flex-direction: row; flex-wrap: wrap; gap: 32px; }
  .detail-aside > * { flex: 1 1 240px; }
}
@media (max-width: 860px) {
  .diptych { grid-template-columns: 1fr; }
  .panel + .panel { border-left: 0; border-top: 1px solid var(--on-paper); }
  .facts { grid-template-columns: 1fr; }
  .fact + .fact { border-left: 0; border-top: 1px solid var(--on-paper); }
  .step-grid { grid-template-columns: 1fr; }
  .step { border-left: 0; border-top: 1px solid var(--rule-ink); padding-left: 0; padding-inline: 0; }
  .step:first-child { border-top: 0; }
  .custom-grid { grid-template-columns: 1fr; }
  .support .wrap { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
/* collapse the inline nav to a menu early — 16px+ mono links need the room */
@media (max-width: 940px) {
  .nav-links { display: none; }
  .nav-toggle { display: grid; place-items: center; }
  .topbar.open .nav-links {
    display: flex; flex-direction: column; align-items: flex-start; gap: 20px;
    position: absolute; top: 76px; left: 0; right: 0; background: var(--ink);
    padding: 26px var(--gutter); border-bottom: 1px solid var(--rule-ink); z-index: 90;
  }
}
@media (max-width: 680px) {
  .foot-grid { grid-template-columns: 1fr; }
  .hero-top { flex-direction: column; align-items: flex-start; }
}

/* =========================================================================
   Contact modal — "GOING LIVE" broadcast panel
   ------------------------------------------------------------------------
   Echoes the hero command-demo: on-air bar + REC light, a self-typing
   !kontakt line, and two channel rows that reuse the catalog lime-sweep.
   Opened by any [data-contact] trigger; pure progressive enhancement.
   ========================================================================= */
.cmodal { position: fixed; inset: 0; z-index: 120; display: grid; place-items: center; padding: clamp(16px, 4vw, 48px); }
.cmodal[hidden] { display: none; }

.cmodal-scrim {
  position: absolute; inset: 0; background: rgba(8, 8, 10, 0.74);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  opacity: 0; transition: opacity .3s ease;
}
.cmodal.in .cmodal-scrim { opacity: 1; }

.cmodal-panel {
  position: relative; width: min(640px, 100%); max-height: calc(100dvh - 32px); overflow: auto;
  background: var(--ink); color: var(--on-ink); border: 1.5px solid var(--lime);
  box-shadow: 0 30px 90px -28px rgba(0, 0, 0, 0.7);
  transform: translateY(28px) scale(.965); opacity: 0;
  transition: transform .44s cubic-bezier(.2, .7, .2, 1), opacity .3s ease;
}
.cmodal.in .cmodal-panel { transform: none; opacity: 1; }
/* lime line that "draws" across the top as the panel lands */
.cmodal-panel::before {
  content: ""; position: absolute; left: 0; top: -1.5px; height: 3px; width: 0;
  background: var(--lime); transition: width .55s cubic-bezier(.2, .7, .2, 1) .14s;
}
.cmodal.in .cmodal-panel::before { width: 100%; }
.cmodal-panel:focus-visible { outline: none; }

/* top bar */
.cmodal-bar {
  display: flex; align-items: center; gap: 12px; padding: 12px 16px;
  border-bottom: 1px solid var(--rule-ink);
}
.cmodal-x { margin-left: auto; font-family: var(--mono); font-weight: 700; font-size: var(--t-label); letter-spacing: .06em; text-transform: uppercase; color: var(--muted-ink); transition: color .18s; }
.cmodal-x:hover { color: var(--lime); }

.cmodal-body { padding: clamp(24px, 3.6vw, 42px); }
.cmodal-body h2 { font-family: var(--display); font-weight: 700; font-size: clamp(34px, 5.4vw, 58px); text-transform: uppercase; color: var(--on-ink); margin-top: 14px; }
.cmodal-body h2 em { font-style: normal; color: var(--lime); }

.cmodal-typed { font-family: var(--mono); font-size: clamp(16px, 2.2vw, 22px); margin-top: 18px; display: flex; align-items: baseline; gap: 10px; }
.cmodal-typed .prompt { color: var(--lime); }
.cmodal-typed .typed { color: var(--on-ink); white-space: pre; }
.cmodal-typed .caret { width: 10px; height: 1.05em; background: var(--lime); display: inline-block; transform: translateY(.12em); animation: caret 1s steps(2, end) infinite; }
.cmodal-sub { font-family: var(--mono); font-size: var(--t-label); color: var(--muted-ink); margin-top: 14px; }

.cmodal-rows { margin-top: clamp(22px, 3vw, 32px); border-top: 1px solid var(--rule-ink); }
.crow {
  --accent: var(--lime);
  position: relative; z-index: 0; display: grid;
  grid-template-columns: 42px clamp(30px, 3.4vw, 40px) 1fr auto auto;
  align-items: center; gap: clamp(12px, 2vw, 22px);
  padding: clamp(16px, 2.1vw, 24px) 0; border-bottom: 1px solid var(--rule-ink);
  opacity: 0; transform: translateY(12px);
  transition: padding-left .28s cubic-bezier(.2, .7, .2, 1);
}
.cmodal.in .crow {
  opacity: 1; transform: none;
  transition: padding-left .28s cubic-bezier(.2, .7, .2, 1),
              opacity .45s ease var(--d, .2s),
              transform .45s cubic-bezier(.2, .7, .2, 1) var(--d, .2s);
}
.crow::after { content: ""; position: absolute; left: 0; top: 0; bottom: -1px; width: 0; background: var(--lime); z-index: -1; transition: width .3s cubic-bezier(.2, .7, .2, 1); }
.crow:hover, .crow:focus-visible { padding-left: clamp(12px, 1.6vw, 20px); }
.crow:hover::after, .crow:focus-visible::after { width: 100%; }
.crow-num { font-family: var(--mono); font-size: clamp(16px, 1.1vw, 18px); color: var(--muted-ink); transition: color .2s; }
.crow-icon { color: var(--accent); display: flex; transition: color .2s, transform .22s cubic-bezier(.2, .7, .2, 1); }
.crow-icon svg { width: 100%; height: auto; }
.crow:hover .crow-icon { transform: translateY(-2px) rotate(-4deg); }
.crow-name { min-width: 0; }
.crow-name .nm { display: block; font-family: var(--display); font-weight: 700; text-transform: uppercase; letter-spacing: -.02em; font-size: clamp(26px, 4.6vw, 42px); line-height: .94; color: var(--on-ink); transition: color .2s; }
.crow-sub { font-family: var(--mono); font-size: clamp(13px, 1.4vw, 15px); color: var(--muted-ink); transition: color .2s; }
.crow-meta { font-family: var(--mono); font-size: var(--t-label); text-transform: uppercase; color: var(--muted-ink); transition: color .2s; white-space: nowrap; }
.crow-arr { font-family: var(--display); font-size: clamp(22px, 2.6vw, 32px); color: var(--muted-ink); transition: color .2s, transform .22s; }
.crow:hover .crow-num, .crow:hover .crow-sub, .crow:hover .crow-meta, .crow:hover .crow-arr, .crow:hover .crow-name .nm, .crow:hover .crow-icon { color: var(--ink); }
.crow:hover .crow-arr { transform: translateX(5px); }

.cmodal-foot { margin-top: clamp(18px, 2.4vw, 28px); font-family: var(--mono); font-size: var(--t-label); color: var(--muted-ink); display: flex; align-items: center; gap: 10px; }
.cmodal-foot .tick { width: 8px; height: 8px; background: var(--lime); flex: none; }

/* trigger nudge: contact buttons get a soft lime pulse to invite the click */
@media (prefers-reduced-motion: no-preference) {
  [data-contact].btn-fill, [data-contact].btn-ink { animation: contact-breathe 3.2s ease-in-out infinite; }
}
@keyframes contact-breathe {
  0%, 100% { box-shadow: 0 0 0 0 rgba(230, 239, 0, 0); }
  50% { box-shadow: 0 0 0 4px rgba(230, 239, 0, .22); }
}

@media (max-width: 560px) {
  .crow { grid-template-columns: 32px clamp(26px, 8vw, 34px) 1fr auto; }
  .crow-meta { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .cmodal-scrim, .cmodal-panel, .cmodal-panel::before, .crow, .crow-icon { transition: none !important; }
  .cmodal-panel { transform: none; opacity: 1; }
  .crow { opacity: 1; transform: none; }
  .cmodal-typed .caret { animation: none; }
}
