/* =========================================================
   Global True Crime — "The Night Desk"
   Dark Scandinavian crime-desk dossier
   ========================================================= */

:root {
  /* --- colour (OKLCH, neutrals tinted toward the brand hue ~250) --- */
  --ink:        oklch(0.165 0.012 255);   /* page background — cold near-black */
  --ink-raise:  oklch(0.205 0.014 255);   /* raised surface */
  --ink-sink:   oklch(0.135 0.012 255);   /* recessed / footer */
  --line:       oklch(0.31 0.012 255);    /* hairlines */
  --line-soft:  oklch(0.25 0.012 255);

  --paper:      oklch(0.94 0.006 258);    /* primary text — cool off-white */
  --paper-dim:  oklch(0.73 0.008 258);    /* secondary */
  --paper-faint:oklch(0.56 0.012 258);    /* meta / tertiary */

  /* police lights — deep red + deep blue */
  --blood:      oklch(0.45 0.16 26);      /* deep red base */
  --blood-lift: oklch(0.60 0.19 27);      /* red for text/links on dark */
  --blue:       oklch(0.45 0.14 258);     /* deep blue base */
  --blue-lift:  oklch(0.65 0.15 258);     /* blue for accents on dark */

  /* --- type --- */
  --display: "Bebas Neue", "Anton", Impact, "Haettenschweiler", sans-serif;
  --sans: "Schibsted Grotesk", system-ui, -apple-system, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", monospace;

  /* --- space (4pt scale) --- */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px; --s-5: 24px;
  --s-6: 32px; --s-7: 48px; --s-8: 64px; --s-9: 96px; --s-10: 128px;

  --maxw: 1240px;
  --radius: 14px;

  /* --- easing (Emil's stronger curves) --- */
  --ease-out: cubic-bezier(0.23, 1, 0.32, 1);
  --ease-in-out: cubic-bezier(0.77, 0, 0.175, 1);
}

* { box-sizing: border-box; margin: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--sans);
  font-size: clamp(1rem, 0.97rem + 0.18vw, 1.075rem);
  line-height: 1.6;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* film grain — fixed, never on a scrolling container */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0.04;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img { display: block; max-width: 100%; height: auto; }

a { color: inherit; text-decoration: none; }

::selection { background: var(--blood); color: oklch(0.96 0.01 85); }

:focus-visible {
  outline: 2px solid var(--blood-lift);
  outline-offset: 3px;
  border-radius: 3px;
}

.skip-link {
  position: absolute;
  left: var(--s-4);
  top: -100px;
  z-index: 10000;
  background: var(--paper);
  color: var(--ink);
  padding: var(--s-2) var(--s-4);
  border-radius: 8px;
  font-weight: 600;
  transition: top 160ms var(--ease-out);
}
.skip-link:focus { top: var(--s-4); }

/* ---------- shared bits ---------- */
.eyebrow,
.kicker {
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper-faint);
}
.kicker { display: inline-flex; align-items: center; gap: var(--s-3); }
.kicker__dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--blood-lift);
  box-shadow: 0 0 0 0 var(--blood-lift);
  animation: pulse 3s var(--ease-in-out) infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 oklch(0.64 0.15 28 / 0.5); }
  50%      { box-shadow: 0 0 0 6px oklch(0.64 0.15 28 / 0); }
}

.meta {
  font-family: var(--mono);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  color: var(--paper-faint);
}
.meta--accent { color: var(--blood-lift); }

.section-title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(2.4rem, 1.5rem + 3.6vw, 4rem);
  line-height: 0.92;
  letter-spacing: 0.015em;
}

/* Bebas Neue ships a single weight — never request bold (avoids ugly faux-bold) */
.hero__title, .section-title, .filenum, .latest__title, .case__num,
.cta__title, .wordmark__mark, .wordmark__full, .hero__stats dd { font-weight: 400; }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-family: var(--sans);
  font-weight: 600;
  font-size: 0.95rem;
  line-height: 1;
  padding: 14px 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 140ms var(--ease-out),
              background-color 200ms var(--ease-out),
              border-color 200ms var(--ease-out),
              color 200ms var(--ease-out);
}
.btn:active { transform: scale(0.97); }
.btn--sm { padding: 9px 16px; font-size: 0.85rem; }
.btn--lg { padding: 17px 28px; font-size: 1rem; }

.btn--primary {
  background: var(--paper);
  color: var(--ink);
}
.btn--primary:hover { background: oklch(0.99 0.012 85); }

.btn--ghost {
  background: transparent;
  color: var(--paper);
  border-color: var(--line);
}
.btn--ghost:hover {
  border-color: var(--paper-dim);
  background: oklch(0.93 0.012 85 / 0.05);
}

.btn__play { width: 12px; height: 13px; }
.btn__arr  { width: 15px; height: 15px; transition: transform 200ms var(--ease-out); }
.btn:hover .btn__arr { transform: translateX(3px); }

/* ---------- nav ---------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: oklch(0.165 0.012 255 / 0.72);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-bottom: 1px solid transparent;
  transition: border-color 300ms var(--ease-out), background-color 300ms var(--ease-out);
}
.nav[data-scrolled] {
  border-bottom-color: var(--line-soft);
  background: oklch(0.155 0.012 255 / 0.88);
}
.nav__inner {
  max-width: var(--maxw);
  margin-inline: auto;
  padding: var(--s-3) var(--s-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-5);
}
.wordmark { display: inline-flex; align-items: baseline; gap: var(--s-3); }
.wordmark__mark {
  font-family: var(--display);
  font-size: 1.35rem;
  letter-spacing: 0.05em;
  color: var(--blood-lift);
}
.wordmark__full {
  font-family: var(--display);
  font-size: 1.3rem;
  letter-spacing: 0.04em;
}
.nav__links { display: flex; gap: var(--s-6); }
.nav__links a {
  font-size: 0.9rem;
  color: var(--paper-dim);
  position: relative;
  transition: color 180ms var(--ease-out);
}
.nav__links a::after {
  content: "";
  position: absolute;
  left: 0; bottom: -5px;
  width: 100%; height: 1px;
  background: var(--blood-lift);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 240ms var(--ease-out);
}
.nav__links a:hover { color: var(--paper); }
.nav__links a:hover::after { transform: scaleX(1); }

/* ---------- hero ---------- */
.hero {
  position: relative;
  isolation: isolate;
  overflow: clip;
  min-height: clamp(600px, 88vh, 880px);
  display: flex;
  align-items: flex-start;
}
/* full-bleed cover artwork — police lights on a broken-glass world map */
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 42%;
}
.hero__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(to right, var(--ink) 0%, oklch(0.165 0.012 255 / 0.5) 44%, oklch(0.165 0.012 255 / 0.12) 76%, transparent 100%),
    linear-gradient(to bottom, oklch(0.165 0.012 255 / 0.35) 0%, transparent 22%, transparent 72%, var(--ink) 100%);
}
.hero__content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  /* nav is sticky/in-flow, so this is the gap below the header */
  padding: 50px var(--s-5) var(--s-9);
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(var(--s-6), 5vw, var(--s-9));
  align-items: start;
}
.hero__tags { display: flex; gap: var(--s-2); margin-bottom: var(--s-6); }
.hero__title { margin: var(--s-4) 0 var(--s-5); }
.hero__logo {
  width: min(440px, 92%);
  height: auto;
  filter: drop-shadow(0 8px 34px oklch(0.06 0.02 258 / 0.75));
}

/* ---------- latest-episode card (right hero column) ---------- */
.ep-card {
  justify-self: end;
  width: 100%;
  max-width: 420px;
  padding: clamp(var(--s-4), 2vw, var(--s-5));
  border-radius: calc(var(--radius) + 6px);
  border: 1px solid var(--line);
  background: oklch(0.135 0.012 255 / 0.72);
  backdrop-filter: blur(16px) saturate(1.1);
  -webkit-backdrop-filter: blur(16px) saturate(1.1);
  box-shadow: 0 30px 70px -30px oklch(0.06 0.02 258 / 0.9);
}
.ep-card__label {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--paper-dim);
  margin-bottom: var(--s-4);
}
.ep-card__art {
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  border-radius: var(--radius);
  overflow: hidden;
  isolation: isolate;
}
.ep-card__art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 500ms var(--ease-out);
}
.ep-card__play {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--paper);
  background: radial-gradient(closest-side, oklch(0.1 0.02 258 / 0.35), transparent);
  opacity: 0.95;
  transition: opacity 200ms var(--ease-out);
}
.ep-card__play svg {
  width: 64px;
  height: 64px;
  padding: 18px;
  border-radius: 50%;
  background: oklch(0.135 0.012 255 / 0.72);
  border: 1px solid oklch(0.95 0.01 258 / 0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  transition: transform 200ms var(--ease-out), background-color 200ms var(--ease-out);
}
@media (hover: hover) {
  .ep-card__art:hover img { transform: scale(1.04); }
  .ep-card__art:hover .ep-card__play svg { transform: scale(1.08); background: var(--blood); }
}
.ep-card__info { margin: var(--s-4) 0; }
.ep-card__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-3);
}
.ep-card__num {
  font-family: var(--display);
  font-size: 1.3rem;
  letter-spacing: 0.03em;
  color: var(--blood-lift);
}
.ep-card__title {
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.5rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.ep-card__sub {
  font-family: var(--mono);
  font-size: 0.74rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--paper-faint);
  margin-top: var(--s-2);
}
.ep-card__platforms {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s-3);
  padding-top: var(--s-4);
  border-top: 1px solid var(--line-soft);
}
.ep-card__on {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--paper-faint);
}
.ep-card__platforms a {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--paper);
  transition: color 160ms var(--ease-out);
}
.ep-card__platforms a:hover { color: var(--blood-lift); }
.hero__lede {
  max-width: 46ch;
  color: var(--paper-dim);
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.25rem);
  line-height: 1.62;
}
.hero__lineage {
  margin-top: var(--s-4);
  color: var(--paper-faint);
  font-size: 0.95rem;
}
.hero__lineage em { font-style: italic; }

.hero__actions {
  margin-top: var(--s-7);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
}

.hero__stats {
  margin-top: var(--s-8);
  padding-top: var(--s-5);
  border-top: 1px solid var(--line-soft);
  display: flex;
  gap: clamp(var(--s-6), 5vw, var(--s-8));
}
.hero__stats dt {
  font-family: var(--mono);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--paper-faint);
  margin-bottom: var(--s-2);
}
.hero__stats dd {
  font-family: var(--display);
  font-weight: 600;
  font-size: 1.5rem;
}
.hero__stats dd span { color: var(--blood-lift); }

.tag {
  font-family: var(--sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  padding: 6px 11px;
  border-radius: 999px;
  background: oklch(0.135 0.012 255 / 0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--line);
  color: var(--paper);
}
.tag--mono { font-family: var(--mono); font-weight: 400; color: var(--paper-dim); }

/* ---------- redaction reveal ---------- */
.redact {
  position: relative;
  display: inline-block;
  color: var(--paper);
  font-style: italic;
  cursor: help;
  isolation: isolate;
}
.redact__text { position: relative; z-index: 0; }
.redact__bar {
  position: absolute;
  inset: -1px -3px;
  z-index: 1;
  background: var(--paper);
  border-radius: 2px;
  clip-path: inset(0 0 0 0);
  transition: clip-path 520ms var(--ease-in-out);
}
.redact:hover .redact__bar,
.redact:focus-visible .redact__bar,
.redact.is-revealed .redact__bar {
  clip-path: inset(0 0 0 100%);
}

/* ---------- marquee ---------- */
.marquee {
  margin: var(--s-9) 0;
  padding: var(--s-4) 0;
  border-block: 1px solid var(--line-soft);
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee__track {
  display: flex;
  width: max-content;
  white-space: nowrap;
  animation: marquee 38s linear infinite;
}
.marquee__track span {
  font-family: var(--display);
  font-size: clamp(1.6rem, 1.1rem + 2.4vw, 3rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--paper-faint);
  padding-right: 0.3em;
}
@keyframes marquee {
  to { transform: translateX(-50%); }
}

/* ---------- case files ---------- */
.cases {
  max-width: var(--maxw);
  margin-inline: auto;
  padding: 0 var(--s-5);
}
.section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
  justify-content: space-between;
  gap: var(--s-4);
  margin-bottom: var(--s-7);
}
.section-note {
  max-width: 38ch;
  color: var(--paper-faint);
  font-size: 0.92rem;
}

.case-list { list-style: none; padding: 0; }
.case {
  display: grid;
  grid-template-columns: 88px 1fr auto;
  gap: clamp(var(--s-4), 3vw, var(--s-7));
  align-items: start;
  padding: var(--s-6) var(--s-3);
  border-top: 1px solid var(--line-soft);
  transition: background-color 240ms var(--ease-out), padding 240ms var(--ease-out);
}
.case:last-child { border-bottom: 1px solid var(--line-soft); }
.case:hover {
  background: oklch(0.205 0.014 255 / 0.5);
}
.case__num {
  font-family: var(--display);
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1;
  color: transparent;
  -webkit-text-stroke: 1px var(--line);
  transition: color 240ms var(--ease-out), -webkit-text-stroke-color 240ms var(--ease-out);
}
.case:hover .case__num {
  color: var(--blood-lift);
  -webkit-text-stroke-color: transparent;
}
.case__title {
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(1.2rem, 1.05rem + 0.7vw, 1.5rem);
  line-height: 1.15;
  letter-spacing: -0.01em;
}
.case__sub {
  font-family: var(--mono);
  font-size: 0.74rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--paper-faint);
  margin: var(--s-2) 0 var(--s-3);
}
.case__logline {
  max-width: 62ch;
  color: var(--paper-dim);
  font-size: 0.97rem;
}
.case__meta {
  display: flex;
  flex-direction: column;
  align-items: end;
  gap: var(--s-2);
  text-align: right;
  white-space: nowrap;
}

.cases__foot { margin-top: var(--s-7); display: flex; justify-content: center; }

/* ---------- cta ---------- */
.cta {
  max-width: var(--maxw);
  margin: var(--s-10) auto 0;
  padding: 0 var(--s-5);
}
.cta__inner {
  padding: clamp(var(--s-8), 7vw, var(--s-10)) var(--s-5);
  text-align: center;
  border-radius: calc(var(--radius) + 10px);
  border: 1px solid var(--line-soft);
  background:
    radial-gradient(55% 100% at 16% 0%, oklch(0.5 0.16 26 / 0.20), transparent 62%),
    radial-gradient(55% 100% at 84% 0%, oklch(0.5 0.14 258 / 0.20), transparent 62%),
    linear-gradient(180deg, var(--ink-raise), var(--ink-sink));
}
.cta__title {
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(2.2rem, 1.4rem + 4vw, 4.2rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.cta__sub {
  margin: var(--s-4) auto 0;
  max-width: 46ch;
  color: var(--paper-dim);
}
.cta__actions {
  margin-top: var(--s-7);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  justify-content: center;
}

/* ---------- footer ---------- */
.footer {
  margin-top: var(--s-10);
  border-top: 1px solid var(--line-soft);
  background: var(--ink-sink);
}
.footer__inner {
  max-width: var(--maxw);
  margin-inline: auto;
  padding: var(--s-8) var(--s-5) var(--s-6);
  display: grid;
  grid-template-columns: repeat(2, auto);
  justify-content: start;
  gap: clamp(var(--s-7), 8vw, var(--s-10));
}
.footer__col h3 {
  font-family: var(--mono);
  font-size: 0.7rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--paper-faint);
  margin-bottom: var(--s-4);
  font-weight: 400;
}
.footer__col a {
  display: block;
  color: var(--paper-dim);
  font-size: 0.92rem;
  padding: 5px 0;
  transition: color 160ms var(--ease-out);
}
.footer__col a:hover { color: var(--blood-lift); }
.footer__base {
  max-width: var(--maxw);
  margin-inline: auto;
  padding: var(--s-5);
  border-top: 1px solid var(--line-soft);
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--paper-faint);
  font-size: 0.82rem;
}

/* ---------- scroll reveal ---------- */
[data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
}
[data-reveal].is-visible { opacity: 1; transform: none; }

/* feed-rendered episode rows are click-through to the episode page */
.case { position: relative; }
.case__link { position: absolute; inset: 0; z-index: 2; border-radius: 6px; }
.case__link:focus-visible { outline-offset: -4px; }
/* small inline feed status note under the case list */
.cases__status {
  font-family: var(--mono);
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--paper-faint);
  text-align: center;
  margin-top: var(--s-5);
}
.cases__status[hidden] { display: none; }

/* ---------- responsive ---------- */
@media (max-width: 940px) {
  .hero { min-height: auto; }
  .hero__content {
    grid-template-columns: 1fr;
    gap: var(--s-7);
    padding-top: 50px;
  }
  .hero__scrim {
    background:
      linear-gradient(to bottom, oklch(0.165 0.012 255 / 0.5) 0%, oklch(0.165 0.012 255 / 0.2) 30%, oklch(0.165 0.012 255 / 0.55) 70%, var(--ink) 100%);
  }
  .ep-card { justify-self: stretch; max-width: 460px; }
  .footer__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px) {
  .nav__links { display: none; }
  .hero__logo { width: min(420px, 90%); }
  .case { grid-template-columns: 56px 1fr; }
  .case__meta { grid-column: 2; flex-direction: row; align-items: center; gap: var(--s-4); text-align: left; }
  .case__num { font-size: 1.8rem; }
  .hero__stats { gap: var(--s-6); flex-wrap: wrap; }
  .footer__inner { grid-template-columns: 1fr; }
  .footer__base { flex-direction: column; gap: var(--s-3); align-items: start; }
}

/* ---------- reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  [data-reveal] { opacity: 1; transform: none; }
  .marquee__track { animation: none; }
  .redact__bar { clip-path: inset(0 0 0 100%); }
}

/* gate hover-only flourishes to real hover devices */
@media (hover: none) {
  .redact { cursor: default; }
}
