/* ============================================================
   home.css · forside-specifikke styles (hero/section/piece/cases/values/principles/contact)
   Extracted from prototype index.html inline-style (linje 94–338 + 414–442).
   Delte partials (topbar/footer/mobilmenu/welcome/burger) ligger i base.css.
   ============================================================ */

/* ============================================================
   HERO with logo 02 · hero mark
   ============================================================ */
.hero { padding: 96px 64px 80px; max-width: 1480px; margin: 0 auto; }

.hero-main {
  display: grid; grid-template-columns: 320px 1fr;
  gap: 64px; align-items: center;
  margin-bottom: 88px;
}
.hero-mark {
  width: 280px; aspect-ratio: 1;
  align-self: start;
  margin-top: 12px;
}
/* page-spec hero-h1 · bevidst variant (forsiden er størst), ikke en dublet */
.hero h1 {
  font-weight: 300; font-size: clamp(72px, 9.5vw, 168px);
  line-height: 0.9; letter-spacing: -0.045em; margin: 0;
}
.hero h1 .b { font-weight: 600; }
.hero h1 .dim { color: var(--ink-mute); }

.hero-bottom {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr;
  gap: 64px; align-items: end;
  padding-top: 32px; border-top: 1px solid var(--line);
}
.hero-bottom .blurb {
  font-size: 1.25rem; line-height: 1.55; color: var(--ink); margin: 0;
  max-width: 520px;
}
.hero-bottom .blurb .dot { width: 9px; height: 9px; background: var(--accent); border-radius: 50%; display: inline-block; vertical-align: 2px; margin-right: 8px; }
.hero-bottom .actions { display: flex; flex-direction: column; gap: 14px; }
.hero-bottom .actions a {
  display: inline-flex; align-items: center; justify-content: space-between;
  gap: 10px; padding: 10px 0;
  border-bottom: 1.5px solid var(--ink); font-weight: 500; font-size: 0.95rem;
  transition: all 180ms;
}
.hero-bottom .actions a:hover { color: var(--accent); border-color: var(--accent); padding-left: 4px; }

/* ============================================================
   SECTION-HEAD · forside override (margin-bottom: 96px)
   ============================================================ */
.section .section-head { margin-bottom: 96px; }
/* .section-head--tight nu konsolideret i base.css */

/* Hero-rule wrapper-cell · semantisk klasse for hver 4-col grid-celle.
   Bæres af .col-key/.col-val children; klassen findes for at undgå bare-div. */
.hero-rule .rule-cell { /* grid child; styling sker via .col-key/.col-val */ }

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

/* ============================================================
   SERVICES · strict rows
   ============================================================ */
.piece {
  display: grid; grid-template-columns: 80px 1.2fr 1.4fr 80px;
  gap: 48px; padding: 48px 0;
  border-bottom: 1px solid var(--line); align-items: start;
  transition: padding 220ms;
}
.piece:first-of-type { border-top: 1px solid var(--line); }
.piece:hover { padding-left: 16px; padding-right: 16px; margin: 0 -16px; }
.piece:hover .arrow { color: var(--accent); transform: translateX(8px); }
.piece:hover h3 { color: var(--accent); }
.piece .ix {
  font-family: "JetBrains Mono", monospace; font-size: 12px;
  letter-spacing: 0.2em; font-weight: 600; color: var(--accent);
  padding-top: 10px;
}
.piece h3 {
  font-weight: 400; font-size: clamp(34px, 3.6vw, 52px);
  line-height: 1.0; letter-spacing: -0.025em; margin: 0;
  transition: color 200ms;
}
.piece h3 .b { font-weight: 600; }
.piece .body { font-size: 1.0625rem; line-height: 1.6; color: var(--ink-mute); }
.piece .body p { margin: 0 0 14px; }
.piece .body .meta {
  display: flex; gap: 20px; font-family: "JetBrains Mono", monospace;
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-mute); font-weight: 500; margin-top: 18px;
  padding-top: 16px; border-top: 1px dotted var(--line-strong);
}
.piece .body .meta .dot { width: 6px; height: 6px; background: var(--accent); border-radius: 50%; display: inline-block; vertical-align: 1px; margin-right: 6px; }
.piece .arrow { align-self: center; justify-self: end; font-size: 1.75rem; color: var(--ink-dim); transition: all 250ms; padding-top: 4px; }

/* ============================================================
   CASES grid
   ============================================================ */
.cases-head {
  display: grid; grid-template-columns: 200px 1.6fr 1fr;
  gap: 48px; align-items: end;
  margin-bottom: 80px; padding-bottom: 24px;
  border-bottom: 1px solid var(--line-strong);
}
.cases-head h2 {
  font-weight: 300; font-size: clamp(48px, 6.4vw, 116px);
  line-height: 0.92; letter-spacing: -0.035em; margin: 0;
}
.cases-head h2 .b { font-weight: 600; }
.cases-head .intro { font-size: 1.0625rem; line-height: 1.55; color: var(--ink-mute); margin: 0; align-self: end; max-width: 380px; }

.case-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.case-card {
  display: flex; flex-direction: column;
  padding: 32px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 6px;
  transition: all 220ms;
  min-height: 380px;
}
.case-card:hover {
  border-color: var(--ink);
  transform: translateY(-2px);
}
.case-card .meta {
  display: flex; align-items: baseline; gap: 10px;
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-mute);
  font-weight: 500;
  margin-bottom: 36px;
}
.case-card .meta .dot { width: 7px; height: 7px; background: var(--accent); border-radius: 50%; }
.case-card h3 {
  font-weight: 500; font-size: 1.625rem; line-height: 1.1;
  letter-spacing: -0.015em; margin: 0 0 12px;
}
.case-card h3 .b { font-weight: 600; }
.case-card .stub {
  font-size: 0.9375rem; line-height: 1.55; color: var(--ink-mute);
  margin: 0; flex: 1;
}
.case-card .footer-row {
  margin-top: 32px; padding-top: 20px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
}
.case-card .read {
  font-family: "JetBrains Mono", monospace; font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; font-weight: 600;
  color: var(--ink);
}
.case-card:hover .read { color: var(--accent); }
.case-card .stat-mini {
  font-family: "Inter Tight", sans-serif; font-weight: 500; font-size: 1.125rem;
  letter-spacing: -0.01em; color: var(--ink);
}
.case-card .stat-mini .acc { color: var(--accent); }

.cases-foot {
  margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
}
.cases-foot .fine { color: var(--ink-mute); font-size: 0.9375rem; }
.cases-foot .fine .dot { width: 8px; height: 8px; background: var(--accent); border-radius: 50%; display: inline-block; vertical-align: 1px; margin-right: 8px; }
.cases-foot a.all {
  padding: 10px 0; border-bottom: 1.5px solid var(--ink);
  font-weight: 500; font-size: 0.95rem;
  transition: all 180ms;
}
.cases-foot a.all:hover { color: var(--accent); border-color: var(--accent); padding-left: 4px; }

/* ============================================================
   VALUES
   ============================================================ */
.values .lead { display: flex; align-items: center; gap: 14px; margin-bottom: 80px; }
.values .lead .dot { width: 10px; height: 10px; background: var(--accent); border-radius: 50%; }
.values-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line-strong); }
.value { padding: 64px 32px 40px 0; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line-strong); }
.value:nth-child(n+2) { padding-left: 32px; }
.value:last-child { border-right: 0; }
.value .marker { width: 9px; height: 9px; background: var(--accent); border-radius: 50%; margin-bottom: 28px; }
.value h3 {
  font-weight: 400; font-size: clamp(40px, 4.5vw, 64px);
  line-height: 0.95; letter-spacing: -0.025em; margin: 0 0 16px;
}
.value h3 .b { font-weight: 600; }
.value p { font-size: 1rem; line-height: 1.6; color: var(--ink-mute); margin: 0; max-width: 320px; }

/* ============================================================
   PRINCIPLES
   ============================================================ */
.principles-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid var(--line-strong);
}
.principle {
  padding: 48px 24px 56px 0;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.principle:nth-child(n+2) { padding-left: 24px; }
.principle:last-child { border-right: 0; }
.principle .n { color: var(--accent); font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: 0.2em; font-weight: 600; margin-bottom: 24px; }
.principle h3 { font-weight: 600; font-size: 1.375rem; letter-spacing: -0.015em; line-height: 1.2; margin: 0 0 12px; }
.principle p { font-size: 0.9375rem; line-height: 1.6; color: var(--ink-mute); margin: 0; }

/* ============================================================
   RESPONSIVE · forside-specifikke regler
   (topbar/footer/burger/mobile-menu/hero-rule/contact/section allerede i base.css)
   ============================================================ */
@media (max-width: 900px) {
  .hero-main { grid-template-columns: 1fr; gap: 32px; }
  .hero-mark { width: 180px; }
  .hero-bottom { grid-template-columns: 1fr; gap: 32px; }
  .cases-head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 56px; }
  .piece { grid-template-columns: 60px 1fr; gap: 24px; }
  .piece .arrow, .piece .body { grid-column: 2; }
  .case-cards { grid-template-columns: 1fr; }
  .values-grid { grid-template-columns: 1fr; }
  .value { border-right: 0; padding-left: 0; padding-right: 0; }
  .value:nth-child(n+2) { padding-left: 0; }
  .principles-grid { grid-template-columns: 1fr 1fr; }
  .principle:nth-child(2n) { border-right: 0; }
  .section .section-head { margin-bottom: 56px; }
}
@media (max-width: 540px) {
  .principles-grid { grid-template-columns: 1fr; }
  .principle { border-right: 0; }
  .principle:nth-child(2n) { border-right: 0; }
}
