/* ============================================================
   Sprucebird — Cinematic homepage
   Editorial luxury · dark espresso/olive · Cormorant + Hanken
   Reference language: Son Daven (dark, high-contrast serif caps,
   centered marks, scroll-revealed prologue, pill buttons).
   ============================================================ */

/* ---- Reset -------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
img, svg { max-width: 100%; display: block; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
input, textarea, select { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

/* ---- Tokens ------------------------------------------------- */
:root {
  /* dark cinematic ground, warm */
  --ink-0:   #1c1b10;   /* deepest */
  --bg:      #26241544; /* placeholder, overwritten below */
  --bg:      #262415;   /* main dark espresso-olive */
  --bg-2:    #2f2e1c;   /* raised dark */
  --bg-olive:#333d29;   /* dark olive section (from palette) */

  /* light ground for inverted sections */
  --paper:   #d3d4ba;   /* pale sage paper */
  --paper-2: #c2c5aa;   /* palette pale sage */

  /* foreground on dark */
  --cream:   #d8d8c0;   /* primary text on dark */
  --khaki:   #b6ad90;   /* palette */
  --tan:     #a68a64;   /* palette */
  --tan-2:   #936639;   /* palette, deeper */
  --muted:   #8a8466;   /* dim labels */
  --faint:   rgba(216,216,192,0.16);
  --rule:    rgba(182,173,144,0.18);
  --rule-2:  rgba(182,173,144,0.32);

  /* accent (warm gold-tan) */
  --accent:  #a68a64;
  --accent-2:#b6ad90;

  /* ink on paper */
  --ink:       #2c2a1a;
  --ink-soft:  rgba(44,42,26,0.70);
  --ink-faint: rgba(44,42,26,0.46);
  --rule-ink:  rgba(44,42,26,0.18);

  --font-display: "Cormorant Garamond", "Times New Roman", Georgia, serif;
  --font-sans: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --max:      1280px;
  --max-text: 760px;
  --pad:      max(22px, min(5vw, 56px));
  --section:  clamp(96px, 13vw, 200px);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* Accent / mood tweaks */
[data-accent="gold"]  { --accent: #b89947; --accent-2: #c2b06a; }
[data-accent="tan"]   { --accent: #a68a64; --accent-2: #b6ad90; }
[data-accent="sage"]  { --accent: #a4ac86; --accent-2: #b6ad90; }

[data-ground="olive"] { --bg: #2c331f; --bg-2: #35402a; --ink-0: #20271a; }
[data-ground="espresso"] { --bg: #2a2113; --bg-2: #342817; --ink-0: #1d1709; }
[data-ground="forest"] { --bg: #262415; --bg-2: #2f2e1c; --ink-0: #1c1b10; }

/* ---- Base --------------------------------------------------- */
body {
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.6;
  color: var(--cream);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* film-grain veil */
body::after {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 9000;
  opacity: var(--grain, 0.08);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 360 360' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

::selection { background: var(--accent); color: var(--ink-0); }

/* ---- Type --------------------------------------------------- */
.display {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 0.98;
  letter-spacing: 0.005em;
  text-transform: uppercase;
  color: var(--cream);
}
.display em, .display i {
  font-style: italic;
  text-transform: none;
  color: var(--accent);
  font-weight: 500;
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 500; }

/* Label / eyebrow with flanking marks */
.tag {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--tan);
}
.tag--center { justify-content: center; }
.tag__marks { display: inline-flex; gap: 5px; }
.tag__marks::before, .tag__marks::after,
.tag__marks i {
  content: "";
  width: 5px; height: 5px;
  background: var(--accent);
  transform: rotate(45deg);
  display: inline-block;
  opacity: 0.85;
}
.tag__marks i:nth-child(2) { opacity: 0.55; }
.tag__marks i:nth-child(3) { opacity: 0.32; }
.tag__line { width: 36px; height: 1px; background: var(--rule-2); }

.mono { font-family: var(--font-mono); letter-spacing: 0.04em; }

/* ---- Layout primitives -------------------------------------- */
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }
.section { padding: var(--section) 0; position: relative; }
.section--tight { padding: clamp(72px,9vw,128px) 0; }

.panel-dark  { background: var(--bg); color: var(--cream); }
.panel-deep  { background: var(--ink-0); color: var(--cream); }
.panel-olive { background: var(--bg-olive); color: var(--cream); }
.panel-paper { background: var(--paper); color: var(--ink); }
.panel-paper .tag { color: var(--tan-2); }
.panel-paper .display { color: var(--ink); }
.panel-paper .display em { color: var(--tan-2); }

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

/* ---- Buttons ------------------------------------------------ */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 30px;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  line-height: 1;
  border: 1px solid var(--rule-2);
  color: var(--cream);
  white-space: nowrap;
  transition: background .35s var(--ease), color .35s var(--ease),
              border-color .35s var(--ease), transform .35s var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn--solid { background: var(--khaki); color: var(--ink-0); border-color: var(--khaki); }
.btn--solid:hover { background: var(--cream); border-color: var(--cream); }
.btn--ghost { background: transparent; color: var(--cream); }
.btn--ghost:hover { border-color: var(--cream); background: rgba(216,216,192,0.04); }
.panel-paper .btn { color: var(--ink); border-color: var(--rule-ink); }
.panel-paper .btn--solid { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.panel-paper .btn--solid:hover { background: var(--tan-2); border-color: var(--tan-2); }
.btn__arrow { transition: transform .35s var(--ease); }
.btn:hover .btn__arrow { transform: translateX(4px); }

/* ---- Logo motif (pre-tinted line-art badge) ----------------- */
.motif {
  background: url("../assets/logo-tan.png") center / contain no-repeat;
}

/* =====================================================================
   PRELOADER
   ===================================================================== */
.preloader {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--ink-0);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 30px;
  transition: opacity .9s var(--ease), visibility .9s var(--ease);
}
.preloader.is-done { opacity: 0; visibility: hidden; }
.preloader__svg {
  width: 150px; height: auto; display: block;
  overflow: visible;
  opacity: 0;
  animation: introMark .7s var(--ease) .1s forwards;
}
/* old-style self-drawing logo: trace the outline, then fill in.
   stroke-dasharray / dashoffset are seeded to the path length by the
   preloader JS, then transitioned to 0 to "draw" the mark. */
.preloader__svg path {
  fill: none;
  stroke: var(--khaki);
  stroke-width: 3.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: stroke-dashoffset 1.9s var(--ease);
}
.preloader__svg.is-drawn path {
  fill: var(--khaki);
  transition: stroke-dashoffset 1.9s var(--ease), fill 1.5s ease .15s;
}
.preloader__word {
  font-family: var(--font-sans);
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.5em; text-transform: uppercase;
  color: var(--tan); padding-left: 0.5em;
  opacity: 0; animation: introMark 1s var(--ease) 1.5s forwards;
}
@keyframes introMark { to { opacity: 1; transform: none; } }

/* =====================================================================
   HEADER
   ===================================================================== */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  padding: 22px var(--pad);
  display: flex; align-items: center; gap: 24px;
  transition: background .4s var(--ease), padding .4s var(--ease),
              border-color .4s var(--ease);
  border-bottom: 1px solid transparent;
}
.nav.is-scrolled {
  background: color-mix(in srgb, var(--cream) 90%, transparent);
  backdrop-filter: blur(10px) saturate(1.1);
  -webkit-backdrop-filter: blur(10px) saturate(1.1);
  padding-top: 14px; padding-bottom: 14px;
  border-bottom-color: rgba(44,42,26,0.16);
}
/* On the cream bar, flip content to ink for contrast */
.nav.is-scrolled .nav__name { color: var(--ink); }
.nav.is-scrolled .nav__mark { background-image: url("../assets/logo-ink.png"); }
.nav.is-scrolled .nav__link { color: var(--ink-soft); }
.nav.is-scrolled .nav__link:hover { color: var(--ink); }
.nav.is-scrolled .nav__cta { color: var(--ink); border-color: rgba(44,42,26,0.30); }
.nav.is-scrolled .nav__cta:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.nav.is-scrolled .nav__toggle span,
.nav.is-scrolled .nav__toggle span::before,
.nav.is-scrolled .nav__toggle span::after { background: var(--ink); }
.nav__brand { display: flex; align-items: center; gap: 12px; }
.nav__mark {
  width: 26px; height: 46px;
  background: url("../assets/logo-cream.png") center / contain no-repeat;
}
.nav__name {
  font-family: var(--font-sans); font-weight: 600;
  font-size: 14px; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--cream); padding-left: 0.28em;
}
.nav__links { display: flex; align-items: center; gap: 6px; margin-left: auto; }
.nav__link {
  padding: 9px 16px;
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--khaki);
  transition: color .3s;
  position: relative;
}
.nav__link::after {
  content: ""; position: absolute; left: 16px; right: 16px; bottom: 4px;
  height: 1px; background: var(--accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s var(--ease);
}
.nav__link:hover { color: var(--cream); }
.nav__link:hover::after { transform: scaleX(1); }
.nav__cta {
  margin-left: 10px;
  padding: 11px 22px; border-radius: 999px;
  border: 1px solid var(--rule-2);
  font-size: 12px; font-weight: 600;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--cream);
  white-space: nowrap;
  transition: background .3s, color .3s, border-color .3s;
}
.nav__cta:hover { background: var(--khaki); color: var(--ink-0); border-color: var(--khaki); }

.nav__toggle { display: none; width: 42px; height: 42px; margin-left: auto;
  align-items: center; justify-content: center; }
.nav__toggle span { width: 22px; height: 1.5px; background: var(--cream); position: relative; display: block; }
.nav__toggle span::before, .nav__toggle span::after {
  content: ""; position: absolute; left: 0; width: 22px; height: 1.5px; background: var(--cream); }
.nav__toggle span::before { top: -7px; } .nav__toggle span::after { top: 7px; }

@media (max-width: 880px) {
  .nav__links {
    position: fixed; inset: 0 0 0 auto; width: min(360px, 84vw);
    background: var(--ink-0);
    flex-direction: column; align-items: stretch; justify-content: center;
    gap: 8px; padding: 80px 40px;
    transform: translateX(100%); transition: transform .5s var(--ease);
    border-left: 1px solid var(--rule);
  }
  .nav__links.is-open { transform: none; }
  .nav__link { padding: 14px 0; font-size: 15px; }
  .nav__link::after { display: none; }
  .nav__cta { margin: 16px 0 0; text-align: center; }
  .nav__toggle { display: inline-flex; }
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero {
  min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 140px 0 64px;
  position: relative; overflow: hidden;
  background:
    radial-gradient(120% 90% at 50% 8%, rgba(166,138,100,0.10), transparent 60%),
    var(--bg);
}
.hero__motif {
  position: absolute; top: 50%; left: 50%;
  width: min(560px, 88vw); height: min(980px, 150vh);
  transform: translate(-50%, -50%);
  background: url("../assets/logo-khaki.png") center / contain no-repeat;
  opacity: 0.07;
  pointer-events: none;
}
.hero__inner { position: relative; z-index: 2; text-align: center; }
.hero__tag { margin-bottom: clamp(28px, 4vw, 44px); }
.hero__title {
  font-family: var(--font-display);
  font-weight: 500;
  text-transform: uppercase;
  font-size: clamp(40px, 7.2vw, 116px);
  line-height: 0.96;
  letter-spacing: 0.004em;
  color: var(--cream);
  max-width: 15ch; margin: 0 auto;
}
.hero__title em { font-style: italic; text-transform: none; color: var(--accent); }
.hero__sub {
  max-width: 50ch; margin: clamp(28px,4vw,40px) auto 0;
  font-size: clamp(16px, 1.5vw, 19px);
  color: var(--khaki); line-height: 1.65;
}
.hero__ctas { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: clamp(34px,4vw,48px); }
.hero__scroll {
  position: absolute; left: 50%; bottom: 30px; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.24em;
  text-transform: uppercase; color: var(--muted); z-index: 2;
}
.hero__scroll i { width: 1px; height: 40px; background: linear-gradient(var(--tan), transparent); position: relative; overflow: hidden; }
.hero__scroll i::after { content:""; position:absolute; top:0; left:0; width:1px; height:14px; background: var(--cream); animation: scrollDot 2.2s var(--ease) infinite; }
@keyframes scrollDot { 0%{transform:translateY(-14px);opacity:0} 30%{opacity:1} 100%{transform:translateY(40px);opacity:0} }

/* small meta row beneath hero */
.hero__meta {
  position: relative; z-index: 2;
  margin-top: clamp(48px, 7vw, 90px);
  display: flex; justify-content: center; gap: clamp(24px,5vw,64px);
  flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--muted);
}
.hero__meta span { display: inline-flex; align-items: center; gap: 8px; }
.hero__meta span::before { content:""; width:4px; height:4px; background: var(--accent); transform: rotate(45deg); }

/* =====================================================================
   PROLOGUE — scroll-revealed quote
   ===================================================================== */
.prologue { text-align: center; }
.prologue__tag { margin-bottom: clamp(40px, 6vw, 72px); }
.prologue__quote {
  font-family: var(--font-display);
  font-weight: 500;
  text-transform: uppercase;
  font-size: clamp(28px, 4.6vw, 64px);
  line-height: 1.16;
  letter-spacing: 0.006em;
  max-width: 19ch; margin: 0 auto;
  color: var(--cream);
}
.prologue__quote .w {
  color: color-mix(in srgb, var(--cream) 16%, transparent);
  transition: color .25s linear;
}
.prologue__quote .w.lit { color: var(--cream); }
.prologue__quote em { font-style: italic; text-transform: none; }
.prologue__quote em.lit { color: var(--accent); }
.prologue__cite {
  margin-top: clamp(40px,5vw,64px);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--muted);
}

/* =====================================================================
   GENERIC SECTION HEAD
   ===================================================================== */
.head { margin-bottom: clamp(48px, 6vw, 84px); }
.head--center { text-align: center; }
.head__tag { margin-bottom: 26px; }
.head__title {
  font-family: var(--font-display); font-weight: 500; text-transform: uppercase;
  font-size: clamp(30px, 4.4vw, 60px); line-height: 1.04; letter-spacing: 0.006em;
  max-width: 18ch;
}
.head--center .head__title { margin: 0 auto; }
.head__title em { font-style: italic; text-transform: none; color: var(--accent); }
.head__lead {
  margin-top: 24px; max-width: 46ch; font-size: clamp(15px,1.4vw,18px);
  color: var(--khaki); line-height: 1.65;
}
.head--center .head__lead { margin-left: auto; margin-right: auto; }
.panel-paper .head__lead { color: var(--ink-soft); }

/* Two-column statement (problem) */
.statement { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(40px, 7vw, 110px); align-items: start; }
.statement__big {
  font-family: var(--font-display); font-weight: 500; text-transform: uppercase;
  font-size: clamp(28px, 3.6vw, 50px); line-height: 1.08; letter-spacing: 0.006em;
}
.statement__big em { font-style: italic; text-transform: none; color: var(--accent); }
.statement__body p { color: var(--khaki); font-size: clamp(15px,1.4vw,18px); }
.statement__body p + p { margin-top: 18px; }
.quote {
  margin: 30px 0; padding: 6px 0 6px 26px;
  border-left: 1.5px solid var(--accent);
  font-family: var(--font-display); font-style: italic; text-transform: none;
  font-size: clamp(20px,2.2vw,28px); line-height: 1.3; color: var(--cream);
}
.quote cite {
  display: block; margin-top: 14px; font-family: var(--font-mono); font-style: normal;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted);
}
@media (max-width: 860px) { .statement { grid-template-columns: 1fr; gap: 36px; } }

/* Numbered diagnostic list */
.diag { display: grid; gap: 0; }
.diag__row {
  display: grid; grid-template-columns: 64px 1fr; gap: clamp(18px,3vw,48px);
  align-items: baseline;
  padding: clamp(22px,2.6vw,34px) 0;
  border-top: 1px solid var(--rule);
}
.diag__row:last-child { border-bottom: 1px solid var(--rule); }
.diag__n { font-family: var(--font-mono); font-size: 13px; color: var(--accent); letter-spacing: 0.1em; }
.diag__t { font-family: var(--font-display); text-transform: none; font-size: clamp(19px,2.1vw,27px); line-height: 1.3; color: var(--cream); font-weight: 500; }
@media (max-width: 620px) { .diag__row { grid-template-columns: 1fr; gap: 8px; } }

/* =====================================================================
   STUDIO (paper) — manifesto with motif
   ===================================================================== */
.studio { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(40px,7vw,100px); align-items: center; }
.studio__motif {
  aspect-ratio: 500 / 880;
  width: 100%; max-width: 300px;
  background: url("../assets/logo-ink.png") center / contain no-repeat;
  opacity: 0.92;
}
.studio__body p { color: var(--ink-soft); font-size: clamp(16px,1.5vw,19px); line-height: 1.6; max-width: 40ch; }
.studio__body p + p { margin-top: 16px; }
@media (max-width: 860px) { .studio { grid-template-columns: 1fr; gap: 32px; } .studio__motif { max-width: 180px; } }

/* =====================================================================
   INTEGRATION MODEL — diagram
   ===================================================================== */
.model {
  border: 1px solid var(--rule);
  border-radius: 4px;
  padding: clamp(28px, 4vw, 64px);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: clamp(20px, 4vw, 56px);
  align-items: center;
  background:
    radial-gradient(80% 120% at 50% 50%, rgba(166,138,100,0.06), transparent 70%),
    var(--bg-2);
}
.model__label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); margin-bottom: 16px; display: block; }
.model__in { display: flex; flex-direction: column; gap: 7px; }
.model__chip {
  font-family: var(--font-mono); font-size: 13px; color: var(--khaki);
  padding: 9px 14px; border: 1px solid var(--rule); border-radius: 3px;
  background: rgba(0,0,0,0.12);
}
.model__core { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 14px; }
.model__node {
  width: 78px; height: 138px;
  background: url("../assets/logo-tan.png") center / contain no-repeat;
}
.model__core span {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--muted); max-width: 16ch; line-height: 1.6;
}
.model__out {
  border: 1px solid var(--rule-2);
  background: rgba(166,138,100,0.08);
  border-radius: 4px; padding: 22px 24px;
}
.model__out strong {
  display: block; font-family: var(--font-display); text-transform: uppercase;
  font-weight: 500; font-size: clamp(20px,2.2vw,28px); color: var(--cream); line-height: 1.1; margin-bottom: 8px;
}
.model__out p { font-size: 14px; color: var(--khaki); line-height: 1.55; }
@media (max-width: 860px) {
  .model { grid-template-columns: 1fr; gap: 28px; }
  .model__core { flex-direction: row; justify-content: center; }
  .model__node { width: 48px; height: 84px; }
}

/* =====================================================================
   SERVICES (paper)
   ===================================================================== */
.services { display: grid; gap: 0; border-top: 1px solid var(--rule-ink); }
.svc {
  display: grid; grid-template-columns: 72px 1.1fr 1.4fr auto;
  gap: clamp(16px,3vw,48px); align-items: center;
  padding: clamp(28px,3.4vw,46px) 0;
  border-bottom: 1px solid var(--rule-ink);
  color: var(--ink);
  transition: padding-left .4s var(--ease);
}
.svc:hover { padding-left: 14px; }
.svc__n { font-family: var(--font-mono); font-size: 13px; color: var(--tan-2); letter-spacing: 0.08em; }
.svc__title { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(24px,3vw,40px); line-height: 1.02; }
.svc__desc { color: var(--ink-soft); font-size: 15px; line-height: 1.55; max-width: 40ch; }
.svc__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.svc__tags span { font-family: var(--font-mono); font-size: 11px; color: var(--ink-soft); border: 1px solid var(--rule-ink); padding: 4px 9px; border-radius: 999px; white-space: nowrap; }
.svc__arrow { font-family: var(--font-display); font-size: 28px; color: var(--tan-2); transition: transform .4s var(--ease); }
.svc:hover .svc__arrow { transform: translate(6px,-6px); }
@media (max-width: 980px) {
  .svc { grid-template-columns: 48px 1fr; }
  .svc__desc { grid-column: 1 / -1; }
  .svc__arrow { display: none; }
}

/* =====================================================================
   PROCESS — timeline steps
   ===================================================================== */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.step {
  padding: clamp(28px,3vw,40px) clamp(24px,2.6vw,36px) clamp(40px,5vw,64px);
  border-left: 1px solid var(--rule);
  position: relative;
}
.step:first-child { border-left: 0; }
.step__n { font-family: var(--font-mono); font-size: 12px; color: var(--accent); letter-spacing: 0.12em; }
.step__dot { position: absolute; top: -4px; left: -4px; width: 7px; height: 7px; background: var(--accent); transform: rotate(45deg); }
.step:first-child .step__dot { left: -4px; }
.step__title { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(22px,2.4vw,32px); margin: 18px 0 14px; line-height: 1.05; color: var(--cream); }
.step__desc { color: var(--khaki); font-size: 15px; line-height: 1.6; }
.step__meta { display: block; margin-top: 22px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--tan); }
.steps__rail { height: 1px; background: var(--rule); margin-bottom: 0; }
@media (max-width: 860px) {
  .steps { grid-template-columns: 1fr; }
  .step { border-left: 0; border-top: 1px solid var(--rule); padding-top: 32px; }
  .step__dot { left: -3px; top: -3px; }
}

/* =====================================================================
   WORK
   ===================================================================== */
.work { display: grid; gap: clamp(20px,2.4vw,28px); }
.work__row { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(20px,2.4vw,28px); }
.case {
  display: flex; flex-direction: column;
  border: 1px solid var(--rule);
  border-radius: 4px;
  overflow: hidden;
  background: var(--bg-2);
  transition: border-color .4s var(--ease), transform .5s var(--ease);
  color: var(--cream);
}
.case:hover { border-color: var(--rule-2); transform: translateY(-4px); }
.case--wide { grid-column: 1 / -1; }
.case__img {
  position: relative; aspect-ratio: 16/9; overflow: hidden;
  background:
    repeating-linear-gradient(135deg, rgba(166,138,100,0.10) 0 2px, transparent 2px 11px),
    var(--ink-0);
  display: flex; align-items: center; justify-content: center;
}
.case--wide .case__img { aspect-ratio: 21/7; }
.case__img .motif {
  width: 60px; height: 106px; background: var(--tan); opacity: 0.5;
}
.case__imgnote {
  position: absolute; bottom: 14px; left: 16px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--muted);
}
.case__body { padding: clamp(24px,2.6vw,36px); display: flex; flex-direction: column; gap: 16px; flex: 1; }
.case__meta { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.case__industry { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.case__status { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
.case__title { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(22px,2.5vw,34px); line-height: 1.05; }
.case--wide .case__title { max-width: 22ch; }
.case__desc { color: var(--khaki); font-size: 15px; line-height: 1.6; max-width: 52ch; }
.case__stats { display: flex; gap: clamp(20px,3vw,44px); margin-top: auto; padding-top: 18px; border-top: 1px solid var(--rule); }
.case__stat-n { display: block; font-family: var(--font-display); text-transform: none; font-size: clamp(22px,2.4vw,30px); color: var(--cream); }
.case__stat-l { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
@media (max-width: 760px) { .work__row, .case--wide { grid-template-columns: 1fr; } }

/* =====================================================================
   STAKES — big statement + stats (deep)
   ===================================================================== */
.stakes { display: grid; grid-template-columns: 1fr 1.1fr; gap: clamp(40px,7vw,110px); align-items: start; }
.stakes__big { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(30px,4vw,58px); line-height: 1.04; letter-spacing: 0.006em; }
.stakes__big em { font-style: italic; text-transform: none; color: var(--accent); }
.stakes__body p { color: var(--khaki); font-size: clamp(15px,1.5vw,18px); line-height: 1.65; max-width: 44ch; }
.stakes__body p + p { margin-top: 18px; }
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(20px,3vw,36px); margin-top: clamp(40px,5vw,60px); }
.stat__n { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(34px,4vw,54px); line-height: 1; color: var(--cream); }
.stat__l { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin-top: 8px; display: block; }
@media (max-width: 860px) { .stakes { grid-template-columns: 1fr; gap: 32px; } .stats { grid-template-columns: 1fr 1fr; } }

/* =====================================================================
   CTA + FOOTER
   ===================================================================== */
.cta { text-align: center; }
.cta__tag { margin-bottom: 30px; }
.cta__title { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(40px,7vw,110px); line-height: 0.96; letter-spacing: 0.006em; color: var(--cream); }
.cta__title em { font-style: italic; text-transform: none; color: var(--accent); }
.cta__sub { max-width: 46ch; margin: 28px auto 40px; color: var(--khaki); font-size: clamp(15px,1.5vw,18px); line-height: 1.65; }

.foot { background: var(--ink-0); border-top: 1px solid var(--rule); padding: clamp(56px,7vw,90px) 0 40px; }
.foot__top { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: clamp(32px,5vw,64px); padding-bottom: clamp(40px,5vw,64px); border-bottom: 1px solid var(--rule); }
.foot__brand { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.foot__mark { width: 24px; height: 42px; background: url("../assets/logo-cream.png") center/contain no-repeat; }
.foot__name { font-family: var(--font-sans); font-weight: 600; font-size: 13px; letter-spacing: 0.28em; text-transform: uppercase; padding-left: 0.28em; }
.foot__tag { color: var(--khaki); max-width: 30ch; font-size: 15px; line-height: 1.6; }
.foot__contact { margin-top: 20px; font-family: var(--font-mono); font-size: 12px; color: var(--muted); line-height: 1.9; }
.foot__contact a { color: var(--khaki); }
.foot__contact a:hover { color: var(--cream); }
.foot__col .foot__heading { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-bottom: 18px; }
.foot__col ul { display: flex; flex-direction: column; gap: 11px; }
.foot__col a { font-size: 14px; color: var(--khaki); transition: color .3s; }
.foot__col a:hover { color: var(--cream); }
.foot__base { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding-top: 26px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--muted); }
.foot__base ul { display: flex; gap: 22px; }
.foot__base a:hover { color: var(--khaki); }
@media (max-width: 760px) { .foot__top { grid-template-columns: 1fr; gap: 36px; } .foot__base { flex-direction: column; align-items: flex-start; gap: 14px; } }

/* =====================================================================
   SCROLL REVEAL
   ===================================================================== */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal[data-delay="1"] { transition-delay: .08s; }
.reveal[data-delay="2"] { transition-delay: .16s; }
.reveal[data-delay="3"] { transition-delay: .24s; }
.reveal[data-delay="4"] { transition-delay: .32s; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .hero__scroll i::after { animation: none; }
  .prologue__quote .w { color: var(--cream); }
  * { scroll-behavior: auto; }
}

/* =====================================================================
   TWEAKS PANEL
   ===================================================================== */
.tw {
  position: fixed; right: 18px; bottom: 18px; z-index: 9500;
  width: 290px; background: var(--ink-0);
  border: 1px solid var(--rule-2); border-radius: 8px;
  box-shadow: 0 24px 60px rgba(0,0,0,0.5);
  display: none; overflow: hidden;
}
.tw.is-open { display: block; }
.tw__head { display: flex; align-items: center; justify-content: space-between; padding: 13px 15px; border-bottom: 1px solid var(--rule); cursor: grab; }
.tw__title { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--tan); }
.tw__close { width: 22px; height: 22px; color: var(--khaki); display: inline-flex; align-items: center; justify-content: center; border-radius: 5px; }
.tw__close:hover { background: rgba(216,216,192,0.08); color: var(--cream); }
.tw__body { padding: 16px 15px 18px; display: flex; flex-direction: column; gap: 16px; }
.tw__label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted); display: block; margin-bottom: 8px; }
.tw__seg { display: flex; gap: 4px; padding: 3px; background: rgba(0,0,0,0.25); border: 1px solid var(--rule); border-radius: 7px; }
.tw__seg button { flex: 1; padding: 7px 6px; border-radius: 5px; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--khaki); font-weight: 500; }
.tw__seg button.on { background: var(--khaki); color: var(--ink-0); }
.tw__range { -webkit-appearance: none; appearance: none; width: 100%; height: 3px; border-radius: 999px; background: var(--rule-2); outline: none; margin: 4px 0 2px; }
.tw__range::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 15px; height: 15px; border-radius: 999px; background: var(--accent); cursor: pointer; border: 0; box-shadow: 0 1px 3px rgba(0,0,0,0.4); }
.tw__range::-moz-range-thumb { width: 15px; height: 15px; border-radius: 999px; background: var(--accent); cursor: pointer; border: 0; }
.tw__val { float: right; color: var(--khaki); letter-spacing: 0.08em; }
.tw__sw { display: flex; gap: 9px; }
.tw__sw button { width: 30px; height: 30px; border-radius: 999px; border: 2px solid var(--rule); position: relative; transition: transform .2s, border-color .2s; }
.tw__sw button:hover { transform: scale(1.08); }
.tw__sw button.on { border-color: var(--cream); transform: scale(1.05); }

/* ============================================================
   OLIVE + CREAM THEME  —  alternative color mapping
   #2D3520 dark olive as the DOMINANT color · #E6E3D0 cream as the
   main accent. Sage minimized. The few light moments (Studio /
   Services) are cream cards; everything else is olive.
   ============================================================ */
:root {
  --bg:       #313821;   /* dark olive ground (main dark) */
  --bg-2:     #3a4129;   /* raised olive (cards / panels) */
  --bg-olive: #39412a;   /* process band (a step off base) */
  --ink-0:    #262d18;   /* deepest olive band (stakes / footer) */

  --paper:    #e6e3d0;   /* CREAM — alternating light sections */
  --paper-2:  #dcdac4;

  /* foreground on dark olive */
  --cream:    #dedfc8;   /* primary text & headlines (soft cream) */
  --khaki:    #b3b896;   /* secondary text */
  --tan:      #cdcfb0;   /* eyebrows / soft labels */
  --tan-2:    #b9bd9c;
  --muted:    #8b9070;   /* dim mono labels */
  --faint:    rgba(230,227,208,0.16);
  --rule:     rgba(230,227,208,0.16);
  --rule-2:   rgba(230,227,208,0.30);

  --accent:   #e6e3d0;   /* CREAM — main accent (emphasis · marks · fills) */
  --accent-2: #f2f0e2;

  /* ink = dark olive, used on the cream paper cards */
  --ink:        #2d3520;
  --ink-soft:   rgba(45,53,32,0.72);
  --ink-faint:  rgba(45,53,32,0.46);
  --rule-ink:   rgba(45,53,32,0.16);
}

/* Ground tweak — olive family (no espresso) */
[data-ground="forest"]   { --bg:#313821; --bg-2:#3a4129; --ink-0:#262d18; }
[data-ground="olive"]    { --bg:#373f25; --bg-2:#404830; --ink-0:#2a3119; }
[data-ground="espresso"] { --bg:#2c331d; --bg-2:#353c25; --ink-0:#222814; }

/* Accent tweak — cream / sage / gold */
[data-accent="tan"]  { --accent:#e6e3d0; --accent-2:#f2f0e2; }   /* cream (default) */
[data-accent="sage"] { --accent:#c2c5aa; --accent-2:#d3d5bd; }
[data-accent="gold"] { --accent:#c9b07a; --accent-2:#d8c290; }

/* Logo tints */
.nav__mark { background-image: url("../assets/logo-cream.png"); }
.hero__motif { background-image: url("../assets/logo-cream.png"); opacity: 0.05; }
.studio__motif { background-image: url("../assets/logo-olive.png"); }   /* dark badge on cream card */
.model__node { background-image: url("../assets/logo-cream.png"); }
.case__img .motif { background-image: url("../assets/logo-cream.png"); }

/* CREAM alternating sections — re-scope tokens so every would-be-cream
   element reads as dark olive on the cream ground. */
.panel-paper {
  background: var(--paper);
  color: #2a3119;
  --cream:#2a3119;
  --khaki:#495235;
  --tan:#677150;
  --tan-2:#5e6743;
  --muted:#6f7452;
  --accent:#677150;
  --accent-2:#586541;
  --rule:rgba(42,49,25,0.16);
  --rule-2:rgba(42,49,25,0.30);
  --ink:#2a3119;
  --ink-soft:rgba(42,49,25,0.72);
  --ink-faint:rgba(42,49,25,0.48);
  --rule-ink:rgba(42,49,25,0.16);
}
.panel-paper .tag, .svc__n, .svc__arrow { color: var(--tan); }
.panel-paper .head__title em, .panel-paper .display em { color: var(--accent); }
.panel-paper .btn { color: var(--ink); border-color: var(--rule-ink); }
.panel-paper .btn--solid { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.panel-paper .btn--solid:hover { background: #495235; border-color: #495235; }

/* Buttons — cream primary on dark olive */
.btn { color: var(--cream); border-color: var(--rule-2); }
.btn--solid { background: var(--accent); color: var(--ink-0); border-color: var(--accent); }
.btn--solid:hover { background: var(--accent-2); border-color: var(--accent-2); color: var(--ink-0); }
.btn--ghost { color: var(--cream); }
.btn--ghost:hover { border-color: var(--cream); background: rgba(230,227,208,0.05); }
.panel-paper .btn { color: var(--ink); border-color: var(--rule-ink); }
.panel-paper .btn--solid { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.panel-paper .btn--solid:hover { background: #444f30; border-color: #444f30; }

/* Nav — dark olive scrolled bar with cream content */
.nav__cta:hover { background: var(--accent); color: var(--ink-0); border-color: var(--accent); }
.nav.is-scrolled { background: color-mix(in srgb, var(--bg) 88%, transparent); border-bottom-color: var(--rule); }
.nav.is-scrolled .nav__name { color: var(--cream); }
.nav.is-scrolled .nav__mark { background-image: url("../assets/logo-cream.png"); }
.nav.is-scrolled .nav__link { color: var(--khaki); }
.nav.is-scrolled .nav__link:hover { color: var(--cream); }
.nav.is-scrolled .nav__cta { color: var(--cream); border-color: var(--rule-2); }
.nav.is-scrolled .nav__cta:hover { background: var(--accent); color: var(--ink-0); border-color: var(--accent); }
.nav.is-scrolled .nav__toggle span,
.nav.is-scrolled .nav__toggle span::before,
.nav.is-scrolled .nav__toggle span::after { background: var(--cream); }

/* Tweak panel on dark */
.tw { background: var(--ink-0); border-color: var(--rule-2); box-shadow: 0 24px 60px rgba(0,0,0,0.45); }
.tw__seg { background: rgba(0,0,0,0.22); }
.tw__seg button.on { background: var(--accent); color: var(--ink-0); }
.tw__close:hover { background: rgba(230,227,208,0.08); }

/* ============================================================
   INTERIOR PAGES — shared components
   ============================================================ */
.nav__link.is-active { color: var(--cream); }
.nav__link.is-active::after { transform: scaleX(1); }

/* Page intro (interior hero) */
.page-intro { padding-top: clamp(150px, 21vh, 250px); padding-bottom: clamp(56px,7vw,96px); }
.page-intro__crumb { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-bottom: 26px; }
.page-intro__crumb a { color: var(--muted); }
.page-intro__crumb a:hover { color: var(--cream); }
.page-intro__title { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(40px, 7.2vw, 108px); line-height: 0.95; letter-spacing: 0.006em; max-width: 17ch; color: var(--cream); }
.page-intro__title em { font-style: italic; text-transform: none; color: var(--accent); }
.page-intro__lead { margin-top: 30px; max-width: 50ch; font-size: clamp(16px,1.6vw,21px); color: var(--khaki); line-height: 1.6; }

/* Generic prose (legal / long copy) */
.prose { max-width: 64ch; }
.prose h2 { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(22px,2.4vw,30px); margin: 44px 0 16px; color: var(--cream); }
.prose h3 { font-family: var(--font-sans); font-weight: 700; font-size: 16px; letter-spacing: 0.02em; margin: 26px 0 8px; color: var(--cream); }
.prose p, .prose li { color: var(--khaki); line-height: 1.7; margin-bottom: 14px; }
.prose ul { padding-left: 20px; list-style: disc; }
.prose .updated { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }

/* For / not-for two-column */
.fit { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,5vw,72px); }
.fit__col h3 { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(21px,2.3vw,29px); margin-bottom: 8px; color: var(--cream); }
.fit__col > p { color: var(--khaki); font-size: 14px; margin-bottom: 18px; }
.fit__col ul { display: flex; flex-direction: column; }
.fit__col li { display: grid; grid-template-columns: 20px 1fr; gap: 12px; padding: 15px 0; border-top: 1px solid var(--rule); font-size: clamp(14px,1.4vw,16px); color: var(--khaki); align-items: start; }
.fit__col li:last-child { border-bottom: 1px solid var(--rule); }
.fit__col li .mk { color: var(--accent); font-family: var(--font-mono); font-size: 13px; line-height: 1.5; }
.fit--no li .mk { color: var(--muted); }
@media (max-width: 760px) { .fit { grid-template-columns: 1fr; gap: 36px; } }

/* Feature rows (alternating text + motif/well) */
.feat { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(32px,6vw,90px); align-items: center; }
.feat + .feat { margin-top: clamp(56px,7vw,104px); }
.feat--rev > :first-child { order: 2; }
.feat__n { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; color: var(--accent); }
.feat__title { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(26px,3.2vw,44px); line-height: 1.04; margin: 14px 0 18px; color: var(--cream); }
.feat__title em { font-style: italic; text-transform: none; color: var(--accent); }
.feat__body { color: var(--khaki); font-size: clamp(15px,1.5vw,18px); line-height: 1.65; max-width: 42ch; }
.feat__body p + p { margin-top: 14px; }
.feat__list { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 20px; }
.feat__list span { font-family: var(--font-mono); font-size: 11px; color: var(--khaki); border: 1px solid var(--rule); padding: 5px 11px; border-radius: 999px; }
.feat__well { aspect-ratio: 5/4; border: 1px solid var(--rule); border-radius: 4px; background: repeating-linear-gradient(135deg, rgba(140,140,110,0.10) 0 2px, transparent 2px 12px), var(--bg-2); display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; }
.feat__well .motif { width: 64px; height: 113px; opacity: 0.6; }
.feat__well .case__imgnote { position: absolute; bottom: 14px; left: 16px; }
@media (max-width: 860px) { .feat { grid-template-columns: 1fr; gap: 28px; } .feat--rev > :first-child { order: 0; } }

/* Founders / bios */
.bios { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,64px); }
.bio__portrait { aspect-ratio: 4/5; border: 1px solid var(--rule); border-radius: 4px; background: repeating-linear-gradient(135deg, rgba(140,140,110,0.10) 0 2px, transparent 2px 13px), var(--bg-2); display: flex; align-items: flex-end; padding: 22px; position: relative; overflow: hidden; margin-bottom: 22px; }
.bio__portrait .motif { position: absolute; inset: 0; margin: auto; width: 78px; height: 138px; opacity: 0.5; }
.bio__pmeta { position: relative; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.bio__name { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: clamp(24px,2.6vw,34px); line-height: 1.05; color: var(--cream); }
.bio__role { font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin: 8px 0 14px; }
.bio__body p { color: var(--khaki); font-size: 15px; line-height: 1.65; }
.bio__body p + p { margin-top: 12px; }
@media (max-width: 760px) { .bios { grid-template-columns: 1fr; gap: 48px; } }

/* Contact form */
.contact { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(40px,6vw,88px); align-items: start; }
.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 24px; }
.field label { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); }
.field input, .field textarea, .field select { background: transparent; border: 0; border-bottom: 1px solid var(--rule-2); padding: 11px 0; font-size: 17px; color: var(--cream); font-family: var(--font-sans); outline: none; border-radius: 0; transition: border-color .25s; }
.field input:focus, .field textarea:focus, .field select:focus { border-bottom-color: var(--accent); }
.field textarea { resize: vertical; min-height: 120px; line-height: 1.5; }
.field option { color: #2a3119; }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.chips label { display: inline-flex; align-items: center; padding: 9px 15px; border: 1px solid var(--rule-2); border-radius: 999px; font-size: 13px; font-family: var(--font-mono); color: var(--khaki); cursor: pointer; transition: all .2s; }
.chips input { position: absolute; opacity: 0; pointer-events: none; }
.chips label:has(input:checked) { background: var(--accent); color: var(--ink-0); border-color: var(--accent); }
.contact__aside { border: 1px solid var(--rule); border-radius: 4px; padding: 30px; background: var(--bg-2); }
.contact__aside h4 { font-family: var(--font-display); text-transform: uppercase; font-weight: 500; font-size: 22px; color: var(--cream); margin-bottom: 10px; }
.contact__aside p { color: var(--khaki); font-size: 15px; line-height: 1.6; }
.contact__aside dl { margin-top: 26px; display: flex; flex-direction: column; gap: 18px; }
.contact__aside dt { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); margin-bottom: 5px; }
.contact__aside dd { color: var(--cream); font-size: 15px; }
.contact__aside a { color: var(--accent); }
@media (max-width: 860px) { .contact { grid-template-columns: 1fr; gap: 36px; } }
