/* ==========================================================================
   Impact Outsourcing — main.css (regenerated, scoped)
   Per-page rules use `.page-NAME .selector` scoping to prevent class-name
   collisions across pages (.final-cta, .proof, .principles, .lead).
   ========================================================================== */

/* ==== Design tokens (deduplicated) ==== */
:root {
    --ink: #0F0F10;
    --paper: #FAFAF7;
    --white: #FFFFFF;
    --gold: #C9A227;
    --warm-grey: #6E6E73;
    --soft-line: #E5E5E0;
    --slate: #1C1C1E;
    --container: 1180px;
    --gutter: 24px;

    --f-display: "Fraunces", "Times New Roman", Georgia, serif;
    --f-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
    --f-mono: "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  }

/* ========== Impact Outsourcing Homepage.html  (.page-home) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px;
    line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
  .prose { max-width: 680px; }

  .eyebrow {
    font-family: var(--f-sans);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display);
    font-weight: 400;
    letter-spacing: -0.015em;
    margin: 0;
    color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; -webkit-hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }

  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-home .lead{ font-size: 19px; line-height: 1.55; color: var(--ink); }
  .meta { color: var(--warm-grey); font-size: 14px; }

  /* Buttons */
  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer; border: 1px solid transparent;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { border-color: var(--ink); color: var(--ink); background: transparent; }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .btn-ghost-light { border-color: var(--paper); color: var(--paper); background: transparent; }
  .btn-ghost-light:hover { background: var(--paper); color: var(--ink); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav {
    position: sticky; top: 0; z-index: 50;
    background: rgba(250, 250, 247, 0.85);
    backdrop-filter: saturate(140%) blur(12px);
    -webkit-backdrop-filter: saturate(140%) blur(12px);
    border-bottom: 1px solid var(--soft-line);
  }
  .nav-inner {
    display: flex; align-items: center; justify-content: space-between;
    height: 104px;
  }
  .logo {
    display: inline-flex; align-items: center;
  }
  .logo img { max-height: 48px; width: auto; display: block; }
  .footer-logo img { height: 140px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-cta { display: flex; gap: 12px; align-items: center; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  /* Hero */
  .hero { padding: 96px 0 120px; border-bottom: 1px solid var(--soft-line); }
  .hero-grid {
    display: grid; grid-template-columns: 1.05fr 0.95fr;
    gap: 80px; align-items: center;
  }
  .hero h1 { max-width: 620px; overflow-wrap: break-word; hyphens: auto; }
  .hero h1 em {
    font-style: italic; font-weight: 300;
    color: var(--ink);
  }
  .hero .lead { margin-top: 28px; max-width: 540px; color: var(--warm-grey); font-size: 20px; }
  .hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .trust-chip {
    margin-top: 24px;
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; letter-spacing: 0.04em;
    color: var(--warm-grey);
    font-family: var(--f-mono);
  }
  .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

  /* Hero visual — rotating value slider */
  .hero-visual {
    position: relative; aspect-ratio: 5/6;
    border: 1px solid rgba(15,15,16,0.08); border-radius: 12px;
    background: #E6BE3A; color: var(--ink); overflow: hidden;
  }
  .hero-slides { position: absolute; inset: 0; }
  .hero-slide {
    position: absolute; inset: 0;
    padding: clamp(24px, 4vw, 40px);
    display: grid; grid-template-rows: auto 1fr auto; gap: 20px;
    opacity: 0; transform: translateX(24px);
    transition: opacity 600ms cubic-bezier(.2,.6,.2,1), transform 600ms cubic-bezier(.2,.6,.2,1);
    pointer-events: none;
  }
  .hero-slide.is-active { opacity: 1; transform: translateX(0); pointer-events: auto; }
  .hs-head { display: flex; justify-content: space-between; align-items: center; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(15,15,16,0.65); }
  .hs-head .hs-cat { color: var(--ink); font-weight: 600; }
  .hs-body { align-self: center; color: var(--ink); }
  .hs-kicker { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(15,15,16,0.65); margin-bottom: 18px; }
  .hs-metric { font-family: var(--f-display); font-size: clamp(44px, 6vw, 84px); line-height: 0.95; font-weight: 400; font-variation-settings: "opsz" 96; letter-spacing: -0.02em; margin-bottom: 14px; color: var(--ink); }
  .hs-metric.small { font-size: clamp(32px, 4vw, 56px); letter-spacing: -0.01em; }
  .hs-metric sup { font-size: 0.45em; font-weight: 400; color: var(--ink); opacity: 0.7; vertical-align: top; line-height: 1; margin-left: 4px; }
  .hs-title { font-family: var(--f-display); font-size: clamp(20px, 2.2vw, 26px); line-height: 1.2; font-weight: 400; margin-bottom: 10px; max-width: 360px; color: var(--ink); }
  .hs-sub { font-size: clamp(12px, 1.2vw, 13px); line-height: 1.6; color: rgba(15,15,16,0.78); max-width: 340px; margin: 0; }
  .hs-foot { display: flex; justify-content: space-between; align-items: end; gap: 16px; }
  .hs-chips { display: flex; gap: 6px; flex-wrap: wrap; }
  .hs-chip { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em; text-transform: uppercase; padding: 5px 10px; border-radius: 3px; border: 1px solid rgba(15,15,16,0.3); color: var(--ink); white-space: nowrap; background: rgba(255,255,255,0.18); }
  .hs-chip.gold { border-color: var(--ink); color: var(--ink); background: rgba(15,15,16,0.08); font-weight: 600; }
  .hero-dots { position: absolute; bottom: 20px; right: 20px; display: flex; gap: 8px; z-index: 5; }
  .hero-dots button {
    width: 28px; height: 3px; padding: 0; border: 0; cursor: pointer;
    background: rgba(15,15,16,0.25); border-radius: 2px;
    transition: background 200ms ease, width 200ms ease;
  }
  .hero-dots button.is-active { background: var(--ink); width: 40px; }
  .hero-dots button:hover { background: rgba(15,15,16,0.55); }
  .hero-dots button.is-active:hover { background: var(--ink); }
  /* Decorative backdrop shapes per-slide */
  .hs-decor { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
  .hs-decor::before, .hs-decor::after { content: ""; position: absolute; border-radius: 50%; }
  .hero-slide[data-slide="1"] .hs-decor::before { right: -80px; top: -80px; width: 260px; height: 260px; background: radial-gradient(circle, rgba(255,255,255,0.3), transparent 70%); }
  .hero-slide[data-slide="1"] .hs-decor::after { left: 40px; bottom: 40px; width: 140px; height: 140px; border: 1px solid rgba(15,15,16,0.12); }
  .hero-slide[data-slide="2"] .hs-decor::before { left: -60px; bottom: -60px; width: 220px; height: 220px; background: radial-gradient(circle, rgba(255,255,255,0.25), transparent 70%); }
  .hero-slide[data-slide="2"] .hs-decor::after { right: 36px; top: 120px; width: 80px; height: 80px; border: 1px dashed rgba(15,15,16,0.3); }
  .hero-slide[data-slide="3"] .hs-decor::before { right: 40px; bottom: 40px; width: 180px; height: 180px; border: 1px solid rgba(15,15,16,0.25); }
  .hero-slide[data-slide="3"] .hs-decor::after { left: -40px; top: 80px; width: 160px; height: 160px; background: radial-gradient(circle, rgba(255,255,255,0.28), transparent 70%); }

  /* Client Strip */
  .section { padding: 120px 0; }
  .section-tight { padding: 80px 0; }
  .section.dark { background: var(--slate); color: var(--paper); }
  .section.dark h2, .section.dark h3 { color: var(--paper); }
  .section.dark .lead { color: rgba(250,250,247,0.7) !important; }
  .section.dark p { color: rgba(250,250,247,0.7); }
  .section.dark .vp-card { border-top-color: var(--paper); }
  .section.dark .vp-card h3 { color: var(--paper); }
  .section.dark .vp-card p { color: rgba(250,250,247,0.7); }
  .section.dark .vp-num { color: var(--gold); }
  .section.dark .metrics { border-top-color: rgba(250,250,247,0.15); border-bottom-color: rgba(250,250,247,0.15); }
  .section.dark .metric { border-right-color: rgba(250,250,247,0.15); }
  .section.dark .metric .num { color: var(--paper); }
  .section.dark .metric .lbl { color: rgba(250,250,247,0.65); }
  .section.paper-alt { background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }

  .clients {
    padding: 72px 0;
    border-bottom: 1px solid var(--soft-line);
  }
  .clients-label {
    text-align: center; margin-bottom: 36px;
    font-size: 13px; letter-spacing: 0.08em;
    color: var(--warm-grey); font-family: var(--f-mono); text-transform: uppercase;
  }
  .logos {
    display: grid; grid-template-columns: repeat(6, 1fr);
    gap: 48px; align-items: center; justify-items: center;
  }
  .logo-wm {
    font-family: var(--f-display); font-weight: 500;
    font-size: 26px; letter-spacing: -0.01em;
    color: var(--gold); opacity: 0.9;
    transition: opacity .2s ease, transform .2s ease, color .2s ease;
    text-align: center; line-height: 1;
  }
  .logo-wm:hover { opacity: 1; transform: translateY(-2px); color: #E5B72E; }
  .logo-wm small { display:block; font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.1em; opacity: 0.55; margin-top: 4px; text-transform: uppercase; font-weight: 400; }
  @media (max-width: 900px){ .logos { grid-template-columns: repeat(3, 1fr); row-gap: 32px; } }

  /* Value prop */
  .valueprop-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px;
    margin-top: 64px;
  }
  .vp-card {
    padding: 40px 0 0;
    border-top: 1px solid var(--ink);
  }
  .vp-num {
    font-family: var(--f-mono); font-size: 12px;
    letter-spacing: 0.1em; color: var(--warm-grey);
    margin-bottom: 24px;
  }
  .vp-card h3 { margin-bottom: 16px; }
  .vp-card p { color: var(--warm-grey); }
  @media (max-width: 900px){ .valueprop-grid { grid-template-columns: 1fr; gap: 32px; } }

  /* Services */
  .services-head {
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
    align-items: end; margin-bottom: 64px;
  }
  .services-head p { color: var(--warm-grey); font-size: 17px; max-width: 460px; margin: 0; }
  .services-grid {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 1px; background: var(--soft-line);
    border: 1px solid var(--soft-line); border-radius: 12px; overflow: hidden;
  }
  .service {
    background: var(--white);
    padding: 40px;
    display: flex; flex-direction: column; justify-content: space-between;
    min-height: 260px;
    transition: background .2s ease;
  }
  .service:hover { background: #FCFCF9; }
  .service:hover .svc-arrow { transform: translateX(4px); color: var(--gold); }
  .svc-ico {
    width: 40px; height: 40px; border: 1px solid var(--ink); border-radius: 6px;
    display: grid; place-items: center; margin-bottom: 24px;
  }
  .svc-ico svg { width: 20px; height: 20px; stroke: var(--ink); fill: none; stroke-width: 1.5; }
  .service h3 { font-size: 22px; margin-bottom: 10px; }
  .service p { font-size: 15px; color: var(--warm-grey); margin: 0; }
  .svc-foot {
    margin-top: 32px;
    display: flex; justify-content: space-between; align-items: center;
    font-size: 13px; font-weight: 500;
    padding-top: 20px; border-top: 1px solid var(--soft-line);
  }
  .svc-arrow { transition: transform .2s ease, color .2s ease; color: var(--ink); }
  @media (max-width: 900px){
    .services-head { grid-template-columns: 1fr; gap: 24px; }
    .services-grid { grid-template-columns: 1fr; }
  }

  /* How it works */
  .how {
    background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line);
  }
  .how-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
    margin-top: 72px;
    position: relative;
  }
  .step { position: relative; padding-top: 32px; border-top: 1px solid var(--ink); }
  .step-num {
    position: absolute; top: -13px; left: 0;
    background: var(--white); padding-right: 14px;
    font-family: var(--f-mono); font-size: 12px;
    color: var(--gold); letter-spacing: 0.1em;
  }
  .step h3 { font-size: 22px; margin-bottom: 14px; }
  .step p { color: var(--warm-grey); font-size: 15px; margin: 0; }
  .step .dur {
    display: inline-block; margin-top: 20px;
    font-family: var(--f-mono); font-size: 11px;
    color: var(--warm-grey); letter-spacing: 0.06em;
    padding: 4px 10px; border: 1px solid var(--soft-line); border-radius: 3px;
  }
  @media (max-width: 900px){ .how-grid { grid-template-columns: 1fr; gap: 40px; } }

  /* Proof & metrics */
  .metrics {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 0; margin-top: 72px;
    border-top: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
  }
  .metric {
    padding: 48px 32px;
    border-right: 1px solid var(--soft-line);
  }
  .metric:last-child { border-right: none; }
  .metric .num {
    font-family: var(--f-display); font-size: clamp(48px, 5vw, 68px);
    font-weight: 300; line-height: 1;
    font-variation-settings: "opsz" 144;
    margin-bottom: 16px; color: var(--ink);
    letter-spacing: -0.03em;
  }
  .metric .num sup { font-size: 0.4em; vertical-align: super; color: var(--gold); font-weight: 500; margin-left: 4px; font-variation-settings: "opsz" 9; }
  .metric .lbl { font-size: 14px; color: var(--warm-grey); line-height: 1.4; }
  @media (max-width: 900px){
    .metrics { grid-template-columns: repeat(2, 1fr); }
    .metric { border-bottom: 1px solid var(--soft-line); }
    .metric:nth-child(2) { border-right: none; }
  }

  /* Testimonial */
  .testimonial { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .testimonial .eyebrow { color: var(--gold); }
  .testimonial blockquote {
    margin: 0; padding: 0;
    font-family: var(--f-display); font-weight: 300;
    font-size: clamp(30px, 3.6vw, 46px); line-height: 1.2;
    letter-spacing: -0.015em;
    font-variation-settings: "opsz" 96;
    color: var(--paper);
    max-width: 900px;
    text-wrap: pretty;
  }
  .testimonial blockquote::before {
    content: "“";
    display: block;
    font-size: 72px; line-height: 0.8;
    color: var(--gold); margin-bottom: 16px;
  }
  .testimonial .author {
    margin-top: 56px; display: flex; align-items: center; gap: 20px;
  }
  .author-photo {
    width: 60px; height: 60px; border-radius: 50%;
    background: linear-gradient(135deg, #3a3a3d, #1c1c1e);
    border: 1px solid rgba(255,255,255,0.15);
    display: grid; place-items: center;
    font-family: var(--f-mono); font-size: 10px; color: rgba(250,250,247,0.5);
  }
  .author-name { font-weight: 500; font-size: 15px; }
  .author-title { font-size: 13px; color: rgba(250,250,247,0.6); margin-top: 2px; }
  .author-co { margin-left: auto; font-family: var(--f-display); font-size: 20px; color: rgba(250,250,247,0.6); font-style: italic; }
  @media (max-width: 700px){ .author-co { display: none; } }

  /* Nairobi */
  .nairobi-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start;
  }
  .nairobi-visual {
    aspect-ratio: 4/5; background: var(--slate);
    border: 1px solid var(--soft-line); border-radius: 12px;
    position: relative; overflow: hidden;
    box-shadow: 0 40px 80px -32px rgba(15,15,16,0.22);
  }
  .nairobi-visual img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .nairobi-visual .corner {
    position: absolute; top: 16px; left: 16px;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
    color: rgba(250,250,247,0.95); text-transform: uppercase;
    background: rgba(15,15,16,0.55); backdrop-filter: blur(8px);
    padding: 7px 10px; border-radius: 4px;
  }
  .nairobi-visual .plate {
    position: absolute; bottom: 16px; left: 16px; right: 16px;
    display: flex; justify-content: space-between; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    color: rgba(250,250,247,0.85); text-transform: uppercase;
  }
  .advantages { margin-top: 40px; display: grid; gap: 0; }
  .advantage {
    display: grid; grid-template-columns: 32px 1fr; gap: 20px;
    padding: 24px 0; border-bottom: 1px solid var(--soft-line); align-items: start;
  }
  .advantage:last-child { border-bottom: none; }
  .advantage .idx { font-family: var(--f-mono); font-size: 12px; color: var(--gold); padding-top: 2px; }
  .advantage h4 { font-family: var(--f-sans); font-weight: 600; font-size: 16px; margin: 0 0 4px; letter-spacing: 0; }
  .advantage p { color: var(--warm-grey); font-size: 14px; margin: 0; }
  @media (max-width: 900px){ .nairobi-grid { grid-template-columns: 1fr; gap: 48px; } }

  /* Social Impact Band (nested) */
  .impact-band {
    margin-top: 80px;
    padding: 48px;
    background: var(--white); border: 1px solid var(--soft-line); border-radius: 12px;
    display: grid; grid-template-columns: 1fr 2fr; gap: 48px; align-items: center;
  }
  .impact-band h3 { font-size: 28px; }
  .impact-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .impact-stat .n { font-family: var(--f-display); font-size: 36px; font-variation-settings: "opsz" 96; line-height: 1; margin-bottom: 6px; font-weight: 400; }
  .impact-stat .l { font-size: 12px; color: var(--warm-grey); line-height: 1.4; }
  .sdg-tags { margin-top: 20px; display: flex; gap: 8px; flex-wrap: wrap; }
  .sdg { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; padding: 4px 10px; border: 1px solid var(--soft-line); border-radius: 3px; color: var(--warm-grey); text-transform: uppercase; }
  @media (max-width: 900px){
    .impact-band { grid-template-columns: 1fr; gap: 32px; padding: 32px; }
    .impact-stats { grid-template-columns: 1fr; }
  }

  /* ISO Band */
  .iso-band {
    padding: 64px 0;
    background: var(--white);
    border-top: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
  }
  .iso-inner {
    display: grid; grid-template-columns: auto 1fr auto; gap: 48px; align-items: center;
  }
  .iso-seal {
    width: 120px; height: 120px; border-radius: 50%;
    border: 1.5px solid var(--ink);
    display: grid; place-items: center; text-align: center;
    font-family: var(--f-display); font-weight: 500;
    position: relative;
    flex-shrink: 0;
  }
  .iso-seal::before {
    content: ""; position: absolute; inset: 8px; border-radius: 50%;
    border: 1px solid var(--soft-line);
  }
  .iso-seal .big { font-size: 22px; line-height: 1; }
  .iso-seal .small { font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.1em; margin-top: 4px; color: var(--warm-grey); text-transform: uppercase; }
  .iso-copy h3 { font-size: 24px; margin-bottom: 8px; }
  .iso-copy p { color: var(--warm-grey); font-size: 14px; margin: 0; max-width: 540px; }
  .iso-cert { font-family: var(--f-mono); font-size: 11px; color: var(--ink); letter-spacing: 0.06em; text-transform: uppercase; text-align: right; }
  .iso-cert .n { color: var(--gold); display:block; margin-top: 4px; }
  @media (max-width: 900px){
    .iso-inner { grid-template-columns: 1fr; gap: 24px; text-align: left; }
    .iso-cert { text-align: left; }
  }

  /* Final CTA */
  .page-home .final-cta{
    padding: 160px 0; text-align: left;
    background: var(--ink); color: var(--paper);
  }
  .page-home .final-cta h2{ color: var(--paper); }
  .page-home .final-cta .lead{ color: rgba(250,250,247,0.7) !important; }
  .final-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .page-home .final-cta h2{ font-size: clamp(40px, 5vw, 64px); max-width: 720px; }
  .final-paths { display: grid; gap: 16px; }
  .page-home .final-cta .path{
    padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: transparent; color: var(--paper); transition: background .2s ease, color .2s ease, border-color .2s ease;
  }
  .page-home .final-cta .path.primary{ background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .page-home .final-cta .path.primary:hover{ background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .page-home .final-cta .path.secondary:hover{ background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .path {
    padding: 28px 32px; border: 1px solid var(--ink); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: var(--white); transition: background .2s ease, color .2s ease;
  }
  .path.primary { background: var(--ink); color: var(--paper); }
  .path.primary:hover { background: var(--gold); color: var(--ink); }
  .path.secondary:hover { background: var(--ink); color: var(--paper); }
  .path .p-head { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .path .p-sub { font-size: 13px; opacity: 0.7; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .path .p-arrow { font-size: 22px; }
  @media (max-width: 900px){ .final-grid { grid-template-columns: 1fr; gap: 48px; } }

  /* Footer */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px){ .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ===== Spec section (below the design) ===== */
  .spec {
    background: var(--paper);
    border-top: 8px solid var(--ink);
    padding: 100px 0 140px;
  }
  .spec .container { max-width: 920px; }
  .spec h1 { font-size: 48px; margin-bottom: 8px; }
  .spec h2 { font-size: 30px; margin-top: 72px; margin-bottom: 20px; padding-top: 24px; border-top: 1px solid var(--soft-line); }
  .spec h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin-top: 32px; margin-bottom: 8px; color: var(--ink); }
  .spec h4 { font-family: var(--f-sans); font-weight: 600; font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--gold); margin-top: 20px; margin-bottom: 8px; }
  .spec p, .spec li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .spec ul, .spec ol { padding-left: 22px; margin: 0 0 1em; }
  .spec li { margin-bottom: 4px; }
  .spec code, .spec pre {
    font-family: var(--f-mono);
    font-size: 13px;
    background: var(--white);
    border: 1px solid var(--soft-line);
    border-radius: 4px;
  }
  .spec code { padding: 2px 6px; }
  .spec pre { padding: 20px 24px; overflow-x: auto; white-space: pre; line-height: 1.55; }
  .spec pre code { padding: 0; border: none; background: transparent; font-size: 13px; }
  .spec .spec-intro { font-size: 17px; color: var(--warm-grey); max-width: 680px; }
  .spec table {
    width: 100%; border-collapse: collapse; margin: 16px 0;
    font-size: 14px;
  }
  .spec th, .spec td {
    text-align: left; padding: 12px 14px;
    border-bottom: 1px solid var(--soft-line);
    vertical-align: top;
  }
  .spec th { font-weight: 600; background: var(--white); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--warm-grey); }
  .spec .section-spec {
    background: var(--white); border: 1px solid var(--soft-line); border-radius: 12px;
    padding: 40px; margin: 24px 0 32px;
  }
  .spec .section-spec h3:first-of-type { margin-top: 0; }
  .spec .tag {
    display: inline-block; font-family: var(--f-mono); font-size: 10px;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 3px 8px; border-radius: 3px; margin-right: 6px;
    background: var(--paper); color: var(--ink); border: 1px solid var(--soft-line);
  }
  .spec .tag.gold { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .spec hr { border: none; border-top: 1px solid var(--soft-line); margin: 48px 0; }
  .spec .score-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin: 24px 0; }
  .spec .score { background: var(--white); border: 1px solid var(--soft-line); border-radius: 10px; padding: 24px; }
  .spec .score .n { font-family: var(--f-display); font-size: 48px; line-height: 1; font-weight: 400; font-variation-settings: "opsz" 96; }
  .spec .score .n .max { color: var(--warm-grey); font-size: 20px; }
  .spec .score .l { font-size: 12px; color: var(--warm-grey); margin-top: 6px; letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 700px){ .spec .score-grid { grid-template-columns: 1fr 1fr; } }

  .spec-toc {
    background: var(--white); border: 1px solid var(--soft-line); border-radius: 12px;
    padding: 32px; margin: 32px 0 48px;
    columns: 2; column-gap: 40px;
  }
  .spec-toc a { font-size: 14px; color: var(--ink); display: block; padding: 6px 0; border-bottom: 1px solid var(--soft-line); }
  .spec-toc a:hover { color: var(--gold); }
  @media (max-width: 700px){ .spec-toc { columns: 1; } }

  .banner {
    background: var(--ink); color: var(--paper);
    text-align: center; padding: 14px;
    font-family: var(--f-mono); font-size: 12px;
    letter-spacing: 0.08em; text-transform: uppercase;
  }
  .banner .dot { color: var(--gold); }

  @media (max-width: 900px){
    .hero-grid { grid-template-columns: 1fr; gap: 48px; }
    .section { padding: 80px 0; }
    .hero { padding: 64px 0 80px; }
    .testimonial { padding: 96px 0; }
    .page-home .final-cta{ padding: 96px 0; }
  }

  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible {
    opacity: 1;
    transform: translateY(0);
  }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== About.html  (.page-about) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px;
    line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
  .prose { max-width: 680px; }

  .eyebrow {
    font-family: var(--f-sans);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display);
    font-weight: 400;
    letter-spacing: -0.015em;
    margin: 0;
    color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(44px, 6vw, 76px); line-height: 1.02; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em { font-style: italic; font-weight: 300; }

  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-about .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .btn .arrow { transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav {
    position: sticky; top: 0; z-index: 10;
    background: rgba(250,250,247,0.85); backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--soft-line);
  }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  /* Banner */
  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* ============ HERO ============ */
  .about-hero {
    padding: 120px 0 100px;
    border-bottom: 1px solid var(--soft-line);
    position: relative;
  }
  .about-hero .breadcrumb {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px;
  }
  .about-hero .breadcrumb a { color: var(--warm-grey); }
  .about-hero .breadcrumb span { color: var(--ink); }
  .about-hero h1 { max-width: 900px; font-size: clamp(44px, 6.2vw, 84px); }
  .about-hero .lead { max-width: 640px; margin-top: 32px; font-size: 22px; }
  .about-meta {
    margin-top: 56px; display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 32px; padding-top: 32px; border-top: 1px solid var(--soft-line);
  }
  .about-meta .m .l { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--warm-grey); text-transform: uppercase; margin-bottom: 8px; }
  .about-meta .m .v { font-family: var(--f-display); font-size: 24px; line-height: 1.15; font-variation-settings: "opsz" 48; }
  @media (max-width: 900px){ .about-meta { grid-template-columns: 1fr 1fr; } }

  /* ============ MANIFESTO (dark) ============ */
  .manifesto { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .manifesto .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: stretch; }
  .manifesto .eyebrow { color: var(--gold); }
  .manifesto h2 { color: var(--paper); }
  .manifesto h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .manifesto .left-col { display: flex; flex-direction: column; gap: 40px; height: 100%; }
  .manifesto .left-col .head { flex: 0 0 auto; }
  .manifesto .portrait-figure {
    position: relative;
    flex: 1 1 0;
    min-height: 0;
    border-radius: 12px;
    overflow: hidden;
    background: #0a0a0b;
    box-shadow: 0 40px 80px -40px rgba(0,0,0,0.6);
  }
  .manifesto .portrait-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .manifesto .portrait-figure::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(28,28,30,0) 55%, rgba(28,28,30,0.75) 100%);
    pointer-events: none;
  }
  .manifesto .portrait-caption {
    position: absolute; bottom: 20px; left: 20px; right: 20px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.85);
  }
  .manifesto .portrait-caption .dot { color: var(--gold); }
  .manifesto .copy p { color: rgba(250,250,247,0.8); font-size: 17px; line-height: 1.65; margin: 0 0 18px; }
  .manifesto .copy p:first-of-type::first-letter {
    font-family: var(--f-display); font-size: 64px; line-height: 0.85;
    float: left; margin: 4px 12px -4px 0; font-weight: 400;
    color: var(--gold); font-variation-settings: "opsz" 144;
  }
  .manifesto .sig {
    margin-top: 32px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.15);
    font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em;
    color: rgba(250,250,247,0.55); text-transform: uppercase;
  }
  .manifesto .sig strong { color: var(--paper); font-weight: 500; }
  @media (max-width: 900px){
    .manifesto { padding: 96px 0; }
    .manifesto .grid { grid-template-columns: 1fr; gap: 48px; align-items: start; }
    .manifesto .left-col { gap: 40px; }
    .manifesto .portrait-figure { aspect-ratio: 3/4; min-height: 0; }
  }

  /* ============ TEAM AT WORK ============ */
  .taw { padding: 140px 0; }
  .taw-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: 80px; align-items: center; }
  .taw-copy h2 { font-size: clamp(36px, 4.4vw, 56px); margin-bottom: 24px; }
  .taw-copy h2 em { color: var(--gold); }
  .taw-copy .lead { color: var(--warm-grey); margin-bottom: 40px; }
  .taw-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; padding: 32px 0; border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .taw-stat .n { font-family: var(--f-display); font-size: clamp(40px, 4.5vw, 56px); line-height: 1; font-variation-settings: "opsz" 96; font-weight: 400; letter-spacing: -0.02em; }
  .taw-stat .n sup { font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .taw-stat .l { font-family: var(--f-sans); font-size: 13px; color: var(--warm-grey); margin-top: 6px; line-height: 1.5; }
  .taw-img-wrap {
    position: relative; aspect-ratio: 4/5; border-radius: 12px; overflow: hidden;
    background: var(--slate);
  }
  .taw-img-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .taw-caption {
    position: absolute; bottom: 16px; left: 16px; right: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.85);
    display: flex; justify-content: space-between;
  }
  .taw-caption .dot { color: var(--gold); }
  @media (max-width: 900px){ .taw { padding: 96px 0; } .taw-grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ PRINCIPLES (dark) ============ */
  .page-about .principles{ background: var(--slate); color: var(--paper); padding: 140px 0; }
  .page-about .principles .eyebrow{ color: var(--gold); }
  .page-about .principles .intro h2{ color: var(--paper); max-width: 720px; }
  .page-about .principles .intro h2 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-about .principles-grid{
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 0;
    margin-top: 80px; border-top: 1px solid rgba(250,250,247,0.15);
  }
  .principle {
    padding: 48px 48px 56px; border-right: 1px solid rgba(250,250,247,0.15);
    border-bottom: 1px solid rgba(250,250,247,0.15);
    position: relative;
  }
  .principle:nth-child(2n) { border-right: none; }
  .principle:nth-last-child(-n+2) { border-bottom: none; }
  .principle .num {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase; margin-bottom: 24px; display: block;
  }
  .principle h3 { color: var(--paper); margin-bottom: 14px; max-width: 380px; }
  .principle p { color: rgba(250,250,247,0.7); font-size: 15px; line-height: 1.6; margin: 0; max-width: 420px; }
  @media (max-width: 900px){
    .page-about .principles{ padding: 96px 0; }
    .page-about .principles-grid{ grid-template-columns: 1fr; }
    .principle { border-right: none !important; padding: 36px 0; }
    .principle:nth-last-child(1) { border-bottom: none; }
  }

  /* ============ LEADERSHIP ============ */
  .leaders { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .leaders .head { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: end; margin-bottom: 64px; }
  .leaders .head h2 em { color: var(--gold); }
  .leaders .head p { color: var(--warm-grey); font-size: 16px; margin: 0; max-width: 440px; }
  .leader-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px; }
  .leader { }
  .leader .portrait {
    aspect-ratio: 4/5; background: var(--paper); border: 1px solid var(--soft-line);
    border-radius: 6px; display: grid; place-items: center;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 20px;
    background-image: repeating-linear-gradient(135deg, transparent 0 14px, rgba(15,15,16,0.03) 14px 15px);
  }
  .leader h3 { font-size: 22px; margin-bottom: 4px; }
  .leader .role { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--gold); text-transform: uppercase; margin-bottom: 12px; }
  .leader p { font-size: 14px; color: var(--warm-grey); line-height: 1.55; margin: 0; }
  @media (max-width: 900px){ .leaders { padding: 96px 0; } .leaders .head { grid-template-columns: 1fr; gap: 32px; margin-bottom: 48px; } .leader-grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ INSIDE THE HUB (single editorial image) ============ */
  .hub { padding: 140px 0; background: var(--paper); }
  .hub-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    gap: 80px;
    align-items: center;
  }
  .hub-copy h2 { font-size: clamp(34px, 4vw, 52px); margin-bottom: 24px; }
  .hub-copy h2 em { color: var(--gold); }
  .hub-copy p { color: var(--warm-grey); font-size: 17px; line-height: 1.65; max-width: 460px; margin-bottom: 40px; }
  .hub-facts {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    border-top: 1px solid var(--soft-line);
  }
  .hub-fact {
    padding: 20px 0; border-bottom: 1px solid var(--soft-line);
    display: grid; grid-template-columns: 110px 1fr; gap: 16px; align-items: baseline;
  }
  .hub-fact:nth-child(2n-1) { padding-right: 16px; border-right: 1px solid var(--soft-line); }
  .hub-fact:nth-child(2n) { padding-left: 24px; }
  .hub-fact .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--warm-grey); text-transform: uppercase; }
  .hub-fact .v { font-family: var(--f-sans); font-size: 13px; font-weight: 500; color: var(--ink); line-height: 1.4; }

  .hub-figure {
    position: relative;
    margin: 0;
    aspect-ratio: 4/5;
    border-radius: 12px;
    overflow: hidden;
    background: var(--slate);
    box-shadow: 0 40px 80px -32px rgba(15,15,16,0.25);
  }
  .hub-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .hub-label {
    position: absolute; top: 20px; left: 20px;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.55); backdrop-filter: blur(8px);
    padding: 8px 12px; border-radius: 4px;
    white-space: nowrap;
    display: inline-flex; align-items: center; gap: 10px;
  }
  .hub-label .live { color: var(--gold); letter-spacing: 0.1em; }
  .hub-cap {
    position: absolute; bottom: 20px; left: 20px; right: 20px;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.85);
  }
  @media (max-width: 900px){
    .hub { padding: 96px 0; }
    .hub-grid { grid-template-columns: 1fr; gap: 48px; }
    .hub-fact:nth-child(2n-1) { padding-right: 0; border-right: none; }
    .hub-fact:nth-child(2n) { padding-left: 0; }
  }

  /* ============ BY THE NUMBERS (slate) ============ */
  .by-numbers { background: var(--slate); color: var(--paper); padding: 120px 0; }
  .by-numbers .head { max-width: 680px; margin-bottom: 64px; }
  .by-numbers .eyebrow { color: var(--gold); }
  .by-numbers h2 { color: var(--paper); }
  .by-numbers h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .numbers-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
  .n-cell { padding: 48px 32px; border-right: 1px solid rgba(250,250,247,0.15); }
  .n-cell:last-child { border-right: none; }
  .n-cell .n { font-family: var(--f-display); font-size: clamp(44px, 4.8vw, 64px); line-height: 1; font-weight: 400; font-variation-settings: "opsz" 96; letter-spacing: -0.02em; margin-bottom: 16px; }
  .n-cell .n sup { font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .n-cell .l { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; margin-bottom: 10px; }
  .n-cell .d { font-size: 13px; color: rgba(250,250,247,0.8); line-height: 1.55; margin: 0; }
  @media (max-width: 900px){
    .by-numbers { padding: 96px 0; }
    .numbers-grid { grid-template-columns: 1fr 1fr; }
    .n-cell { border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
    .n-cell:nth-child(2n) { border-right: none; }
    .n-cell:nth-last-child(-n+2) { border-bottom: none; }
  }

  /* ============ SOCIAL IMPACT ============ */
  .impact { padding: 140px 0; }
  .impact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
  .impact-copy h2 em { color: var(--gold); }
  .impact-copy .lead { color: var(--warm-grey); margin-top: 24px; }
  .impact-rows { display: grid; gap: 0; border-top: 1px solid var(--soft-line); }
  .impact-row {
    display: grid; grid-template-columns: auto 1fr auto; gap: 32px; align-items: baseline;
    padding: 28px 0; border-bottom: 1px solid var(--soft-line);
  }
  .impact-row .idx { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--gold); text-transform: uppercase; width: 40px; }
  .impact-row .t h4 { font-family: var(--f-sans); font-weight: 600; font-size: 16px; letter-spacing: 0; margin: 0 0 6px; }
  .impact-row .t p { font-size: 14px; color: var(--warm-grey); margin: 0; line-height: 1.55; max-width: 420px; }
  .impact-row .v { font-family: var(--f-display); font-size: 28px; font-variation-settings: "opsz" 48; font-weight: 400; line-height: 1; }
  .sdg-row { margin-top: 24px; display: flex; gap: 8px; flex-wrap: wrap; }
  .sdg-tag { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; padding: 5px 10px; border: 1px solid var(--soft-line); border-radius: 3px; color: var(--warm-grey); text-transform: uppercase; }
  @media (max-width: 900px){ .impact { padding: 96px 0; } .impact-grid { grid-template-columns: 1fr; gap: 48px; } .impact-row { grid-template-columns: auto 1fr; } .impact-row .v { grid-column: 1 / -1; margin-top: 4px; } }

  /* ============ JOIN (ink CTA) ============ */
  .join { background: var(--ink); color: var(--paper); padding: 160px 0; }
  .join .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .join h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 64px); }
  .join h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .join .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; }
  .join-paths { display: grid; gap: 16px; }
  .j-path {
    padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: transparent; color: var(--paper); transition: background .2s ease, color .2s ease, border-color .2s ease;
  }
  .j-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .j-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .j-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .j-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .j-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .j-path .a { font-size: 22px; }
  @media (max-width: 900px){ .join { padding: 96px 0; } .join .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ FOOTER ============ */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px){ .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ============ GOLD NUMBER ACCENT ============ */
  .taw-stat .n { color: var(--gold); }
  .about-meta .m .v { color: var(--gold); }
  .impact-row .v { color: var(--gold); }


  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Back-Office Support.html  (.page-back-office) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--f-sans); background: var(--paper); color: var(--ink);
    -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
    font-size: 16px; line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin: 0 0 20px; }
  h1, h2, h3, h4 { font-family: var(--f-display); font-weight: 400; letter-spacing: -0.015em; margin: 0; color: var(--ink); text-wrap: balance; }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-back-office .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons */
  .btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-sans); font-weight: 500; font-size: 15px; letter-spacing: 0.01em; padding: 16px 32px; border-radius: 6px; transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease; cursor: pointer; border: 1px solid transparent; }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }
  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* HERO (reused) */
  .cat-hero { padding: 120px 0 96px; border-bottom: 1px solid var(--soft-line); }
  .cat-hero .breadcrumb { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px; }
  .cat-hero .breadcrumb a { color: var(--warm-grey); }
  .cat-hero .breadcrumb a:hover { color: var(--gold); }
  .cat-hero .breadcrumb span.curr { color: var(--ink); }
  .cat-hero h1 { max-width: 980px; font-size: clamp(44px, 6vw, 78px); }
  .cat-hero .lead { max-width: 720px; margin-top: 32px; font-size: 22px; }
  .cat-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .cat-hero .trust-chip { margin-top: 28px; display: inline-flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: 0.04em; color: var(--warm-grey); font-family: var(--f-mono); }
  .cat-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
  .hero-meta { margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--soft-line); display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
  .hero-meta-item { padding: 0 20px 0 0; border-right: 1px solid var(--soft-line); }
  .hero-meta-item:last-child { border-right: none; padding-right: 0; }
  .hero-meta-item:not(:first-child) { padding-left: 20px; }
  .hero-meta-item .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .hero-meta-item .v { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; letter-spacing: -0.01em; font-variation-settings: "opsz" 48; }
  .hero-meta-item .v small { display: block; font-family: var(--f-sans); font-weight: 400; font-size: 13px; color: var(--warm-grey); margin-top: 4px; letter-spacing: 0; }
  @media (max-width: 900px) {
    .cat-hero { padding: 80px 0 72px; }
    .hero-meta { grid-template-columns: 1fr 1fr; }
    .hero-meta-item { padding: 16px 16px 16px 0; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
    .hero-meta-item:nth-child(2n) { border-right: none; padding-right: 0; }
    .hero-meta-item:nth-last-child(-n+2) { border-bottom: none; }
    .hero-meta-item:not(:first-child) { padding-left: 16px; }
    .hero-meta-item:nth-child(odd) { padding-left: 0; }
  }

  /* OM STRIP (reused) */
  .om-strip { padding: 96px 0; background: var(--slate); color: var(--paper); }
  .om-strip .eyebrow { color: var(--gold); }
  .om-grid { display: grid; grid-template-columns: 0.9fr 2.1fr; gap: 64px; align-items: start; }
  .om-grid .head h3 { color: var(--paper); font-size: clamp(24px, 2.4vw, 30px); max-width: 420px; }
  .om-grid .head h3 em { color: var(--gold); }
  .om-principles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(250,250,247,0.15); }
  .om-principle { padding: 24px 20px 24px 0; border-right: 1px solid rgba(250,250,247,0.15); display: grid; grid-template-rows: auto 1fr; gap: 10px; }
  .om-principle:last-child { border-right: none; padding-right: 0; }
  .om-principle:not(:first-child) { padding-left: 20px; }
  .om-principle .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .om-principle .v { font-family: var(--f-sans); font-weight: 500; font-size: 15px; color: var(--paper); line-height: 1.4; }
  @media (max-width: 900px) {
    .om-grid { grid-template-columns: 1fr; gap: 32px; }
    .om-principles { grid-template-columns: 1fr 1fr; }
    .om-principle { border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 20px; }
    .om-principle:nth-child(2n) { border-right: none; }
    .om-principle:nth-last-child(-n+2) { border-bottom: none; }
    .om-principle:not(:first-child) { padding-left: 20px; }
  }

  /* SUB-SERVICE FEATURE (new: one-card deep card) */
  .subservice { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .subservice .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 56px; }
  .subservice h2 em { color: var(--gold); }
  .subservice .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 460px; }
  .ss-card {
    display: grid; grid-template-columns: 1.2fr 1fr;
    border: 1px solid var(--ink);
    background: var(--paper);
    overflow: hidden;
  }
  .ss-card:hover .ss-arrow { transform: translate(6px, -6px); color: var(--gold); }
  .ss-card:hover .ss-num { color: var(--gold); }
  .ss-left { padding: 56px 56px 48px; border-right: 1px solid var(--soft-line); display: grid; grid-template-rows: auto auto auto 1fr auto; gap: 20px; }
  .ss-left .row { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; }
  .ss-num { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.12em; color: var(--warm-grey); text-transform: uppercase; transition: color .2s ease; }
  .ss-arrow { font-family: var(--f-display); font-style: italic; font-weight: 300; font-size: 36px; line-height: 1; transition: transform .25s ease, color .25s ease; }
  .ss-left h3 { font-size: clamp(30px, 3.4vw, 44px); line-height: 1.02; max-width: 420px; }
  .ss-left h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .ss-left p { font-size: 16px; color: var(--warm-grey); margin: 0; max-width: 460px; line-height: 1.6; }
  .ss-link { margin-top: 12px; font-family: var(--f-sans); font-weight: 500; font-size: 14px; color: var(--ink); display: inline-flex; gap: 8px; align-items: center; }
  .ss-link:hover { color: var(--gold); }
  .ss-right { padding: 56px; background: var(--white); display: grid; grid-template-rows: auto 1fr; gap: 20px; }
  .ss-right .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .ss-right ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
  .ss-right li { font-family: var(--f-mono); font-size: 13px; line-height: 1.5; letter-spacing: 0.01em; color: var(--ink); display: grid; grid-template-columns: 28px 1fr; gap: 10px; padding-bottom: 14px; border-bottom: 1px solid var(--soft-line); }
  .ss-right li:last-child { border-bottom: none; padding-bottom: 0; }
  .ss-right li .idx { color: var(--gold); font-size: 11px; letter-spacing: 0.1em; padding-top: 2px; }
  .ss-footnote { margin-top: 28px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--warm-grey); text-transform: uppercase; display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
  .ss-footnote .sep { color: var(--soft-line); }
  @media (max-width: 900px) {
    .subservice { padding: 96px 0; }
    .subservice .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .ss-card { grid-template-columns: 1fr; }
    .ss-left, .ss-right { padding: 36px 28px; border-right: none; }
    .ss-left { border-bottom: 1px solid var(--soft-line); }
  }

  /* USE CASES (new: 6-card use case grid) */
  .uses { padding: 140px 0; }
  .uses .head { max-width: 760px; margin-bottom: 64px; }
  .uses h2 em { color: var(--gold); }
  .uses .head p { color: var(--warm-grey); font-size: 18px; margin-top: 20px; }
  .use-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--ink); border-left: 1px solid var(--soft-line);
  }
  .use-cell {
    padding: 40px 32px 36px;
    border-right: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
    background: var(--paper);
    display: grid; grid-template-rows: auto auto 1fr auto; gap: 14px;
    transition: background .2s ease;
  }
  .use-cell:hover { background: var(--white); }
  .use-cell:nth-child(6n+1), .use-cell:nth-child(6n+3), .use-cell:nth-child(6n+5) { background: var(--white); }
  .use-cell:nth-child(6n+1):hover, .use-cell:nth-child(6n+3):hover, .use-cell:nth-child(6n+5):hover { background: var(--paper); }
  .use-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .use-cell h3 { font-size: 24px; line-height: 1.1; margin: 0; max-width: 280px; }
  .use-cell h3 em { color: var(--gold); font-weight: 300; font-style: italic; }
  .use-cell p { font-size: 13.5px; line-height: 1.6; color: var(--warm-grey); margin: 0; }
  .use-cell .out { margin-top: 14px; padding-top: 14px; border-top: 1px dashed var(--soft-line); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--ink); text-transform: none; }
  .use-cell .out b { font-weight: 500; color: var(--gold); letter-spacing: 0.08em; text-transform: uppercase; display: block; font-size: 9.5px; margin-bottom: 4px; }
  @media (max-width: 1100px) and (min-width: 901px) { .use-grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 900px) { .uses { padding: 96px 0; } .use-grid { grid-template-columns: 1fr; } }

  /* HOW WE DELIVER (new: 4-step editorial timeline with rail) */
  .deliver { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .deliver .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .deliver h2 em { color: var(--gold); }
  .deliver .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }
  .deliver-rail {
    position: relative;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid var(--ink);
  }
  .deliver-rail::before {
    content: ""; position: absolute; top: -5px; left: 0;
    height: 9px; width: 9px; background: var(--gold); border-radius: 50%;
  }
  .deliver-rail::after {
    content: ""; position: absolute; top: -5px; right: 0;
    height: 9px; width: 9px; border: 1px solid var(--ink); background: var(--paper); border-radius: 50%;
  }
  .deliver-step {
    position: relative;
    padding: 40px 28px 0 0;
    border-right: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto auto auto auto; gap: 14px;
  }
  .deliver-step:last-child { border-right: none; }
  .deliver-step:not(:first-child) { padding-left: 28px; }
  .deliver-step::before {
    content: ""; position: absolute; top: -5px; left: 0;
    height: 9px; width: 1px; background: var(--ink);
  }
  .deliver-step:first-child::before { display: none; }
  .deliver-step .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .deliver-step h4 { font-family: var(--f-display); font-size: 24px; line-height: 1.1; font-weight: 400; margin: 0; font-variation-settings: "opsz" 48; }
  .deliver-step h4 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .deliver-step p { font-size: 14px; line-height: 1.6; color: var(--warm-grey); margin: 0; }
  .deliver-step .out { font-family: var(--f-mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--ink); text-transform: uppercase; padding-top: 10px; border-top: 1px dashed var(--soft-line); margin-top: 4px; }
  .deliver-step .out b { color: var(--gold); font-weight: 500; }
  @media (max-width: 900px) {
    .deliver { padding: 96px 0; }
    .deliver .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .deliver-rail { grid-template-columns: 1fr; border-top: none; }
    .deliver-rail::before, .deliver-rail::after { display: none; }
    .deliver-step { border-right: none; border-bottom: 1px solid var(--soft-line); padding: 32px 0; border-top: 1px solid var(--ink); }
    .deliver-step:first-child { border-top: 1px solid var(--ink); }
    .deliver-step:last-child { border-bottom: none; }
    .deliver-step:not(:first-child) { padding-left: 0; }
    .deliver-step::before { display: none; }
  }

  /* QUALITY & SECURITY (new: two-column with image) */
  .nonneg { padding: 140px 0; background: var(--paper); }
  .nonneg .head { max-width: 760px; margin-bottom: 64px; }
  .nonneg h2 em { color: var(--gold); }
  .nonneg .head p { color: var(--warm-grey); font-size: 18px; margin-top: 20px; }
  .nonneg-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 0; border-top: 1px solid var(--ink); }
  .nonneg-col { padding: 48px 48px 48px 0; border-right: 1px solid var(--soft-line); }
  .nonneg-col:last-child { border-right: none; padding-right: 0; padding-left: 48px; }
  .nonneg-col .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 14px; }
  .nonneg-col h3 { font-size: clamp(26px, 2.6vw, 34px); margin-bottom: 18px; max-width: 340px; }
  .nonneg-col h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .nonneg-col > p { font-size: 15px; line-height: 1.65; color: var(--warm-grey); margin: 0 0 24px; max-width: 440px; }
  .nonneg-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 0; border-top: 1px solid var(--soft-line); }
  .nonneg-list li { padding: 18px 0; border-bottom: 1px solid var(--soft-line); display: grid; grid-template-columns: 24px 1fr; gap: 12px; font-size: 14px; line-height: 1.5; }
  .nonneg-list li:last-child { border-bottom: none; }
  .nonneg-list li::before { content: "—"; color: var(--gold); font-family: var(--f-mono); }
  .nonneg-list li b { font-weight: 500; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink); display: block; margin-bottom: 4px; }
  .nonneg-figure { margin-top: 48px; }
  .nonneg-figure img { width: 100%; height: auto; object-fit: cover; aspect-ratio: 4 / 3; filter: saturate(0.85) contrast(1.02); }
  .plate-caption { margin-top: 14px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--warm-grey); text-transform: uppercase; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
  .plate-caption .dot { color: var(--gold); }
  @media (max-width: 900px) {
    .nonneg { padding: 96px 0; }
    .nonneg-grid { grid-template-columns: 1fr; }
    .nonneg-col { padding: 36px 0; border-right: none; border-bottom: 1px solid var(--soft-line); }
    .nonneg-col:last-child { border-bottom: none; padding-left: 0; padding-bottom: 0; }
  }

  /* PROOF (reused) */
  .page-back-office .proof{ background: var(--slate); color: var(--paper); padding: 140px 0; }
  .page-back-office .proof .head{ max-width: 720px; margin-bottom: 72px; }
  .page-back-office .proof .eyebrow{ color: var(--gold); }
  .page-back-office .proof h2{ color: var(--paper); }
  .page-back-office .proof h2 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-back-office .proof-grid{ display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
  .page-back-office .proof-cell{ padding: 48px 32px 48px 0; border-right: 1px solid rgba(250,250,247,0.15); }
  .page-back-office .proof-cell:last-child{ border-right: none; padding-right: 0; }
  .page-back-office .proof-cell:not(:first-child){ padding-left: 32px; }
  .page-back-office .proof-cell .n{ font-family: var(--f-display); font-size: clamp(44px, 4.8vw, 64px); line-height: 1; font-variation-settings: "opsz" 96; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 16px; color: var(--paper); }
  .page-back-office .proof-cell .n sup{ font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .page-back-office .proof-cell .l{ font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; margin-bottom: 10px; }
  .page-back-office .proof-cell .d{ font-size: 13px; color: rgba(250,250,247,0.8); line-height: 1.55; margin: 0; }
  .page-back-office .proof-foot{ margin-top: 40px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; display: flex; gap: 24px; flex-wrap: wrap; align-items: center; }
  .page-back-office .proof-foot .sep{ color: rgba(250,250,247,0.35); }
  .page-back-office .proof-foot .g{ color: var(--gold); }
  @media (max-width: 900px) {
    .page-back-office .proof{ padding: 96px 0; }
    .page-back-office .proof-grid{ grid-template-columns: 1fr 1fr; }
    .page-back-office .proof-cell{ border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 32px 20px; }
    .page-back-office .proof-cell:nth-child(2n){ border-right: none; }
    .page-back-office .proof-cell:nth-last-child(-n+2){ border-bottom: none; }
    .page-back-office .proof-cell:not(:first-child){ padding-left: 20px; }
  }

  /* DISCOVERY (reused) */
  .discovery { background: var(--ink); color: var(--paper); padding: 140px 0; }
  .discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 60px); }
  .discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
  .discovery .eyebrow { color: var(--gold); }
  .d-paths { display: grid; gap: 16px; }
  .d-path { padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px; background: transparent; color: var(--paper); transition: background .2s ease, color .2s ease, border-color .2s ease; }
  .d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .d-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .d-path .a { font-size: 22px; }
  @media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* RELATED (new: 4-card grid to other categories) */
  .related { padding: 140px 0; background: var(--paper); border-top: 1px solid var(--soft-line); }
  .related .head { margin-bottom: 56px; max-width: 680px; }
  .related h2 { font-size: clamp(28px, 2.6vw, 36px); }
  .related h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .rel-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--ink); }
  .rel-card { display: block; padding: 32px 24px 28px 0; border-right: 1px solid var(--soft-line); transition: background .2s ease; }
  .rel-card:not(:first-child) { padding-left: 24px; }
  .rel-card:last-child { border-right: none; }
  .rel-card:hover { background: var(--white); }
  .rel-card:hover .rel-arrow { transform: translate(4px, -4px); color: var(--gold); }
  .rel-card .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 18px; }
  .rel-card .row { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 14px; }
  .rel-card h3 { font-size: 22px; line-height: 1.1; max-width: 220px; }
  .rel-card h3 em { color: var(--gold); font-weight: 300; font-style: italic; }
  .rel-card p { font-size: 13px; line-height: 1.55; color: var(--warm-grey); margin: 0; max-width: 240px; }
  .rel-arrow { font-family: var(--f-display); font-style: italic; font-weight: 300; font-size: 24px; color: var(--ink); transition: transform .25s ease, color .25s ease; }
  @media (max-width: 900px) {
    .related { padding: 96px 0; }
    .rel-grid { grid-template-columns: 1fr 1fr; }
    .rel-card { border-bottom: 1px solid var(--soft-line); padding: 24px 16px 24px 0; }
    .rel-card:nth-child(2n) { border-right: none; padding-right: 0; }
    .rel-card:not(:first-child) { padding-left: 0; }
    .rel-card:nth-child(2n) { padding-left: 16px; }
    .rel-card:nth-last-child(-n+2) { border-bottom: none; }
  }

  /* FINAL CTA (reused) */
  .page-back-office .final-cta{ padding: 120px 0; background: var(--paper); border-top: 1px solid var(--soft-line); }
  .page-back-office .final-cta .row{ display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; }
  .page-back-office .final-cta h3{ font-size: clamp(28px, 3vw, 38px); max-width: 680px; }
  .page-back-office .final-cta h3 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-back-office .final-cta .actions{ display: flex; gap: 12px; flex-wrap: wrap; }
  @media (max-width: 900px) { .page-back-office .final-cta{ padding: 80px 0; } .page-back-office .final-cta .row{ grid-template-columns: 1fr; gap: 24px; } }

  /* FOOTER (reused) */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* HANDOFF (reused) */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note { margin-top: 48px; padding: 24px 28px; background: var(--ink); color: var(--paper); border-radius: 10px; font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em; }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  .hero-meta-item .v { color: var(--gold); }

  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Contact.html  (.page-contact) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px; line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow {
    font-family: var(--f-sans); font-weight: 600;
    font-size: 12px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display); font-weight: 400;
    letter-spacing: -0.015em; margin: 0; color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(32px, 3.6vw, 48px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; color: var(--gold); }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-contact .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons */
  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer; border: 1px solid transparent;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* ============ HERO (compact — form above fold is the priority) ============ */
  .c-hero { padding: 88px 0 64px; border-bottom: 1px solid var(--soft-line); }
  .c-hero .breadcrumb {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 28px;
  }
  .c-hero .breadcrumb a { color: var(--warm-grey); }
  .c-hero .breadcrumb a:hover { color: var(--gold); }
  .c-hero .breadcrumb span.curr { color: var(--ink); }

  .c-hero-grid {
    display: grid; grid-template-columns: 1.35fr 1fr; gap: 72px; align-items: end;
  }
  .c-hero h1 { max-width: 720px; font-size: clamp(40px, 5.2vw, 68px); }
  .c-hero .lead { max-width: 540px; margin-top: 24px; font-size: 19px; }
  .c-hero .trust-chip {
    margin-top: 28px;
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; letter-spacing: 0.04em;
    color: var(--warm-grey); font-family: var(--f-mono);
  }
  .c-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

  /* Response-time card on the right */
  .resp-card {
    border: 1px solid var(--soft-line); border-radius: 10px;
    padding: 28px; background: var(--white);
    display: grid; gap: 18px;
  }
  .resp-card .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .resp-card .row { display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: baseline; padding: 14px 0; border-bottom: 1px solid var(--soft-line); }
  .resp-card .row:last-child { border-bottom: none; padding-bottom: 0; }
  .resp-card .row:first-of-type { padding-top: 0; }
  .resp-card .row .n {
    font-family: var(--f-display); font-weight: 400; font-size: 30px; line-height: 1;
    font-variation-settings: "opsz" 96; letter-spacing: -0.02em; color: var(--ink);
    min-width: 110px;
  }
  .resp-card .row .n sup { font-size: 0.5em; color: var(--gold); vertical-align: top; margin-left: 2px; font-family: var(--f-sans); font-weight: 500; letter-spacing: 0.02em; }
  .resp-card .row .v { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em; color: var(--warm-grey); text-transform: uppercase; line-height: 1.5; }

  @media (max-width: 900px) {
    .c-hero { padding: 64px 0 56px; }
    .c-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  }

  /* ============ ROUTER (3 paths, paper) ============ */
  .router { padding: 112px 0; background: var(--paper); }
  .router .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 56px; }
  .router .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 420px; }
  .router h2 { max-width: 560px; }

  .router-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--ink);
  }
  .router-card {
    padding: 40px 32px 32px 0;
    border-right: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto auto 1fr auto; gap: 18px;
    transition: background .2s ease;
  }
  .router-card:last-child { border-right: none; padding-right: 0; }
  .router-card:not(:first-child) { padding-left: 32px; }
  .router-card:hover { background: var(--white); }

  .router-card .num {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase;
  }
  .router-card h3 {
    font-size: 28px; line-height: 1.15; margin: 0; max-width: 260px;
  }
  .router-card h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .router-card p {
    font-size: 14.5px; color: var(--warm-grey); line-height: 1.6;
    margin: 0; max-width: 320px;
  }
  .router-card .go {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--ink);
    display: inline-flex; align-items: center; gap: 8px;
    padding-top: 16px; border-top: 1px solid var(--soft-line);
    transition: color .2s ease;
  }
  .router-card:hover .go { color: var(--gold); }
  .router-card .go .a { transition: transform .2s ease; display: inline-block; }
  .router-card:hover .go .a { transform: translateX(3px); }

  @media (max-width: 900px) {
    .router { padding: 80px 0; }
    .router .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .router-grid { grid-template-columns: 1fr; }
    .router-card { border-right: none; padding: 32px 0 !important; }
    .router-card:last-child { border-bottom: none; }
  }

  /* ============ BRIEF FORM (the centerpiece — editorial, paper -> white panel) ============ */
  .brief { padding: 140px 0; background: var(--slate); color: var(--paper); }
  .brief .eyebrow { color: var(--gold); }
  .brief-head {
    max-width: 760px; margin-bottom: 64px;
  }
  .brief-head h2 { color: var(--paper); }
  .brief-head h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .brief-head p { color: rgba(250,250,247,0.7); font-size: 17px; margin-top: 18px; max-width: 560px; }

  .brief-panel {
    background: var(--paper); color: var(--ink);
    border-radius: 14px; padding: 72px 80px;
    box-shadow: 0 40px 80px -32px rgba(0,0,0,0.4);
  }

  .brief-meta {
    display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
    padding-bottom: 32px; margin-bottom: 44px; border-bottom: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
    color: var(--warm-grey); text-transform: uppercase;
  }
  .brief-meta .on { color: var(--ink); }
  .brief-meta .on .dot { color: var(--gold); }

  form.brief-form { display: grid; gap: 32px; }
  .fld { display: grid; gap: 10px; }
  .fld-row { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
  .fld label {
    font-family: var(--f-display); font-weight: 400; font-size: 19px;
    font-variation-settings: "opsz" 48; letter-spacing: -0.005em;
    color: var(--ink); line-height: 1.3;
  }
  .fld label em { color: var(--gold); font-style: italic; font-weight: 300; }
  .fld .hint { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--warm-grey); text-transform: uppercase; }

  .fld input[type="text"],
  .fld input[type="email"],
  .fld select,
  .fld textarea {
    width: 100%;
    font-family: var(--f-sans); font-size: 16px; color: var(--ink);
    background: transparent;
    border: none;
    border-bottom: 1px solid var(--soft-line);
    padding: 12px 0 14px;
    outline: none;
    transition: border-color .2s ease;
    border-radius: 0;
    -webkit-appearance: none; -moz-appearance: none; appearance: none;
  }
  .fld input[type="text"]:focus,
  .fld input[type="email"]:focus,
  .fld select:focus,
  .fld textarea:focus {
    border-bottom-color: var(--ink);
  }
  .fld input::placeholder,
  .fld textarea::placeholder { color: var(--warm-grey); opacity: 0.65; }

  .fld select {
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5L6 6.5L11 1.5' stroke='%230F0F10' stroke-width='1.25'/></svg>");
    background-repeat: no-repeat;
    background-position: right 4px center;
    padding-right: 28px;
  }

  .fld textarea {
    min-height: 140px; resize: vertical; line-height: 1.55;
  }

  .char-count {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    color: var(--warm-grey); text-transform: uppercase; text-align: right;
  }

  /* File upload */
  .file-drop {
    border: 1px dashed var(--soft-line); border-radius: 8px;
    padding: 22px 24px;
    display: flex; align-items: center; justify-content: space-between; gap: 16px;
    cursor: pointer;
    transition: border-color .2s ease, background .2s ease;
    background: var(--white);
  }
  .file-drop:hover { border-color: var(--ink); }
  .file-drop input[type="file"] { position: absolute; opacity: 0; pointer-events: none; }
  .file-drop .fd-left { display: grid; gap: 4px; }
  .file-drop .fd-title { font-family: var(--f-sans); font-weight: 500; font-size: 14px; color: var(--ink); }
  .file-drop .fd-sub { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--warm-grey); text-transform: uppercase; }
  .file-drop .fd-icon {
    width: 36px; height: 36px; border-radius: 50%;
    background: var(--ink); color: var(--paper);
    display: grid; place-items: center; font-size: 16px; flex-shrink: 0;
  }
  .file-drop.has-file { border-style: solid; border-color: var(--gold); background: var(--paper); }
  .file-drop.has-file .fd-icon { background: var(--gold); color: var(--ink); }

  /* Submit bar */
  .submit-bar {
    margin-top: 24px; padding-top: 32px; border-top: 1px solid var(--soft-line);
    display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center;
  }
  .submit-bar .fine {
    font-family: var(--f-sans); font-size: 13px; color: var(--warm-grey); line-height: 1.55;
    max-width: 520px; margin: 0;
  }
  .submit-bar .fine strong { color: var(--ink); font-weight: 500; }

  @media (max-width: 900px) {
    .brief { padding: 80px 0; }
    .brief-panel { padding: 48px 28px; border-radius: 10px; }
    .fld-row { grid-template-columns: 1fr; gap: 32px; }
    .submit-bar { grid-template-columns: 1fr; gap: 20px; }
  }

  /* ============ NEXT (white, horizontal 3-step flow) ============ */
  .next { background: var(--white); padding: 140px 0; border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .next .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .next h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .next .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }

  .next-track { position: relative; padding: 0 0 8px; }
  .next-rail { position: absolute; top: 44px; left: 0; right: 0; height: 1px; background: var(--ink); }
  .next-rail::after {
    content: ""; position: absolute; right: -1px; top: -4px;
    border-left: 8px solid var(--ink);
    border-top: 4px solid transparent; border-bottom: 4px solid transparent;
  }
  .next-stages { display: grid; grid-template-columns: repeat(3, 1fr); position: relative; z-index: 1; }
  .next-stage { padding: 0 32px 0 0; position: relative; }
  .next-stage:last-child { padding-right: 0; }
  .next-stage:not(:first-child) { padding-left: 32px; border-left: 1px solid var(--soft-line); }
  .next-stage .node {
    display: block; width: 24px; height: 24px; border-radius: 50%;
    background: var(--gold); border: 1.5px solid var(--gold);
    margin: 32px 0 24px;
    position: relative; z-index: 2;
  }
  .next-stage .when {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase; margin-bottom: 12px;
  }
  .next-stage h3 { font-size: 24px; margin-bottom: 14px; }
  .next-stage h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .next-stage p { font-size: 14.5px; color: var(--warm-grey); line-height: 1.6; margin: 0; max-width: 340px; }

  @media (max-width: 900px) {
    .next { padding: 96px 0; }
    .next .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
    .next-rail { display: none; }
    .next-stages { grid-template-columns: 1fr; }
    .next-stage { padding: 24px 0; border-left: none; border-top: 1px solid var(--soft-line); }
    .next-stage:first-child { border-top: 1px solid var(--ink); }
    .next-stage .node { margin: 20px 0; }
  }

  /* ============ DIRECT CONTACT (paper, 2 column) ============ */
  .direct { padding: 140px 0; background: var(--paper); }
  .direct .head { max-width: 760px; margin-bottom: 64px; }
  .direct h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .direct .head p { color: var(--warm-grey); font-size: 17px; margin-top: 18px; max-width: 520px; }

  .direct-grid {
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 72px;
    align-items: start;
  }

  .dir-col { display: grid; gap: 0; }
  .dir-col h3 {
    font-size: 26px; margin: 0 0 28px; padding-bottom: 16px;
    border-bottom: 1px solid var(--ink);
  }
  .dir-col h3 em { color: var(--gold); font-style: italic; font-weight: 300; }

  .dir-row {
    padding: 24px 0; border-bottom: 1px solid var(--soft-line);
    display: grid; grid-template-columns: 130px 1fr auto; gap: 24px; align-items: center;
  }
  .dir-row:last-child { border-bottom: none; }
  .dir-row .k {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase;
  }
  .dir-row .v {
    font-family: var(--f-display); font-weight: 400; font-size: 18px;
    font-variation-settings: "opsz" 48; letter-spacing: -0.01em;
    color: var(--ink);
  }
  .dir-row .v a { border-bottom: 1px solid transparent; transition: border-color .2s ease, color .2s ease; }
  .dir-row .v a:hover { color: var(--gold); border-bottom-color: var(--gold); }
  .dir-row .go {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase;
  }

  /* Office column — map placeholder + details */
  .map-box {
    position: relative; aspect-ratio: 4/3; border-radius: 10px; overflow: hidden;
    background: var(--slate);
    margin-bottom: 28px;
  }
  .map-svg { width: 100%; height: 100%; display: block; }
  .map-box .band-label {
    position: absolute; top: 16px; left: 16px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 6px 10px; border-radius: 3px;
  }
  .map-box .band-cap {
    position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .map-box .band-cap .dot { color: var(--gold); }

  .office-meta { display: grid; gap: 0; }
  .office-meta .or { padding: 16px 0; border-bottom: 1px solid var(--soft-line); display: grid; grid-template-columns: 130px 1fr; gap: 24px; align-items: baseline; }
  .office-meta .or:last-child { border-bottom: none; }
  .office-meta .or .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .office-meta .or .v { font-family: var(--f-sans); font-size: 15px; color: var(--ink); line-height: 1.55; }

  @media (max-width: 900px) {
    .direct { padding: 96px 0; }
    .direct-grid { grid-template-columns: 1fr; gap: 56px; }
  }

  /* ============ TRUST BAND (slate) ============ */
  .trust-band { background: var(--slate); color: var(--paper); padding: 64px 0; }
  .tb-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  }
  .tb-cell {
    padding: 8px 28px 8px 0;
    border-right: 1px solid rgba(250,250,247,0.15);
    display: grid; grid-template-rows: auto auto; gap: 8px; align-content: center;
  }
  .tb-cell:last-child { border-right: none; padding-right: 0; }
  .tb-cell:not(:first-child) { padding-left: 28px; }
  .tb-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .tb-cell .v {
    font-family: var(--f-display); font-weight: 400; font-size: 19px; line-height: 1.3;
    font-variation-settings: "opsz" 48; letter-spacing: -0.005em; color: var(--paper);
  }
  .tb-cell .v em { color: var(--gold); font-style: italic; font-weight: 300; }
  .tb-cell .s { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: rgba(250,250,247,0.55); text-transform: uppercase; margin-top: 4px; }

  @media (max-width: 900px) {
    .tb-grid { grid-template-columns: 1fr 1fr; }
    .tb-cell { padding: 20px 20px 20px 0; border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
    .tb-cell:nth-child(2n) { border-right: none; }
    .tb-cell:nth-last-child(-n+2) { border-bottom: none; }
    .tb-cell:not(:first-child) { padding-left: 20px; }
    .tb-cell:nth-child(odd) { padding-left: 0; }
  }

  /* ============ FOOTER ============ */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ============ HANDOFF NOTE ============ */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note {
    margin-top: 48px; padding: 24px 28px;
    background: var(--ink); color: var(--paper); border-radius: 10px;
    font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em;
  }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  .resp-card .row .n { color: var(--gold); }
  .router-card .num { color: var(--gold); }
  .tb-cell .v { color: var(--gold); }
  .dir-row .v { color: var(--gold); }


  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Data Annotation and Labeling.html  (.page-data-annotation) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--f-sans); background: var(--paper); color: var(--ink);
    -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
    font-size: 16px; line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin: 0 0 20px; }
  h1, h2, h3, h4 { font-family: var(--f-display); font-weight: 400; letter-spacing: -0.015em; margin: 0; color: var(--ink); text-wrap: balance; }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-data-annotation .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons */
  .btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-sans); font-weight: 500; font-size: 15px; letter-spacing: 0.01em; padding: 16px 32px; border-radius: 6px; transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease; cursor: pointer; border: 1px solid transparent; }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }
  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* HERO */
  .cat-hero { padding: 120px 0 96px; border-bottom: 1px solid var(--soft-line); }
  .cat-hero .breadcrumb { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px; }
  .cat-hero .breadcrumb a { color: var(--warm-grey); }
  .cat-hero .breadcrumb a:hover { color: var(--gold); }
  .cat-hero .breadcrumb span.curr { color: var(--ink); }
  .cat-hero h1 { max-width: 960px; font-size: clamp(44px, 6vw, 78px); }
  .cat-hero .lead { max-width: 700px; margin-top: 32px; font-size: 22px; }
  .cat-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .cat-hero .trust-chip { margin-top: 28px; display: inline-flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: 0.04em; color: var(--warm-grey); font-family: var(--f-mono); }
  .cat-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
  .hero-meta { margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--soft-line); display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
  .hero-meta-item { padding: 0 20px 0 0; border-right: 1px solid var(--soft-line); }
  .hero-meta-item:last-child { border-right: none; padding-right: 0; }
  .hero-meta-item:not(:first-child) { padding-left: 20px; }
  .hero-meta-item .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .hero-meta-item .v { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; letter-spacing: -0.01em; font-variation-settings: "opsz" 48; }
  .hero-meta-item .v small { display: block; font-family: var(--f-sans); font-weight: 400; font-size: 13px; color: var(--warm-grey); margin-top: 4px; letter-spacing: 0; }
  @media (max-width: 900px) {
    .cat-hero { padding: 80px 0 72px; }
    .hero-meta { grid-template-columns: 1fr 1fr; }
    .hero-meta-item { padding: 16px 16px 16px 0; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
    .hero-meta-item:nth-child(2n) { border-right: none; padding-right: 0; }
    .hero-meta-item:nth-last-child(-n+2) { border-bottom: none; }
    .hero-meta-item:not(:first-child) { padding-left: 16px; }
    .hero-meta-item:nth-child(odd) { padding-left: 0; }
  }

  /* OM STRIP */
  .om-strip { padding: 96px 0; background: var(--slate); color: var(--paper); }
  .om-strip .eyebrow { color: var(--gold); }
  .om-grid { display: grid; grid-template-columns: 0.9fr 2.1fr; gap: 64px; align-items: start; }
  .om-grid .head h3 { color: var(--paper); font-size: clamp(24px, 2.4vw, 30px); max-width: 420px; }
  .om-grid .head h3 em { color: var(--gold); }
  .om-principles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(250,250,247,0.15); }
  .om-principle { padding: 24px 20px 24px 0; border-right: 1px solid rgba(250,250,247,0.15); display: grid; grid-template-rows: auto 1fr; gap: 10px; }
  .om-principle:last-child { border-right: none; padding-right: 0; }
  .om-principle:not(:first-child) { padding-left: 20px; }
  .om-principle .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .om-principle .v { font-family: var(--f-sans); font-weight: 500; font-size: 15px; color: var(--paper); line-height: 1.4; }
  @media (max-width: 900px) {
    .om-grid { grid-template-columns: 1fr; gap: 32px; }
    .om-principles { grid-template-columns: 1fr 1fr; }
    .om-principle { border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 20px; }
    .om-principle:nth-child(2n) { border-right: none; }
    .om-principle:nth-last-child(-n+2) { border-bottom: none; }
    .om-principle:not(:first-child) { padding-left: 20px; }
  }

  /* THREE TRACKS */
  .tracks { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .tracks .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 64px; }
  .tracks h2 em { color: var(--gold); }
  .tracks .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }
  .track-list { display: grid; gap: 0; border-top: 1px solid var(--ink); }
  .track {
    display: grid; grid-template-columns: 88px 1fr 1.1fr auto;
    align-items: stretch; gap: 32px;
    padding: 48px 0;
    border-bottom: 1px solid var(--soft-line);
    transition: background .2s ease;
    position: relative;
  }
  .track:hover { background: var(--paper); }
  .track:hover .t-num { color: var(--gold); }
  .track:hover .t-arrow { transform: translate(6px, -6px); color: var(--gold); }
  .track .t-num { font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.12em; color: var(--warm-grey); padding-top: 8px; transition: color .2s ease; }
  .track .t-body h3 { font-size: clamp(28px, 3vw, 38px); line-height: 1.05; margin-bottom: 14px; max-width: 380px; }
  .track .t-body h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .track .t-body p { font-size: 15px; color: var(--warm-grey); margin: 0; max-width: 420px; line-height: 1.6; }
  .track .t-meta { display: grid; grid-template-rows: auto 1fr; gap: 12px; padding-top: 8px; }
  .track .t-meta .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .track .t-meta ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; }
  .track .t-meta li { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.02em; color: var(--ink); display: flex; gap: 10px; }
  .track .t-meta li::before { content: "—"; color: var(--gold); flex: none; }
  .track .t-arrow { font-family: var(--f-display); font-size: 32px; line-height: 1; color: var(--ink); align-self: start; padding-top: 8px; transition: transform .25s ease, color .25s ease; font-style: italic; font-weight: 300; }
  @media (max-width: 900px) {
    .tracks { padding: 96px 0; }
    .tracks .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .track { grid-template-columns: 1fr; gap: 16px; padding: 36px 0; }
    .track .t-num { padding-top: 0; }
    .track .t-arrow { position: absolute; top: 36px; right: 0; }
  }

  /* TECHNIQUES MATRIX */
  .tech { padding: 140px 0; }
  .tech .head { max-width: 720px; margin: 0 auto 64px; text-align: center; }
  .tech h2 em { color: var(--gold); }
  .tech .head p { color: var(--warm-grey); font-size: 18px; margin-top: 20px; }
  .tech-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--ink); border-left: 1px solid var(--soft-line);
  }
  .tech-cell {
    padding: 36px 32px;
    border-right: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
    background: var(--paper);
    display: grid; grid-template-rows: auto auto auto 1fr; gap: 10px;
  }
  .tech-cell:nth-child(6n+1), .tech-cell:nth-child(6n+3), .tech-cell:nth-child(6n+5) { background: var(--white); }
  .tech-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .tech-cell h3 { font-size: 22px; line-height: 1.15; margin: 0; }
  .tech-cell p { font-size: 13px; line-height: 1.55; color: var(--warm-grey); margin: 0; }
  .tech-cell .use { margin-top: 8px; padding-top: 12px; border-top: 1px solid var(--soft-line); font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--ink); text-transform: uppercase; }
  @media (max-width: 900px) { .tech { padding: 96px 0; } .tech-grid { grid-template-columns: 1fr; } }
  @media (max-width: 1100px) and (min-width: 901px) { .tech-grid { grid-template-columns: 1fr 1fr; } }

  /* TOOLING STRIP (slate) */
  .tooling { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .tooling .eyebrow { color: var(--gold); }
  .tooling h2 { color: var(--paper); max-width: 720px; }
  .tooling h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .tooling .lead { color: rgba(250,250,247,0.75); max-width: 640px; margin-top: 24px; font-size: 19px; }
  .tool-grid { margin-top: 72px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(250,250,247,0.15); }
  .tool-cell { padding: 32px 28px 32px 0; border-right: 1px solid rgba(250,250,247,0.15); }
  .tool-cell:last-child { border-right: none; padding-right: 0; }
  .tool-cell:not(:first-child) { padding-left: 28px; }
  .tool-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 12px; }
  .tool-cell h4 { font-family: var(--f-display); font-size: 22px; font-weight: 400; color: var(--paper); line-height: 1.15; margin-bottom: 10px; font-variation-settings: "opsz" 48; }
  .tool-cell p { font-size: 13px; line-height: 1.55; color: rgba(250,250,247,0.7); margin: 0; }
  @media (max-width: 900px) {
    .tooling { padding: 96px 0; }
    .tool-grid { grid-template-columns: 1fr 1fr; }
    .tool-cell { padding: 24px 20px 24px 0; border-bottom: 1px solid rgba(250,250,247,0.15); }
    .tool-cell:nth-child(2n) { border-right: none; padding-right: 0; padding-left: 20px; }
    .tool-cell:nth-last-child(-n+2) { border-bottom: none; }
  }

  /* PROCESS STRIP */
  .process { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .process .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .process h2 em { color: var(--gold); }
  .process .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }
  .proc-steps { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; position: relative; border-top: 1px solid var(--ink); }
  .proc-step { padding: 32px 20px 0 0; border-right: 1px solid var(--soft-line); display: grid; grid-template-rows: auto auto auto; gap: 12px; }
  .proc-step:last-child { border-right: none; }
  .proc-step:not(:first-child) { padding-left: 20px; }
  .proc-step .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .proc-step h4 { font-family: var(--f-display); font-size: 20px; line-height: 1.15; font-weight: 400; margin: 0; font-variation-settings: "opsz" 48; }
  .proc-step p { font-size: 13px; line-height: 1.55; color: var(--warm-grey); margin: 0; }
  @media (max-width: 900px) {
    .process { padding: 96px 0; }
    .process .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .proc-steps { grid-template-columns: 1fr; }
    .proc-step { border-right: none; border-bottom: 1px solid var(--soft-line); padding: 24px 0; }
    .proc-step:last-child { border-bottom: none; }
    .proc-step:not(:first-child) { padding-left: 0; }
  }

  /* PROOF */
  .page-data-annotation .proof{ background: var(--slate); color: var(--paper); padding: 140px 0; }
  .page-data-annotation .proof .head{ max-width: 720px; margin-bottom: 72px; }
  .page-data-annotation .proof .eyebrow{ color: var(--gold); }
  .page-data-annotation .proof h2{ color: var(--paper); }
  .page-data-annotation .proof h2 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-data-annotation .proof-grid{ display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
  .page-data-annotation .proof-cell{ padding: 48px 32px 48px 0; border-right: 1px solid rgba(250,250,247,0.15); }
  .page-data-annotation .proof-cell:last-child{ border-right: none; padding-right: 0; }
  .page-data-annotation .proof-cell:not(:first-child){ padding-left: 32px; }
  .page-data-annotation .proof-cell .n{ font-family: var(--f-display); font-size: clamp(44px, 4.8vw, 64px); line-height: 1; font-variation-settings: "opsz" 96; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 16px; color: var(--paper); }
  .page-data-annotation .proof-cell .n sup{ font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .page-data-annotation .proof-cell .l{ font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; margin-bottom: 10px; }
  .page-data-annotation .proof-cell .d{ font-size: 13px; color: rgba(250,250,247,0.8); line-height: 1.55; margin: 0; }
  .page-data-annotation .proof-foot{ margin-top: 40px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; display: flex; gap: 24px; flex-wrap: wrap; align-items: center; }
  .page-data-annotation .proof-foot .sep{ color: rgba(250,250,247,0.35); }
  .page-data-annotation .proof-foot .g{ color: var(--gold); }
  @media (max-width: 900px) {
    .page-data-annotation .proof{ padding: 96px 0; }
    .page-data-annotation .proof-grid{ grid-template-columns: 1fr 1fr; }
    .page-data-annotation .proof-cell{ border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 32px 20px; }
    .page-data-annotation .proof-cell:nth-child(2n){ border-right: none; }
    .page-data-annotation .proof-cell:nth-last-child(-n+2){ border-bottom: none; }
    .page-data-annotation .proof-cell:not(:first-child){ padding-left: 20px; }
  }

  /* DISCOVERY CTA */
  .discovery { background: var(--ink); color: var(--paper); padding: 140px 0; }
  .discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 60px); }
  .discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
  .discovery .eyebrow { color: var(--gold); }
  .d-paths { display: grid; gap: 16px; }
  .d-path { padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px; background: transparent; color: var(--paper); transition: background .2s ease, color .2s ease, border-color .2s ease; }
  .d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .d-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .d-path .a { font-size: 22px; }
  @media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* FINAL CTA */
  .page-data-annotation .final-cta{ padding: 120px 0; background: var(--paper); border-top: 1px solid var(--soft-line); }
  .page-data-annotation .final-cta .row{ display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; }
  .page-data-annotation .final-cta h3{ font-size: clamp(28px, 3vw, 38px); max-width: 680px; }
  .page-data-annotation .final-cta h3 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-data-annotation .final-cta .actions{ display: flex; gap: 12px; flex-wrap: wrap; }
  @media (max-width: 900px) { .page-data-annotation .final-cta{ padding: 80px 0; } .page-data-annotation .final-cta .row{ grid-template-columns: 1fr; gap: 24px; } }

  /* FOOTER */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* HANDOFF */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note { margin-top: 48px; padding: 24px 28px; background: var(--ink); color: var(--paper); border-radius: 10px; font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em; }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  .hero-meta-item .v { color: var(--gold); }


  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Data Validation and QA.html  (.page-data-validation) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px; line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow {
    font-family: var(--f-sans); font-weight: 600;
    font-size: 12px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display); font-weight: 400;
    letter-spacing: -0.015em; margin: 0; color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-data-validation .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons (copied verbatim) */
  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer; border: 1px solid transparent;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* ============ HERO ============ */
  .cat-hero { padding: 120px 0 96px; border-bottom: 1px solid var(--soft-line); }
  .cat-hero .breadcrumb {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px;
  }
  .cat-hero .breadcrumb a { color: var(--warm-grey); }
  .cat-hero .breadcrumb a:hover { color: var(--gold); }
  .cat-hero .breadcrumb span.curr { color: var(--ink); }
  .cat-hero h1 { max-width: 960px; font-size: clamp(44px, 6vw, 78px); }
  .cat-hero .lead { max-width: 680px; margin-top: 32px; font-size: 22px; }
  .cat-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .cat-hero .trust-chip {
    margin-top: 28px;
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; letter-spacing: 0.04em;
    color: var(--warm-grey); font-family: var(--f-mono);
  }
  .cat-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

  /* Hero meta strip — signature Impact pattern */
  .hero-meta {
    margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--soft-line);
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  }
  .hero-meta-item {
    padding: 0 20px 0 0; border-right: 1px solid var(--soft-line);
  }
  .hero-meta-item:last-child { border-right: none; padding-right: 0; }
  .hero-meta-item:not(:first-child) { padding-left: 20px; }
  .hero-meta-item .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .hero-meta-item .v {
    font-family: var(--f-display); font-weight: 400; font-size: 22px;
    line-height: 1.2; letter-spacing: -0.01em; font-variation-settings: "opsz" 48;
  }
  .hero-meta-item .v small {
    display: block; font-family: var(--f-sans); font-weight: 400; font-size: 13px;
    color: var(--warm-grey); margin-top: 4px; letter-spacing: 0;
  }
  @media (max-width: 900px) {
    .cat-hero { padding: 80px 0 72px; }
    .hero-meta { grid-template-columns: 1fr 1fr; gap: 0; }
    .hero-meta-item { padding: 16px 16px 16px 0; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
    .hero-meta-item:nth-child(2n) { border-right: none; padding-right: 0; }
    .hero-meta-item:nth-last-child(-n+2) { border-bottom: none; }
    .hero-meta-item:not(:first-child) { padding-left: 16px; }
    .hero-meta-item:nth-child(odd) { padding-left: 0; }
  }

  /* ============ OPERATING MODEL STRIP (slate) ============ */
  .om-strip { padding: 96px 0; background: var(--slate); color: var(--paper); }
  .om-strip .eyebrow { color: var(--gold); }
  .om-grid { display: grid; grid-template-columns: 0.9fr 2.1fr; gap: 64px; align-items: start; }
  .om-grid .head h3 { color: var(--paper); font-size: clamp(24px, 2.4vw, 30px); max-width: 420px; }
  .om-grid .head h3 em { color: var(--gold); }
  .om-principles {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid rgba(250,250,247,0.15);
  }
  .om-principle {
    padding: 24px 20px 24px 0; border-right: 1px solid rgba(250,250,247,0.15);
    display: grid; grid-template-rows: auto 1fr; gap: 10px;
  }
  .om-principle:last-child { border-right: none; padding-right: 0; }
  .om-principle:not(:first-child) { padding-left: 20px; }
  .om-principle .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .om-principle .v { font-family: var(--f-sans); font-weight: 500; font-size: 15px; color: var(--paper); line-height: 1.4; }
  @media (max-width: 900px) {
    .om-grid { grid-template-columns: 1fr; gap: 32px; }
    .om-principles { grid-template-columns: 1fr 1fr; }
    .om-principle { border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 20px; }
    .om-principle:nth-child(2n) { border-right: none; }
    .om-principle:nth-last-child(-n+2) { border-bottom: none; }
    .om-principle:not(:first-child) { padding-left: 20px; }
  }

  /* ============ PIPELINE DIAGRAM (white) ============ */
  .pipeline { background: var(--white); padding: 140px 0; border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .pipeline .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 80px; }
  .pipeline h2 { max-width: 560px; }
  .pipeline h2 em { color: var(--gold); }
  .pipeline .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }

  .pipe-track {
    position: relative;
    padding: 0 0 32px;
  }
  .pipe-rail {
    position: absolute; top: 44px; left: 0; right: 0; height: 1px; background: var(--ink);
  }
  .pipe-rail::after {
    content: ""; position: absolute; right: -1px; top: -4px;
    border-left: 8px solid var(--ink);
    border-top: 4px solid transparent; border-bottom: 4px solid transparent;
  }
  .pipe-stages {
    display: grid; grid-template-columns: repeat(5, 1fr);
    position: relative; z-index: 1;
  }
  .pipe-stage {
    padding: 0 20px 0 0;
    position: relative;
  }
  .pipe-stage:last-child { padding-right: 0; }
  .pipe-stage .node {
    display: block; width: 24px; height: 24px; border-radius: 50%;
    background: var(--paper); border: 1.5px solid var(--ink);
    margin: 32px 0 20px;
    position: relative; z-index: 2;
  }
  .pipe-stage.gate .node { background: var(--gold); border-color: var(--gold); }
  .pipe-stage .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 10px; }
  .pipe-stage h3 { font-size: 22px; margin-bottom: 8px; }
  .pipe-stage p { font-size: 13px; color: var(--warm-grey); line-height: 1.5; margin: 0; }
  .pipe-stage .meta {
    margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    color: var(--ink); text-transform: uppercase; line-height: 1.6;
  }
  .pipe-stage .meta .yep { color: var(--gold); }
  .pipe-stage .meta .nope { color: var(--warm-grey); text-decoration: line-through; }

  .pipe-legend {
    margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--soft-line);
    display: flex; flex-wrap: wrap; gap: 24px;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
    color: var(--warm-grey); text-transform: uppercase;
  }
  .pipe-legend .lg { display: inline-flex; align-items: center; gap: 8px; }
  .pipe-legend .lg .sw { width: 10px; height: 10px; border-radius: 50%; background: var(--gold); display: inline-block; }
  .pipe-legend .lg .sw.ink { background: var(--paper); border: 1.5px solid var(--ink); }
  @media (max-width: 900px) {
    .pipeline { padding: 96px 0; }
    .pipeline .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
    .pipe-track { padding: 0 0 16px; }
    .pipe-rail { display: none; }
    .pipe-stages { grid-template-columns: 1fr; gap: 0; }
    .pipe-stage { padding: 24px 0; border-top: 1px solid var(--soft-line); }
    .pipe-stage:first-child { border-top: 1px solid var(--ink); }
    .pipe-stage .node { margin: 20px 0; }
  }

  /* ============ FOUR CAPABILITIES (paper, 2x2) ============ */
  .caps { padding: 140px 0; }
  .caps .head { max-width: 720px; margin: 0 auto 64px; text-align: center; }
  .caps h2 em { color: var(--gold); }
  .caps .head p { color: var(--warm-grey); font-size: 18px; margin-top: 20px; }
  .caps-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    border-top: 1px solid var(--ink);
    border-left: 1px solid var(--soft-line);
  }
  .cap {
    padding: 48px;
    border-right: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
    background: var(--paper);
    display: grid; grid-template-rows: auto 1fr auto; gap: 16px;
  }
  .cap:nth-child(4n+1), .cap:nth-child(4n+4) { background: var(--white); }
  .cap .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .cap h3 { font-size: clamp(26px, 2.4vw, 32px); line-height: 1.1; margin: 0; }
  .cap h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .cap p { font-size: 16px; line-height: 1.6; color: var(--ink); margin: 0; max-width: 440px; }
  .cap .bullets {
    list-style: none; padding: 0; margin: 16px 0 0;
    display: grid; gap: 10px;
    padding-top: 20px; border-top: 1px solid var(--soft-line);
  }
  .cap .bullets li {
    font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em; color: var(--ink);
    display: flex; gap: 12px;
  }
  .cap .bullets li::before { content: "—"; color: var(--gold); flex: none; }
  @media (max-width: 900px) {
    .caps { padding: 96px 0; }
    .caps-grid { grid-template-columns: 1fr; }
    .cap { padding: 32px; }
  }

  /* ============ SCOPE MODES (slate, side-by-side) ============ */
  .scope { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .scope .head { max-width: 720px; margin-bottom: 72px; }
  .scope .eyebrow { color: var(--gold); }
  .scope h2 { color: var(--paper); }
  .scope h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .scope .lead { color: rgba(250,250,247,0.75); }
  .scope-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    border-top: 1px solid rgba(250,250,247,0.2);
  }
  .scope-mode {
    padding: 48px 40px 48px 0;
    border-right: 1px solid rgba(250,250,247,0.15);
    display: grid; grid-template-rows: auto auto 1fr auto; gap: 18px;
  }
  .scope-mode:last-child { border-right: none; padding-right: 0; padding-left: 40px; }
  .scope-mode .tag {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase;
  }
  .scope-mode .tag .primary-dot { color: var(--gold); }
  .scope-mode h3 { font-size: clamp(26px, 2.6vw, 32px); color: var(--paper); line-height: 1.1; margin: 0; max-width: 380px; }
  .scope-mode h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .scope-mode p { color: rgba(250,250,247,0.78); font-size: 15px; line-height: 1.6; max-width: 440px; margin: 0; }
  .scope-mode ul {
    list-style: none; padding: 0; margin: 0;
    display: grid; gap: 10px;
    padding-top: 18px; border-top: 1px solid rgba(250,250,247,0.15);
  }
  .scope-mode li {
    font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em;
    color: var(--paper); display: flex; gap: 12px;
  }
  .scope-mode li::before { content: "→"; color: var(--gold); flex: none; }
  .scope-mode.primary .tag { padding: 4px 10px; background: var(--gold); color: var(--ink); border-radius: 3px; display: inline-flex; align-self: flex-start; }
  @media (max-width: 900px) {
    .scope { padding: 96px 0; }
    .scope-grid { grid-template-columns: 1fr; }
    .scope-mode { padding: 40px 0; border-right: none; border-bottom: 1px solid rgba(250,250,247,0.15); }
    .scope-mode:last-child { padding-left: 0; border-bottom: none; }
  }

  /* ============ COMMITMENTS (white) ============ */
  .commit { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .commit .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 64px; }
  .commit h2 em { color: var(--gold); }
  .commit .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }
  .commit-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--soft-line);
  }
  .commit-cell {
    padding: 36px 32px 36px 0;
    border-right: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto auto 1fr; gap: 14px;
  }
  .commit-cell:last-child { border-right: none; padding-right: 0; }
  .commit-cell:not(:first-child) { padding-left: 32px; }
  .commit-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .commit-cell h3 { font-size: 22px; line-height: 1.2; margin: 0; }
  .commit-cell h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .commit-cell p { font-size: 14px; line-height: 1.6; color: var(--warm-grey); margin: 0; }
  .commit-note {
    margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.02em; color: var(--warm-grey);
    max-width: 720px;
  }
  .commit-note strong { color: var(--ink); font-weight: 500; }
  @media (max-width: 900px) {
    .commit { padding: 96px 0; }
    .commit .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .commit-grid { grid-template-columns: 1fr; }
    .commit-cell { border-right: none; border-bottom: 1px solid var(--soft-line); padding: 28px 0; }
    .commit-cell:last-child { border-bottom: none; }
    .commit-cell:not(:first-child) { padding-left: 0; }
  }

  /* ============ APPLIES ACROSS (paper, photo-led 2-col) ============ */
  .applies { padding: 140px 0; }
  .applies .a-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
  }
  .applies h2 { font-size: clamp(32px, 3.6vw, 46px); max-width: 480px; }
  .applies h2 em { color: var(--gold); }
  .applies p { color: var(--warm-grey); font-size: 17px; max-width: 460px; line-height: 1.65; }

  .data-types {
    margin-top: 32px; padding-top: 24px;
    border-top: 1px solid var(--soft-line);
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  }
  .dt {
    padding: 14px 14px 14px 0; border-right: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.08em;
    color: var(--ink); text-transform: uppercase;
    display: flex; align-items: center; gap: 10px;
  }
  .dt:nth-child(2n) { border-right: none; padding-right: 0; padding-left: 14px; }
  .dt::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--gold); flex: none; }
  .dt-note {
    grid-column: 1 / -1; padding-top: 16px; margin-top: 4px;
    border-top: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em;
    color: var(--warm-grey); text-transform: none; line-height: 1.6;
    padding-right: 0;
  }

  .applies-figure {
    position: relative; aspect-ratio: 4/5; border-radius: 12px; overflow: hidden;
    background: var(--slate);
    box-shadow: 0 40px 80px -32px rgba(15,15,16,0.22);
  }
  .applies-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .applies-figure::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, rgba(28,28,30,0) 55%, rgba(28,28,30,0.55) 100%);
  }
  .applies-figure .band-label {
    position: absolute; top: 16px; left: 16px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 6px 10px; border-radius: 3px;
    display: inline-flex; align-items: center; gap: 8px;
  }
  .applies-figure .band-label .live { color: var(--gold); }
  .applies-figure .band-cap {
    position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .applies-figure .band-cap .dot { color: var(--gold); }
  @media (max-width: 900px) { .applies { padding: 96px 0; } .applies .a-grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ PROOF / TRUST (slate) ============ */
  .page-data-validation .proof{ background: var(--slate); color: var(--paper); padding: 140px 0; }
  .page-data-validation .proof .head{ max-width: 720px; margin-bottom: 72px; }
  .page-data-validation .proof .eyebrow{ color: var(--gold); }
  .page-data-validation .proof h2{ color: var(--paper); }
  .page-data-validation .proof h2 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-data-validation .proof-grid{
    display: grid; grid-template-columns: repeat(4, 1fr);
    border-top: 1px solid rgba(250,250,247,0.15);
    border-bottom: 1px solid rgba(250,250,247,0.15);
  }
  .page-data-validation .proof-cell{ padding: 48px 32px 48px 0; border-right: 1px solid rgba(250,250,247,0.15); }
  .page-data-validation .proof-cell:last-child{ border-right: none; padding-right: 0; }
  .page-data-validation .proof-cell:not(:first-child){ padding-left: 32px; }
  .page-data-validation .proof-cell .n{ font-family: var(--f-display); font-size: clamp(44px, 4.8vw, 64px); line-height: 1; font-variation-settings: "opsz" 96; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 16px; color: var(--paper); }
  .page-data-validation .proof-cell .n sup{ font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .page-data-validation .proof-cell .l{ font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; margin-bottom: 10px; }
  .page-data-validation .proof-cell .d{ font-size: 13px; color: rgba(250,250,247,0.8); line-height: 1.55; margin: 0; }
  .page-data-validation .proof-foot{
    margin-top: 40px;
    font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em;
    color: rgba(250,250,247,0.6); text-transform: uppercase;
    display: flex; gap: 24px; flex-wrap: wrap; align-items: center;
  }
  .page-data-validation .proof-foot .sep{ color: rgba(250,250,247,0.35); }
  .page-data-validation .proof-foot .g{ color: var(--gold); }
  @media (max-width: 900px) {
    .page-data-validation .proof{ padding: 96px 0; }
    .page-data-validation .proof-grid{ grid-template-columns: 1fr 1fr; }
    .page-data-validation .proof-cell{ border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 32px 20px; }
    .page-data-validation .proof-cell:nth-child(2n){ border-right: none; }
    .page-data-validation .proof-cell:nth-last-child(-n+2){ border-bottom: none; }
    .page-data-validation .proof-cell:not(:first-child){ padding-left: 20px; }
  }

  /* ============ DISCOVERY CTA (ink) ============ */
  .discovery { background: var(--ink); color: var(--paper); padding: 140px 0; }
  .discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 60px); }
  .discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
  .discovery .eyebrow { color: var(--gold); }
  .d-paths { display: grid; gap: 16px; }
  .d-path {
    padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: transparent; color: var(--paper);
    transition: background .2s ease, color .2s ease, border-color .2s ease;
  }
  .d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .d-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .d-path .a { font-size: 22px; }
  @media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ FINAL CTA (paper) ============ */
  .page-data-validation .final-cta{ padding: 120px 0; background: var(--paper); border-top: 1px solid var(--soft-line); }
  .page-data-validation .final-cta .row{ display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; }
  .page-data-validation .final-cta h3{ font-size: clamp(28px, 3vw, 38px); max-width: 680px; }
  .page-data-validation .final-cta h3 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-data-validation .final-cta .actions{ display: flex; gap: 12px; flex-wrap: wrap; }
  @media (max-width: 900px) { .page-data-validation .final-cta{ padding: 80px 0; } .page-data-validation .final-cta .row{ grid-template-columns: 1fr; gap: 24px; } }

  /* ============ FOOTER ============ */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ============ HANDOFF NOTE ============ */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note {
    margin-top: 48px; padding: 24px 28px;
    background: var(--ink); color: var(--paper); border-radius: 10px;
    font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em;
  }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  .hero-meta-item .v { color: var(--gold); }


  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Managed Data Teams.html  (.page-managed-teams) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px; line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow {
    font-family: var(--f-sans); font-weight: 600;
    font-size: 12px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display); font-weight: 400;
    letter-spacing: -0.015em; margin: 0; color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-managed-teams .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons */
  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer; border: 1px solid transparent;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* ============ HERO ============ */
  .cat-hero { padding: 120px 0 96px; border-bottom: 1px solid var(--soft-line); }
  .cat-hero .breadcrumb {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px;
  }
  .cat-hero .breadcrumb a { color: var(--warm-grey); }
  .cat-hero .breadcrumb a:hover { color: var(--gold); }
  .cat-hero .breadcrumb span.curr { color: var(--ink); }
  .cat-hero h1 { max-width: 960px; font-size: clamp(44px, 6vw, 78px); }
  .cat-hero .lead { max-width: 720px; margin-top: 32px; font-size: 22px; }
  .cat-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .cat-hero .trust-chip {
    margin-top: 28px;
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; letter-spacing: 0.04em;
    color: var(--warm-grey); font-family: var(--f-mono);
  }
  .cat-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

  .hero-meta {
    margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--soft-line);
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  }
  .hero-meta-item { padding: 0 20px 0 0; border-right: 1px solid var(--soft-line); }
  .hero-meta-item:last-child { border-right: none; padding-right: 0; }
  .hero-meta-item:not(:first-child) { padding-left: 20px; }
  .hero-meta-item .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .hero-meta-item .v { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; letter-spacing: -0.01em; font-variation-settings: "opsz" 48; }
  .hero-meta-item .v small { display: block; font-family: var(--f-sans); font-weight: 400; font-size: 13px; color: var(--warm-grey); margin-top: 4px; letter-spacing: 0; }
  @media (max-width: 900px) {
    .cat-hero { padding: 80px 0 72px; }
    .hero-meta { grid-template-columns: 1fr 1fr; gap: 0; }
    .hero-meta-item { padding: 16px 16px 16px 0; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
    .hero-meta-item:nth-child(2n) { border-right: none; padding-right: 0; }
    .hero-meta-item:nth-last-child(-n+2) { border-bottom: none; }
    .hero-meta-item:not(:first-child) { padding-left: 16px; }
    .hero-meta-item:nth-child(odd) { padding-left: 0; }
  }

  /* ============ OPERATING MODEL STRIP (slate) ============ */
  .om-strip { padding: 96px 0; background: var(--slate); color: var(--paper); }
  .om-strip .eyebrow { color: var(--gold); }
  .om-grid { display: grid; grid-template-columns: 0.9fr 2.1fr; gap: 64px; align-items: start; }
  .om-grid .head h3 { color: var(--paper); font-size: clamp(24px, 2.4vw, 30px); max-width: 420px; }
  .om-grid .head h3 em { color: var(--gold); }
  .om-principles {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid rgba(250,250,247,0.15);
  }
  .om-principle { padding: 24px 20px 24px 0; border-right: 1px solid rgba(250,250,247,0.15); display: grid; grid-template-rows: auto 1fr; gap: 10px; }
  .om-principle:last-child { border-right: none; padding-right: 0; }
  .om-principle:not(:first-child) { padding-left: 20px; }
  .om-principle .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .om-principle .v { font-family: var(--f-sans); font-weight: 500; font-size: 15px; color: var(--paper); line-height: 1.4; }
  @media (max-width: 900px) {
    .om-grid { grid-template-columns: 1fr; gap: 32px; }
    .om-principles { grid-template-columns: 1fr 1fr; }
    .om-principle { border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 20px; }
    .om-principle:nth-child(2n) { border-right: none; }
    .om-principle:nth-last-child(-n+2) { border-bottom: none; }
    .om-principle:not(:first-child) { padding-left: 20px; }
  }

  /* ============ WHAT YOU GET (photo-led editorial; paper) ============ */
  .whatyouget { padding: 140px 0; background: var(--paper); }
  .wyg-head { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .wyg-head h2 em { color: var(--gold); }
  .wyg-head p { color: var(--warm-grey); font-size: 17px; max-width: 440px; margin: 0; }

  .wyg-layout { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 72px; align-items: start; }

  .wyg-figure {
    position: relative; aspect-ratio: 4/5; border-radius: 12px; overflow: hidden;
    background: var(--slate);
    box-shadow: 0 40px 80px -32px rgba(15,15,16,0.22);
    position: sticky; top: 130px;
  }
  .wyg-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .wyg-figure::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, rgba(28,28,30,0) 55%, rgba(28,28,30,0.55) 100%);
  }
  .wyg-figure .band-label {
    position: absolute; top: 16px; left: 16px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 6px 10px; border-radius: 3px;
    display: inline-flex; align-items: center; gap: 8px;
  }
  .wyg-figure .band-label .live { color: var(--gold); }
  .wyg-figure .band-cap {
    position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .wyg-figure .band-cap .dot { color: var(--gold); }

  .wyg-list { display: grid; gap: 0; border-top: 1px solid var(--ink); }
  .wyg-item { padding: 28px 0; border-bottom: 1px solid var(--soft-line); display: grid; grid-template-columns: 56px 1fr; gap: 20px; align-items: start; }
  .wyg-item .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; padding-top: 6px; }
  .wyg-item h3 { font-size: 24px; line-height: 1.2; margin: 0 0 8px; }
  .wyg-item h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .wyg-item p { font-size: 15px; color: var(--warm-grey); margin: 0; line-height: 1.6; max-width: 520px; }

  @media (max-width: 900px) {
    .whatyouget { padding: 96px 0; }
    .wyg-head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .wyg-layout { grid-template-columns: 1fr; gap: 48px; }
    .wyg-figure { position: static; aspect-ratio: 4/3; }
  }

  /* ============ ENGAGEMENT TIMELINE (white) ============ */
  .engage { background: var(--white); padding: 140px 0; border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .engage .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 80px; }
  .engage h2 { max-width: 620px; }
  .engage h2 em { color: var(--gold); }
  .engage .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }

  .pipe-track { position: relative; padding: 0 0 32px; }
  .pipe-rail { position: absolute; top: 44px; left: 0; right: 0; height: 1px; background: var(--ink); }
  .pipe-rail::after {
    content: ""; position: absolute; right: -1px; top: -4px;
    border-left: 8px solid var(--ink);
    border-top: 4px solid transparent; border-bottom: 4px solid transparent;
  }
  .pipe-stages { display: grid; grid-template-columns: repeat(5, 1fr); position: relative; z-index: 1; }
  .pipe-stage { padding: 0 20px 0 0; position: relative; }
  .pipe-stage:last-child { padding-right: 0; }
  .pipe-stage .node {
    display: block; width: 24px; height: 24px; border-radius: 50%;
    background: var(--white); border: 1.5px solid var(--ink);
    margin: 32px 0 20px;
    position: relative; z-index: 2;
  }
  .pipe-stage.gate .node { background: var(--gold); border-color: var(--gold); }
  .pipe-stage .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 10px; }
  .pipe-stage h3 { font-size: 22px; margin-bottom: 8px; }
  .pipe-stage p { font-size: 13px; color: var(--warm-grey); line-height: 1.5; margin: 0; }
  .pipe-stage .meta {
    margin-top: 14px; padding-top: 12px; border-top: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    color: var(--ink); text-transform: uppercase; line-height: 1.6;
  }
  .pipe-stage .meta .yep { color: var(--gold); }

  .pipe-legend {
    margin-top: 40px; padding-top: 24px; border-top: 1px solid var(--soft-line);
    display: flex; flex-wrap: wrap; gap: 24px;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
    color: var(--warm-grey); text-transform: uppercase;
  }
  .pipe-legend .lg { display: inline-flex; align-items: center; gap: 8px; }
  .pipe-legend .lg .sw { width: 10px; height: 10px; border-radius: 50%; background: var(--gold); display: inline-block; }
  .pipe-legend .lg .sw.ink { background: var(--white); border: 1.5px solid var(--ink); }
  @media (max-width: 900px) {
    .engage { padding: 96px 0; }
    .engage .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
    .pipe-track { padding: 0 0 16px; }
    .pipe-rail { display: none; }
    .pipe-stages { grid-template-columns: 1fr; gap: 0; }
    .pipe-stage { padding: 24px 0; border-top: 1px solid var(--soft-line); }
    .pipe-stage:first-child { border-top: 1px solid var(--ink); }
    .pipe-stage .node { margin: 20px 0; }
  }

  /* ============ COMPARISON (paper, three columns, middle is us) ============ */
  .cmp { padding: 140px 0; background: var(--paper); }
  .cmp .head { max-width: 760px; margin-bottom: 72px; }
  .cmp h2 em { color: var(--gold); }
  .cmp .head p { color: var(--warm-grey); font-size: 18px; margin-top: 18px; max-width: 560px; }

  .cmp-grid {
    display: grid; grid-template-columns: 1fr 1.15fr 1fr; gap: 0;
    align-items: stretch;
    border-top: 1px solid var(--soft-line);
  }
  .cmp-col {
    padding: 40px 32px 40px 0;
    border-right: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto auto 1fr auto; gap: 18px;
    background: var(--paper);
  }
  .cmp-col:last-child { border-right: none; padding-right: 0; }
  .cmp-col:not(:first-child) { padding-left: 32px; }

  .cmp-col .tag {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--warm-grey);
    display: inline-flex; align-self: flex-start;
  }
  .cmp-col h3 {
    font-size: 26px; line-height: 1.15; margin: 0;
    color: var(--ink); max-width: 320px;
  }
  .cmp-col h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .cmp-col .sub { font-family: var(--f-sans); font-size: 14px; color: var(--warm-grey); line-height: 1.55; margin: 0; max-width: 320px; }
  .cmp-col ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; padding-top: 18px; border-top: 1px solid var(--soft-line); }
  .cmp-col li {
    font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.04em;
    color: var(--ink); display: flex; gap: 12px; line-height: 1.55;
  }
  .cmp-col li::before { content: "—"; color: var(--warm-grey); flex: none; }
  .cmp-col .foot {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase;
    padding-top: 16px; border-top: 1px solid var(--soft-line);
  }

  /* Primary (ours) column — ink background pillar */
  .cmp-col.ours {
    background: var(--ink); color: var(--paper);
    margin: -40px 0;
    padding: 80px 40px;
    border-right: none; border-left: none;
    border-radius: 12px;
    box-shadow: 0 40px 80px -40px rgba(15,15,16,0.4);
  }
  .cmp-col.ours .tag {
    background: var(--gold); color: var(--ink);
    padding: 5px 10px; border-radius: 3px;
  }
  .cmp-col.ours h3 { color: var(--paper); }
  .cmp-col.ours h3 em { color: var(--gold); }
  .cmp-col.ours .sub { color: rgba(250,250,247,0.75); }
  .cmp-col.ours ul { border-top-color: rgba(250,250,247,0.2); }
  .cmp-col.ours li { color: var(--paper); }
  .cmp-col.ours li::before { content: "→"; color: var(--gold); }
  .cmp-col.ours .foot { color: rgba(250,250,247,0.6); border-top-color: rgba(250,250,247,0.2); }

  @media (max-width: 1000px) {
    .cmp { padding: 96px 0; }
    .cmp-grid { grid-template-columns: 1fr; }
    .cmp-col { border-right: none; border-bottom: 1px solid var(--soft-line); padding: 40px 0; }
    .cmp-col:last-child { border-bottom: none; }
    .cmp-col:not(:first-child) { padding-left: 0; }
    .cmp-col.ours { margin: 0; padding: 48px 28px; border-radius: 12px; }
  }

  /* ============ FIT SCENARIOS (slate) ============ */
  .fit { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .fit .head { max-width: 760px; margin-bottom: 72px; }
  .fit .eyebrow { color: var(--gold); }
  .fit h2 { color: var(--paper); }
  .fit h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .fit .lead { color: rgba(250,250,247,0.75); }

  .fit-grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid rgba(250,250,247,0.2);
  }
  .fit-cell {
    padding: 40px 28px 40px 0;
    border-right: 1px solid rgba(250,250,247,0.15);
    display: grid; grid-template-rows: auto auto 1fr; gap: 14px;
  }
  .fit-cell:last-child { border-right: none; padding-right: 0; }
  .fit-cell:not(:first-child) { padding-left: 28px; }
  .fit-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .fit-cell h3 { font-size: 22px; line-height: 1.2; color: var(--paper); margin: 0; }
  .fit-cell h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .fit-cell p { font-size: 14px; color: rgba(250,250,247,0.78); line-height: 1.6; margin: 0; }

  @media (max-width: 1000px) {
    .fit { padding: 96px 0; }
    .fit-grid { grid-template-columns: 1fr 1fr; }
    .fit-cell { padding: 28px 20px; border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
    .fit-cell:nth-child(2n) { border-right: none; }
    .fit-cell:nth-last-child(-n+2) { border-bottom: none; }
    .fit-cell:not(:first-child) { padding-left: 20px; }
  }
  @media (max-width: 600px) {
    .fit-grid { grid-template-columns: 1fr; }
    .fit-cell { padding: 28px 0 !important; border-right: none; }
    .fit-cell:not(:first-child) { padding-left: 0 !important; }
    .fit-cell:last-child { border-bottom: none; }
  }

  /* ============ ANCHOR CASE (white, editorial proof slate) ============ */
  .anchor { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .anchor .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 64px; }
  .anchor h2 em { color: var(--gold); }
  .anchor .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 460px; }

  .anchor-body {
    display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 64px; align-items: stretch;
  }

  .anchor-figure {
    position: relative; aspect-ratio: 3/4; border-radius: 12px; overflow: hidden;
    background: var(--slate);
  }
  .anchor-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .anchor-figure::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, rgba(28,28,30,0) 50%, rgba(28,28,30,0.65) 100%);
  }
  .anchor-figure .band-label {
    position: absolute; top: 16px; left: 16px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 6px 10px; border-radius: 3px;
  }
  .anchor-figure .band-cap {
    position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .anchor-figure .band-cap .dot { color: var(--gold); }

  .anchor-panel { display: grid; grid-template-rows: auto auto 1fr auto; gap: 24px; }
  .anchor-tag {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--gold);
    background: rgba(201,162,39,0.08); border: 1px solid rgba(201,162,39,0.25);
    padding: 6px 10px; border-radius: 3px; align-self: flex-start;
  }
  .anchor-panel h3 {
    font-size: clamp(28px, 3vw, 36px); line-height: 1.15; margin: 0;
  }
  .anchor-panel h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .anchor-panel p { color: var(--warm-grey); font-size: 16px; line-height: 1.65; margin: 0; max-width: 520px; }

  .anchor-stats {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    border-top: 1px solid var(--soft-line);
    margin-top: 8px;
  }
  .anchor-stat {
    padding: 20px 20px 20px 0;
    border-right: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
  }
  .anchor-stat:nth-child(2n) { border-right: none; padding-right: 0; padding-left: 20px; }
  .anchor-stat:nth-last-child(-n+2) { border-bottom: none; }
  .anchor-stat .l { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .anchor-stat .n { font-family: var(--f-display); font-size: clamp(32px, 3.4vw, 44px); line-height: 1; font-variation-settings: "opsz" 96; font-weight: 400; letter-spacing: -0.02em; }
  .anchor-stat .n sup { font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }

  @media (max-width: 900px) {
    .anchor { padding: 96px 0; }
    .anchor .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .anchor-body { grid-template-columns: 1fr; gap: 48px; }
    .anchor-figure { aspect-ratio: 4/3; }
  }

  /* ============ DISCOVERY CTA (ink) ============ */
  .discovery { background: var(--ink); color: var(--paper); padding: 140px 0; }
  .discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 60px); }
  .discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
  .discovery .eyebrow { color: var(--gold); }
  .d-paths { display: grid; gap: 16px; }
  .d-path {
    padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: transparent; color: var(--paper);
    transition: background .2s ease, color .2s ease, border-color .2s ease;
  }
  .d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .d-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .d-path .a { font-size: 22px; }
  @media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ RELATED CATEGORIES (paper) ============ */
  .related { padding: 120px 0; background: var(--paper); }
  .related .head { margin-bottom: 48px; }
  .related h2 { font-size: clamp(28px, 3vw, 38px); }
  .rel-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
  .rel-card {
    display: grid; grid-template-rows: auto 1fr auto; gap: 12px;
    padding: 28px; background: var(--white);
    border: 1px solid var(--soft-line); border-radius: 12px;
    transition: border-color .2s ease, transform .2s ease;
  }
  .rel-card:hover { border-color: var(--gold); transform: translateY(-4px); }
  .rel-card .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .rel-card h3 { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; margin: 0; }
  .rel-card p { font-size: 14px; color: var(--warm-grey); line-height: 1.55; margin: 0; }
  .rel-card .cta {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--ink); text-transform: uppercase;
    margin-top: 8px; display: inline-flex; align-items: center; gap: 6px;
  }
  .rel-card:hover .cta { color: var(--gold); }
  @media (max-width: 900px) { .rel-grid { grid-template-columns: 1fr 1fr; } }
  @media (max-width: 600px) { .rel-grid { grid-template-columns: 1fr; } }

  /* ============ FINAL CTA (paper) ============ */
  .page-managed-teams .final-cta{ padding: 120px 0; background: var(--paper); border-top: 1px solid var(--soft-line); }
  .page-managed-teams .final-cta .row{ display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center; }
  .page-managed-teams .final-cta h3{ font-size: clamp(28px, 3vw, 38px); max-width: 680px; }
  .page-managed-teams .final-cta h3 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-managed-teams .final-cta .actions{ display: flex; gap: 12px; flex-wrap: wrap; }
  @media (max-width: 900px) { .page-managed-teams .final-cta{ padding: 80px 0; } .page-managed-teams .final-cta .row{ grid-template-columns: 1fr; gap: 24px; } }

  /* ============ FOOTER ============ */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ============ HANDOFF NOTE ============ */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note {
    margin-top: 48px; padding: 24px 28px;
    background: var(--ink); color: var(--paper); border-radius: 10px;
    font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em;
  }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  .hero-meta-item .v { color: var(--gold); }
  .anchor-stat .n { color: var(--gold); }


  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Services.html  (.page-services) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px;
    line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
  .prose { max-width: 680px; }

  .eyebrow {
    font-family: var(--f-sans); font-weight: 600;
    font-size: 12px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display); font-weight: 400;
    letter-spacing: -0.015em; margin: 0; color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }

  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-services .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons */
  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer; border: 1px solid transparent;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .btn-ghost-light { border-color: var(--paper); color: var(--paper); background: transparent; }
  .btn-ghost-light:hover { background: var(--paper); color: var(--ink); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  /* Banner */
  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* ============ HERO ============ */
  .svc-hero { padding: 120px 0 100px; border-bottom: 1px solid var(--soft-line); }
  .svc-hero .breadcrumb {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px;
  }
  .svc-hero .breadcrumb a { color: var(--warm-grey); }
  .svc-hero .breadcrumb a:hover { color: var(--gold); }
  .svc-hero .breadcrumb span { color: var(--ink); }
  .svc-hero h1 { max-width: 960px; font-size: clamp(44px, 6.2vw, 84px); }
  .svc-hero .lead { max-width: 680px; margin-top: 32px; font-size: 22px; }
  .svc-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .svc-hero .trust-chip {
    margin-top: 28px;
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; letter-spacing: 0.04em;
    color: var(--warm-grey); font-family: var(--f-mono);
  }
  .svc-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

  /* Hero jump strip: lets specialists scan to the category directly */
  .svc-hero .jump-strip {
    margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--soft-line);
    display: grid; grid-template-columns: auto 1fr; gap: 40px; align-items: baseline;
  }
  .svc-hero .jump-strip .lbl {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase;
  }
  .svc-hero .jump-strip .jumps {
    display: flex; flex-wrap: wrap; gap: 8px 12px;
  }
  .svc-hero .jump-strip a {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
    text-transform: uppercase; color: var(--ink);
    padding: 8px 12px; border: 1px solid var(--soft-line); border-radius: 3px;
    transition: border-color .2s ease, color .2s ease, background .2s ease;
  }
  .svc-hero .jump-strip a:hover { border-color: var(--ink); color: var(--ink); background: var(--white); }
  .svc-hero .jump-strip a .n { color: var(--gold); margin-right: 6px; }
  @media (max-width: 900px) {
    .svc-hero { padding: 80px 0 72px; }
    .svc-hero .jump-strip { grid-template-columns: 1fr; gap: 16px; }
  }

  /* ============ OPERATING MODEL STRIP ============ */
  .om-strip { padding: 96px 0; background: var(--slate); color: var(--paper); }
  .om-strip .eyebrow { color: var(--gold); }
  .om-strip .head h3 { color: var(--paper); }
  .om-strip .om-principles { border-top-color: rgba(250,250,247,0.15); }
  .om-strip .om-principle { border-right-color: rgba(250,250,247,0.15); }
  .om-strip .om-principle .v { color: var(--paper); }
  .om-grid {
    display: grid; grid-template-columns: 0.9fr 2.1fr; gap: 64px; align-items: start;
  }
  .om-grid .head .eyebrow { margin-bottom: 14px; }
  .om-grid .head h3 { font-size: clamp(24px, 2.4vw, 30px); max-width: 360px; }
  .om-grid .head h3 em { color: var(--gold); }
  .om-principles {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid var(--soft-line);
  }
  .om-principle {
    padding: 24px 20px 24px 0; border-right: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto 1fr; gap: 10px;
  }
  .om-principle:last-child { border-right: none; padding-right: 0; }
  .om-principle:not(:first-child) { padding-left: 20px; }
  .om-principle .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .om-principle .v { font-family: var(--f-sans); font-weight: 500; font-size: 15px; color: var(--ink); line-height: 1.4; }
  @media (max-width: 900px) {
    .om-grid { grid-template-columns: 1fr; gap: 32px; }
    .om-principles { grid-template-columns: 1fr 1fr; }
    .om-principle { border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); padding: 20px; }
    .om-principle:nth-child(2n) { border-right: none; }
    .om-principle:nth-last-child(-n+2) { border-bottom: none; }
    .om-principle:not(:first-child) { padding-left: 20px; }
  }

  /* ============ SERVICES GRID — MAGAZINE FEATURE FLOW ============ */
  .svc-section { padding: 140px 0; }
  .svc-section + .svc-section { padding-top: 0; }
  .svc-section-head {
    max-width: 720px; margin: 0 auto 100px; text-align: center;
  }
  .svc-section-head h2 em { color: var(--gold); }
  .svc-section-head p { color: var(--warm-grey); font-size: 18px; margin-top: 24px; }

  .svc-band { padding: 100px 0; border-top: 1px solid var(--soft-line); }
  .svc-band:first-of-type { border-top: none; padding-top: 40px; }
  .svc-band.paper-alt { background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .svc-band.dark { background: var(--slate); color: var(--paper); border-top: none; padding: 120px 0; }
  .svc-band.dark h2 { color: var(--paper); }
  .svc-band.dark h2 em { color: var(--gold); }
  .svc-band.dark .band-lead { color: rgba(250,250,247,0.75); }
  .svc-band.dark .svc-band-num .cat { color: var(--paper); }
  .svc-band.dark .svc-band-num .slash { color: rgba(250,250,247,0.4); }
  .svc-band.dark .sub-list { border-top-color: rgba(250,250,247,0.15); }
  .svc-band.dark .sub-list a.sub-row { border-bottom-color: rgba(250,250,247,0.15); }
  .svc-band.dark .sub-list a.sub-row:hover { background: rgba(201,162,39,0.08); }
  .svc-band.dark .sub-name { color: var(--paper); }
  .svc-band.dark .sub-desc { color: rgba(250,250,247,0.6); }
  .svc-band.dark .sub-arrow { color: rgba(250,250,247,0.5); }
  .svc-band.dark .cap-chips { border-top-color: rgba(250,250,247,0.15); }
  .svc-band.dark .cap-chip { background: transparent; border-color: rgba(250,250,247,0.25); color: var(--paper); }
  .svc-band.dark .pull-quote { color: var(--paper); }
  .svc-band.dark .pull-quote em { color: var(--gold); }
  .svc-band.dark .explore-link { border-color: var(--paper); color: var(--paper); }
  .svc-band.dark .explore-link:hover { background: var(--paper); color: var(--ink); }
  .svc-band-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center;
  }
  .svc-band.flip .svc-band-grid { direction: rtl; }
  .svc-band.flip .svc-band-grid > * { direction: ltr; }

  /* Band header block */
  .svc-band-num {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase; margin-bottom: 24px;
    display: inline-flex; align-items: center; gap: 14px;
  }
  .svc-band-num .slash { color: var(--warm-grey); }
  .svc-band-num .cat { color: var(--ink); }
  .svc-band h2 {
    font-size: clamp(36px, 4.2vw, 56px); line-height: 1.05;
    margin-bottom: 24px; max-width: 520px;
  }
  .svc-band h2 em { color: var(--gold); }
  .svc-band .band-lead {
    color: var(--warm-grey); font-size: 18px; line-height: 1.6;
    max-width: 520px; margin-bottom: 36px;
  }

  /* Sub-service list (2-col link rows) */
  .sub-list {
    border-top: 1px solid var(--soft-line);
    margin-bottom: 36px;
  }
  .sub-list.two-col {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0 40px;
  }
  .sub-list a.sub-row {
    display: grid; grid-template-columns: auto 1fr auto; gap: 16px;
    align-items: baseline;
    padding: 18px 0;
    border-bottom: 1px solid var(--soft-line);
    transition: background .15s ease, padding .15s ease;
  }
  .sub-list a.sub-row:hover { background: rgba(201,162,39,0.04); padding-left: 8px; padding-right: 8px; }
  .sub-list a.sub-row:hover .sub-name { color: var(--gold); }
  .sub-list a.sub-row:hover .sub-arrow { transform: translateX(3px); color: var(--gold); }
  .sub-name {
    font-family: var(--f-display); font-weight: 400; font-size: 19px;
    line-height: 1.2; letter-spacing: -0.01em;
    transition: color .15s ease;
  }
  .sub-desc {
    font-family: var(--f-sans); font-size: 13px; color: var(--warm-grey);
    line-height: 1.45;
  }
  .sub-arrow {
    font-family: var(--f-mono); font-size: 14px; color: var(--warm-grey);
    transition: transform .15s ease, color .15s ease;
  }

  /* Capability chip row — for categories without sub-services */
  .cap-chips {
    display: flex; flex-wrap: wrap; gap: 8px;
    margin: 0 0 36px;
    padding: 20px 0 0;
    border-top: 1px solid var(--soft-line);
  }
  .cap-chip {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em;
    padding: 8px 12px; border: 1px solid var(--soft-line); border-radius: 3px;
    color: var(--ink); text-transform: uppercase; background: var(--white);
  }
  .svc-band.paper-alt .cap-chip { background: var(--paper); }

  /* Pull quote variant (used in no-sublist bands for extra visual weight) */
  .pull-quote {
    margin: 24px 0 32px;
    padding: 24px 0 24px 24px;
    border-left: 2px solid var(--gold);
    font-family: var(--f-display); font-weight: 400;
    font-size: clamp(20px, 2vw, 24px); line-height: 1.35;
    font-variation-settings: "opsz" 48;
    color: var(--ink); max-width: 520px;
  }
  .pull-quote em { color: var(--gold); font-style: italic; font-weight: 300; }

  /* Band CTA link */
  .explore-link {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500; font-size: 15px;
    color: var(--ink); padding: 14px 24px;
    border: 1px solid var(--ink); border-radius: 6px;
    transition: background .2s ease, color .2s ease, transform .2s ease;
  }
  .explore-link:hover { background: var(--ink); color: var(--paper); }
  .explore-link .arr { transition: transform .2s ease; }
  .explore-link:hover .arr { transform: translateX(3px); }

  /* Visual column */
  .band-visual { position: relative; }
  .band-figure {
    position: relative; aspect-ratio: 5/6; border-radius: 12px; overflow: hidden;
    background: var(--slate);
    box-shadow: 0 40px 80px -32px rgba(15,15,16,0.22);
  }
  .band-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .band-figure.placeholder {
    background:
      repeating-linear-gradient(135deg, rgba(15,15,16,0.04) 0 14px, transparent 14px 28px),
      var(--white);
    border: 1px solid var(--soft-line);
  }
  .band-figure.placeholder .ph-copy {
    position: absolute; inset: 0;
    display: grid; place-content: center; text-align: center;
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; padding: 32px;
  }
  .band-figure.placeholder .ph-copy .ph-big {
    display: block; font-family: var(--f-display); font-size: 28px;
    color: var(--ink); letter-spacing: -0.01em; margin-bottom: 10px;
    text-transform: none; font-variation-settings: "opsz" 48;
  }
  .band-cap {
    position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .band-cap .dot { color: var(--gold); }
  .band-cap.light { color: var(--warm-grey); }
  .band-figure::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, rgba(28,28,30,0) 55%, rgba(28,28,30,0.6) 100%);
  }
  .band-figure.placeholder::after { display: none; }
  .band-label {
    position: absolute; top: 16px; left: 16px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 6px 10px; border-radius: 3px;
    display: inline-flex; align-items: center; gap: 8px;
  }
  .band-label .live { color: var(--gold); }

  @media (max-width: 900px) {
    .svc-section { padding: 96px 0; }
    .svc-band { padding: 72px 0; }
    .svc-band-grid { grid-template-columns: 1fr; gap: 48px; }
    .svc-band.flip .svc-band-grid { direction: ltr; }
    .sub-list.two-col { grid-template-columns: 1fr; gap: 0; }
  }

  /* ============ ENGAGEMENT MODEL ============ */
  .engage { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .engage .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 80px; }
  .engage h2 em { color: var(--gold); }
  .engage .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }
  .engage-flow {
    display: grid; grid-template-columns: repeat(5, 1fr);
    position: relative;
    border-top: 1px solid var(--ink);
  }
  .engage-step {
    padding: 32px 20px 0;
    position: relative;
    border-right: 1px solid var(--soft-line);
  }
  .engage-step:last-child { border-right: none; }
  .engage-step .dot {
    position: absolute; top: -7px; left: 20px;
    width: 13px; height: 13px; border-radius: 50%;
    background: var(--paper); border: 1.5px solid var(--ink);
  }
  .engage-step .dot.active { background: var(--gold); border-color: var(--gold); }
  .engage-step .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 12px; }
  .engage-step h3 { font-size: 22px; margin-bottom: 10px; }
  .engage-step p { font-size: 14px; color: var(--warm-grey); line-height: 1.5; margin: 0; }
  .engage-note {
    margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--soft-line);
    font-size: 15px; color: var(--warm-grey); max-width: 720px;
  }
  @media (max-width: 900px) {
    .engage { padding: 96px 0; }
    .engage .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
    .engage-flow { grid-template-columns: 1fr; border-top: none; }
    .engage-step { border-right: none; border-top: 1px solid var(--ink); padding: 24px 0 0; }
    .engage-step .dot { left: 0; }
  }

  /* ============ PROOF BAND (slate) ============ */
  .page-services .proof{ background: var(--slate); color: var(--paper); padding: 140px 0; }
  .page-services .proof .head{ max-width: 720px; margin-bottom: 72px; }
  .page-services .proof .eyebrow{ color: var(--gold); }
  .page-services .proof h2{ color: var(--paper); }
  .page-services .proof h2 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-services .proof-grid{ display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
  .page-services .proof-cell{ padding: 48px 32px; border-right: 1px solid rgba(250,250,247,0.15); }
  .page-services .proof-cell:last-child{ border-right: none; }
  .page-services .proof-cell .n{ font-family: var(--f-display); font-size: clamp(44px, 4.8vw, 64px); line-height: 1; font-variation-settings: "opsz" 96; font-weight: 400; letter-spacing: -0.02em; margin-bottom: 16px; color: var(--paper); }
  .page-services .proof-cell .n sup{ font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .page-services .proof-cell .l{ font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: rgba(250,250,247,0.6); text-transform: uppercase; margin-bottom: 10px; }
  .page-services .proof-cell .d{ font-size: 13px; color: rgba(250,250,247,0.8); line-height: 1.55; margin: 0; }
  @media (max-width: 900px) {
    .page-services .proof{ padding: 96px 0; }
    .page-services .proof-grid{ grid-template-columns: 1fr 1fr; }
    .page-services .proof-cell{ border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
    .page-services .proof-cell:nth-child(2n){ border-right: none; }
    .page-services .proof-cell:nth-last-child(-n+2){ border-bottom: none; }
  }

  /* ============ DISCOVERY CTA (ink) ============ */
  .discovery { background: var(--ink); color: var(--paper); padding: 160px 0; }
  .discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 64px); }
  .discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
  .discovery .eyebrow { color: var(--gold); }
  .d-paths { display: grid; gap: 16px; }
  .d-path {
    padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: transparent; color: var(--paper);
    transition: background .2s ease, color .2s ease, border-color .2s ease;
  }
  .d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .d-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .d-path .a { font-size: 22px; }
  @media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* ============ FINAL CTA (paper, short) ============ */
  .page-services .final-cta{ padding: 120px 0; background: var(--paper); border-top: 1px solid var(--soft-line); }
  .page-services .final-cta .row{
    display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
  }
  .page-services .final-cta h3{ font-size: clamp(28px, 3vw, 38px); max-width: 680px; }
  .page-services .final-cta h3 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-services .final-cta .actions{ display: flex; gap: 12px; flex-wrap: wrap; }
  @media (max-width: 900px) { .page-services .final-cta{ padding: 80px 0; } .page-services .final-cta .row{ grid-template-columns: 1fr; gap: 24px; } }

  /* ============ FOOTER ============ */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ============ HANDOFF NOTE ============ */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note {
    margin-top: 48px; padding: 24px 28px;
    background: var(--ink); color: var(--paper); border-radius: 10px;
    font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em;
  }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  /* proof-cell .n stays paper on dark; accent handled by sup */

  /* ============ ACCURACY INFOGRAPHIC (Validation band) ============ */
  .accuracy-graphic {
    position: relative;
    border-radius: 12px;
    overflow: hidden;
    background: #111113;
    box-shadow: 0 40px 80px -32px rgba(15,15,16,0.6);
    border: 1px solid rgba(250,250,247,0.08);
    display: flex; flex-direction: column;
  }
  .ag-header {
    display: flex; justify-content: space-between; align-items: center;
    padding: 16px 20px;
    border-bottom: 1px solid rgba(250,250,247,0.08);
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.55);
    white-space: nowrap;
  }
  .ag-header .ag-title { color: rgba(250,250,247,0.85); }
  .ag-header .ag-live { color: var(--gold); display: inline-flex; align-items: center; gap: 6px; }
  .ag-header .ag-live .pulse {
    width: 6px; height: 6px; border-radius: 50%; background: var(--gold);
    box-shadow: 0 0 0 0 rgba(201,162,39,0.6);
    animation: ag-pulse 1.8s ease-out infinite;
  }
  @keyframes ag-pulse {
    0% { box-shadow: 0 0 0 0 rgba(201,162,39,0.55); }
    70% { box-shadow: 0 0 0 8px rgba(201,162,39,0); }
    100% { box-shadow: 0 0 0 0 rgba(201,162,39,0); }
  }

  .ag-hero {
    flex: 1;
    padding: 28px 20px 22px;
    display: grid; grid-template-columns: 1fr;
    gap: 20px;
  }

  .ag-iaa-block {
    text-align: left;
  }
  .ag-iaa-block .label {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.12em;
    text-transform: uppercase; color: rgba(250,250,247,0.5);
    margin-bottom: 10px;
  }
  .ag-iaa-block .value {
    font-family: var(--f-display); font-variation-settings: "opsz" 144;
    font-weight: 400; font-size: clamp(56px, 7vw, 96px);
    letter-spacing: -0.03em; line-height: 0.9; color: var(--paper);
    display: flex; align-items: baseline; gap: 14px;
  }
  .ag-iaa-block .value .delta {
    font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em;
    color: var(--gold); font-variation-settings: normal;
  }
  .ag-iaa-block .sub {
    margin-top: 10px;
    font-family: var(--f-sans); font-size: 13px; color: rgba(250,250,247,0.65);
    line-height: 1.5; max-width: 340px;
  }
  .ag-iaa-block .sub em { color: var(--gold); font-style: normal; }

  /* Reviewer convergence diagram */
  .ag-target-wrap {
    position: relative;
    aspect-ratio: 1/1;
    max-width: 220px;
    margin: 4px auto 0;
    width: 100%;
  }
  .ag-target-wrap svg { width: 100%; height: 100%; display: block; }

  .ag-ring {
    fill: none;
    stroke: rgba(250,250,247,0.08);
    stroke-width: 1;
  }
  .ag-ring.gold {
    stroke: rgba(201,162,39,0.4);
    stroke-dasharray: 3 4;
  }
  .ag-target-center {
    fill: var(--gold);
  }
  .ag-target-center-ring {
    fill: none; stroke: var(--gold); stroke-width: 1.5;
  }
  .ag-reviewer-line {
    stroke: rgba(250,250,247,0.2); stroke-width: 1;
  }
  .ag-reviewer-dot {
    fill: var(--paper); stroke: #111113; stroke-width: 2;
  }
  .ag-reviewer-label {
    fill: rgba(250,250,247,0.55);
    font-family: 'Geist Mono', ui-monospace, monospace;
    font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase;
  }
  .ag-center-label {
    fill: var(--gold);
    font-family: 'Geist Mono', ui-monospace, monospace;
    font-size: 8px; letter-spacing: 0.12em; text-transform: uppercase;
  }

  /* Distribution strip at bottom */
  .ag-dist {
    padding: 18px 20px 20px;
    border-top: 1px solid rgba(250,250,247,0.08);
  }
  .ag-dist-head {
    display: flex; justify-content: space-between; align-items: baseline;
    margin-bottom: 12px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.5);
  }
  .ag-dist-head .scale { color: rgba(250,250,247,0.35); }
  .ag-dist-bars {
    display: grid; grid-template-columns: repeat(18, 1fr); gap: 3px;
    align-items: end; height: 46px;
  }
  .ag-bar {
    background: rgba(250,250,247,0.14);
    border-radius: 1px;
    transition: background .2s ease;
  }
  .ag-bar.peak { background: var(--gold); }
  .ag-bar.near { background: rgba(201,162,39,0.55); }

  .ag-dist-axis {
    display: flex; justify-content: space-between;
    margin-top: 8px;
    font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.08em;
    color: rgba(250,250,247,0.35);
  }
  .ag-dist-axis .gold { color: var(--gold); }

  /* Specimen strip — below header */
  .ag-specimen {
    display: flex; justify-content: space-between; gap: 12px;
    padding: 10px 20px;
    border-bottom: 1px solid rgba(250,250,247,0.08);
    font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.4);
  }
  .ag-specimen .cell { display: flex; gap: 8px; align-items: baseline; }
  .ag-specimen .k { color: rgba(250,250,247,0.4); }
  .ag-specimen .kv { color: rgba(250,250,247,0.85); }

  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== Social Impact.html  (.page-social-impact) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--f-sans);
    background: var(--paper);
    color: var(--ink);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    font-size: 16px; line-height: 1.55;
  }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }

  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow {
    font-family: var(--f-sans); font-weight: 600;
    font-size: 12px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--gold);
    margin: 0 0 20px;
  }

  h1, h2, h3, h4 {
    font-family: var(--f-display); font-weight: 400;
    letter-spacing: -0.015em; margin: 0; color: var(--ink);
    text-wrap: balance;
  }
  h1 { font-size: clamp(44px, 6vw, 78px); line-height: 1.02; font-variation-settings: "opsz" 144; hyphens: none; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-social-impact .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  /* Buttons */
  .btn {
    display: inline-flex; align-items: center; gap: 10px;
    font-family: var(--f-sans); font-weight: 500;
    font-size: 15px; letter-spacing: 0.01em;
    padding: 16px 32px; border-radius: 6px;
    transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease;
    cursor: pointer; border: 1px solid transparent;
  }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  /* Nav */
  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; display: block; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { color: var(--ink); opacity: 0.85; }
  .nav-links a:hover { opacity: 1; color: var(--gold); }
  .nav-links a.active { color: var(--gold); opacity: 1; }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* ============ HERO ============ */
  .si-hero { padding: 96px 0 0; border-bottom: 1px solid var(--soft-line); }
  .si-hero .breadcrumb {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px;
  }
  .si-hero .breadcrumb a { color: var(--warm-grey); }
  .si-hero .breadcrumb a:hover { color: var(--gold); }
  .si-hero .breadcrumb span.curr { color: var(--ink); }
  .si-hero h1 { max-width: 1000px; }
  .si-hero .lead { max-width: 720px; margin-top: 32px; font-size: 22px; }
  .si-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .si-hero .trust-chip {
    margin-top: 28px;
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 12px; letter-spacing: 0.04em;
    color: var(--warm-grey); font-family: var(--f-mono);
  }
  .si-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }

  .si-hero-figure {
    margin-top: 80px; position: relative;
    aspect-ratio: 16/7; border-radius: 12px 12px 0 0; overflow: hidden;
    background: var(--slate);
  }
  .si-hero-figure img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .si-hero-figure::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, rgba(28,28,30,0) 55%, rgba(28,28,30,0.55) 100%);
  }
  .si-hero-figure .band-label {
    position: absolute; top: 20px; left: 20px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 6px 10px; border-radius: 3px;
  }
  .si-hero-figure .band-cap {
    position: absolute; bottom: 20px; left: 20px; right: 20px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 16px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .si-hero-figure .band-cap .dot { color: var(--gold); }

  .hero-meta {
    margin-top: 0; padding: 32px 0 120px;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid var(--soft-line);
  }
  .hero-meta-item { padding: 0 20px 0 0; border-right: 1px solid var(--soft-line); }
  .hero-meta-item:last-child { border-right: none; padding-right: 0; }
  .hero-meta-item:not(:first-child) { padding-left: 20px; }
  .hero-meta-item .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .hero-meta-item .v { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; letter-spacing: -0.01em; font-variation-settings: "opsz" 48; }
  .hero-meta-item .v small { display: block; font-family: var(--f-sans); font-weight: 400; font-size: 13px; color: var(--warm-grey); margin-top: 4px; letter-spacing: 0; }
  @media (max-width: 900px) {
    .si-hero { padding: 72px 0 0; }
    .si-hero-figure { aspect-ratio: 4/3; margin-top: 48px; }
    .hero-meta { grid-template-columns: 1fr 1fr; padding: 28px 0 72px; }
    .hero-meta-item { padding: 16px 16px 16px 0; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
    .hero-meta-item:nth-child(2n) { border-right: none; padding-right: 0; }
    .hero-meta-item:nth-last-child(-n+2) { border-bottom: none; }
    .hero-meta-item:not(:first-child) { padding-left: 16px; }
    .hero-meta-item:nth-child(odd) { padding-left: 0; }
  }

  /* ============ WHY THIS MATTERS (slate) ============ */
  .si-why { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .si-why .eyebrow { color: var(--gold); }
  .si-why h2 { color: var(--paper); max-width: 880px; }
  .si-why h2 em { color: var(--gold); font-style: italic; font-weight: 300; }

  .why-grid {
    margin-top: 72px;
    display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: start;
  }
  .why-body { max-width: 560px; }
  .why-body p { color: rgba(250,250,247,0.78); font-size: 17px; line-height: 1.7; margin: 0 0 1.2em; }
  .why-body p.emphasis {
    font-family: var(--f-display); font-weight: 400;
    font-size: clamp(22px, 2.4vw, 28px); line-height: 1.3;
    color: var(--paper); font-variation-settings: "opsz" 48;
    margin: 32px 0;
  }
  .why-body p.emphasis em { color: var(--gold); font-style: italic; font-weight: 300; }

  .why-pressures {
    display: grid; gap: 0;
    border-top: 1px solid rgba(250,250,247,0.18);
  }
  .why-pressure {
    padding: 28px 0;
    border-bottom: 1px solid rgba(250,250,247,0.12);
    display: grid; grid-template-columns: 96px 1fr; gap: 24px; align-items: start;
  }
  .why-pressure .code {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase; padding-top: 4px;
  }
  .why-pressure h3 {
    font-size: 20px; line-height: 1.25; color: var(--paper);
    font-variation-settings: "opsz" 48; font-weight: 400; margin: 0 0 8px;
  }
  .why-pressure h3 em { color: var(--gold); }
  .why-pressure p {
    font-size: 14px; color: rgba(250,250,247,0.72);
    line-height: 1.6; margin: 0; max-width: 460px;
  }

  @media (max-width: 1000px) {
    .si-why { padding: 96px 0; }
    .why-grid { grid-template-columns: 1fr; gap: 48px; }
    .why-pressure { grid-template-columns: 72px 1fr; gap: 16px; }
  }

  /* ============ OPERATING PRINCIPLES (paper) ============ */
  .page-social-impact .principles{ padding: 140px 0; background: var(--paper); }
  .page-social-impact .principles .head{ display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .page-social-impact .principles h2 em{ color: var(--gold); }
  .page-social-impact .principles .head p{ color: var(--warm-grey); font-size: 17px; max-width: 420px; margin: 0; }

  .prin-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--ink);
  }
  .prin-card {
    padding: 40px 32px 40px 0;
    border-right: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto auto 1fr auto; gap: 14px;
    background: var(--paper);
    transition: background .2s ease;
  }
  .prin-card:nth-child(3n) { border-right: none; padding-right: 0; }
  .prin-card:not(:nth-child(3n+1)) { padding-left: 32px; }
  .prin-card:nth-last-child(-n+3) { border-bottom: none; }
  .prin-card:hover { background: var(--white); }
  .prin-card .num {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.14em;
    color: var(--gold); text-transform: uppercase;
  }
  .prin-card h3 {
    font-size: 26px; line-height: 1.2; margin: 0;
  }
  .prin-card h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .prin-card p {
    font-size: 15px; color: var(--warm-grey); line-height: 1.6; margin: 0; max-width: 340px;
  }
  .prin-card .foot {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--ink); text-transform: uppercase;
    padding-top: 14px; border-top: 1px solid var(--soft-line); margin-top: 8px;
  }

  @media (max-width: 1000px) {
    .page-social-impact .principles{ padding: 96px 0; }
    .page-social-impact .principles .head{ grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .prin-grid { grid-template-columns: 1fr 1fr; }
    .prin-card { border-right: 1px solid var(--soft-line); padding: 28px 20px; }
    .prin-card:nth-child(3n) { border-right: 1px solid var(--soft-line); padding-right: 20px; }
    .prin-card:nth-child(2n) { border-right: none; padding-right: 0; }
    .prin-card:not(:nth-child(3n+1)) { padding-left: 20px; }
    .prin-card:first-child { padding-left: 0; }
    .prin-card:nth-child(odd) { padding-left: 0; }
    .prin-card:nth-last-child(-n+2) { border-bottom: none; }
  }
  @media (max-width: 640px) {
    .prin-grid { grid-template-columns: 1fr; }
    .prin-card { padding: 28px 0 !important; border-right: none !important; }
  }

  /* ============ REGION (white) ============ */
  .region { background: var(--white); padding: 140px 0; border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .region .head { max-width: 880px; margin-bottom: 64px; }
  .region h2 em { color: var(--gold); }
  .region .head p { color: var(--warm-grey); font-size: 18px; margin-top: 18px; max-width: 640px; }

  .region-body {
    display: grid; grid-template-columns: 1fr 1fr; gap: 72px; align-items: start;
  }
  .region-col .col-k {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase; margin-bottom: 16px;
  }
  .region-col h3 {
    font-size: clamp(24px, 2.4vw, 30px); line-height: 1.2;
    margin: 0 0 24px; max-width: 440px;
  }
  .region-col h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .region-col p { color: var(--warm-grey); font-size: 16px; line-height: 1.65; margin: 0 0 1.1em; max-width: 480px; }

  .hubs {
    margin: 32px 0 40px;
    display: grid; grid-template-columns: repeat(5, 1fr); gap: 0;
    border-top: 1px solid var(--soft-line);
    border-bottom: 1px solid var(--soft-line);
  }
  .hub {
    padding: 18px 12px 18px 0;
    border-right: 1px solid var(--soft-line);
  }
  .hub:last-child { border-right: none; padding-right: 0; }
  .hub:not(:first-child) { padding-left: 12px; }
  .hub .city {
    font-family: var(--f-display); font-size: 17px; line-height: 1.1;
    font-variation-settings: "opsz" 48; font-weight: 400;
  }
  .hub .country {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    color: var(--warm-grey); text-transform: uppercase; margin-top: 6px;
  }
  .hub.us .city { color: var(--ink); }
  .hub.us .country { color: var(--gold); }

  .region-assets {
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin-top: 8px;
  }
  .region-asset {
    padding: 16px; border: 1px solid var(--soft-line); border-radius: 8px;
    background: var(--paper);
  }
  .region-asset .l { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .region-asset .v { font-size: 14px; line-height: 1.5; color: var(--ink); }

  @media (max-width: 1000px) {
    .region { padding: 96px 0; }
    .region-body { grid-template-columns: 1fr; gap: 48px; }
    .hubs { grid-template-columns: repeat(2, 1fr); }
    .hub { padding: 16px !important; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
    .hub:nth-child(2n) { border-right: none; }
    .hub:nth-last-child(-n+2) { border-bottom: none; }
    .hub:nth-last-child(1):nth-child(odd) { border-bottom: none; grid-column: span 2; }
  }

  /* ============ ON THE FLOOR (paper, magazine gallery) ============ */
  .floor { background: var(--paper); padding: 140px 0; }
  .floor .head { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .floor h2 em { color: var(--gold); }
  .floor .head p { color: var(--warm-grey); font-size: 17px; max-width: 440px; margin: 0; }

  .floor-gallery {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: 100px;
    gap: 16px;
  }
  .floor-fig {
    position: relative; overflow: hidden; border-radius: 12px;
    background: var(--slate);
  }
  .floor-fig img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .floor-fig::after {
    content: ""; position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(180deg, rgba(28,28,30,0) 50%, rgba(28,28,30,0.65) 100%);
  }
  .floor-fig .band-label {
    position: absolute; top: 14px; left: 14px; z-index: 2;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: rgba(250,250,247,0.95);
    background: rgba(15,15,16,0.6); backdrop-filter: blur(6px);
    padding: 5px 9px; border-radius: 3px;
  }
  .floor-fig .band-cap {
    position: absolute; bottom: 14px; left: 14px; right: 14px; z-index: 2;
    display: flex; justify-content: space-between; align-items: end; gap: 12px;
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    text-transform: uppercase; color: rgba(250,250,247,0.88);
  }
  .floor-fig .band-cap .dot { color: var(--gold); }

  /* Woven photo+content rows */
  .floor-row {
    display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
    align-items: center;
    padding: 48px 0;
    border-top: 1px solid var(--soft-line);
  }
  .floor-row:first-of-type { border-top: 1px solid var(--ink); }
  .floor-row.reverse .floor-fig { order: 2; }
  .floor-row.reverse .floor-copy { order: 1; }
  .floor-row .floor-fig { aspect-ratio: 4/3; grid-column: auto; grid-row: auto; }
  .floor-copy .col-k {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase; margin-bottom: 14px;
  }
  .floor-copy h3 {
    font-family: var(--f-display); font-weight: 400;
    font-size: clamp(26px, 2.6vw, 34px); line-height: 1.2; margin: 0 0 18px;
    font-variation-settings: "opsz" 96;
  }
  .floor-copy h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .floor-copy p { color: var(--warm-grey); font-size: 16px; line-height: 1.65; margin: 0 0 1em; max-width: 480px; }
  .floor-copy p:last-child { margin-bottom: 0; }

  @media (max-width: 1000px) {
    .floor { padding: 96px 0; }
    .floor .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .floor-row { grid-template-columns: 1fr; gap: 32px; padding: 40px 0; }
    .floor-row.reverse .floor-fig { order: 0; }
    .floor-row.reverse .floor-copy { order: 0; }
  }

  /* ============ ALIGNMENT (paper-alt / white) ============ */
  .align { background: var(--white); padding: 140px 0; border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .align .head { display: grid; grid-template-columns: 1.3fr 1fr; gap: 64px; align-items: end; margin-bottom: 64px; }
  .align h2 em { color: var(--gold); }
  .align .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }

  .align-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
    border-top: 1px solid var(--ink);
  }
  .align-col {
    padding: 40px 32px 40px 0;
    border-right: 1px solid var(--soft-line);
    display: grid; grid-template-rows: auto auto 1fr auto; gap: 18px;
  }
  .align-col:last-child { border-right: none; padding-right: 0; }
  .align-col:not(:first-child) { padding-left: 32px; }
  .align-col .badge {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--gold);
    background: rgba(201,162,39,0.08); border: 1px solid rgba(201,162,39,0.25);
    padding: 6px 10px; border-radius: 3px; align-self: flex-start;
  }
  .align-col h3 {
    font-size: 24px; line-height: 1.2; margin: 0;
    max-width: 320px;
  }
  .align-col h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .align-col ul { list-style: none; padding: 24px 0 0; margin: 0; display: grid; gap: 14px; border-top: 1px solid var(--soft-line); }
  .align-col li {
    font-family: var(--f-sans); font-size: 14px;
    color: var(--ink); line-height: 1.55;
    display: grid; grid-template-columns: 52px 1fr; gap: 14px; align-items: baseline;
  }
  .align-col li .tag {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em;
    color: var(--gold); text-transform: uppercase; padding-top: 2px;
  }
  .align-col .foot {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--warm-grey); text-transform: uppercase;
    padding-top: 20px; border-top: 1px solid var(--soft-line); margin-top: 8px;
  }

  @media (max-width: 1000px) {
    .align { padding: 96px 0; }
    .align .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .align-grid { grid-template-columns: 1fr; }
    .align-col { border-right: none; border-bottom: 1px solid var(--soft-line); padding: 32px 0; }
    .align-col:last-child { border-bottom: none; }
    .align-col:not(:first-child) { padding-left: 0; }
  }

  /* ============ PROCUREMENT (paper) ============ */
  .procure { background: var(--paper); padding: 140px 0; }
  .procure .body { display: grid; grid-template-columns: 1.1fr 1.4fr; gap: 80px; align-items: start; }
  .procure h2 em { color: var(--gold); }
  .procure .lead { color: var(--warm-grey); font-size: 18px; margin-top: 24px; max-width: 420px; }
  .procure .btn { margin-top: 32px; }

  .procure-list {
    display: grid; gap: 0;
    border-top: 1px solid var(--ink);
  }
  .procure-item {
    padding: 24px 0;
    border-bottom: 1px solid var(--soft-line);
    display: grid; grid-template-columns: 64px 1fr auto; gap: 24px; align-items: center;
  }
  .procure-item .k {
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.12em;
    color: var(--gold); text-transform: uppercase;
  }
  .procure-item .name {
    font-family: var(--f-display); font-weight: 400; font-size: 22px;
    line-height: 1.2; font-variation-settings: "opsz" 48;
  }
  .procure-item .name em { color: var(--gold); font-style: italic; font-weight: 300; }
  .procure-item .desc {
    font-family: var(--f-sans); font-size: 14px; color: var(--warm-grey);
    margin-top: 4px;
  }
  .procure-item .status {
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--ink); text-transform: uppercase;
    padding: 6px 10px; border: 1px solid var(--soft-line); border-radius: 3px;
    background: var(--white);
    display: inline-flex; align-items: center; gap: 8px;
  }
  .procure-item .status .pulse {
    width: 6px; height: 6px; border-radius: 50%; background: var(--gold);
  }

  @media (max-width: 1000px) {
    .procure { padding: 96px 0; }
    .procure .body { grid-template-columns: 1fr; gap: 48px; }
    .procure-item { grid-template-columns: 52px 1fr; gap: 16px; }
    .procure-item .status { grid-column: 2; margin-top: 8px; justify-self: flex-start; }
  }

  /* ============ PROOF (slate) ============ */
  .page-social-impact .proof{ background: var(--slate); color: var(--paper); padding: 140px 0; }
  .page-social-impact .proof .head{ display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
  .page-social-impact .proof .eyebrow{ color: var(--gold); }
  .page-social-impact .proof h2{ color: var(--paper); }
  .page-social-impact .proof h2 em{ color: var(--gold); font-style: italic; font-weight: 300; }
  .page-social-impact .proof .head p{ color: rgba(250,250,247,0.72); font-size: 17px; margin: 0; max-width: 460px; }

  .page-social-impact .proof-grid{
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
    border-top: 1px solid rgba(250,250,247,0.2);
  }
  .page-social-impact .proof-cell{
    padding: 40px 28px 40px 0;
    border-right: 1px solid rgba(250,250,247,0.15);
    display: grid; grid-template-rows: auto auto 1fr; gap: 16px;
  }
  .page-social-impact .proof-cell:last-child{ border-right: none; padding-right: 0; }
  .page-social-impact .proof-cell:not(:first-child){ padding-left: 28px; }
  .page-social-impact .proof-cell .l{
    font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em;
    color: var(--gold); text-transform: uppercase;
  }
  .page-social-impact .proof-cell .n{
    font-family: var(--f-display); font-size: clamp(48px, 5.4vw, 72px);
    line-height: 1; font-variation-settings: "opsz" 144; font-weight: 400;
    letter-spacing: -0.025em; color: var(--paper);
  }
  .page-social-impact .proof-cell .n sup{ font-size: 0.4em; color: var(--gold); vertical-align: top; margin-left: 4px; }
  .page-social-impact .proof-cell .d{
    font-family: var(--f-sans); font-size: 13px;
    color: rgba(250,250,247,0.66); line-height: 1.55; margin: 0;
  }

  @media (max-width: 1000px) {
    .page-social-impact .proof{ padding: 96px 0; }
    .page-social-impact .proof .head{ grid-template-columns: 1fr; gap: 24px; margin-bottom: 48px; }
    .page-social-impact .proof-grid{ grid-template-columns: 1fr 1fr; }
    .page-social-impact .proof-cell{ padding: 28px 20px !important; border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
    .page-social-impact .proof-cell:nth-child(2n){ border-right: none; }
    .page-social-impact .proof-cell:nth-last-child(-n+2){ border-bottom: none; }
  }

  /* ============ FINAL CTA (ink) ============ */
  .final { background: var(--ink); color: var(--paper); padding: 140px 0; }
  .final .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .final .eyebrow { color: var(--gold); }
  .final h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 60px); }
  .final h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .final .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }

  .f-paths { display: grid; gap: 16px; }
  .f-path {
    padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px;
    display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px;
    background: transparent; color: var(--paper);
    transition: background .2s ease, color .2s ease, border-color .2s ease;
  }
  .f-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .f-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .f-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .f-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
  .f-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .f-path .a { font-size: 22px; }
  @media (max-width: 900px) {
    .final { padding: 96px 0; }
    .final .grid { grid-template-columns: 1fr; gap: 48px; }
  }

  /* ============ FOOTER ============ */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* ============ HANDOFF NOTE ============ */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; letter-spacing: 0; margin: 40px 0 10px; color: var(--ink); }
  .handoff h3:first-of-type { margin-top: 0; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; color: var(--ink); }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff li { margin-bottom: 4px; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note {
    margin-top: 48px; padding: 24px 28px;
    background: var(--ink); color: var(--paper); border-radius: 10px;
    font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em;
  }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* ============ GOLD NUMBER ACCENT ============ */
  .hero-meta-item .v { color: var(--gold); }


  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== services/hitl-ai-operations/index.html  (.page-hitl) ========== */
* { box-sizing: border-box; }
  html, body { margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body { font-family: var(--f-sans); background: var(--paper); color: var(--ink); -webkit-font-smoothing: antialiased; font-size: 16px; line-height: 1.55; }
  img { max-width: 100%; display: block; }
  a { color: inherit; text-decoration: none; }
  .container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }

  .eyebrow { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin: 0 0 20px; }
  h1, h2, h3, h4 { font-family: var(--f-display); font-weight: 400; letter-spacing: -0.015em; margin: 0; color: var(--ink); text-wrap: balance; }
  h1 { font-size: clamp(36px, 4.6vw, 60px); line-height: 1.05; font-variation-settings: "opsz" 144; }
  h2 { font-size: clamp(34px, 4vw, 52px); line-height: 1.06; font-variation-settings: "opsz" 96; }
  h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
  h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; }
  p { margin: 0 0 1em; text-wrap: pretty; }
  .page-hitl .lead{ font-size: 20px; line-height: 1.55; color: var(--warm-grey); }

  .btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-sans); font-weight: 500; font-size: 15px; padding: 16px 32px; border-radius: 6px; transition: background .2s ease, color .2s ease, border-color .2s ease; cursor: pointer; border: 1px solid transparent; }
  .btn-primary { background: var(--ink); color: var(--paper); }
  .btn-primary:hover { background: var(--gold); color: var(--ink); }
  .btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
  .btn-ghost:hover { background: var(--ink); color: var(--paper); }
  .arrow { display: inline-block; transition: transform .2s ease; }
  .btn:hover .arrow { transform: translateX(3px); }

  .nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.85); backdrop-filter: blur(12px); border-bottom: 1px solid var(--soft-line); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
  .logo img { max-height: 48px; width: auto; }
  .nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
  .nav-links a { opacity: 0.85; }
  .nav-links a:hover, .nav-links a.active { opacity: 1; color: var(--gold); }
  .nav-cta .btn { padding: 10px 20px; font-size: 14px; }
  @media (max-width: 900px) { .nav-links { display: none; } }

  .banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
  .banner .dot { color: var(--gold); }

  /* HERO */
  .cat-hero { padding: 120px 0 96px; border-bottom: 1px solid var(--soft-line); }
  .breadcrumb { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px; }
  .breadcrumb a { color: var(--warm-grey); }
  .breadcrumb a:hover { color: var(--gold); }
  .breadcrumb .curr { color: var(--ink); }
  .cat-hero h1 { max-width: 960px; font-size: clamp(44px, 6vw, 78px); }
  .cat-hero .lead { max-width: 680px; margin-top: 32px; font-size: 22px; }
  .cat-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
  .trust-chip { margin-top: 28px; display: inline-flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: 0.04em; color: var(--warm-grey); font-family: var(--f-mono); }
  .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
  .hero-meta { margin-top: 72px; padding-top: 32px; border-top: 1px solid var(--soft-line); display: grid; grid-template-columns: repeat(4, 1fr); }
  .hero-meta-item { padding: 0 20px 0 0; border-right: 1px solid var(--soft-line); }
  .hero-meta-item:last-child { border-right: none; padding-right: 0; }
  .hero-meta-item:not(:first-child) { padding-left: 20px; }
  .hero-meta-item .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
  .hero-meta-item .v { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; font-variation-settings: "opsz" 48; }
  .hero-meta-item .v small { display: block; font-family: var(--f-sans); font-size: 13px; color: var(--warm-grey); margin-top: 4px; letter-spacing: 0; }
  @media (max-width: 900px) {
    .cat-hero { padding: 80px 0 72px; }
    .hero-meta { grid-template-columns: 1fr 1fr; }
    .hero-meta-item { padding: 16px 16px 16px 0; border-bottom: 1px solid var(--soft-line); }
    .hero-meta-item:nth-child(2n) { border-right: none; padding-right: 0; }
    .hero-meta-item:nth-last-child(-n+2) { border-bottom: none; }
    .hero-meta-item:not(:first-child) { padding-left: 16px; }
    .hero-meta-item:nth-child(odd) { padding-left: 0; }
  }

  /* OM STRIP */
  .om-strip { padding: 96px 0; background: var(--slate); color: var(--paper); }
  .om-grid { display: grid; grid-template-columns: 0.9fr 2.1fr; gap: 64px; align-items: start; }
  .om-grid .head h3 { color: var(--paper); font-size: clamp(24px, 2.4vw, 30px); max-width: 420px; }
  .om-grid .head h3 em { color: var(--gold); }
  .om-principles { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(250,250,247,0.15); }
  .om-principle { padding: 24px 20px 24px 0; border-right: 1px solid rgba(250,250,247,0.15); }
  .om-principle:last-child { border-right: none; padding-right: 0; }
  .om-principle:not(:first-child) { padding-left: 20px; }
  .om-principle .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 10px; }
  .om-principle .v { font-family: var(--f-sans); font-weight: 500; font-size: 15px; color: var(--paper); line-height: 1.4; }
  @media (max-width: 900px) {
    .om-grid { grid-template-columns: 1fr; gap: 32px; }
    .om-principles { grid-template-columns: 1fr 1fr; }
    .om-principle { border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); padding: 20px; }
    .om-principle:nth-child(2n) { border-right: none; }
    .om-principle:nth-last-child(-n+2) { border-bottom: none; }
    .om-principle:not(:first-child) { padding-left: 20px; }
  }

  /* SIX PILLARS (indexed rows) */
  .pillars { background: var(--paper); padding: 140px 0; }
  .pillars .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 80px; }
  .pillars h2 em { color: var(--gold); }
  .pillars .head p { color: var(--warm-grey); font-size: 17px; max-width: 460px; margin: 0; }
  .pillar-list { border-top: 1px solid var(--ink); }
  .pillar {
    display: grid; grid-template-columns: 80px 1.4fr 1fr;
    gap: 40px; align-items: start;
    padding: 48px 0;
    border-bottom: 1px solid var(--soft-line);
  }
  .pillar:last-child { border-bottom: none; }
  .pillar .n { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; padding-top: 8px; }
  .pillar .body h3 { font-size: clamp(26px, 2.6vw, 34px); margin-bottom: 14px; }
  .pillar .body h3 em { color: var(--gold); }
  .pillar .body p { font-size: 16px; color: var(--warm-grey); margin: 0; max-width: 480px; }
  .pillar .tags { display: grid; gap: 8px; padding-top: 10px; }
  .pillar .tag { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--ink); text-transform: uppercase; display: flex; gap: 10px; }
  .pillar .tag::before { content: "—"; color: var(--gold); flex: none; }
  @media (max-width: 900px) {
    .pillars { padding: 96px 0; }
    .pillars .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
    .pillar { grid-template-columns: 1fr; gap: 16px; padding: 32px 0; }
  }

  /* WORKFLOW (white) — three rhythm modes */
  .flows { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .flows .head { max-width: 720px; margin-bottom: 72px; }
  .flows h2 em { color: var(--gold); }
  .flows-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--soft-line); }
  .flow { padding: 40px 32px 40px 0; border-right: 1px solid var(--soft-line); display: grid; grid-template-rows: auto auto 1fr auto; gap: 16px; }
  .flow:last-child { border-right: none; padding-right: 0; }
  .flow:not(:first-child) { padding-left: 32px; }
  .flow .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .flow h3 { font-size: 24px; margin: 0; }
  .flow h3 em { color: var(--gold); }
  .flow p { font-size: 14px; line-height: 1.6; color: var(--warm-grey); margin: 0; }
  .flow .diag {
    padding: 18px 0; border-top: 1px solid var(--soft-line);
    font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--ink); text-transform: uppercase;
    display: flex; flex-wrap: wrap; gap: 8px 12px; align-items: center; line-height: 1.7;
  }
  .flow .diag .step { background: var(--paper); border: 1px solid var(--soft-line); padding: 6px 10px; border-radius: 3px; }
  .flow .diag .step.gold { background: var(--gold); border-color: var(--gold); color: var(--ink); }
  .flow .diag .arr { color: var(--gold); }
  @media (max-width: 900px) {
    .flows { padding: 96px 0; }
    .flows-grid { grid-template-columns: 1fr; }
    .flow { padding: 32px 0; border-right: none; border-bottom: 1px solid var(--soft-line); }
    .flow:last-child { border-bottom: none; }
    .flow:not(:first-child) { padding-left: 0; }
  }

  /* INFRASTRUCTURE (paper split) */
  .infra { padding: 140px 0; }
  .infra-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
  .infra h2 em { color: var(--gold); }
  .infra .lead { color: var(--warm-grey); max-width: 440px; margin-top: 24px; }
  .infra-req { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--soft-line); display: grid; gap: 0; }
  .ir { padding: 16px 0; border-bottom: 1px solid var(--soft-line); display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: center; }
  .ir:last-child { border-bottom: none; }
  .ir .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
  .ir .v { font-family: var(--f-display); font-weight: 400; font-size: 17px; line-height: 1.3; font-variation-settings: "opsz" 48; }
  .ir .v em { color: var(--gold); font-style: italic; font-weight: 300; }
  .ir .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ink); }

  .infra-figure { position: relative; aspect-ratio: 4/5; border-radius: 12px; overflow: hidden; background: var(--slate); box-shadow: 0 40px 80px -32px rgba(15,15,16,0.22); }
  .infra-figure img { width: 100%; height: 100%; object-fit: cover; }
  .infra-figure::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(28,28,30,0) 55%, rgba(28,28,30,0.55) 100%); pointer-events: none; }
  .infra-figure .band-label { position: absolute; top: 16px; left: 16px; z-index: 2; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(250,250,247,0.95); background: rgba(15,15,16,0.6); backdrop-filter: blur(6px); padding: 6px 10px; border-radius: 3px; display: inline-flex; align-items: center; gap: 8px; }
  .infra-figure .band-label .live { color: var(--gold); }
  .infra-figure .band-cap { position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2; display: flex; justify-content: space-between; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(250,250,247,0.88); }
  .infra-figure .band-cap .dot { color: var(--gold); }
  @media (max-width: 900px) { .infra { padding: 96px 0; } .infra-grid { grid-template-columns: 1fr; gap: 48px; } }

  /* WHO'S IN THE LOOP (slate) */
  .roles { background: var(--slate); color: var(--paper); padding: 140px 0; }
  .roles .head { max-width: 720px; margin-bottom: 72px; }
  .roles .eyebrow { color: var(--gold); }
  .roles h2 { color: var(--paper); }
  .roles h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .roles .lead { color: rgba(250,250,247,0.75); }
  .roles-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(250,250,247,0.2); border-bottom: 1px solid rgba(250,250,247,0.2); }
  .role { padding: 48px 32px 48px 0; border-right: 1px solid rgba(250,250,247,0.15); }
  .role:last-child { border-right: none; padding-right: 0; }
  .role:not(:first-child) { padding-left: 32px; }
  .role .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 16px; }
  .role h3 { font-size: 22px; color: var(--paper); margin-bottom: 12px; }
  .role h3 em { color: var(--gold); }
  .role p { font-size: 13px; color: rgba(250,250,247,0.78); line-height: 1.6; margin: 0; }
  @media (max-width: 900px) {
    .roles { padding: 96px 0; }
    .roles-grid { grid-template-columns: 1fr 1fr; }
    .role { padding: 32px 20px; border-right: 1px solid rgba(250,250,247,0.15); border-bottom: 1px solid rgba(250,250,247,0.15); }
    .role:nth-child(2n) { border-right: none; }
    .role:nth-last-child(-n+2) { border-bottom: none; }
    .role:not(:first-child) { padding-left: 20px; }
  }

  /* PROOF / TRUST */
  .page-hitl .proof{ background: var(--paper); padding: 140px 0; border-top: 1px solid var(--soft-line); }
  .page-hitl .proof .head{ max-width: 720px; margin-bottom: 72px; }
  .page-hitl .proof h2 em{ color: var(--gold); }
  .page-hitl .proof-grid{ display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .page-hitl .proof-cell{ padding: 48px 32px 48px 0; border-right: 1px solid var(--soft-line); }
  .page-hitl .proof-cell:last-child{ border-right: none; padding-right: 0; }
  .page-hitl .proof-cell:not(:first-child){ padding-left: 32px; }
  .page-hitl .proof-cell .n{ font-family: var(--f-display); font-size: clamp(44px, 4.8vw, 64px); line-height: 1; font-variation-settings: "opsz" 96; margin-bottom: 16px; }
  .page-hitl .proof-cell .n sup{ font-size: 0.45em; color: var(--gold); vertical-align: top; margin-left: 3px; }
  .page-hitl .proof-cell .l{ font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--warm-grey); text-transform: uppercase; margin-bottom: 10px; }
  .page-hitl .proof-cell .d{ font-size: 13px; color: var(--warm-grey); line-height: 1.55; margin: 0; }
  .page-hitl .proof-foot{ margin-top: 40px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.06em; color: var(--warm-grey); text-transform: uppercase; display: flex; gap: 24px; flex-wrap: wrap; }
  .page-hitl .proof-foot .sep{ color: rgba(15,15,16,0.25); }
  .page-hitl .proof-foot .g{ color: var(--gold); }
  @media (max-width: 900px) { .page-hitl .proof{ padding: 96px 0; } .page-hitl .proof-grid{ grid-template-columns: 1fr 1fr; } .page-hitl .proof-cell{ border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); padding: 32px 20px; } .page-hitl .proof-cell:nth-child(2n){ border-right: none; } .page-hitl .proof-cell:nth-last-child(-n+2){ border-bottom: none; } .page-hitl .proof-cell:not(:first-child){ padding-left: 20px; } }

  /* DISCOVERY (ink) */
  .discovery { background: var(--ink); color: var(--paper); padding: 140px 0; }
  .discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
  .discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(40px, 5vw, 60px); }
  .discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
  .discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
  .discovery .eyebrow { color: var(--gold); }
  .d-paths { display: grid; gap: 16px; }
  .d-path { padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px; color: var(--paper); transition: background .2s ease, color .2s ease, border-color .2s ease; }
  .d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
  .d-path.primary:hover, .d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
  .d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; }
  .d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  .d-path .a { font-size: 22px; }
  @media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

  /* FOOTER */
  footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; }
  .foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
  footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
  footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
  footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
  footer a:hover { color: var(--paper); }
  footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
  .footer-logo img { height: 140px; margin-bottom: 24px; }
  .foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
  @media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

  /* HANDOFF */
  .handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 100px 0 140px; }
  .handoff .container { max-width: 920px; }
  .handoff h2 { font-size: 40px; margin-bottom: 16px; }
  .handoff .intro { color: var(--warm-grey); font-size: 17px; max-width: 680px; margin-bottom: 48px; }
  .handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 17px; margin: 40px 0 10px; }
  .handoff p, .handoff li { font-size: 15px; line-height: 1.65; }
  .handoff ul { padding-left: 22px; margin: 0 0 1em; }
  .handoff code { font-family: var(--f-mono); font-size: 13px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
  .handoff .complete-note { margin-top: 48px; padding: 24px 28px; background: var(--ink); color: var(--paper); border-radius: 10px; font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em; }
  .handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

  /* Scroll reveal — fade + rise when section enters viewport */
  .reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
    will-change: opacity, transform;
  }
  .reveal.is-visible { opacity: 1; transform: translateY(0); }
  @media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
  }

  /* Count-up — prevent layout shift while animating */
  .count-up { font-variant-numeric: tabular-nums; }

/* ========== services/annotation/lidar-3d/index.html  (.page-annotation-lidar) ========== */
/* LiDAR-specific — a synthetic point-cloud placeholder with scan lines, styled to feel like a viewer */
  .lidar-placeholder { position: relative; aspect-ratio: 4/3; border-radius: 12px; overflow: hidden; background: radial-gradient(ellipse at 30% 40%, #1f1f22 0%, #0a0a0c 80%); box-shadow: 0 40px 80px -32px rgba(15,15,16,0.35); }
  .lidar-placeholder.small { aspect-ratio: 4/3; box-shadow: 0 30px 60px -28px rgba(15,15,16,0.3); border-radius: 10px; }
  .lidar-placeholder svg { width: 100%; height: 100%; display: block; }
  .lidar-placeholder .ov-label { position: absolute; top: 14px; left: 14px; z-index: 2; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(250,250,247,0.9); background: rgba(15,15,16,0.6); backdrop-filter: blur(6px); padding: 5px 9px; border-radius: 3px; display: inline-flex; align-items: center; gap: 8px; }
  .lidar-placeholder .ov-label .live { color: var(--gold); }
  .lidar-placeholder .ov-note { position: absolute; bottom: 14px; right: 14px; z-index: 2; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(250,250,247,0.5); }
  .lidar-hero-figure { aspect-ratio: 3/2; margin: 0; }
  .lidar-hero-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 1; }
  .lidar-hero-figure .ov-label, .lidar-hero-figure .ov-note { z-index: 3; }
  .lidar-tech-figure { margin: 0; }
  .lidar-tech-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; z-index: 1; }
  .lidar-tech-figure .ov-label { z-index: 3; }
  .lidar-tech-figure.wide { aspect-ratio: 3/2; }
  .lidar-tech-figure.wide .lidar-tech-img { object-fit: contain; background: #000; }
  .lidar-tech-figure.wide.cover .lidar-tech-img { object-fit: cover; }

/* ========== Shared annotation sub-page layout (annotation-subpage.css) ========== */
/* ============ SHARED SUB-PAGE STYLES — Impact Outsourcing annotation sub-pages ============ */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--f-sans); background: var(--paper); color: var(--ink);
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  font-size: 16px; line-height: 1.55;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
.eyebrow { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); margin: 0 0 20px; }
h1, h2, h3, h4 { font-family: var(--f-display); font-weight: 400; letter-spacing: -0.015em; margin: 0; color: var(--ink); text-wrap: balance; }
h1 { font-size: clamp(40px, 5.6vw, 72px); line-height: 1.05; font-variation-settings: "opsz" 144; hyphens: none; }
h2 { font-size: clamp(32px, 3.8vw, 48px); line-height: 1.06; font-variation-settings: "opsz" 96; }
h3 { font-size: clamp(22px, 2vw, 26px); line-height: 1.2; font-variation-settings: "opsz" 48; }
h1 em, h2 em, h3 em { font-style: italic; font-weight: 300; color: var(--gold); }
p { margin: 0 0 1em; text-wrap: pretty; }
.lead { font-size: 20px; line-height: 1.55; color: var(--warm-grey); }
.btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-sans); font-weight: 500; font-size: 15px; letter-spacing: 0.01em; padding: 16px 32px; border-radius: 6px; transition: background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease; cursor: pointer; border: 1px solid transparent; }
.btn-primary { background: var(--ink); color: var(--paper); }
.btn-primary:hover { background: var(--gold); color: var(--ink); }
.btn-ghost { background: transparent; color: var(--ink); border: 1px solid var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn-ghost-light { background: transparent; color: var(--paper); border: 1px solid rgba(250,250,247,0.4); }
.btn-ghost-light:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.arrow { display: inline-block; transition: transform .2s ease; }
.btn:hover .arrow { transform: translateX(3px); }

/* NAV */
.nav { position: sticky; top: 0; z-index: 50; background: rgba(250,250,247,0.88); backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px); border-bottom: 1px solid var(--soft-line); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 104px; }
.logo img { max-height: 48px; width: auto; display: block; }
.nav-links { display: flex; gap: 32px; font-size: 14px; font-weight: 500; }
.nav-links a { color: var(--ink); opacity: 0.85; }
.nav-links a:hover { opacity: 1; color: var(--gold); }
.nav-links a.active { color: var(--gold); opacity: 1; }
.nav-cta .btn { padding: 10px 20px; font-size: 14px; }
@media (max-width: 900px) { .nav-links { display: none; } }
.banner { background: var(--ink); color: var(--paper); text-align: center; padding: 14px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }
.banner .dot { color: var(--gold); }

/* HERO */
.sub-hero { padding: 120px 0 0; }
.sub-hero .breadcrumb { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--warm-grey); text-transform: uppercase; margin-bottom: 32px; }
.sub-hero .breadcrumb a { color: var(--warm-grey); }
.sub-hero .breadcrumb a:hover { color: var(--gold); }
.sub-hero .breadcrumb span.curr { color: var(--ink); }
.sub-hero-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 80px; align-items: end; padding-bottom: 96px; border-bottom: 1px solid var(--soft-line); }
.sub-hero h1 em { color: var(--gold); }
.sub-hero .lead { max-width: 520px; margin-top: 32px; font-size: 20px; }
.sub-hero-ctas { margin-top: 40px; display: flex; gap: 12px; flex-wrap: wrap; }
.sub-hero .trust-chip { margin-top: 28px; display: inline-flex; align-items: center; gap: 10px; font-size: 12px; letter-spacing: 0.04em; color: var(--warm-grey); font-family: var(--f-mono); }
.sub-hero .trust-chip .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--gold); }
.sub-hero-figure { position: relative; aspect-ratio: 4/3; border-radius: 12px; overflow: hidden; background: var(--slate); box-shadow: 0 40px 80px -32px rgba(15,15,16,0.25); }
.sub-hero-figure img { width: 100%; height: 100%; object-fit: cover; }
.sub-hero-figure .label { position: absolute; top: 16px; left: 16px; z-index: 2; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(250,250,247,0.95); background: rgba(15,15,16,0.65); backdrop-filter: blur(6px); padding: 6px 10px; border-radius: 3px; display: inline-flex; align-items: center; gap: 8px; }
.sub-hero-figure .label .live { color: var(--gold); }
@media (max-width: 900px) { .sub-hero { padding: 80px 0 0; } .sub-hero-grid { grid-template-columns: 1fr; gap: 48px; padding-bottom: 64px; } }

/* AT A GLANCE (hero meta) */
.sub-glance { padding: 48px 0 96px; background: var(--paper); }
.sub-glance-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.sub-glance-cell { padding: 0 20px 0 0; border-right: 1px solid var(--soft-line); }
.sub-glance-cell:last-child { border-right: none; padding-right: 0; }
.sub-glance-cell:not(:first-child) { padding-left: 20px; }
.sub-glance-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
.sub-glance-cell .v { font-family: var(--f-display); font-weight: 400; font-size: 22px; line-height: 1.2; letter-spacing: -0.01em; font-variation-settings: "opsz" 48; }
.sub-glance-cell .v small { display: block; font-family: var(--f-sans); font-weight: 400; font-size: 13px; color: var(--warm-grey); margin-top: 4px; }
@media (max-width: 900px) {
  .sub-glance { padding: 32px 0 64px; }
  .sub-glance-grid { grid-template-columns: 1fr 1fr; }
  .sub-glance-cell { padding: 16px 16px 16px 0; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
  .sub-glance-cell:nth-child(2n) { border-right: none; padding-right: 0; }
  .sub-glance-cell:nth-last-child(-n+2) { border-bottom: none; }
  .sub-glance-cell:not(:first-child) { padding-left: 16px; }
  .sub-glance-cell:nth-child(odd) { padding-left: 0; }
}

/* TECHNIQUE GALLERY */
.gallery { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
.gallery .head { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: end; margin-bottom: 72px; }
.gallery .head h2 em { color: var(--gold); }
.gallery .head p { color: var(--warm-grey); font-size: 17px; margin: 0; max-width: 440px; }
.tech-row { display: grid; grid-template-columns: 1fr 1.3fr; gap: 64px; align-items: center; padding: 64px 0; border-top: 1px solid var(--soft-line); }
.tech-row:first-of-type { border-top: 1px solid var(--ink); }
.tech-row.reverse { grid-template-columns: 1.3fr 1fr; }
.tech-row.reverse .tech-figure { order: 1; }
.tech-row.reverse .tech-body { order: 2; }
.tech-body .k { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 16px; }
.tech-body h3 { font-size: clamp(28px, 3vw, 38px); line-height: 1.05; margin-bottom: 16px; }
.tech-body h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
.tech-body p { font-size: 16px; color: var(--ink); max-width: 460px; line-height: 1.6; margin-bottom: 20px; }
.tech-body ul { list-style: none; padding: 0; margin: 20px 0 0; padding-top: 20px; border-top: 1px solid var(--soft-line); display: grid; gap: 8px; max-width: 460px; }
.tech-body li { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.03em; color: var(--ink); display: flex; gap: 10px; }
.tech-body li::before { content: "—"; color: var(--gold); flex: none; }
.tech-figure { position: relative; aspect-ratio: 4/3; border-radius: 10px; overflow: hidden; background: var(--slate); box-shadow: 0 30px 60px -28px rgba(15,15,16,0.2); }
.tech-figure img { width: 100%; height: 100%; object-fit: cover; }
.tech-figure .tag { position: absolute; bottom: 14px; left: 14px; z-index: 2; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: rgba(250,250,247,0.92); background: rgba(15,15,16,0.6); backdrop-filter: blur(6px); padding: 5px 9px; border-radius: 3px; }
.tech-figure.placeholder { background: var(--slate); display: grid; place-items: center; color: rgba(250,250,247,0.5); padding: 48px; text-align: center; box-shadow: none; border: 1px dashed rgba(250,250,247,0.25); }
.tech-figure.placeholder .p-svg { width: 72px; height: 72px; margin: 0 auto 20px; opacity: 0.4; }
.tech-figure.placeholder .p-svg svg { width: 100%; height: 100%; display: block; }
.tech-figure.placeholder .p-label { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(250,250,247,0.55); margin-bottom: 8px; }
.tech-figure.placeholder .p-desc { font-family: var(--f-sans); font-size: 13px; color: rgba(250,250,247,0.75); line-height: 1.5; max-width: 300px; }
.tech-figure.cuboid-figure { background: var(--ink) !important; box-shadow: 0 30px 60px -28px rgba(15,15,16,0.2); overflow: hidden; }
.tech-figure.cuboid-figure img { object-fit: cover !important; }
.tech-figure.cuboid-figure .tag { color: rgba(250,250,247,0.95); background: rgba(15,15,16,0.72); backdrop-filter: blur(6px); border: 0; }
.tech-figure.video-tracking-figure { background: var(--paper) !important; box-shadow: none !important; border-radius: 0 !important; overflow: visible !important; aspect-ratio: 3/2 !important; }
.tech-figure.video-tracking-figure img { object-fit: contain !important; background: transparent !important; }
.tech-figure.video-tracking-figure .tag { color: var(--ink); background: rgba(255,255,255,0.9); border: 1px solid var(--soft-line); backdrop-filter: blur(6px); }
.tech-figure.keypoint-figure { background: var(--paper) !important; box-shadow: none !important; border-radius: 0 !important; overflow: visible !important; }
.tech-figure.keypoint-figure img { object-fit: contain !important; background: transparent !important; mix-blend-mode: multiply; }
.tech-figure.keypoint-figure .tag { color: var(--ink); background: rgba(255,255,255,0.9); border: 1px solid var(--soft-line); backdrop-filter: blur(6px); }
figure.tech-figure.dual { display: grid !important; grid-template-columns: 1fr 1fr; gap: 24px; background: transparent !important; aspect-ratio: auto !important; box-shadow: none !important; border-radius: 0 !important; overflow: visible !important; }
figure.tech-figure.dual .dual-cell { position: relative; overflow: visible; background: transparent; border-radius: 0; aspect-ratio: auto; box-shadow: none; }
figure.tech-figure.dual .dual-cell img { width: 100%; height: auto; object-fit: contain; display: block; background: transparent; mix-blend-mode: multiply; }
figure.tech-figure.dual > .tag { display: none !important; }
figure.tech-figure.dual .dual-cell .sub-tag { position: absolute; top: 12px; left: 12px; z-index: 2; font-family: var(--f-mono); font-size: 9px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink); background: rgba(255,255,255,0.9); backdrop-filter: blur(6px); border: 1px solid var(--soft-line); padding: 5px 8px; border-radius: 3px; }
@media (max-width: 900px) {
  .gallery { padding: 96px 0; }
  .gallery .head { grid-template-columns: 1fr; gap: 24px; margin-bottom: 40px; }
  .tech-row, .tech-row.reverse { grid-template-columns: 1fr; gap: 32px; padding: 40px 0; }
  .tech-row.reverse .tech-figure { order: 2; }
  .tech-row.reverse .tech-body { order: 1; }
}

/* DOMAIN / USE-CASE STRIP (slate) */
.domain { background: var(--slate); color: var(--paper); padding: 140px 0; }
.domain .eyebrow { color: var(--gold); }
.domain h2 { color: var(--paper); max-width: 720px; }
.domain h2 em { color: var(--gold); }
.domain .lead { color: rgba(250,250,247,0.75); max-width: 640px; margin-top: 24px; font-size: 19px; }
.domain-grid { margin-top: 72px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid rgba(250,250,247,0.15); }
.domain-cell { padding: 32px 28px 32px 0; border-right: 1px solid rgba(250,250,247,0.15); display: grid; grid-template-rows: auto auto auto 1fr; gap: 10px; }
.domain-cell:last-child { border-right: none; padding-right: 0; }
.domain-cell:not(:first-child) { padding-left: 28px; }
.domain-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
.domain-cell h4 { font-family: var(--f-display); font-size: 22px; font-weight: 400; color: var(--paper); line-height: 1.15; font-variation-settings: "opsz" 48; margin: 0; }
.domain-cell p { font-size: 13px; line-height: 1.55; color: rgba(250,250,247,0.75); margin: 0; }
.domain-cell .meta { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; color: rgba(250,250,247,0.55); text-transform: uppercase; padding-top: 12px; border-top: 1px solid rgba(250,250,247,0.12); margin-top: auto; }
@media (max-width: 900px) {
  .domain { padding: 96px 0; }
  .domain-grid { grid-template-columns: 1fr 1fr; }
  .domain-cell { padding: 24px 20px 24px 0; border-bottom: 1px solid rgba(250,250,247,0.15); }
  .domain-cell:nth-child(2n) { border-right: none; padding-right: 0; padding-left: 20px; }
  .domain-cell:nth-last-child(-n+2) { border-bottom: none; }
}

/* SCHEMA SPECIFICS (paper) */
.schema { padding: 140px 0; background: var(--paper); }
.schema .head { max-width: 720px; margin-bottom: 64px; }
.schema h2 em { color: var(--gold); }
.schema .lead { color: var(--warm-grey); margin-top: 20px; }
.schema-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--ink); border-left: 1px solid var(--soft-line); }
.schema-cell { padding: 36px 32px; border-right: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); background: var(--paper); display: grid; grid-template-rows: auto auto 1fr; gap: 10px; }
.schema-cell:nth-child(6n+1), .schema-cell:nth-child(6n+3), .schema-cell:nth-child(6n+5) { background: var(--white); }
.schema-cell .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; }
.schema-cell h3 { font-size: 22px; line-height: 1.15; margin: 0; }
.schema-cell h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
.schema-cell p { font-size: 13px; line-height: 1.55; color: var(--warm-grey); margin: 0; }
@media (max-width: 900px) { .schema { padding: 96px 0; } .schema-grid { grid-template-columns: 1fr; } }
@media (max-width: 1100px) and (min-width: 901px) { .schema-grid { grid-template-columns: 1fr 1fr; } }

/* FAQ (white) */
.faq { padding: 140px 0; background: var(--white); border-top: 1px solid var(--soft-line); }
.faq .head { max-width: 720px; margin-bottom: 48px; }
.faq h2 em { color: var(--gold); }
.faq-list { border-top: 1px solid var(--ink); }
.faq-item { border-bottom: 1px solid var(--soft-line); padding: 32px 0; display: grid; grid-template-columns: 80px 1fr; gap: 48px; align-items: start; }
.faq-item .n { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; padding-top: 4px; }
.faq-item h3 { font-size: clamp(22px, 2.2vw, 28px); line-height: 1.15; margin-bottom: 14px; }
.faq-item h3 em { color: var(--gold); font-style: italic; font-weight: 300; }
.faq-item p { font-size: 15px; line-height: 1.65; color: var(--warm-grey); margin: 0; max-width: 680px; }
@media (max-width: 900px) { .faq { padding: 96px 0; } .faq-item { grid-template-columns: 1fr; gap: 12px; } }

/* CROSS-SELL STRIP (other tracks) */
.other-tracks { padding: 120px 0; background: var(--paper); border-top: 1px solid var(--soft-line); border-bottom: 1px solid var(--soft-line); }
.other-tracks .head { margin-bottom: 48px; max-width: 720px; }
.other-tracks h2 em { color: var(--gold); }
.other-tracks .head p { color: var(--warm-grey); font-size: 16px; margin-top: 16px; }
.ot-list { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border-top: 1px solid var(--ink); }
.ot-link { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px; padding: 36px 32px 36px 0; border-bottom: 1px solid var(--soft-line); transition: background .2s ease; }
.ot-link:nth-child(2n-1) { border-right: 1px solid var(--soft-line); padding-right: 32px; }
.ot-link:nth-child(2n) { padding-left: 32px; padding-right: 0; }
.ot-link:hover { background: var(--white); }
.ot-link:hover .ot-arrow { transform: translate(6px, -6px); color: var(--gold); }
.ot-link .k { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.1em; color: var(--gold); text-transform: uppercase; margin-bottom: 8px; }
.ot-link .t { font-family: var(--f-display); font-size: clamp(22px, 2.4vw, 28px); line-height: 1.1; margin-bottom: 6px; }
.ot-link .t em { color: var(--gold); font-style: italic; font-weight: 300; }
.ot-link .d { font-size: 13px; color: var(--warm-grey); line-height: 1.5; max-width: 380px; margin: 0; }
.ot-arrow { font-family: var(--f-display); font-size: 28px; color: var(--ink); font-style: italic; font-weight: 300; transition: transform .25s ease, color .25s ease; align-self: start; padding-top: 6px; }
@media (max-width: 900px) { .ot-list { grid-template-columns: 1fr; } .ot-link, .ot-link:nth-child(2n-1), .ot-link:nth-child(2n) { border-right: none; padding: 28px 0; } }

/* DISCOVERY CTA */
.discovery { background: var(--ink); color: var(--paper); padding: 140px 0; }
.discovery .grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: end; }
.discovery h2 { color: var(--paper); max-width: 680px; font-size: clamp(36px, 4.4vw, 54px); }
.discovery h2 em { color: var(--gold); font-style: italic; font-weight: 300; }
.discovery .lead { color: rgba(250,250,247,0.7); margin-top: 24px; max-width: 520px; font-size: 19px; }
.discovery .eyebrow { color: var(--gold); }
.d-paths { display: grid; gap: 16px; }
.d-path { padding: 28px 32px; border: 1px solid rgba(250,250,247,0.25); border-radius: 10px; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 20px; background: transparent; color: var(--paper); transition: background .2s ease, color .2s ease, border-color .2s ease; }
.d-path.primary { background: var(--gold); color: var(--ink); border-color: var(--gold); }
.d-path.primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.d-path.secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.d-path .h { font-family: var(--f-display); font-size: 22px; margin-bottom: 4px; font-weight: 400; }
.d-path .s { font-size: 13px; opacity: 0.75; font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
.d-path .a { font-size: 22px; }
@media (max-width: 900px) { .discovery { padding: 96px 0; } .discovery .grid { grid-template-columns: 1fr; gap: 48px; } }

/* FOOTER */
footer { background: var(--ink); color: var(--paper); padding: 80px 0 40px; border-top: 1px solid rgba(250,250,247,0.1); }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; }
footer h4 { font-family: var(--f-sans); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 18px; }
footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
footer a { font-size: 14px; color: rgba(250,250,247,0.75); }
footer a:hover { color: var(--paper); }
footer .brand p { color: rgba(250,250,247,0.55); font-size: 14px; max-width: 300px; }
.footer-logo img { height: 140px; width: auto; display: block; margin-bottom: 24px; }
.foot-bottom { margin-top: 64px; padding-top: 24px; border-top: 1px solid rgba(250,250,247,0.1); display: flex; justify-content: space-between; font-size: 12px; color: rgba(250,250,247,0.5); font-family: var(--f-mono); letter-spacing: 0.04em; text-transform: uppercase; }
@media (max-width: 900px) { .foot-grid { grid-template-columns: 1fr 1fr; } }

/* HANDOFF */
.handoff { background: var(--paper); border-top: 8px solid var(--ink); padding: 80px 0 120px; }
.handoff .container { max-width: 920px; }
.handoff h2 { font-size: 36px; margin-bottom: 14px; }
.handoff .intro { color: var(--warm-grey); font-size: 16px; max-width: 680px; margin-bottom: 40px; }
.handoff h3 { font-family: var(--f-sans); font-weight: 600; font-size: 16px; letter-spacing: 0; margin: 32px 0 10px; color: var(--ink); }
.handoff h3:first-of-type { margin-top: 0; }
.handoff p, .handoff li { font-size: 14px; line-height: 1.65; color: var(--ink); }
.handoff ul { padding-left: 22px; margin: 0 0 1em; }
.handoff code { font-family: var(--f-mono); font-size: 12px; background: var(--white); border: 1px solid var(--soft-line); border-radius: 4px; padding: 2px 6px; }
.handoff .complete-note { margin-top: 40px; padding: 22px 26px; background: var(--ink); color: var(--paper); border-radius: 10px; font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.04em; }
.handoff .complete-note .tick { color: var(--gold); margin-right: 8px; }

/* Scroll reveal — fade + rise when section enters viewport */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms cubic-bezier(.2,.6,.2,1), transform 700ms cubic-bezier(.2,.6,.2,1);
  will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* Count-up — prevent layout shift while animating */
.count-up { font-variant-numeric: tabular-nums; }

/* ========== Global enhancements ========== */
/* Focus-visible: gold ring, 2px offset, matches brand */
:where(a, button, .btn, [tabindex]):focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: 4px;
}

/* Reduced motion guard (the .reveal block already has one; this is global) */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Print styles: legible, neutral, no decorative sections */
@media print {
  .nav, .banner, .final-cta, .discovery, .join, .final { display: none !important; }
  body { background: white !important; color: black !important; font-size: 11pt; line-height: 1.4; }
  a { color: black !important; text-decoration: underline; }
  a[href^="http"]::after { content: " (" attr(href) ")"; font-size: 9pt; }
  img { max-width: 100% !important; break-inside: avoid; }
  h1, h2, h3 { break-after: avoid; page-break-after: avoid; }
  section { break-inside: avoid-page; }
}
