@import url('colors_and_type.css');

/* Marketing page: type system is FIGTREE end-to-end. Cormorant is reserved
   for ornamental italic accents only. */

/* ============================================================
   GLASS SYSTEM — driven by Tweaks panel
   ============================================================ */
:root {
  --glass-blur: 18px;
  --glass-saturation: 1.4; /* @kind other */
  --glass-tint: rgba(248, 245, 238, 0.10);   /* parchment whisper */
  --glass-tint-strong: rgba(248, 245, 238, 0.20);
  --glass-border: rgba(255, 255, 255, 0.22);
  --glass-border-strong: rgba(255, 255, 255, 0.45);
  --glass-shadow:
    0 1px 0 rgba(255, 255, 255, 0.35) inset,
    0 -1px 0 rgba(20, 18, 12, 0.06) inset,
    0 20px 40px -16px rgba(20, 18, 12, 0.22),
    0 50px 80px -40px rgba(20, 18, 12, 0.25);
}

.glass {
  background: var(--glass-tint);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
}
/* ---------- Glass toggle overrides (driven by Tweaks data attrs) ---------- */

/* Nav — off goes back to transparent */
body[data-glass-nav="off"] .hero-cine .nav {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: transparent !important;
  box-shadow: none !important;
  margin: 0;
  padding: 28px 48px;
  border-radius: 0;
}
body[data-glass-nav="off"] .hero-cine .nav::before { display: none; }

/* Architecture tiles — off goes back to opaque parchment cards */
body[data-glass-tiles="off"] .arch-tile {
  background: linear-gradient(135deg, rgba(255,255,255,0.92) 0%, rgba(232,229,220,0.85) 100%) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: rgba(255,255,255,0.7) !important;
}
body[data-glass-tiles="off"] .arch-tile::before { display: none; }

/* Pills — off goes back to dark ink pills */
body[data-glass-pills="off"] .arch-pill {
  background: var(--wc-ink-600) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: var(--wc-ink-600) !important;
  color: var(--wc-parchment-50);
  box-shadow: none !important;
}
body[data-glass-pills="off"] .arch-pill .name { color: var(--wc-parchment-50); }
body[data-glass-pills="off"] .arch-pill .toggle { background: rgba(248,245,238,0.18); color: var(--wc-parchment-50); }
body[data-glass-pills="off"] .arch-pill .body { color: rgba(248,245,238,0.85); }
body[data-glass-pills="off"] .arch-pill.active { background: var(--wc-ink-700) !important; border-color: var(--wc-ink-700) !important; }

/* Product frames — apply glass when toggle on */
body[data-glass-frames="on"] .product-frame {
  background: var(--glass-tint-strong);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  border: 1px solid var(--glass-border);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.4) inset,
    0 30px 60px -24px rgba(20,18,12,0.18);
}
body[data-glass-frames="on"] .product-frame .bar { background: transparent; border-bottom-color: var(--glass-border); }
body[data-glass-frames="on"] .product-frame th { background: transparent; border-bottom-color: var(--glass-border); }
body[data-glass-frames="on"] .product-frame td { border-bottom-color: var(--glass-border); }
body[data-glass-frames="on"] .classifier .rationale {
  background: var(--glass-tint);
  border-color: var(--glass-border);
  backdrop-filter: blur(calc(var(--glass-blur) * 0.5));
}

/* Showcase sections need a colored backdrop for product-frame glass to look like glass */
.showcase {
  position: relative;
  isolation: isolate;
}
.showcase::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 35% 60% at 80% 30%, rgba(205,176,97,0.10) 0%, transparent 60%),
    radial-gradient(ellipse 30% 50% at 20% 70%, rgba(61,88,120,0.08) 0%, transparent 60%);
  filter: blur(40px);
  opacity: 0;
  transition: opacity var(--dur-base);
}
body[data-glass-frames="on"] .showcase::before { opacity: 1; }

/* sheen — a soft top-edge highlight that makes glass feel lit */
.glass::before,
.glass-strong::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.18) 0%, rgba(255,255,255,0) 35%, rgba(255,255,255,0) 100%);
  mix-blend-mode: screen;
  opacity: 0.7;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  background: var(--wc-parchment-100);
  color: var(--fg-1);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ---------- Layout ---------- */
.wrap { max-width: 1660px; margin: 0 auto; padding: 0 56px; }
section { padding: 120px 0; }
@media (max-width: 760px) {
  .wrap { padding: 0 24px; }
  section { padding: 72px 0; }
}

/* ============================================================
   HERO — Full-bleed cinematic, dramatic gradient
   ============================================================ */
.hero-cine {
  position: relative;
  min-height: 100vh;
  background:
    /* warm rim of light, top-left */
    radial-gradient(ellipse 70% 50% at 22% 18%, rgba(220,197,125,0.22) 0%, transparent 55%),
    /* deep golden glow, bottom-center */
    radial-gradient(ellipse 90% 60% at 50% 110%, rgba(205,176,97,0.28) 0%, transparent 60%),
    /* faint oxblood whisper */
    radial-gradient(ellipse 50% 50% at 80% 70%, rgba(122,49,33,0.20) 0%, transparent 65%),
    /* base linear: charred → night */
    linear-gradient(170deg, #1a1410 0%, #110d0a 35%, #07060a 70%, #03020a 100%);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  color: var(--wc-parchment-50);
}

/* Background video — drops in below the gradient, lifts the gradient
   to a soft tint on top so the footage carries the mood. */
.hero-bg-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
/* subtle film grain for material warmth */
.hero-cine::before {
  content: "";
  position: absolute; inset: 0;
  z-index: 1;
  background-image:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,0.025) 0%, transparent 60%);
  mix-blend-mode: overlay;
  pointer-events: none;
}
/* horizon vignette + tint over the video so type stays legible */
.hero-cine::after {
  content: "";
  position: absolute; inset: 0;
  z-index: 1;
  background:
    radial-gradient(ellipse at center, transparent 30%, rgba(3,2,6,0.65) 100%),
    linear-gradient(180deg, rgba(10,10,9,0.35) 0%, rgba(10,10,9,0.15) 40%, rgba(10,10,9,0.55) 100%);
  pointer-events: none;
}

.hero-cine .nav {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 14px 22px;
  margin: 18px 28px 0;
  gap: 32px;
  background: var(--glass-tint);
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  border: 1px solid var(--glass-border);
  border-radius: 999px;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.2) inset,
    0 18px 40px -24px rgba(0, 0, 0, 0.5);
}
.hero-cine .nav::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.15), transparent 60%);
  mix-blend-mode: screen;
}
.hero-cine .nav-links { display: flex; gap: 28px; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; }
.hero-cine .nav-links a {
  font-family: var(--font-sans);
  font-size: 14px; font-weight: 500;
  color: rgba(248,245,238,0.78);
  text-decoration: none;
  white-space: nowrap;
  transition: color var(--dur-fast);
}
.hero-cine .nav-links a:hover { color: var(--wc-parchment-50); }
.hero-cine .brand-mark {
  text-decoration: none;
  display: inline-flex; align-items: center;
  justify-self: center;
}
.hero-cine .brand-mark img { height: 26px; width: auto; display: block; }
.hero-cine .nav-right { display: flex; gap: 16px; justify-content: flex-end; align-items: center; }
.hero-cine .nav-right a.signin {
  color: rgba(248,245,238,0.78); text-decoration: none;
  font-size: 14px; font-weight: 500;
  white-space: nowrap;
}
.hero-cine .nav-right a.signin:hover { color: var(--wc-parchment-50); }

/* Bottom content */
.hero-cine .content {
  position: relative; z-index: 2;
  margin-top: auto;
  padding: 0 64px 88px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
  width: 100%;
}
.hero-cine .h-cine {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 95px;
  line-height: 1.0;
  letter-spacing: -0.035em;
  color: var(--wc-parchment-50);
  margin: 0 0 28px;
  max-width: none;
}
.hero-cine .h-cine em {
  font-family: var(--font-sans);
  font-style: normal;
  color: var(--wc-gold-400);
  font-weight: 500;
}
.hero-sub-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
}
.hero-cine .tagline {
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 400;
  color: rgba(248,245,238,0.78);
  margin: 0;
}
@media (max-width: 760px) {
  .hero-cine .content { padding: 0 24px 56px; }
  .hero-sub-row { gap: 12px; }
}
@media (min-width: 1100px) {
  .hero-cine .content { padding-bottom: 96px; }
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 22px; font-weight: 500; font-size: 14px;
  border-radius: 999px;
  border: 1px solid transparent; cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast), transform var(--dur-fast);
  text-decoration: none; line-height: 1;
  font-family: inherit;
  white-space: nowrap;
}
.btn i { width: 15px; height: 15px; }
.btn-primary { background: var(--wc-ink-900); color: var(--wc-parchment-50); }
.btn-primary:hover { background: #fff; color: var(--wc-ink-900); border-color: var(--border-3); }
.btn-gold { background: var(--wc-gold-500); color: var(--wc-ink-900); }
.btn-gold:hover { background: var(--wc-gold-600); color: var(--wc-ink-900); }
.btn-ghost { background: transparent; color: var(--fg-1); border-color: var(--border-3); }
.btn-ghost:hover { background: var(--wc-ink-900); color: var(--wc-parchment-50); border-color: var(--wc-ink-900); }
.btn-ghost-light {
  background: rgba(248,245,238,0.06); color: var(--wc-parchment-50);
  border-color: rgba(248,245,238,0.20);
}
.btn-ghost-light:hover { background: var(--wc-parchment-50); color: var(--wc-ink-900); border-color: var(--wc-parchment-50); }
.btn-quiet { background: transparent; color: var(--fg-1); padding-left: 0; padding-right: 0; border-radius: 0; }
.btn-quiet::after { content: ""; display: inline-block; width: 18px; height: 1px; background: currentColor; margin-left: 10px; transition: width var(--dur-base) var(--ease-out); vertical-align: middle; }
.btn-quiet:hover::after { width: 36px; }

/* ---------- Eyebrow ---------- */
.eb {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.18em;
  color: var(--wc-gold-700);
  text-transform: uppercase;
  display: inline-block;
}
.eb-light { color: var(--wc-gold-400); }

/* ============================================================
   TELL-TALE SIGNS
   ============================================================ */
.telltale {
  background: var(--wc-parchment-100);
  padding: 120px 0 110px;
}
.telltale .wrap { max-width: 1660px; }
.tt-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: 100px;
  align-items: center;
}
.tt-main { min-width: 0; }
.tt-photo {
  position: relative;
  align-self: stretch;
  min-height: 100%;
}
.tt-photo img {
  width: 100%;
  height: 100%;
  min-height: 520px;
  object-fit: cover;
  border-radius: 14px;
  display: block;
}
.tt-head { margin-bottom: 64px; }
.tt-head .eb { display: block; margin-bottom: 18px; }
.tt-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(40px, 5vw, 62px);
  line-height: 1.04;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0 0 16px;
}
.tt-sub {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 18px;
  color: var(--fg-3);
  margin: 0;
}
.tt-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 36px;
}
.tt-item {
  display: grid;
  grid-template-columns: 84px 1fr;
  align-items: center;
  gap: 8px;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--border-1);
}
.tt-item:last-child { border-bottom: none; padding-bottom: 0; }
.tt-num {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 64px;
  line-height: 1;
  color: var(--wc-gold-600);
}
.tt-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  line-height: 1.5;
  color: var(--wc-gold-800);
  margin: 0;
  max-width: 52ch;
}
@media (max-width: 860px) {
  .tt-wrap { grid-template-columns: 1fr; gap: 40px; }
  .tt-photo img { min-height: 320px; max-height: 420px; }
}
@media (max-width: 720px) {
  .telltale { padding: 80px 0 72px; }
  .tt-head { margin-bottom: 44px; }
  .tt-item { grid-template-columns: 56px 1fr; gap: 12px; padding-bottom: 28px; }
  .tt-list { gap: 28px; }
  .tt-num { font-size: 46px; }
  .tt-quote { font-size: 18px; }
}

/* ============================================================
   WHO YOU'D BE WORKING WITH — team bridge
   ============================================================ */
.team-bridge {
  background: var(--wc-parchment-100);
  padding: 120px 0;
  border-top: 1px solid var(--border-1);
}
.team-bridge .wrap { max-width: 1160px; text-align: center; }
.team-bridge .eb { display: block; margin-bottom: 22px; }
.team-bridge-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(34px, 4.2vw, 52px);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0 auto 24px;
  max-width: 28ch;
}
.team-bridge-body {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.7;
  color: var(--fg-2);
  margin: 0 auto;
  max-width: 62ch;
}
@media (max-width: 720px) {
  .team-bridge { padding: 84px 0; }
  .team-bridge-body { font-size: 16.5px; }
}

/* ============================================================
   WHY WE BUILT THIS — quiet text bridge
   ============================================================ */
.bridge {
  background: var(--wc-parchment-100);
  padding: 130px 0;
  border-top: 1px solid var(--border-1);
}
.bridge .wrap { max-width: 1160px; text-align: center; }
.bridge .eb { display: block; margin-bottom: 22px; }
.bridge-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(36px, 4.4vw, 54px);
  line-height: 1.06;
  letter-spacing: -0.02em;
  color: var(--fg-1);
  margin: 0 0 20px;
}
.bridge-sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(21px, 2.4vw, 27px);
  line-height: 1.35;
  color: var(--wc-gold-700);
  margin: 0 0 28px;
}
.bridge-body {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.7;
  color: var(--fg-2);
  margin: 0 auto;
  max-width: 60ch;
}
@media (max-width: 720px) {
  .bridge { padding: 88px 0; }
  .bridge-body { font-size: 16.5px; }
}

/* ============================================================
   ARCHITECTURE SECTION — scroll-pinned stacking tiles
   ============================================================ */
.arch {
  position: relative;
  /* shorter track — ~half a viewport of scroll per layer */
  height: calc(var(--layer-count, 6) * 52vh + 100vh);
  background: var(--wc-parchment-100);
  isolation: isolate;
}
.arch-sticky {
  position: sticky; top: 0;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: center;
  padding: 60px 48px;
  gap: 28px;
  max-width: 1040px;
  margin: 0 auto;
  overflow: visible;
}
/* colored gradient blobs behind the glass — gives the backdrop something
   to refract through the tiles. */
.arch-sticky::before {
  content: "";
  position: absolute; inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 55% 38% at 50% 0%, rgba(205,176,97,0.20) 0%, transparent 62%),
    radial-gradient(ellipse 55% 38% at 50% 100%, rgba(61,88,120,0.12) 0%, transparent 66%);
  filter: blur(40px);
  opacity: 0.7;
}
.arch-pills, .arch-stack-wrap, .arch-layers { position: relative; z-index: 1; }
@media (max-width: 900px) {
  .arch-sticky { padding: 56px 24px; }
}

/* Left: layer pills */
.arch-pills {
  display: flex; flex-direction: column; gap: 12px;
  max-width: 440px;
}
.arch-intro {
  margin-bottom: 6px;
}
.arch-intro .eb { margin-bottom: 18px; display: block; }
.arch-intro h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 44px;
  line-height: 1.05;
  letter-spacing: -0.022em;
  margin: 0 0 16px;
  color: var(--fg-1);
  max-width: 16ch;
}
.arch-intro p {
  font-size: 15px; line-height: 1.55; color: var(--fg-2);
  margin: 0; max-width: 40ch;
}

/* Scroll-expanding layer cards */
.arch-layers { display: flex; flex-direction: column; gap: 12px; }
.arch-layer {
  background: var(--glass-tint-strong);
  backdrop-filter: blur(calc(var(--glass-blur) * 0.6)) saturate(var(--glass-saturation));
  -webkit-backdrop-filter: blur(calc(var(--glass-blur) * 0.6)) saturate(var(--glass-saturation));
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  padding: 18px 28px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.35) inset, 0 6px 18px -10px rgba(20,18,12,0.12);
  transition: padding var(--dur-base) var(--ease-out), background var(--dur-base), border-color var(--dur-base), box-shadow var(--dur-base), transform var(--dur-base) var(--ease-out);
}
.arch-layer-head { display: flex; align-items: baseline; gap: 22px; }
.arch-layer-num { font-family: var(--font-mono); font-size: 14px; font-weight: 500; color: var(--wc-gold-700); flex-shrink: 0; }
.arch-layer-name { font-family: var(--font-serif); font-weight: 500; font-size: 24px; letter-spacing: -0.01em; color: var(--fg-1); transition: font-size var(--dur-base) var(--ease-out), color var(--dur-base); }
.arch-layer-body { max-height: 0; overflow: hidden; opacity: 0; transition: max-height var(--dur-base) var(--ease-out), opacity var(--dur-fast); }
.arch-layer-body p { margin: 14px 0 0 46px; font-family: var(--font-sans); font-size: 16px; line-height: 1.62; color: var(--fg-2); max-width: 64ch; }
.arch-layer.active {
  border-color: var(--glass-border-strong);
  padding: 30px 28px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.5) inset, 0 18px 44px -18px rgba(20,18,12,0.22);
  transform: scale(1.012);
}
.arch-layer.active .arch-layer-name { font-size: 34px; color: var(--wc-gold-800); }
.arch-layer.active .arch-layer-body { max-height: 280px; opacity: 1; }
@media (max-width: 760px) {
  .arch-layer-name { font-size: 21px; }
  .arch-layer.active .arch-layer-name { font-size: 25px; }
  .arch-layer-body p { margin-left: 0; font-size: 15px; }
}

.arch-pill {
  background: var(--glass-tint-strong);
  backdrop-filter: blur(calc(var(--glass-blur) * 0.6)) saturate(var(--glass-saturation));
  -webkit-backdrop-filter: blur(calc(var(--glass-blur) * 0.6)) saturate(var(--glass-saturation));
  border: 1px solid var(--glass-border);
  color: var(--fg-1);
  border-radius: 999px;
  padding: 10px 14px 10px 18px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  font-family: var(--font-sans);
  font-size: 14px; font-weight: 500;
  cursor: default;
  width: fit-content;
  max-width: 100%;
  transition:
    background var(--dur-base) var(--ease-out),
    border-radius var(--dur-base) var(--ease-out),
    padding var(--dur-base) var(--ease-out),
    max-width var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out);
  overflow: hidden;
  position: relative;
  box-shadow: 0 1px 0 rgba(255,255,255,0.35) inset, 0 6px 18px -8px rgba(20,18,12,0.12);
}
.arch-pill .name { white-space: nowrap; color: var(--fg-1); }
.arch-pill .toggle {
  width: 22px; height: 22px; border-radius: 999px;
  background: rgba(20,18,12,0.08);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; line-height: 1; color: var(--fg-2);
  flex-shrink: 0;
  transition: transform var(--dur-base) var(--ease-out), background var(--dur-base);
}
.arch-pill .body {
  display: none;
  font-size: 14px; line-height: 1.5;
  color: var(--fg-2);
  margin-top: 8px;
  font-weight: 400;
  max-width: 38ch;
}
.arch-pill.active {
  background: var(--glass-tint-strong);
  border-color: var(--glass-border-strong);
  border-radius: 18px;
  padding: 16px 18px;
  width: 100%;
  max-width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas: "name toggle" "body body";
  align-items: start;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.5) inset,
    0 18px 40px -16px rgba(20,18,12,0.2);
}
.arch-pill.active .name {
  grid-area: name;
  font-weight: 500;
  font-size: 15px;
}
.arch-pill.active .toggle { grid-area: toggle; background: var(--wc-gold-500); color: var(--wc-ink-900); }
.arch-pill.active .toggle .icon { transform: rotate(45deg); }
.arch-pill.active .body { grid-area: body; display: block; }

/* Layer photo as a low-opacity wash behind each expanded pill */
.arch-pill::after {
  content: "";
  position: absolute; inset: 0;
  z-index: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
  pointer-events: none;
}
.arch-pill.active::after { opacity: 0; }
.arch-pill > * { position: relative; z-index: 1; }
.arch-pill[data-layer="0"]::after { background-image: url('assets/layer-1.jpg'); }
.arch-pill[data-layer="1"]::after { background-image: url('assets/layer-2.jpg'); }
.arch-pill[data-layer="2"]::after { background-image: url('assets/layer-3.jpg'); }
.arch-pill[data-layer="3"]::after { background-image: url('assets/layer-4.jpg'); }
.arch-pill[data-layer="4"]::after { background-image: url('assets/layer-5.jpg'); }
.arch-pill[data-layer="5"]::after { background-image: url('assets/layer-6.jpg'); }

/* Right: isometric tile stack */
.arch-stack-wrap {
  position: relative;
  height: 540px;
  display: flex; align-items: center; justify-content: center;
  perspective: 1400px;
}
.arch-stack {
  position: relative;
  width: 460px; height: 460px;
  transform-style: preserve-3d;
  transform: rotateX(58deg) rotateZ(-32deg);
}

.arch-tile {
  position: absolute;
  inset: 0;
  border-radius: 22px;
  background: var(--glass-tint-strong);
  background-size: cover;
  background-position: center;
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturation));
  border: 1px solid var(--glass-border-strong);
  /* Stacked box-shadows form the thick "slab" edge.
     Each tile is rotated rotateX(58deg) by its parent, so positive Y
     offsets land on the bottom-front of the slab — exactly where the
     thickness should peek out toward the viewer. */
  box-shadow:
    /* front face highlight + lip */
    0 1px 0 rgba(255,255,255,0.65) inset,
    0 -1px 0 rgba(20,18,12,0.05) inset,
    /* slab thickness — progressively darker rings of beige/parchment.
       28px tall edge, 2px per ring */
    0  2px 0 rgba(252,249,241,0.95),
    0  4px 0 rgba(247,243,231,0.95),
    0  6px 0 rgba(240,234,219,0.95),
    0  8px 0 rgba(232,225,206,0.95),
    0 10px 0 rgba(224,215,193,0.96),
    0 12px 0 rgba(215,205,180,0.96),
    0 14px 0 rgba(206,195,167,0.96),
    0 16px 0 rgba(197,184,155,0.97),
    0 18px 0 rgba(188,174,143,0.97),
    0 20px 0 rgba(179,164,132,0.97),
    0 22px 0 rgba(170,154,121,0.98),
    0 24px 0 rgba(160,144,111,0.98),
    0 26px 0 rgba(150,135,101,0.98),
    0 28px 0 rgba(140,125,92,0.98),
    /* etched dark base line */
    0 29px 0 rgba(50,42,22,0.25),
    /* ambient under-slab shadow */
    0 44px 40px -10px rgba(20,18,12,0.35),
    0 80px 100px -36px rgba(20,18,12,0.35);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  opacity: 0;
  transform: translateZ(0) translateY(-340px) scale(0.94);
  transition:
    opacity 700ms cubic-bezier(0.22, 0.61, 0.36, 1),
    transform 800ms cubic-bezier(0.22, 0.61, 0.36, 1);
  will-change: transform, opacity;
  overflow: visible;
}
.arch-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    /* top-edge sheen */
    linear-gradient(180deg, rgba(255,255,255,0.28) 0%, rgba(255,255,255,0) 30%),
    /* warm gold rim, top-left */
    radial-gradient(ellipse 60% 40% at 18% 12%, rgba(205,176,97,0.18) 0%, transparent 70%);
  mix-blend-mode: screen;
}
.arch-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  /* etched bottom-right shadow line */
  box-shadow: inset -1px -1px 0 rgba(20,18,12,0.08);
}
.arch-tile .tile-label {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 34px;
  letter-spacing: -0.018em;
  color: var(--wc-parchment-50);
  text-align: center;
  /* No counter-rotation: the label lies flat on the slab face,
     sharing the stack's rotateX(58deg) rotateZ(-32deg) angle. */
  transform: none;
  padding: 0 28px;
  /* Dark drop shadow so white type reads over the photo. */
  text-shadow:
    0 1px 2px rgba(10,9,7,0.55),
    0 4px 14px rgba(10,9,7,0.45);
}
.arch-tile.in {
  opacity: 1;
}

/* Layer photographs as slab faces */
.arch-tile[data-layer="0"] { background-image: linear-gradient(rgba(20,18,12,0.52), rgba(20,18,12,0.62)), url('assets/layer-1.jpg'); }
.arch-tile[data-layer="1"] { background-image: linear-gradient(rgba(20,18,12,0.52), rgba(20,18,12,0.62)), url('assets/layer-2.jpg'); }
.arch-tile[data-layer="2"] { background-image: linear-gradient(rgba(20,18,12,0.52), rgba(20,18,12,0.62)), url('assets/layer-3.jpg'); }
.arch-tile[data-layer="3"] { background-image: linear-gradient(rgba(20,18,12,0.52), rgba(20,18,12,0.62)), url('assets/layer-4.jpg'); }
.arch-tile[data-layer="4"] { background-image: linear-gradient(rgba(20,18,12,0.52), rgba(20,18,12,0.62)), url('assets/layer-5.jpg'); }
.arch-tile[data-layer="5"] { background-image: linear-gradient(rgba(20,18,12,0.52), rgba(20,18,12,0.62)), url('assets/layer-6.jpg'); }

/* progress mark (the little capsule under the stack like in Legora) */
.arch-progress {
  position: absolute;
  left: 50%;
  bottom: -52px;
  transform: translateX(-50%);
  width: 96px; height: 8px;
  border-radius: 999px;
  background: var(--wc-stone-200);
  overflow: hidden;
}
.arch-progress > div {
  height: 100%;
  background: var(--wc-ink-700);
  border-radius: 999px;
  width: 0%;
  transition: width 400ms var(--ease-out);
}

/* mini hint at top */
.arch-hint {
  position: absolute; top: 24px; left: 50%; transform: translateX(-50%);
  font-family: var(--font-sans); font-size: 11px; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-3);
}

/* ============================================================
   The rest of the page (re-themed to Figtree)
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(248, 245, 238, 0.84);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-1);
}
.nav-inner {
  max-width: 1660px; margin: 0 auto;
  padding: 18px 56px;
  display: flex; align-items: center; gap: 32px;
}
.nav .logo { height: 22px; width: auto; display: block; }
.nav ul.std { list-style: none; padding: 0; margin: 0; display: flex; gap: 30px; }
.nav ul.std a {
  font-size: 14px; font-weight: 500; color: var(--fg-2);
  text-decoration: none; transition: color var(--dur-fast);
}
.nav ul.std a:hover { color: var(--fg-1); }
.nav .right { margin-left: auto; display: flex; align-items: center; gap: 14px; }

/* All headlines are Figtree now */
.h-hero, .h-section, .h-feature, .pull-quote {
  font-family: var(--font-sans);
  letter-spacing: -0.022em;
}
.h-section {
  font-weight: 500;
  font-size: clamp(40px, 5.5vw, 72px);
  line-height: 1.02;
  margin: 0;
  color: var(--fg-1);
  max-width: 18ch;
}
.h-section em { font-family: var(--font-serif); font-style: italic; color: var(--wc-gold-700); font-weight: 500; letter-spacing: -0.015em; }
.h-feature {
  font-weight: 500;
  font-size: 26px;
  line-height: 1.15;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--fg-1);
}
.lede {
  font-weight: 400;
  font-size: 17px;
  line-height: 1.55;
  color: var(--fg-2);
  max-width: 56ch;
  margin: 0;
}

/* Trust */
.trust { padding: 56px 0; background: #fff; border-bottom: 1px solid var(--border-1); }
.trust .lbl { font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.18em; color: var(--fg-3); text-transform: uppercase; font-weight: 500; margin-bottom: 28px; text-align: center; display: block; }
.trust-logos {
  display: flex; justify-content: space-between; align-items: center;
  gap: 40px; flex-wrap: wrap;
  filter: saturate(0); opacity: 0.66;
}
.trust-logos .firm {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.005em;
  color: var(--fg-1);
  white-space: nowrap;
}
.trust-logos .firm.caps { font-weight: 700; letter-spacing: 0.18em; font-size: 14px; text-transform: uppercase; }
.frame-illus { margin-left: auto; font-family: var(--font-sans); font-size: 10px; letter-spacing: 0.04em; color: var(--fg-3); opacity: 0.72; white-space: nowrap; }

/* Frameworks / regimes strip */
.regimes { padding: 56px 0 60px; background: #fff; border-bottom: 1px solid var(--border-1); }
.regimes .lbl {
  font-family: var(--font-sans); font-size: 11px; letter-spacing: 0.18em;
  color: var(--fg-3); text-transform: uppercase; font-weight: 500;
  margin-bottom: 30px; text-align: center; display: block;
}
.regime-row {
  display: flex; justify-content: center; align-items: center;
  flex-wrap: wrap; gap: 14px 26px;
  max-width: 1000px; margin: 0 auto;
}
.regime {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.01em;
  color: var(--fg-2);
  opacity: 0.72;
  white-space: nowrap;
  position: relative;
}
.regime:not(:last-child)::after {
  content: "·";
  position: absolute; right: -15px; top: 50%; transform: translateY(-50%);
  color: var(--wc-gold-600); opacity: 0.7;
}
.regime-note {
  font-family: var(--font-sans);
  font-size: 13.5px;
  color: var(--fg-3);
  text-align: center;
  margin: 26px auto 0;
  max-width: 60ch;
}
@media (max-width: 720px) {
  .regime-row { gap: 12px 22px; }
  .regime { font-size: 13px; }
  .regime:not(:last-child)::after { right: -13px; }
}

/* Feature row */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 56px 48px; }
@media (max-width: 900px) { .feature-grid { grid-template-columns: 1fr; gap: 40px; } }
.feature { display: flex; flex-direction: column; gap: 14px; }
.feature .num { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); letter-spacing: 0.06em; }
.feature p { font-size: 14.5px; line-height: 1.6; color: var(--fg-2); margin: 0; }

/* Showcase */
.showcase { background: #fff; border-top: 1px solid var(--border-1); }
.showcase .row { display: grid; grid-template-columns: 1fr 1.2fr; gap: 80px; align-items: center; }
@media (max-width: 1000px) { .showcase .row { grid-template-columns: 1fr; gap: 36px; } }
.showcase .row.reverse { grid-template-columns: 1.2fr 1fr; }
.showcase .row.reverse .copy { order: 2; }
.showcase .copy h3 {
  font-family: var(--font-sans); font-weight: 500;
  font-size: 40px; line-height: 1.05;
  letter-spacing: -0.022em;
  margin: 12px 0 16px; max-width: 14ch;
}
.showcase .copy p { font-size: 16px; line-height: 1.6; color: var(--fg-2); margin: 0 0 20px; max-width: 48ch; }

.product-frame { background: #fff; border: 1px solid var(--border-2); border-radius: 12px; box-shadow: var(--shadow-lg); overflow: hidden; position: relative; }
.product-frame .bar { background: var(--wc-parchment-100); border-bottom: 1px solid var(--border-1); padding: 10px 14px; display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); }
.product-frame .dots { display: flex; gap: 5px; }
.product-frame .dots i { width: 9px; height: 9px; border-radius: 999px; background: var(--wc-stone-200); display: block; }
.product-frame .url { margin-left: 10px; font-size: 11px; color: var(--fg-3); }
.product-frame table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.product-frame th, .product-frame td { padding: 11px 14px; text-align: left; border-bottom: 1px solid var(--border-1); }
.product-frame th { font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--fg-3); font-weight: 500; background: var(--wc-parchment-50); }
.product-frame td .mono { font-family: var(--font-mono); color: var(--fg-3); font-size: 11.5px; display: block; margin-top: 2px; }
.pill-mini { display: inline-flex; align-items: center; gap: 5px; font-size: 10.5px; font-weight: 500; padding: 2px 8px; border-radius: 999px; }
.pill-mini .dot { width: 5px; height: 5px; border-radius: 999px; }
.pill-ok { background: var(--wc-success-50); color: var(--wc-success-700); }
.pill-ok .dot { background: var(--wc-success-500); }
.pill-warn { background: var(--wc-warning-50); color: var(--wc-warning-700); }
.pill-warn .dot { background: var(--wc-warning-500); }
.pill-gold { background: var(--wc-gold-50); color: var(--wc-gold-700); }
.pill-gold .dot { background: var(--wc-gold-500); }

.classifier { padding: 20px 22px; display: flex; flex-direction: column; gap: 14px; }
.classifier .conf { display: flex; flex-direction: column; gap: 5px; }
.classifier .conf .top { display: flex; justify-content: space-between; align-items: baseline; font-size: 12.5px; }
.classifier .conf .top b { font-family: var(--font-mono); font-weight: 500; font-size: 13px; }
.classifier .conf .bar { height: 4px; background: var(--wc-stone-100); border-radius: 999px; overflow: hidden; }
.classifier .conf .bar > div { height: 100%; background: var(--wc-gold-500); border-radius: 999px; }
.classifier .conf .bar.mid > div { background: var(--wc-stone-300); }
.classifier .conf .bar.low > div { background: var(--wc-stone-200); }
.classifier .rationale {
  background: var(--wc-parchment-100); border: 1px solid var(--border-1);
  border-radius: 8px; padding: 12px 14px;
  font-family: var(--font-serif); font-style: italic;
  font-size: 14px; line-height: 1.5; color: var(--fg-2);
}
.classifier .rationale::before {
  content: "Rationale"; display: block;
  font-family: var(--font-sans); font-style: normal; font-weight: 700;
  font-size: 10px; letter-spacing: 0.16em; color: var(--fg-3);
  margin-bottom: 4px; text-transform: uppercase;
}
.classifier .rationale ul { margin: 8px 0; padding-left: 18px; }
.classifier .rationale li { margin-bottom: 5px; }

/* Pull quote */
.quote-section { background: var(--wc-ink-900); color: var(--wc-parchment-50); padding: 140px 0; }
.quote-section .wrap { max-width: 1500px; }
.quote-section .eb { color: var(--wc-gold-400); }
.quote-mark {
  font-family: var(--font-serif); font-size: 240px; line-height: 0.5;
  color: var(--wc-gold-500); display: block;
  margin-bottom: -10px; margin-top: -30px;
  font-style: italic; font-weight: 500;
}
.pull-quote {
  font-weight: 500;
  font-size: clamp(32px, 4vw, 56px);
  line-height: 1.15;
  letter-spacing: -0.022em;
  color: var(--wc-parchment-50);
  margin: 0;
  max-width: 26ch;
}
.pull-quote em { font-family: var(--font-serif); font-style: italic; color: var(--wc-gold-400); font-weight: 500; letter-spacing: -0.015em; }
.quote-mark-close {
  text-align: right;
  margin-top: -40px;
  margin-bottom: -30px;
}
.quote-attr { margin-top: 48px; display: flex; gap: 14px; align-items: center; font-size: 13px; color: var(--wc-stone-300); }
.quote-attr .avatar {
  width: 44px; height: 44px; border-radius: 999px;
  background: linear-gradient(135deg, var(--wc-gold-600), var(--wc-gold-800));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-sans); font-weight: 700;
  letter-spacing: 0.04em; font-size: 14px; color: var(--wc-ink-900);
}
.quote-attr b { color: var(--wc-parchment-50); display: block; font-weight: 500; }

/* Editorial */
.editorial {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px;
  border-top: 1px solid var(--border-1); padding-top: 80px;
}
@media (max-width: 900px) { .editorial { grid-template-columns: 1fr; gap: 36px; } }
.editorial article { display: flex; flex-direction: column; gap: 14px; }
.editorial .tag { font-family: var(--font-sans); font-weight: 700; font-size: 11px; letter-spacing: 0.18em; color: var(--wc-gold-700); text-transform: uppercase; }
.editorial h4 {
  font-family: var(--font-sans); font-weight: 500;
  font-size: 24px; line-height: 1.15;
  letter-spacing: -0.015em; margin: 0; color: var(--fg-1); max-width: 16ch;
}
.editorial p { font-size: 14.5px; line-height: 1.6; color: var(--fg-2); margin: 0; }
.editorial a { font-size: 13px; font-weight: 500; color: var(--fg-1); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; margin-top: 6px; }
.editorial a::after { content: "→"; transition: transform var(--dur-fast); }
.editorial a:hover::after { transform: translateX(4px); }

/* CTA */
.cta { text-align: center; padding: 160px 0; border-top: 1px solid var(--border-1); }
.cta .h-section { margin: 16px auto 28px; max-width: 20ch; }
.cta .actions { display: inline-flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
.cta .note { display: block; margin-top: 24px; font-size: 12.5px; color: var(--fg-3); font-style: italic; font-family: var(--font-serif); }

/* ============================================================
   RESOURCES PAGE
   ============================================================ */
.res-header {
  background: var(--wc-parchment-100);
  padding: 96px 0 60px;
}
.res-header .eb { margin-bottom: 18px; display: block; }
.res-header-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 60px;
  align-items: end;
}
@media (max-width: 900px) { .res-header-grid { grid-template-columns: 1fr; gap: 28px; } }
.res-header h1 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(40px, 5.4vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.028em;
  color: var(--fg-1);
  margin: 0;
  max-width: 16ch;
}
.res-header h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  color: var(--wc-gold-700);
  letter-spacing: -0.018em;
}
.res-header .lede {
  font-family: var(--font-sans);
  font-size: 16.5px;
  line-height: 1.6;
  color: var(--fg-2);
  margin: 0;
  max-width: 48ch;
}

/* Featured article */
.res-featured {
  background: var(--wc-parchment-100);
  padding: 36px 0 80px;
}
.res-featured-card {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 56px;
  align-items: center;
  background: #fff;
  border: 1px solid var(--border-2);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
@media (max-width: 900px) { .res-featured-card { grid-template-columns: 1fr; gap: 0; } }

.res-featured-visual {
  background: linear-gradient(135deg, #1a1410 0%, #0a0907 100%);
  aspect-ratio: 4 / 3;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.res-featured-visual::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 30% 25%, rgba(205,176,97,0.30) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 75% 70%, rgba(166,56,44,0.20) 0%, transparent 60%);
}
.res-featured-glyph {
  position: relative;
  z-index: 1;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 220px;
  line-height: 1;
  color: var(--wc-gold-400);
  letter-spacing: -0.04em;
}
.res-featured-body {
  padding: 48px 56px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
@media (max-width: 900px) { .res-featured-body { padding: 32px 28px 36px; } }
.res-featured-body .tag {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--wc-gold-700);
}
.res-featured-body h2 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--fg-1);
  margin: 4px 0 8px;
  max-width: 18ch;
}
.res-featured-body p {
  font-family: var(--font-sans);
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--fg-2);
  margin: 0;
  max-width: 50ch;
}
.res-featured-meta {
  display: flex; align-items: center; gap: 16px;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--fg-3);
  margin-top: 8px;
}
.res-featured-meta .author { color: var(--fg-1); font-weight: 500; }
.res-featured-meta .dot { width: 3px; height: 3px; border-radius: 999px; background: var(--border-3); }
.res-featured-link {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--fg-1);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 12px;
  width: fit-content;
}
.res-featured-link::after { content: "→"; transition: transform var(--dur-fast); }
.res-featured-link:hover::after { transform: translateX(4px); }

/* Filter pills */
.res-filter-row {
  background: var(--wc-parchment-100);
  padding: 0 0 36px;
  border-bottom: 1px solid var(--border-1);
}
.res-filter-pills {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.res-filter-pill {
  font-family: var(--font-sans);
  font-size: 13.5px;
  font-weight: 500;
  padding: 8px 16px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid var(--border-2);
  color: var(--fg-2);
  cursor: pointer;
  transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast);
}
.res-filter-pill:hover { background: #fff; color: var(--fg-1); border-color: var(--border-3); }
.res-filter-pill.active {
  background: var(--wc-ink-900);
  border-color: var(--wc-ink-900);
  color: var(--wc-parchment-50);
}
.res-filter-pill .count {
  margin-left: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-3);
}
.res-filter-pill.active .count { color: rgba(248,245,238,0.55); }

/* Grid */
.res-grid-section {
  background: var(--wc-parchment-100);
  padding: 64px 0 120px;
}
.res-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px 28px;
}
@media (max-width: 1000px) { .res-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .res-grid { grid-template-columns: 1fr; } }

.res-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  text-decoration: none;
  color: inherit;
  transition: transform var(--dur-base) var(--ease-out);
}
.res-card:hover { transform: translateY(-2px); }
.res-card-vis {
  aspect-ratio: 16 / 11;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  background: var(--wc-stone-50);
  border: 1px solid var(--border-1);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: box-shadow var(--dur-base);
}
.res-card:hover .res-card-vis { box-shadow: var(--shadow-md); }
.res-card-tag {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wc-gold-700);
}
.res-card-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.15;
  letter-spacing: -0.012em;
  margin: 4px 0 0;
  color: var(--fg-1);
  max-width: 22ch;
}
.res-card-excerpt {
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: var(--fg-2);
  margin: 0;
}
.res-card-meta {
  font-family: var(--font-sans);
  font-size: 12.5px;
  color: var(--fg-3);
  margin-top: 4px;
}

/* Card visual variants */
.res-vis-quote {
  background: linear-gradient(135deg, var(--wc-parchment-200) 0%, var(--wc-stone-100) 100%);
}
.res-vis-quote::after {
  content: '"';
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 220px;
  line-height: 0.6;
  color: var(--wc-gold-500);
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -25%);
}
.res-vis-ink {
  background: linear-gradient(135deg, #1a1410 0%, #0a0907 100%);
}
.res-vis-ink::before {
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 60% at 30% 30%, rgba(205,176,97,0.22) 0%, transparent 60%);
}
.res-vis-ink .glyph {
  position: relative;
  z-index: 1;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--wc-gold-400);
}
.res-vis-gold {
  background: linear-gradient(135deg, var(--wc-gold-50) 0%, #f4e3b1 100%);
}
.res-vis-gold .stat {
  position: relative;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 92px;
  line-height: 1;
  letter-spacing: -0.04em;
  color: var(--wc-ink-900);
  display: inline-flex;
  align-items: baseline;
}
.res-vis-gold .stat .unit {
  font-size: 0.32em;
  margin-left: 0.06em;
  font-weight: 500;
  color: var(--wc-gold-700);
}
.res-vis-stone {
  background: linear-gradient(135deg, var(--wc-stone-50) 0%, var(--wc-stone-100) 100%);
  padding: 22px;
  align-items: flex-end;
  justify-content: flex-end;
}
.res-vis-stone .mock {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 12px 14px;
  width: 100%;
  max-width: 240px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: var(--shadow-xs);
  font-family: var(--font-sans);
  font-size: 11px;
}
.res-vis-stone .mock-head {
  font-weight: 700;
  font-size: 9.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-3);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border-1);
}
.res-vis-stone .mock-row { display: flex; justify-content: space-between; color: var(--fg-1); padding: 2px 0; font-size: 11.5px; }
.res-vis-stone .mock-row .v { color: var(--fg-3); font-family: var(--font-mono); }

.res-vis-doc {
  background: linear-gradient(135deg, var(--wc-parchment-200) 0%, var(--wc-stone-100) 100%);
}
.res-vis-doc .glyph {
  position: relative;
  z-index: 1;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 200px;
  line-height: 0.85;
  letter-spacing: -0.04em;
  color: var(--wc-ink-700);
}

/* hide when filtered out */
.res-card.is-hidden { display: none; }

/* Resources CTA */
.res-cta {
  background: var(--wc-parchment-200);
  padding: 100px 0;
  border-top: 1px solid var(--border-1);
}
.res-cta-grid {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 48px;
}
@media (max-width: 760px) { .res-cta-grid { grid-template-columns: 1fr; text-align: center; } }
.res-cta h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0;
  max-width: 18ch;
}
.res-cta h2 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  color: var(--wc-gold-700);
  letter-spacing: -0.015em;
}
.res-cta p {
  font-family: var(--font-sans);
  font-size: 15.5px;
  color: var(--fg-2);
  margin: 12px 0 0;
  max-width: 46ch;
}
.res-cta-actions { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 760px) { .res-cta-actions { justify-content: center; } }

/* ============================================================
   SECURITY PAGE
   ============================================================ */

/* Dark nav variant for the security page */
.sec-nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10, 10, 9, 0.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(248, 245, 238, 0.08);
}
.sec-nav-inner {
  max-width: 1660px; margin: 0 auto;
  padding: 18px 56px;
  display: flex; align-items: center; gap: 32px;
}
@media (max-width: 760px) { .sec-nav-inner { padding: 18px 24px; } }
.sec-nav-inner img { height: 22px; width: auto; display: block; }
.sec-nav-inner ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 28px; }
.sec-nav-inner ul a {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: rgba(248,245,238,0.65);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.sec-nav-inner ul a:hover { color: var(--wc-parchment-50); }
.sec-nav-inner ul a.active { color: var(--wc-parchment-50); font-weight: 500; }
.sec-nav-right { margin-left: auto; display: flex; align-items: center; gap: 14px; }
.sec-nav-right a.signin {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--wc-parchment-50);
  text-decoration: none;
  white-space: nowrap;
}

/* Hero */
.sec-hero {
  background: var(--wc-ink-900);
  color: var(--wc-parchment-50);
  padding: 60px 0 100px;
  border-bottom: 1px solid rgba(248,245,238,0.06);
}
.sec-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1.25fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 1000px) { .sec-hero-grid { grid-template-columns: 1fr; gap: 32px; } }
.sec-hero-left { display: flex; flex-direction: column; gap: 28px; }
.sec-eb-row {
  display: flex; align-items: baseline; gap: 14px;
  font-family: var(--font-sans);
  font-size: 12px;
  flex-wrap: wrap;
}
.sec-eb-row .label {
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--wc-gold-400);
}
.sec-eb-row .tag { color: rgba(248,245,238,0.55); font-weight: 400; }
.sec-h1 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(40px, 5.4vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.028em;
  color: var(--wc-parchment-50);
  margin: 0;
  max-width: 14ch;
}
.sec-h1 em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  color: var(--wc-gold-400);
  letter-spacing: -0.018em;
}
.sec-lede {
  font-family: var(--font-sans);
  font-size: 15.5px;
  line-height: 1.6;
  color: rgba(248,245,238,0.66);
  margin: 0;
  max-width: 42ch;
}
.sec-trustcenter {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  color: var(--wc-ink-900);
  background: var(--wc-parchment-50);
  text-decoration: none;
  padding: 11px 20px;
  border-radius: 999px;
  display: inline-flex; align-items: center; gap: 8px;
  width: fit-content;
  transition: background var(--dur-fast);
}
.sec-trustcenter:hover { background: var(--wc-gold-200); }
.sec-trustcenter i { width: 14px; height: 14px; }

/* Hero photo + floating icon tiles */
.sec-hero-photo {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--wc-ink-800) 0%, var(--wc-ink-900) 100%);
}
.sec-hero-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.sec-icon-row {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  display: flex; align-items: center;
  gap: 8px;
  padding: 14px;
  background: rgba(20,18,12,0.18);
  border-radius: 22px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.10);
}
.sec-icon-tile {
  width: 76px; height: 76px;
  border-radius: 16px;
  background: rgba(248,245,238,0.10);
  border: 1px solid rgba(255,255,255,0.15);
  display: flex; align-items: center; justify-content: center;
  color: rgba(248,245,238,0.78);
  backdrop-filter: blur(6px);
}
.sec-icon-tile.center {
  background: var(--wc-parchment-50);
  color: var(--wc-ink-900);
  border-color: var(--wc-parchment-50);
  box-shadow: 0 8px 24px rgba(20,18,12,0.30);
}
.sec-icon-tile i { width: 30px; height: 30px; stroke-width: 1.4; }
.sec-icon-tile.center i { stroke-width: 1.6; }

/* Certified */
.sec-cert {
  background: var(--wc-ink-900);
  padding: 120px 0;
  border-bottom: 1px solid rgba(248,245,238,0.06);
}
.sec-cert-head {
  text-align: center;
  max-width: 880px;
  margin: 0 auto 64px;
}
.sec-cert-head .eb {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--wc-gold-400);
  display: block;
  margin-bottom: 22px;
}
.sec-cert-head h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 42px);
  line-height: 1.18;
  letter-spacing: -0.018em;
  color: var(--wc-parchment-50);
  margin: 0;
}
.sec-cert-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(248,245,238,0.10);
  border-radius: 6px;
  overflow: hidden;
}
@media (max-width: 900px) { .sec-cert-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .sec-cert-grid { grid-template-columns: 1fr; } }
.sec-cert-card {
  background: var(--wc-ink-900);
  padding: 26px 26px 22px;
  border-right: 1px solid rgba(248,245,238,0.10);
  border-bottom: 1px solid rgba(248,245,238,0.10);
  display: flex; flex-direction: column;
  min-height: 280px;
}
.sec-cert-card:last-child { border-right: none; }
@media (max-width: 900px) {
  .sec-cert-card:nth-child(2) { border-right: none; }
}
.sec-cert-card h3 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 15px;
  color: var(--wc-parchment-50);
  margin: 0 0 10px;
  letter-spacing: -0.005em;
}
.sec-cert-card p {
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.5;
  color: rgba(248,245,238,0.62);
  margin: 0;
}
.sec-cert-emblem {
  margin-top: auto;
  padding-top: 28px;
}
.sec-cert-emblem svg {
  width: 60px; height: 60px;
  color: rgba(248,245,238,0.30);
}

/* Two-up rows section */
.sec-rows {
  background: var(--wc-ink-900);
  padding: 100px 0;
  border-bottom: 1px solid rgba(248,245,238,0.06);
}
.sec-rows-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 900px) { .sec-rows-grid { grid-template-columns: 1fr; gap: 32px; } }
.sec-rows-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 28px;
  letter-spacing: -0.015em;
  color: var(--wc-parchment-50);
  margin: 0;
}
.sec-rows-list {
  border-top: 1px solid rgba(248,245,238,0.10);
}
.sec-rows-row {
  padding: 20px 0;
  border-bottom: 1px solid rgba(248,245,238,0.10);
  display: flex; flex-direction: column; gap: 8px;
}
.sec-rows-row h4 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 15px;
  color: var(--wc-parchment-50);
  margin: 0;
}
.sec-rows-row p {
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.55;
  color: rgba(248,245,238,0.62);
  margin: 0;
  max-width: 60ch;
}

/* Your data. Your decisions. */
.sec-control {
  background: var(--wc-ink-900);
  padding: 120px 0;
  border-bottom: 1px solid rgba(248,245,238,0.06);
}
.sec-control-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 56px;
}
.sec-control-head .eb {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--wc-gold-400);
  display: block;
  margin-bottom: 22px;
}
.sec-control-head h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--wc-parchment-50);
  margin: 0;
}
.sec-control-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border: 1px solid rgba(248,245,238,0.10);
  border-radius: 6px;
  overflow: hidden;
}
@media (max-width: 900px) { .sec-control-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .sec-control-grid { grid-template-columns: 1fr; } }
.sec-control-card {
  padding: 36px 28px 28px;
  border-right: 1px solid rgba(248,245,238,0.10);
  display: flex; flex-direction: column;
  min-height: 360px;
}
.sec-control-card:last-child { border-right: none; }
.sec-control-card .icon {
  display: flex; align-items: center; justify-content: center;
  height: 140px;
  margin-bottom: auto;
  color: rgba(248,245,238,0.45);
}
.sec-control-card .icon svg { width: 88px; height: 88px; }
.sec-control-card h4 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 16px;
  color: var(--wc-parchment-50);
  margin: 0 0 8px;
  letter-spacing: -0.005em;
}
.sec-control-card p {
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.5;
  color: rgba(248,245,238,0.62);
  margin: 0;
}

/* FAQ */
.sec-faq {
  background: var(--wc-ink-900);
  padding: 100px 0 80px;
  border-bottom: 1px solid rgba(248,245,238,0.06);
}
.sec-faq-inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 48px;
}
@media (max-width: 760px) { .sec-faq-inner { padding: 0 24px; } }
.sec-faq h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 28px;
  letter-spacing: -0.015em;
  color: var(--wc-parchment-50);
  margin: 0 0 28px;
}
.sec-faq-list {
  border-top: 1px solid rgba(248,245,238,0.12);
}
.sec-faq-item {
  border-bottom: 1px solid rgba(248,245,238,0.12);
}
.sec-faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 18px 0;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14.5px;
  color: var(--wc-parchment-50);
}
.sec-faq-item summary::-webkit-details-marker { display: none; }
.sec-faq-item summary::after {
  content: "+";
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: 22px;
  color: rgba(248,245,238,0.7);
  transition: transform var(--dur-base);
}
.sec-faq-item[open] summary::after { content: "−"; }
.sec-faq-item .body {
  padding: 0 0 20px;
  color: rgba(248,245,238,0.66);
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.6;
  max-width: 64ch;
}

/* CTA */
.sec-cta {
  background: var(--wc-ink-900);
  padding: 80px 0 120px;
}
.sec-cta-inner { max-width: 1660px; margin: 0 auto; padding: 0 56px; }
@media (max-width: 760px) { .sec-cta-inner { padding: 0 24px; } }
.sec-cta h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: var(--wc-parchment-50);
  margin: 0;
}
.sec-cta p {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: rgba(248,245,238,0.5);
  margin: 0 0 40px;
}
.sec-cta .cta-btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  color: var(--wc-ink-900);
  background: var(--wc-parchment-50);
  padding: 12px 22px;
  border-radius: 999px;
  text-decoration: none;
  transition: background var(--dur-fast);
}
.sec-cta .cta-btn:hover { background: var(--wc-gold-200); }
.sec-cta .cta-btn i { width: 14px; height: 14px; }

/* ============================================================
   COMPANY PAGE
   ============================================================ */

/* ---- Hero ---- */
.co-hero {
  background: var(--wc-parchment-100);
  padding: 80px 0 60px;
}
.co-hero-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 900px) { .co-hero-grid { grid-template-columns: 1fr; gap: 32px; } }
.co-hero .eb-row {
  display: flex; align-items: baseline; gap: 14px;
  font-family: var(--font-sans);
  font-size: 12px;
  margin-bottom: 26px;
  flex-wrap: wrap;
}
.co-hero .eb-row .brand {
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-1);
}
.co-hero .eb-row .tagline {
  color: var(--fg-3);
  font-weight: 400;
  letter-spacing: 0;
}
.co-hero h1 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.15;
  letter-spacing: -0.022em;
  color: var(--fg-1);
  margin: 0;
  max-width: 26ch;
}

.co-hero-photo {
  background: var(--wc-parchment-100);
  padding: 0 0 80px;
}
.co-hero-photo .frame {
  aspect-ratio: 16 / 8;
  border-radius: 6px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--wc-ink-800) 0%, var(--wc-ink-900) 100%);
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.co-hero-photo .frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  display: block;
}
.co-hero-photo .frame::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 30% 40% at 50% 30%, rgba(205,176,97,0.20) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 50% 90%, rgba(20,18,12,0.50) 0%, transparent 70%);
}
.co-hero-photo .placeholder {
  position: relative; z-index: 1;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 18px;
  color: rgba(248,245,238,0.45);
  letter-spacing: 0.02em;
}

/* ---- The Way (replaces pillars) ---- */
.co-way {
  background: var(--wc-stone-50);
  padding: 120px 0;
  border-top: 1px solid var(--border-1);
}
.co-way-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 80px;
  align-items: start;
}
@media (max-width: 900px) { .co-way-grid { grid-template-columns: 1fr; gap: 40px; } }
.co-way-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 26px;
  letter-spacing: -0.012em;
  color: var(--fg-1);
  margin: 0;
}
.co-way-items {
  display: flex; flex-direction: column;
  gap: 56px;
}
.co-way-item h4 {
  font-family: var(--font-sans);
  font-size: 0;
  margin: 0 0 18px;
  display: flex; align-items: baseline; gap: 14px;
  flex-wrap: wrap;
}
.co-way-item h4 .cat {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-1);
}
.co-way-item h4 .tag {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 12.5px;
  color: var(--fg-3);
}
.co-way-item p {
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.5;
  color: var(--fg-1);
  margin: 0;
  max-width: 46ch;
}

/* ---- Director quote (color band) ---- */
.co-quote {
  background: var(--wc-gold-500);
  color: var(--wc-ink-900);
  padding: 120px 0;
}
.co-quote-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 96px;
  align-items: center;
}
@media (max-width: 900px) { .co-quote-grid { grid-template-columns: 1fr; gap: 40px; } }
.co-quote-photo {
  aspect-ratio: 4 / 5;
  border-radius: 4px;
  background:
    radial-gradient(ellipse 60% 60% at 35% 30%, rgba(255,255,255,0.45) 0%, transparent 60%),
    linear-gradient(135deg, var(--wc-parchment-100) 0%, var(--wc-stone-100) 100%);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 96px;
  color: var(--wc-gold-700);
  letter-spacing: -0.02em;
  max-width: 460px;
  width: 100%;
  justify-self: end;
}
.co-quote-body { position: relative; }
.co-quote-mark {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 40px;
  line-height: 1;
  color: var(--wc-ink-900);
  margin-bottom: 4px;
  display: block;
}
.co-quote-text {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.35;
  letter-spacing: -0.012em;
  color: var(--wc-ink-900);
  margin: 0 0 28px;
  max-width: 36ch;
}
.co-quote-attr .name {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14px;
  color: var(--wc-ink-900);
  margin: 0;
}
.co-quote-attr .role {
  font-family: var(--font-sans);
  font-size: 13px;
  color: rgba(10,10,9,0.65);
  margin: 2px 0 0;
}

/* ---- Numbers (light variant) ---- */
.co-numbers {
  background: var(--wc-parchment-100);
  color: var(--fg-1);
  padding: 120px 0;
  border-top: 1px solid var(--border-1);
}
.co-numbers .eb { color: var(--wc-gold-700); display: block; margin-bottom: 18px; }
.co-numbers h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(32px, 4vw, 48px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0 0 56px;
  max-width: 22ch;
}
.co-numbers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
@media (max-width: 900px) { .co-numbers-grid { grid-template-columns: repeat(2, 1fr); } }
.co-number {
  display: flex; flex-direction: column;
  gap: 10px;
  padding: 24px 0 0;
  border-top: 1px solid var(--border-2);
}
.co-number .v {
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: clamp(48px, 5vw, 72px);
  line-height: 1;
  letter-spacing: -0.035em;
  color: var(--fg-1);
}
.co-number .l {
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--fg-2);
  max-width: 22ch;
} — Two-column contact/demo page
   ============================================================ */
.gs-page {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 100vh;
  background: var(--wc-parchment-100);
}
@media (max-width: 900px) { .gs-page { grid-template-columns: 1fr; } }

/* ---- Left beige panel ---- */
.gs-left {
  background:
    radial-gradient(ellipse 70% 50% at 22% 18%, rgba(205,176,97,0.16) 0%, transparent 55%),
    radial-gradient(ellipse 90% 60% at 50% 110%, rgba(205,176,97,0.10) 0%, transparent 60%),
    var(--wc-parchment-200);
  color: var(--fg-1);
  padding: 56px 64px;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
}
@media (max-width: 900px) { .gs-left { padding: 40px 28px 56px; } }

.gs-crumbs {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--fg-3);
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 92px;
}
.gs-crumbs a {
  color: var(--wc-gold-700);
  text-decoration: none;
  transition: color var(--dur-fast);
}
.gs-crumbs a:hover { color: var(--wc-gold-800); }
.gs-crumbs .sep { color: var(--border-3); }

.gs-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: 28px;
}
.gs-eyebrow::before {
  content: "";
  width: 22px; height: 2px;
  background: var(--wc-gold-500);
  border-radius: 2px;
}

.gs-headline {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(44px, 5.4vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.028em;
  color: var(--fg-1);
  margin: 0 0 28px;
  max-width: 14ch;
}
.gs-headline em {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  color: var(--wc-gold-700);
  letter-spacing: -0.018em;
  display: block;
}

.gs-lede {
  font-family: var(--font-sans);
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--fg-2);
  margin: 0 0 56px;
  max-width: 40ch;
}

.gs-contacts {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.gs-contact {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: center;
  gap: 16px;
}
.gs-contact .ico {
  width: 44px; height: 44px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--border-2);
  display: flex; align-items: center; justify-content: center;
  color: var(--wc-gold-700);
}
.gs-contact .ico i { width: 18px; height: 18px; stroke-width: 1.5; }
.gs-contact .meta { display: flex; flex-direction: column; gap: 4px; }
.gs-contact .label {
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.gs-contact .val {
  font-family: var(--font-sans);
  font-size: 14.5px;
  color: var(--fg-1);
  font-weight: 500;
}

/* ---- Right panel ---- */
.gs-right {
  padding: 56px 64px;
  background: var(--wc-parchment-100);
  display: flex;
  flex-direction: column;
}
@media (max-width: 900px) { .gs-right { padding: 40px 28px 56px; } }

.gs-mode-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  background: #fff;
  border: 1px solid var(--border-2);
  border-radius: 999px;
  padding: 4px;
  gap: 4px;
  margin-bottom: 44px;
  position: relative;
  max-width: 460px;
}
.gs-mode-tab {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--fg-2);
  background: transparent;
  border: 0;
  padding: 12px 20px;
  border-radius: 999px;
  cursor: pointer;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
}
.gs-mode-tab:hover { color: var(--fg-1); }
.gs-mode-tab.active {
  background: var(--wc-ink-900);
  color: var(--wc-parchment-50);
}
.gs-mode-tab i { width: 15px; height: 15px; stroke-width: 1.75; }

.gs-form-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 36px;
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--fg-1);
  margin: 0 0 8px;
}
.gs-form-sub {
  font-family: var(--font-sans);
  font-size: 14.5px;
  color: var(--fg-2);
  margin: 0 0 36px;
}

.gs-form { display: flex; flex-direction: column; gap: 18px; }
.gs-form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 600px) { .gs-form-grid-2 { grid-template-columns: 1fr; } }
.gs-field { display: flex; flex-direction: column; gap: 6px; }
.gs-field > label {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-1);
}
.gs-field input,
.gs-field textarea {
  font: inherit;
  font-family: var(--font-sans);
  font-size: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--border-2);
  background: #fff;
  color: var(--fg-1);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.gs-field input::placeholder,
.gs-field textarea::placeholder { color: var(--fg-3); }
.gs-field input:focus,
.gs-field textarea:focus {
  outline: none;
  border-color: var(--wc-gold-500);
  box-shadow: var(--ring-focus);
}
.gs-field textarea { min-height: 120px; resize: vertical; line-height: 1.5; }

.gs-submit {
  margin-top: 8px;
  padding: 14px 24px;
  border-radius: 999px;
  background: var(--wc-ink-900);
  color: var(--wc-parchment-50);
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 14.5px;
  border: 1px solid transparent;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.gs-submit:hover { background: #fff; color: var(--wc-ink-900); border-color: var(--border-3); }
.gs-submit i { width: 16px; height: 16px; }

/* Calendar */
.gs-calendar {
  background: #fff;
  border: 1px solid var(--border-2);
  border-radius: 14px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.gs-cal-head {
  display: flex; align-items: center; justify-content: space-between;
}
.gs-cal-head .month {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 15px;
  color: var(--fg-1);
}
.gs-cal-nav { display: flex; gap: 4px; }
.gs-cal-nav button {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: transparent;
  border: 1px solid var(--border-2);
  color: var(--fg-2);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-fast), color var(--dur-fast);
}
.gs-cal-nav button:hover { background: var(--wc-parchment-100); color: var(--fg-1); }
.gs-cal-nav i { width: 14px; height: 14px; }

.gs-cal-dow {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-3);
  padding: 0 4px;
}
.gs-cal-dow span { text-align: center; padding: 4px 0; }

.gs-cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.gs-cal-day {
  aspect-ratio: 1;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-1);
  background: transparent;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  transition: background var(--dur-fast), color var(--dur-fast);
  display: flex; align-items: center; justify-content: center;
}
.gs-cal-day:hover { background: var(--wc-parchment-200); }
.gs-cal-day.muted { color: var(--fg-muted); cursor: default; }
.gs-cal-day.muted:hover { background: transparent; }
.gs-cal-day.disabled { color: var(--fg-muted); text-decoration: line-through; cursor: not-allowed; }
.gs-cal-day.disabled:hover { background: transparent; }
.gs-cal-day.selected {
  background: var(--wc-ink-900);
  color: var(--wc-parchment-50);
}
.gs-cal-day.today {
  box-shadow: inset 0 0 0 1px var(--wc-gold-500);
}

.gs-cal-slots {
  border-top: 1px solid var(--border-1);
  padding-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.gs-cal-slots-label {
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-3);
}
.gs-cal-slot-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(86px, 1fr));
  gap: 8px;
}
.gs-cal-slot {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  padding: 9px 12px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid var(--border-2);
  color: var(--fg-1);
  cursor: pointer;
  transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast);
}
.gs-cal-slot:hover {
  background: var(--wc-parchment-200);
  border-color: var(--border-3);
}
.gs-cal-slot.selected {
  background: var(--wc-gold-500);
  border-color: var(--wc-gold-500);
  color: var(--wc-ink-900);
}
.gs-cal-empty {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 13.5px;
  color: var(--fg-3);
  padding: 4px 0;
}

/* fade panels in/out cleanly */
.gs-panel {
  display: none;
  flex-direction: column;
  animation: gsFade 250ms var(--ease-out);
}
.gs-panel.active { display: flex; }
@keyframes gsFade {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: none; }
}

/* ---- Microsoft Bookings embed ---- */
.gs-bookings {
  margin-top: 6px;
  border: 1px solid var(--wc-ink-100, rgba(22,34,49,0.12));
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 1px 3px rgba(22,34,49,0.06);
}
.gs-bookings-frame {
  display: block;
  width: 100%;
  height: 720px;
  border: 0;
}
@media (max-width: 900px) { .gs-bookings-frame { height: 640px; } }

/* ============================================================
   IMPACT — Two-column stats block (parchment band)
   ============================================================ */
.impact-section {
  background: #fff;
  padding: 120px 0;
  border-top: 1px solid var(--border-1);
}
.impact-grid {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 80px;
}
@media (max-width: 900px) { .impact-grid { grid-template-columns: 1fr; gap: 48px; } }

.impact-intro .eb-dot {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-2);
  letter-spacing: 0;
  margin-bottom: 26px;
}
.impact-intro .eb-dot::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--wc-gold-500);
}
.impact-intro .lead {
  font-family: var(--font-sans);
  font-size: 16.5px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--fg-1);
  margin: 0 0 22px;
  max-width: 38ch;
}
.impact-intro .footnote {
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--fg-2);
  margin: 0;
}

.impact-stats { display: flex; flex-direction: column; }
.impact-row {
  display: grid;
  grid-template-columns: minmax(0, auto) 1fr;
  align-items: center;
  gap: 40px;
  padding: 38px 0 32px;
  border-top: 1px solid var(--border-2);
}
.impact-row:last-child { border-bottom: 1px solid var(--border-2); }
.impact-cite {
  font-family: var(--font-sans);
  font-size: 12px;
  line-height: 1.5;
  color: var(--fg-3);
  opacity: 0.85;
  margin: 22px 0 0;
  max-width: 56ch;
}
.impact-payoff {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 16px;
  line-height: 1.6;
  color: var(--fg-1);
  margin: 22px 0 0;
  max-width: 60ch;
}
.impact-stat {
  font-family: var(--font-sans);
  font-weight: 300;
  font-size: clamp(72px, 9vw, 132px);
  line-height: 1;
  letter-spacing: -0.045em;
  color: var(--fg-1);
  display: inline-flex;
  align-items: baseline;
}
.impact-stat .unit {
  font-size: 0.42em;
  font-weight: 400;
  margin-left: 0.04em;
  letter-spacing: -0.02em;
}
.impact-caption {
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--fg-2);
  max-width: 22ch;
  justify-self: end;
  text-align: left;
}
@media (max-width: 900px) {
  .impact-stat { font-size: clamp(56px, 14vw, 84px); }
  .impact-caption { justify-self: start; max-width: 30ch; }
  .impact-row { gap: 20px; padding: 24px 0; }
}

/* ============================================================
   DELIVERS — full deliverables list
   ============================================================ */
.delivers {
  background: var(--wc-parchment-100);
  padding: 120px 0;
  border-top: 1px solid var(--border-1);
}
.delivers-head {
  margin-bottom: 64px;
  max-width: 60ch;
}
.delivers-head .eb { display: block; margin-bottom: 18px; }
.delivers-head h2 {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--fg-1);
  margin: 0 0 16px;
  max-width: 20ch;
}
.delivers-head p {
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.6;
  color: var(--fg-2);
  margin: 0;
}
.delivers-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 64px;
  border-top: 1px solid var(--border-2);
}
@media (max-width: 820px) { .delivers-grid { grid-template-columns: 1fr; column-gap: 0; } }
.delivers-item {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 18px;
  padding: 26px 0;
  border-bottom: 1px solid var(--border-1);
}
.delivers-item .idx {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--wc-gold-700);
  padding-top: 3px;
  letter-spacing: 0.02em;
}
.delivers-item h3 {
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--fg-1);
  margin: 0 0 7px;
}
.delivers-item p {
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--fg-2);
  margin: 0;
}

/* ============================================================
   PRODUCT SUITE — Four-up product cards
   ============================================================ */
.product-suite {
  background: #fff;
  padding: 120px 0;
  border-top: 1px solid var(--border-1);
}
.ps-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  margin-bottom: 56px;
  flex-wrap: wrap;
}
.ps-head .head-left .eb { margin-bottom: 12px; display: block; }
.ps-head .h-section { margin: 0; max-width: 18ch; font-size: clamp(36px, 4vw, 52px); }
.ps-readmore {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--fg-2);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  padding-bottom: 6px;
  transition: color var(--dur-fast);
}
.ps-readmore:hover { color: var(--fg-1); }
.ps-arrow {
  display: inline-block;
  color: var(--wc-gold-700);
  font-family: var(--font-mono);
  font-size: 14px;
  line-height: 1;
}

.ps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}
@media (max-width: 1100px) { .ps-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px)  { .ps-grid { grid-template-columns: 1fr; } }

.ps-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ps-visual {
  aspect-ratio: 1.05;
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
}
.ps-title {
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.018em;
  margin: 12px 0 0;
  color: var(--fg-1);
}
.ps-body {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--fg-2);
  margin: 0;
  flex: 1;
}
.ps-link {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--fg-1);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
  transition: color var(--dur-fast);
}
.ps-link:hover { color: var(--wc-gold-700); }
.ps-pill-soon {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  font-family: var(--font-sans);
  font-size: 11.5px;
  font-weight: 500;
  color: var(--fg-3);
  border: 1px solid var(--border-3);
  border-radius: 999px;
  margin-top: 6px;
  width: fit-content;
  letter-spacing: 0;
}

/* Image-fill variant for product visuals */
.ps-visual-img {
  position: relative;
  overflow: hidden;
}
.ps-visual-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* --- Card 1: Classifier — scatter visual --- */
.ps-visual-classifier {
  background: linear-gradient(135deg, #d6cdb6 0%, #c0b496 100%);
}
.ps-visual-classifier svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ps-badge {
  position: absolute;
  bottom: 16px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: rgba(255, 255, 255, 0.88);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 999px;
  font-family: var(--font-sans);
  font-size: 11.5px;
  font-weight: 500;
  color: var(--fg-1);
}
.ps-badge .dot {
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--wc-gold-500);
}
.ps-badge.is-success .dot { background: var(--wc-success-500); }
.ps-badge.is-info .dot    { background: var(--wc-info-500); }
.ps-badge.is-warning .dot { background: var(--wc-warning-500); }

/* --- Card 2: Monitors — mock list --- */
.ps-visual-monitors {
  background: var(--wc-stone-50);
  border: 1px solid var(--border-1);
  padding: 18px;
  gap: 4px;
}
.ps-mock {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 16px 18px;
  width: 100%;
  max-width: 240px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: var(--shadow-xs);
}
.ps-mock-title {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  color: var(--fg-1);
}
.ps-mock-label {
  font-family: var(--font-sans);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-3);
  margin-top: 2px;
}
.ps-mock-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 12.5px;
  color: var(--fg-1);
  padding: 4px 0;
  border-top: 1px solid var(--border-1);
}
.ps-mock-row:nth-child(3) { border-top: 0; }
.ps-mock-cc {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--fg-3);
  letter-spacing: 0.02em;
}

/* --- Card 3: Filings — XML code --- */
.ps-visual-filings {
  background: #0f0d0a;
  padding: 18px;
  justify-content: flex-start;
}
.ps-mock-code {
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.55;
  color: #e8e0c8;
  margin: 0;
  white-space: pre-wrap;
  word-break: break-all;
}
.ps-mock-code .tag { color: var(--wc-gold-400); }
.ps-mock-code .v   { color: #d4cfbe; }

/* --- Card 4: Audit Trail — entity list --- */
.ps-visual-audit {
  background: var(--wc-stone-50);
  border: 1px solid var(--border-1);
  padding: 18px;
  align-items: flex-end;
  justify-content: flex-end;
}
.ps-mock-table {
  background: #fff;
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 12px 14px;
  width: 100%;
  max-width: 280px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  box-shadow: var(--shadow-xs);
}
.ps-mock-table .head {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-sans);
  font-size: 11.5px;
  font-weight: 500;
  color: var(--fg-1);
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border-1);
}
.ps-mock-table .head .count { color: var(--fg-3); font-weight: 500; }
.ps-mock-table .row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-sans);
  font-size: 11px;
  color: var(--fg-1);
  padding: 3px 0;
}
.ps-mock-table .row .status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10.5px;
  color: var(--fg-2);
}
.ps-mock-table .row .status .dot {
  width: 5px; height: 5px;
  border-radius: 999px;
}
.ps-mock-table .status.passive  .dot { background: var(--wc-warning-500); }
.ps-mock-table .status.reporting .dot { background: var(--wc-success-500); }
.ps-mock-table .status.investment .dot { background: var(--wc-info-500); }
.ps-mock-table .status.active    .dot { background: var(--wc-success-500); }
.ps-mock-table .status.review    .dot { background: var(--wc-danger-500); }

/* ============================================================
   MATURITY — Five stages from chaos to WealthComply
   ============================================================ */
.maturity-section {
  background: var(--wc-parchment-100);
  color: var(--fg-1);
  padding: 120px 0 100px;
  border-top: 1px solid var(--border-1);
}
.maturity-section .wrap { max-width: 1660px; }
.maturity-section .eb { color: var(--wc-gold-700); }
.maturity-section .h-section { color: var(--fg-1); margin: 18px 0 16px; max-width: 24ch; }
.maturity-section .lede-dark {
  font-family: var(--font-sans); font-weight: 400;
  font-size: 16px; line-height: 1.55;
  color: var(--fg-2);
  margin: 0 0 56px;
  max-width: 56ch;
}

/* Numbered circle track */
.maturity-track {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
  padding-bottom: 0;
  margin-bottom: 14px;
}
/* horizontal colored gradient line running through the circles */
.maturity-track::before {
  content: "";
  position: absolute;
  /* line sits on the vertical center of the circles (28px from top = circle radius) */
  top: 28px;
  /* runs from the center of column 1 to the center of column 5 */
  left: calc((100% - 4 * 20px) / 10 + 0px);
  right: calc((100% - 4 * 20px) / 10 + 0px);
  height: 2px;
  background: linear-gradient(
    90deg,
    var(--wc-danger-500) 0%,
    var(--wc-warning-500) 27%,
    var(--wc-gold-700) 50%,
    var(--wc-success-500) 73%,
    var(--wc-gold-500) 100%
  );
  opacity: 0.55;
  z-index: 0;
}
.maturity-stage {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: center;
}
.maturity-stage .num {
  width: 56px; height: 56px;
  border-radius: 999px;
  border: 1.5px solid currentColor;
  background: var(--wc-parchment-100);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.01em;
  line-height: 1;
  transition: transform var(--dur-base);
}
.maturity-stage[data-tone="red"]    { color: var(--wc-danger-500); }
.maturity-stage[data-tone="amber"]  { color: var(--wc-warning-500); }
.maturity-stage[data-tone="bronze"] { color: var(--wc-gold-700); }
.maturity-stage[data-tone="green"]  { color: var(--wc-success-500); }
.maturity-stage[data-tone="gold"]   { color: var(--wc-ink-900); }
.maturity-stage[data-tone="gold"] .num {
  background: var(--wc-gold-500);
  border-color: var(--wc-gold-500);
  color: var(--wc-ink-900);
}

/* Cards */
.maturity-cards {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
.maturity-card {
  background: #fff;
  border: 1px solid var(--border-2);
  border-radius: 14px;
  padding: 24px 22px 22px;
  display: flex; flex-direction: column;
  min-height: 360px;
  box-shadow: var(--shadow-sm);
}
.maturity-card.is-wc {
  background: var(--wc-gold-50);
  border-color: rgba(205,176,97,0.45);
}
.maturity-card h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 24px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--fg-1);
  margin: 0;
  max-width: 14ch;
}
.maturity-card .card-subtitle {
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 14.5px;
  line-height: 1.45;
  color: var(--fg-2);
  margin: 10px 0 0;
}
.maturity-card .card-rule {
  width: 28px;
  height: 1.5px;
  background: currentColor;
  opacity: 0.55;
  border: 0;
  margin: 18px 0 16px;
}
.maturity-card[data-tone="red"]    .card-rule { background: var(--wc-danger-500); }
.maturity-card[data-tone="amber"]  .card-rule { background: var(--wc-warning-500); }
.maturity-card[data-tone="bronze"] .card-rule { background: var(--wc-gold-700); }
.maturity-card[data-tone="green"]  .card-rule { background: var(--wc-success-500); }
.maturity-card[data-tone="gold"]   .card-rule { background: var(--wc-gold-500); }

.maturity-card ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex; flex-direction: column;
  gap: 11px;
  flex: 1;
}
.maturity-card ul li {
  font-family: var(--font-sans);
  font-size: 13.5px;
  line-height: 1.45;
  color: var(--fg-2);
  padding-left: 16px;
  position: relative;
}
.maturity-card ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 4px; height: 4px;
  border-radius: 999px;
  background: var(--wc-stone-300);
}
.maturity-card.is-wc ul li::before { background: var(--wc-gold-500); }

.audit-readiness {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--border-1);
  display: flex; flex-direction: column;
  gap: 10px;
}
.audit-readiness .pips {
  display: flex; gap: 6px;
}
.audit-readiness .pip {
  width: 7px; height: 7px;
  border-radius: 999px;
  background: var(--wc-stone-100);
}
.maturity-card[data-tone="red"]    .audit-readiness .pip.filled { background: var(--wc-danger-500); }
.maturity-card[data-tone="amber"]  .audit-readiness .pip.filled { background: var(--wc-warning-500); }
.maturity-card[data-tone="bronze"] .audit-readiness .pip.filled { background: var(--wc-gold-700); }
.maturity-card[data-tone="green"]  .audit-readiness .pip.filled { background: var(--wc-success-500); }
.maturity-card[data-tone="gold"]   .audit-readiness .pip.filled { background: var(--wc-gold-500); }
.audit-readiness .label {
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-3);
}

@media (max-width: 1100px) {
  .maturity-track,
  .maturity-cards { grid-template-columns: repeat(2, 1fr); }
  .maturity-track::before { display: none; }
  .maturity-card { min-height: 0; }
}
@media (max-width: 600px) {
  .maturity-track { display: none; }
  .maturity-cards { grid-template-columns: 1fr; counter-reset: matcard; }
  .maturity-card { counter-increment: matcard; position: relative; padding-top: 24px; }
  .maturity-card::before {
    content: counter(matcard, decimal-leading-zero);
    position: absolute; top: 18px; right: 22px;
    width: 40px; height: 40px; border-radius: 999px;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-serif); font-style: italic; font-weight: 500; font-size: 17px;
    background: var(--wc-parchment-100); border: 1.5px solid currentColor;
  }
  .maturity-card[data-tone="red"]::before    { color: var(--wc-danger-500); }
  .maturity-card[data-tone="amber"]::before  { color: var(--wc-warning-500); }
  .maturity-card[data-tone="bronze"]::before  { color: var(--wc-gold-700); }
  .maturity-card[data-tone="green"]::before   { color: var(--wc-success-500); }
  .maturity-card[data-tone="gold"]::before {
    color: var(--wc-ink-900); background: var(--wc-gold-500); border-color: var(--wc-gold-500);
  }
}

/* ============================================================
   COMPARE — dark section, multi-select approach comparison
   ============================================================ */
.compare-section {
  background: var(--wc-ink-900);
  color: var(--wc-parchment-50);
  padding: 120px 0;
  border-top: 1px solid var(--wc-ink-700);
  border-bottom: 1px solid var(--wc-ink-700);
}
.compare-section .wrap { max-width: 1500px; }
.compare-section .eb { color: var(--wc-gold-400); }
.compare-section .h-section {
  color: var(--wc-parchment-50);
  margin: 18px 0 18px;
  max-width: 22ch;
}
.compare-section .lede-dark {
  font-family: var(--font-sans); font-weight: 400;
  font-size: 16px; line-height: 1.55;
  color: rgba(248,245,238,0.62);
  margin: 0;
  max-width: 52ch;
}

.approach-selector {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-top: 36px;
}
.approach-btn {
  padding: 10px 18px 10px 14px;
  background: rgba(248,245,238,0.04);
  border: 1px solid rgba(248,245,238,0.10);
  border-radius: 999px;
  color: rgba(248,245,238,0.62);
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast);
  display: inline-flex; align-items: center; gap: 8px;
  line-height: 1;
}
.approach-btn:hover {
  background: rgba(248,245,238,0.07);
  border-color: rgba(248,245,238,0.20);
  color: var(--wc-parchment-50);
}
.approach-btn.active {
  background: rgba(205,176,97,0.12);
  border-color: rgba(205,176,97,0.45);
  color: var(--wc-gold-400);
}
.approach-btn .check-box {
  width: 16px; height: 16px;
  border-radius: 4px;
  border: 1.5px solid rgba(248,245,238,0.22);
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur-fast), border-color var(--dur-fast);
  flex-shrink: 0;
}
.approach-btn.active .check-box {
  background: var(--wc-gold-500);
  border-color: var(--wc-gold-500);
}
.approach-btn .check-box svg { opacity: 0; transition: opacity var(--dur-fast); }
.approach-btn.active .check-box svg { opacity: 1; }

.compare-empty {
  margin-top: 36px;
  padding: 48px 24px;
  text-align: center;
  border: 1px dashed rgba(248,245,238,0.10);
  border-radius: 10px;
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 15px;
  color: rgba(248,245,238,0.40);
}
.compare-grid {
  margin-top: 36px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(248,245,238,0.08);
  background: rgba(248,245,238,0.015);
}
.cg-header {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  background: rgba(248,245,238,0.03);
  border-bottom: 1px solid rgba(248,245,238,0.08);
}
.cg-header-cell {
  padding: 14px 18px;
  font-family: var(--font-sans);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: rgba(248,245,238,0.42);
}
.cg-header-cell:last-child {
  background: rgba(205,176,97,0.08);
  color: var(--wc-gold-400);
}
.cg-header-cell.wc-label {
  display: flex; align-items: center; gap: 6px;
}
.cg-row {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  border-bottom: 1px solid rgba(248,245,238,0.05);
  transition: background var(--dur-fast);
}
.cg-row:last-child { border-bottom: none; }
.cg-row:hover { background: rgba(248,245,238,0.02); }
.cg-cell {
  padding: 14px 18px;
  font-size: 13px;
  font-family: var(--font-sans);
  display: flex; align-items: center;
}
.cg-cell.label-cell {
  color: rgba(248,245,238,0.78);
  font-weight: 500;
}
.cg-cell.wc-cell { background: rgba(205,176,97,0.045); }
.cg-rating { display: flex; align-items: center; gap: 5px; }
.cg-pip {
  width: 7px; height: 7px;
  border-radius: 999px;
  transition: background var(--dur-base);
}
.cg-pip.empty  { background: rgba(248,245,238,0.08); }
.cg-pip.red    { background: var(--wc-danger-500); }
.cg-pip.amber  { background: var(--wc-warning-500); }
.cg-pip.green  { background: var(--wc-success-500); }
.cg-pip.gold   { background: var(--wc-gold-500); }
.cg-rating-label {
  font-family: var(--font-sans);
  font-size: 12px;
  margin-left: 10px;
  font-weight: 500;
}
.cg-rating-label.red    { color: var(--wc-danger-500); }
.cg-rating-label.amber  { color: var(--wc-warning-500); }
.cg-rating-label.green  { color: var(--wc-success-500); }
.cg-rating-label.gold   { color: var(--wc-gold-400); }
.compare-note {
  margin-top: 22px;
  font-family: var(--font-serif);
  font-size: 13px;
  font-style: italic;
  color: rgba(248,245,238,0.42);
  text-align: center;
}

@media (max-width: 760px) {
  .cg-header, .cg-row { grid-template-columns: 1.4fr 1fr 1fr; }
  .cg-cell { padding: 10px 12px; font-size: 12px; }
  .cg-rating-label { display: none; }
}

/* Footer */
.legal-hero {
  background: var(--wc-parchment-200);
  padding: 80px 0 56px;
  border-bottom: 1px solid var(--border-2);
}
.legal-hero .eb {
  font-family: var(--font-sans); font-weight: 600; font-size: 12px;
  letter-spacing: 0.20em; text-transform: uppercase; color: var(--wc-gold-700);
  display: block; margin-bottom: 16px;
}
.legal-hero h1 {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(38px, 5vw, 60px); line-height: 1.05; letter-spacing: -0.018em;
  color: var(--fg-1); margin: 0 0 14px; max-width: 18ch;
}
.legal-hero .updated {
  font-family: var(--font-sans); font-size: 13.5px; color: var(--fg-3);
}
.legal-body { background: var(--wc-parchment-100); padding: 72px 0 110px; }
.legal-doc { max-width: 760px; margin: 0 auto; }
.legal-doc .lede {
  font-family: var(--font-sans); font-size: 17px; line-height: 1.65;
  color: var(--fg-2); margin: 0 0 44px;
}
.legal-doc h2 {
  font-family: var(--font-serif); font-weight: 500;
  font-size: 26px; letter-spacing: -0.012em; color: var(--fg-1);
  margin: 48px 0 14px; padding-top: 28px; border-top: 1px solid var(--border-2);
  display: flex; gap: 14px; align-items: baseline;
}
.legal-doc h2 .n {
  font-family: var(--font-mono); font-size: 13px; font-weight: 500;
  color: var(--wc-gold-700);
}
.legal-doc h3 {
  font-family: var(--font-sans); font-weight: 600; font-size: 15.5px;
  color: var(--fg-1); margin: 26px 0 8px; letter-spacing: -0.005em;
}
.legal-doc p, .legal-doc li {
  font-family: var(--font-sans); font-size: 15px; line-height: 1.65; color: var(--fg-2);
}
.legal-doc p { margin: 0 0 14px; }
.legal-doc ul { margin: 0 0 16px; padding-left: 22px; }
.legal-doc li { margin-bottom: 7px; }
.legal-doc li::marker { color: var(--wc-gold-600); }
.legal-doc strong { color: var(--fg-1); font-weight: 600; }
.legal-doc a { color: var(--wc-gold-700); text-decoration: underline; text-underline-offset: 2px; }
.legal-doc .callout {
  background: #fff; border: 1px solid var(--border-2); border-radius: 12px;
  padding: 20px 22px; margin: 24px 0; box-shadow: var(--shadow-sm);
}
.legal-doc .callout p { margin: 0; font-size: 14px; }
.legal-doc .legal-table { width: 100%; border-collapse: collapse; margin: 8px 0 20px; }
.legal-doc .legal-table th, .legal-doc .legal-table td {
  text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--border-1);
  font-family: var(--font-sans); font-size: 14px; vertical-align: top;
}
.legal-doc .legal-table th {
  font-weight: 600; color: var(--fg-1); background: var(--wc-parchment-100);
  font-size: 12px; letter-spacing: 0.04em; text-transform: uppercase;
}
.legal-doc .legal-table td { color: var(--fg-2); }

/* Footer */
.footer-cta {
  border-top: 1px solid var(--border-2);
  background: var(--wc-parchment-100);
}
.footer-cta-inner {
  max-width: 1660px; margin: 0 auto; padding: 64px 56px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center;
}
@media (max-width: 820px) { .footer-cta-inner { grid-template-columns: 1fr; gap: 32px; padding: 48px 24px; } }
.footer-cta .eb { display: block; margin-bottom: 14px; }
.footer-cta h3 {
  font-family: var(--font-serif); font-weight: 500;
  font-size: clamp(28px, 3.2vw, 40px); line-height: 1.1; letter-spacing: -0.015em;
  color: var(--fg-1); margin: 0 0 12px; max-width: none; white-space: nowrap;
}
@media (max-width: 720px) { .footer-cta h3 { white-space: normal; } }
.footer-cta p { font-family: var(--font-sans); font-size: 15px; line-height: 1.55; color: var(--fg-2); margin: 0; max-width: 46ch; }
.footer-form { display: flex; flex-direction: column; gap: 12px; }
.footer-form .row { display: flex; gap: 10px; }
@media (max-width: 480px) { .footer-form .row { flex-direction: column; } }
.footer-form input[type="email"] {
  flex: 1; font-family: var(--font-sans); font-size: 14px;
  padding: 13px 16px; border-radius: 999px;
  border: 1px solid var(--border-3); background: #fff; color: var(--fg-1);
  transition: border-color var(--dur-fast), box-shadow var(--dur-fast);
}
.footer-form input[type="email"]::placeholder { color: var(--fg-3); }
.footer-form input[type="email"]:focus { outline: none; border-color: var(--wc-gold-500); box-shadow: var(--ring-focus); }
.footer-form .submit {
  font-family: var(--font-sans); font-weight: 500; font-size: 14px;
  padding: 13px 22px; border-radius: 999px; border: 0; cursor: pointer;
  background: var(--wc-ink-900); color: var(--wc-parchment-50);
  display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
  transition: background var(--dur-fast);
}
.footer-form .submit:hover { background: var(--wc-ink-700); }
.footer-form .submit i { width: 15px; height: 15px; }
.footer-form .consent {
  display: flex; align-items: flex-start; gap: 9px;
  font-family: var(--font-sans); font-size: 12px; line-height: 1.45; color: var(--fg-3);
}
.footer-form .consent input { margin-top: 2px; accent-color: var(--wc-gold-600); flex-shrink: 0; }
.footer-form .ok {
  font-family: var(--font-sans); font-size: 13.5px; color: var(--wc-success-600); font-weight: 500;
  display: none; align-items: center; gap: 8px;
}
.footer-form.is-done .ok { display: flex; }
.footer-form.is-done .row, .footer-form.is-done .consent { display: none; }

footer { background: var(--wc-parchment-200); color: var(--fg-2); padding: 80px 0 40px; border-top: 1px solid var(--border-2); }
footer .grid { display: flex; flex-wrap: wrap; gap: 48px; margin-bottom: 64px; }
footer .grid > .brand-block { flex: 1.6 1 280px; }
footer .grid > div:not(.brand-block) { flex: 1 1 150px; }
@media (max-width: 900px) { footer .grid { gap: 36px; } footer .grid > div:not(.brand-block) { flex-basis: 40%; } }
footer h5 { font-family: var(--font-sans); font-weight: 700; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--wc-gold-700); margin: 0 0 16px; }
footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
footer a { color: var(--fg-2); text-decoration: none; font-size: 14px; }
footer a:hover { color: var(--fg-1); }
footer .brand-block img { height: 28px; margin-bottom: 18px; }
footer .brand-block p { font-family: var(--font-serif); font-style: italic; font-size: 17px; line-height: 1.45; color: var(--fg-2); max-width: 28ch; margin: 0; }
footer .social {
  display: flex; gap: 10px; margin-top: 22px;
}
footer .social a {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: rgba(20, 18, 12, 0.04);
  border: 1px solid var(--border-2);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--fg-2);
  transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast);
}
footer .social a:hover {
  background: var(--wc-gold-50);
  border-color: rgba(205, 176, 97, 0.40);
  color: var(--wc-gold-700);
}
footer .social svg { width: 16px; height: 16px; }
footer .bottom {
  border-top: 1px solid var(--border-2); padding-top: 28px;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
  font-size: 12px; color: var(--fg-3);
}
footer .bottom .marks { display: flex; gap: 18px; font-family: var(--font-sans); font-weight: 500; font-size: 10px; letter-spacing: 0.16em; }

/* ============================================================
   MOBILE NAV MENU (hamburger + overlay) — injected by mobile-menu.js
   ============================================================ */
.wc-burger { display: none; }
@media (max-width: 760px) {
  .wc-burger {
    display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
    width: 42px; height: 42px; padding: 0 10px;
    background: transparent; border: 0; cursor: pointer;
    justify-self: end; align-self: center;
    position: relative; z-index: 60;
  }
  /* place the burger in the hero glass nav's right cell */
  .hero-cine .nav .wc-burger { grid-column: 2; }
  .wc-burger span {
    display: block; height: 2px; width: 22px; border-radius: 2px;
    background: var(--fg-1);
    transition: transform var(--dur-fast) var(--ease-out), opacity var(--dur-fast);
  }
  /* hero nav sits on dark imagery → white bars */
  .hero-cine .nav .wc-burger span,
  .sec-nav .wc-burger span { background: var(--wc-parchment-50); }
  .wc-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .wc-burger.open span:nth-child(2) { opacity: 0; }
  .wc-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  .wc-mobile-menu {
    position: fixed; inset: 0; z-index: 55;
    background: var(--wc-ink-900);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity var(--dur-base) var(--ease-out);
  }
  .wc-mobile-menu.open { opacity: 1; pointer-events: auto; }
  .wc-mobile-inner {
    display: flex; flex-direction: column; align-items: center; gap: 22px;
    padding: 32px; width: 100%;
  }
  .wc-mobile-link {
    font-family: var(--font-serif); font-weight: 500; font-size: 30px;
    letter-spacing: -0.01em; color: var(--wc-parchment-50); text-decoration: none;
  }
  .wc-mobile-link.is-cta {
    margin-top: 12px; font-family: var(--font-sans); font-weight: 500; font-size: 16px;
    background: var(--wc-gold-500); color: var(--wc-ink-900);
    padding: 13px 26px; border-radius: 999px; letter-spacing: 0;
  }
}

/* ============================================================
   MOBILE OPTIMIZATION — consolidated
   ============================================================ */
@media (max-width: 760px) {
  /* --- Nav: hide inline link lists, keep logo + CTA --- */
  .hero-cine .nav { grid-template-columns: 1fr auto; margin: 14px 16px 0; padding: 12px 16px; gap: 12px; }
  .hero-cine .nav-links { display: none; }
  .hero-cine .brand-mark { justify-self: start; }
  .hero-cine .nav-right { gap: 10px; }
  .hero-cine .nav-right a.signin { display: none; }

  /* Light/dark navs on interior pages are inline-styled flex bars;
     hide their middle <ul> and tighten the container. */
  nav > div > ul { display: none !important; }
  nav > div { padding-left: 20px !important; padding-right: 20px !important; gap: 16px !important; }
  .sec-nav-inner ul { display: none !important; }

  /* --- Hero headline: rein in the inline 100px --- */
  .hero-cine .h-cine { font-size: 52px !important; line-height: 1.04; }
  .hero-cine .content { padding: 0 24px 64px; }
  .hero-cine .tagline { font-size: 15px !important; }
  .hero-sub-row { flex-direction: column; gap: 14px; }

  /* --- Section headings that use fixed inline sizes --- */
  .delivers-head h2 { white-space: normal !important; font-size: 30px !important; }
  .compare-section .h-section,
  .delivers-head h2,
  .co-hero h1 { width: auto !important; max-width: none !important; }

  /* --- Platform layer cards: static stacked list on mobile --- */
  .arch { height: auto; }
  .arch-sticky { position: relative; height: auto; min-height: 0; padding: 64px 24px; gap: 24px; }
  /* the scroll-driven JS reveal can't run without the tall sticky track,
     so force every slab visible and stacked by its data-layer offset */
  .arch-tile { opacity: 1 !important; }
  .arch-tile[data-layer="0"] { transform: translateZ(0) scale(1) !important; }
  .arch-tile[data-layer="1"] { transform: translateZ(34px) scale(1) !important; }
  .arch-tile[data-layer="2"] { transform: translateZ(68px) scale(1) !important; }
  .arch-tile[data-layer="3"] { transform: translateZ(102px) scale(1) !important; }
  .arch-tile[data-layer="4"] { transform: translateZ(136px) scale(1) !important; }
  .arch-tile[data-layer="5"] { transform: translateZ(170px) scale(1) !important; }

  /* --- Platform pills: tappable accordion on mobile --- */
  .arch-pill .toggle { display: inline-flex; }
  .arch-pill:not(.active) .body { display: none; }

  /* --- Tables scroll horizontally rather than crush --- */
  .wc-table-wrap, .compare-grid { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* --- Footer: stack columns 2-up cleanly --- */
  footer { padding: 56px 0 32px; }
  footer .grid > .brand-block { flex-basis: 100%; }

  /* --- Get-started: calendar + form breathe --- */
  .gs-cal-slot-grid { grid-template-columns: repeat(auto-fill, minmax(72px, 1fr)); }
}

/* Tablet-down: arch text column no longer needs to align to a 2-col grid */
@media (max-width: 900px) {
  .arch-intro h2 { font-size: clamp(30px, 6vw, 44px); }
}
