/* ============================================================
   cases.css · cases-oversigt-specifikke styles
   Extracted from prototype cases.html inline-style.
   Delte regler (topbar/footer/section/contact/welcome/burger/mobilmenu) ligger i base.css.
   ============================================================ */

/* HERO */
.hero { padding: 96px 64px 80px; max-width: 1480px; margin: 0 auto; }
/* page-spec hero-h1 · bevidst variant fra base (cases-listen mindre end forsiden), ikke en dublet */
.hero h1 {
  font-weight: 300; font-size: clamp(64px, 8vw, 148px);
  line-height: 0.92; letter-spacing: -0.04em; margin: 0 0 56px;
  max-width: 1300px;
}
.hero h1 .b { font-weight: 600; }
.hero h1 .dim { color: var(--ink-mute); }
/* .hero-eyebrow nu konsolideret i base.css */

/* CASE ROWS · large list */
.case-rows { padding: 0; }
.case-row {
  display: grid; grid-template-columns: 80px 1.3fr 1.6fr 200px 80px;
  gap: 48px; padding: 56px 0;
  border-bottom: 1px solid var(--line); align-items: start;
  transition: padding 220ms;
}
.case-row:first-of-type { border-top: 1px solid var(--line-strong); }
.case-row:hover { padding-left: 16px; padding-right: 16px; margin: 0 -16px; }
.case-row:hover h2 { color: var(--accent); }
.case-row:hover .arrow { color: var(--accent); transform: translateX(8px); }

.case-row .ix {
  font-family: "JetBrains Mono", monospace; font-size: 12px;
  letter-spacing: 0.2em; font-weight: 600; color: var(--accent);
  padding-top: 12px;
}
.case-row .title-block h2 {
  font-weight: 400; font-size: clamp(32px, 3.4vw, 52px);
  line-height: 1.0; letter-spacing: -0.025em; margin: 0 0 16px;
  transition: color 200ms;
}
.case-row .title-block h2 .b { font-weight: 600; }
.case-row .title-block .meta {
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute);
  font-weight: 500; display: flex; align-items: center; gap: 10px;
}
.case-row .title-block .meta .dot { width: 6px; height: 6px; background: var(--accent); border-radius: 50%; }

.case-row .stub {
  font-size: 1.0625rem; line-height: 1.55; color: var(--ink-mute);
  margin: 0; max-width: 480px;
}

.case-row .stat-wrap { padding-top: 4px; }
.case-row .stat {
  font-weight: 200; font-size: clamp(48px, 5vw, 72px);
  line-height: 0.85; letter-spacing: -0.04em; color: var(--ink);
}
.case-row .stat .unit { font-size: 0.3em; color: var(--ink-mute); margin-left: 6px; vertical-align: 0.45em; font-weight: 400; }
.case-row .stat-label {
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute);
  margin-top: 8px; font-weight: 500;
}

.case-row .arrow {
  align-self: center; justify-self: end;
  font-size: 1.75rem; color: var(--ink-dim);
  transition: all 250ms; padding-top: 8px;
}

/* HERO-RULE modifier · extra top-spacing under hero h1 på cases-oversigten */
.hero .hero-rule--spaced { margin-top: 96px; }

/* Hero-rule wrapper-cell · semantisk klasse for hver 4-col grid-celle. */
.hero-rule .rule-cell { /* grid child; styling sker via .col-key/.col-val */ }

/* Section uden top-padding · bruges når hero allerede afslutter visuelt */
.section.section--flush-top { padding-top: 0; }

/* Lede med tæt margin under (intro før .upcoming-liste) */
.upcoming-section .lede--tight { margin-bottom: 40px; }

/* Contact grid-item · wrapper for .key/.val par i .contact .grid. */
.contact .grid .contact-item { /* grid child; styling sker via .key/.val */ }

/* UPCOMING */
.upcoming-section { padding: 96px 64px 64px; max-width: 1480px; margin: 0 auto; }
.upcoming { padding: 32px 0; border-bottom: 1px solid var(--line); display: grid; grid-template-columns: 80px 1fr; gap: 48px; opacity: 0.6; }
.upcoming:first-of-type { border-top: 1px solid var(--line-strong); }
.upcoming .ix { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.2em; color: var(--ink-mute); font-weight: 500; padding-top: 4px; }
.upcoming .text { font-size: 1.125rem; color: var(--ink-mute); line-height: 1.5; }
.upcoming .text strong { color: var(--ink); font-weight: 500; }

@media (max-width: 900px) {
  .hero { padding: 56px 24px 48px; }
  .case-row { grid-template-columns: 1fr; gap: 16px; padding: 32px 0; }
  .case-row .arrow { display: none; }
  .upcoming-section { padding: 64px 24px; }
  .upcoming { grid-template-columns: 1fr; }
}
