/* =========================================================
   ALG CONNECT — Site Shell
   Tokens lifted verbatim from the brand design system.
   ========================================================= */

:root {
  --gold-100: oklch(95% 0.05 92);
  --gold-300: oklch(86% 0.09 90);
  --gold-500: oklch(76% 0.13 88);
  --gold-700: oklch(58% 0.12 80);
  --gold-900: oklch(40% 0.08 70);

  --ink-950: oklch(13% 0.01 80);
  --ink-900: oklch(17% 0.011 80);
  --ink-800: oklch(20% 0.012 80);
  --ink-700: oklch(31% 0.013 80);
  --ink-600: oklch(44% 0.014 80);
  --ink-400: oklch(61% 0.014 80);
  --ink-200: oklch(86% 0.012 82);
  --ink-100: oklch(93% 0.013 84);
  --ink-50:  oklch(97% 0.015 85);
  --paper:   oklch(99% 0.008 85);

  --success: oklch(58% 0.10 145);
  --warning: oklch(72% 0.12 75);
  --danger:  oklch(54% 0.16 28);

  --font-serif: 'Playfair Display', 'Iowan Old Style', Georgia, serif;
  --font-sans:  'Manrope', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-mono:  'IBM Plex Mono', ui-monospace, Menlo, monospace;

  --t-display: clamp(48px, 8.5vw, 152px);
  --t-h1:      clamp(36px, 5vw, 72px);
  --t-h2:      clamp(26px, 2.6vw, 36px);
  --t-h3:      20px;
  --t-body:    16px;
  --t-small:   14px;
  --t-meta:    13px;
  --t-kicker:  11px;

  --ease-expo:  cubic-bezier(0.16, 1, 0.3, 1);
  --ease-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-smooth: cubic-bezier(0.76, 0, 0.24, 1);
  --dur-fast:   220ms;
  --dur-mid:    560ms;
  --dur-slow:   1000ms;
  --dur-grand:  1400ms;

  --gutter: clamp(20px, 4vw, 96px);
}

:root[data-theme='dark'] {
  --bg: var(--ink-950);
  --surface: var(--ink-900);
  --surface-2: var(--ink-800);
  --fg: var(--ink-50);
  --fg-soft: var(--ink-200);
  --muted: var(--ink-400);
  --hairline: oklch(58% 0.12 80 / 0.22);
  --hairline-strong: oklch(58% 0.12 80 / 0.5);
  --scrim: oklch(0% 0 0 / 0.4);
  --logo-light-display: none;
  --logo-dark-display: block;
}
:root[data-theme='light'] {
  --bg: var(--ink-50);
  --surface: var(--paper);
  --surface-2: var(--ink-100);
  --fg: var(--ink-950);
  --fg-soft: var(--ink-800);
  --muted: var(--ink-600);
  --hairline: var(--ink-200);
  --hairline-strong: oklch(40% 0.08 70 / 0.5);
  --scrim: oklch(100% 0 0 / 0.4);
  --logo-light-display: block;
  --logo-dark-display: none;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { background: var(--bg); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: var(--t-body);
  line-height: 1.65;
  font-weight: 400;
  overflow-x: hidden;
  transition: background var(--dur-mid) var(--ease-expo), color var(--dur-mid) var(--ease-expo);
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }

.kicker {
  font-family: var(--font-sans);
  font-size: var(--t-kicker);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
}
.eyebrow-mono {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  font-variant-numeric: tabular-nums;
}
.serif { font-family: var(--font-serif); font-weight: 400; letter-spacing: -0.012em; }
h1, h2, h3, h4 { margin: 0; font-family: var(--font-serif); font-weight: 400; letter-spacing: -0.012em; }
.display { font-size: var(--t-display); line-height: 0.92; }
.h1 { font-size: var(--t-h1); line-height: 1.04; }
.h2 { font-size: var(--t-h2); line-height: 1.12; }
.h3 { font-size: var(--t-h3); line-height: 1.3; }
p { margin: 0; max-width: 62ch; }
.lead { font-size: 18px; line-height: 1.6; color: var(--fg-soft); max-width: 56ch; }
.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; letter-spacing: 0; }

::selection { background: var(--gold-500); color: var(--ink-950); }

/* PRELOADER */
.preloader {
  position: fixed; inset: 0;
  background: var(--ink-950);
  z-index: 999;
  display: grid; place-items: center;
  pointer-events: all;
}
.preloader__inner { position: relative; width: min(60vw, 280px); text-align: center; }
.preloader__mark {
  width: 64px; height: 64px;
  margin: 0 auto 24px;
  opacity: 0; transform: scale(0.92);
  animation: preMarkIn 1200ms var(--ease-expo) 200ms forwards;
}
.preloader__mark svg { width: 100%; height: 100%; overflow: visible; }
.preloader__mark svg path,
.preloader__mark svg line {
  stroke: var(--gold-500); stroke-width: 1; fill: none;
  stroke-dasharray: 200; stroke-dashoffset: 200;
  animation: preStroke 1400ms var(--ease-expo) 600ms forwards;
}
.preloader__word {
  font-family: var(--font-serif);
  color: var(--ink-50);
  font-size: 22px; letter-spacing: 0.32em; font-weight: 400;
  display: block; overflow: hidden; white-space: nowrap;
  text-align: center;
}
.preloader__word span {
  display: inline-block; transform: translateY(120%);
  animation: preWord 1200ms var(--ease-smooth) forwards;
}
.preloader__word span:nth-child(1){animation-delay:280ms}
.preloader__word span:nth-child(2){animation-delay:380ms}
.preloader__word span:nth-child(3){animation-delay:480ms}
.preloader__word span:nth-child(4){animation-delay:580ms}
.preloader__word span:nth-child(5){animation-delay:680ms}
.preloader__word span:nth-child(6){animation-delay:780ms}
.preloader__word span:nth-child(7){animation-delay:880ms}
.preloader__word span:nth-child(8){animation-delay:980ms}
.preloader__word span:nth-child(9){animation-delay:1080ms}
.preloader__word span:nth-child(10){animation-delay:1180ms}
.preloader__word span:nth-child(11){animation-delay:1280ms}
.preloader__loading {
  margin-top: 26px;
  font-family: var(--font-serif);
  color: var(--gold-500);
  font-size: 13px; letter-spacing: 0.32em; font-weight: 400;
  display: block; overflow: hidden; white-space: nowrap;
  text-align: center;
}
.preloader__loading span {
  display: inline-block; transform: translateY(120%);
  animation: preWord 1200ms var(--ease-smooth) forwards;
}
.preloader__loading span:nth-child(1){animation-delay:1100ms}
.preloader__loading span:nth-child(2){animation-delay:1180ms}
.preloader__loading span:nth-child(3){animation-delay:1260ms}
.preloader__loading span:nth-child(4){animation-delay:1340ms}
.preloader__loading span:nth-child(5){animation-delay:1420ms}
.preloader__loading span:nth-child(6){animation-delay:1500ms}
.preloader__loading span:nth-child(7){animation-delay:1580ms}
.preloader__counter {
  margin-top: 18px;
  font-family: var(--font-mono);
  font-size: 13px; color: var(--ink-200);
  letter-spacing: 0.20em; font-variant-numeric: tabular-nums;
  opacity: 0;
  animation: preCounter 900ms var(--ease-smooth) 1400ms forwards;
  display: flex; justify-content: center; align-items: baseline; gap: 8px;
}
.preloader__counter-num { color: var(--ink-50); min-width: 4ch; text-align: right; font-variant-numeric: tabular-nums; }
.preloader__counter-sep { color: var(--gold-500); }
.preloader__counter-total { color: var(--ink-400); }
.preloader__bar {
  position: absolute; left: 0; right: 0; bottom: -42px;
  height: 1px; background: oklch(58% 0.12 80 / 0.2);
  overflow: hidden;
}
.preloader__bar::after {
  content: ''; position: absolute; inset: 0;
  background: var(--gold-500);
  transform: translateX(-100%);
  animation: preBar 2600ms var(--ease-smooth) 200ms forwards;
}
.preloader { transition: opacity 1100ms var(--ease-smooth); }
.preloader.is-out { opacity: 0; pointer-events: none; }
.preloader.is-out .preloader__inner { animation: preInnerOut 1100ms var(--ease-smooth) forwards; }
.preloader.is-out .preloader__bar { animation: preBarOut 800ms var(--ease-smooth) forwards; }
@keyframes preMarkIn { to { opacity: 1; transform: scale(1); } }
@keyframes preStroke { to { stroke-dashoffset: 0; } }
@keyframes preWord  { to { transform: translateY(0); } }
@keyframes preCounter { to { opacity: 1; } }
@keyframes preBar { to { transform: translateX(0); } }
@keyframes preInnerOut { to { opacity: 0; transform: translateY(-8px); } }
@keyframes preBarOut { to { opacity: 0; transform: scaleX(1.04); } }

/* PAGE TRANSITION CURTAIN
   Cover (~420ms) → navigate → reveal (~520ms). Total ~940ms.
   The curtain uses the foreground color so it's high-contrast in both themes
   (dark slab on light, light slab on dark). No body opacity fade-in — the
   curtain alone does the work, eliminating the "blink" cross-fade jolt. */
.page-curtain {
  position: fixed; inset: 0;
  background: var(--fg);
  z-index: 998; pointer-events: none;
  transform: translateY(100vh);
  visibility: hidden;
  will-change: transform;
}
.page-curtain::before {
  content: ''; position: absolute; left: 0; right: 0; top: 0;
  height: 1px; background: var(--gold-500);
  opacity: 0; transform-origin: left center; transform: scaleX(0);
}
.page-curtain.is-in {
  visibility: visible;
  animation: curtainIn 420ms cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
.page-curtain.is-in::before {
  animation: curtainLine 420ms cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
/* Reveal phase — html.pt-arriving set by inline head script before paint.
   Curtain begins covering, falls back DOWN past the bottom of the viewport. */
html.pt-arriving .page-curtain {
  visibility: visible;
  transform: translateY(0);
  animation: curtainOut 520ms cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
html.pt-arriving .page-curtain::before {
  opacity: 1; transform: scaleX(1);
  animation: curtainLineOut 520ms cubic-bezier(0.65, 0, 0.35, 1) forwards;
}
@keyframes curtainIn {
  0%   { transform: translateY(100vh); }
  100% { transform: translateY(0); }
}
@keyframes curtainOut {
  0%   { transform: translateY(0); }
  100% { transform: translateY(100vh); }
}
@keyframes curtainLine {
  0%   { opacity: 0; transform: scaleX(0); transform-origin: left center; }
  100% { opacity: 1; transform: scaleX(1); transform-origin: left center; }
}
@keyframes curtainLineOut {
  0%   { opacity: 1; transform: scaleX(1); transform-origin: right center; }
  100% { opacity: 0; transform: scaleX(0); transform-origin: right center; }
}

/* CURSOR */
.cursor {
  position: fixed; top: 0; left: 0;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--gold-500);
  pointer-events: none; z-index: 996;
  transform: translate3d(-50px, -50px, 0);
  mix-blend-mode: difference;
  transition: width 320ms var(--ease-expo), height 320ms var(--ease-expo), background 320ms var(--ease-expo), opacity 220ms;
  opacity: 0;
}
.cursor.is-visible { opacity: 0.9; }
.cursor.is-large { width: 56px; height: 56px; background: oklch(76% 0.13 88 / 0.5); }
@media (pointer: coarse), (hover: none) { .cursor { display: none; } }

/* NAV */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 50;
  padding: 24px var(--gutter);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  transition: background var(--dur-mid) var(--ease-expo), backdrop-filter var(--dur-mid) var(--ease-expo), border-color var(--dur-mid) var(--ease-expo);
  border-bottom: 1px solid transparent;
}
.nav.is-stuck {
  background: color-mix(in oklch, var(--bg) 86%, transparent);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-bottom-color: var(--hairline);
}
.nav__brand {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--font-serif);
  font-size: 18px; letter-spacing: 0.32em; text-transform: uppercase;
  transition: letter-spacing 700ms var(--ease-expo);
}
.nav__brand:hover { letter-spacing: 0.40em; }
.nav__brand-glyph { width: 22px; height: 22px; flex: none; }
.nav__brand-glyph svg { width: 100%; height: 100%; display: block; }
.nav__brand-glyph svg path, .nav__brand-glyph svg line {
  stroke: var(--gold-500); fill: none; stroke-width: 3.4;
  stroke-linecap: round; stroke-linejoin: round;
}
.nav__links { display: flex; gap: 32px; align-items: center; }
.nav__link {
  font-family: var(--font-sans);
  font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-soft); position: relative; padding: 4px 0;
  transition: color var(--dur-fast) var(--ease-expo);
}
.nav__link::after {
  content: ''; position: absolute;
  left: 0; right: 100%; bottom: 0;
  height: 1px; background: var(--gold-500);
  transition: right var(--dur-mid) var(--ease-expo);
}
.nav__link:hover { color: var(--fg); }
.nav__link:hover::after { right: 0; }
.nav__link.is-active { color: var(--fg); }
.nav__link.is-active::after { right: 0; }
.nav__actions { display: flex; gap: 16px; align-items: center; }
.theme-toggle {
  width: 38px; height: 38px;
  border: 1px solid var(--hairline);
  display: grid; place-items: center;
  transition: border-color var(--dur-fast), background var(--dur-fast);
  position: relative;
}
.theme-toggle:hover { border-color: var(--gold-500); }
.theme-toggle svg { width: 14px; height: 14px; stroke: var(--fg); fill: none; stroke-width: 1.2; }
.theme-toggle .icon-sun { display: var(--logo-dark-display); }
.theme-toggle .icon-moon { display: var(--logo-light-display); }
.nav__menu-btn { display: none; }

@media (max-width: 880px) {
  .nav__links { display: none; }
  .nav__menu-btn {
    position: relative;
    z-index: 60;
    display: inline-flex; align-items: center;
    font-family: var(--font-sans); font-size: 12px;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--fg-soft);
    border: 1px solid var(--hairline);
    padding: 11px 42px 11px 14px;
    min-height: 38px;
    transition: border-color var(--dur-fast), color var(--dur-fast);
  }
  /* The .nav__sheet is rendered as a sibling of .nav (directly under <body>),
     not a descendant, so .nav's `backdrop-filter` (added on scroll via
     .is-stuck) cannot trap the sheet inside the nav's containing block. */
  /* When the menu is open, hide the brand and theme toggle so the close
     button has nothing competing with it and the sheet's content is the
     only thing visible. */
  .nav.is-open .nav__brand,
  .nav.is-open .nav__actions > .nav__link,
  .nav.is-open .theme-toggle { opacity: 0; pointer-events: none; transition: opacity var(--dur-fast); }
  .nav__menu-btn::before {
    content: 'MENU';
    display: inline-block; min-width: 4em;
    transition: color var(--dur-fast);
  }
  .nav.is-open .nav__menu-btn { border-color: var(--gold-500); color: var(--gold-500); }
  .nav.is-open .nav__menu-btn::before { content: 'CLOSE'; color: var(--gold-500); }
  .nav__menu-btn span {
    position: absolute; right: 14px;
    display: block; width: 18px; height: 1px;
    background: var(--fg);
    transform-origin: center;
    transition: transform 320ms var(--ease-expo), top 320ms var(--ease-expo), background var(--dur-fast);
  }
  .nav__menu-btn span:first-child { top: calc(50% - 4px); }
  .nav__menu-btn span:last-child  { top: calc(50% + 4px); }
  .nav.is-open .nav__menu-btn span { background: var(--gold-500); }
  .nav.is-open .nav__menu-btn span:first-child { top: 50%; transform: rotate(45deg); }
  .nav.is-open .nav__menu-btn span:last-child  { top: 50%; transform: rotate(-45deg); }
  .nav__sheet {
    position: fixed;
    top: 0; left: 0;
    width: 100vw;
    height: 100vh;
    height: 100dvh;
    background: var(--bg); z-index: 49;
    padding: 110px var(--gutter) 48px;
    display: grid; grid-template-rows: 1fr auto;
    overflow-y: auto;
    opacity: 0;
    visibility: hidden;
    transition: opacity 220ms ease, visibility 0s linear 220ms;
    pointer-events: none;
  }
  .nav.is-open ~ .nav__sheet {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity 220ms ease, visibility 0s linear 0s;
  }
  .nav__sheet a {
    font-family: var(--font-serif);
    font-size: clamp(36px, 8vw, 64px);
    letter-spacing: -0.012em;
    color: var(--fg);
    display: block; padding: 14px 0;
    border-bottom: 1px solid var(--hairline);
    line-height: 1.1;
  }
}
@media (min-width: 881px) { .nav__sheet { display: none; } }

/* LAYOUT */
main { padding-top: 0; }
.section { padding: clamp(72px, 12vw, 160px) var(--gutter); position: relative; }
.section--tight { padding: clamp(48px, 8vw, 112px) var(--gutter); }
.grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; }
.col-span-8 { grid-column: span 8; }
.col-span-7 { grid-column: span 7; }
.col-span-6 { grid-column: span 6; }
.col-span-5 { grid-column: span 5; }
.col-span-4 { grid-column: span 4; }
.col-span-3 { grid-column: span 3; }
@media (max-width: 880px) {
  .col-span-8, .col-span-7, .col-span-6, .col-span-5, .col-span-4, .col-span-3 { grid-column: span 12; }
}

/* REVEAL */
[data-reveal] {
  opacity: 0; transform: translateY(24px);
  transition: opacity var(--dur-grand) var(--ease-expo), transform var(--dur-grand) var(--ease-expo);
  transition-delay: var(--reveal-delay, 0ms);
}
[data-reveal].is-in { opacity: 1; transform: translateY(0); }
/* padding-bottom + matching negative margin gives descenders (g, p, y, q)
   breathing room inside the overflow:hidden mask without shifting baselines. */
.mask-line {
  display: block; overflow: hidden;
  padding-bottom: 0.18em; margin-bottom: -0.18em;
}
.mask-line > span {
  display: block; transform: translateY(110%);
  transition: transform 1100ms var(--ease-expo);
  transition-delay: var(--mask-delay, 0ms);
}
.mask-in .mask-line > span,
.is-in .mask-line > span,
[data-reveal].is-in .mask-line > span { transform: translateY(0); }
.draw-rule {
  display: block; height: 1px;
  background: var(--hairline-strong); width: 100%;
  transform: scaleX(0); transform-origin: left center;
  transition: transform 1400ms var(--ease-expo);
}
.is-in .draw-rule, [data-reveal].is-in .draw-rule { transform: scaleX(1); }

/* HERO (Home) */
.hero {
  position: relative; min-height: 100vh;
  padding: clamp(120px, 16vw, 200px) var(--gutter) clamp(48px, 8vw, 120px);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  align-items: end; overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 100% 60% at 70% 30%, oklch(58% 0.12 80 / 0.18), transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, color-mix(in oklch, var(--bg) 90%, var(--gold-700) 10%) 100%);
}
:root[data-theme='light'] .hero__bg {
  background:
    radial-gradient(ellipse 80% 50% at 70% 25%, oklch(95% 0.05 92 / 0.7), transparent 60%),
    linear-gradient(180deg, var(--bg) 0%, color-mix(in oklch, var(--bg) 92%, var(--gold-300) 8%) 100%);
}
.hero__hairline-v {
  position: absolute; top: 96px; bottom: 96px;
  right: var(--gutter); width: 1px;
  background: var(--hairline);
  transform-origin: top center; transform: scaleY(0);
  animation: drawV 1600ms var(--ease-expo) 800ms forwards;
}
@keyframes drawV { to { transform: scaleY(1); } }
.hero__edition {
  position: absolute; top: 96px; right: calc(var(--gutter) + 24px);
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
  font-family: var(--font-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.16em; font-variant-numeric: tabular-nums;
  opacity: 0;
  animation: heroFade 800ms var(--ease-expo) 1200ms forwards;
}
@keyframes heroFade { to { opacity: 1; } }
.hero__kicker {
  grid-column: 1 / span 12; position: relative; z-index: 2;
  display: flex; align-items: center; gap: 14px;
  margin-bottom: clamp(32px, 5vw, 64px);
}
.hero__kicker .dot { width: 6px; height: 6px; background: var(--gold-500); transform: rotate(45deg); }
.hero__title {
  grid-column: 1 / span 12; position: relative; z-index: 2;
  font-family: var(--font-serif); font-size: var(--t-display);
  line-height: 0.92; letter-spacing: -0.018em; font-weight: 400; margin: 0;
}
.hero__title em { font-style: italic; color: var(--gold-500); letter-spacing: -0.024em; }
.hero__meta {
  grid-column: 1 / span 7; position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  margin-top: clamp(40px, 6vw, 72px); padding-top: 24px;
  border-top: 1px solid var(--hairline);
}
.hero__meta-block .label {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 8px;
}
.hero__meta-block .value { font-family: var(--font-serif); font-size: 24px; line-height: 1.3; }
.hero__cta-row {
  grid-column: 9 / span 4;
  display: flex; flex-direction: column; gap: 16px;
  margin-top: clamp(40px, 6vw, 72px);
  position: relative; z-index: 2;
}
@media (max-width: 880px) {
  .hero { grid-template-columns: 1fr; align-items: start; }
  .hero__kicker, .hero__title, .hero__meta, .hero__cta-row { grid-column: 1 / -1; }
  .hero__meta { grid-template-columns: 1fr 1fr; }
  .hero__edition, .hero__hairline-v { display: none; }
}

/* PAGE HERO (interior pages) */
.page-hero {
  padding: clamp(160px, 22vw, 280px) var(--gutter) clamp(48px, 8vw, 96px);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  align-items: end; position: relative; overflow: hidden;
  border-bottom: 1px solid var(--hairline);
}
.page-hero__kicker {
  grid-column: 1 / span 3;
  display: flex; flex-direction: column; gap: 4px;
}
.page-hero__title {
  grid-column: 4 / span 9;
  font-size: var(--t-display); line-height: 0.92;
  letter-spacing: -0.018em; font-weight: 400;
}
.page-hero__title em { font-style: italic; color: var(--gold-500); }
.page-hero__lead {
  grid-column: 4 / span 6; margin-top: clamp(24px, 4vw, 48px);
  font-family: var(--font-serif); font-size: clamp(20px, 2.2vw, 28px);
  line-height: 1.45; letter-spacing: -0.005em;
  color: var(--fg-soft);
}
@media (max-width: 880px) {
  .page-hero__kicker, .page-hero__title, .page-hero__lead { grid-column: 1 / -1; }
}

/* BUTTONS */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 18px 28px;
  font-family: var(--font-sans); font-size: 12px;
  letter-spacing: 0.18em; text-transform: uppercase;
  border: 1px solid var(--hairline-strong);
  color: var(--fg);
  position: relative; overflow: hidden;
  transition: color var(--dur-mid) var(--ease-expo), border-color var(--dur-mid) var(--ease-expo);
  cursor: pointer; white-space: nowrap;
}
.btn::before {
  content: ''; position: absolute; inset: 0;
  background: var(--gold-500);
  transform: translateY(101%);
  transition: transform 700ms var(--ease-expo);
  z-index: -1;
}
.btn:hover { color: var(--ink-950); border-color: var(--gold-500); }
.btn:hover::before { transform: translateY(0); }
.btn .arrow {
  width: 14px; height: 1px; background: currentColor;
  position: relative; transition: width var(--dur-mid) var(--ease-expo);
}
.btn .arrow::after {
  content: ''; position: absolute; right: 0; top: 50%;
  width: 6px; height: 6px;
  border-top: 1px solid currentColor; border-right: 1px solid currentColor;
  transform: translate(0, -50%) rotate(45deg);
}
.btn:hover .arrow { width: 22px; }
.btn--ghost { border-color: var(--hairline); color: var(--fg-soft); }
.btn--ghost:hover { color: var(--ink-950); }
.btn--solid { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.btn--solid::before { background: var(--gold-500); }
.btn--solid:hover { color: var(--ink-950); }
.magnet { transition: transform 320ms var(--ease-expo); will-change: transform; }

/* MANIFESTO */
.manifesto {
  padding: clamp(96px, 14vw, 200px) var(--gutter);
  border-top: 1px solid var(--hairline);
  position: relative;
}
.manifesto__kicker { grid-column: 1 / span 3; display: flex; flex-direction: column; gap: 8px; }
.manifesto__body {
  grid-column: 5 / span 7;
  font-family: var(--font-serif);
  font-size: clamp(28px, 3.4vw, 48px);
  line-height: 1.2; letter-spacing: -0.012em;
}
.manifesto__body em { font-style: italic; color: var(--gold-500); }
.manifesto__principles {
  margin-top: clamp(64px, 8vw, 112px);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  border-top: 1px solid var(--hairline);
  padding-top: 48px;
}
.principle { display: grid; grid-template-columns: 24px 1fr; gap: 16px; padding-right: 16px; }
.principle .num {
  font-family: var(--font-mono); font-size: 11px; color: var(--gold-500);
  letter-spacing: 0.16em; font-variant-numeric: tabular-nums; padding-top: 4px;
}
.principle h3 { font-size: 22px; margin-bottom: 8px; }
.principle p { color: var(--muted); font-size: 15px; line-height: 1.6; }
@media (max-width: 880px) {
  .manifesto__kicker, .manifesto__body { grid-column: 1 / -1; }
  .manifesto__body { font-size: 24px; }
  .manifesto__principles { grid-template-columns: 1fr; gap: 32px; }
}

/* FEATURED / PROPS GRID */
.featured {
  padding: clamp(96px, 14vw, 200px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.featured__head { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-bottom: clamp(64px, 8vw, 112px); }
.featured__head h2 { grid-column: 1 / span 8; font-size: clamp(32px, 4vw, 56px); line-height: 1.04; }
.featured__head .meta-col { grid-column: 10 / span 3; font-size: 14px; color: var(--muted); align-self: end; }
.featured__head .meta-col p { margin-bottom: 12px; }

.props-grid {
  display: grid; grid-template-columns: repeat(12, 1fr);
  gap: 24px; row-gap: clamp(64px, 8vw, 112px);
}
.prop { position: relative; display: flex; flex-direction: column; gap: 18px; cursor: pointer; }
.prop--xl { grid-column: span 8; }
.prop--md { grid-column: span 4; }
.prop--alt { grid-column: span 7; }
.prop--alt-md { grid-column: span 5; }
@media (max-width: 880px) {
  .prop--xl, .prop--md, .prop--alt, .prop--alt-md { grid-column: span 12; }
}
.prop__frame { position: relative; aspect-ratio: 4/5; overflow: hidden; background: var(--surface-2); }
.prop--xl .prop__frame, .prop--alt .prop__frame { aspect-ratio: 16/10; }
.prop__plate { position: absolute; inset: 0; transition: transform 1400ms var(--ease-expo); }
.prop:hover .prop__plate { transform: scale(1.06); }
.prop__plate::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, oklch(13% 0.01 80 / 0.6) 100%);
}
.prop__plate--p1 { background: linear-gradient(135deg, oklch(31% 0.013 80), oklch(19% 0.012 80) 60%, oklch(40% 0.08 70 / 0.5) 100%); }
.prop__plate--p2 { background: linear-gradient(150deg, oklch(60% 0.06 85), oklch(78% 0.10 88) 50%, oklch(90% 0.05 90) 100%); }
.prop__plate--p3 { background: linear-gradient(180deg, oklch(44% 0.014 80), oklch(25% 0.012 80) 70%, oklch(17% 0.011 80) 100%); }
.prop__plate--p4 { background: linear-gradient(120deg, oklch(86% 0.012 82), oklch(76% 0.13 88 / 0.4) 70%, oklch(58% 0.12 80 / 0.3) 100%); }
.prop__plate--p5 { background: linear-gradient(160deg, oklch(25% 0.012 80), oklch(44% 0.014 80) 60%, oklch(58% 0.12 80 / 0.4) 100%); }
.prop__plate--p6 { background: linear-gradient(200deg, oklch(93% 0.013 84), oklch(86% 0.09 90) 50%, oklch(76% 0.13 88) 100%); }

.prop__plate svg.silhouette {
  position: absolute; bottom: 0; left: 50%;
  transform: translateX(-50%); width: 80%; height: 60%; opacity: 0.18;
  transition: transform 1400ms var(--ease-expo);
}
.prop:hover .prop__plate svg.silhouette { transform: translateX(-50%) translateY(-8px); }
.prop__plate svg.silhouette path,
.prop__plate svg.silhouette line,
.prop__plate svg.silhouette rect { stroke: var(--ink-50); fill: none; stroke-width: 0.5; vector-effect: non-scaling-stroke; }
:root[data-theme='light'] .prop__plate--p2 svg.silhouette path,
:root[data-theme='light'] .prop__plate--p4 svg.silhouette path,
:root[data-theme='light'] .prop__plate--p6 svg.silhouette path { stroke: var(--ink-950); }

.prop__badge {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink-50);
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: oklch(0% 0 0 / 0.4);
  backdrop-filter: blur(8px);
  border: 1px solid oklch(100% 0 0 / 0.18);
}
.prop__badge .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--success);
  animation: heart 2400ms var(--ease-expo) infinite;
}
.prop__badge--reserved .dot { background: var(--warning); }
.prop__badge--sold .dot { background: var(--danger); animation: none; }
@keyframes heart {
  0%, 100% { box-shadow: 0 0 0 0 oklch(58% 0.10 145 / 0.6); }
  50%      { box-shadow: 0 0 0 8px oklch(58% 0.10 145 / 0); }
}
.prop__ref {
  position: absolute; bottom: 16px; left: 16px;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-50);
  transition: letter-spacing 700ms var(--ease-expo);
}
.prop:hover .prop__ref { letter-spacing: 0.22em; }
.prop__price {
  position: absolute; bottom: 16px; right: 16px;
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold-500); letter-spacing: 0.12em;
}
.prop__caption { display: grid; grid-template-columns: 1fr auto; gap: 24px; align-items: end; }
.prop__title { font-family: var(--font-serif); font-size: 26px; line-height: 1.15; }
.prop__loc {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; color: var(--muted);
  text-transform: uppercase; margin-top: 6px;
}
.prop__details {
  display: flex; gap: 20px;
  font-family: var(--font-mono); font-size: 11px; color: var(--muted);
  letter-spacing: 0.10em; text-transform: uppercase;
  font-variant-numeric: tabular-nums; white-space: nowrap;
}
.featured__foot { margin-top: clamp(64px, 8vw, 96px); display: flex; justify-content: center; }

/* SERVICES TEASER (used on Home and Services) */
.services-teaser {
  padding: clamp(96px, 14vw, 200px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.services-teaser__head { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-bottom: clamp(48px, 6vw, 80px); }
.services-teaser h2 { grid-column: 1 / span 7; font-size: clamp(32px, 4vw, 56px); line-height: 1.04; }
.services-teaser__list {
  display: grid; grid-template-columns: 1fr; gap: 0;
  border-top: 1px solid var(--hairline);
}
.svc-row {
  display: grid; grid-template-columns: 60px 1fr 240px 80px;
  gap: 24px; align-items: center;
  padding: 32px 0;
  border-bottom: 1px solid var(--hairline);
  transition: padding 700ms var(--ease-expo), background 700ms var(--ease-expo);
  position: relative; cursor: pointer; overflow: hidden;
}
.svc-row::before {
  content: ''; position: absolute;
  left: 0; right: 100%; bottom: -1px;
  height: 1px; background: var(--gold-500);
  transition: right 1000ms var(--ease-expo); z-index: 1;
}
.svc-row:hover::before { right: 0; }
.svc-row:hover { padding-left: 24px; }
.svc-row .num { font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.16em; }
.svc-row .name {
  font-family: var(--font-serif); font-size: clamp(24px, 3vw, 36px);
  line-height: 1.1; letter-spacing: -0.012em;
}
.svc-row .desc { font-size: 14px; color: var(--muted); line-height: 1.5; }
.svc-row .arrow-cell { text-align: right; display: flex; justify-content: flex-end; }
.svc-row:hover .name { color: var(--gold-500); }
@media (max-width: 880px) {
  .svc-row { grid-template-columns: 32px 1fr 32px; padding: 24px 0; }
  .svc-row .desc { display: none; }
  .services-teaser h2 { grid-column: 1 / -1; }
}

/* CTA STRIP */
.cta-strip {
  padding: clamp(96px, 14vw, 180px) var(--gutter);
  border-top: 1px solid var(--hairline);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; align-items: center;
}
.cta-strip__title {
  grid-column: 1 / span 7;
  font-family: var(--font-serif);
  font-size: clamp(32px, 4.5vw, 64px);
  line-height: 1.05; letter-spacing: -0.014em;
}
.cta-strip__title em { font-style: italic; color: var(--gold-500); }
.cta-strip__action { grid-column: 9 / span 4; display: flex; flex-direction: column; gap: 16px; align-items: flex-start; }
@media (max-width: 880px) {
  .cta-strip__title, .cta-strip__action { grid-column: 1 / -1; }
}

/* FOOTER */
.footer {
  padding: 80px var(--gutter) 32px;
  border-top: 1px solid var(--hairline);
  background: color-mix(in oklch, var(--bg) 92%, var(--ink-950) 8%);
}
:root[data-theme='dark'] .footer { background: var(--ink-950); }
.footer__grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-bottom: 64px; }
.footer__brand { grid-column: 1 / span 4; display: flex; flex-direction: column; gap: 18px; }
.footer__col { grid-column: span 2; }
.footer__col:nth-of-type(2) { grid-column: 6 / span 2; }
.footer__col:nth-of-type(3) { grid-column: 8 / span 2; }
.footer__col:nth-of-type(4) { grid-column: 10 / span 3; }
.footer__col h4 {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 16px; font-weight: 500;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer__col a { color: var(--fg-soft); font-size: 14px; transition: color var(--dur-fast); }
.footer__col a:hover { color: var(--gold-500); }
.footer__bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; border-top: 1px solid var(--hairline);
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; color: var(--muted); text-transform: uppercase;
}
.footer__bottom a { color: var(--muted); transition: color var(--dur-fast); }
.footer__bottom a:hover { color: var(--gold-500); }
@media (max-width: 880px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__brand, .footer__col,
  .footer__col:nth-of-type(2), .footer__col:nth-of-type(3), .footer__col:nth-of-type(4) { grid-column: span 1; }
  .footer__brand { grid-column: span 2; }
  .footer__bottom { flex-direction: column; gap: 12px; align-items: flex-start; }
}

/* MARQUEE */
.marquee {
  border-block: 1px solid var(--hairline);
  overflow: hidden; padding: 28px 0;
  background: var(--surface);
}
.marquee__track {
  display: inline-flex; gap: 80px; white-space: nowrap;
  animation: mq 38s linear infinite; will-change: transform;
  font-family: var(--font-serif);
  font-size: clamp(28px, 3.6vw, 56px);
  line-height: 1; letter-spacing: -0.014em;
}
.marquee__track span { display: inline-flex; align-items: center; gap: 80px; }
.marquee__track .diamond {
  width: 8px; height: 8px;
  background: var(--gold-500);
  transform: rotate(45deg); display: inline-block;
}
.marquee:hover .marquee__track { animation-play-state: paused; }
@keyframes mq { to { transform: translateX(-50%); } }

/* SHARED PAGE BLOCKS — used by Services / About / Contact / Intake */

.cap-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  padding: clamp(72px, 10vw, 144px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.cap-card {
  grid-column: span 6;
  display: grid; grid-template-rows: auto 1fr auto;
  gap: 24px; padding: 32px 0; min-height: 360px;
  border-top: 1px solid var(--hairline);
}
.cap-card:nth-child(odd)  { padding-right: clamp(0px, 4vw, 64px); }
.cap-card:nth-child(even) { padding-left:  clamp(0px, 4vw, 64px); }
.cap-card:nth-child(even) {
  border-left: 1px solid var(--hairline);
}
.cap-card .num {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold-500); letter-spacing: 0.16em;
}
.cap-card h3 {
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1; letter-spacing: -0.012em;
}
.cap-card p { color: var(--muted); font-size: 15px; line-height: 1.65; max-width: 56ch; }
.cap-card ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--fg-soft); letter-spacing: 0.06em;
  text-transform: uppercase;
}
.cap-card ul li::before { content: '— '; color: var(--gold-500); }
@media (max-width: 880px) {
  .cap-card { grid-column: span 12; padding: 32px 0 !important; border-left: 0 !important; }
}

/* PROCESS */
.process {
  padding: clamp(96px, 14vw, 180px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.process__head { margin-bottom: clamp(48px, 6vw, 96px); }
.process__steps {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  border-top: 1px solid var(--hairline); padding-top: 32px;
}
.step .num {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold-500); letter-spacing: 0.16em;
  margin-bottom: 12px;
}
.step h3 { font-size: 22px; line-height: 1.2; margin-bottom: 12px; }
.step p { color: var(--muted); font-size: 14px; line-height: 1.6; }
@media (max-width: 880px) {
  .process__steps { grid-template-columns: 1fr; gap: 32px; }
}

/* TEAM */
.team {
  padding: clamp(96px, 14vw, 180px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.team__head { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-bottom: clamp(48px, 6vw, 80px); }
.team__head h2 { grid-column: 1 / span 8; font-size: clamp(32px, 4vw, 56px); line-height: 1.04; }
.team__head p { grid-column: 9 / span 4; align-self: end; color: var(--muted); font-size: 14px; }
.team__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.member { display: flex; flex-direction: column; gap: 16px; }
.member__photo {
  aspect-ratio: 4/5; background: var(--surface-2);
  position: relative; overflow: hidden;
}
.member__photo .plate {
  position: absolute; inset: 0;
  transition: transform 1400ms var(--ease-expo);
}
.member:hover .plate { transform: scale(1.04); }
.member__photo svg.face {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  opacity: 0.32;
}
.member__photo svg.face path,
.member__photo svg.face circle,
.member__photo svg.face line {
  stroke: var(--ink-50); fill: none; stroke-width: 0.6;
  vector-effect: non-scaling-stroke;
}
.member__name { font-size: 22px; line-height: 1.2; }
.member__role {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--muted);
}
.member__bio { color: var(--muted); font-size: 14px; line-height: 1.6; }

/* iOS-style monogram avatar — circular, gradient background, large serif initials */
.member__photo--avatar { display: grid; place-items: center; }
.member__photo--avatar .plate {
  background: radial-gradient(ellipse 60% 50% at 30% 25%, oklch(35% 0.014 80), oklch(17% 0.011 80) 70%) !important;
}
.member__photo--avatar .avatar {
  position: relative;
  z-index: 2;
  width: clamp(140px, 50%, 220px);
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background:
    radial-gradient(circle at 30% 28%, oklch(76% 0.13 88 / 0.22), transparent 55%),
    radial-gradient(circle at 70% 80%, oklch(58% 0.12 80 / 0.18), transparent 60%),
    linear-gradient(160deg, oklch(25% 0.012 80), oklch(17% 0.011 80));
  box-shadow:
    inset 0 1px 0 oklch(76% 0.13 88 / 0.18),
    inset 0 -20px 40px -20px oklch(0% 0 0 / 0.4),
    0 30px 60px -20px oklch(0% 0 0 / 0.5);
  outline: 1px solid oklch(76% 0.13 88 / 0.4);
  outline-offset: 6px;
  transition: transform 1400ms var(--ease-expo);
}
.member:hover .member__photo--avatar .avatar { transform: scale(1.04); }
.member__photo--avatar .avatar__initials {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(64px, 13vw, 108px);
  line-height: 1;
  letter-spacing: -0.04em;
  background: linear-gradient(180deg, oklch(95% 0.05 92) 0%, oklch(76% 0.13 88) 60%, oklch(58% 0.12 80) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  padding-top: 0.04em;
}
.member__photo--avatar .avatar__caption {
  position: absolute;
  bottom: -36px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: oklch(76% 0.13 88 / 0.85);
  white-space: nowrap;
}
.member__photo--avatar::before,
.member__photo--avatar::after {
  content: ''; position: absolute; left: 50%; transform: translateX(-50%);
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.20em;
  color: var(--muted); pointer-events: none;
}
.member__photo--avatar::before { content: 'I'; top: 18px; }
.member__photo--avatar::after  { content: 'ALG CONNECT'; bottom: 18px; letter-spacing: 0.32em; }

@media (max-width: 880px) {
  .team__head h2, .team__head p { grid-column: 1 / -1; }
  .team__grid { grid-template-columns: 1fr 1fr; }
  .member__photo--avatar .avatar__caption { bottom: -28px; font-size: 9px; }
}
@media (max-width: 560px) {
  .team__grid { grid-template-columns: 1fr; }
}

/* PRESS */
.press {
  padding: clamp(72px, 10vw, 144px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.press__head { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; margin-bottom: 48px; }
.press__head h2 { grid-column: 1 / span 8; font-size: clamp(28px, 3.4vw, 44px); }
.press__list {
  display: grid; grid-template-columns: 1fr;
  border-top: 1px solid var(--hairline);
}
.press-row {
  display: grid; grid-template-columns: 80px 1fr 1fr 60px;
  gap: 24px; align-items: center;
  padding: 24px 0;
  border-bottom: 1px solid var(--hairline);
  transition: padding 600ms var(--ease-expo);
  cursor: pointer; position: relative;
}
.press-row:hover { padding-left: 16px; }
.press-row .yr { font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: 0.16em; }
.press-row .outlet { font-family: var(--font-serif); font-size: 22px; line-height: 1.2; }
.press-row .head { color: var(--muted); font-size: 14px; }
.press-row .arr {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold-500); justify-self: end;
  transition: transform var(--dur-mid) var(--ease-expo);
}
.press-row:hover .arr { transform: translateX(8px); }
@media (max-width: 880px) {
  .press-row { grid-template-columns: 60px 1fr 30px; }
  .press-row .head { display: none; }
}

/* STATS */
.stats {
  padding: clamp(72px, 10vw, 144px) var(--gutter);
  border-top: 1px solid var(--hairline);
  /* auto-fit so the strip carries 3 items (About) or 4 items (Home) equally */
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 24px;
}
.stat { display: flex; flex-direction: column; gap: 12px; }
.stat .num {
  font-family: var(--font-serif);
  font-size: clamp(40px, 5.5vw, 80px); line-height: 1;
  letter-spacing: -0.016em;
  font-variant-numeric: tabular-nums;
}
.stat .num em { font-style: italic; color: var(--gold-500); }
.stat .label {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.16em;
  text-transform: uppercase;
}
.stat .desc { color: var(--muted); font-size: 14px; max-width: 30ch; }
@media (max-width: 880px) {
  .stats { grid-template-columns: 1fr 1fr; }
}

/* FORM */
.form-wrap {
  padding: clamp(72px, 10vw, 144px) var(--gutter);
  border-top: 1px solid var(--hairline);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 48px;
}
.form-aside { grid-column: 1 / span 4; }
.form-aside .kicker-head {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted); margin-bottom: 16px;
}
.form-aside h2 {
  font-size: clamp(28px, 3.4vw, 44px); line-height: 1.1;
  margin-bottom: 24px;
}
.form-aside p { color: var(--muted); font-size: 15px; margin-bottom: 24px; }
.form-aside .meta {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--fg-soft); letter-spacing: 0.06em;
  margin-top: 32px; padding-top: 24px;
  border-top: 1px solid var(--hairline);
  display: flex; flex-direction: column; gap: 8px;
}
.form-aside .meta strong {
  display: block; color: var(--gold-500);
  font-weight: 500; letter-spacing: 0.16em;
  text-transform: uppercase; margin-bottom: 4px;
}

.form-body { grid-column: 6 / span 7; }
.form-section {
  border-top: 1px solid var(--hairline);
  padding-top: 32px; margin-bottom: 48px;
}
.form-section:first-child { border-top: 0; padding-top: 0; }
.form-section__head {
  display: grid; grid-template-columns: 60px 1fr;
  gap: 24px; margin-bottom: 24px;
}
.form-section__num {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold-500); letter-spacing: 0.16em;
}
.form-section__title {
  font-family: var(--font-serif); font-size: 26px;
  line-height: 1.2; letter-spacing: -0.012em;
}
.form-section__title small {
  display: block; font-family: var(--font-sans);
  font-size: 13px; color: var(--muted); margin-top: 4px;
  letter-spacing: 0; text-transform: none;
}

.form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  margin-bottom: 24px;
}
.form-row--full { grid-template-columns: 1fr; }
.form-row--3 { grid-template-columns: 1fr 1fr 1fr; }
@media (max-width: 880px) {
  .form-row, .form-row--3 { grid-template-columns: 1fr; }
}

.field { display: flex; flex-direction: column; gap: 6px; position: relative; }
.field label {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: color var(--dur-fast);
}
.field:focus-within label { color: var(--gold-700); }
.field input,
.field textarea,
.field select {
  font-family: var(--font-sans); font-size: 16px;
  background: transparent; color: var(--fg);
  border: 0; border-bottom: 1px solid var(--hairline);
  padding: 12px 0;
  outline: none;
  transition: border-color var(--dur-fast);
  width: 100%;
}
.field textarea { min-height: 96px; resize: vertical; line-height: 1.5; }
.field input::placeholder,
.field textarea::placeholder { color: var(--muted); opacity: 0.6; }
.field::after {
  content: ''; position: absolute;
  left: 50%; right: 50%; bottom: 0;
  height: 1px; background: var(--gold-500);
  transition: left var(--dur-mid) var(--ease-expo), right var(--dur-mid) var(--ease-expo);
  pointer-events: none;
}
.field:focus-within::after { left: 0; right: 0; }
.field select { appearance: none; -webkit-appearance: none; cursor: pointer; }
.field--select {
  background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%),
                    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position: calc(100% - 14px) 22px, calc(100% - 8px) 22px;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
}

.checkboxes {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
.checkbox-item {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; border: 1px solid var(--hairline);
  cursor: pointer;
  transition: border-color var(--dur-fast), background var(--dur-fast);
  font-family: var(--font-sans); font-size: 14px;
  user-select: none;
}
.checkbox-item:hover { border-color: var(--gold-500); }
.checkbox-item input { display: none; }
.checkbox-item .box {
  width: 14px; height: 14px;
  border: 1px solid var(--hairline-strong);
  display: grid; place-items: center;
  position: relative; flex-shrink: 0;
}
.checkbox-item .box::after {
  content: ''; width: 6px; height: 6px;
  background: var(--gold-500);
  transform: scale(0);
  transition: transform var(--dur-fast) var(--ease-expo);
}
.checkbox-item input:checked + .box::after { transform: scale(1); }
.checkbox-item input:checked + .box { border-color: var(--gold-500); }
@media (max-width: 880px) {
  .checkboxes { grid-template-columns: 1fr; }
}

.radio-group { display: flex; flex-direction: column; gap: 10px; }
.radio-item {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 14px 16px; border: 1px solid var(--hairline);
  cursor: pointer; transition: border-color var(--dur-fast);
  font-family: var(--font-sans); font-size: 14px;
}
.radio-item:hover { border-color: var(--gold-500); }
.radio-item input { display: none; }
.radio-item .dot {
  width: 12px; height: 12px;
  border: 1px solid var(--hairline-strong); border-radius: 50%;
  display: grid; place-items: center;
  flex-shrink: 0; margin-top: 2px;
}
.radio-item .dot::after {
  content: ''; width: 4px; height: 4px;
  border-radius: 50%; background: var(--gold-500);
  transform: scale(0);
  transition: transform var(--dur-fast);
}
.radio-item input:checked + .dot::after { transform: scale(1); }
.radio-item input:checked + .dot { border-color: var(--gold-500); }
.radio-item .lbl { flex: 1; }
.radio-item .lbl small { display: block; color: var(--muted); font-size: 12px; margin-top: 2px; }

.form-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 48px; padding-top: 32px;
  border-top: 1px solid var(--hairline); gap: 24px;
}
.form-foot p {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--muted); letter-spacing: 0.16em; max-width: 36ch;
}
@media (max-width: 880px) {
  .form-wrap { grid-template-columns: 1fr; gap: 32px; }
  .form-aside, .form-body { grid-column: 1 / -1; }
  .form-foot { flex-direction: column; align-items: stretch; }
}

/* OFFICES */
.offices {
  padding: clamp(72px, 10vw, 144px) var(--gutter);
  border-top: 1px solid var(--hairline);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.office {
  border-top: 1px solid var(--hairline);
  padding-top: 32px;
  display: flex; flex-direction: column; gap: 18px;
}
.office .city { font-family: var(--font-serif); font-size: 32px; line-height: 1; }
.office .ref {
  font-family: var(--font-mono); font-size: 11px;
  color: var(--gold-500); letter-spacing: 0.16em;
}
.office address {
  font-style: normal; font-size: 14px; line-height: 1.6;
  color: var(--fg-soft);
}
.office .links {
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--font-mono); font-size: 13px; color: var(--fg-soft);
  margin-top: auto; padding-top: 16px;
  border-top: 1px solid var(--hairline);
}
.office .links a:hover { color: var(--gold-500); }
@media (max-width: 880px) { .offices { grid-template-columns: 1fr; } }

/* REDUCED MOTION */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-delay: 0ms !important;
    transition-duration: 0.01ms !important;
  }
  .preloader { display: none; }
  .cursor { display: none; }
  [data-reveal] { opacity: 1; transform: none; }
  .mask-line > span { transform: none; }
  .draw-rule { transform: scaleX(1); }
  .hero__hairline-v { transform: scaleY(1); animation: none; }
  .marquee__track { animation: none; }
  html.pt-arriving .page-curtain { visibility: hidden; transform: translateY(100vh); animation: none; }
  html.pt-arriving body { animation: none; }
}

/* =========================================================
   IMAGERY LAYER — added in revision 2
   Photos sit on top of existing gradient plates so failed
   image loads still leave the original gradient visible.
   ========================================================= */

/* Home hero — atmospheric architectural photo */
.hero__photo {
  position: absolute; inset: 0; z-index: 0;
  background-image: url('https://images.unsplash.com/photo-1477959858617-67f85cf4f1df?auto=format&fit=crop&w=2400&q=80');
  background-size: cover; background-position: center;
  filter: saturate(0.78) contrast(1.04);
  opacity: 0.42;
}
:root[data-theme='light'] .hero__photo {
  opacity: 0.28;
  filter: saturate(0.88) contrast(1.02) brightness(1.06);
}
.hero__photo::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--bg) 30%, transparent) 0%,
      color-mix(in oklch, var(--bg) 86%, transparent) 78%,
      var(--bg) 100%),
    linear-gradient(90deg,
      color-mix(in oklch, var(--bg) 50%, transparent) 0%,
      transparent 65%);
}

/* Featured engagements — real photography on top of plates */
.prop__photo {
  position: absolute; inset: 0; z-index: 1;
  background-size: cover; background-position: center;
  transition: transform 1400ms var(--ease-expo);
}
.prop:hover .prop__photo { transform: scale(1.06); }
.prop__photo::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, transparent 50%, oklch(13% 0.01 80 / 0.65) 100%),
    linear-gradient(180deg, oklch(13% 0.01 80 / 0.10) 0%, transparent 28%);
}
.prop__photo--p1 { background-image: url('https://images.unsplash.com/photo-1552664730-d307ca884978?auto=format&fit=crop&w=1800&q=80'); }
.prop__photo--p2 { background-image: url('https://images.unsplash.com/photo-1444723121867-7a241cacace9?auto=format&fit=crop&w=1200&q=80'); }
.prop__photo--p3 { background-image: url('https://images.unsplash.com/photo-1454165804606-c3d57bc86b40?auto=format&fit=crop&w=1200&q=80'); }
.prop__photo--p4 { background-image: url('https://images.unsplash.com/photo-1497366216548-37526070297c?auto=format&fit=crop&w=1800&q=80'); }
.prop__photo--p5 { background-image: url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1200&q=80'); }
.prop__photo--p6 { background-image: url('https://images.unsplash.com/photo-1542744173-8e7e53415bb0?auto=format&fit=crop&w=1800&q=80'); }
.prop__plate svg.silhouette { opacity: 0; }
.prop__badge, .prop__ref, .prop__price { z-index: 2; }

/* Manifesto — single decisive editorial image */
.manifesto__figure {
  grid-column: 1 / span 12;
  margin-top: clamp(64px, 9vw, 120px);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
}
.manifesto__figure-img {
  grid-column: 2 / span 7; aspect-ratio: 16/9; overflow: hidden;
  position: relative; background: var(--surface-2);
  background-image: url('https://images.unsplash.com/photo-1524758631624-e2822e304c36?auto=format&fit=crop&w=2000&q=80');
  background-size: cover; background-position: center;
}
.manifesto__figure-img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(20deg, oklch(13% 0.01 80 / 0.20), transparent 55%);
}
.manifesto__figure-caption {
  grid-column: 10 / span 3; align-self: end; padding-bottom: 12px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted); line-height: 1.7;
}
.manifesto__figure-caption strong { color: var(--gold-500); font-weight: 500; display: block; margin-bottom: 4px; }
@media (max-width: 880px) {
  .manifesto__figure-img,
  .manifesto__figure-caption { grid-column: 1 / -1; }
}

/* Team portraits — replace silhouette gradient with real photo */
.team__photo {
  position: relative; aspect-ratio: 4/5; overflow: hidden;
  background: var(--surface-2);
  background-size: cover; background-position: center top;
  transition: filter 700ms var(--ease-expo);
  filter: grayscale(0.55) contrast(0.96);
}
.team-card:hover .team__photo,
.team__card:hover .team__photo { filter: grayscale(0); }
.team__photo::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, oklch(13% 0.01 80 / 0.35) 100%);
}
.team__photo--m1 { background-image: url('https://images.unsplash.com/photo-1497032628192-86f99bcd76bc?auto=format&fit=crop&w=900&q=80'); }
.team__photo--m2 { background-image: url('https://images.unsplash.com/photo-1521737711867-e3b97375f902?auto=format&fit=crop&w=900&q=80'); }
.team__photo--m3 { background-image: url('https://images.unsplash.com/photo-1504384308090-c894fdcc538d?auto=format&fit=crop&w=900&q=80'); }
.team__photo--m4 { background-image: url('https://images.unsplash.com/photo-1517245386807-bb43f82c33c4?auto=format&fit=crop&w=900&q=80'); }
.team__photo--m5 { background-image: url('https://images.unsplash.com/photo-1568992687947-868a62a9f521?auto=format&fit=crop&w=900&q=80'); }
.team__photo--m6 { background-image: url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?auto=format&fit=crop&w=900&q=80'); }

/* Real-photo overlay for the existing .member__photo (about page) */
.member__photo .portrait {
  position: absolute; inset: 0; z-index: 2;
  background-size: cover; background-position: center top;
  filter: grayscale(0.55) contrast(0.96);
  transition: filter 700ms var(--ease-expo), transform 1400ms var(--ease-expo);
}
.member:hover .portrait { filter: grayscale(0); transform: scale(1.04); }
.member__photo .portrait::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, oklch(13% 0.01 80 / 0.40) 100%);
}
.member__photo:has(.portrait) svg.face { display: none; }
.portrait--m1 { background-image: url('https://images.unsplash.com/photo-1497032628192-86f99bcd76bc?auto=format&fit=crop&w=900&q=80'); }
.portrait--m2 { background-image: url('https://images.unsplash.com/photo-1521737711867-e3b97375f902?auto=format&fit=crop&w=900&q=80'); }
.portrait--m3 { background-image: url('https://images.unsplash.com/photo-1504384308090-c894fdcc538d?auto=format&fit=crop&w=900&q=80'); }
.portrait--m4 { background-image: url('https://images.unsplash.com/photo-1517245386807-bb43f82c33c4?auto=format&fit=crop&w=900&q=80'); }
.portrait--m5 { background-image: url('https://images.unsplash.com/photo-1568992687947-868a62a9f521?auto=format&fit=crop&w=900&q=80'); }
.portrait--m6 { background-image: url('https://images.unsplash.com/photo-1522071820081-009f0129c71c?auto=format&fit=crop&w=900&q=80'); }

/* Service card thumbnails */
.svc-card__img {
  position: relative; aspect-ratio: 3/2; overflow: hidden;
  background: var(--surface-2); margin-bottom: 28px;
  background-size: cover; background-position: center;
  transition: transform 1200ms var(--ease-expo);
}
.svc-card:hover .svc-card__img { transform: scale(1.02); }
.svc-card__img::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, oklch(13% 0.01 80 / 0.35) 100%);
}
.svc-card__img--s1 { background-image: url('https://images.unsplash.com/photo-1556761175-b413da4baf72?auto=format&fit=crop&w=1400&q=80'); }
.svc-card__img--s2 { background-image: url('https://images.unsplash.com/photo-1460925895917-afdab827c52f?auto=format&fit=crop&w=1400&q=80'); }
.svc-card__img--s3 { background-image: url('https://images.unsplash.com/photo-1551288049-bebda4e38f71?auto=format&fit=crop&w=1400&q=80'); }
.svc-card__img--s4 { background-image: url('https://images.unsplash.com/photo-1450101499163-c8848c66ca85?auto=format&fit=crop&w=1400&q=80'); }
.svc-card__img--s5 { background-image: url('https://images.unsplash.com/photo-1431540015161-0bf868a2d407?auto=format&fit=crop&w=1400&q=80'); }

/* Interior page heroes — atmospheric photo behind hero copy */
.page-hero { position: relative; }
.page-hero__photo {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  opacity: 0.55; filter: saturate(0.85) contrast(1.05);
}
:root[data-theme='light'] .page-hero__photo { opacity: 0.32; filter: saturate(0.9) brightness(1.06); }
.page-hero__photo::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, color-mix(in oklch, var(--bg) 20%, transparent) 0%, color-mix(in oklch, var(--bg) 75%, transparent) 70%, var(--bg) 100%),
    linear-gradient(90deg, color-mix(in oklch, var(--bg) 35%, transparent) 0%, transparent 65%);
}
.page-hero > *:not(.page-hero__photo) { position: relative; z-index: 1; }
.page-hero__photo--about    { background-image: url('https://images.unsplash.com/photo-1556761175-5973dc0f32e7?auto=format&fit=crop&w=2400&q=80'); }
.page-hero__photo--services { background-image: url('https://images.unsplash.com/photo-1497366811353-6870744d04b2?auto=format&fit=crop&w=2400&q=80'); }
.page-hero__photo--contact  { background-image: url('https://images.unsplash.com/photo-1486312338219-ce68d2c6f44d?auto=format&fit=crop&w=2400&q=80'); }

/* =========================================================
   IMAGERY + TYPOGRAPHY ENRICHMENTS — revision 3
   New sections used to give the site visual mass without
   inventing copy: word-stack, plate-bleed (full-bleed
   parallax), plates (editorial gallery), location, moods.
   ========================================================= */

/* WORD STACK — oversized typographic moment ----- */
.word-stack {
  padding: clamp(120px, 18vw, 240px) var(--gutter);
  border-top: 1px solid var(--hairline);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.word-stack__row {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(56px, 14vw, 220px);
  line-height: 0.92; letter-spacing: -0.020em;
  color: var(--fg); display: block; overflow: hidden;
  padding-bottom: 0.18em; margin: 0 0 -0.18em 0;
}
.word-stack__row em { font-style: italic; color: var(--gold-500); letter-spacing: -0.026em; }
.word-stack__row > span {
  display: inline-block; transform: translateY(110%);
  transition: transform 1300ms var(--ease-expo);
  transition-delay: var(--mask-delay, 0ms);
  will-change: transform;
}
[data-reveal].is-in .word-stack__row > span { transform: translateY(0); }
.word-stack__row--right { text-align: right; }
.word-stack__rule {
  height: 1px; background: var(--hairline);
  transform-origin: left center; transform: scaleX(0);
  transition: transform 1400ms var(--ease-expo) var(--mask-delay, 0ms);
  margin: clamp(8px, 1vw, 16px) 0;
}
[data-reveal].is-in .word-stack__rule { transform: scaleX(1); }
.word-stack__meta {
  font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.20em;
  text-transform: uppercase; color: var(--muted);
  font-variant-numeric: tabular-nums;
  display: flex; justify-content: space-between; gap: 24px;
  padding-top: clamp(16px, 2vw, 24px);
  margin-top: clamp(16px, 2vw, 24px);
  border-top: 1px solid var(--hairline);
}
@media (max-width: 880px) {
  .word-stack__meta { flex-direction: column; gap: 8px; }
}

/* PLATE-BLEED — cinematic full-bleed parallax photo ----- */
.plate-bleed {
  position: relative; overflow: hidden;
  height: clamp(70vh, 86vh, 96vh);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  align-items: end; padding: var(--gutter);
  border-top: 1px solid var(--hairline);
}
.plate-bleed__photo {
  position: absolute; left: 0; right: 0; top: -8%; bottom: -8%; z-index: 0;
  background-size: cover; background-position: center;
  filter: saturate(0.78) contrast(1.04);
  will-change: transform;
}
.plate-bleed__photo::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg,
      color-mix(in oklch, var(--bg) 60%, transparent) 0%,
      color-mix(in oklch, var(--bg) 32%, transparent) 28%,
      color-mix(in oklch, var(--bg) 38%, transparent) 55%,
      color-mix(in oklch, var(--bg) 90%, transparent) 92%,
      var(--bg) 100%),
    linear-gradient(90deg,
      color-mix(in oklch, var(--bg) 50%, transparent) 0%,
      transparent 65%);
}
:root[data-theme='light'] .plate-bleed__photo { filter: saturate(0.86) contrast(1.02) brightness(0.98); }
.plate-bleed__kicker .eyebrow-mono { color: var(--fg-soft); }
.plate-bleed__caption { color: var(--fg-soft) !important; }
.plate-bleed__kicker {
  grid-column: 1 / span 4; position: relative; z-index: 2;
  display: flex; flex-direction: column; gap: 8px;
  margin-bottom: clamp(40px, 6vw, 80px);
}
.plate-bleed__title {
  grid-column: 1 / span 9; position: relative; z-index: 2;
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(36px, 6vw, 96px);
  line-height: 1.0; letter-spacing: -0.015em;
  margin: 0; color: var(--fg);
}
.plate-bleed__title em { font-style: italic; color: var(--gold-500); letter-spacing: -0.022em; }
.plate-bleed__caption {
  grid-column: 11 / span 2; position: relative; z-index: 2;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted); align-self: end;
  margin-bottom: clamp(40px, 6vw, 80px); line-height: 1.7;
}
.plate-bleed__caption strong { color: var(--gold-500); display: block; margin-bottom: 4px; font-weight: 500; }
@media (max-width: 880px) {
  .plate-bleed { height: 70vh; align-items: end; }
  .plate-bleed__kicker, .plate-bleed__title, .plate-bleed__caption { grid-column: 1 / -1; }
  .plate-bleed__caption { margin-bottom: 0; align-self: auto; padding-top: 16px; }
  .plate-bleed__title { font-size: clamp(36px, 9vw, 64px); }
}

/* PLATES — editorial asymmetric gallery ----- */
.plates {
  padding: clamp(96px, 14vw, 200px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.plates__head {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  margin-bottom: clamp(64px, 8vw, 112px);
}
.plates__head h2 {
  grid-column: 1 / span 8; font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(32px, 4vw, 56px); line-height: 1.04; letter-spacing: -0.012em; margin: 0;
}
.plates__head h2 em { font-style: italic; color: var(--gold-500); }
.plates__head .meta {
  grid-column: 10 / span 3; font-size: 14px; color: var(--muted); align-self: end; line-height: 1.6;
}
.plates__head .meta p { margin: 0 0 10px; }
.plates__grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  row-gap: clamp(64px, 9vw, 128px);
}
.plate-item {
  position: relative; display: flex; flex-direction: column; gap: 14px;
}
.plate-item--xl { grid-column: 2 / span 7; }
.plate-item--md { grid-column: 9 / span 4; align-self: end; padding-bottom: clamp(24px, 4vw, 64px); }
.plate-item--alt-xl { grid-column: 6 / span 7; }
.plate-item--alt-md { grid-column: 1 / span 4; align-self: start; padding-top: clamp(24px, 4vw, 64px); }
.plate-item__frame {
  position: relative; aspect-ratio: 16/10; overflow: hidden; background: var(--surface-2);
}
.plate-item--md .plate-item__frame, .plate-item--alt-md .plate-item__frame { aspect-ratio: 4/5; }
.plate-item__photo {
  position: absolute; inset: 0; z-index: 0;
  background-size: cover; background-position: center;
  transition: transform 1400ms var(--ease-expo);
  filter: saturate(0.84) contrast(1.04);
}
.plate-item:hover .plate-item__photo { transform: scale(1.04); }
.plate-item__photo::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 65%, oklch(13% 0.01 80 / 0.42) 100%);
}
.plate-item__roman {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.20em;
  color: var(--ink-50); text-transform: uppercase;
  padding: 6px 10px;
  background: oklch(0% 0 0 / 0.42);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid oklch(100% 0 0 / 0.18);
  z-index: 2;
}
.plate-item__caption {
  display: grid; grid-template-columns: 1fr auto; gap: 16px; align-items: end;
}
.plate-item__caption .title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(20px, 1.8vw, 26px); line-height: 1.2; letter-spacing: -0.012em;
}
.plate-item__caption .meta {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted); white-space: nowrap;
}
@media (max-width: 880px) {
  .plate-item--xl, .plate-item--md, .plate-item--alt-xl, .plate-item--alt-md {
    grid-column: 1 / -1; padding: 0; align-self: auto;
  }
  .plates__head h2, .plates__head .meta { grid-column: 1 / -1; }
  .plates__head .meta { margin-top: 16px; }
  .plates__grid { row-gap: 48px; }
}

/* LOCATION — Selangor office card with photo + address ----- */
.location {
  padding: clamp(96px, 14vw, 180px) var(--gutter);
  border-top: 1px solid var(--hairline);
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  align-items: stretch;
}
.location__head { grid-column: 1 / span 4; display: flex; flex-direction: column; gap: 8px; }
.location__head .eyebrow-mono { margin-bottom: 8px; }
.location__head h3 {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(28px, 3vw, 44px); line-height: 1.04; letter-spacing: -0.012em;
  margin: 0;
}
.location__head h3 em { font-style: italic; color: var(--gold-500); }
.location__address {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(17px, 1.5vw, 21px); line-height: 1.55;
  color: var(--fg-soft); margin-top: 28px;
}
.location__channels {
  display: flex; flex-direction: column; gap: 0;
  margin-top: 28px; border-top: 1px solid var(--hairline);
}
.location__channels a {
  display: grid; grid-template-columns: 80px 1fr; gap: 16px; align-items: baseline;
  padding: 14px 0; border-bottom: 1px solid var(--hairline);
  font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.10em;
  text-transform: uppercase; color: var(--fg);
  transition: color var(--dur-fast), padding var(--dur-mid) var(--ease-expo);
}
.location__channels a:hover { color: var(--gold-500); padding-left: 8px; }
.location__channels a .lbl { color: var(--muted); font-size: 11px; letter-spacing: 0.18em; }
.location__photo {
  grid-column: 6 / span 7;
  background-size: cover; background-position: center;
  position: relative; overflow: hidden;
  background-image: url('https://images.unsplash.com/photo-1524758631624-e2822e304c36?auto=format&fit=crop&w=2000&q=80');
}
.location__photo::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, transparent 50%, oklch(13% 0.01 80 / 0.55) 100%),
    linear-gradient(20deg, oklch(13% 0.01 80 / 0.18), transparent 60%);
}
.location__photo .badge {
  position: absolute; bottom: 16px; left: 16px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.20em;
  color: var(--ink-50); text-transform: uppercase;
  padding: 8px 12px;
  background: oklch(0% 0 0 / 0.42);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid oklch(100% 0 0 / 0.20);
}
@media (max-width: 880px) {
  .location__head, .location__photo { grid-column: 1 / -1; }
  .location__photo { aspect-ratio: 4/3; }
  .location__channels a { grid-template-columns: 60px 1fr; gap: 12px; font-size: 11px; letter-spacing: 0.04em; }
  .location__channels a .lbl { font-size: 10px; }
}

/* MOODS — small 3-plate strip (used on services page) ----- */
.moods {
  padding: clamp(96px, 14vw, 180px) var(--gutter);
  border-top: 1px solid var(--hairline);
}
.moods__head {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px;
  margin-bottom: clamp(48px, 6vw, 80px);
}
.moods__head h2 {
  grid-column: 1 / span 8; font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(28px, 3.4vw, 48px); line-height: 1.04; letter-spacing: -0.012em; margin: 0;
}
.moods__head h2 em { font-style: italic; color: var(--gold-500); }
.moods__head p {
  grid-column: 10 / span 3; font-size: 14px; color: var(--muted);
  align-self: end; line-height: 1.6; margin: 0;
}
.moods__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.mood { display: flex; flex-direction: column; gap: 16px; }
.mood__frame {
  aspect-ratio: 4/5; overflow: hidden; position: relative; background: var(--surface-2);
}
.mood__photo {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  transition: transform 1400ms var(--ease-expo); filter: saturate(0.86) contrast(1.04);
}
.mood:hover .mood__photo { transform: scale(1.04); }
.mood__photo::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, oklch(13% 0.01 80 / 0.32) 100%);
}
.mood__roman {
  position: absolute; top: 14px; left: 14px;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.20em;
  color: var(--ink-50); text-transform: uppercase;
  padding: 6px 10px; background: oklch(0% 0 0 / 0.42);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid oklch(100% 0 0 / 0.18);
}
.mood__title {
  font-family: var(--font-serif); font-weight: 400;
  font-size: clamp(22px, 2vw, 30px); line-height: 1.15; letter-spacing: -0.012em;
}
.mood__title em { font-style: italic; color: var(--gold-500); }
.mood__caption {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--muted);
}
@media (max-width: 880px) {
  .moods__grid { grid-template-columns: 1fr; gap: 32px; }
  .moods__head h2, .moods__head p { grid-column: 1 / -1; }
}

/* Background image bindings for new sections */
.plate-bleed--p1 .plate-bleed__photo { background-image: url('https://images.unsplash.com/photo-1552664730-d307ca884978?auto=format&fit=crop&w=2400&q=80'); }
.plate-bleed--p2 .plate-bleed__photo { background-image: url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=2400&q=80'); }
.plate-item--I .plate-item__photo   { background-image: url('https://images.unsplash.com/photo-1542744173-8e7e53415bb0?auto=format&fit=crop&w=1600&q=80'); }
.plate-item--II .plate-item__photo  { background-image: url('https://images.unsplash.com/photo-1497366216548-37526070297c?auto=format&fit=crop&w=1200&q=80'); }
.plate-item--III .plate-item__photo { background-image: url('https://images.unsplash.com/photo-1454165804606-c3d57bc86b40?auto=format&fit=crop&w=1600&q=80'); }
.plate-item--IV .plate-item__photo  { background-image: url('https://images.unsplash.com/photo-1444723121867-7a241cacace9?auto=format&fit=crop&w=1200&q=80'); }
.mood__photo--m1 { background-image: url('https://images.unsplash.com/photo-1551288049-bebda4e38f71?auto=format&fit=crop&w=1200&q=80'); }
.mood__photo--m2 { background-image: url('https://images.unsplash.com/photo-1477959858617-67f85cf4f1df?auto=format&fit=crop&w=1200&q=80'); }
.mood__photo--m3 { background-image: url('https://images.unsplash.com/photo-1450101499163-c8848c66ca85?auto=format&fit=crop&w=1200&q=80'); }

/* Reduced motion — neutralise parallax, word-stack, and scale hover */
@media (prefers-reduced-motion: reduce) {
  .word-stack__row > span { transform: none; }
  .word-stack__rule { transform: scaleX(1); }
  .plate-bleed__photo { transform: none !important; }
  .plate-item__photo, .mood__photo { transition: none; }
}

/* =========================================================
   EDITORIAL ENRICHMENT — folio system, pull-quotes, chapter
   dividers, marginalia, signature, watermark, colophon,
   scroll progress. Pure layout/typography density — no
   fabricated copy.
   ========================================================= */

/* SCROLL PROGRESS — hairline pinned to top of viewport ----- */
.scroll-progress{
  position:fixed; top:0; left:0; right:0; height:2px;
  background:transparent; z-index:55; pointer-events:none;
}
.scroll-progress__bar{
  height:100%; width:0%;
  background:linear-gradient(90deg, transparent 0%, var(--gold-500) 30%, var(--gold-300) 100%);
  transform-origin:left; will-change:width;
  transition:width 80ms linear;
  box-shadow:0 0 12px oklch(76% 0.13 88 / 0.35);
}

/* PULL QUOTE — large editorial type moment ----- */
.pull-quote{
  padding:clamp(96px,14vw,180px) var(--gutter);
  display:grid; grid-template-columns:repeat(12,1fr); gap:24px;
  border-top:1px solid var(--hairline);
  position:relative; overflow:hidden;
}
.pull-quote__mark{
  grid-column:1/span 2;
  font-family:var(--font-serif);
  font-size:clamp(120px,18vw,260px);
  line-height:0.8;
  color:var(--gold-500);
  font-style:italic;
  align-self:start;
  margin-top:-0.15em;
}
.pull-quote__body{
  grid-column:4/span 8;
  font-family:var(--font-serif);
  font-size:clamp(28px,3.6vw,52px);
  line-height:1.18;
  letter-spacing:-0.012em;
  color:var(--fg);
}
.pull-quote__body em{ font-style:italic; color:var(--gold-500); }
.pull-quote__attrib{
  grid-column:4/span 8;
  margin-top:clamp(32px,4vw,56px);
  display:flex; align-items:center; gap:16px;
  padding-top:18px; border-top:1px solid var(--hairline);
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase;
  color:var(--muted);
}
.pull-quote__attrib .diamond{
  width:6px; height:6px; background:var(--gold-500);
  transform:rotate(45deg);
}
@media (max-width:880px){
  .pull-quote{ grid-template-columns:1fr; gap:24px; }
  .pull-quote__mark{ grid-column:1/-1; font-size:120px; line-height:0.7; margin-bottom:-32px; }
  .pull-quote__body, .pull-quote__attrib{ grid-column:1/-1; }
}

/* MARGINALIA — small mono note pinned to gutter ----- */
.marginalia{
  font-family:var(--font-mono);
  font-size:11px; line-height:1.7;
  letter-spacing:0.06em;
  color:var(--muted);
  text-transform:uppercase;
  padding-top:6px;
  border-top:1px solid var(--hairline);
  max-width:24ch;
}
.marginalia strong{
  display:block; color:var(--gold-500);
  font-weight:500; margin-bottom:6px;
  letter-spacing:0.18em;
}

/* SIGNATURE — director's signature block ----- */
.signature{
  padding:clamp(64px,10vw,120px) var(--gutter);
  display:grid; grid-template-columns:repeat(12,1fr); gap:24px;
  border-top:1px solid var(--hairline);
  align-items:end;
}
.signature__intro{
  grid-column:1/span 5;
  font-family:var(--font-serif);
  font-size:clamp(24px,2.8vw,36px);
  line-height:1.3; letter-spacing:-0.012em;
  color:var(--fg);
}
.signature__intro em{ font-style:italic; color:var(--gold-500); }
.signature__sign{
  grid-column:7/span 5;
  display:flex; flex-direction:column; gap:18px;
  padding-top:24px; border-top:1px solid var(--hairline);
}
.signature__mark{
  font-family:var(--font-serif);
  font-style:italic;
  font-size:clamp(40px,5vw,72px);
  line-height:1; color:var(--fg);
  letter-spacing:-0.02em;
  display:inline-block;
  transform:rotate(-2deg);
  border-bottom:1px solid var(--gold-500);
  padding-bottom:8px;
  width:fit-content;
}
.signature__credit{
  display:flex; flex-direction:column; gap:4px;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase;
  color:var(--muted);
}
.signature__credit strong{
  color:var(--fg); font-weight:500;
  font-family:var(--font-sans); letter-spacing:0.06em;
  text-transform:none; font-size:14px;
}
@media (max-width:880px){
  .signature{ grid-template-columns:1fr; gap:32px; }
  .signature__intro, .signature__sign{ grid-column:1/-1; }
}

/* WATERMARK — oversized brand glyph behind hero ----- */
.watermark{
  position:absolute; pointer-events:none; user-select:none;
  font-family:var(--font-serif);
  font-size:clamp(280px,40vw,640px);
  line-height:0.85;
  font-weight:400;
  color:var(--fg);
  opacity:0.04;
  letter-spacing:-0.05em;
  white-space:nowrap;
  z-index:1;
}
:root[data-theme='light'] .watermark{ opacity:0.06; }

/* DISCIPLINES — large editorial service cards ----- */
.disciplines{
  padding:clamp(64px,8vw,120px) var(--gutter);
  border-top:1px solid var(--hairline);
}
.discipline{
  display:grid; grid-template-columns:repeat(12,1fr);
  gap:clamp(32px,5vw,72px);
  padding:clamp(80px,10vw,140px) 0;
  border-bottom:1px solid var(--hairline);
  align-items:center;
}
.discipline:last-of-type{ border-bottom:0; padding-bottom:clamp(32px,4vw,56px); }
.discipline:first-of-type{ padding-top:clamp(32px,4vw,56px); }
.discipline__photo{
  grid-column:1/span 5;
  aspect-ratio:4/5;
  overflow:hidden;
  position:relative;
  background:var(--surface-2);
  background-size:cover; background-position:center;
}
.discipline__photo::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 60%, oklch(13% 0.01 80 / 0.45) 100%);
}
.discipline__photo--d1{ background-image:url("https://images.unsplash.com/photo-1551288049-bebda4e38f71?auto=format&fit=crop&w=1600&q=80"); }
.discipline__photo--d2{ background-image:url("https://images.unsplash.com/photo-1449824913935-59a10b8d2000?auto=format&fit=crop&w=1600&q=80"); }
.discipline--reverse .discipline__photo{ grid-column:8/span 5; grid-row:1; }
.discipline--reverse .discipline__body{ grid-column:1/span 6; grid-row:1; }
.discipline__body{
  grid-column:7/span 6;
  display:flex; flex-direction:column; gap:24px;
}
.discipline__num{
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--gold-500);
  display:flex; gap:14px; align-items:center;
}
.discipline__num .diamond{
  width:6px; height:6px; background:var(--gold-500);
  transform:rotate(45deg);
}
.discipline__title{
  font-family:var(--font-serif);
  font-size:clamp(36px,5vw,72px);
  line-height:1.02; letter-spacing:-0.018em;
  margin:0;
}
.discipline__title em{ font-style:italic; color:var(--gold-500); }
.discipline__lead{
  font-family:var(--font-serif);
  font-size:clamp(20px,1.8vw,24px);
  line-height:1.5; color:var(--fg-soft);
  max-width:52ch;
}
.discipline__list{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:14px;
  padding-top:18px; border-top:1px solid var(--hairline);
  max-width:52ch;
}
.discipline__list li{
  display:grid; grid-template-columns:32px 1fr;
  gap:8px;
  font-size:14px; line-height:1.55; color:var(--fg-soft);
}
.discipline__list li::before{
  content:counter(disc-list,decimal-leading-zero);
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.16em; color:var(--gold-500);
  padding-top:3px;
  counter-increment:disc-list;
}
.discipline__list{ counter-reset:disc-list; }
@media (max-width:880px){
  .discipline{ grid-template-columns:1fr; padding:64px 0; }
  .discipline__photo, .discipline__body{ grid-column:1/-1; grid-row:auto !important; }
  .discipline--reverse .discipline__photo{ grid-row:1 !important; }
}

/* COLOPHON — specifications block above footer ----- */
.colophon{
  padding:clamp(48px,6vw,72px) var(--gutter);
  border-top:1px solid var(--hairline);
  display:grid; grid-template-columns:repeat(12,1fr); gap:24px;
  background:color-mix(in oklch, var(--bg) 96%, var(--gold-500) 4%);
}
.colophon__title{
  grid-column:1/span 3;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.20em; text-transform:uppercase;
  color:var(--gold-500);
}
.colophon__grid{
  grid-column:5/span 8;
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.colophon__item{
  display:flex; flex-direction:column; gap:6px;
  padding-top:14px; border-top:1px solid var(--hairline);
}
.colophon__item .lbl{
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted);
}
.colophon__item .val{
  font-family:var(--font-serif); font-size:18px;
  line-height:1.4; letter-spacing:-0.012em;
  color:var(--fg);
}
.colophon__item .val em{ font-style:italic; color:var(--gold-500); }
@media (max-width:880px){
  .colophon{ grid-template-columns:1fr; gap:24px; }
  .colophon__title, .colophon__grid{ grid-column:1/-1; }
  .colophon__grid{ grid-template-columns:1fr 1fr; gap:18px; }
}

/* SECTION FOLIO — small page-marker pinned to right edge ----- */
.section-folio{
  position:absolute; top:24px; right:var(--gutter);
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted);
  font-variant-numeric:tabular-nums;
  display:flex; flex-direction:column; align-items:flex-end;
  gap:4px; pointer-events:none; z-index:2;
}
.section-folio strong{ color:var(--gold-500); font-weight:500; }
@media (max-width:880px){ .section-folio{ display:none; } }

/* Reduced motion for new elements */
@media (prefers-reduced-motion: reduce){
  .scroll-progress__bar{ transition:none; }
}
