/* =========================================================
   RIVIERA  —  V3 / REEL
   Cinematic, W+K-tonal, polished but loud.
   Bone · Ink · Silver · Cobalt · Tomato (CI palette locked)
   ========================================================= */

:root {
  --bone:    #F3F1ED;
  --bone-2:  #E8E5DD;
  --bone-3:  #DBD7CD;
  --ink:     #0B0B0D;
  --ink-2:   #141417;
  --ink-3:   #6E6E73;
  --silver:  #A6AAAD;
  --silver-2:#D7D9DB;
  --cobalt:  #0047FF;
  --cobalt-2:#0033B8;
  --tomato:  #E50914;

  --rule:      rgba(11,11,13,.14);
  --rule-2:    rgba(11,11,13,.32);
  --rule-bone: rgba(243,241,237,.18);

  --sans: "Inter", system-ui, -apple-system, "Helvetica Neue", Helvetica, Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, Menlo, monospace;

  --mx:   clamp(20px, 4vw, 64px);
  --maxw: 1480px;

  --letterbox: clamp(56px, 6vw, 88px);

  --ease:     cubic-bezier(.2,.7,.2,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

* { box-sizing: border-box; }
*::selection { background: var(--cobalt); color: var(--bone); }

html, body {
  margin: 0; padding: 0;
  background: var(--ink);
  color: var(--bone);
  font-family: var(--sans);
  font-feature-settings: "ss01","cv11";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { overflow-x: hidden; }

a   { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
ol, ul { list-style: none; padding: 0; margin: 0; }

.mono {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.mono--mute { color: var(--silver); }

.dot      { color: var(--tomato); }
.dot--bone{ color: var(--bone); }

/* =========================================================
   FILM GRAIN OVERLAY  —  static SVG noise across the whole site
   ========================================================= */
.grain {
  position: fixed;
  inset: -10%;
  width: 120%;
  height: 120%;
  pointer-events: none;
  z-index: 9000;
  opacity: .35;
  mix-blend-mode: overlay;
  animation: grainShift 1.6s steps(2) infinite;
}
@keyframes grainShift {
  0%   { transform: translate(0,0); }
  20%  { transform: translate(-2%, 1%); }
  40%  { transform: translate(1%, -1%); }
  60%  { transform: translate(-1%, 2%); }
  80%  { transform: translate(2%, -2%); }
  100% { transform: translate(0,0); }
}
@media (prefers-reduced-motion: reduce) { .grain { animation: none; } }

/* =========================================================
   CUSTOM CURSOR  —  desktop only
   ========================================================= */
.cursor {
  position: fixed;
  top: 0; left: 0;
  width: 0; height: 0;
  z-index: 9999;
  pointer-events: none;
  mix-blend-mode: difference;
  display: none;
}
@media (hover: hover) and (pointer: fine) {
  .cursor { display: block; }
  body { cursor: none; }
  a, button, .magnetic, .magnetic-soft { cursor: none; }
}
.cursor__dot {
  position: absolute;
  top: -3px; left: -3px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--bone);
  transition: transform .2s var(--ease), opacity .2s;
}
.cursor__ring {
  position: absolute;
  top: -22px; left: -22px;
  width: 44px; height: 44px;
  border: 1px solid var(--bone);
  border-radius: 50%;
  opacity: .35;
  transition: transform .35s var(--ease-out), opacity .25s, border-color .25s, background .25s;
}
.cursor.is-hot .cursor__ring {
  transform: scale(1.7);
  background: var(--cobalt);
  border-color: var(--cobalt);
  opacity: .9;
  mix-blend-mode: normal;
}
.cursor.is-hot .cursor__dot { opacity: 0; }
.cursor__label {
  position: absolute;
  top: 26px; left: 26px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bone);
  background: var(--ink);
  padding: 4px 8px;
  white-space: nowrap;
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity .2s, transform .2s;
}
.cursor.is-hot .cursor__label { opacity: 1; transform: translateY(0); }

/* =========================================================
   NAV
   ========================================================= */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: rgba(11,11,13,.4);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--rule-bone);
}
.nav__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 16px var(--mx);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}
.logo {
  display: inline-flex;
  flex-direction: column;
  line-height: 1;
  gap: 3px;
  color: var(--bone);
}
.logo__mark {
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -.02em;
}
.logo__sub {
  font-family: var(--mono);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .22em;
  color: var(--silver);
  text-transform: uppercase;
}
.nav__links {
  display: flex;
  gap: 28px;
  font-size: 14px;
  font-weight: 500;
}
.nav__links a {
  position: relative;
  padding: 6px 0;
  color: var(--bone);
}
.nav__links a::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 1px;
  background: var(--cobalt);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s var(--ease-out);
}
.nav__links a:hover::after { transform: scaleX(1); }
.nav__cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 18px;
  background: var(--cobalt);
  color: var(--bone);
  font-size: 13px;
  font-weight: 600;
  transition: background .2s var(--ease), transform .2s var(--ease);
}
.nav__cta svg { width: 14px; height: 14px; }
.nav__cta:hover { background: var(--bone); color: var(--ink); }
@media (max-width: 880px) { .nav__links { display: none; } }

/* =========================================================
   §01  HERO  —  cinematic slate
   ========================================================= */
.hero {
  position: relative;
  min-height: 100svh;
  background: var(--ink);
  color: var(--bone);
  overflow: hidden;
  isolation: isolate;
}

/* the noise canvas — full bleed behind everything */
.hero__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: .22;
  mix-blend-mode: screen;
  filter: contrast(1.4) brightness(.9);
}

/* cobalt diagonal sweep behind type */
.hero__sweep {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(11,11,13,.55) 0%, rgba(11,11,13,.15) 35%, rgba(11,11,13,.0) 50%, rgba(11,11,13,.5) 100%);
}
.hero__sweep::before {
  content: "";
  position: absolute;
  top: -10%; right: -10%;
  width: 70%;
  height: 130%;
  background: var(--cobalt);
  transform: rotate(-22deg) translateX(20%);
  transform-origin: top right;
  clip-path: polygon(60% 0, 100% 0, 100% 100%, 0 100%);
  opacity: .42;
  filter: blur(2px);
}
.hero__sweep::after {
  content: "";
  position: absolute;
  bottom: -20%;
  left: -10%;
  width: 60%;
  height: 90%;
  background: radial-gradient(closest-side, rgba(0,71,255,.35), transparent 70%);
  filter: blur(40px);
  pointer-events: none;
}

/* letterbox bars */
.hero__letterbox {
  position: absolute;
  left: 0; right: 0;
  height: var(--letterbox);
  background: var(--ink);
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 clamp(20px, 3vw, 36px);
  border-color: var(--rule-bone);
}
.hero__letterbox--top    { top: 0;    border-bottom: 1px solid var(--rule-bone); }
.hero__letterbox--bottom { bottom: 0; border-top: 1px solid var(--rule-bone); }

.slate {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--silver);
}
.slate__pip {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--tomato);
  animation: pip 1.4s var(--ease) infinite;
}
@keyframes pip {
  0%,100% { opacity: 1; transform: scale(1); }
  50%     { opacity: .35; transform: scale(.6); }
}
.slate__sep { color: rgba(243,241,237,.35); }
.slate--top-right span { color: var(--cobalt); }
.slate__bars {
  display: inline-flex;
  align-items: flex-end;
  gap: 2px;
  height: 14px;
}
.slate__bars span {
  display: inline-block;
  width: 2px;
  background: var(--cobalt);
  animation: bars 1.1s ease-in-out infinite;
}
.slate__bars span:nth-child(1) { height: 30%; animation-delay: 0s;   }
.slate__bars span:nth-child(2) { height: 70%; animation-delay: .15s; }
.slate__bars span:nth-child(3) { height: 50%; animation-delay: .3s;  }
.slate__bars span:nth-child(4) { height: 90%; animation-delay: .45s; }
.slate__bars span:nth-child(5) { height: 40%; animation-delay: .6s;  }
@keyframes bars { 0%,100% { transform: scaleY(.4); } 50% { transform: scaleY(1); } }

/* hero inner content */
.hero__inner {
  position: relative;
  z-index: 3;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: calc(var(--letterbox) + clamp(40px, 6vw, 80px)) var(--mx)
           calc(var(--letterbox) + clamp(28px, 4vw, 56px));
  min-height: 100svh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: clamp(20px, 2.4vw, 30px);
}

.hero__rail {
  color: var(--silver);
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.hero__rail::before {
  content: "";
  width: 38px;
  height: 1px;
  background: var(--cobalt);
}

/* the hero hammer — TENSION SELLS. */
.hero__title {
  margin: 0;
  font-family: var(--sans);
  font-weight: 900;
  line-height: .88;
  letter-spacing: -.055em;
  /* sized so the longest word ("Brand-building", 14ch) fits on one line at 1440 */
  font-size: clamp(64px, 12.6vw, 184px);
  display: flex;
  flex-direction: column;
  gap: clamp(0px, .2vw, 6px);
  color: var(--bone);
  max-width: 100%;
}
.hero__word {
  display: inline-flex;
  align-items: baseline;
  position: relative;
  overflow: hidden;
  /* descenders (g/y/p) on Inter at 900 weight extend ~.22em below baseline — pad for clearance */
  padding-bottom: .26em;
  max-width: 100%;
  white-space: nowrap;
}
.hero__word--blue { color: var(--cobalt); }
.hero__word--small {
  font-size: .42em;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--silver-2);
  margin-bottom: .04em;
}
.hero__word .ch {
  display: inline-block;
  transform: translateY(110%);
  opacity: 0;
  transition: transform .9s var(--ease-out), opacity .8s var(--ease-out);
  will-change: transform;
}
body.is-ready .hero__word .ch { transform: translateY(0); opacity: 1; }
.hero__dot {
  display: inline-block;
  margin-left: .02em;
  transform: translateY(110%);
  opacity: 0;
  transition: transform .9s var(--ease-out) .55s, opacity .8s var(--ease-out) .55s;
}
body.is-ready .hero__dot { transform: translateY(0); opacity: 1; }

/* failsafe */
@keyframes heroFailsafe { to { transform: none; opacity: 1; } }
.hero__word .ch, .hero__dot { animation: heroFailsafe 0s 1.6s forwards; }

.hero__sub {
  margin: 0;
  max-width: 32ch;
  font-size: clamp(22px, 2.4vw, 38px);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--bone);
}
.hero__sub em {
  font-style: italic;
  color: var(--cobalt);
  font-weight: 700;
}

.hero__meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule-bone);
  padding-top: 22px;
  max-width: 1180px;
}
.hero__meta > div {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0 18px;
  border-right: 1px solid var(--rule-bone);
}
.hero__meta > div:first-child { padding-left: 0; }
.hero__meta > div:last-child  { border-right: 0; }
.hero__meta > div span:first-child {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--silver);
}
.hero__meta > div span:last-child {
  font-size: 13px;
  font-weight: 500;
  color: var(--bone);
}
@media (max-width: 800px) {
  .hero__meta { grid-template-columns: repeat(2, 1fr); gap: 12px 0; }
  .hero__meta > div:nth-child(2) { border-right: 0; }
}

.hero__ctas {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 12px;
}
.btn {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 16px 22px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -.005em;
  transition: background .2s var(--ease), color .2s var(--ease), transform .2s var(--ease);
}
.btn svg { width: 16px; height: 16px; }
.btn--primary {
  background: var(--cobalt);
  color: var(--bone);
}
.btn--primary:hover { background: var(--bone); color: var(--ink); transform: translateY(-1px); }
.btn--ghost {
  background: transparent;
  color: var(--bone);
  border: 1.5px solid var(--bone);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 16px 20px;
}
.btn--ghost:hover { background: var(--bone); color: var(--ink); }

/* hero scroll cue */
.hero__cue {
  position: absolute;
  left: var(--mx);
  bottom: calc(var(--letterbox) + 18px);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  color: var(--silver);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.hero__cue__line {
  position: relative;
  width: 80px;
  height: 1px;
  background: var(--rule-bone);
  overflow: hidden;
}
.hero__cue__line::after {
  content: "";
  position: absolute;
  left: -40%;
  top: 0;
  width: 40%;
  height: 100%;
  background: var(--cobalt);
  animation: cueRun 1.6s var(--ease) infinite;
}
@keyframes cueRun {
  0%   { transform: translateX(0); }
  100% { transform: translateX(350%); }
}

/* =========================================================
   §02  MANIFESTO REEL  —  scroll-pinned full-bleed
   ========================================================= */
.reel {
  position: relative;
  background: var(--ink);
  color: var(--bone);
  height: 320vh;             /* scroll runway — 5 lines, ~64vh per line */
  border-top: 1px solid var(--rule-bone);
}
.reel__rail {
  position: absolute;
  top: 18px;
  left: var(--mx);
  color: var(--silver);
  z-index: 3;
}

.reel__pin {
  position: sticky;
  top: 0;
  height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border-bottom: 1px solid var(--rule-bone);
}

.reel__stage {
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--mx);
}

.reel__line {
  position: absolute;
  margin: 0;
  width: calc(100% - (var(--mx) * 2));
  text-align: center;
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(48px, 9.5vw, 168px);
  line-height: 1.04;
  letter-spacing: -.045em;
  color: var(--bone);
  opacity: 0;
  transform: translateY(40px) scale(.96);
  transition: opacity .55s var(--ease-out), transform .7s var(--ease-out);
  will-change: opacity, transform;
}
.reel__line.is-active {
  opacity: 1;
  transform: none;
}

.reel__line[data-i="0"] em,
.reel__line[data-i="1"] em,
.reel__line[data-i="2"] em,
.reel__line[data-i="3"] em,
.reel__line[data-i="4"] em { color: var(--cobalt); }

/* Per-line treatment — alternate emphasis */
.reel__line[data-i="0"] { color: var(--bone); }
.reel__line[data-i="1"] { color: var(--cobalt); }
.reel__line[data-i="2"] { color: var(--bone); }
.reel__line[data-i="3"] { color: var(--cobalt); }
.reel__line[data-i="4"] { color: var(--bone); }

.reel__counter {
  position: absolute;
  top: 28px;
  right: var(--mx);
  z-index: 3;
  color: var(--silver);
  font-size: 13px;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.reel__counter [data-reel-current] {
  color: var(--cobalt);
  font-size: 17px;
  font-weight: 600;
}
.reel__counter__sep { color: rgba(243,241,237,.35); }

.reel__progress {
  position: absolute;
  bottom: 24px; left: var(--mx); right: var(--mx);
  height: 1px;
  background: var(--rule-bone);
  z-index: 3;
}
.reel__progress__fill {
  display: block;
  height: 100%;
  background: var(--cobalt);
  width: 0%;
  transform-origin: left;
  transition: width .15s linear;
}

/* =========================================================
   §03  PULL QUOTE  —  cinemascope on bone
   ========================================================= */
.quote {
  background: var(--bone);
  color: var(--ink);
  padding: clamp(96px, 11vw, 180px) var(--mx);
  position: relative;
  border-top: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
}
.quote__rail {
  position: absolute;
  top: 24px; left: var(--mx);
  color: var(--ink-3);
}
.quote__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0;
}
.quote__text {
  margin: 0 0 28px;
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(44px, 7vw, 132px);
  line-height: .98;
  letter-spacing: -.038em;
  color: var(--ink);
}
.quote__text em {
  font-style: italic;
  color: var(--cobalt);
}
.quote__cite {
  color: var(--ink-3);
  display: inline-flex;
  gap: 10px;
}
.quote__cite__sep { color: var(--rule-2); }

/* =========================================================
   PANEL SYSTEM
   ========================================================= */
.panel {
  position: relative;
  padding: clamp(96px, 10vw, 168px) var(--mx);
  border-bottom: 1px solid var(--ink);
  overflow: hidden;
}
.panel--bone   { background: var(--bone);   color: var(--ink); }
.panel--ink    { background: var(--ink);    color: var(--bone); border-bottom-color: var(--ink); }
.panel--cobalt { background: var(--cobalt); color: var(--bone); border-bottom-color: var(--ink); }

.panel__rail {
  position: absolute;
  top: 24px; left: var(--mx);
  opacity: .6;
}
.panel--bone   .panel__rail { color: var(--ink-3); opacity: 1; }
.panel--ink    .panel__rail { color: var(--silver); }
.panel--cobalt .panel__rail { color: var(--bone); opacity: .8; }

/* corner brackets on dark panels */
.panel--ink::before,
.panel--cobalt::before {
  content: "";
  position: absolute;
  top: 24px; right: 24px;
  width: 36px; height: 36px;
  border-top: 2px solid var(--bone);
  border-right: 2px solid var(--bone);
}
.panel--bone::before {
  content: "";
  position: absolute;
  top: 24px; right: 24px;
  width: 36px; height: 36px;
  border-top: 2px solid var(--ink);
  border-right: 2px solid var(--ink);
}

/* =========================================================
   §04  BELIEFS  —  cobalt full-bleed
   ========================================================= */
.believe__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(280px, 1fr) 2fr;
  gap: clamp(40px, 5vw, 88px);
  align-items: end;
}
.believe__title {
  margin: 0;
  font-size: clamp(48px, 7vw, 132px);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -.04em;
  color: var(--bone);
}
.believe__list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule-bone);
}
.believe__list li {
  display: grid;
  grid-template-columns: 1fr 80px 1fr;
  align-items: center;
  gap: 24px;
  padding: clamp(18px, 2.4vw, 32px) 0;
  border-bottom: 1px solid var(--rule-bone);
  font-size: clamp(36px, 6vw, 96px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.04em;
}
.believe__a { color: var(--bone); text-align: left; }
.believe__b { color: rgba(243,241,237,.45); text-align: right; }
.believe__op {
  text-align: center;
  color: var(--tomato);
  font-family: var(--mono);
  font-size: clamp(28px, 3.2vw, 56px);
  font-weight: 700;
  position: relative;
  top: -.06em;
}
@media (max-width: 880px) {
  .believe__inner { grid-template-columns: 1fr; }
  .believe__list li { grid-template-columns: 1fr 56px 1fr; gap: 12px; }
}

/* =========================================================
   §05  METHOD  —  five verbs, ink panel
   ========================================================= */
.method__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}
.method__title {
  margin: 0 0 clamp(40px, 5vw, 72px);
  font-size: clamp(48px, 7vw, 132px);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -.04em;
  color: var(--bone);
  max-width: 14ch;
}
.method__list {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--rule-bone);
}
.method__step {
  display: grid;
  grid-template-columns: 200px 320px 1fr;
  gap: clamp(18px, 2.5vw, 40px);
  align-items: baseline;
  padding: clamp(22px, 2.6vw, 40px) 0;
  border-bottom: 1px solid var(--rule-bone);
  transition: background .2s var(--ease), padding-left .25s var(--ease);
}
.method__step:hover {
  background: rgba(243,241,237,.04);
  padding-left: 14px;
}
.method__num {
  color: var(--tomato);
}
.method__step h3 {
  margin: 0;
  font-size: clamp(28px, 3.4vw, 52px);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.03em;
  color: var(--bone);
}
.method__step p {
  margin: 0;
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.5;
  color: var(--silver-2);
  max-width: 56ch;
}
@media (max-width: 880px) {
  .method__step { grid-template-columns: 1fr; gap: 8px; }
}

/* =========================================================
   §06  WORK  —  film-reel cards
   ========================================================= */
.work__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}
.work__title {
  margin: 0 0 18px;
  font-size: clamp(40px, 6vw, 110px);
  font-weight: 900;
  line-height: .95;
  letter-spacing: -.04em;
  color: var(--ink);
  max-width: 18ch;
}
.work__lede {
  margin: 0 0 clamp(40px, 5vw, 64px);
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink-3);
  max-width: 56ch;
}
.work__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2vw, 36px);
}
.case {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--ink);
  color: var(--bone);
  overflow: hidden;
  isolation: isolate;
  transform: translateZ(0);
  transition: transform .35s var(--ease-out);
}
.case:hover { transform: translateY(-3px); }

.case__media {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--ink-2);
  border-bottom: 1px solid var(--rule-bone);
}
.case__media__inner {
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  filter: grayscale(100%) contrast(1.1) brightness(.7);
  transform: scale(1.04);
  transition: transform 1s var(--ease-out), filter .6s var(--ease);
}
.case:hover .case__media__inner {
  transform: scale(1.1);
  filter: grayscale(100%) contrast(1.2) brightness(.85);
}
.case__media::after {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(11,11,13,0) 35%, rgba(11,11,13,.85) 100%),
    linear-gradient(135deg, rgba(0,71,255,.55), rgba(0,71,255,0) 60%);
  mix-blend-mode: normal;
  pointer-events: none;
}
.case__media__inner[data-img="beauty"] {
  background-image:
    radial-gradient(circle at 30% 40%, #8a8a8a 0%, #2c2c30 60%, #0b0b0d 100%);
}
.case__media__inner[data-img="food"] {
  background-image:
    radial-gradient(circle at 70% 60%, #a3a098 0%, #3a3a3a 65%, #0b0b0d 100%);
}
.case__media__inner[data-img="hosp"] {
  background-image:
    radial-gradient(circle at 40% 30%, #b5b3aa 0%, #4a4a4a 55%, #0b0b0d 100%);
}
.case__media__inner[data-img="health"] {
  background-image:
    radial-gradient(circle at 60% 70%, #9a9a9a 0%, #353539 60%, #0b0b0d 100%);
}

.case__body {
  padding: 28px 28px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.case__sector { color: var(--cobalt); margin: 0; }
.case h3 {
  margin: 0;
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 800;
  letter-spacing: -.022em;
  line-height: 1.05;
  color: var(--bone);
  max-width: 24ch;
}
.case p {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--silver);
}
.case__stat {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--rule-bone);
  display: flex;
  align-items: baseline;
  gap: 14px;
}
.case__stat__num {
  font-family: var(--sans);
  font-size: clamp(36px, 4vw, 56px);
  font-weight: 900;
  letter-spacing: -.03em;
  color: var(--cobalt);
  font-variant-numeric: tabular-nums;
}
.case__stat__num sub {
  font-size: .55em;
  vertical-align: baseline;
  margin-left: 2px;
  font-weight: 700;
}
.case__stat em {
  font-style: normal;
  font-size: 13px;
  color: var(--silver);
}

@media (max-width: 760px) { .work__grid { grid-template-columns: 1fr; } }

/* =========================================================
   §07  NUMBERS
   ========================================================= */
.numbers__inner { max-width: var(--maxw); margin: 0 auto; }
.numbers__title {
  margin: 0 0 clamp(40px, 5vw, 72px);
  font-size: clamp(48px, 7vw, 120px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.04em;
  color: var(--bone);
}
.numbers__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule-bone);
}
.numbers__cell {
  padding: 32px 24px 36px 0;
  border-right: 1px solid var(--rule-bone);
  border-bottom: 1px solid var(--rule-bone);
}
.numbers__cell:nth-child(4n) { border-right: 0; padding-right: 0; }
.numbers__big {
  font-size: clamp(72px, 11vw, 180px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.05em;
  color: var(--bone);
  font-variant-numeric: tabular-nums;
  margin-bottom: 16px;
}
.numbers__big::after {
  content: ".";
  color: var(--tomato);
}
.numbers__label {
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.4;
  color: var(--silver-2);
  max-width: 22ch;
}
@media (max-width: 880px) {
  .numbers__grid { grid-template-columns: repeat(2, 1fr); }
  .numbers__cell:nth-child(2n) { border-right: 0; }
}

/* =========================================================
   §08  STUDIO  —  operators
   ========================================================= */
.studio__inner { max-width: var(--maxw); margin: 0 auto; }
.studio__title {
  margin: 0 0 18px;
  font-size: clamp(40px, 5.4vw, 96px);
  font-weight: 900;
  line-height: .98;
  letter-spacing: -.038em;
  color: var(--ink);
  max-width: 18ch;
}
.studio__lede {
  margin: 0 0 clamp(40px, 5vw, 64px);
  font-size: clamp(16px, 1.3vw, 19px);
  line-height: 1.45;
  color: var(--ink-2);
  max-width: 56ch;
}
.studio__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.op {
  position: relative;
  background: var(--ink);
  color: var(--bone);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform .35s var(--ease-out);
}
.op:hover { transform: translateY(-3px); }

.op__portrait {
  position: relative;
  aspect-ratio: 4/5;
  background:
    radial-gradient(circle at 50% 38%, #6a6a6a 0%, #2a2a2d 55%, #0b0b0d 100%);
  filter: grayscale(100%) contrast(1.05);
  border-bottom: 1px solid var(--rule-bone);
}
.op__portrait__overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(11,11,13,0) 50%, rgba(11,11,13,.7) 100%),
    linear-gradient(135deg, rgba(0,71,255,.45), rgba(0,71,255,0) 60%);
}
.op__body {
  padding: 26px 26px 32px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.op__id { color: var(--cobalt); margin: 0; }
.op__name {
  margin: 0;
  font-size: clamp(22px, 2.2vw, 30px);
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.05;
  color: var(--bone);
}
.op__bio {
  margin: 0;
  font-size: 14px;
  line-height: 1.5;
  color: var(--silver);
}
.op__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--rule-bone);
}
.op__tags span {
  padding: 4px 10px;
  border: 1px solid var(--rule-bone);
  color: var(--silver);
}
@media (max-width: 880px) { .studio__cards { grid-template-columns: 1fr; } }

/* =========================================================
   §09  VOICE
   ========================================================= */
.voice__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 96px);
  align-items: end;
}
.voice__title {
  margin: 0;
  font-size: clamp(40px, 5.5vw, 92px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.035em;
  color: var(--ink);
}
.voice__title em { font-style: italic; color: var(--cobalt); }
.voice__words {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1vw, 14px);
}
.voice__words li {
  font-size: clamp(36px, 6vw, 92px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.04em;
  color: var(--ink);
}
.voice__words li:nth-child(2) { transform: translateX(clamp(12px, 3vw, 40px)); color: var(--cobalt); }
.voice__words li:nth-child(4) { transform: translateX(clamp(20px, 5vw, 64px)); color: var(--cobalt); }
@media (max-width: 880px) {
  .voice__inner { grid-template-columns: 1fr; }
  .voice__words li { transform: none !important; }
}

/* =========================================================
   §10  ENGAGE  —  two doors
   ========================================================= */
.engage__inner { max-width: var(--maxw); margin: 0 auto; }
.engage__title {
  margin: 0 0 12px;
  font-size: clamp(56px, 9vw, 168px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.04em;
  color: var(--ink);
}
.engage__lede {
  margin: 0 0 clamp(40px, 5vw, 64px);
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.4;
  color: var(--ink-2);
}
.engage__split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--ink);
  border: 1px solid var(--ink);
}
.door {
  position: relative;
  padding: 40px 32px 44px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  background: var(--bone);
  transition: background .25s var(--ease), color .25s var(--ease), transform .25s var(--ease);
  min-height: 280px;
}
.door--in:hover { background: var(--cobalt); color: var(--bone); transform: translateY(-2px); }
.door--in:hover h3,
.door--in:hover p { color: var(--bone); }
.door--in:hover .door__id { color: var(--bone); opacity: .85; }
.door--in:hover .door__email { color: var(--bone); border-color: rgba(243,241,237,.45); }

.door--out { background: var(--bone-2); }
.door--out:hover { background: var(--bone-3); }
.door__id { color: var(--cobalt); }
.door h3 {
  margin: 0;
  font-size: clamp(26px, 2.8vw, 40px);
  font-weight: 800;
  letter-spacing: -.025em;
  line-height: 1.05;
  color: var(--ink);
  max-width: 18ch;
}
.door p {
  margin: 0;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ink-2);
  max-width: 38ch;
}
.door__email {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 700;
  color: var(--cobalt);
  border-top: 1px solid var(--rule);
  padding-top: 18px;
  letter-spacing: -.005em;
}
.door__email svg { width: 16px; height: 16px; }
.door__email--mute { color: var(--ink-3); }
@media (max-width: 760px) { .engage__split { grid-template-columns: 1fr; } }

/* =========================================================
   FOOTER  —  simple. logo · signature · email · ©
   ========================================================= */
.foot {
  background: var(--ink);
  color: var(--bone);
  padding: clamp(64px, 7vw, 104px) var(--mx) 28px;
  border-top: 1px solid var(--ink);
}
.foot__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(40px, 5vw, 72px);
}

.foot__brand {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}
.foot__brand .logo__mark { color: var(--bone); font-size: 22px; letter-spacing: -.01em; }
.foot__brand .logo__sub  { color: var(--silver); font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; }

.foot__sig {
  margin: 0;
  font-size: clamp(40px, 6.4vw, 120px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.035em;
  color: var(--bone);
  max-width: 18ch;
}
.foot__sig em { font-style: italic; color: var(--cobalt); }

.foot__legal {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  align-items: center;
  justify-content: space-between;
  padding-top: 24px;
  border-top: 1px solid var(--rule-bone);
  color: var(--silver);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.foot__legal a {
  color: var(--bone);
  font-weight: 500;
  transition: color .2s var(--ease);
}
.foot__legal a:hover { color: var(--cobalt); }

@media (max-width: 760px) {
  .foot__legal { gap: 12px 20px; }
}

/* =========================================================
   SCROLL REVEAL  +  REDUCED MOTION
   ========================================================= */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
.reveal.is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    transition-duration: .01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
  .reel { height: auto; }
  .reel__pin { position: static; height: auto; padding: 80px 0; }
  .reel__line { position: static; opacity: 1; transform: none; padding: 24px 0; }
}


/* =========================================================
   §03  LETTER  —  founders note
   ========================================================= */
.letter { padding: clamp(80px,9vw,140px) var(--mx); }
.letter__inner {
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 96px);
  align-items: start;
}
.letter__title {
  font-family: var(--ff);
  font-weight: 800;
  font-size: clamp(40px, 5.6vw, 84px);
  line-height: 1.04;
  letter-spacing: -.025em;
  color: var(--ink);
  margin: 0;
}
.letter__title em {
  font-style: italic;
  font-weight: 800;
  color: var(--cobalt);
}
.letter__body {
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 1.4vw, 22px);
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.55;
  color: var(--ink-2);
  max-width: 56ch;
}
.letter__body p { margin: 0; }
.letter__body strong { color: var(--ink); font-weight: 700; }
.letter__body em { font-style: italic; color: var(--ink); }
.letter__sig {
  grid-column: 2;
  margin-top: clamp(24px, 3vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 6px;
  color: var(--ink-2);
}
.letter__scribble {
  width: 140px;
  height: 36px;
  color: var(--cobalt);
}
.letter__sig p { margin: 0; font-size: 14px; line-height: 1.5; }
.letter__sig strong { color: var(--ink); }
.letter__sig .mono { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-3); }

@media (max-width: 880px) {
  .letter__inner { grid-template-columns: 1fr; gap: 36px; }
  .letter__sig { grid-column: 1; }
}


/* =========================================================
   §05  ACCESS  —  what you get (8 disciplines)
   ========================================================= */
.access { padding: clamp(80px,9vw,140px) var(--mx); }
.access__inner { max-width: var(--maxw); margin: 0 auto; }
.access__title {
  font-family: var(--ff);
  font-weight: 800;
  font-size: clamp(40px, 6vw, 96px);
  line-height: .94;
  letter-spacing: -.025em;
  color: var(--ink);
  margin: 0 0 clamp(20px,1.6vw,28px);
}
.access__title em {
  font-style: italic;
  font-weight: 800;
  color: var(--cobalt);
}
.access__lede {
  max-width: 64ch;
  font-size: clamp(15px, 1.1vw, 18px);
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 clamp(48px, 6vw, 80px);
}
.access__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 4vw, 80px);
  border-top: 1px solid var(--rule);
  padding-top: clamp(32px, 4vw, 56px);
}
.access__col__title {
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 24px;
}
.access__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.access__list li {
  padding: clamp(20px, 2vw, 28px) 0;
  border-top: 1px solid var(--rule);
}
.access__list li:first-child { border-top: 0; padding-top: 0; }
.access__list h4 {
  margin: 0 0 6px;
  font-family: var(--ff);
  font-weight: 700;
  font-size: clamp(18px, 1.4vw, 22px);
  line-height: 1.2;
  letter-spacing: -.01em;
  color: var(--ink);
}
.access__list p {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-2);
}
@media (max-width: 760px) {
  .access__grid { grid-template-columns: 1fr; gap: 32px; }
}


/* =========================================================
   §07  COMPARE  —  vs table
   ========================================================= */
.vs { padding: clamp(80px,9vw,140px) var(--mx); }
.vs__inner { max-width: var(--maxw); margin: 0 auto; }
.vs__title {
  font-family: var(--ff);
  font-weight: 800;
  font-size: clamp(36px, 5.4vw, 80px);
  line-height: 1.06;
  letter-spacing: -.025em;
  color: var(--ink);
  margin: 0 0 clamp(40px, 5vw, 64px);
}
.vs__title em {
  font-style: italic;
  font-weight: 800;
  color: var(--cobalt);
}
.vs__table {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) repeat(3, minmax(0, 1.4fr));
  border: 1px solid var(--rule);
  background: var(--bone);
}
.vs__row {
  display: contents;
}
.vs__cell {
  padding: clamp(14px, 1.3vw, 20px) clamp(14px, 1.4vw, 22px);
  border-top: 1px solid var(--rule);
  border-right: 1px solid var(--rule);
  font-size: clamp(13px, 1vw, 15px);
  line-height: 1.45;
  color: var(--ink-2);
}
.vs__row:first-child .vs__cell { border-top: 0; }
.vs__cell:nth-child(4n) { border-right: 0; }
.vs__row--head .vs__cell {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  background: rgba(11,11,13,.03);
}
.vs__cell--label {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.vs__cell--us {
  background: var(--ink);
  color: var(--bone);
  font-weight: 600;
}
.vs__row--head .vs__cell--us {
  background: var(--ink);
  color: var(--bone);
  letter-spacing: .14em;
}
@media (max-width: 760px) {
  .vs__table {
    grid-template-columns: 1fr;
    border: 0;
  }
  .vs__row {
    display: block;
    border: 1px solid var(--rule);
    margin-bottom: 16px;
  }
  .vs__row--head { display: none; }
  .vs__cell { border: 0; border-bottom: 1px solid var(--rule); padding: 14px 16px; }
  .vs__cell:last-child { border-bottom: 0; }
  .vs__cell--label { background: rgba(11,11,13,.04); }
}


/* =========================================================
   §08  STANDARD  —  three rules (ink panel)
   ========================================================= */
.standard { padding: clamp(80px,9vw,140px) var(--mx); }
.standard__inner { max-width: var(--maxw); margin: 0 auto; }
.standard__title {
  font-family: var(--ff);
  font-weight: 800;
  font-size: clamp(40px, 6vw, 96px);
  line-height: .94;
  letter-spacing: -.025em;
  color: var(--bone);
  margin: 0 0 clamp(48px, 5.4vw, 80px);
}
.standard__title em {
  font-style: italic;
  font-weight: 800;
  color: var(--cobalt-light, #5b86ff);
}
.standard__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(243,241,237,.18);
}
.standard__rule {
  padding: clamp(28px, 3vw, 44px) clamp(20px, 2vw, 32px);
  border-right: 1px solid rgba(243,241,237,.18);
  border-bottom: 1px solid rgba(243,241,237,.18);
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 1.6vw, 24px);
  background: transparent;
  transition: background .4s var(--ease-out);
}
.standard__rule:nth-child(3n) { border-right: 0; }
.standard__rule:hover { background: rgba(0,71,255,.08); }
.standard__ref {
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--cobalt-light, #5b86ff);
  margin: 0;
  line-height: 1.4;
}
.standard__body {
  margin: 0;
  font-family: var(--ff);
  font-weight: 500;
  font-size: clamp(18px, 1.5vw, 24px);
  line-height: 1.35;
  letter-spacing: -.01em;
  color: var(--bone);
}
.standard__body em {
  font-style: italic;
  font-weight: 600;
  color: var(--cobalt-light, #5b86ff);
}
@media (max-width: 880px) {
  .standard__list { grid-template-columns: 1fr; }
  .standard__rule { border-right: 0; }
}


/* =========================================================
   §01 HERO — eyebrow + new word sizing
   ========================================================= */
.hero__eyebrow {
  position: absolute;
  top: calc(var(--letterbox) + clamp(28px, 4vw, 56px));
  left: var(--mx);
  font-size: 11px;
  letter-spacing: .26em;
  color: var(--cobalt);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 14px;
}
.hero__eyebrow::before {
  content: "";
  width: 38px;
  height: 1px;
  background: var(--cobalt);
}
.hero__word--big {
  font-size: 1em;
}
.hero__word--small {
  font-size: .26em;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--silver);
  margin-bottom: .16em;
  font-family: var(--mono);
}
.hero__word--big.hero__word--blue { color: var(--cobalt); }

/* =========================================================
   §04 DIFFERENCE — three things that don't exist anywhere else
   Cobalt full-bleed, 3up cinematic stack
   ========================================================= */
.diff { padding: clamp(96px, 11vw, 160px) var(--mx); }
.diff__inner { max-width: var(--maxw); margin: 0 auto; }
.diff__eyebrow {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.7);
  margin: 0 0 32px;
}
.diff__title {
  font-family: var(--sans);
  font-size: clamp(56px, 9vw, 168px);
  font-weight: 900;
  line-height: .9;
  letter-spacing: -.04em;
  color: var(--bone);
  margin: 0 0 clamp(48px, 6vw, 96px);
  max-width: 18ch;
}
.diff__title em {
  font-style: italic;
  color: var(--ink);
}
.diff__list {
  border-top: 1.5px solid rgba(243,241,237,.28);
}
.diff__row {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: clamp(24px, 4vw, 80px);
  align-items: flex-start;
  padding: clamp(36px, 4vw, 64px) 0;
  border-bottom: 1.5px solid rgba(243,241,237,.28);
  transition: background .25s var(--ease);
}
.diff__row:hover { background: rgba(11,11,13,.06); }
.diff__num {
  font-family: var(--sans);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(64px, 7vw, 128px);
  line-height: 1;
  color: rgba(243,241,237,.16);
  letter-spacing: -.04em;
}
.diff__copy h3 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(26px, 3.4vw, 48px);
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--bone);
  margin: 0 0 18px;
  max-width: 22ch;
}
.diff__copy h3 em { font-style: italic; color: var(--ink); }
.diff__copy p {
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.6;
  color: rgba(243,241,237,.78);
  margin: 0;
  max-width: 60ch;
}

/* =========================================================
   §05 PROCESS — 5 steps, ink panel
   ========================================================= */
.process { padding: clamp(96px, 11vw, 160px) var(--mx); }
.process__inner { max-width: var(--maxw); margin: 0 auto; }
.process__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 4vw, 80px);
  align-items: end;
  margin-bottom: clamp(48px, 6vw, 96px);
}
.process__title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(40px, 5.4vw, 88px);
  line-height: 1.05;
  letter-spacing: -.03em;
  color: var(--bone);
  margin: 0;
  max-width: 14ch;
}
.process__title em { font-style: italic; color: var(--cobalt); }
.process__lede {
  font-size: clamp(15px, 1.2vw, 19px);
  line-height: 1.6;
  color: var(--silver);
  margin: 0;
  max-width: 50ch;
}
.process__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: rgba(243,241,237,.1);
  border: 1px solid rgba(243,241,237,.1);
}
.process__step {
  background: var(--ink);
  padding: 28px 24px 36px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  position: relative;
  min-height: 280px;
  transition: background .25s var(--ease);
}
.process__step:hover { background: var(--ink-2); }
.process__num {
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--cobalt);
}
.process__step h3 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(22px, 2vw, 32px);
  letter-spacing: -.02em;
  color: var(--bone);
  margin: 0;
}
.process__step p {
  font-size: 14px;
  line-height: 1.55;
  color: rgba(243,241,237,.5);
  margin: 0;
}

/* =========================================================
   §06 CAPABILITIES — 8 disciplines, bone panel
   ========================================================= */
.caps { padding: clamp(96px, 11vw, 160px) var(--mx); }
.caps__inner { max-width: var(--maxw); margin: 0 auto; }
.caps__title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(48px, 7vw, 128px);
  line-height: 1.05;
  letter-spacing: -.04em;
  color: var(--ink);
  margin: 0 0 24px;
  max-width: 16ch;
}
.caps__title em { font-style: italic; color: var(--cobalt); }
.caps__lede {
  font-size: clamp(15px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink-3);
  margin: 0 0 clamp(48px, 6vw, 88px);
  max-width: 60ch;
}
.caps__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.caps__cell {
  background: var(--bone);
  padding: 32px 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 200px;
  transition: background .25s var(--ease);
  position: relative;
}
.caps__cell:hover { background: var(--bone-2); }
.caps__num {
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--cobalt);
  margin-bottom: auto;
}
.caps__cell h4 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 19px;
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0;
}
.caps__cell p {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink-3);
  margin: 0;
}

/* =========================================================
   §07 PHASES — Foundation → Partnership
   ========================================================= */
.phases { padding: clamp(96px, 11vw, 160px) var(--mx); }
.phases__inner { max-width: var(--maxw); margin: 0 auto; }
.phases__title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(48px, 7vw, 128px);
  line-height: 1.05;
  letter-spacing: -.04em;
  color: var(--bone);
  margin: 0 0 clamp(48px, 6vw, 88px);
  max-width: 14ch;
}
.phases__title em { font-style: italic; color: var(--cobalt); }
.phases__split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1.5px solid rgba(243,241,237,.18);
}
.phase {
  padding: clamp(36px, 4vw, 56px) clamp(24px, 3vw, 48px) clamp(40px, 5vw, 72px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  border-right: 1.5px solid rgba(243,241,237,.18);
}
.phase:last-child { border-right: 0; }
.phase--filled { background: var(--cobalt); color: var(--bone); }
.phase__id {
  font-size: 10px;
  letter-spacing: .24em;
  color: var(--cobalt);
}
.phase--filled .phase__id { color: var(--bone); opacity: .85; }
.phase__time {
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--silver);
}
.phase--filled .phase__time { color: rgba(243,241,237,.7); }
.phase h3 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(28px, 3.2vw, 48px);
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--bone);
  margin: 12px 0 6px;
  max-width: 18ch;
}
.phase--filled h3 { color: var(--bone); }
.phase p {
  font-size: clamp(15px, 1.15vw, 17px);
  line-height: 1.55;
  color: var(--silver);
  margin: 0;
  max-width: 42ch;
}
.phase--filled p { color: rgba(243,241,237,.85); }

/* =========================================================
   §09 BRANDS — legacy styles (section now replaced by .reach)
   ========================================================= */
.brands { padding: clamp(96px, 11vw, 160px) var(--mx); }
.brands__inner { max-width: var(--maxw); margin: 0 auto; }
.brands__title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(48px, 7vw, 128px);
  line-height: .94;
  letter-spacing: -.04em;
  color: var(--bone);
  margin: 0 0 24px;
  max-width: 14ch;
}
.brands__title em { font-style: italic; color: var(--cobalt); }
.brands__lede {
  font-size: clamp(15px, 1.2vw, 19px);
  line-height: 1.6;
  color: var(--silver);
  margin: 0 0 clamp(40px, 5vw, 64px);
  max-width: 56ch;
}
/* =========================================================
   §09  REACH — scale × category matrix
   ========================================================= */
.reach { padding: clamp(96px, 11vw, 180px) var(--mx); }
.reach__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: clamp(48px, 6vw, 96px);
}
.reach__head {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(32px, 4vw, 80px);
  align-items: end;
}
.reach__title {
  margin: 0;
  font-family: var(--sans);
  font-size: clamp(48px, 6vw, 112px);
  font-weight: 900;
  letter-spacing: -.04em;
  line-height: .95;
  color: var(--bone);
}
.reach__title em { font-style: italic; color: var(--cobalt); font-weight: 900; }
.reach__lede {
  margin: 0;
  font-size: clamp(15px, 1.1vw, 18px);
  line-height: 1.55;
  color: var(--silver);
  max-width: 48ch;
}

/* reachimg — cinematic hero illustration with editorial overlays */
.reachimg {
  position: relative;
  margin: 0 calc(var(--mx) * -1);
  border-top: 1px solid rgba(243,241,237,.22);
  border-bottom: 1px solid rgba(243,241,237,.22);
  aspect-ratio: 16 / 9;
  overflow: hidden;
  isolation: isolate;
  background: #04060c;
}
.reachimg__media {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  filter: contrast(1.05) saturate(1.05) brightness(.95);
  z-index: 1;
}
.reachimg__veil {
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 80% at 18% 92%, rgba(11,11,13,.78) 0%, rgba(11,11,13,.55) 28%, rgba(11,11,13,.10) 60%, transparent 80%),
    linear-gradient(180deg, rgba(11,11,13,.22) 0%, transparent 30%, transparent 60%, rgba(11,11,13,.55) 100%);
  z-index: 2;
  pointer-events: none;
}
.reachimg__copy {
  position: absolute;
  left: clamp(28px, 3.6vw, 64px);
  bottom: clamp(56px, 6vw, 96px);
  right: clamp(28px, 3.6vw, 64px);
  z-index: 4;
  display: flex;
  flex-direction: column;
  gap: clamp(14px, 1.4vw, 24px);
  max-width: min(820px, 60%);
}
.reachimg__plate {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 10px;
  letter-spacing: .26em;
  color: var(--silver);
  text-transform: uppercase;
}
.reachimg__plate::before {
  content: "";
  width: 10px; height: 10px;
  background: var(--red);
  border-radius: 50%;
  display: inline-block;
}
.reachimg__title {
  margin: 0;
  font-family: var(--sans);
  font-size: clamp(40px, 5.6vw, 104px);
  font-weight: 900;
  letter-spacing: -.04em;
  line-height: 1.04;
  color: var(--bone);
}
.reachimg__title em { font-style: italic; color: var(--cobalt); font-weight: 900; line-height: 1.04; }
.reachimg__lede {
  margin: 0;
  font-size: clamp(15px, 1.05vw, 18px);
  line-height: 1.55;
  color: var(--silver);
  max-width: 52ch;
}

/* horizontal scale ticks across the bottom of the image */
.reachimg__ticks {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  margin: 0; padding: 0;
  list-style: none;
  border-top: 1px solid rgba(243,241,237,.18);
  background: linear-gradient(180deg, transparent 0%, rgba(11,11,13,.65) 100%);
}
.reachimg__ticks li {
  position: relative;
  padding: 14px 16px 14px;
  border-left: 1px solid rgba(243,241,237,.14);
  font-size: 10px;
  letter-spacing: .26em;
  color: var(--bone);
  text-transform: uppercase;
  display: flex;
  align-items: center;
  justify-content: center;
}
.reachimg__ticks li:first-child { border-left: 0; }
.reachimg__ticks li::before {
  content: "";
  position: absolute;
  top: 0; left: 50%;
  width: 1px; height: 14px;
  background: var(--cobalt);
  transform: translateX(-.5px);
}
.reachimg__ticks li:first-child::before,
.reachimg__ticks li:last-child::before { background: var(--red); height: 18px; }

/* vertical category chips along the right edge of the image */
.reachimg__chips {
  position: absolute;
  top: clamp(24px, 3vw, 40px);
  right: clamp(24px, 3vw, 40px);
  z-index: 3;
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  text-align: right;
}
.reachimg__chips li {
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--bone);
  text-transform: uppercase;
  background: rgba(11,11,13,.55);
  border: 1px solid rgba(243,241,237,.22);
  padding: 6px 10px;
  backdrop-filter: blur(4px);
}
.reachimg__chips li:nth-child(2n) {
  border-color: var(--cobalt);
  color: var(--bone);
}

/* legacy atlas remains hidden */
.atlas[hidden] { display: none !important; }
.atlas {
  position: relative;
  margin: 0 calc(var(--mx) * -1);
  border-top: 1px solid rgba(243,241,237,.22);
  border-bottom: 1px solid rgba(243,241,237,.22);
  padding: clamp(28px, 3.4vw, 56px) 0;
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.4vw, 22px);
  overflow: hidden;
  user-select: none;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.atlas__row {
  width: 100%;
  overflow: hidden;
  white-space: nowrap;
  display: flex;
}
.atlas__track {
  display: inline-flex;
  align-items: center;
  gap: clamp(28px, 3vw, 64px);
  flex-shrink: 0;
  white-space: nowrap;
  padding-right: clamp(28px, 3vw, 64px);
  will-change: transform;
}
.atlas__track--rtl      { animation: atlas-rtl 70s linear infinite; }
.atlas__track--ltr      { animation: atlas-ltr 80s linear infinite; }
.atlas__track--rtl-slow { animation: atlas-rtl 110s linear infinite; }

@keyframes atlas-rtl { from { transform: translateX(0);    } to { transform: translateX(-50%); } }
@keyframes atlas-ltr { from { transform: translateX(-50%); } to { transform: translateX(0);    } }

@media (prefers-reduced-motion: reduce) {
  .atlas__track--rtl,
  .atlas__track--ltr,
  .atlas__track--rtl-slow { animation: none; transform: translateX(0); }
}

/* row tiers */
.atlas__row--lg .atlas__track > span {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(56px, 9vw, 168px);
  letter-spacing: -.04em;
  line-height: 1;
  color: var(--bone);
}
.atlas__row--md .atlas__track > span {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(36px, 5.6vw, 108px);
  letter-spacing: -.035em;
  line-height: 1;
  color: var(--cobalt);
}
.atlas__row--md .atlas__track > span em { font-style: italic; }
.atlas__row--sm .atlas__track > span {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(20px, 2.4vw, 40px);
  letter-spacing: -.01em;
  line-height: 1;
  color: var(--bone);
}

/* separators */
.atlas__sep {
  display: inline-block;
  flex-shrink: 0;
  width: clamp(10px, 1vw, 14px);
  height: clamp(10px, 1vw, 14px);
  border-radius: 50%;
}
.atlas__sep--red    { background: var(--red); }
.atlas__sep--bone   { background: var(--bone); transform: rotate(45deg); border-radius: 0; }
.atlas__sep--cobalt { background: var(--cobalt); width: clamp(6px, .7vw, 10px); height: clamp(6px, .7vw, 10px); }

/* stats strip below the matrix */
.reach__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(243,241,237,.22);
  border: 1px solid rgba(243,241,237,.22);
}
.reach__stats li {
  background: var(--ink);
  padding: clamp(20px, 2vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
}
.reach__stats .mono {
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--silver);
}
.reach__stats strong {
  font-family: var(--sans);
  font-size: clamp(24px, 2.6vw, 44px);
  font-weight: 900;
  letter-spacing: -.025em;
  color: var(--bone);
  line-height: 1.05;
}
.reach__arr {
  color: var(--cobalt);
  font-style: normal;
  margin: 0 .15em;
}
.reach__foot {
  font-size: 10px;
  letter-spacing: .2em;
  color: var(--silver);
  text-align: center;
  margin: 0;
  text-transform: uppercase;
}

/* reel — closer line "Until now." treatment */
.reel__line--hero em { color: var(--cobalt); font-style: italic; }
.reel__line[data-i="2"] { color: var(--bone); }
.reel__line[data-i="3"] { color: var(--cobalt); }
.reel__line[data-i="4"] { color: var(--bone); }


/* =========================================================
   MOBILE POLISH  —  first-class layout under 720px
   Treat phone as a primary canvas, not a fallback.
   ========================================================= */
@media (max-width: 720px) {

  :root {
    --mx: 20px;
    --letterbox: 38px;
  }

  /* kill custom cursor + grain perf cost */
  .cursor { display: none !important; }
  .grain { opacity: .22; }

  /* ---------- NAV ---------- */
  .nav__inner { padding: 12px var(--mx); gap: 12px; }
  .logo__mark { font-size: 16px; }
  .logo__sub  { font-size: 8px; letter-spacing: .2em; }
  .nav__cta { padding: 10px 14px; font-size: 12px; }
  .nav__cta svg { width: 12px; height: 12px; }

  /* ---------- HERO ---------- */
  .hero { min-height: 100svh; }
  .hero__sweep::before { width: 110%; transform: rotate(-18deg) translateX(10%); opacity: .35; }
  .hero__sweep::after  { filter: blur(28px); }

  .hero__letterbox { padding: 0 14px; }
  /* drop the long descriptor on mobile, keep mark + take */
  .slate--top span:nth-child(3),
  .slate--top span:nth-child(4) { display: none; }
  .slate { font-size: 9px; letter-spacing: .12em; gap: 8px; }
  .slate--top-right span { font-size: 9px; }

  /* hero rail is redundant against the slate on mobile */
  .hero__rail { display: none; }

  .hero__inner {
    padding: calc(var(--letterbox) + 28px) var(--mx)
             calc(var(--letterbox) + 28px);
    gap: 18px;
  }
  .hero__title {
    /* longest word "Brand-building" (14ch) must fit at 390px — tighter letter-spacing buys headroom */
    font-size: clamp(54px, 12.6vw, 116px);
    letter-spacing: -.075em;
    line-height: .9;
  }
  .hero__word--small { font-size: .42em; }
  .hero__sub { font-size: 18px; line-height: 1.2; max-width: 30ch; }

  .hero__ctas { width: 100%; }
  .hero__ctas .btn { width: 100%; justify-content: center; padding: 18px 22px; font-size: 15px; }

  /* SCROLL cue overlapped the CTA at narrow widths — drop it on phones */
  .hero__cue { display: none; }

  /* ---------- PANEL CHROME ---------- */
  .panel { padding: clamp(64px, 18vw, 104px) var(--mx); }
  .panel__rail,
  .reel__rail,
  .quote__rail { font-size: 9px; letter-spacing: .14em; top: 16px; }
  .panel--ink::before,
  .panel--cobalt::before,
  .panel--bone::before { width: 22px; height: 22px; top: 16px; right: 16px; border-width: 1.5px; }

  /* ---------- §02  MANIFESTO REEL  —  push type so it FILLS the viewport ---------- */
  .reel { height: 280vh; }
  .reel__line {
    font-size: clamp(48px, 13vw, 110px);
    letter-spacing: -.05em;
    line-height: 1.04;
    width: calc(100% - (var(--mx) * 2));
  }
  .reel__counter { top: 16px; right: var(--mx); font-size: 11px; }
  .reel__counter [data-reel-current] { font-size: 13px; }
  .reel__progress { bottom: 16px; }

  /* ---------- §03  LETTER ---------- */
  .letter { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .letter__inner { gap: 28px; }
  .letter__title { font-size: clamp(40px, 11vw, 64px); line-height: 1.04; }
  .letter__body { font-size: 16px; line-height: 1.55; gap: 16px; }
  .letter__sig { margin-top: 20px; }
  .letter__scribble { width: 110px; height: 28px; }

  /* ---------- §04  BELIEFS ---------- */
  .believe__title { font-size: clamp(44px, 13vw, 84px); line-height: .94; }
  .believe__list li {
    grid-template-columns: 1fr;
    grid-template-areas:
      "a"
      "op"
      "b";
    gap: 4px;
    padding: 18px 0;
    font-size: clamp(36px, 11vw, 64px);
    line-height: 1;
  }
  .believe__a  { grid-area: a;  text-align: left; }
  .believe__op { grid-area: op; text-align: left; font-size: clamp(22px, 6vw, 32px); }
  .believe__b  { grid-area: b;  text-align: left; }

  /* ---------- §05  ACCESS ---------- */
  .access { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .access__title { font-size: clamp(40px, 12vw, 72px); }
  .access__lede  { font-size: 16px; line-height: 1.55; }
  .access__grid  { gap: 36px; padding-top: 28px; }
  .access__col__title { font-size: 10px; letter-spacing: .2em; margin-bottom: 18px; }
  .access__list li { padding: 18px 0; }
  .access__list h4 { font-size: 18px; }
  .access__list p  { font-size: 14px; }

  /* ---------- §06  METHOD ---------- */
  .method__title { font-size: clamp(48px, 14vw, 92px); max-width: 12ch; }
  .method__step  { padding: 22px 0; gap: 6px; }
  .method__step .mono { font-size: 10px; letter-spacing: .18em; }
  .method__step h3 { font-size: clamp(28px, 8vw, 44px); }
  .method__step p  { font-size: 15px; line-height: 1.5; }

  /* ---------- §04  DIFFERENCE ---------- */
  .diff { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .diff__title { font-size: clamp(44px, 13vw, 84px); line-height: .94; }
  .diff__row {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 28px 0;
  }
  .diff__num { font-size: 56px; }
  .diff__copy h3 { font-size: clamp(22px, 6.5vw, 32px); margin-bottom: 12px; }
  .diff__copy p  { font-size: 15px; line-height: 1.55; }

  /* ---------- §05  PROCESS ---------- */
  .process { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .process__head { grid-template-columns: 1fr; gap: 20px; margin-bottom: 36px; }
  .process__title { font-size: clamp(40px, 12vw, 72px); max-width: 14ch; }
  .process__lede  { font-size: 15px; line-height: 1.55; }
  .process__list  {
    grid-template-columns: 1fr;
    background: rgba(243,241,237,.14);
    border: 0;
  }
  .process__step  { min-height: 0; padding: 24px 20px 26px; gap: 12px; }
  .process__step h3 { font-size: clamp(24px, 7vw, 32px); }
  .process__step p  { font-size: 14px; }

  /* ---------- §06  CAPABILITIES ---------- */
  .caps { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .caps__title { font-size: clamp(40px, 12vw, 72px); }
  .caps__lede  { font-size: 15px; line-height: 1.55; margin-bottom: 36px; }
  .caps__grid  {
    grid-template-columns: 1fr 1fr;
  }
  .caps__cell  { min-height: 160px; padding: 22px 16px 20px; gap: 10px; }
  .caps__cell h4 { font-size: 16px; }
  .caps__cell p  { font-size: 12px; }

  /* ---------- §07  PHASES ---------- */
  .phases { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .phases__title { font-size: clamp(40px, 12vw, 72px); margin-bottom: 36px; max-width: 14ch; }
  .phases__split { grid-template-columns: 1fr; }
  .phase  {
    border-right: 0;
    border-bottom: 1.5px solid rgba(243,241,237,.18);
    padding: 28px 0 32px;
  }
  .phase:last-child { border-bottom: 0; }
  .phase h3 { font-size: clamp(26px, 7.5vw, 36px); }

  /* ---------- §08  COMPARE  —  card layout ---------- */
  .vs { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .vs__title { font-size: clamp(36px, 11vw, 60px); margin-bottom: 32px; }
  .vs__row { background: var(--bone); }
  /* first cell in each row becomes a row title in cobalt */
  .vs__row .vs__cell--label {
    background: var(--ink);
    color: var(--bone);
    font-size: 10px;
    letter-spacing: .2em;
    padding: 14px 16px;
  }
  /* prefix labels for the three columns inside each card */
  .vs__row .vs__cell:nth-child(2)::before,
  .vs__row .vs__cell:nth-child(3)::before,
  .vs__row .vs__cell:nth-child(4)::before {
    display: block;
    font-family: var(--mono);
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--ink-3);
    margin-bottom: 6px;
  }
  .vs__row .vs__cell:nth-child(2)::before { content: "Riviera"; color: var(--cobalt); }
  .vs__row .vs__cell:nth-child(3)::before { content: "Agency"; }
  .vs__row .vs__cell:nth-child(4)::before { content: "In-house hire"; }
  .vs__row .vs__cell--us {
    background: rgba(0,71,255,.04);
    color: var(--ink);
  }
  .vs__row .vs__cell { font-size: 14px; line-height: 1.5; }

  /* ---------- §08  STANDARD ---------- */
  .standard { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .standard__title { font-size: clamp(40px, 12vw, 72px); margin-bottom: 32px; }
  .standard__rule  { padding: 24px 0; border-bottom: 1px solid rgba(243,241,237,.18); }
  .standard__list  { border-top: 1px solid rgba(243,241,237,.18); }
  .standard__body  { font-size: 18px; line-height: 1.4; }

  /* ---------- §09  REACH — blueprint hero ---------- */
  .reach { padding: clamp(72px, 16vw, 110px) var(--mx); }
  .reach__inner { gap: 32px; }

  .reachimg { aspect-ratio: 4 / 5; }
  .reachimg__copy {
    left: 18px; right: 18px;
    bottom: 64px;
    max-width: none;
    gap: 12px;
  }
  .reachimg__title { font-size: clamp(36px, 10vw, 60px); }
  .reachimg__lede  { font-size: 14px; max-width: none; }
  .reachimg__plate { font-size: 9px; letter-spacing: .22em; }
  .reachimg__plate::before { width: 8px; height: 8px; }

  .reachimg__chips {
    top: 14px; right: 14px;
    gap: 6px;
  }
  .reachimg__chips li { font-size: 8px; padding: 4px 7px; letter-spacing: .18em; }
  .reachimg__chips li:nth-child(n+6) { display: none; }

  .reachimg__ticks li { padding: 10px 4px; font-size: 8px; letter-spacing: .14em; }

  /* stats strip — 2x2 on phone */
  .reach__stats { grid-template-columns: 1fr 1fr; }
  .reach__stats li { padding: 18px 16px; gap: 8px; }
  .reach__stats strong { font-size: clamp(22px, 6vw, 32px); line-height: 1.1; }

  .reach__foot { font-size: 9px; letter-spacing: .14em; }

  /* ---------- HERO eyebrow ---------- */
  .hero__eyebrow { display: none; }

  /* ---------- §10 ENGAGE ---------- */
  .engage__title { font-size: clamp(56px, 16vw, 96px); }
  .engage__lede  { font-size: 17px; line-height: 1.45; margin-bottom: 32px; }
  .engage__split { gap: 1px; }
  .door { padding: 28px 22px 32px; min-height: 220px; gap: 14px; }
  .door h3 { font-size: 24px; }
  .door p  { font-size: 14px; }
  .door__email { font-size: 15px; padding-top: 14px; }

  /* ---------- FOOTER ---------- */
  .foot { padding: 64px var(--mx) 28px; }
  .foot__top { padding-bottom: 28px; gap: 20px; }
  .foot__brand .logo__mark { font-size: 18px; }
  .foot__manifesto { font-size: 13px; }
  .foot__sig {
    margin: 36px 0 36px;
    font-size: clamp(48px, 14vw, 80px);
    line-height: 1.05;
  }
  .foot__cols { gap: 24px 16px; padding-top: 28px; margin-bottom: 36px; }
  .foot__cols h5 { font-size: 10px; letter-spacing: .2em; margin-bottom: 12px; }
  .foot__cols a { font-size: 13px; padding: 8px 0; }
  .foot__legal { gap: 14px; font-size: 9px; letter-spacing: .12em; padding-top: 18px; }
}


/* =========================================================
   SHARED PAGE HERO  (work, notes)
   ========================================================= */
.page-hero {
  position: relative;
  background: var(--ink);
  color: var(--bone);
  padding: clamp(140px, 14vw, 200px) var(--mx) clamp(80px, 9vw, 140px);
  border-bottom: 1.5px solid rgba(243,241,237,.2);
  overflow: hidden;
}
.page-hero::after {
  content: "";
  position: absolute;
  right: -6%;
  top: 12%;
  width: 60vw;
  height: 50vh;
  background: radial-gradient(ellipse at center, rgba(0,71,255,.32), rgba(0,71,255,0) 70%);
  pointer-events: none;
}
.page-hero__rail {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.7);
  margin-bottom: clamp(36px, 4vw, 56px);
}
.page-hero__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.page-hero__eyebrow {
  font-size: 12px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.7);
  margin: 0 0 24px;
}
.page-hero__title {
  font-family: var(--sans);
  font-size: clamp(72px, 12vw, 220px);
  font-weight: 900;
  line-height: .88;
  letter-spacing: -.04em;
  margin: 0 0 clamp(32px, 4vw, 56px);
  color: var(--bone);
}
.page-hero__title em {
  font-style: italic;
  color: var(--cobalt);
}
.page-hero__sub {
  font-size: clamp(17px, 1.4vw, 22px);
  line-height: 1.45;
  color: rgba(243,241,237,.78);
  max-width: 60ch;
  margin: 0;
}

/* =========================================================
   FILTER BAR  (shared work + notes)
   ========================================================= */
.work-filter {
  padding: clamp(36px, 4vw, 64px) var(--mx);
  border-bottom: 1.5px solid var(--rule);
}
.work-filter__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px;
  justify-content: space-between;
}
.work-filter__rail {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(11,11,13,.5);
  flex-basis: 100%;
  margin-bottom: 8px;
}
.work-filter__bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.filter-btn {
  appearance: none;
  background: transparent;
  border: 1.5px solid var(--ink);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .02em;
  padding: 12px 20px;
  cursor: pointer;
  transition: background .25s var(--ease), color .25s var(--ease);
}
.filter-btn:hover { background: var(--ink); color: var(--bone); }
.filter-btn.is-active { background: var(--cobalt); color: var(--bone); border-color: var(--cobalt); }
.work-filter__count {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(11,11,13,.5);
}

/* =========================================================
   WORK GRID
   ========================================================= */
.work { padding: clamp(60px, 7vw, 110px) var(--mx) clamp(80px, 9vw, 140px); }
.work__inner { max-width: var(--maxw); margin: 0 auto; }
.work__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(24px, 3vw, 48px);
  list-style: none;
  padding: 0;
  margin: 0;
}
.work-card { transition: transform .35s var(--ease); }
.work-card__link {
  display: block;
  background: var(--bone-2);
  text-decoration: none;
  color: var(--ink);
  border: 1px solid var(--rule);
  transition: transform .35s var(--ease), border-color .35s var(--ease);
}
.work-card__link:hover { transform: translateY(-4px); border-color: var(--cobalt); }
.work-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #14151a;
}
.work-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(.4) contrast(1.04);
  transition: transform .6s var(--ease), filter .35s var(--ease);
}
.work-card__link:hover .work-card__media img {
  transform: scale(1.04);
  filter: grayscale(0) contrast(1);
}
.work-card__sweep {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,71,255,0) 60%, rgba(0,71,255,.55) 100%);
  mix-blend-mode: multiply;
  pointer-events: none;
  opacity: .85;
  transition: opacity .35s var(--ease);
}
.work-card__link:hover .work-card__sweep { opacity: 0; }
.work-card__arch {
  position: absolute;
  top: 16px;
  left: 16px;
  background: var(--bone);
  color: var(--ink);
  padding: 6px 10px;
  font-size: 10px;
  letter-spacing: .24em;
}
.work-card__meta {
  padding: clamp(20px, 2vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.work-card__year {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(11,11,13,.5);
}
.work-card__brand {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(28px, 2.6vw, 44px);
  line-height: 1;
  letter-spacing: -.02em;
  margin: 4px 0 0;
}
.work-card__cat {
  font-size: 11px;
  letter-spacing: .22em;
  color: rgba(11,11,13,.55);
}
.work-card__tagline {
  font-size: 16px;
  line-height: 1.45;
  color: rgba(11,11,13,.78);
  margin: 8px 0 0;
}
.work-card__cta {
  margin-top: 12px;
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--cobalt);
}
.work__empty {
  padding: 64px 0;
  text-align: center;
  color: rgba(11,11,13,.6);
}
.work__empty a { color: var(--cobalt); text-decoration: underline; text-underline-offset: 4px; }

/* =========================================================
   END STRIP — shared bottom CTA
   ========================================================= */
.end-strip { padding: clamp(80px, 10vw, 140px) var(--mx); border-top: 1.5px solid rgba(243,241,237,.2); }
.end-strip__inner {
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(32px, 4vw, 80px);
  align-items: end;
}
.end-strip__title {
  font-family: var(--sans);
  font-size: clamp(56px, 7vw, 120px);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -.04em;
  margin: 0;
  color: var(--bone);
}
.end-strip__title em { font-style: italic; color: var(--cobalt); }
.end-strip__sub {
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.5;
  color: rgba(243,241,237,.78);
  margin: 0 0 18px;
  max-width: 44ch;
}
.end-strip .btn {
  justify-self: start;
  align-self: end;
}

/* =========================================================
   CASE STUDY PAGE
   ========================================================= */
.case-hero {
  position: relative;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 0;
  background: var(--ink);
  color: var(--bone);
  min-height: 92vh;
  padding-top: 90px;
  border-bottom: 1.5px solid rgba(243,241,237,.2);
}
.case-hero__media {
  position: relative;
  overflow: hidden;
  background: #0e0f12;
}
.case-hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(.6) contrast(1.05);
}
.case-hero__sweep {
  position: absolute; inset: 0;
  background: linear-gradient(120deg, rgba(0,71,255,.45), rgba(0,71,255,0) 70%);
  mix-blend-mode: screen;
  pointer-events: none;
}
.case-hero__content {
  padding: clamp(40px, 5vw, 96px) clamp(28px, 4vw, 80px) clamp(60px, 6vw, 96px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 18px;
  position: relative;
}
.case-hero__back {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.65);
  text-decoration: none;
  align-self: flex-start;
  margin-bottom: clamp(28px, 4vw, 64px);
  transition: color .2s var(--ease);
}
.case-hero__back:hover { color: var(--cobalt); }
.case-hero__rail {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.7);
}
.slate__sep { opacity: .3; }
.case-hero__brand {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(64px, 8.5vw, 168px);
  line-height: .9;
  letter-spacing: -.04em;
  margin: 6px 0 4px;
  color: var(--bone);
}
.case-hero__category {
  font-size: 12px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.65);
  margin: 0 0 14px;
}
.case-hero__tagline {
  font-size: clamp(18px, 1.5vw, 24px);
  line-height: 1.4;
  color: var(--bone);
  margin: 0;
  max-width: 36ch;
}

.case-section {
  padding: clamp(80px, 9vw, 160px) var(--mx);
  border-bottom: 1.5px solid var(--rule);
}
.case-section.panel--ink { border-bottom-color: rgba(243,241,237,.18); color: var(--bone); }
.case-section.panel--cobalt { border-bottom: 0; color: var(--bone); }
.case-section__rail {
  font-size: 11px;
  letter-spacing: .28em;
  color: inherit;
  opacity: .65;
  margin-bottom: clamp(36px, 4vw, 64px);
  max-width: var(--maxw);
  margin-left: auto;
  margin-right: auto;
}
.panel--ink .case-section__rail { color: rgba(243,241,237,.7); opacity: 1; }
.case-section__inner {
  max-width: var(--maxw);
  margin: 0 auto;
}
.case-section__title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(48px, 7vw, 132px);
  line-height: .92;
  letter-spacing: -.04em;
  margin: 0 0 clamp(36px, 4vw, 64px);
  max-width: 18ch;
}
.case-section__title em { font-style: italic; color: var(--cobalt); }
.panel--ink .case-section__title { color: var(--bone); }
.panel--ink .case-section__title em { color: var(--cobalt); }
.case-section__body p {
  font-size: clamp(17px, 1.3vw, 21px);
  line-height: 1.55;
  margin: 0 0 18px;
  max-width: 70ch;
  color: rgba(11,11,13,.82);
}

/* §02 — work list */
.case-work__list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1.5px solid rgba(243,241,237,.22);
}
.case-work__row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: clamp(24px, 4vw, 80px);
  padding: clamp(28px, 3.5vw, 48px) 0;
  border-bottom: 1.5px solid rgba(243,241,237,.22);
}
.case-work__num {
  font-size: clamp(40px, 4.5vw, 72px);
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--cobalt);
  font-family: var(--sans);
  line-height: 1;
}
.case-work__copy h3 {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(24px, 2.4vw, 38px);
  line-height: 1.1;
  margin: 0 0 12px;
  color: var(--bone);
  letter-spacing: -.01em;
}
.case-work__copy p {
  font-size: clamp(16px, 1.15vw, 19px);
  line-height: 1.55;
  color: rgba(243,241,237,.78);
  margin: 0;
  max-width: 70ch;
}

/* §03 — stats bar */
.case-stats {
  padding: clamp(60px, 6vw, 100px) var(--mx);
  background: var(--cobalt);
  color: var(--bone);
}
.case-stats .case-section__rail {
  color: rgba(243,241,237,.85);
  opacity: 1;
  margin-bottom: clamp(28px, 3vw, 48px);
}
.case-stats__bar {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: var(--maxw);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1.5px solid rgba(243,241,237,.3);
  border-bottom: 1.5px solid rgba(243,241,237,.3);
}
.case-stats__item {
  padding: clamp(36px, 4vw, 64px) clamp(20px, 2vw, 32px);
  border-right: 1.5px solid rgba(243,241,237,.3);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.case-stats__item:last-child { border-right: 0; }
.case-stats__num {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(56px, 7vw, 132px);
  line-height: 1;
  letter-spacing: -.04em;
}
.case-stats__label {
  font-size: 11px;
  letter-spacing: .26em;
  color: rgba(243,241,237,.85);
  max-width: 28ch;
}

/* §04 — outcomes */
.case-outcomes__list {
  list-style: none;
  margin: 0 0 clamp(48px, 6vw, 96px);
  padding: 0;
  border-top: 1.5px solid rgba(11,11,13,.18);
}
.case-outcome {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: clamp(20px, 3vw, 48px);
  padding: clamp(20px, 2.5vw, 32px) 0;
  border-bottom: 1.5px solid rgba(11,11,13,.18);
}
.case-outcome__num {
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--cobalt);
  padding-top: 6px;
}
.case-outcome p {
  font-size: clamp(17px, 1.3vw, 22px);
  line-height: 1.5;
  margin: 0;
  color: var(--ink);
  max-width: 70ch;
}
.case-scope { padding-top: clamp(24px, 3vw, 48px); }
.case-scope__label {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(11,11,13,.55);
  margin: 0 0 16px;
}
.case-scope__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.case-scope__item {
  border: 1.5px solid var(--ink);
  padding: 8px 14px;
  font-size: 12px;
  letter-spacing: .04em;
}

/* §05 — quote */
.case-quote { padding: clamp(96px, 11vw, 180px) var(--mx); }
.case-quote__copy {
  margin: 0;
  position: relative;
  max-width: var(--maxw);
  margin-left: auto;
  margin-right: auto;
}
.case-quote__mark {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(120px, 16vw, 280px);
  line-height: 1;
  color: var(--cobalt);
  display: block;
  margin-bottom: -.4em;
}
.case-quote__copy p {
  font-family: var(--sans);
  font-weight: 700;
  font-size: clamp(28px, 3.4vw, 64px);
  line-height: 1.15;
  letter-spacing: -.02em;
  margin: 0;
  color: var(--bone);
  max-width: 28ch;
}
.case-quote__attr {
  margin-top: 32px;
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.65);
  max-width: var(--maxw);
  margin-left: auto;
  margin-right: auto;
}

/* prev / next */
.case-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1.5px solid var(--rule);
  border-bottom: 1.5px solid var(--rule);
}
.case-nav__link {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: clamp(36px, 4vw, 64px) clamp(28px, 3vw, 48px);
  text-decoration: none;
  color: var(--ink);
  background: var(--bone);
  border-right: 1.5px solid var(--rule);
  transition: background .25s var(--ease), color .25s var(--ease), padding .25s var(--ease);
}
.case-nav__link:last-child { border-right: 0; }
.case-nav__link:hover { background: var(--ink); color: var(--bone); }
.case-nav__link:hover .case-nav__cat { color: rgba(243,241,237,.6); }
.case-nav__link--next { text-align: right; }
.case-nav__brand {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(32px, 3.5vw, 56px);
  line-height: 1;
  letter-spacing: -.02em;
}
.case-nav__cat {
  font-size: 11px;
  letter-spacing: .26em;
  color: rgba(11,11,13,.5);
}

/* 404 */
.case-404 {
  min-height: 80vh;
  display: grid;
  place-items: center;
  background: var(--ink);
  color: var(--bone);
  padding: 120px var(--mx);
}
.case-404__inner { text-align: center; display: flex; flex-direction: column; gap: 20px; align-items: center; }
.case-404__inner h1 {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(48px, 7vw, 120px);
  line-height: .9;
  letter-spacing: -.04em;
  margin: 0;
}

/* =========================================================
   CONTACT — split screen
   ========================================================= */
.contact-screen {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: calc(100vh - 90px);
  margin-top: 90px;
  border-bottom: 1.5px solid var(--rule);
}
.contact-left {
  background: var(--ink);
  color: var(--bone);
  position: relative;
  overflow: hidden;
  padding: clamp(56px, 6vw, 96px) clamp(32px, 4vw, 80px);
  display: flex;
  align-items: center;
}
.contact-left::after {
  content: "";
  position: absolute;
  right: -10%;
  bottom: -10%;
  width: 70%;
  height: 60%;
  background: radial-gradient(ellipse at center, rgba(0,71,255,.32), rgba(0,71,255,0) 70%);
  pointer-events: none;
}
.contact-left__inner { position: relative; z-index: 2; max-width: 560px; }
.contact-left__rail {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(243,241,237,.7);
  margin-bottom: clamp(36px, 4vw, 56px);
}
.contact-left__title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(54px, 6.2vw, 124px);
  line-height: 1.02;
  letter-spacing: -.04em;
  margin: 0 0 clamp(28px, 3vw, 48px);
  color: var(--bone);
}
.contact-left__title em { display: inline-block; padding-right: .12em; }
.contact-left__title em { font-style: italic; color: var(--cobalt); }
.contact-left__lede {
  font-size: clamp(17px, 1.3vw, 21px);
  line-height: 1.5;
  color: rgba(243,241,237,.78);
  margin: 0 0 clamp(36px, 4vw, 56px);
  max-width: 50ch;
}
.contact-left__meta {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1.5px solid rgba(243,241,237,.22);
}
.contact-left__meta li {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 24px;
  padding: 18px 0;
  border-bottom: 1.5px solid rgba(243,241,237,.22);
  font-size: 15px;
  align-items: baseline;
}
.contact-left__meta li .mono {
  font-size: 11px;
  letter-spacing: .26em;
  color: rgba(243,241,237,.5);
}
.contact-left__meta a { color: var(--bone); text-decoration: underline; text-underline-offset: 4px; text-decoration-color: rgba(0,71,255,.6); }
.contact-left__meta a:hover { color: var(--cobalt); }
.contact-left__sig {
  margin: clamp(36px, 4vw, 56px) 0 0;
  font-family: var(--sans);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(18px, 1.5vw, 22px);
  color: rgba(243,241,237,.55);
}
.contact-right {
  background: var(--bone);
  padding: clamp(56px, 6vw, 96px) clamp(32px, 4vw, 80px);
  display: flex;
  align-items: center;
}
.contact-form {
  width: 100%;
  max-width: 560px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}
.contact-form__rail {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(11,11,13,.5);
  padding-bottom: 24px;
  border-bottom: 1.5px solid var(--rule);
  margin-bottom: 12px;
}
.field {
  border-bottom: 1.5px solid var(--rule);
  padding: 18px 0 14px;
  position: relative;
  transition: border-color .25s var(--ease);
}
.field:focus-within { border-bottom-color: var(--cobalt); }
.field label {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 8px;
}
.field__num {
  font-size: 11px;
  letter-spacing: .28em;
  color: rgba(11,11,13,.4);
}
.field__label {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .02em;
  color: var(--ink);
}
.field input,
.field textarea {
  width: 100%;
  appearance: none;
  background: transparent;
  border: 0;
  outline: 0;
  font-family: var(--sans);
  font-size: clamp(20px, 1.6vw, 26px);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
  padding: 4px 0 6px;
  resize: vertical;
  caret-color: var(--cobalt);
}
.field input::placeholder,
.field textarea::placeholder {
  color: rgba(11,11,13,.3);
  font-weight: 400;
}
.field--area textarea { min-height: 120px; }
.contact-form__foot {
  display: flex;
  align-items: center;
  gap: 24px;
  padding-top: 28px;
  flex-wrap: wrap;
}
.contact-form__small {
  font-size: 11px;
  letter-spacing: .26em;
  color: rgba(11,11,13,.5);
}
.contact-form__success {
  padding: 32px 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.contact-form__success[hidden],
[data-work-empty][hidden],
[data-notes-empty][hidden],
[data-case-404][hidden] { display: none !important; }
.contact-form__success .mono {
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--cobalt);
}
.contact-form__success h3 {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(40px, 5vw, 72px);
  line-height: .95;
  letter-spacing: -.03em;
  margin: 0;
}
.contact-form__success p { font-size: 17px; line-height: 1.5; color: rgba(11,11,13,.78); margin: 0; max-width: 48ch; }

/* =========================================================
   NOTES grid
   ========================================================= */
.notes { padding: clamp(60px, 7vw, 110px) var(--mx) clamp(80px, 9vw, 140px); }
.notes__inner { max-width: var(--maxw); margin: 0 auto; }
.notes__list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1.5px solid var(--rule);
}
.note {
  border-bottom: 1.5px solid var(--rule);
}
.note__link {
  display: grid;
  grid-template-columns: 220px 1fr 200px;
  gap: clamp(24px, 3vw, 64px);
  align-items: baseline;
  padding: clamp(28px, 3.5vw, 48px) 0;
  text-decoration: none;
  color: var(--ink);
  transition: padding .25s var(--ease), background .25s var(--ease);
}
.note__link:hover {
  background: var(--bone-2);
  padding-left: 24px;
  padding-right: 24px;
}
.note__head {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.note__cat {
  font-size: 10px;
  letter-spacing: .3em;
  color: var(--cobalt);
  font-weight: 600;
}
.note__date {
  font-size: 11px;
  letter-spacing: .26em;
  color: rgba(11,11,13,.5);
}
.note__title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(22px, 2.4vw, 36px);
  line-height: 1.15;
  letter-spacing: -.015em;
  margin: 0;
  max-width: 30ch;
}
.note__excerpt {
  display: none;
  font-size: 16px;
  line-height: 1.5;
  color: rgba(11,11,13,.7);
  margin: 12px 0 0;
}
.note__cta {
  font-size: 11px;
  letter-spacing: .28em;
  color: var(--cobalt);
  text-align: right;
  align-self: end;
}
.notes__empty { padding: 64px 0; text-align: center; color: rgba(11,11,13,.6); }


/* =========================================================
   MOBILE — work / case / contact / notes  (≤720px)
   ========================================================= */
@media (max-width: 720px) {
  .page-hero { padding: clamp(120px, 30vw, 180px) var(--mx) clamp(48px, 12vw, 88px); }
  .page-hero__title { font-size: clamp(56px, 22vw, 130px); }
  .page-hero__sub { font-size: 16px; line-height: 1.5; }
  .page-hero__rail { font-size: 10px; letter-spacing: .22em; }
  .page-hero__eyebrow { font-size: 11px; letter-spacing: .22em; }

  .work-filter__inner { gap: 18px; }
  .filter-btn { padding: 10px 16px; font-size: 12px; }
  .work-filter__rail { display: none; }

  .work__grid { grid-template-columns: 1fr; gap: 24px; }
  .work-card__brand { font-size: clamp(28px, 9vw, 40px); }
  .work-card__tagline { font-size: 15px; }

  .end-strip__inner { grid-template-columns: 1fr; gap: 24px; }
  .end-strip__title { font-size: clamp(44px, 13vw, 88px); }
  .end-strip .btn { width: 100%; justify-content: center; }

  /* CASE */
  .case-hero {
    grid-template-columns: 1fr;
    min-height: 0;
  }
  .case-hero__media { aspect-ratio: 16 / 11; min-height: 0; }
  .case-hero__content { padding: 36px 22px 56px; gap: 14px; }
  .case-hero__back { margin-bottom: 24px; }
  .case-hero__brand { font-size: clamp(56px, 18vw, 100px); }
  .case-hero__tagline { font-size: 17px; }

  .case-section { padding: clamp(64px, 14vw, 100px) var(--mx); }
  .case-section__title { font-size: clamp(40px, 12vw, 80px); }
  .case-section__body p { font-size: 16px; }

  .case-work__list { border-top: 1px solid rgba(243,241,237,.22); }
  .case-work__row {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 24px 0;
  }
  .case-work__num { font-size: 44px; }
  .case-work__copy h3 { font-size: clamp(22px, 6.5vw, 32px); }
  .case-work__copy p { font-size: 15px; }

  .case-stats__bar {
    grid-template-columns: 1fr;
    border: 0;
    border-top: 1.5px solid rgba(243,241,237,.3);
  }
  .case-stats__item {
    border-right: 0;
    border-bottom: 1.5px solid rgba(243,241,237,.3);
    padding: 28px 0;
  }
  .case-stats__num { font-size: clamp(56px, 18vw, 96px); }

  .case-outcome { grid-template-columns: 50px 1fr; gap: 16px; padding: 18px 0; }
  .case-outcome p { font-size: 16px; }

  .case-quote { padding: clamp(72px, 16vw, 120px) var(--mx); }
  .case-quote__mark { font-size: 120px; margin-bottom: -.3em; }
  .case-quote__copy p { font-size: clamp(26px, 7vw, 40px); }

  .case-nav { grid-template-columns: 1fr; }
  .case-nav__link { border-right: 0; border-bottom: 1.5px solid var(--rule); padding: 28px 22px; }
  .case-nav__link--next { text-align: left; }
  .case-nav__brand { font-size: clamp(28px, 9vw, 44px); }

  /* CONTACT */
  .contact-screen { grid-template-columns: 1fr; min-height: 0; }
  .contact-left { padding: 56px 22px; }
  .contact-left__title { font-size: clamp(56px, 16vw, 100px); }
  .contact-left__lede { font-size: 16px; }
  .contact-left__meta li { grid-template-columns: 1fr; gap: 4px; padding: 14px 0; }
  .contact-right { padding: 48px 22px; }
  .field input, .field textarea { font-size: 18px; }
  .contact-form__foot { gap: 16px; }
  .contact-form__foot .btn { width: 100%; justify-content: center; }

  /* NOTES */
  .note__link {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 24px 0;
  }
  .note__link:hover { padding-left: 0; padding-right: 0; }
  .note__head { flex-direction: row; gap: 14px; align-items: center; }
  .note__title { font-size: clamp(22px, 6.5vw, 30px); }
  .note__cta { text-align: left; }
}

/* very narrow phones — iPhone SE / Galaxy Fold cover */
@media (max-width: 380px) {
  :root { --mx: 14px; }
  .hero__title { font-size: 12.6vw; letter-spacing: -.08em; }
  .hero__sub { font-size: 16px; }
  .reel__line { font-size: 14vw; }
  .letter__title { font-size: 11vw; }
  .access__title { font-size: 12vw; }
  .method__title { font-size: 14vw; }
  .vs__title, .standard__title { font-size: 11vw; }
  .engage__title { font-size: 16vw; }
  .foot__sig { font-size: 14vw; }
}
