/* ============================================================
   KØS · Design System
   Brand System v2.0 · Warm Intelligence Spectrum
   Carbon / Mist / Gold · Space Grotesk + Inter
   "Chaos is potential. Clarity is a decision."
   ============================================================ */

/* ---- 1. Tokens ------------------------------------------------ */
:root {
  /* Colour · 75 carbon / 20 mist / 5 gold */
  --carbon:        #1A1A1A;   /* primary background, depth */
  --carbon-deep:   #141414;   /* deeper sections */
  --carbon-raise:  #212121;   /* raised surfaces, cards */
  --mist:          #F2F2F5;   /* typography, negative space */
  --gold:          #D99440;   /* accent only · never dominant */

  --mist-70:  rgba(242,242,245,0.70);  /* body text */
  --mist-45:  rgba(242,242,245,0.45);  /* secondary text */
  --mist-25:  rgba(242,242,245,0.25);  /* faint */
  --line:     rgba(242,242,245,0.12);  /* hairlines */
  --line-soft:rgba(242,242,245,0.07);
  --gold-dim: rgba(217,148,64,0.14);
  --gold-line:rgba(217,148,64,0.40);

  /* Type */
  --display:  "Space Grotesk", system-ui, sans-serif;
  --text:     "Inter", system-ui, -apple-system, sans-serif;

  /* Fluid type scale */
  --fs-display: clamp(2.9rem, 6.4vw, 5.6rem);
  --fs-h1:      clamp(2.1rem, 4.4vw, 3.5rem);
  --fs-h2:      clamp(1.55rem, 2.7vw, 2.15rem);
  --fs-h3:      clamp(1.12rem, 1.5vw, 1.3rem);
  --fs-lead:    clamp(1.15rem, 1.6vw, 1.4rem);
  --fs-body:    1.0625rem;
  --fs-small:   0.8125rem;
  --fs-label:   0.6875rem;

  /* Space */
  --s1: 0.5rem;  --s2: 1rem;   --s3: 1.5rem;  --s4: 2rem;
  --s5: 3rem;    --s6: 4.5rem; --s7: 7rem;    --s8: 10rem;

  /* Measure */
  --measure: 68ch;
  --wrap:    1180px;
  --wrap-narrow: 760px;

  --ease: cubic-bezier(0.16, 0.84, 0.44, 1);
}

/* ---- 2. Reset ------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  background: var(--carbon);
  color: var(--mist-70);
  font-family: var(--text);
  font-size: var(--fs-body);
  line-height: 1.72;
  font-feature-settings: "kern" 1, "liga" 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; }
::selection { background: var(--gold); color: var(--carbon); }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }

/* ---- 3. Typography ------------------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--display);
  color: var(--mist);
  font-weight: 500;
  line-height: 1.06;
  letter-spacing: -0.02em;
}
.display {
  font-family: var(--display);
  font-size: var(--fs-display);
  font-weight: 500;
  line-height: 0.98;
  letter-spacing: -0.035em;
  color: var(--mist);
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); letter-spacing: -0.01em; }

p { max-width: var(--measure); }
strong { color: var(--mist); font-weight: 600; }
em { font-style: italic; }

.lead {
  font-size: var(--fs-lead);
  line-height: 1.6;
  color: var(--mist);
  font-weight: 400;
  max-width: 36ch;
}

/* Eyebrow / label · the system's connective tissue */
.label {
  font-family: var(--display);
  font-size: var(--fs-label);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
}
.label::before {
  content: "";
  width: 24px; height: 1px;
  background: var(--gold);
}
.label.plain::before { display: none; }

/* Inline links inside prose */
.prose a {
  color: var(--mist);
  text-decoration: none;
  border-bottom: 1px solid var(--gold-line);
  transition: border-color 0.25s var(--ease), color 0.25s var(--ease);
}
.prose a:hover { border-color: var(--gold); color: var(--gold); }

/* Gold accent word · used sparingly */
.accent { color: var(--gold); }

/* ---- 4. Layout ----------------------------------------------- */
.wrap { width: 100%; max-width: var(--wrap); margin-inline: auto; padding-inline: var(--s4); }
.wrap-narrow { max-width: var(--wrap-narrow); }
.section { padding-block: var(--s7); }
.section-deep { background: var(--carbon-deep); }
.section-tight { padding-block: var(--s6); }

.rule { height: 1px; background: var(--line); border: 0; }
.rule-gold { height: 1px; background: var(--gold-line); border: 0; }

.grid { display: grid; gap: var(--s4); }
@media (min-width: 720px) {
  .grid-2 { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(3, 1fr); }
}

/* Editorial two-column: sticky aside + flowing body */
.editorial { display: grid; gap: var(--s5); }
@media (min-width: 940px) {
  .editorial {
    grid-template-columns: 220px 1fr;
    gap: var(--s6);
  }
  .editorial-aside { position: sticky; top: 120px; align-self: start; }
}

/* ---- 5. The Ø mark ------------------------------------------- */
.mark {
  font-family: var(--display);
  font-weight: 500;
  line-height: 1;
  display: inline-block;
}
.mark-lg { font-size: clamp(6rem, 22vw, 18rem); color: var(--mist); letter-spacing: -0.04em; }
.mark-gold { color: var(--gold); }

/* ---- 6. Navigation ------------------------------------------- */
.nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(26,26,26,0.82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line-soft);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 68px;
}
.nav-logo {
  font-family: var(--display);
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--mist);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.nav-logo .o { color: var(--gold); }
.nav-logo img { height: 13px; width: auto; display: block; }
.footer .nav-logo img { height: 15px; }
.nav-links { display: flex; align-items: center; gap: var(--s4); list-style: none; }
.nav-links a {
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mist-45);
  text-decoration: none;
  transition: color 0.22s var(--ease);
}
.nav-links a:hover, .nav-links a[aria-current="page"] { color: var(--mist); }
.nav-cta {
  border: 1px solid var(--line);
  padding: 0.55rem 1.1rem;
  color: var(--mist) !important;
  transition: border-color 0.22s var(--ease), background 0.22s var(--ease);
}
.nav-cta:hover { border-color: var(--gold); background: var(--gold-dim); }
.nav-lang {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem;
  border: 1px solid var(--line);
  border-radius: 2px;
  transition: border-color 0.22s var(--ease), opacity 0.22s var(--ease);
  opacity: 0.7;
}
.nav-lang img {
  display: block;
  width: 22px; height: 16px;
  object-fit: cover;
  border-radius: 1px;
}
.nav-lang:hover { border-color: var(--gold-line); opacity: 1; }
.nav-toggle { display: none; background: none; border: 0; color: var(--mist); cursor: pointer; font-family: var(--display); font-size: var(--fs-label); letter-spacing: 0.14em; text-transform: uppercase; }
@media (max-width: 760px) {
  .nav-links { display: none; }
  .nav-links.open {
    display: flex; flex-direction: column; align-items: flex-start;
    position: absolute; left: 0; right: 0; top: 68px;
    background: var(--carbon-deep);
    border-bottom: 1px solid var(--line);
    padding: var(--s4); gap: var(--s3);
  }
  .nav-toggle { display: block; }
}

/* ---- 7. Buttons & links -------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 0.95rem 1.6rem;
  border: 1px solid var(--line);
  color: var(--mist);
  transition: border-color 0.25s var(--ease), background 0.25s var(--ease), transform 0.25s var(--ease);
}
.btn:hover { border-color: var(--gold); background: var(--gold-dim); }
.btn-solid { background: var(--gold); color: var(--carbon); border-color: var(--gold); }
.btn-solid:hover { background: #e8a44d; transform: translateY(-1px); }
.btn .arrow { transition: transform 0.25s var(--ease); }
.btn:hover .arrow { transform: translateX(3px); }

.textlink {
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 0.5rem;
  border-bottom: 1px solid transparent;
  transition: border-color 0.25s var(--ease);
}
.textlink:hover { border-color: var(--gold-line); }

/* ---- 8. Components ------------------------------------------- */

/* Numbered section index · echoes the book's spread system */
.index-num {
  font-family: var(--display);
  font-size: var(--fs-small);
  color: var(--gold);
  letter-spacing: 0.1em;
}

/* KØS point-of-view callout · the studio's voice in the margin of knowledge */
.pov {
  border-left: 2px solid var(--gold);
  background: var(--gold-dim);
  padding: var(--s3) var(--s4);
  margin-block: var(--s4);
}
.pov .label { margin-bottom: var(--s2); }
.pov p {
  font-family: var(--display);
  font-size: var(--fs-h3);
  line-height: 1.4;
  color: var(--mist);
  letter-spacing: -0.01em;
  max-width: 46ch;
}

/* Definition block · the reference's atomic unit (maps to schema DefinedTerm) */
.define {
  border: 1px solid var(--line);
  border-top: 2px solid var(--gold);
  padding: var(--s4);
  background: var(--carbon-raise);
}
.define dt {
  font-family: var(--display);
  font-size: var(--fs-h3);
  color: var(--mist);
  margin-bottom: var(--s2);
}
.define dd { color: var(--mist-70); max-width: var(--measure); }

/* Q&A block · drives FAQ schema + featured snippets + LLM extraction */
.qa { border-top: 1px solid var(--line); }
.qa-item { border-bottom: 1px solid var(--line); padding-block: var(--s4); }
.qa-q {
  font-family: var(--display);
  font-size: var(--fs-h3);
  color: var(--mist);
  margin-bottom: var(--s2);
  letter-spacing: -0.01em;
}
.qa-a { color: var(--mist-70); }
.qa-a + .qa-a { margin-top: var(--s2); }

/* Key takeaways · extractable summary block for GEO */
.keybox {
  border: 1px solid var(--line);
  border-left: 2px solid var(--gold);
  padding: var(--s4);
  background: var(--carbon-raise);
}
.keybox .label { margin-bottom: var(--s3); }
.keybox ul { list-style: none; }
.keybox li { padding-left: 1.6rem; position: relative; margin-bottom: var(--s2); color: var(--mist-70); max-width: var(--measure); }
.keybox li:last-child { margin-bottom: 0; }
.keybox li::before { content: "/"; position: absolute; left: 0; color: var(--gold); font-family: var(--display); }

/* Article meta row */
.article-meta {
  display: flex; flex-wrap: wrap; gap: var(--s4);
  font-size: var(--fs-small); color: var(--mist-45);
  margin-top: var(--s4);
}
.article-meta b { color: var(--mist-70); font-weight: 500; }

/* Citation marginalia · scholarly trust signal for GEO */
.cite {
  font-size: var(--fs-small);
  color: var(--mist-45);
  line-height: 1.55;
}
.cite-num {
  font-family: var(--display);
  color: var(--gold);
  font-size: 0.7rem;
  vertical-align: super;
}
.references {
  border-top: 1px solid var(--line);
  padding-top: var(--s4);
  margin-top: var(--s6);
}
.references ol { list-style: none; counter-reset: ref; }
.references li {
  counter-increment: ref;
  position: relative;
  padding-left: 2.2rem;
  margin-bottom: var(--s2);
  font-size: var(--fs-small);
  color: var(--mist-45);
  max-width: var(--measure);
}
.references li::before {
  content: counter(ref);
  position: absolute; left: 0; top: 0;
  font-family: var(--display);
  color: var(--gold);
  font-size: 0.7rem;
}
.references a { color: var(--mist-70); text-decoration: none; border-bottom: 1px solid var(--line); }
.references a:hover { color: var(--gold); }

/* Cards · reference index, dispatch, work */
.card {
  display: block;
  border: 1px solid var(--line);
  background: var(--carbon-raise);
  padding: var(--s4);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease), background 0.3s var(--ease);
}
.card:hover { border-color: var(--gold-line); transform: translateY(-3px); background: #242424; }
.card .index-num { display: block; margin-bottom: var(--s3); }
.card h3 { margin-bottom: var(--s2); }
.card p { font-size: var(--fs-small); color: var(--mist-45); }
.card .card-go {
  margin-top: var(--s3);
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  display: inline-flex; gap: 0.4rem;
}

/* Reference hub · entry list grouped by part */
.ref-part { margin-top: var(--s6); }
.ref-part-head { display: flex; align-items: baseline; gap: var(--s3); margin-bottom: var(--s3); }
.ref-part-head .part-num { font-family: var(--display); color: var(--gold); font-size: var(--fs-small); }
.ref-part-head h2 { font-size: var(--fs-h3); letter-spacing: 0.02em; text-transform: uppercase; }
.ref-list { list-style: none; border-top: 1px solid var(--line); }
.ref-row {
  display: grid; grid-template-columns: 3rem 1fr auto; gap: var(--s3);
  align-items: baseline;
  padding-block: var(--s3);
  border-bottom: 1px solid var(--line);
  text-decoration: none; color: inherit;
  transition: background 0.25s var(--ease), padding-left 0.25s var(--ease);
}
a.ref-row:hover { background: var(--carbon-raise); padding-left: var(--s2); }
.ref-row .r-num { font-family: var(--display); font-size: var(--fs-small); color: var(--gold); padding-top: 0.4rem; }
.ref-row .r-title {
  display: block;
  font-family: var(--display);
  font-size: var(--fs-h3);
  font-weight: 500;
  color: var(--mist);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.ref-row .r-desc {
  display: block;
  font-size: var(--fs-small);
  color: var(--mist-45);
  margin-top: 0.5rem;
  line-height: 1.6;
  max-width: 62ch;
}
.ref-row .r-state {
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
  padding-top: 0.45rem;
}
.ref-row .r-state.live { color: var(--gold); }
.ref-row .r-state.soon { color: var(--mist-25); }
.ref-row.soon { cursor: default; }
@media (max-width: 620px) {
  .ref-row { grid-template-columns: 2rem 1fr; }
  .ref-row .r-state { grid-column: 2; }
}

/* Table of contents (reference articles) */
.toc { font-size: var(--fs-small); }
.toc .label { margin-bottom: var(--s3); }
.toc ol { list-style: none; counter-reset: toc; }
.toc li { counter-increment: toc; margin-bottom: 0.7rem; }
.toc a {
  color: var(--mist-45);
  text-decoration: none;
  display: flex; gap: 0.7rem;
  transition: color 0.2s var(--ease);
}
.toc a::before {
  content: counter(toc, decimal-leading-zero);
  font-family: var(--display);
  color: var(--gold);
  font-size: 0.7rem;
}
.toc a:hover { color: var(--mist); }

/* Article prose rhythm */
.prose > * + * { margin-top: var(--s3); }
.prose h2 { margin-top: var(--s6); margin-bottom: var(--s2); }
.prose h3 { margin-top: var(--s5); margin-bottom: var(--s1); }
.prose ul, .prose ol { padding-left: 1.4rem; max-width: var(--measure); }
.prose li { margin-bottom: 0.5rem; }
.prose li::marker { color: var(--gold); }
.prose blockquote {
  border-left: 2px solid var(--line);
  padding-left: var(--s3);
  font-family: var(--display);
  font-size: var(--fs-h3);
  color: var(--mist);
  line-height: 1.4;
}
.prose blockquote cite { display: block; margin-top: var(--s2); font-family: var(--text); font-size: var(--fs-small); font-style: normal; color: var(--mist-45); }

/* Breadcrumb */
.crumb { font-size: var(--fs-label); font-family: var(--display); letter-spacing: 0.12em; text-transform: uppercase; color: var(--mist-45); display: flex; gap: 0.6rem; flex-wrap: wrap; }
.crumb a { color: var(--mist-45); text-decoration: none; }
.crumb a:hover { color: var(--gold); }
.crumb span[aria-current] { color: var(--mist); }

/* Logo wall · Work proof, real client marks, named, no detail */
.logowall { display: flex; flex-wrap: wrap; gap: var(--s5) var(--s6); align-items: center; justify-content: center; }
.logowall img {
  height: 26px; width: auto; max-width: 130px;
  object-fit: contain;
  filter: brightness(0) invert(1);
  opacity: 0.5;
  transition: opacity 0.3s var(--ease);
}
.logowall img:hover { opacity: 1; }
.logowall span {
  font-family: var(--display);
  font-size: var(--fs-small);
  letter-spacing: 0.04em;
  color: var(--mist-45);
}

/* ---- 8b. Rich media · video hero, imagery, services ---------- */

/* Video hero · texture, not tech-cliché: heavy carbon overlay */
.hero-video { position: relative; overflow: hidden; }
.hero-video > video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.hero-video .hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(180deg, rgba(20,19,18,0.72) 0%, rgba(26,26,26,0.88) 65%, rgba(26,26,26,0.97) 100%);
}
.hero-video .wrap { position: relative; z-index: 2; }

/* Editorial feature · text beside a real photograph */
.feature { display: grid; gap: var(--s5); align-items: center; }
@media (min-width: 880px) {
  .feature { grid-template-columns: 1fr 1fr; gap: var(--s6); }
  .feature.reverse .feature-text { order: 2; }
}
.feature-img {
  width: 100%; height: 100%; min-height: 340px;
  object-fit: cover;
  border: 1px solid var(--line);
  filter: grayscale(0.25) contrast(1.05);
}

/* Services · what we actually do, plain and concrete */
.services-grid { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
@media (min-width: 640px) { .services-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .services-grid { grid-template-columns: repeat(3, 1fr); } }
.service {
  background: var(--carbon);
  padding: var(--s4);
  transition: background 0.3s var(--ease);
}
.service:hover { background: var(--carbon-raise); }
.service .s-num {
  font-family: var(--display);
  font-size: var(--fs-small);
  color: var(--gold);
  letter-spacing: 0.1em;
}
.service h2 { margin: var(--s2) 0; font-size: var(--fs-h3); }
.service p { font-size: var(--fs-small); color: var(--mist-45); line-height: 1.7; }
/* Service card as a link */
a.service { text-decoration: none; color: inherit; display: block; }
a.service:hover { background: var(--carbon-raise); }
.service .s-go {
  margin-top: var(--s3);
  display: inline-flex; gap: 0.45rem; align-items: center;
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
}

/* ---- 8c. Contact map + dispatch cards ------------------------ */

/* Responsive Google Maps embed, tuned to the carbon theme */
.map-embed {
  position: relative; width: 100%;
  aspect-ratio: 16 / 11;
  border: 1px solid var(--line);
  background: var(--carbon-raise);
  overflow: hidden;
}
.map-embed iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
  filter: grayscale(1) contrast(1.04) brightness(0.96);
}

/* Contact detail rows */
.contact-detail { border-top: 1px solid var(--line); padding-top: var(--s3); margin-top: var(--s3); }
.contact-detail:first-of-type { border-top: 0; padding-top: 0; margin-top: 0; }
.contact-detail h2 {
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 0.55rem;
}
.contact-detail a, .contact-detail p { font-size: var(--fs-body); color: var(--mist-70); text-decoration: none; }
.contact-detail a:hover { color: var(--mist); }

/* Dispatch cards with cover image */
.dispatch-grid { display: grid; gap: var(--s4); }
@media (min-width: 640px) { .dispatch-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .dispatch-grid { grid-template-columns: repeat(3, 1fr); } }
.dispatch-card {
  display: block;
  border: 1px solid var(--line);
  background: var(--carbon-raise);
  text-decoration: none; color: inherit;
  transition: border-color 0.3s var(--ease), transform 0.3s var(--ease);
}
.dispatch-card:hover { border-color: var(--gold-line); transform: translateY(-3px); }
.dispatch-card img {
  width: 100%; aspect-ratio: 4 / 3;
  object-fit: cover; display: block;
  border-bottom: 1px solid var(--line);
  filter: grayscale(0.15) contrast(1.04);
}
.dispatch-card .dc-body { padding: var(--s4); }
.dispatch-card .dc-issue {
  font-family: var(--display);
  font-size: var(--fs-small);
  color: var(--gold);
  letter-spacing: 0.08em;
}
.dispatch-card h2 { margin: var(--s2) 0; font-size: var(--fs-h3); }
.dispatch-card p { font-size: var(--fs-small); color: var(--mist-45); line-height: 1.65; }

/* Stat row */
.stats { display: flex; flex-wrap: wrap; gap: var(--s6); }
.stat-num { font-family: var(--display); font-size: var(--fs-h1); color: var(--gold); line-height: 1; }
.stat-label { font-size: var(--fs-label); letter-spacing: 0.14em; text-transform: uppercase; color: var(--mist-45); margin-top: var(--s2); }

/* ---- 9. Footer ----------------------------------------------- */
.footer { background: var(--carbon-deep); border-top: 1px solid var(--line); padding-block: var(--s6); }
.footer-grid { display: grid; gap: var(--s4); }
@media (min-width: 720px) { .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; } }
.footer h2 { font-size: var(--fs-label); letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); margin-bottom: var(--s3); font-weight: 500; }
.footer a { color: var(--mist-45); text-decoration: none; display: block; margin-bottom: 0.6rem; transition: color 0.2s var(--ease); }
.footer a:hover { color: var(--mist); }
.footer-base { margin-top: var(--s5); padding-top: var(--s4); border-top: 1px solid var(--line-soft); font-size: var(--fs-small); color: var(--mist-25); display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--s2); }

/* ---- 10. Utilities & motion ---------------------------------- */
.skip { position: absolute; left: -999px; }
.skip:focus { left: var(--s4); top: var(--s2); z-index: 200; background: var(--gold); color: var(--carbon); padding: 0.6rem 1rem; }
.mt-0 { margin-top: 0; } .mb-0 { margin-bottom: 0; }
.muted { color: var(--mist-45); }
.center { text-align: center; }
.maxw-narrow { max-width: var(--wrap-narrow); }

/* Quiet, intentional reveal · no glow, no bounce, no cliché */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 0.7s var(--ease), transform 0.7s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
}

/* ---- 11. Cookie banner --------------------------------------- */
.cookie-banner {
  position: fixed;
  left: var(--s3); right: var(--s3);
  bottom: var(--s3);
  z-index: 9999;
  max-width: 560px;
  margin-inline: auto;
  display: none;
  align-items: center;
  gap: var(--s3);
  flex-wrap: wrap;
  justify-content: center;
  background: var(--carbon-raise);
  border: 1px solid var(--line);
  padding: var(--s3) var(--s4);
  box-shadow: 0 14px 50px rgba(0,0,0,0.5);
}
.cookie-banner.show { display: flex; }
.cookie-banner p {
  margin: 0;
  font-size: var(--fs-small);
  color: var(--mist-70);
  flex: 1 1 240px;
}
.cookie-banner p a { color: var(--mist); text-decoration: underline; text-underline-offset: 3px; }
.cookie-banner p a:hover { color: var(--gold); }
.cookie-banner button {
  font-family: var(--display);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--gold);
  color: var(--carbon);
  border: 0;
  padding: 0.7rem 1.2rem;
  cursor: pointer;
  transition: background 0.22s var(--ease);
}
.cookie-banner button:hover { background: #e8a44d; }
