/* ============================================================
   DSTE v2 — Brutalist · Multicolor Accent System
   ============================================================ */
:root {
  /* Monochrome Base — warm-tinted neutrals for editorial depth */
  --color-black: #0C0B09;
  --color-near-black: #161410;
  --color-ink: #1C1A16;
  --color-graphite: #2C2924;
  --color-charcoal: #3C3830;
  --color-iron: #5C5750;
  --color-steel: #7C786E;
  --color-stone: #A09890;
  --color-fog: #C8C4BC;
  --color-mist: #E4E0D8;
  --color-paper: #E9E4DB;
  --color-bone: #F0EDE8;
  --color-white: #FDFCFA;

  /* MULTI-ACCENT PALETTE — refined for monochrome backgrounds.
     Saturation/lightness tuned so each pops on bone (#F5F4F1) and on black. */
  --c-orange:   #FF3D14;
  --c-yellow:   #F4C800;
  --c-acid:     #C8EE16;
  --c-mint:     #00C98D;
  --c-cyan:     #00A6F5;
  --c-iceblue:  #5BC4F5;
  --c-cobalt:   #1B2BE8;
  --c-violet:   #7C36F0;
  --c-magenta:  #F71B85;
  --c-red:      #DC1620;
  --c-cream:    #F4EFE6;
  --c-sand:     #E8DFC8;

  /* Section theme — overridden per-section via [data-theme-section] */
  --theme-bg: var(--color-bone);
  --theme-fg: var(--color-black);
  --theme-accent: var(--c-orange);
  --theme-accent-fg: var(--color-black);
  --theme-rule: var(--color-black);
  --theme-rule-soft: rgba(10,10,10,0.14);

  /* Typography */
  --font-display: "Archivo", "Inter Tight", "Helvetica Neue", sans-serif;
  --font-ui:      "Inter Tight", "Inter", sans-serif;
  --font-body:    "Inter Tight", "Inter", sans-serif;
  --font-body-en: "Helvetica Neue", Helvetica, Arial, sans-serif;
  --font-body-jp: "Noto Sans JP", sans-serif;
  --font-mono:    "JetBrains Mono", "IBM Plex Mono", ui-monospace, monospace;

  /* Heavy display weights */
  --fw-display: 900;
  --fw-display-alt: 800;
  --fw-bold: 700;
  --fw-medium: 500;
  --fw-regular: 400;

  /* Type scale — bigger, tighter */
  --fs-mega: clamp(96px, 22vw, 380px);
  --fs-display: clamp(80px, 16vw, 280px);
  --fs-h1: clamp(56px, 9vw, 160px);
  --fs-h2: clamp(40px, 5.5vw, 96px);
  --fs-h3: clamp(28px, 3vw, 56px);
  --fs-h4: clamp(20px, 1.6vw, 28px);
  --fs-body: 16px;
  --fs-body-sm: 14px;
  --fs-caption: 12px;

  /* Tracking — tuned for 900-weight Archivo */
  --track-mega: -0.055em;
  --track-tightest: -0.038em;
  --track-tight: -0.018em;
  --track-wide: 0.04em;
  --track-wider: 0.1em;
  --track-widest: 0.18em;

  /* Line heights — tighter on display, breathing room on body */
  --lh-mega: 0.84;
  --lh-display: 0.86;
  --lh-h1: 0.88;

  /* Layout */
  --nav-w: 240px;
  --gutter-lg: 64px;
  --gutter-xl: 112px;
  --space-section: clamp(96px, 12vw, 192px);

  /* Motion */
  --ease: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --dur-fast: 180ms;
  --dur: 320ms;

  /* Border weights — chunky */
  --bw-hair: 1px;
  --bw-thin: 2px;
  --bw-thick: 3px;
  --bw-chunky: 6px;
}

/* SECTION THEMES — backgrounds stay monochrome.
   Only --theme-accent changes per section; --theme-bg / --theme-fg / --theme-rule remain neutral. */
[data-theme-section]           { --theme-bg: var(--color-bone);    --theme-fg: var(--color-black); --theme-rule: var(--color-black); --theme-accent-fg: var(--color-black); }
[data-theme-section="bone"]    { --theme-bg: var(--color-bone); }
[data-theme-section="paper"]   { --theme-bg: var(--color-paper);   --theme-accent: var(--c-cobalt);  }
[data-theme-section="cream"]   { --theme-bg: var(--color-bone);    --theme-accent: var(--c-magenta); }
[data-theme-section="sand"]    { --theme-bg: var(--color-paper);   --theme-accent: var(--c-cobalt);  }

[data-theme-section="orange"]  { --theme-accent: var(--c-orange);  }
[data-theme-section="yellow"]  { --theme-accent: var(--c-yellow);  }
[data-theme-section="acid"]    { --theme-accent: var(--c-acid);    }
[data-theme-section="mint"]    { --theme-accent: var(--c-mint);    }
[data-theme-section="cyan"]    { --theme-accent: var(--c-cyan);    }
[data-theme-section="iceblue"] { --theme-accent: var(--c-iceblue); }
[data-theme-section="cobalt"]  { --theme-accent: var(--c-cobalt);  --theme-accent-fg: var(--color-bone); }
[data-theme-section="violet"]  { --theme-accent: var(--c-violet);  --theme-accent-fg: var(--color-bone); }
[data-theme-section="magenta"] { --theme-accent: var(--c-magenta); --theme-accent-fg: var(--color-bone); }
[data-theme-section="red"]     { --theme-accent: var(--c-red);     --theme-accent-fg: var(--color-bone); }

/* Dark monochrome sections — bg flips to black, fg to bone, accent stays vivid */
[data-theme-section="black"],
[data-theme-section="ink"] {
  --theme-bg: var(--color-black);
  --theme-fg: var(--color-bone);
  --theme-rule: rgba(240,237,232,0.2);
  --theme-accent: var(--c-accent-primary, var(--c-orange));
  --theme-accent-fg: var(--color-black);
}
[data-theme-section="ink"]    { --theme-bg: var(--color-ink); }

/* Section-colors OFF — flatten everything to a single accent */
[data-section-colors="false"] [data-theme-section]:not([data-theme-section="black"]):not([data-theme-section="ink"]) {
  --theme-bg: var(--color-bone);
  --theme-fg: var(--color-black);
  --theme-rule: var(--color-black);
  --theme-accent: var(--c-accent-primary, var(--c-orange));
  --theme-accent-fg: var(--color-black);
}
[data-section-colors="false"] [data-theme-section="black"],
[data-section-colors="false"] [data-theme-section="ink"] {
  --theme-accent: var(--c-accent-primary, var(--c-orange));
}

/* PAGE-LEVEL THEMES — applied to <main> via [data-page-theme] */
[data-page-theme] { --theme-bg: var(--color-bone); --theme-fg: var(--color-black); --theme-rule: var(--color-black); }
[data-page-theme="home"]    { --theme-accent: var(--c-accent-primary, var(--c-orange)); }
[data-page-theme="about"]   { --theme-accent: var(--c-iceblue); }
[data-page-theme="service"] { --theme-accent: var(--c-yellow); }
[data-page-theme="company"] { --theme-accent: var(--c-cobalt); }
[data-page-theme="news"]    { --theme-accent: var(--c-magenta); }
[data-page-theme="contact"] { --theme-accent: var(--c-mint); }
[data-page-theme="recruit"] { --theme-accent: var(--c-violet); --theme-accent-fg: var(--color-bone); }
[data-page-theme="recruit"] .job:hover,
[data-page-theme="recruit"] .card:hover { color: var(--color-bone); }
[data-page-theme="styleguide"] { --theme-accent: var(--c-accent-primary, var(--c-orange)); }

/* When section-colors=OFF, force ALL [data-page-theme] and [data-theme-section]
   variants to fall through to the primary accent. */
[data-section-colors="false"] [data-page-theme="home"],
[data-section-colors="false"] [data-page-theme="about"],
[data-section-colors="false"] [data-page-theme="service"],
[data-section-colors="false"] [data-page-theme="company"],
[data-section-colors="false"] [data-page-theme="news"],
[data-section-colors="false"] [data-page-theme="contact"],
[data-section-colors="false"] [data-page-theme="recruit"],
[data-section-colors="false"] [data-page-theme="styleguide"],
[data-section-colors="false"] [data-theme-section="bone"],
[data-section-colors="false"] [data-theme-section="paper"],
[data-section-colors="false"] [data-theme-section="cream"],
[data-section-colors="false"] [data-theme-section="sand"],
[data-section-colors="false"] [data-theme-section="orange"],
[data-section-colors="false"] [data-theme-section="yellow"],
[data-section-colors="false"] [data-theme-section="acid"],
[data-section-colors="false"] [data-theme-section="mint"],
[data-section-colors="false"] [data-theme-section="cyan"],
[data-section-colors="false"] [data-theme-section="cobalt"],
[data-section-colors="false"] [data-theme-section="violet"],
[data-section-colors="false"] [data-theme-section="magenta"],
[data-section-colors="false"] [data-theme-section="red"] {
  --theme-accent: var(--c-accent-primary, var(--c-orange));
  --theme-accent-fg: var(--color-black);
}

/* ============================================================
   Reset / Base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-rendering: optimizeLegibility; }
body {
  font-family: var(--font-body-en);
  font-size: var(--fs-body);
  line-height: 1.5;
  color: var(--color-black);
  background: var(--color-bone);
  font-feature-settings: "ss01", "tnum";
  overflow-x: hidden;
}

/* Background tone override (Tweaks → "Background tone") */
html[data-bg-tone="bone"] body { background: var(--color-bone); color: var(--color-black); }
html[data-bg-tone="paper"] body { background: var(--color-paper); color: var(--color-black); }
html[data-bg-tone="white"] body { background: #ffffff; color: var(--color-black); }
html[data-bg-tone="ink"] body { background: var(--color-black); color: var(--color-bone); }
html[data-bg-tone="ink"] [data-theme-section]:not([data-theme-section="black"]):not([data-theme-section="ink"]) {
  --theme-bg: transparent;
  --theme-fg: var(--color-bone);
  --theme-rule: rgba(240,237,232,0.14);
  --theme-accent-fg: var(--color-black);
}
html[data-bg-tone="ink"] [data-page-theme] {
  --theme-bg: transparent;
  --theme-fg: var(--color-bone);
  --theme-rule: rgba(240,237,232,0.14);
}

/* Per-page accent override (Tweaks → "Page accent") — wins over section accents on that page */
html[data-page-accent-override="true"] [data-page-theme],
html[data-page-accent-override="true"] [data-theme-section] {
  --theme-accent: var(--page-accent-override);
}
html { overflow-x: hidden; }
.app, .stage, .page, .section { max-width: 100%; overflow-x: clip; }
img, svg, video { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; padding: 0; }
a { color: inherit; text-decoration: none; }
input, textarea, select { font: inherit; color: inherit; }
::selection { background: var(--c-yellow); color: var(--color-black); }

/* ============================================================
   Type utilities
   ============================================================ */
.t-mega    { font-family: var(--font-display); font-weight: var(--fw-display); font-size: var(--fs-mega); line-height: 0.82; letter-spacing: var(--track-mega); }
.t-display { font-family: var(--font-display); font-weight: var(--fw-display); font-size: var(--fs-display); line-height: 0.84; letter-spacing: var(--track-mega); }
.t-h1      { font-family: var(--font-display); font-weight: var(--fw-display); font-size: var(--fs-h1); line-height: 0.86; letter-spacing: var(--track-tightest); }
.t-h2      { font-family: var(--font-display); font-weight: var(--fw-display-alt); font-size: var(--fs-h2); line-height: 0.92; letter-spacing: var(--track-tightest); }
.t-h3      { font-family: var(--font-display); font-weight: var(--fw-display-alt); font-size: var(--fs-h3); line-height: 1.0; letter-spacing: var(--track-tight); }
.t-h4      { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-h4); line-height: 1.1; letter-spacing: var(--track-tight); }
.t-mono    { font-family: var(--font-mono); }
.t-eyebrow { font-family: var(--font-mono); font-size: var(--fs-caption); text-transform: uppercase; letter-spacing: var(--track-widest); font-weight: 500; }
.t-label   { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: var(--track-wider); font-weight: 500; }
.t-italic  { font-style: italic; }

.accent-bg { background: var(--theme-accent); color: var(--theme-accent-fg); }
.accent-fg { color: var(--theme-accent); }

/* ============================================================
   SIDE NAV — chunky, brutalist
   ============================================================ */
.sidenav {
  position: fixed; top: 0; left: 0; bottom: 0;
  width: var(--nav-w);
  background: var(--color-black);
  color: var(--color-bone);
  z-index: 50;
  display: flex; flex-direction: column;
  padding: 24px 20px 20px;
  border-right: var(--bw-thin) solid var(--color-black);
  transition: transform var(--dur) var(--ease);
}
.sidenav__brand { display: flex; flex-direction: column; gap: 6px; margin-bottom: 40px; cursor: pointer; }
.sidenav__logo {
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: 36px; line-height: 0.85;
  letter-spacing: var(--track-mega);
  color: var(--color-bone);
}
.sidenav__logo em { color: var(--theme-accent); font-style: normal; }
.sidenav__tag {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  color: var(--color-stone); line-height: 1.4;
}

.sidenav__list { list-style: none; padding: 0; margin: 0; flex: 1; }
.sidenav__link {
  display: flex; align-items: baseline; gap: 10px;
  padding: 12px 0;
  border-top: 1px solid rgba(240,237,232,0.18);
  font-family: var(--font-display);
  font-weight: var(--fw-display-alt);
  font-size: 22px; line-height: 1;
  letter-spacing: var(--track-tightest);
  color: var(--color-bone);
  position: relative;
  transition: color var(--dur-fast), padding var(--dur-fast);
  cursor: pointer;
}
.sidenav__item:last-child .sidenav__link { border-bottom: 1px solid rgba(240,237,232,0.18); }
.sidenav__link:hover { padding-left: 8px; color: var(--theme-accent); }
.sidenav__link[data-active="true"] { color: var(--theme-accent); }
.sidenav__link[data-active="true"]::before {
  content: "▸"; position: absolute; left: -4px; color: var(--theme-accent);
}
.sidenav__num {
  font-family: var(--font-mono); font-weight: 400; font-size: 10px;
  letter-spacing: var(--track-wide); color: var(--color-stone); min-width: 22px;
}

.sidenav__foot { margin-top: auto; padding-top: 20px; display: grid; gap: 14px; }
.sidenav__meta {
  font-family: var(--font-mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  color: var(--color-stone); line-height: 1.6;
}
.sidenav__locale { display: flex; gap: 4px; }
.sidenav__locale button {
  padding: 4px 10px;
  font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: var(--track-wide);
  border: 1px solid var(--color-stone);
  color: var(--color-stone);
}
.sidenav__locale button[data-active="true"] {
  background: var(--theme-accent); color: var(--color-black); border-color: var(--theme-accent);
}

/* TOP variant */
.sidenav[data-variant="top"] {
  width: 100%; height: 64px; bottom: auto;
  flex-direction: row; align-items: center;
  padding: 0 20px; border-right: 0;
  border-bottom: var(--bw-thin) solid var(--color-bone);
}
.sidenav[data-variant="top"] .sidenav__brand { margin: 0 32px 0 0; }
.sidenav[data-variant="top"] .sidenav__logo { font-size: 22px; }
.sidenav[data-variant="top"] .sidenav__tag { display: none; }
.sidenav[data-variant="top"] .sidenav__list { display: flex; flex: 1; gap: 0; align-items: stretch; }
.sidenav[data-variant="top"] .sidenav__link { border: 0; padding: 0 16px; font-size: 13px; height: 64px; align-items: center; }
.sidenav[data-variant="top"] .sidenav__link[data-active="true"]::before { display: none; }
.sidenav[data-variant="top"] .sidenav__link[data-active="true"] { background: var(--theme-accent); color: var(--color-black); }
.sidenav[data-variant="top"] .sidenav__foot { margin-top: 0; padding-top: 0; flex-direction: row; align-items: center; display: flex; gap: 12px; }
.sidenav[data-variant="top"] .sidenav__meta { display: none; }
.sidenav[data-variant="top"] .sidenav__num { display: none; }
.app[data-nav="top"] .stage { padding-left: 0; padding-top: 64px; }

/* OVERLAY variant */
.sidenav[data-variant="overlay"] {
  width: 100%; transform: translateX(-100%); border-right: 0;
}
.sidenav[data-variant="overlay"][data-open="true"] { transform: translateX(0); }
.sidenav[data-variant="overlay"] .sidenav__list { display: grid; gap: 0; }
.sidenav[data-variant="overlay"] .sidenav__link { font-size: clamp(56px, 10vw, 120px); padding: 16px 0; font-weight: var(--fw-display); }
.app[data-nav="overlay"] .stage { padding-left: 0; }
.app[data-nav="overlay"] .menu-trigger { display: flex; }

.menu-trigger {
  display: none; position: fixed; top: 16px; right: 16px;
  z-index: 100; width: 64px; height: 64px;
  background: var(--c-orange); color: var(--color-black);
  align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  font-weight: 700;
  border: var(--bw-thin) solid var(--color-black);
}

/* ============================================================
   Stage / Pages
   ============================================================ */
.app { min-height: 100vh; }
.stage { padding-left: var(--nav-w); min-height: 100vh; position: relative; }
.page { min-height: 100vh; animation: pageIn 600ms var(--ease-out); }
@keyframes pageIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

.section {
  background: var(--theme-bg);
  color: var(--theme-fg);
  padding: var(--space-section) var(--gutter-lg);
  border-bottom: var(--bw-thin) solid var(--theme-rule);
  position: relative;
}
.section--lg { padding: calc(var(--space-section) * 0.85) var(--gutter-lg); }
.section--xl { padding: calc(var(--space-section) * 1.25) var(--gutter-lg); }
.section--flush { padding: 0; }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 18px 26px;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 14px;
  letter-spacing: var(--track-wide);
  border: var(--bw-thin) solid var(--theme-fg);
  background: var(--theme-fg); color: var(--theme-bg);
  text-transform: uppercase;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease), transform var(--dur-fast) var(--ease);
  cursor: pointer; position: relative;
  overflow: hidden;
  isolation: isolate;
}
.btn::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--theme-accent);
  transform: translateY(101%);
  transition: transform var(--dur) var(--ease-out);
  z-index: -1;
}
.btn:hover::before { transform: translateY(0); }
.btn:hover { background: transparent; color: var(--theme-accent-fg); border-color: var(--theme-fg); }
.btn--ghost { background: transparent; color: var(--theme-fg); }
.btn--ghost::before { background: var(--theme-fg); }
.btn--ghost:hover { color: var(--theme-bg); border-color: var(--theme-fg); }
.btn--accent { background: var(--theme-accent); color: var(--theme-accent-fg); border-color: var(--theme-fg); }
.btn--accent::before { background: var(--theme-fg); }
.btn--accent:hover { color: var(--theme-bg); border-color: var(--theme-fg); }
.btn--sm { padding: 10px 16px; font-size: 11px; }
.btn--lg { padding: 24px 36px; font-size: 16px; }
.btn--block { width: 100%; justify-content: space-between; }
.btn .arrow { display: inline-block; transition: transform var(--dur-fast); }
.btn:hover .arrow { transform: translateX(4px); }
.btn[disabled] { opacity: 0.4; cursor: not-allowed; pointer-events: none; }

.btn--link {
  background: none; border: 0; padding: 6px 0;
  border-bottom: var(--bw-thin) solid var(--theme-fg);
  color: var(--theme-fg); text-transform: uppercase;
  font-size: 12px; letter-spacing: var(--track-wider);
  font-family: var(--font-mono); font-weight: 500;
  position: relative;
  background-image: linear-gradient(var(--theme-accent), var(--theme-accent));
  background-repeat: no-repeat;
  background-size: 0% 100%;
  background-position: 0 0;
  transition: background-size var(--dur) var(--ease-out), color var(--dur) var(--ease-out);
}
.btn--link:hover { color: var(--theme-accent-fg); background-size: 100% 100%; border-color: var(--theme-accent); padding-left: 8px; padding-right: 8px; }

/* ============================================================
   Inputs
   ============================================================ */
.field { display: grid; gap: 8px; }
.field__label {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  color: var(--theme-fg); opacity: 0.6;
  display: flex; justify-content: space-between;
}
.field__label .req { color: var(--theme-accent); opacity: 1; }
.field__input,
.field__select,
.field__textarea {
  width: 100%; padding: 16px 16px;
  border: var(--bw-thin) solid var(--theme-fg);
  background: transparent;
  font-family: var(--font-display); font-weight: 500;
  font-size: 18px; color: var(--theme-fg);
  outline: none;
  transition: background var(--dur-fast);
}
.field__input:focus,
.field__select:focus,
.field__textarea:focus { background: var(--theme-accent); }
.field__textarea { min-height: 140px; resize: vertical; }
.field__select { appearance: none; background-image: linear-gradient(45deg, transparent 50%, currentColor 50%), linear-gradient(135deg, currentColor 50%, transparent 50%); background-position: calc(100% - 16px) 24px, calc(100% - 10px) 24px; background-size: 6px 6px; background-repeat: no-repeat; padding-right: 40px; cursor: pointer; }
.field--invalid .field__input,
.field--invalid .field__textarea { border-color: var(--c-red); }
.field__error { font-family: var(--font-mono); font-size: 11px; color: var(--c-red); text-transform: uppercase; letter-spacing: var(--track-wide); font-weight: 500; }

.checkbox { display: flex; align-items: flex-start; gap: 12px; cursor: pointer; }
.checkbox__box {
  width: 22px; height: 22px;
  border: var(--bw-thin) solid var(--theme-fg);
  flex-shrink: 0; margin-top: 1px;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
}
.checkbox__box[data-checked="true"] { background: var(--theme-accent); }
.checkbox__box[data-checked="true"]::after {
  content: ""; width: 10px; height: 5px;
  border-left: 2.5px solid var(--theme-fg); border-bottom: 2.5px solid var(--theme-fg);
  transform: rotate(-45deg) translate(1px, -1px);
}
.checkbox__label { font-size: 13px; line-height: 1.5; opacity: 0.85; }

/* ============================================================
   Cards
   ============================================================ */
.card {
  border: var(--bw-thin) solid var(--theme-fg);
  background: var(--theme-bg);
  color: var(--theme-fg);
  padding: 36px;
  display: flex; flex-direction: column; gap: 16px;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), transform var(--dur) var(--ease);
  position: relative;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
}
.card::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--theme-accent);
  transform: translateY(101%);
  transition: transform var(--dur) var(--ease-out);
  z-index: -1;
}
.card:hover::before { transform: translateY(0); }
.card:hover { color: var(--theme-accent-fg); background: transparent; }
.card__num { font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: var(--track-wider); font-weight: 500; opacity: 0.6; }
.card__title { font-family: var(--font-display); font-weight: var(--fw-display); font-size: 36px; line-height: 0.95; letter-spacing: var(--track-tightest); }
.card__body { font-size: 14px; line-height: 1.55; opacity: 0.78; flex: 1; }
.card__cta {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 16px;
  border-top: 1px solid currentColor;
  font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: var(--track-wider); font-weight: 500;
}

/* ============================================================
   Chip
   ============================================================ */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 10px;
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  border: 1.5px solid var(--theme-fg);
  background: transparent; color: var(--theme-fg);
}
.chip--solid { background: var(--theme-fg); color: var(--theme-bg); }
.chip--accent { background: var(--theme-accent); color: var(--theme-accent-fg); border-color: var(--theme-accent); }
.chip--observe { color: var(--c-mint); border-color: var(--c-mint); }
.chip--obscure { color: #2B9EF5; border-color: #2B9EF5; }
.chip--nudge   { color: #F5BE20; border-color: #F5BE20; }
.chip--repeat  { color: var(--c-accent-primary, #FF4A1C); border-color: var(--c-accent-primary, #FF4A1C); }
.chip--observe:hover, .chip--obscure:hover, .chip--nudge:hover, .chip--repeat:hover {
  background: var(--c-accent-primary, var(--c-orange));
  color: var(--color-white);
  border-color: var(--c-accent-primary, var(--c-orange));
}

/* ============================================================
   Marquee
   ============================================================ */
.ticker {
  overflow: hidden; display: flex; gap: 32px;
  border-top: var(--bw-thin) solid var(--theme-rule);
  border-bottom: var(--bw-thin) solid var(--theme-rule);
  padding: 20px 0;
  background: var(--theme-bg);
  cursor: pointer;
}
.ticker--solid { background: var(--theme-fg); color: var(--theme-bg); }
.ticker__inner {
  display: flex; gap: 56px; white-space: nowrap;
  animation: ticker 28s linear infinite;
  animation-play-state: running;
  padding-left: 56px;
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: clamp(40px, 7vw, 120px);
  line-height: 1;
  letter-spacing: var(--track-mega);
  text-transform: uppercase;
  flex-shrink: 0;
  transition: color var(--dur) var(--ease);
}
.ticker:hover .ticker__inner { animation-duration: 80s; color: var(--c-accent-primary); }
.ticker:hover .ticker__inner span { color: var(--c-accent-primary, #FF4A1C) !important; }
.ticker__inner span { display: flex; align-items: center; gap: 56px; }
.ticker__inner span::after {
  content: ""; width: 18px; height: 18px;
  background: var(--c-accent-primary); display: inline-block;
  border-radius: 50%;
  transition: transform var(--dur) var(--ease);
}
.ticker:hover .ticker__inner span::after { transform: scale(1.4); }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================================
   Footer
   ============================================================ */
.footer {
  background: var(--color-black);
  color: var(--color-bone);
  padding: 0;
  --theme-bg: var(--color-black);
  --theme-fg: var(--color-bone);
  --theme-accent: var(--c-accent-primary, var(--c-orange));
  --theme-rule: rgba(240,237,232,0.2);
}
.footer__mega {
  padding: 56px var(--gutter-lg) 32px;
  border-bottom: var(--bw-thin) solid rgba(240,237,232,0.2);
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: clamp(40px, 10vw, 200px);
  line-height: 0.85;
  letter-spacing: var(--track-mega);
  white-space: nowrap;
  overflow: hidden;
}
.footer__mega em { font-style: italic; color: var(--c-magenta); }
.footer__grid {
  padding: 64px var(--gutter-lg);
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 48px;
  border-bottom: var(--bw-thin) solid rgba(240,237,232,0.2);
}
.footer__col h4 {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  color: var(--color-stone); margin: 0 0 16px;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.footer__col a {
  font-family: var(--font-display); font-weight: var(--fw-medium);
  font-size: 18px;
  color: var(--color-bone);
  letter-spacing: var(--track-tight);
  cursor: pointer;
  transition: color var(--dur-fast);
}
.footer__col a:hover { color: var(--c-accent-primary, var(--c-orange)); }
.footer__bottom {
  padding: 24px var(--gutter-lg);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  color: var(--color-stone);
}
.footer__bottom-links { display: flex; gap: 24px; }
.footer__bottom-links a:hover { color: var(--color-bone); cursor: pointer; }

/* ============================================================
   HEROES — brutalist big-type
   ============================================================ */
.hero { position: relative; min-height: 100vh; padding: 0; display: flex; flex-direction: column; }

/* Variant A — full-bleed mega type */
.hero--A { padding: 32px var(--gutter-lg) 48px; background: var(--theme-bg); color: var(--theme-fg); }
.hero--A .hero__top {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  margin-bottom: 56px;
}
.hero--A .hero__title {
  font-family: var(--font-display);
  font-weight: var(--fw-display);
  font-size: calc(clamp(40px, 11vw, 185px) * var(--h1-scale, 1));
  line-height: 0.84;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}
.hero--A .hero__title-row { display: block; overflow: hidden; }
.hero--A .hero__title em { font-style: italic; }
.hero--A .hero__title span.outline {
  -webkit-text-stroke: 3px var(--theme-fg); color: transparent;
  font-style: normal;
}
.hero--A .hero__title span.outline-accent {
  -webkit-text-stroke: 3px var(--theme-accent); color: transparent;
  font-style: normal; display: block;
}
.hero--A .hero__title span.text-accent {
  color: var(--theme-accent);
}
.hero--A .hero__title span.fill-accent {
  background: var(--theme-accent); color: var(--theme-accent-fg);
  padding: 0 0.08em;
}
.hero--A .hero__row {
  display: flex; align-items: center; gap: 16px;
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
}
.hero--A .hero__line { flex: 1; height: 0; border-top: 2px solid var(--theme-fg); }
.hero--A .hero__bottom {
  display: grid; grid-template-columns: 1fr 1fr 320px;
  gap: 48px; align-items: end;
  margin-top: auto;
  padding-top: 64px;
}
.hero--A .hero__intro { font-size: 16px; line-height: 1.55; max-width: 420px; }

/* Variant B — Split image + accent block */
.hero--B {
  display: grid; grid-template-columns: 1fr 1fr;
  background: var(--theme-bg); color: var(--theme-fg);
}
.hero--B .hero__left {
  padding: 56px var(--gutter-lg);
  display: flex; flex-direction: column; justify-content: space-between;
  border-right: var(--bw-thin) solid var(--theme-fg);
}
.hero--B .hero__title {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: calc(clamp(40px, 8vw, 160px) * var(--h1-scale, 1)); line-height: 0.84;
  letter-spacing: var(--track-mega); text-transform: uppercase;
  word-break: break-word; overflow-wrap: break-word;
}
.hero--B .hero__title em { font-style: italic; color: var(--theme-accent); }
.hero--B .hero__right {
  background: var(--theme-accent); color: var(--theme-accent-fg);
  position: relative; overflow: hidden;
  padding: 56px var(--gutter-lg);
  display: flex; flex-direction: column; justify-content: space-between;
}
.hero--B .hero__photo {
  flex: 1; min-height: 320px;
  background-image: linear-gradient(135deg, rgba(0,0,0,0.2), rgba(0,0,0,0.3)), url("https://images.unsplash.com/photo-1497366216548-37526070297c?auto=format&fit=crop&w=1600&q=80");
  background-size: cover; background-position: center;
  filter: grayscale(100%) contrast(1.2);
  margin: 24px 0;
  border: var(--bw-thin) solid currentColor;
}

/* Variant C — Editorial w/ stat strip */
.hero--C { padding: 32px var(--gutter-lg) 0; background: var(--theme-bg); color: var(--theme-fg); }
.hero--C .hero__top {
  display: flex; justify-content: space-between;
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  padding-bottom: 32px;
  border-bottom: var(--bw-thin) solid var(--theme-fg);
}
.hero--C .hero__title {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: calc(clamp(48px, 11vw, 220px) * var(--h1-scale, 1));
  line-height: 0.84; letter-spacing: var(--track-mega);
  text-transform: uppercase;
  padding: 32px 0;
  word-break: break-word; overflow-wrap: break-word;
}
.hero--C .hero__title em { font-style: italic; color: var(--theme-accent); }
.hero--C .hero__sub {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 48px; padding: 32px 0;
  border-top: var(--bw-thin) solid var(--theme-fg);
  border-bottom: var(--bw-thin) solid var(--theme-fg);
}
.hero--C .hero__sub p { font-size: 16px; line-height: 1.55; max-width: 320px; margin: 0; }
.hero--C .hero__stats {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
}
.hero--C .stat {
  padding: 40px 24px;
  border-right: var(--bw-thin) solid var(--theme-fg);
}
.hero--C .stat:last-child { border-right: 0; }
.hero--C .stat__num {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: clamp(56px, 6vw, 96px); line-height: 1;
  letter-spacing: var(--track-mega);
}
.hero--C .stat__num em {
  font-family: var(--font-mono); font-style: normal; font-weight: 500;
  font-size: 24px; color: var(--theme-accent); margin-left: 4px;
}
.hero--C .stat__label {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  margin-top: 12px; opacity: 0.7;
}

/* ============================================================
   Generic blocks
   ============================================================ */
.block-title {
  display: grid; grid-template-columns: 200px 1fr;
  gap: 48px; margin-bottom: 64px; align-items: start;
}
.block-title__num {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  padding-top: 12px;
  border-top: var(--bw-thick) solid var(--theme-fg);
}
.block-title__heading {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: calc(clamp(40px, 6vw, 120px) * var(--h1-scale, 1));
  line-height: 0.88; letter-spacing: var(--track-mega);
  text-wrap: balance; text-transform: uppercase;
  word-break: break-word; overflow-wrap: break-word;
}
.block-title__heading em { font-style: italic; color: var(--theme-accent); }
.block-title__heading .outline { -webkit-text-stroke: 2.5px var(--theme-fg); color: transparent; font-style: normal; }

.split-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 64px; }
.split-3 { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 32px; }
.split-4 { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 24px; }

@media (max-width: 1100px) {
  .split-3 { grid-template-columns: repeat(2, 1fr); }
  .split-4 { grid-template-columns: repeat(2, 1fr); }
  .hero--B { grid-template-columns: 1fr; }
  .hero--C .hero__sub { grid-template-columns: 1fr; }
  .hero--C .hero__stats { grid-template-columns: repeat(2, 1fr); }
  .hero--A .hero__bottom { grid-template-columns: 1fr 1fr; gap: 32px; }
}

/* Service rows — chunky */
.svc-row {
  display: grid; grid-template-columns: 80px 1fr 2fr 1fr;
  gap: 48px; padding: 48px 0;
  border-top: var(--bw-thin) solid var(--theme-fg);
  align-items: start;
  transition: background var(--dur-fast);
}
.svc-row:last-child { border-bottom: var(--bw-thin) solid var(--theme-fg); }
.svc-row__num { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: var(--track-wider); text-transform: uppercase; opacity: 0.6; }
.svc-row__title {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: clamp(36px, 4.5vw, 80px);
  line-height: 0.92; letter-spacing: var(--track-mega);
  text-transform: uppercase;
}
.svc-row__title em { font-style: italic; }
.svc-row__body { font-size: 14px; line-height: 1.6; opacity: 0.78; padding-top: 12px; }
.svc-row__tags { display: flex; flex-wrap: wrap; gap: 6px; padding-top: 12px; }
.svc-row__cta {
  display: flex; flex-direction: column; justify-content: space-between;
  align-items: flex-end; padding-top: 12px; height: 100%;
}
.svc-row__inquire {
  background: #0C0B09; color: #FDFCFA; border: none;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; padding: 8px 14px; cursor: pointer;
  margin-top: 16px; align-self: flex-end;
}

/* News list */
.news-row {
  display: grid; grid-template-columns: 120px 100px 1fr 80px;
  gap: 32px; padding: 28px 0;
  border-top: var(--bw-thin) solid var(--theme-fg);
  align-items: center;
  cursor: pointer;
  transition: padding var(--dur-fast), background var(--dur-fast);
}
.news-row:last-child { border-bottom: var(--bw-thin) solid var(--theme-fg); }
.news-row:hover { padding-left: 16px; background: var(--theme-accent); color: var(--theme-accent-fg); }
.news-row__date { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: var(--track-wide); }
.news-row__title { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 22px; line-height: 1.2; letter-spacing: var(--track-tight); }
.news-row__arrow { font-family: var(--font-mono); font-size: 16px; text-align: right; }

/* Clients grid */
.clients-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  border-top: var(--bw-thin) solid var(--theme-fg);
  border-left: var(--bw-thin) solid var(--theme-fg);
}
.clients-grid__cell {
  padding: 48px 32px;
  border-right: var(--bw-thin) solid var(--theme-fg);
  border-bottom: var(--bw-thin) solid var(--theme-fg);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 140px;
  overflow: hidden;
}
.clients-grid__name {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(11px, 2.5vw, 22px);
  letter-spacing: -0.03em;
  text-transform: uppercase;
  text-align: center;
  word-break: break-word;
}

/* Page header */
.page-header {
  padding: 80px var(--gutter-lg) 64px;
  background: var(--theme-bg);
  color: var(--theme-fg);
  border-bottom: var(--bw-thin) solid var(--theme-rule);
  display: grid; grid-template-columns: 200px 1fr;
  gap: 48px;
}
.page-header__num {
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  padding-top: 16px;
}
.page-header__title {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: calc(clamp(56px, 11vw, 240px) * var(--h1-scale, 1)); line-height: 0.82;
  letter-spacing: var(--track-mega);
  text-transform: uppercase;
  word-break: break-word; overflow-wrap: break-word;
}
.page-header__title em { font-style: italic; color: var(--theme-accent); }
.page-header__title .outline { -webkit-text-stroke: 3px var(--theme-fg); color: transparent; font-style: normal; }
.page-header__sub { font-size: 16px; line-height: 1.6; max-width: 480px; margin-top: 24px; opacity: 0.78; }

/* Values */
.values { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.value {
  padding: 56px 32px;
  border-right: var(--bw-thin) solid var(--theme-fg);
  border-top: var(--bw-thin) solid var(--theme-fg);
  display: flex; flex-direction: column; gap: 16px; min-height: 360px;
  background: var(--theme-bg);
  color: var(--theme-fg);
}
.value:last-child { border-right: 0; }
.value__num { font-family: var(--font-mono); font-size: 11px; font-weight: 500; letter-spacing: var(--track-wider); text-transform: uppercase; opacity: 0.6; }
.value__title {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: clamp(36px, 3.5vw, 64px);
  letter-spacing: var(--track-mega); line-height: 0.92;
  text-transform: uppercase;
}
.value__title em { font-style: italic; color: var(--theme-accent); }
.value__body { font-family: var(--font-body-en); font-weight: 600; font-size: 14px; line-height: 1.6; opacity: 0.8; margin-top: auto; }

/* Process */
.process { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); border-top: var(--bw-thin) solid var(--theme-fg); border-bottom: var(--bw-thin) solid var(--theme-fg); }
.process__step { padding: 56px 32px; border-right: var(--bw-thin) solid var(--theme-fg); }
.process__step:last-child { border-right: 0; }
.process__num { font-family: var(--font-mono); font-size: 11px; font-weight: 500; letter-spacing: var(--track-wider); text-transform: uppercase; margin-bottom: 32px; opacity: 0.6; }
.process__title { font-family: var(--font-display); font-weight: var(--fw-display); font-size: 36px; letter-spacing: var(--track-mega); line-height: 0.95; text-transform: uppercase; margin-bottom: 16px; }
.process__body { font-size: 14px; line-height: 1.55; opacity: 0.8; }

/* Members */
.member {
  border-top: var(--bw-thin) solid var(--theme-fg);
  padding: 32px 0;
  display: grid; grid-template-columns: 80px 1fr 1.4fr 80px;
  gap: 32px; align-items: center; cursor: pointer;
  transition: padding var(--dur-fast), background var(--dur-fast);
}
.member:hover { padding-left: 16px; background: var(--theme-accent); color: var(--theme-accent-fg); }
.member:last-child { border-bottom: var(--bw-thin) solid var(--theme-fg); }
.member__photo {
  width: 64px; height: 64px;
  background: var(--color-graphite);
  background-size: cover; background-position: center;
  filter: grayscale(100%) contrast(1.1);
  border: 2px solid currentColor;
}
.member__name { font-family: var(--font-display); font-weight: var(--fw-display-alt); font-size: 28px; letter-spacing: var(--track-tightest); line-height: 1; }
.member__title { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); opacity: 0.7; margin-top: 6px; }
.member__bio { font-size: 13px; line-height: 1.55; opacity: 0.78; }

/* Jobs */
.job {
  border-top: var(--bw-thin) solid var(--theme-fg);
  padding: 32px 0;
  display: grid; grid-template-columns: 1fr 200px 200px 80px;
  gap: 32px; align-items: center; cursor: pointer;
  transition: padding var(--dur-fast), background var(--dur-fast);
}
.job:hover { padding-left: 16px; background: var(--theme-accent); color: var(--theme-accent-fg); }
.job:last-child { border-bottom: var(--bw-thin) solid var(--theme-fg); }
.job__title {
  font-family: var(--font-display); font-weight: var(--fw-display);
  font-size: clamp(28px, 3vw, 48px); letter-spacing: var(--track-mega);
  text-transform: uppercase; line-height: 0.95;
}
.job__meta { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); opacity: 0.7; }
.job__arrow { font-family: var(--font-mono); font-size: 18px; text-align: right; }

/* Contact */
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 96px; }
.contact-form { display: grid; gap: 32px; }
.contact-side h4 { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); margin: 0 0 16px; opacity: 0.6; }
.contact-side dl { margin: 0 0 40px; padding: 24px 0; border-top: var(--bw-thin) solid var(--theme-fg); border-bottom: var(--bw-thin) solid var(--theme-fg); display: grid; grid-template-columns: 80px 1fr; gap: 12px 24px; }
.contact-side dt { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); opacity: 0.6; }
.contact-side dd { margin: 0; font-size: 14px; }

/* Image placeholder */
.ph {
  background: var(--color-black); color: var(--color-bone);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wider);
  position: relative; overflow: hidden;
  aspect-ratio: 4/3;
  border: var(--bw-thin) solid var(--theme-fg);
}
/* ── Venture card hover ──────────────────────────── */
.venture-card {
  transition: background 0.22s ease, color 0.22s ease;
  cursor: default;
}
.venture-card:hover {
  background: var(--theme-fg) !important;
  color: var(--theme-bg) !important;
}
.venture-card:hover h3 {
  color: var(--theme-accent) !important;
}
.venture-card:hover .t-mono {
  color: var(--theme-bg) !important;
  opacity: 0.6 !important;
}
.venture-card:hover a {
  color: var(--theme-bg) !important;
  border-color: rgba(255,255,255,0.15) !important;
}
.venture-card:hover p {
  opacity: 0.75 !important;
}

.ph--photo {
  background: var(--color-graphite);
  background-image: linear-gradient(135deg, rgba(0,0,0,0.3), rgba(0,0,0,0.55)), var(--ph-img, none);
  background-size: cover; background-position: center;
}

/* ============================================================
   Style Guide
   ============================================================ */
.sg-section { padding: 96px var(--gutter-lg); border-bottom: var(--bw-thin) solid var(--theme-rule); background: var(--theme-bg); color: var(--theme-fg); }
.sg-head { display: grid; grid-template-columns: 200px 1fr; gap: 48px; margin-bottom: 64px; }
.sg-head__num { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); padding-top: 12px; border-top: var(--bw-thick) solid var(--theme-fg); }
.sg-head__title { font-family: var(--font-display); font-weight: var(--fw-display); font-size: clamp(40px, 6vw, 120px); line-height: 0.88; letter-spacing: var(--track-mega); text-transform: uppercase; word-break: break-word; overflow-wrap: break-word; }
.sg-head__title em { font-style: italic; color: var(--theme-accent); }
.sg-head__sub { font-size: 14px; opacity: 0.78; margin-top: 16px; max-width: 480px; line-height: 1.6; }

.color-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); border-top: var(--bw-thin) solid var(--theme-fg); border-left: var(--bw-thin) solid var(--theme-fg); }
.color-cell {
  border-right: var(--bw-thin) solid var(--theme-fg);
  border-bottom: var(--bw-thin) solid var(--theme-fg);
  aspect-ratio: 1; position: relative; display: flex; align-items: flex-end;
}
.color-cell__chip { position: absolute; inset: 0; }
.color-cell__meta {
  position: relative; padding: 12px; width: 100%;
  background: var(--theme-bg); color: var(--theme-fg);
  border-top: var(--bw-thin) solid var(--theme-fg);
  font-family: var(--font-mono); font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: var(--track-wide);
  display: flex; justify-content: space-between;
}

.type-row {
  display: grid; grid-template-columns: 220px 80px 80px 1fr;
  gap: 24px; padding: 28px 0;
  border-top: var(--bw-thin) solid var(--theme-fg);
  align-items: baseline;
}
.type-row:last-child { border-bottom: var(--bw-thin) solid var(--theme-fg); }
.type-row__name { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); }
.type-row__size { font-family: var(--font-mono); font-size: 11px; opacity: 0.6; }

.cmp-card { border: var(--bw-thin) solid var(--theme-fg); padding: 32px; background: var(--theme-bg); color: var(--theme-fg); }
.cmp-card__head { display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); padding-bottom: 24px; border-bottom: var(--bw-thin) solid var(--theme-fg); margin-bottom: 24px; }
.cmp-card__row { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; padding: 12px 0; }

/* Section theme rule cards */
.theme-rule-card {
  padding: 32px; border: var(--bw-thin) solid var(--color-black);
  background: var(--bg-swatch, var(--c-orange));
  color: var(--fg-swatch, var(--color-black));
  display: flex; flex-direction: column; gap: 12px;
  min-height: 160px;
}
.theme-rule-card__name { font-family: var(--font-display); font-weight: var(--fw-display); font-size: 32px; letter-spacing: var(--track-mega); text-transform: uppercase; line-height: 0.92; }
.theme-rule-card__use { font-family: var(--font-mono); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: var(--track-wider); margin-top: auto; }

/* Misc */
.flex-between { display: flex; justify-content: space-between; align-items: center; gap: 24px; }
/* ============================================================
   Title hover — fill ↔ outline swap on big display headings
   ============================================================ */
.title-fx {
  display: inline-block;
  position: relative;
  cursor: pointer;
  color: currentColor;
  -webkit-text-stroke: 0 transparent;
  transition: color 380ms var(--ease), -webkit-text-stroke 380ms var(--ease);
}
.title-fx:hover {
  color: transparent;
  -webkit-text-stroke: 2.5px currentColor;
}
/* Outline → fill (inverse) */
.title-fx--outline {
  color: transparent;
  -webkit-text-stroke: 2.5px var(--theme-fg);
}
.title-fx--outline:hover {
  color: var(--theme-accent);
  -webkit-text-stroke: 2.5px transparent;
}
.title-fx--accent { color: var(--theme-accent); }
.title-fx--accent:hover { color: transparent; -webkit-text-stroke: 2.5px var(--theme-accent); }

/* ============================================================
   Reveal — mask-based slide-up for display text
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 700ms var(--ease-out), transform 900ms var(--ease-out);
}
.reveal[data-revealed="true"] { opacity: 1; transform: translateY(0); }

/* Bigger, clipping reveal for hero/title rows: mask up from bottom.
   Only applies to elements with BOTH .reveal AND data-revealed (controlled by IntersectionObserver).
   Plain titles without <Reveal> are unaffected. */
.reveal.hero__title-row,
.hero__title .reveal,
.hero__title.reveal,
.page-header__title .reveal,
.page-header__title.reveal,
.block-title__heading .reveal,
.block-title__heading.reveal,
.sg-head__title .reveal,
.sg-head__title.reveal {
  display: block;
  overflow: hidden;
  clip-path: inset(0 0 100% 0);
  transform: translateY(0);
  opacity: 1;
  transition: clip-path 1000ms var(--ease-out);
  will-change: clip-path;
}
.reveal.hero__title-row[data-revealed="true"],
.hero__title .reveal[data-revealed="true"],
.hero__title.reveal[data-revealed="true"],
.page-header__title .reveal[data-revealed="true"],
.page-header__title.reveal[data-revealed="true"],
.block-title__heading .reveal[data-revealed="true"],
.block-title__heading.reveal[data-revealed="true"],
.sg-head__title .reveal[data-revealed="true"],
.sg-head__title.reveal[data-revealed="true"] {
  clip-path: inset(0 0 0 0);
}

/* Sequenced inner span lift — adds depth to the mask */
.reveal.hero__title-row > *,
.hero__title .reveal > *,
.hero__title.reveal > *,
.page-header__title .reveal > *,
.page-header__title.reveal > *,
.block-title__heading .reveal > *,
.block-title__heading.reveal > *,
.sg-head__title .reveal > *,
.sg-head__title.reveal > * {
  display: inline-block;
  transform: translateY(105%);
  transition: transform 1000ms var(--ease-out);
}
.reveal.hero__title-row[data-revealed="true"] > *,
.hero__title .reveal[data-revealed="true"] > *,
.hero__title.reveal[data-revealed="true"] > *,
.page-header__title .reveal[data-revealed="true"] > *,
.page-header__title.reveal[data-revealed="true"] > *,
.block-title__heading .reveal[data-revealed="true"] > *,
.block-title__heading.reveal[data-revealed="true"] > *,
.sg-head__title .reveal[data-revealed="true"] > *,
.sg-head__title.reveal[data-revealed="true"] > * {
  transform: translateY(0);
}

/* Safety: if JS hasn't toggled within 1.2s, force reveal so content can't get stuck hidden */
@keyframes revealForce { to { clip-path: inset(0 0 0 0); } }
@keyframes revealForceInner { to { transform: translateY(0); } }
.reveal { animation: revealForce 0ms 1500ms forwards; }
.reveal > * { animation: revealForceInner 0ms 1500ms forwards; }
.reveal[data-revealed="true"], .reveal[data-revealed="true"] > * { animation: none; }

.swatch-row { display: flex; gap: 6px; flex-wrap: wrap; }
.swatch { width: 26px; height: 26px; border: 2px solid transparent; cursor: pointer; transition: all var(--dur-fast); border-radius: 4px; padding: 0; }
.swatch[data-active="true"] { border-color: #29261b; transform: scale(1.12); }

/* ── Responsive ──────────────────────────────────────── */
@media (max-width: 900px) {
  :root { --nav-w: 0px; --gutter-lg: 24px; --gutter-xl: 56px; }
  .sidenav:not([data-variant="top"]):not([data-variant="overlay"]) { transform: translateX(-100%); }
  .stage { padding-left: 0; padding-top: 64px; }
  .block-title, .page-header { grid-template-columns: 1fr; gap: 24px; }
  .split-2, .split-3, .split-4, .hero--B { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .clients-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .clients-grid__cell { padding: 32px 20px; min-height: 100px; }
  .svc-row { grid-template-columns: 60px 1fr; }
  .svc-row__body, .svc-row__tags, .svc-row__cta { grid-column: 1/-1; }
  .svc-row__cta { flex-direction: row; align-items: center; justify-content: space-between; height: auto; padding-top: 0; }
  .svc-row__cta .svc-row__tags { padding-top: 0; }
  .svc-row__inquire { margin-top: 0; }
  .news-row {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    grid-template-areas: "date arrow" "title title";
    gap: 6px 16px;
  }
  .news-row__date   { grid-area: date; }
  .news-row__title  { grid-area: title; font-size: clamp(16px, 4.2vw, 20px); line-height: 1.35; }
  .news-row__arrow  { grid-area: arrow; display: block; }
  .news-row > span:nth-child(2) { display: none; } /* chip wrapper */
  .member { grid-template-columns: 64px 1fr; }
  .member__bio, .member__arrow { display: none; }
  .job { grid-template-columns: 1fr; gap: 8px; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .values { grid-template-columns: 1fr; }
  .value { border-right: 0; }
  .color-grid { grid-template-columns: repeat(3, 1fr); }
  .type-row { grid-template-columns: 1fr; gap: 8px; }
}

/* ── 680px — Hero bottom collapse & mid-size polish ── */
@media (max-width: 680px) {
  .hero--A .hero__bottom {
    grid-template-columns: 1fr;
    gap: 28px;
    padding-top: 36px;
  }
  .hero--A .hero__top {
    margin-bottom: 28px;
    flex-wrap: wrap;
    gap: 4px 16px;
  }
  .hero--A .hero__intro { max-width: 100%; }
  .svc-row { gap: 16px; padding: 32px 0; }
  .news-row { padding: 20px 0; }
  .page-header { padding-top: 40px; padding-bottom: 40px; }
  .footer__bottom { flex-direction: column; gap: 16px; align-items: flex-start; }
  .footer__bottom-links { flex-wrap: wrap; gap: 8px 20px; }
}

/* ── 480px — Small phone ─────────────────────────────── */
@media (max-width: 480px) {
  :root {
    --gutter-lg: 20px;
    --gutter-xl: 40px;
  }
  .hero--A { padding-top: 20px; padding-bottom: 28px; }
  .footer__grid { grid-template-columns: 1fr; gap: 32px; }
  .footer__mega { padding-top: 40px; padding-bottom: 24px; }
  .section { padding: clamp(56px, 10vw, 96px) var(--gutter-lg); }
  .section--lg { padding: clamp(48px, 8vw, 80px) var(--gutter-lg); }
  .svc-row { gap: 12px; padding: 28px 0; }
  .svc-row__title { font-size: clamp(24px, 7vw, 40px); }
  .chip { font-size: 9px; padding: 3px 7px; }
  .btn { font-size: 12px; padding: 10px 18px; }
}

/* ── Responsive grid replacements (was inline-style in app-pages.jsx) ── */

/* Service 03.2 — Capabilities table: 5-col → 1-col stack on mobile */
.caps-row { display: grid; grid-template-columns: 140px 1fr 1fr 1fr 1fr; }
@media (max-width: 900px) {
  .caps-row { grid-template-columns: 1fr; }
  .caps-row > :first-child { border-right: 0; padding: 16px; font-size: 11px; }
}

/* About — Selected Work snippets: 3-col → stack on mobile */
.work-snippets {
  margin-top: 64px; border-top: 1px solid var(--theme-fg); padding-top: 40px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px;
}
@media (max-width: 680px) {
  .work-snippets { grid-template-columns: 1fr; gap: 32px; margin-top: 48px; padding-top: 32px; }
}

/* Company 04.1 — Leadership member row: 2-col → stack on mobile */
.member-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: start;
  border-top: 2px solid var(--theme-fg); padding-top: 48px;
}
@media (max-width: 900px) {
  .member-grid { grid-template-columns: 1fr; gap: 24px; padding-top: 32px; }
}

/* Service 03.1 — Lead row: 2-col asymmetric → stack on mobile */
.svc-lead {
  display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1.5fr);
  gap: 64px; margin-bottom: 72px; align-items: start;
}
@media (max-width: 900px) {
  .svc-lead { grid-template-columns: 1fr; gap: 20px; margin-bottom: 48px; }
}

/* Company 04.2 — Profile dl: 160px label → narrower on mobile */
.profile-dl {
  margin: 0; display: grid; grid-template-columns: 160px 1fr;
  row-gap: 18px; column-gap: 32px;
  border-top: 2px solid var(--theme-fg); padding-top: 24px;
}
@media (max-width: 480px) {
  .profile-dl { grid-template-columns: 96px 1fr; column-gap: 16px; }
}

/* Contact — 2-col Name/Email row: stack on mobile */
.form-row-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 32px; }
@media (max-width: 600px) {
  .form-row-2 { grid-template-columns: 1fr; gap: 20px; }
}

/* Service 03.0 — Three Ventures grid: 12-col span layout → stack on mobile */
.vc-grid {
  display: grid; grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 1px; background: var(--theme-fg);
}
@media (max-width: 900px) {
  .vc-grid { grid-template-columns: 1fr; }
  .vc-grid > .venture-card { grid-column: 1 / -1 !important; min-height: 240px !important; padding: 32px 24px !important; }
}

/* ── Scroll Hint ─────────────────────────────────────────────
   Bottom-right cue inside hero. Vertical line + label.
   Subtle pulse — never demands attention. */
.scroll-hint {
  position: fixed;
  right: 24px;
  bottom: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  pointer-events: none;
  opacity: 0.55;
  z-index: 10;
  transition: opacity 0.4s ease;
}
.scroll-hint--hidden {
  opacity: 0;
}
.scroll-hint__label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--theme-fg);
  writing-mode: vertical-rl;
  transform: rotate(180deg);
}
.scroll-hint__line {
  width: 1px;
  height: 56px;
  background: var(--theme-fg);
  transform-origin: top;
  animation: scroll-hint-pulse 2.4s ease-in-out infinite;
}
@keyframes scroll-hint-pulse {
  0%, 100% { transform: scaleY(0.3); opacity: 0.4; }
  50%      { transform: scaleY(1);   opacity: 1; }
}
@media (prefers-reduced-motion: reduce) {
  .scroll-hint__line { animation: none; }
}
@media (max-width: 700px) {
  .scroll-hint { right: 16px; bottom: 16px; }
  .scroll-hint__line { height: 36px; }
}

/* ── Hero AFTER. ghost ──────────────────────────────────────
   Outline echo trailing the accent fill. Drifts slower (case B).
   Visualizes "preconception lingering before the verdict". */
.hero--A .hero__title-row--ghosted {
  position: relative;
}
.hero--A .hero__ghost {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-block;
  pointer-events: none;
  font-style: normal;
  -webkit-text-stroke: 2px var(--theme-accent);
  color: transparent;
  opacity: 0.42;
  will-change: transform;
}
@media (prefers-reduced-motion: reduce) {
  .hero--A .hero__ghost { display: none; }
}
