/* ============================================================
   Sub-page styles — extends styles.css
============================================================ */

/* Breadcrumb ─────────────────────────────────────────────── */
.crumb {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em;
  color: rgba(255,255,255,.45); text-transform: uppercase;
  margin-bottom: 24px;
}
.crumb a { color: var(--gold); }
.crumb a:hover { color: var(--gold-hi); }
.crumb .sep { color: rgba(255,255,255,.25); }

/* Sub-page hero ──────────────────────────────────────────── */
.sub-hero {
  position: relative; background: #001122; overflow: hidden;
  padding: 80px 0 80px;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.sub-hero-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 80% 20%, rgba(248,178,74,.12), transparent 60%);
}
.sub-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(248,178,74,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(248,178,74,.05) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at 50% 50%, #000 0%, transparent 70%);
}
.sub-hero-inner {
  position: relative;
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 64px; align-items: end;
}
.sub-hero-inner > :only-child { grid-column: 1 / -1; max-width: 880px; }
.sub-hero-title {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(36px, 8.5vw, 88px);
  line-height: 1; letter-spacing: -0.03em;
  margin: 18px 0 22px;
  color: #fff; text-transform: uppercase;
}
.sub-hero-title .gold { color: var(--gold); }
.sub-hero-title .stroke {
  color: var(--gold);
}
.sub-hero-sub {
  font-family: var(--serif); font-size: 20px; line-height: 1.55;
  color: rgba(255,255,255,.78); max-width: 640px; margin: 0;
}
.sub-hero-stats {
  display: flex; flex-direction: column; gap: 16px;
  border-left: 1px solid rgba(248,178,74,.3);
  padding-left: 32px;
}
.sub-hero-stat {
  display: flex; flex-direction: column; gap: 4px;
}
.sub-hero-stat b {
  font-family: var(--display); font-weight: 900; font-size: 40px;
  color: var(--gold); letter-spacing: -0.02em; line-height: 1;
}
.sub-hero-stat span {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: rgba(255,255,255,.5); text-transform: uppercase;
}

/* Mega Menu ──────────────────────────────────────────────── */
.mega {
  position: absolute; left: 0; right: 0; top: 80px;
  background: rgba(0,17,34,.98);
  backdrop-filter: blur(20px);
  border-top: 1px solid rgba(248,178,74,.3);
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 25px 50px -8px rgba(0,0,0,.8);
  opacity: 0; pointer-events: none; transform: translateY(-8px);
  transition: opacity .2s ease, transform .2s ease;
  z-index: 40;
}
.mega.open { opacity: 1; pointer-events: auto; transform: none; }
.mega-inner {
  width: min(1440px, calc(100% - 64px));
  margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr 1fr 300px;
  gap: 48px;
  padding: 48px 32px 56px;
}
.mega-inner[data-cols="2"] { grid-template-columns: 1fr 1fr 300px; }
.mega-inner[data-cols="3"] { grid-template-columns: 1fr 1fr 1fr 300px; }
.mega-col h6 {
  font-family: var(--mono); font-size: 10px; letter-spacing: .25em;
  color: var(--gold); text-transform: uppercase;
  margin: 0 0 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(248,178,74,.2);
}
.mega-col a {
  display: block; padding: 8px 0;
  font-family: var(--sans); font-size: 15px; color: rgba(255,255,255,.85);
  transition: color .15s ease, transform .15s ease;
}
.mega-col a:hover {
  color: var(--gold); transform: translateX(4px);
}
.mega-col a small {
  display: block;
  font-family: var(--serif); font-weight: 400; font-size: 12px;
  color: rgba(255,255,255,.4); letter-spacing: 0;
  text-transform: none; margin-top: 2px;
}
.mega-feature {
  background: linear-gradient(180deg, rgba(248,178,74,.08) 0%, rgba(0,0,0,.4) 100%);
  border: 1px solid rgba(248,178,74,.3);
  padding: 24px;
  display: flex; flex-direction: column;
  gap: 12px;
}
.mega-feature .mf-tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: var(--gold); text-transform: uppercase;
}
.mega-feature h5 {
  font-family: var(--display); font-weight: 900; font-size: 22px;
  color: #fff; margin: 0;
}
.mega-feature p {
  font-family: var(--serif); font-size: 13px; line-height: 1.5;
  color: rgba(255,255,255,.7); margin: 0;
}
.mega-feature a.mf-link {
  margin-top: auto;
  font-family: var(--sans); font-weight: 700; font-size: 13px;
  color: var(--gold); letter-spacing: .04em;
}

/* FORGE page ─────────────────────────────────────────────── */
.forge-modules {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px;
  margin-top: 48px;
}
.module {
  background: #0B0B0B; border: 1px solid rgba(248,178,74,.4);
  border-radius: 6px; padding: 26px;
  display: flex; flex-direction: column; gap: 14px;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
  cursor: pointer;
}
.module:hover {
  transform: translateY(-4px);
  background: linear-gradient(180deg, rgba(248,178,74,.06), #0B0B0B);
  border-color: var(--gold);
}
.module-icon {
  width: 48px; height: 48px;
  border: 1.5px solid var(--gold);
  display: grid; place-items: center;
  font-family: var(--mono); font-weight: 700; font-size: 18px;
  color: var(--gold);
}
.module h4 {
  font-family: var(--sans); font-weight: 700; font-size: 22px;
  color: #fff; margin: 0;
}
.module p {
  font-family: var(--sans); font-weight: 500; font-size: 14px;
  color: rgba(255,255,255,.7); margin: 0;
}
.module .tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: var(--gold); text-transform: uppercase;
}

/* Pipeline stages ────────────────────────────────────────── */
.pipeline {
  display: flex; flex-direction: column; gap: 12px;
  margin-top: 48px;
}
.stage {
  display: grid; grid-template-columns: 280px 1fr;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
  border-left: 3px solid var(--gold);
  transition: background .25s ease, border-color .25s ease;
}
.stage:hover { background: rgba(248,178,74,.04); border-left-color: var(--gold-hi); border-color: rgba(248,178,74,.25); }
.stage.active { border-color: var(--gold); border-left-width: 4px; background: rgba(248,178,74,.05); }
.stage-num {
  display: flex; align-items: center; gap: 18px;
  padding: 32px 28px;
  border-right: 1px solid rgba(255,255,255,.05);
}
.stage-num-i {
  font-family: var(--mono); font-size: 11px; letter-spacing: .25em;
  color: rgba(248,178,74,.7); text-transform: uppercase;
  width: 30px;
}
.stage-num-name {
  font-family: var(--display); font-weight: 700; font-size: 28px;
  color: #fff; letter-spacing: -0.01em;
}
.stage-body {
  padding: 32px 36px;
  display: flex; flex-direction: column; gap: 14px;
}
.stage-goal {
  font-family: var(--sans); font-weight: 700; font-size: 16px;
  color: var(--amber);
}
.stage-modules { display: flex; flex-direction: column; gap: 10px; }
.stage-mod {
  display: grid; grid-template-columns: 120px 1fr; gap: 16px;
  padding-top: 10px;
  border-top: 1px dashed rgba(255,255,255,.06);
}
.stage-mod:first-child { border-top: 0; padding-top: 0; }
.stage-mod b {
  font-family: var(--mono); font-size: 12px; letter-spacing: .15em;
  color: var(--gold); text-transform: uppercase;
}
.stage-mod span {
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  color: rgba(255,255,255,.75);
}

/* SDLC Timeline ──────────────────────────────────────────── */
.sdlc {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 12px;
  margin-top: 48px;
  padding: 32px 0;
}
.sdlc-step {
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
.sdlc-step::after {
  content: ""; position: absolute; right: -10px; top: 12px;
  width: 8px; height: 8px;
  border-top: 1.5px solid var(--gold);
  border-right: 1.5px solid var(--gold);
  transform: rotate(45deg);
}
.sdlc-step:last-child::after { display: none; }
.sdlc-icon {
  width: 24px; height: 24px; border: 1.5px solid var(--gold);
  display: grid; place-items: center;
  font-family: var(--mono); font-size: 11px; color: var(--gold);
}
.sdlc-step b {
  font-family: var(--sans); font-weight: 700; font-size: 16px; color: #fff;
}
.sdlc-step span {
  font-family: var(--sans); font-size: 13px; line-height: 1.5;
  color: rgba(255,255,255,.65);
}

/* Generic content ────────────────────────────────────────── */
.section-pad { padding: 120px 0; }
.section-head { text-align: center; margin-bottom: 24px; }
.section-head h2 { margin: 16px 0 14px; }
.section-head .lede { margin: 0 auto; }

/* Federal — services ─────────────────────────────────────── */
.services {
  display: flex; flex-direction: column; gap: 0;
  margin-top: 64px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.svc {
  display: grid; grid-template-columns: 80px 320px 1fr 200px;
  gap: 32px; align-items: center;
  padding: 32px 24px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: background .2s ease, padding .2s ease;
}
.svc:hover { background: rgba(248,178,74,.04); }
.svc-num {
  font-family: var(--mono); font-size: 14px; letter-spacing: .2em;
  color: rgba(248,178,74,.6);
}
.svc-name {
  font-family: var(--display); font-weight: 900; font-size: 26px;
  color: #fff; letter-spacing: -0.01em;
}
.svc-desc { font-family: var(--serif); font-size: 15px; line-height: 1.6; color: rgba(255,255,255,.7); }
.svc-tags {
  display: flex; flex-wrap: wrap; gap: 6px; justify-content: flex-end;
}
.svc-tag {
  padding: 4px 10px;
  font-family: var(--mono); font-size: 10px; letter-spacing: .15em;
  color: rgba(255,255,255,.65); border: 1px solid rgba(255,255,255,.15);
  text-transform: uppercase;
}
.svc:hover .svc-tag { border-color: rgba(248,178,74,.4); color: var(--gold); }

/* Certs strip ────────────────────────────────────────────── */
.certs {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 24px;
  padding: 56px 0;
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.cert {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
  text-align: center;
}
.cert-badge {
  width: 100%; aspect-ratio: 1; max-width: 130px;
  background: #fff; border-radius: 12px;
  display: grid; place-items: center;
  padding: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
  transition: transform .25s ease, box-shadow .25s ease;
}
.cert:hover .cert-badge {
  transform: translateY(-4px);
  box-shadow: 0 14px 34px rgba(0,0,0,.5);
}
.cert-badge img {
  width: 100%; height: 100%; object-fit: contain;
}
.cert span {
  font-family: var(--mono); font-size: 10px; letter-spacing: .12em;
  color: rgba(255,255,255,.55); text-transform: uppercase;
  line-height: 1.5; max-width: 130px;
}
@media (max-width: 900px) {
  .certs { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 560px) {
  .certs { grid-template-columns: repeat(2, 1fr); }
}

/* Our Story — Figma-aligned hero ─────────────────────────── */
.os-hero {
  position: relative;
  overflow: hidden;
  background: #001122;
  padding: 200px 0 180px;
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.os-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 10%, rgba(81,162,255,.18), transparent 60%),
    radial-gradient(ellipse 100% 80% at 50% 110%, rgba(0,17,34,1) 0%, rgba(0,17,34,.7) 40%, transparent 80%),
    url("../assets/hero-bg.png") center 30% / cover no-repeat;
  filter: saturate(.85);
}
.os-hero-bg::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 110% 55% at 50% 105%, rgba(81,162,255,.35) 0%, rgba(81,162,255,.08) 35%, transparent 60%),
    linear-gradient(180deg, rgba(0,17,34,.5) 0%, transparent 35%, rgba(0,17,34,.85) 100%);
}
.os-hero-inner {
  position: relative;
  max-width: 1024px;
  padding: 0 32px;
  margin: 0 auto;
}
.os-hero-pill {
  display: inline-flex; align-items: center;
  padding: 9px 28px;
  border-radius: 999px;
  border: 1px solid var(--gold);
  background: rgba(254,154,0,.1);
  font-family: var(--sans); font-weight: 700; font-size: 14px;
  letter-spacing: .05em; color: var(--gold-hi);
  text-transform: uppercase;
}
.os-hero-title {
  font-family: var(--sans);
  font-weight: 900;
  font-size: clamp(56px, 7vw, 96px);
  line-height: .95;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 36px 0 0;
}
.os-hero-title .stroke {
  color: var(--gold);
  display: block;
}
.os-hero-sub {
  font-family: var(--sans);
  font-size: 24px;
  line-height: 1.62;
  color: rgba(255,255,255,.78);
  max-width: 760px;
  margin: 40px auto 0;
}

/* Our Story — narrative + timeline grid ──────────────────── */
.os-story {
  background: #000a14;
  padding: 120px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.os-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: start;
}
.os-narrative h2 {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 36px;
  letter-spacing: -.022em;
  color: #fff;
  margin: 0 0 32px;
}
.os-narrative-image {
  margin: 28px 0 28px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  align-items: end;
}
.os-narrative-image figure { margin: 0; }
.os-narrative-image img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,.08);
  background: #0a1b2e;
}
.os-narrative-image figcaption {
  margin-top: 12px;
  font-family: var(--sans); font-weight: 700;
  font-size: 14px; line-height: 1.45;
  color: rgba(255,255,255,.6);
}
.os-narrative-image .caption-secondary { font-weight: 400; color: rgba(255,255,255,.5); }
.os-narrative p {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.7;
  color: rgba(255,255,255,.7);
  margin: 0 0 18px;
}

.os-tl-pane {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 33px;
}
.os-tl-head {
  font-family: var(--sans); font-weight: 700;
  font-size: 22px; letter-spacing: .05em;
  color: var(--gold-hi);
  text-align: center;
  line-height: 1.3;
  margin: 0 0 36px;
}
.os-tl-head small {
  display: block;
  font-family: var(--sans); font-weight: 700;
  font-size: 22px; letter-spacing: .05em;
  color: var(--gold-hi);
}
.os-tl {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 64px;
  padding: 12px 0;
}
.os-tl::before {
  content: "";
  position: absolute;
  left: 50%; top: 0; bottom: 0;
  width: 2px;
  transform: translateX(-1px);
  background: linear-gradient(180deg, #51A2FF 0%, #FDC700 50%, #FF6467 100%);
  opacity: .3;
}
.os-tl-evt {
  position: relative;
  padding: 12px 0;
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.os-tl-evt.left {
  grid-column: 1;
  justify-content: flex-end;
  text-align: right;
}
.os-tl-evt.right {
  grid-column: 2;
  justify-content: flex-start;
  text-align: left;
}
.os-tl-evt .os-tl-text {
  display: flex; flex-direction: column; gap: 6px;
  max-width: 210px;
}
.os-tl-evt b {
  font-family: var(--sans); font-weight: 700;
  font-size: 16px; line-height: 1.4;
}
.os-tl-evt span {
  font-family: var(--sans); font-size: 14px;
  line-height: 1.45;
  color: rgba(255,255,255,.7);
}
.os-tl-icon {
  flex-shrink: 0;
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: 6px;
}
.os-tl-evt::after {
  content: "";
  position: absolute;
  top: 24px;
  width: 16px; height: 16px;
  border-radius: 50%;
  border: 2px solid #001122;
}
.os-tl-evt.left::after { right: -40px; }
.os-tl-evt.right::after { left: -40px; }

/* Track color variants */
.os-tl-evt.c-blue b { color: #51A2FF; }
.os-tl-evt.c-blue .os-tl-icon { background: rgba(43,127,255,.2); border: 1px solid rgba(81,162,255,.5); color: #51A2FF; }
.os-tl-evt.c-blue::after { background: #51A2FF; }
.os-tl-evt.c-green b { color: #9AE600; }
.os-tl-evt.c-green .os-tl-icon { background: rgba(124,207,0,.2); border: 1px solid rgba(154,230,0,.5); color: #9AE600; }
.os-tl-evt.c-green::after { background: #9AE600; }
.os-tl-evt.c-orange b { color: #FF8904; }
.os-tl-evt.c-orange .os-tl-icon { background: rgba(255,105,0,.2); border: 1px solid rgba(255,137,4,.5); color: #FF8904; }
.os-tl-evt.c-orange::after { background: #FF8904; }
.os-tl-evt.c-red b { color: #FF6467; }
.os-tl-evt.c-red .os-tl-icon { background: rgba(251,44,54,.2); border: 1px solid rgba(255,100,103,.5); color: #FF6467; }
.os-tl-evt.c-red::after { background: #FF6467; }
.os-tl-evt.c-purple b { color: #C27AFF; }
.os-tl-evt.c-purple .os-tl-icon { background: rgba(173,70,255,.2); border: 1px solid rgba(194,122,255,.5); color: #C27AFF; }
.os-tl-evt.c-purple::after { background: #C27AFF; }

.os-tl-icon svg { width: 20px; height: 20px; }

/* Our Story — horizontal alternating timeline (redesigned) ── */
.os-readmore { margin-top: 36px; }
.os-timeline { background: #00060f; padding: 100px 0; border-bottom: 1px solid rgba(255,255,255,.05); }
.os-tl2-head { text-align: center; margin-bottom: 56px; }
.os-tl2-head h2 {
  font-family: var(--display); font-weight: 800; font-size: clamp(28px, 4vw, 44px);
  letter-spacing: -.01em; color: #fff; margin: 0 0 12px;
}
.os-tl2-head p {
  font-family: var(--mono); letter-spacing: .22em; text-transform: uppercase;
  font-size: 12px; color: var(--gold); margin: 0;
}
.os-tl2-scroll { overflow-x: auto; padding-bottom: 18px; }
.os-tl2-track { display: flex; min-width: 1240px; }
.os-tl2-col { flex: 1 1 0; min-width: 150px; display: grid; grid-template-rows: 1fr auto 1fr; }
.os-tl2-top { align-self: end; text-align: center; padding: 0 12px 24px; }
.os-tl2-bot { align-self: start; text-align: center; padding: 24px 12px 0; }
.os-tl2-node { position: relative; height: 2px; background: rgba(255,255,255,.16); display: flex; align-items: center; justify-content: center; }
.os-tl2-node .dot {
  width: 16px; height: 16px; border-radius: 50%; background: var(--gold);
  border: 3px solid #00060f; outline: 2px solid var(--gold); position: relative; z-index: 1;
}
.os-tl2-col .y { font-family: var(--display); font-weight: 800; font-size: 22px; line-height: 1; color: var(--gold); }
.os-tl2-col .t { font-family: var(--sans); font-weight: 700; font-size: 14px; line-height: 1.3; color: #fff; margin: 6px 0 7px; }
.os-tl2-col p { font-family: var(--sans); font-weight: 300; font-size: 12.5px; line-height: 1.5; color: rgba(255,255,255,.62); margin: 0; }
.os-tl2-col.c-blue   .y { color: #51A2FF; } .os-tl2-col.c-blue   .dot { background: #51A2FF; outline-color: #51A2FF; }
.os-tl2-col.c-teal   .y { color: #2DD4BF; } .os-tl2-col.c-teal   .dot { background: #2DD4BF; outline-color: #2DD4BF; }
.os-tl2-col.c-green  .y { color: #9AE600; } .os-tl2-col.c-green  .dot { background: #9AE600; outline-color: #9AE600; }
.os-tl2-col.c-gold   .y { color: var(--gold-hi); } .os-tl2-col.c-gold .dot { background: var(--gold-hi); outline-color: var(--gold-hi); }
.os-tl2-col.c-orange .y { color: #FF8904; } .os-tl2-col.c-orange .dot { background: #FF8904; outline-color: #FF8904; }
.os-tl2-col.c-red    .y { color: #FF6467; } .os-tl2-col.c-red    .dot { background: #FF6467; outline-color: #FF6467; }
.os-tl2-col.c-purple .y { color: #C27AFF; } .os-tl2-col.c-purple .dot { background: #C27AFF; outline-color: #C27AFF; }

/* Leadership & Governance (Figma-aligned) ─────────────────── */
.os-leader {
  background: #001122;
  padding: 130px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.os-leader-head {
  text-align: center;
  margin: 0 auto 80px;
  max-width: 760px;
}
.os-leader-eyebrow {
  display: block;
  font-family: var(--sans); font-weight: 700;
  font-size: 14px; letter-spacing: .05em;
  color: var(--gold-hi);
  text-transform: uppercase;
  margin-bottom: 18px;
}
.os-leader-title {
  font-family: var(--sans); font-weight: 900;
  font-size: 48px;
  letter-spacing: -.022em;
  color: #fff;
  margin: 0 0 18px;
}
.os-leader-lede {
  font-family: var(--sans); font-weight: 300;
  font-size: 18px; line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0;
}
.os-andrea {
  max-width: 459px;
  margin: 0 auto 48px;
}
.os-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.os-leader-card {
  display: flex; flex-direction: column;
  background: none;
  border: 0;
  padding: 0;
  text-align: left;
  cursor: pointer;
  color: inherit;
  font: inherit;
  transition: transform .2s ease;
}
.os-leader-card:hover { transform: translateY(-3px); }
.os-leader-card-photo {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  overflow: hidden;
  margin-bottom: 18px;
  position: relative;
}
.os-leader-card-photo img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
}
.os-leader-card-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,17,34,0) 50%, rgba(0,17,34,.55) 100%);
  pointer-events: none;
}
.os-leader-card-name {
  font-family: var(--sans); font-weight: 700;
  font-size: 20px; line-height: 1.4;
  color: #fff;
  margin: 0 0 4px;
}
.os-leader-card-role {
  font-family: var(--sans); font-weight: 500;
  font-size: 14px; line-height: 1.45;
  letter-spacing: .05em;
  color: var(--gold-hi);
  text-transform: uppercase;
}

/* Founder section ─────────────────────────────────────────── */
.os-founder {
  background: #001122;
  padding: 130px 0;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.os-founder-grid {
  display: grid;
  grid-template-columns: 1fr 459px;
  gap: 80px;
  align-items: start;
}
.os-founder-text h2 {
  font-family: var(--sans); font-weight: 900;
  font-size: 48px;
  letter-spacing: -.022em;
  color: #fff;
  margin: 0 0 8px;
}
.os-founder-text .sub {
  font-family: var(--sans); font-weight: 700;
  font-size: 20px;
  color: var(--gold-hi);
  margin: 0 0 28px;
}
.os-founder-text p {
  font-family: var(--sans); font-weight: 300;
  font-size: 18px; line-height: 1.62;
  color: rgba(255,255,255,.7);
  margin: 0 0 18px;
}
.os-founder-card {
  display: flex;
  flex-direction: column;
}
.os-founder-photo {
  aspect-ratio: 1 / 1;
  border-radius: 6px;
  overflow: hidden;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  position: relative;
}
.os-founder-photo img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center 20%;
  display: block;
}
.os-founder-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,17,34,.5) 0%, rgba(0,17,34,0) 50%);
  opacity: .55;
  pointer-events: none;
}
.os-founder-card .name {
  font-family: var(--sans); font-weight: 700;
  font-size: 20px;
  color: #fff;
  margin: 24px 0 6px;
}
.os-founder-card .title {
  font-family: var(--sans); font-weight: 500;
  font-size: 14px;
  letter-spacing: .05em;
  color: var(--gold-hi);
  text-transform: uppercase;
}

/* CTA — match figma ───────────────────────────────────────── */
.os-cta {
  background: rgba(255,255,255,.02);
  border-top: 1px solid rgba(255,255,255,.05);
  padding: 97px 0;
}
.os-cta-inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
}
.os-cta h2 {
  font-family: var(--sans); font-weight: 900;
  font-size: 48px;
  letter-spacing: -.022em;
  color: #fff;
  margin: 0 0 24px;
  line-height: 1.1;
}
.os-cta p {
  font-family: var(--sans); font-weight: 300;
  font-size: 18px; line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0 0 36px;
}
.os-cta-actions {
  display: flex; justify-content: center;
  gap: 16px; flex-wrap: wrap;
}
.os-cta .btn-primary {
  background: linear-gradient(180deg, var(--gold-hi) 0%, var(--gold) 50%, var(--gold-lo) 100%);
  color: #0B0B0B;
}
.os-cta .btn-ghost {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  color: #fff;
}

@media (max-width: 1100px) {
  .os-grid { grid-template-columns: 1fr; gap: 48px; }
  .os-grid-3 { grid-template-columns: 1fr 1fr; }
  .os-founder-grid { grid-template-columns: 1fr; }
  .os-founder-card { max-width: 459px; }
  .os-tl { gap: 0 32px; }
  .os-tl-evt.left::after { right: -24px; }
  .os-tl-evt.right::after { left: -24px; }
}
@media (max-width: 640px) {
  .os-hero { padding: 130px 0 110px; }
  .os-tl-pane { padding: 24px 14px; }
  .os-tl { gap: 0 14px; }
  .os-tl-evt.left::after { right: -15px; }
  .os-tl-evt.right::after { left: -15px; }
  .os-grid-3 { grid-template-columns: 1fr; }
  .os-leader-title, .os-cta h2, .os-founder-text h2 { font-size: 36px; }
  .os-hero-sub { font-size: 18px; }
}

/* Leadership cards ──────────────────────────────────────── */
.leadership {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin-top: 56px;
}
.leader {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.08);
  padding: 28px;
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color .2s ease, background .2s ease;
}
.leader:hover { border-color: rgba(248,178,74,.4); background: rgba(248,178,74,.03); }
.leader-photo {
  aspect-ratio: 4/5;
  background:
    linear-gradient(135deg, rgba(248,178,74,.15) 0%, rgba(0,17,34,.5) 100%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 1px, transparent 1px 12px);
  border: 1px solid rgba(255,255,255,.08);
  display: grid; place-items: center;
  font-family: var(--mono); font-size: 11px; letter-spacing: .2em;
  color: rgba(255,255,255,.3); text-transform: uppercase;
  position: relative;
  overflow: hidden;
}
.leader-photo::after {
  content: attr(data-initials);
  font-family: var(--display); font-size: 64px; font-weight: 900;
  color: rgba(248,178,74,.5); letter-spacing: -0.02em;
  position: absolute; inset: 0; display: grid; place-items: center;
}
.leader b {
  font-family: var(--display); font-weight: 700; font-size: 20px;
  color: #fff;
}
.leader-role {
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  color: var(--gold); text-transform: uppercase;
}
.leader-bio {
  font-family: var(--serif); font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,.65); margin: 0;
}

/* Values ────────────────────────────────────────────────── */
.values {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  margin-top: 56px; border-top: 1px solid rgba(255,255,255,.08);
}
.value {
  padding: 36px 28px;
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  display: flex; flex-direction: column; gap: 12px;
}
.value:nth-child(4n) { border-right: 0; }
.val-num {
  font-family: var(--mono); font-size: 11px; letter-spacing: .25em;
  color: rgba(248,178,74,.7); text-transform: uppercase;
}
.value b {
  font-family: var(--display); font-weight: 900; font-size: 24px;
  color: var(--gold); letter-spacing: -0.01em;
}
.value p {
  font-family: var(--serif); font-size: 14px; line-height: 1.55;
  color: rgba(255,255,255,.7); margin: 0;
}

/* Work — case studies layout (Figma) ───────────────────────── */
.work-case {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  gap: 0;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
  transition: border-color .2s ease;
}
.work-case:hover { border-color: rgba(248,178,74,.4); }
.work-case-image {
  min-height: 360px;
  background-size: cover;
  background-position: center;
  border-right: 1px solid rgba(255,255,255,.06);
}
.work-case-body { padding: 40px; display: flex; flex-direction: column; gap: 14px; }
.work-case-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.work-case-tags span {
  font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  color: rgba(255,255,255,.7); text-transform: uppercase;
  padding: 5px 12px;
  background: rgba(248,178,74,.06);
  border: 1px solid rgba(248,178,74,.25);
  border-radius: 999px;
}
.work-case-title {
  font-family: var(--sans); font-weight: 400; font-size: 30px;
  letter-spacing: -.02em; color: #fff;
  margin: 0;
}
.work-case-sub {
  font-family: var(--sans); font-weight: 700; font-size: 16px;
  color: var(--gold-hi);
  margin-bottom: 4px;
}
.work-case-desc {
  font-family: var(--sans); font-size: 15px; line-height: 1.6;
  color: rgba(255,255,255,.7); margin: 0;
}
.work-case-metrics {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: 6px;
}
.work-case-metrics > div { display: flex; flex-direction: column; gap: 4px; }
.work-case-metrics b {
  font-family: var(--sans); font-weight: 700; font-size: 18px;
  color: var(--gold-hi); letter-spacing: -.005em;
}
.work-case-metrics span {
  font-family: var(--sans); font-size: 13px;
  color: rgba(255,255,255,.6);
}
.work-case-link {
  font-family: var(--mono); font-size: 12px; letter-spacing: .15em;
  color: var(--gold); text-transform: uppercase;
  align-self: flex-start;
}
.work-case-link:hover { color: var(--gold-hi); }
@media (max-width: 1100px) {
  .work-case { grid-template-columns: 1fr; }
  .work-case-image { min-height: 220px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.06); }
  .work-case-metrics { grid-template-columns: 1fr; }
}

/* Contact — quick-links sidebar ─────────────────────────── */
.contact-sidebar-block {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  padding: 28px 32px;
  display: flex; flex-direction: column; gap: 14px;
}
.contact-sidebar-block h4 {
  font-family: var(--sans); font-weight: 700; font-size: 16px;
  letter-spacing: .04em;
  color: var(--gold-hi);
  text-transform: uppercase;
  margin: 0;
  border: 0; padding: 0;
  display: flex; align-items: center; justify-content: space-between;
}
.contact-sidebar-block p, .contact-sidebar-block a {
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  color: rgba(255,255,255,.78); margin: 0;
  display: block;
}
.contact-sidebar-block a { color: rgba(255,255,255,.85); }
.contact-sidebar-block a:hover { color: var(--gold-hi); }
.contact-sidebar-block .quick-link { display: flex; align-items: center; gap: 10px; padding: 6px 0; }
.contact-sidebar-block .quick-link::before { content: "→"; color: var(--gold); }


/* Contract Vehicles — Marketplace Awardable (Tradewinds / Platform One) */
.mkt-grid {
  display: grid; grid-template-columns: 320px 1fr; gap: 56px; align-items: start;
}
.mkt-media {
  position: sticky; top: 104px;
  display: flex; flex-direction: column; align-items: center; gap: 22px;
  padding: 40px 32px;
  background:
    radial-gradient(ellipse 80% 70% at 50% 38%, rgba(248,178,74,.10), rgba(255,255,255,0) 70%),
    linear-gradient(160deg, rgba(255,255,255,.07), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.12);
}
.mkt-badge { width: 100%; max-width: 232px; height: auto; }
.mkt-status {
  font-family: var(--mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--gold); border: 1px solid rgba(248,178,74,.4); background: rgba(248,178,74,.06);
  padding: 8px 16px; text-align: center;
}
.mkt-body { max-width: 880px; }
.mkt-title {
  font-family: var(--sans); font-weight: 700; font-size: clamp(28px,3.2vw,40px);
  letter-spacing: -.025em; line-height: 1.14; color: #fff; margin: 18px 0 16px;
}
.mkt-hook {
  font-family: var(--serif); font-size: 21px; line-height: 1.4; color: var(--gold); margin: 0 0 30px;
}
.mkt-body p {
  font-family: var(--sans); font-size: 16px; line-height: 1.72; color: rgba(255,255,255,.74); margin: 0 0 18px;
}
.mkt-sub {
  font-family: var(--sans); font-weight: 700; font-size: 21px; color: #fff;
  margin: 38px 0 14px; letter-spacing: -.01em;
}
.mkt-body a.mkt-link { color: var(--gold); text-decoration: underline; text-underline-offset: 2px; }
.mkt-highlights {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; margin-top: 44px;
}
.mkt-hl {
  border: 1px solid rgba(248,178,74,.2);
  background: linear-gradient(135deg, rgba(254,154,0,.05), rgba(0,0,0,0));
  padding: 24px 22px;
}
.mkt-hl h4 {
  font-family: var(--sans); font-weight: 700; font-size: 15px; text-transform: uppercase;
  letter-spacing: .03em; color: var(--gold); margin: 0 0 8px;
}
.mkt-hl p { font-family: var(--sans); font-size: 14px; line-height: 1.55; color: rgba(255,255,255,.72); margin: 0; }
@media (max-width: 980px) {
  .mkt-grid { grid-template-columns: 1fr; gap: 32px; }
  .mkt-media { position: static; flex-direction: row; justify-content: center; }
  .mkt-badge { max-width: 150px; }
  .mkt-highlights { grid-template-columns: 1fr; }
}

/* Contract Vehicles — Acquisition roadmap flowchart (TSM / P1SM) */
.roadmap {
  margin-top: 44px;
  display: flex; flex-direction: column; align-items: center; gap: 0;
}
.rm-title {
  font-family: var(--sans); font-weight: 700; font-size: 16px; letter-spacing: .02em;
  color: #fff; text-align: center; margin: 0 0 24px;
}
.rm-step {
  width: 100%; max-width: 560px;
  border: 1px solid; border-radius: 10px;
  padding: 16px 22px; text-align: center;
}
.rm-step h4 { font-family: var(--sans); font-weight: 700; font-size: 16px; margin: 0 0 4px; letter-spacing: -.01em; }
.rm-step p { font-family: var(--sans); font-size: 13.5px; line-height: 1.45; margin: 0; opacity: .85; }
.rm-green { background: rgba(31,138,91,.12); border-color: rgba(31,138,91,.5); }
.rm-green h4 { color: #5fd0a0; } .rm-green p { color: #b6e6cf; }
.rm-amber { background: rgba(248,178,74,.1); border-color: rgba(248,178,74,.5); }
.rm-amber h4 { color: var(--gold); } .rm-amber p { color: #f3d3a3; }
.rm-red { background: rgba(214,90,74,.12); border-color: rgba(214,90,74,.5); }
.rm-red h4 { color: #e89b8f; } .rm-red p { color: #f0c4bc; }
/* connector */
.rm-conn { width: 2px; height: 22px; background: rgba(255,255,255,.25); }
/* branch rows */
.rm-branch {
  width: 100%;
  display: grid; gap: 12px;
  padding: 0;
}
.rm-branch.cols4 { grid-template-columns: repeat(4, 1fr); }
.rm-branch.cols5 { grid-template-columns: repeat(5, 1fr); }
.rm-opt {
  border: 1px solid; border-radius: 8px; padding: 12px 10px; text-align: center;
  display: flex; flex-direction: column; gap: 3px;
}
.rm-opt b { font-family: var(--sans); font-weight: 700; font-size: 14px; }
.rm-opt span { font-family: var(--sans); font-size: 11.5px; line-height: 1.35; opacity: .8; }
.rm-purple { background: rgba(138,116,222,.12); border-color: rgba(138,116,222,.45); }
.rm-purple b { color: #b3a3ec; } .rm-purple span { color: #cfc6f2; }
.rm-gray { background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.18); }
.rm-gray b { color: #e6e6e6; } .rm-gray span { color: rgba(255,255,255,.6); }
.rm-notes { width: 100%; max-width: 760px; margin-top: 28px; display: flex; flex-direction: column; gap: 10px; }
.rm-note {
  border: 1px dashed rgba(255,255,255,.2); border-radius: 8px; padding: 14px 20px; text-align: center;
  font-family: var(--sans); font-size: 13.5px; color: rgba(255,255,255,.7);
}
@media (max-width: 760px) {
  .rm-branch.cols4, .rm-branch.cols5 { grid-template-columns: repeat(2, 1fr); }
}

/* Contract Vehicles — WOSB Sole Source Fast Path (Figma) ──── */
.wosb-callout {
  display: flex; align-items: center; gap: 24px;
  background: linear-gradient(135deg, rgba(254,154,0,.05), rgba(0,0,0,0));
  border: 1px solid rgba(254,154,0,.3);
  padding: 28px 36px;
  margin-bottom: 32px;
}
.wosb-callout svg {
  flex-shrink: 0; width: 48px; height: 48px;
  color: var(--gold);
}
.wosb-callout p {
  font-family: var(--sans); font-size: 18px; line-height: 1.6;
  color: rgba(255,255,255,.85); margin: 0;
}

.wosb-steps {
  display: flex; flex-direction: column;
}
.wosb-step {
  display: flex; gap: 24px;
  background: linear-gradient(135deg, rgba(254,154,0,.03), rgba(0,0,0,0));
  border: 1px solid rgba(254,154,0,.2);
  padding: 25px;
  align-items: flex-start;
}
.wosb-num {
  flex-shrink: 0;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(254,154,0,.1);
  border: 1px solid var(--gold-hi);
  display: grid; place-items: center;
  font-family: var(--sans); font-weight: 400; font-size: 20px;
  color: var(--gold-hi);
}
.wosb-body {
  flex: 1; display: flex; flex-direction: column; gap: 10px;
}
.wosb-body h3 {
  font-family: var(--sans); font-weight: 700; font-size: 20px;
  letter-spacing: -.012em;
  color: var(--gold-hi);
  margin: 0;
}
.wosb-body > p {
  font-family: var(--sans); font-size: 16px; line-height: 1.6;
  color: rgba(255,255,255,.8);
  margin: 0;
}
.wosb-list {
  display: flex; flex-direction: column; gap: 4px;
  margin: 0; padding: 0;
}
.wosb-list li {
  font-family: var(--sans); font-size: 15px; line-height: 1.55;
  color: rgba(255,255,255,.78);
  padding-left: 18px; position: relative;
}
.wosb-list li::before {
  content: "•"; position: absolute; left: 0; color: var(--gold);
}
.wosb-auth {
  font-family: var(--sans); font-style: italic; font-size: 14px;
  color: rgba(255,255,255,.6);
}
.wosb-divider {
  display: grid; place-items: center;
  padding: 14px 0;
}
.wosb-divider::before {
  content: "";
  display: block;
  width: 2px; height: 24px;
  background: linear-gradient(180deg, rgba(255,185,0,.6), transparent);
}
.wosb-divider::after {
  content: "▼";
  font-size: 12px;
  color: rgba(255,185,0,.6);
  margin-top: -8px;
}

.wosb-why-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
/* Single-view horizontal infographic (matches the original DSD WOSB graphic) */
.wosb-steps {
  display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px;
  position: relative; margin-top: 8px;
}
.wosb-steps::before {
  content: ""; position: absolute; top: 13px; left: 8%; right: 8%; height: 2px;
  background: rgba(255,255,255,.16); z-index: 0;
}
.wosb-st {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: 9px; padding: 0 3px; position: relative; z-index: 1;
}
.wosb-st-num {
  width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center;
  font-family: var(--sans); font-weight: 800; font-size: 12px; color: #fff;
  box-shadow: 0 0 0 4px #000814;
}
.wosb-st-icon {
  width: 50px; height: 50px; border-radius: 50%; display: grid; place-items: center;
  margin-top: 2px;
}
.wosb-st-icon svg { width: 24px; height: 24px; color: #fff; }
.wosb-st h3 {
  font-family: var(--sans); font-weight: 700; font-size: 11.5px; line-height: 1.2;
  text-transform: uppercase; letter-spacing: .01em; margin: 2px 0 0;
}
.wosb-st p {
  font-family: var(--sans); font-size: 11px; line-height: 1.4;
  color: rgba(255,255,255,.66); margin: 0;
}
.wosb-st .wosb-st-auth {
  font-family: var(--mono); font-size: 9.5px; line-height: 1.35; letter-spacing: .01em;
  color: var(--gold); margin-top: auto; padding-top: 4px; opacity: .85;
}
.wosb-st .wosb-st-ex { font-size: 10px; color: rgba(255,255,255,.5); margin: 0; }
/* per-step colors */
.wst1 .wosb-st-num, .wst1 .wosb-st-icon { background: #2b4a6f; } .wst1 h3 { color: #7ea3cf; }
.wst2 .wosb-st-num, .wst2 .wosb-st-icon { background: #2a6fdb; } .wst2 h3 { color: #7fb0ec; }
.wst3 .wosb-st-num, .wst3 .wosb-st-icon { background: #1f8a8a; } .wst3 h3 { color: #66c8c8; }
.wst4 .wosb-st-num, .wst4 .wosb-st-icon { background: #2e9e6b; } .wst4 h3 { color: #6fd0a0; }
.wst5 .wosb-st-num, .wst5 .wosb-st-icon { background: #d9a328; } .wst5 h3 { color: #ecc870; }
.wst6 .wosb-st-num, .wst6 .wosb-st-icon { background: #df7b2e; } .wst6 h3 { color: #f0a86e; }
.wst7 .wosb-st-num, .wst7 .wosb-st-icon { background: #7d5fc0; } .wst7 h3 { color: #b3a3ec; }
.wst8 .wosb-st-num, .wst8 .wosb-st-icon { background: #c0392b; } .wst8 h3 { color: #e89b8f; }
@media (max-width: 900px) {
  .wosb-steps { grid-template-columns: repeat(4, 1fr); gap: 20px 10px; }
  .wosb-steps::before { display: none; }
}
@media (max-width: 520px) {
  .wosb-steps { grid-template-columns: repeat(2, 1fr); }
}
/* Compact single-view step flow (matches the original infographic) */
.wosb-flow {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.wosb-card {
  position: relative; background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.1); border-radius: 8px;
  padding: 20px 18px; display: flex; flex-direction: column; gap: 8px;
}
.wosb-card .wosb-cn {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--gold); color: #0B0B0B;
  font-family: var(--display); font-weight: 800; font-size: 16px;
  display: grid; place-items: center; margin-bottom: 4px;
}
.wosb-card h3 {
  font-family: var(--sans); font-weight: 700; font-size: 14px; line-height: 1.25;
  letter-spacing: .01em; text-transform: uppercase; color: #fff; margin: 0;
}
.wosb-card p {
  font-family: var(--sans); font-size: 13px; line-height: 1.5;
  color: rgba(255,255,255,.72); margin: 0;
}
.wosb-card .wosb-ex { font-size: 12px; color: rgba(255,255,255,.6); margin: 0; }
.wosb-card .wosb-auth {
  font-family: var(--mono); font-style: normal; font-size: 11px; letter-spacing: .02em;
  color: var(--gold); margin-top: auto; padding-top: 6px;
}
@media (max-width: 980px) { .wosb-flow { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .wosb-flow { grid-template-columns: 1fr; } }
.wosb-why {
  display: flex; gap: 16px; align-items: flex-start;
  background: linear-gradient(135deg, rgba(254,154,0,.03), rgba(0,0,0,0));
  border: 1px solid rgba(254,154,0,.2);
  padding: 25px;
}
.wosb-why-icon {
  flex-shrink: 0; width: 32px; height: 32px;
  color: var(--gold-hi);
}
.wosb-why-icon svg { width: 100%; height: 100%; }
.wosb-why-body { display: flex; flex-direction: column; gap: 8px; }
.wosb-why-body h3 {
  font-family: var(--sans); font-weight: 700; font-size: 18px;
  line-height: 1.4; letter-spacing: -.012em;
  color: var(--gold-hi); margin: 0;
}
.wosb-why-body p {
  font-family: var(--sans); font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,.8); margin: 0;
}

.wosb-note {
  text-align: center;
  border: 1px solid rgba(254,154,0,.2);
  padding: 49px 24px;
  margin-top: 48px;
  font-family: var(--sans); font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,.6);
}

/* Vehicle compact cards */
.vh-cards {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.vh-card {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  padding: 28px 30px;
  display: flex; flex-direction: column; gap: 18px;
  transition: border-color .2s ease;
}
.vh-card:hover { border-color: rgba(248,178,74,.4); }
.vh-card-head {
  display: flex; gap: 20px; align-items: flex-start;
}
.vh-logo {
  flex-shrink: 0;
  width: 56px; height: 56px;
}
.vh-logo-bar { width: 100%; height: 100%; }
.vh-card-head h3 {
  flex: 1;
  font-family: var(--serif); font-weight: 400; font-size: 22px;
  letter-spacing: -.015em; line-height: 1.2;
  color: #fff;
  margin: 0;
}
.vh-card-sub {
  font-size: 16px;
  color: rgba(255,255,255,.7);
}
.vh-card-arrow {
  width: 20px; height: 20px;
  color: rgba(255,255,255,.5);
  flex-shrink: 0;
}
.vh-card:hover .vh-card-arrow { color: var(--gold); }
.vh-card-meta { display: flex; flex-direction: column; gap: 8px; }
.vh-card-contract {
  font-family: var(--sans); font-weight: 500; font-size: 13px;
  letter-spacing: .02em; color: var(--gold-hi);
}
.vh-card-period {
  font-family: var(--sans); font-weight: 500; font-size: 13px;
  color: rgba(255,255,255,.7);
}
.vh-codes {
  margin-top: 56px;
  font-family: var(--sans); font-weight: 500; font-size: 13px;
  letter-spacing: .05em;
  color: var(--gold-hi);
  line-height: 1.6;
}

@media (max-width: 1100px) {
  .wosb-why-grid { grid-template-columns: 1fr; }
  .vh-cards { grid-template-columns: 1fr; }
}


/* Federal — Awards & Certs row (Figma-aligned) ─────────── */
.cert-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 12px;
  padding: 48px 0;
}
.cert-badge {
  aspect-ratio: 4 / 5;
  background: #fff;
  color: #0B0B0B;
  border-radius: 4px;
  padding: 12px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
  font-family: var(--sans);
  position: relative;
  overflow: hidden;
}
.cert-badge-img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}
.cert-badge-mark {
  width: 36px;
  height: 36px;
  display: grid; place-items: center;
}
.cert-badge-mark svg { width: 100%; height: 100%; }
.cert-badge.cb-nsai .cert-badge-mark,
.cb-nsai { color: #0B0B0B; }
.cert-badge-name {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.15;
  text-transform: uppercase;
}
.cert-badge-meta {
  font-family: var(--mono);
  font-size: 9px;
  letter-spacing: .08em;
  color: #555;
  margin-top: auto;
  padding-top: 6px;
  border-top: 1px solid rgba(0,0,0,.12);
  width: 100%;
}

/* WOSB badge */
.cert-badge-wosb { background: #fff; }
.cb-wosb-shield {
  width: 56px; height: 56px;
  background: #B71C1C;
  border-radius: 50%;
  display: grid; place-items: center;
  position: relative;
}
.cb-wosb-shield::before {
  content: "";
  position: absolute;
  inset: 4px;
  border: 1px solid #fff;
  border-radius: 50%;
}
.cb-sba {
  color: #fff;
  font-family: var(--display);
  font-weight: 900;
  font-size: 14px;
  letter-spacing: .04em;
}

/* CMMI badge */
.cert-badge-cmmi { background: #fff; padding: 10px 6px; }
.cb-cmmi-mark {
  background: #E67E22;
  color: #fff;
  font-family: var(--display);
  font-weight: 900;
  font-size: 14px;
  letter-spacing: .04em;
  padding: 5px 10px;
  border-radius: 2px;
}
.cb-cmmi-foot {
  display: flex; flex-direction: column; gap: 0;
  font-family: var(--sans);
  line-height: 1.1;
  color: #0B0B0B;
}
.cb-cmmi-foot b {
  font-weight: 700;
  font-size: 10px;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.cb-cmmi-foot span {
  font-weight: 900;
  font-size: 14px;
  color: #E67E22;
  letter-spacing: .02em;
}

@media (max-width: 1100px) {
  .cert-row { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 640px) {
  .cert-row { grid-template-columns: repeat(2, 1fr); gap: 8px; }
}


.forge-hero {
  position: relative;
  overflow: hidden;
  background: #001122;
  padding: 180px 0 140px;
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.forge-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% 30%, rgba(254,154,0,.1), transparent 70%),
    linear-gradient(180deg, #0B0B0B 0%, #001122 50%, #0B0B0B 100%);
}
.forge-hero-inner { position: relative; }
.forge-wordmark {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(60px, 9vw, 120px);
  letter-spacing: -.03em;
  line-height: 1;
  margin: 0 0 28px;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 18px;
}
.forge-wordmark .dsd {
  color: #fff;
}
.forge-wordmark .forge {
  background: linear-gradient(180deg, var(--gold-hi) 0%, var(--gold) 50%, var(--gold-lo) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
/* DSD globe icon used as the "O" in FORGE wordmarks */
.forge-o {
  height: .8em;
  width: .8em;
  object-fit: contain;
  display: inline-block;
  vertical-align: -.07em;
  margin: 0 .015em;
}
/* Neutralize the homepage section ".forge" rule bleeding onto inline wordmark spans */
.forge-wordmark .forge,
.forge-ov-logo .forge,
.fp-forge-mark .forge {
  position: static;
  padding: 0;
  overflow: visible;
}
.forge-tagline {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.5;
  letter-spacing: -.015em;
  color: rgba(255,255,255,.7);
  max-width: 720px;
  margin: 0 auto;
}

/* 4 module grid */
.forge-modules-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
}
.forge-mod {
  background: linear-gradient(135deg, rgba(248,178,74,.05), rgba(0,0,0,0));
  border: 1px solid rgba(248,178,74,.2);
  display: flex; flex-direction: column;
  position: relative;
  transition: border-color .2s ease;
}
.forge-mod:hover { border-color: rgba(248,178,74,.4); }
.forge-mod::before,
.forge-mod::after {
  content: ""; position: absolute;
  width: 16px; height: 16px;
  border: 1px solid rgba(248,178,74,.4);
}
.forge-mod::before { top: 4px; right: 4px; }
.forge-mod::after { bottom: 4px; right: 4px; }
.forge-mod-img {
  height: 192px;
  background-size: cover;
  background-position: center;
  filter: saturate(.8);
  border-bottom: 1px solid rgba(248,178,74,.15);
}
.forge-mod-body { padding: 32px; display: flex; flex-direction: column; gap: 16px; }
.forge-mod-name {
  font-family: var(--sans); font-weight: 400; font-size: 30px;
  letter-spacing: -.025em;
  color: var(--gold-hi);
  margin: 0;
  text-transform: uppercase;
}
.forge-mod-cat {
  font-family: var(--sans); font-weight: 700; font-size: 12px;
  letter-spacing: .05em;
  color: rgba(255,255,255,.4);
  text-transform: uppercase;
}
.forge-mod-lede {
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0;
}
.forge-mod-list {
  display: flex; flex-direction: column; gap: 8px;
  margin: 0; padding: 0;
}
.forge-mod-list li {
  font-family: var(--sans); font-size: 13px; line-height: 1.55;
  color: rgba(255,255,255,.65);
  padding-left: 16px;
  position: relative;
}
.forge-mod-list li::before {
  content: ""; position: absolute;
  left: 0; top: 8px;
  width: 4px; height: 4px;
  background: var(--gold);
}
.forge-mod-list li b {
  font-weight: 700;
  color: rgba(255,255,255,.9);
}
.forge-mod-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--serif); font-weight: 700; font-size: 14px;
  letter-spacing: .05em;
  color: var(--gold);
  margin-top: 4px;
}
.forge-mod-link svg { width: 16px; height: 16px; }
.forge-mod-link:hover { color: var(--gold-hi); }

/* 3 connecting columns */
.forge-connect-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
.forge-connect {
  background: linear-gradient(135deg, rgba(248,178,74,.03), rgba(0,0,0,0));
  border: 1px solid rgba(248,178,74,.2);
  padding: 32px;
  display: flex; flex-direction: column; gap: 14px;
}
.forge-connect h3 {
  font-family: var(--sans); font-weight: 700; font-size: 20px;
  color: #fff;
  margin: 0;
}
.forge-connect p {
  font-family: var(--sans); font-weight: 300; font-size: 18px;
  line-height: 1.55;
  color: rgba(255,255,255,.6);
  margin: 0;
}

/* Impact grid (3x3) */
.impact-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.08);
  border-left: 1px solid rgba(255,255,255,.08);
}
.impact-card {
  padding: 32px 28px;
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  display: flex; flex-direction: column; gap: 12px;
  transition: background .2s ease;
}
.impact-card:hover { background: rgba(248,178,74,.03); }
.impact-card h3 {
  font-family: var(--sans); font-weight: 700; font-size: 16px;
  letter-spacing: .05em;
  color: var(--gold-hi);
  text-transform: uppercase;
  margin: 0;
}
.impact-card p {
  font-family: var(--sans); font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,.7);
  margin: 0;
}

/* Mockup */
.forge-mockup {
  max-width: 1100px;
  margin: 0 auto;
}

/* Forge CTA */
.forge-cta {
  background: linear-gradient(135deg, rgba(254,154,0,.1), rgba(0,0,0,0));
  border: 1px solid rgba(254,154,0,.2);
  border-radius: 6px;
  padding: 60px 40px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 32px;
}
.forge-cta h2 {
  font-family: var(--sans); font-weight: 400; font-size: 36px;
  letter-spacing: -.005em;
  text-transform: uppercase;
  color: #fff;
  margin: 0;
}

/* Product pages — Kalvis / Astra / OptiBase / Veles (Figma) ── */
.pp-hero {
  position: relative;
  background: linear-gradient(180deg, #001122 0%, #001a33 50%, #001122 100%);
  padding: 140px 0 80px;
  overflow: hidden;
  border-bottom: 1px solid rgba(255,255,255,.05);
}
.pp-hero-inner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.pp-hero-eyebrow {
  font-family: var(--sans); font-weight: 700; font-size: 22px;
  letter-spacing: .04em;
  color: #fff;
  margin: 0 0 8px;
  text-transform: uppercase;
}
.pp-hero-title {
  font-family: var(--sans); font-weight: 900; font-size: clamp(64px, 7vw, 96px);
  letter-spacing: -.025em;
  line-height: 1;
  color: var(--gold-hi);
  margin: 0 0 16px;
  text-transform: uppercase;
}
.pp-hero-sub {
  font-family: var(--sans); font-weight: 700; font-size: 14px;
  letter-spacing: .15em;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  margin: 0;
  max-width: 460px;
  line-height: 1.5;
}
.pp-hero-right {
  font-family: var(--sans); font-weight: 700; font-size: 14px;
  letter-spacing: .15em;
  color: var(--gold-hi);
  text-transform: uppercase;
  text-align: right;
  margin: 0;
  align-self: flex-end;
  line-height: 1.6;
}

/* Banner image */
.pp-banner {
  height: 480px;
  background-size: cover;
  background-position: center;
  background-color: #001122;
  border-bottom: 1px solid rgba(255,255,255,.06);
  position: relative;
}
.pp-banner::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,17,34,.4) 0%, transparent 30%, transparent 70%, rgba(0,17,34,.4) 100%);
}

/* Callout box (intro statement) */
.pp-callout-wrap { background: #001122; padding: 80px 0; }
.pp-callout {
  background: linear-gradient(135deg, rgba(255,255,255,.02), rgba(0,0,0,0));
  border: 1px solid rgba(255,255,255,.08);
  padding: 56px 80px;
  position: relative;
}
.pp-callout::before,
.pp-callout::after {
  content: ""; position: absolute;
  width: 28px; height: 28px;
  border: 1px solid var(--gold);
}
.pp-callout::before { top: -1px; left: -1px; border-right: 0; border-bottom: 0; }
.pp-callout::after { bottom: -1px; right: -1px; border-left: 0; border-top: 0; }
.pp-callout-corner-tr,
.pp-callout-corner-bl {
  position: absolute;
  width: 28px; height: 28px;
  border: 1px solid var(--gold);
}
.pp-callout-corner-tr { top: -1px; right: -1px; border-left: 0; border-bottom: 0; }
.pp-callout-corner-bl { bottom: -1px; left: -1px; border-right: 0; border-top: 0; }
.pp-callout p {
  font-family: var(--serif); font-weight: 300; font-size: 28px;
  line-height: 1.35;
  letter-spacing: -.015em;
  color: #FAF9F6;
  margin: 0;
  max-width: 900px;
}

/* Core Capabilities */
.pp-section { background: #001122; padding: 80px 0; }
.pp-section-title {
  font-family: var(--sans); font-weight: 900; font-size: 36px;
  letter-spacing: -.005em;
  color: var(--gold-hi);
  text-transform: uppercase;
  text-align: center;
  margin: 0 0 56px;
}
.pp-caps-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.pp-cap {
  background: linear-gradient(135deg, rgba(255,255,255,.03), rgba(0,0,0,0));
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 32px;
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color .2s ease;
}
.pp-cap:hover { border-color: rgba(248,178,74,.35); }
.pp-cap-head { display: flex; align-items: center; gap: 16px; }
.pp-cap-icon {
  width: 50px; height: 50px;
  border-radius: 6px;
  background: rgba(254,154,0,.1);
  border: 1px solid rgba(254,154,0,.3);
  color: var(--gold-hi);
  display: grid; place-items: center;
}
.pp-cap-icon svg { width: 24px; height: 24px; }
.pp-cap-name {
  font-family: var(--sans); font-weight: 700; font-size: 18px;
  letter-spacing: .05em;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
}
.pp-cap p {
  font-family: var(--sans); font-weight: 300; font-size: 16px;
  line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0;
}

/* Transformation statement */
.pp-transform {
  background: linear-gradient(180deg, transparent 0%, rgba(0,26,51,.3) 50%, transparent 100%);
  padding: 96px 0;
}
.pp-transform-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.pp-transform-left h2 {
  font-family: var(--sans); font-weight: 900; font-size: 44px;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 32px;
  text-transform: uppercase;
}
.pp-transform-left h2 em {
  font-style: italic;
  font-family: var(--serif);
  font-weight: 300;
  text-transform: none;
  color: rgba(255,255,255,.92);
}
.pp-transform-left p {
  font-family: var(--sans); font-weight: 700; font-size: 13px;
  letter-spacing: .15em;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  margin: 0;
  max-width: 520px;
  line-height: 1.65;
}
.pp-transform-right {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.pp-trans-card {
  background: rgba(0,17,34,.8);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 28px;
  display: flex; flex-direction: column; gap: 12px;
}
.pp-trans-num {
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  color: rgba(255,255,255,.4);
  text-transform: uppercase;
}
.pp-trans-title {
  font-family: var(--sans); font-weight: 700; font-size: 18px;
  letter-spacing: -.005em;
  color: #fff;
  margin: 0;
  line-height: 1.25;
}
.pp-trans-sub {
  font-family: var(--sans); font-size: 14px;
  color: rgba(255,255,255,.6);
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.pp-trans-foot {
  font-family: var(--sans); font-weight: 500; font-size: 13px;
  line-height: 1.5;
  color: var(--gold-hi);
}

/* Specifications */
.pp-specs { background: #001122; padding: 80px 0; }
.pp-specs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  max-width: 1240px;
  margin: 0 auto;
}
.pp-spec {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 24px 28px;
}
.pp-spec b {
  font-family: var(--sans); font-weight: 700; font-size: 16px;
  color: #fff;
}
.pp-spec span {
  font-family: var(--sans); font-weight: 400; font-size: 16px;
  color: rgba(255,255,255,.7);
  margin-left: 6px;
}

/* Learn More CTA card */
.pp-learn { background: #001122; padding: 0 0 96px; }
.pp-learn-card {
  background: linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,0));
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 36px 40px;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 24px;
}
.pp-learn-card h3 {
  font-family: var(--sans); font-weight: 900; font-size: 32px;
  letter-spacing: -.005em;
  color: var(--gold-hi);
  text-transform: uppercase;
  margin: 0;
}

/* DSD Forge Ecosystem section */
.pp-ecosystem {
  background: linear-gradient(180deg, #001122 0%, #000814 100%);
  padding: 96px 0;
}
.pp-eco-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.pp-eco-left h2 {
  font-family: var(--display); font-weight: 800; font-size: 40px;
  letter-spacing: -.01em;
  color: var(--gold-hi);
  text-transform: uppercase;
  margin: 0 0 24px;
}
.pp-eco-left p {
  font-family: var(--sans); font-size: 16px; line-height: 1.65;
  color: rgba(255,255,255,.75);
  margin: 0 0 32px;
}
.pp-eco-sun {
  aspect-ratio: 1;
  max-width: 460px;
  margin: 0 auto;
  position: relative;
  display: grid; place-items: center;
}
.pp-eco-sun svg { width: 100%; height: 100%; }

/* Ready to Accelerate CTA */
.pp-cta { background: #001122; padding: 96px 0; }
.pp-cta-card {
  background: linear-gradient(135deg, rgba(254,154,0,.1), rgba(0,0,0,0));
  border: 1px solid rgba(254,154,0,.2);
  border-radius: 6px;
  padding: 56px 40px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 28px;
}
.pp-cta-card h2 {
  font-family: var(--sans); font-weight: 900; font-size: 36px;
  letter-spacing: -.005em;
  color: #fff;
  text-transform: uppercase;
  margin: 0;
}

@media (max-width: 1100px) {
  .pp-hero-inner { grid-template-columns: 1fr; gap: 32px; }
  .pp-hero-right { text-align: left; align-self: auto; }
  .pp-caps-grid,
  .pp-specs-grid { grid-template-columns: 1fr; }
  .pp-transform-grid { grid-template-columns: 1fr; gap: 32px; }
  .pp-transform-right { grid-template-columns: 1fr 1fr; }
  .pp-eco-grid { grid-template-columns: 1fr; gap: 40px; }
  .pp-eco-sun { max-width: 320px; }
  .pp-callout { padding: 32px 24px; }
  .pp-callout p { font-size: 22px; }
}
@media (max-width: 640px) {
  .pp-transform-right { grid-template-columns: 1fr; }
  .pp-transform-left h2 { font-size: 32px; }
  .pp-section-title, .pp-cta-card h2, .pp-eco-left h2, .pp-learn-card h3 { font-size: 26px; }
  .pp-hero-title { font-size: 56px; }
  .pp-learn-card { flex-direction: column; align-items: flex-start; }
}

/* Legal pages — simple Figma layout ─────────────────────── */
.legal-page {
  background: #0B0B0B;
  min-height: calc(100vh - 80px);
  padding: 128px 0;
}
.legal-page-inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 96px;
  display: flex;
  flex-direction: column;
  gap: 48px;
}
.legal-page h1 {
  margin: 0;
  color: #fff;
}
.legal-terms h1 {
  font-family: var(--sans); font-weight: 500; font-size: 36px;
  line-height: 1.1;
}
.legal-display h1 {
  font-family: var(--display); font-weight: 900; font-size: 48px;
  line-height: 1.1; letter-spacing: -.04em;
}
.legal-page-body { display: flex; flex-direction: column; gap: 32px; }
.legal-page-body p {
  font-family: var(--sans); font-size: 16px; line-height: 1.625;
  color: #fff;
  margin: 0;
  max-width: 1140px;
}
.legal-display .legal-page-body p {
  font-family: var(--sans); font-weight: 300; font-size: 18px;
  line-height: 1.55;
}
@media (max-width: 1100px) {
  .legal-page-inner { padding: 0 48px; }
}
@media (max-width: 640px) {
  .legal-page { padding: 80px 0; }
  .legal-page-inner { padding: 0 24px; gap: 32px; }
  .legal-terms h1 { font-size: 28px; }
  .legal-display h1 { font-size: 36px; }
}

@media (max-width: 1100px) {
  .forge-modules-grid { grid-template-columns: 1fr; }
  .forge-connect-grid { grid-template-columns: 1fr; }
  .impact-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .impact-grid { grid-template-columns: 1fr; }
  .forge-tagline { font-size: 18px; }
  .forge-cta h2 { font-size: 28px; }
}


/* Careers — Figma-aligned ─────────────────────────────────── */
.ben-cat {
  display: flex; flex-direction: column; gap: 18px;
}
.ben-cat-head {
  font-family: var(--sans); font-weight: 700; font-size: 24px;
  letter-spacing: -.025em;
  color: var(--gold-hi);
  margin: 0;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(248,178,74,.2);
}
.ben-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.ben-item {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 24px 26px;
  display: flex; flex-direction: column; gap: 8px;
  transition: border-color .2s ease, background .2s ease;
}
.ben-item:hover { border-color: rgba(248,178,74,.3); background: rgba(248,178,74,.03); }
.ben-item b {
  font-family: var(--sans); font-weight: 700; font-size: 18px;
  color: #fff; line-height: 1.4;
}
.ben-item p {
  font-family: var(--sans); font-size: 14px; line-height: 1.55;
  color: rgba(255,255,255,.7); margin: 0;
}

.why-card {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 33px;
  display: flex; flex-direction: column; gap: 16px;
  transition: border-color .2s ease, transform .2s ease;
}
.why-card:hover { border-color: rgba(248,178,74,.4); transform: translateY(-3px); }
.why-icon {
  width: 48px; height: 48px;
  color: var(--gold);
  display: grid; place-items: center;
}
.why-icon svg { width: 100%; height: 100%; }
.why-card h3 {
  font-family: var(--sans); font-weight: 700; font-size: 20px;
  color: var(--gold-hi);
  margin: 0;
}
.why-card p {
  font-family: var(--sans); font-weight: 300; font-size: 18px;
  line-height: 1.55;
  color: #fff;
  margin: 0;
}

.role-list {
  display: flex; flex-direction: column; gap: 20px;
}
.role {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 32px;
  display: flex; flex-direction: column; gap: 14px;
  transition: border-color .2s ease, background .2s ease;
}
.role:hover { border-color: rgba(248,178,74,.35); background: rgba(248,178,74,.04); }
.role-apply {
  align-self: flex-start; display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--sans); font-weight: 700; font-size: 14px; letter-spacing: .02em;
  color: var(--gold); margin-top: 4px; transition: gap .2s ease, color .2s ease;
}
.role-apply:hover { color: var(--gold-hi); gap: 14px; }
.role-meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.role-tag {
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  color: var(--gold); text-transform: uppercase;
  padding: 5px 10px;
  background: rgba(248,178,74,.08);
  border: 1px solid rgba(248,178,74,.25);
  border-radius: 999px;
}
.role-clear {
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  color: rgba(255,255,255,.7); text-transform: uppercase;
  padding: 5px 10px;
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 999px;
}
.role-clear.ts { color: var(--gold); border-color: var(--gold); }
.role h3 {
  font-family: var(--sans); font-weight: 700; font-size: 22px;
  color: #fff;
  margin: 0; letter-spacing: -.005em;
}
.role p {
  font-family: var(--sans); font-size: 15px; line-height: 1.6;
  color: rgba(255,255,255,.7); margin: 0;
}
.role-loc {
  font-family: var(--mono); font-size: 12px; letter-spacing: .15em;
  color: rgba(255,255,255,.6); text-transform: uppercase;
  padding-top: 8px;
  border-top: 1px dashed rgba(255,255,255,.08);
}

.talent-form {
  max-width: 720px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  padding: 36px 40px;
  display: flex; flex-direction: column; gap: 24px;
}
.talent-head {
  font-family: var(--sans); font-weight: 400; font-size: 24px;
  letter-spacing: -.015em;
  color: #fff;
  margin: 0;
}
.talent-form .field label {
  font-family: var(--sans); font-weight: 700; font-size: 14px;
  letter-spacing: 0;
  color: rgba(255,255,255,.8);
  text-transform: none;
}
.talent-form .field label small {
  font-family: var(--sans); font-weight: 400; font-size: 13px;
  color: rgba(255,255,255,.5);
}
.talent-form .field input[type="url"] {
  border-radius: 4px;
  background: rgba(255,255,255,.05);
}
.file-drop {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px;
  padding: 36px 24px;
  border: 1px dashed rgba(255,255,255,.2);
  background: rgba(255,255,255,.02);
  border-radius: 6px;
  cursor: pointer;
  transition: border-color .2s ease, background .2s ease;
  text-align: center;
}
.file-drop:hover, .file-drop.drag {
  border-color: var(--gold);
  background: rgba(248,178,74,.05);
}
.file-drop svg {
  width: 48px; height: 48px;
  color: var(--gold);
}
.file-drop-main {
  font-family: var(--sans); font-weight: 500; font-size: 15px;
  color: rgba(255,255,255,.85);
}
.file-drop-sub {
  font-family: var(--sans); font-size: 13px;
  color: rgba(255,255,255,.55);
}

@media (max-width: 1100px) {
  .ben-list { grid-template-columns: 1fr; }
  .why-card { padding: 24px; }
}


.fed-domains-head { margin-bottom: 48px; }
.fed-pill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 16px;
  background: rgba(248,178,74,.1);
  border: 1px solid rgba(248,178,74,.2);
  font-family: var(--serif); font-size: 12px;
  letter-spacing: .2em; color: var(--gold); text-transform: uppercase;
  margin-bottom: 24px;
}
.fed-pill-dot { width: 8px; height: 8px; background: var(--gold); }
.fed-domains-title {
  font-family: var(--sans); font-weight: 400; font-size: 36px;
  letter-spacing: -.025em; color: #fff;
  margin: 0 0 12px;
}
.fed-domains-sub {
  font-family: var(--serif); font-size: 16px; line-height: 1.6;
  color: rgba(255,255,255,.7); margin: 0; max-width: 700px;
}
.fed-domains-tabs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 32px;
}
.fed-tab {
  padding: 18px 22px;
  font-family: var(--sans); font-weight: 500; font-size: 15px;
  color: rgba(255,255,255,.85);
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.1);
  text-align: left;
  cursor: pointer;
  transition: all .15s ease;
  line-height: 1.3;
}
.fed-tab:hover { border-color: rgba(248,178,74,.4); color: #fff; background: rgba(248,178,74,.06); }
.fed-tab.active {
  background: rgba(248,178,74,.1);
  border-color: var(--gold);
  color: var(--gold);
}
.fed-domains-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  background: linear-gradient(180deg, rgba(248,178,74,.03) 0%, rgba(0,0,0,0) 100%);
  border: 1px solid rgba(248,178,74,.2);
  padding: 40px;
  align-items: stretch;
}
.fed-domain-name {
  font-family: var(--sans); font-weight: 400; font-size: 30px;
  letter-spacing: -.025em; color: #fff;
  margin: 0 0 24px;
}
.fed-domain-desc {
  font-family: var(--sans); font-weight: 300; font-size: 18px;
  line-height: 1.55; color: rgba(255,255,255,.7);
  margin: 0 0 24px;
}
.fed-domain-impact {
  font-family: var(--sans); font-weight: 700; font-size: 14px;
  letter-spacing: .05em; color: var(--gold);
  text-transform: uppercase; margin-bottom: 12px;
}
.fed-domain-list {
  display: flex; flex-direction: column; gap: 8px;
  margin: 0 0 32px; padding: 0;
}
.fed-domain-list li {
  font-family: var(--sans); font-size: 16px; line-height: 1.55;
  color: rgba(255,255,255,.78); padding-left: 18px; position: relative;
}
.fed-domain-list li::before {
  content: ""; position: absolute; left: 0; top: 9px;
  width: 6px; height: 6px; background: var(--gold);
}
.fed-domain-cta { align-self: flex-start; }
.fed-domains-image {
  background-color: rgba(0,17,34,.6);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border: 1px solid rgba(248,178,74,.2);
  min-height: 380px;
  position: relative;
  filter: saturate(.95) brightness(1.12);
  transition: background-image .25s ease;
}
.fed-domains-image::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,17,34,.15) 0%, rgba(0,17,34,.4) 100%);
}
@media (max-width: 760px) {
  .fed-domains-tabs { grid-template-columns: 1fr 1fr; }
  .fed-domains-panel { grid-template-columns: 1fr; }
  .fed-domains-image { min-height: 240px; }
}
@media (max-width: 460px) {
  .fed-domains-tabs { grid-template-columns: 1fr; }
}
.lab-products {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px;
  margin-top: 56px;
}
.lab-product {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.08);
  padding: 36px;
  display: flex; flex-direction: column; gap: 16px;
  position: relative;
  transition: all .25s ease;
}
.lab-product:hover {
  border-color: var(--gold);
  background: linear-gradient(135deg, rgba(248,178,74,.06), rgba(255,255,255,.02));
}
.lab-product .corner {
  position: absolute; width: 20px; height: 20px;
  border: 2px solid var(--gold);
}
.lab-product .corner.tl { top: -2px; left: -2px; border-right: 0; border-bottom: 0; }
.lab-product .corner.br { bottom: -2px; right: -2px; border-left: 0; border-top: 0; }
.lab-product .lp-tag {
  font-family: var(--mono); font-size: 10px; letter-spacing: .25em;
  color: var(--gold); text-transform: uppercase;
}
.lab-product .lp-logo { display: flex; align-items: center; margin-bottom: 16px; }
.lab-product .lp-logo.chip {
  width: 76px; height: 76px; padding: 9px; border-radius: 12px;
  background: #000; border: 1px solid rgba(255,255,255,.14);
  justify-content: center;
}
.lab-product .lp-logo.chip img { width: 100%; height: 100%; object-fit: contain; display: block; }
.lab-product .lp-logo.wordmark img { height: 46px; width: auto; display: block; }
/* Innovation Lab — Research/Patents section */
.il-research-body { max-width: 1024px; }
.il-research-body p {
  font-family: var(--sans); font-weight: 300; font-size: 18px; line-height: 1.62;
  color: rgba(255,255,255,.72); margin: 0 0 20px;
}
.il-research-portrait {
  float: right; width: 150px; height: 150px; border-radius: 50%;
  object-fit: cover; margin: 6px 0 18px 36px;
  border: 2px solid rgba(248,178,74,.4);
  shape-outside: circle(50%); shape-margin: 12px;
}
@media (max-width: 600px) {
  .il-research-portrait { float: none; display: block; margin: 0 auto 24px; }
}
.lab-product h3 {
  font-family: var(--display); font-weight: 900; font-size: 40px;
  color: #fff; letter-spacing: -0.02em; margin: 8px 0 6px;
}
.lab-product .lp-cat {
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  color: rgba(255,255,255,.5); text-transform: uppercase;
}
.lab-product p {
  font-family: var(--serif); font-size: 16px; line-height: 1.65;
  color: rgba(255,255,255,.75); margin: 12px 0 0;
}
.lab-product .lp-meta {
  display: flex; gap: 24px; margin-top: 20px;
  padding-top: 20px; border-top: 1px solid rgba(255,255,255,.08);
}
.lab-product .lp-meta div { display: flex; flex-direction: column; gap: 2px; }
.lab-product .lp-meta b {
  font-family: var(--mono); font-size: 13px; color: #fff; letter-spacing: .04em;
}
.lab-product .lp-meta span {
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: rgba(255,255,255,.4); text-transform: uppercase;
}
.lab-product .lp-link {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 22px;
  font-family: var(--sans); font-weight: 700; font-size: 14px; letter-spacing: .02em;
  color: var(--gold); align-self: flex-start;
  transition: gap .2s ease, color .2s ease;
}
.lab-product .lp-link:hover { color: var(--gold-hi); gap: 14px; }

/* Contact form ──────────────────────────────────────────── */
.contact-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  margin-top: 48px;
}
.contact-form {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  padding: 40px;
  display: flex; flex-direction: column; gap: 22px;
}
.field { display: flex; flex-direction: column; gap: 8px; }
.field label {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: rgba(255,255,255,.5); text-transform: uppercase;
}
.field label .req { color: var(--gold); }
.field input, .field textarea, .field select {
  background: #0B0B0B;
  border: 1px solid rgba(255,255,255,.15);
  padding: 14px 16px;
  font-family: var(--sans); font-size: 15px; color: #fff;
  border-radius: 0;
  transition: border-color .2s ease, background .2s ease;
}
.field input:focus, .field textarea:focus, .field select:focus {
  outline: 0; border-color: var(--gold);
  background: #001122;
  box-shadow: 0 0 0 3px rgba(248,178,74,.12);
}
.field textarea { resize: vertical; min-height: 140px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.app-section-title {
  font-family: var(--sans); font-weight: 700; font-size: 22px; letter-spacing: .01em;
  color: #fff; margin: 0; padding-bottom: 14px; border-bottom: 1px solid rgba(255,255,255,.12);
}
.radio-group { display: flex; gap: 8px; flex-wrap: wrap; }
.radio-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  border: 1px solid rgba(255,255,255,.15);
  font-family: var(--sans); font-size: 13px; font-weight: 500;
  color: rgba(255,255,255,.75); cursor: pointer;
  transition: all .15s ease;
}
.radio-pill:hover { border-color: rgba(248,178,74,.5); color: #fff; }
.radio-pill input { display: none; }
.radio-pill.active {
  border-color: var(--gold); color: var(--gold);
  background: rgba(248,178,74,.08);
}
.form-meta {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--mono); font-size: 11px; letter-spacing: .15em;
  color: rgba(255,255,255,.4); text-transform: uppercase;
}
.contact-aside {
  display: flex; flex-direction: column; gap: 36px;
}
.aside-block h4 {
  font-family: var(--mono); font-size: 11px; letter-spacing: .25em;
  color: var(--gold); text-transform: uppercase;
  margin: 0 0 14px;
  padding-bottom: 10px; border-bottom: 1px solid rgba(248,178,74,.2);
}
.aside-block p, .aside-block a {
  display: block;
  font-family: var(--serif); font-size: 16px; line-height: 1.6;
  color: rgba(255,255,255,.85); margin: 4px 0 0;
}
.aside-block a { color: var(--gold); }
.aside-block .meta {
  font-family: var(--mono); font-size: 11px; letter-spacing: .12em;
  color: rgba(255,255,255,.5); text-transform: uppercase;
  margin-top: 8px;
}

.form-success {
  display: none;
  background: linear-gradient(135deg, rgba(5,223,114,.1), rgba(248,178,74,.06));
  border: 1px solid var(--green);
  padding: 36px;
  text-align: center;
}
.form-success.show { display: flex; flex-direction: column; gap: 14px; align-items: center; }
.form-success h3 {
  font-family: var(--display); font-weight: 700; font-size: 28px;
  color: #fff; margin: 0;
}
.form-success p { color: rgba(255,255,255,.85); margin: 0; }
.form-success .mono { color: var(--green); }

/* Commercial — capability cards ──────────────────────────── */
.cap-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin-top: 56px;
}
.cap-card {
  background: linear-gradient(180deg, rgba(254,154,0,.04) 0%, rgba(0,0,0,0) 100%);
  border: 1px solid rgba(255,255,255,.1);
  padding: 36px 32px;
  display: flex; flex-direction: column; gap: 18px;
  transition: all .25s ease;
}
.cap-card:hover {
  border-color: rgba(248,178,74,.5);
  background: linear-gradient(180deg, rgba(254,154,0,.08) 0%, rgba(0,0,0,0) 100%);
  transform: translateY(-3px);
}
.cap-card .cap-i {
  display: block; margin-bottom: 10px;
  font-family: var(--sans); font-weight: 800; font-size: 19px; letter-spacing: .01em;
  line-height: 1.2; color: var(--gold-hi); text-transform: uppercase;
}
.cap-card h3 {
  font-family: var(--display); font-weight: 700; font-size: 24px;
  color: #fff; margin: 0; line-height: 1.2;
}
.cap-card p {
  font-family: var(--serif); font-size: 15px; line-height: 1.6;
  color: rgba(255,255,255,.7); margin: 0;
}
.cap-card ul {
  display: flex; flex-direction: column; gap: 8px;
  margin-top: auto;
  padding-top: 16px; border-top: 1px solid rgba(255,255,255,.06);
}
.cap-card li {
  font-family: var(--mono); font-size: 12px; letter-spacing: .08em;
  color: rgba(255,255,255,.6); padding-left: 16px; position: relative;
}
.cap-card li::before {
  content: "→"; position: absolute; left: 0; color: var(--gold);
}

/* Case studies row ─────────────────────────────────────── */
.case-row {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin-top: 56px;
}
.case {
  position: relative;
  background: #0B0B0B; border: 1px solid rgba(255,255,255,.08);
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
  transition: all .25s ease;
}
.case:hover { border-color: var(--gold); }
.case-sector {
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  color: var(--gold); text-transform: uppercase;
}
.case h4 {
  font-family: var(--display); font-weight: 700; font-size: 22px;
  color: #fff; margin: 0; line-height: 1.3;
}
.case-metric {
  font-family: var(--display); font-weight: 900; font-size: 56px;
  background: linear-gradient(180deg, var(--gold-hi), var(--gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  letter-spacing: -0.03em; line-height: 1;
}
.case-label {
  font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,.6);
}
.case p {
  font-family: var(--serif); font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,.7); margin: 0;
}

/* Quote ─────────────────────────────────────────────────── */
.quote-block {
  display: grid; grid-template-columns: 80px 1fr; gap: 32px;
  align-items: start;
  padding: 56px 0;
}
.quote-mark {
  font-family: var(--display); font-weight: 900; font-size: 120px;
  color: var(--gold); line-height: .8;
}
.quote-text {
  font-family: var(--display); font-weight: 400; font-size: 28px;
  line-height: 1.4; color: #fff; letter-spacing: -0.01em;
  margin: 0;
}
.quote-attr {
  font-family: var(--mono); font-size: 12px; letter-spacing: .15em;
  color: var(--gold); text-transform: uppercase;
  margin-top: 16px;
}
.quote-attr small {
  display: block;
  font-family: var(--sans); font-weight: 400; font-size: 11px;
  color: rgba(255,255,255,.5); letter-spacing: .08em;
  margin-top: 4px;
}

/* Job rows ─────────────────────────────────────────────── */
.jobs { display: flex; flex-direction: column; border-top: 1px solid rgba(255,255,255,.08); margin-top: 32px; }
.job { display: grid; grid-template-columns: 1fr 200px 160px 120px; gap: 24px; align-items: center; padding: 24px 16px; border-bottom: 1px solid rgba(255,255,255,.08); transition: background .2s ease; cursor: pointer; }
.job:hover { background: rgba(248,178,74,.04); padding-left: 24px; }
.job-title { font-family: var(--display); font-weight: 700; font-size: 18px; color: #fff; }
.job-team { font-family: var(--mono); font-size: 11px; letter-spacing: .15em; color: var(--gold); text-transform: uppercase; }
.job-loc { font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,.65); }
.job-clear { font-family: var(--mono); font-size: 10px; letter-spacing: .15em; color: rgba(255,255,255,.6); text-transform: uppercase; padding: 4px 8px; border: 1px solid rgba(255,255,255,.15); justify-self: end; }
.job-clear.ts { color: var(--gold); border-color: var(--gold); }

/* Vehicle detail ─────────────────────────────────────── */
.vh-detail { background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.1); border-left: 3px solid var(--gold); padding: 32px 36px; display: grid; grid-template-columns: 80px 1fr 240px; gap: 32px; align-items: start; margin-bottom: 16px; transition: background .2s ease; }
.vh-detail:hover { background: rgba(248,178,74,.04); }
.vh-i { font-family: var(--mono); font-size: 12px; letter-spacing: .25em; color: var(--gold); text-transform: uppercase; padding-top: 8px; }
.vh-body h3 { font-family: var(--display); font-weight: 900; font-size: 30px; color: #fff; margin: 0 0 8px; letter-spacing: -.01em; }
.vh-body .vh-sub { font-family: var(--sans); font-weight: 500; font-size: 14px; color: rgba(255,255,255,.6); margin-bottom: 14px; letter-spacing: .04em; text-transform: uppercase; }
.vh-body p { font-family: var(--serif); font-size: 15px; line-height: 1.65; color: rgba(255,255,255,.8); margin: 0 0 12px; }
.vh-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.vh-tags span { font-family: var(--mono); font-size: 10px; letter-spacing: .12em; color: rgba(255,255,255,.6); padding: 4px 8px; border: 1px solid rgba(255,255,255,.1); text-transform: uppercase; }
.vh-info { display: flex; flex-direction: column; gap: 10px; }
.vh-info-row { display: flex; flex-direction: column; gap: 2px; padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.06); }
.vh-info-row:last-child { border: 0; }
.vh-info-row span { font-family: var(--mono); font-size: 9px; letter-spacing: .2em; color: rgba(255,255,255,.4); text-transform: uppercase; }
.vh-info-row b { font-family: var(--mono); font-size: 13px; color: #fff; letter-spacing: .04em; }
.vh-info-row b.amber { color: var(--gold); }

/* Article cards ──────────────────────────────────────── */
.art-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.art { background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.08); padding: 28px; display: flex; flex-direction: column; gap: 14px; transition: all .25s ease; }
.art:hover { border-color: rgba(248,178,74,.5); background: rgba(248,178,74,.03); }
.art-cover { aspect-ratio: 16/9; background: linear-gradient(135deg, rgba(248,178,74,.15), rgba(0,17,34,.7)); border: 1px solid rgba(255,255,255,.08); display: grid; place-items: center; font-family: var(--mono); font-size: 11px; letter-spacing: .2em; color: rgba(255,255,255,.4); text-transform: uppercase; position: relative; overflow: hidden; }
.art-cover::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(248,178,74,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(248,178,74,.06) 1px, transparent 1px); background-size: 24px 24px; }
.art-cover span { position: relative; }
.art-cover.has-img { background: #001122 center / cover no-repeat; }
.art-cover.has-img::before { display: none; }
.art-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; color: var(--gold); text-transform: uppercase; }
.art h3 { font-family: var(--display); font-weight: 700; font-size: 20px; line-height: 1.3; color: #fff; margin: 0; }
.art p { font-family: var(--serif); font-size: 14px; line-height: 1.55; color: rgba(255,255,255,.7); margin: 0; }
.art-meta { display: flex; align-items: center; gap: 12px; margin-top: auto; padding-top: 12px; border-top: 1px solid rgba(255,255,255,.06); font-family: var(--mono); font-size: 11px; color: rgba(255,255,255,.45); letter-spacing: .04em; }

/* Legal / TOC ────────────────────────────────────────── */
.legal { display: grid; grid-template-columns: 260px 1fr; gap: 64px; margin-top: 48px; }
.legal-toc { position: sticky; top: 100px; align-self: start; padding-right: 20px; }
.legal-toc h6 { font-family: var(--mono); font-size: 10px; letter-spacing: .2em; color: var(--gold); margin: 0 0 14px; text-transform: uppercase; }
.legal-toc a { display: block; padding: 6px 0; font-family: var(--sans); font-size: 13px; color: rgba(255,255,255,.6); border-left: 2px solid transparent; padding-left: 12px; transition: all .15s ease; }
.legal-toc a:hover, .legal-toc a.active { color: var(--gold); border-color: var(--gold); }
.legal-body h2 { font-family: var(--display); font-weight: 700; font-size: 24px; color: #fff; margin: 48px 0 14px; letter-spacing: -.01em; }
.legal-body h2:first-child { margin-top: 0; }
.legal-body p, .legal-body li { font-family: var(--serif); font-size: 15px; line-height: 1.7; color: rgba(255,255,255,.78); margin: 0 0 12px; }
.legal-body ul { padding-left: 20px; margin-bottom: 12px; }
.legal-body ul li { list-style: disc; }
.legal-body code { font-family: var(--mono); font-size: 13px; background: rgba(255,255,255,.05); padding: 2px 6px; color: var(--gold); }

/* Product page hero ──────────────────────────────────── */
.prod-hero { padding: 120px 0; background: linear-gradient(180deg, #001122 0%, #000 100%); position: relative; overflow: hidden; }
.prod-hero-grid { background-image: linear-gradient(rgba(248,178,74,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(248,178,74,.04) 1px, transparent 1px); background-size: 48px 48px; position: absolute; inset: 0; mask-image: radial-gradient(ellipse at 50% 50%, #000 0%, transparent 70%); }
.prod-hero-inner { position: relative; display: grid; grid-template-columns: 1fr 480px; gap: 80px; align-items: center; }
.prod-tag { display: inline-block; font-family: var(--mono); font-size: 11px; letter-spacing: .25em; color: var(--gold); padding: 6px 12px; border: 1px solid rgba(248,178,74,.4); text-transform: uppercase; margin-bottom: 24px; }
.prod-name { font-family: var(--display); font-weight: 900; font-size: clamp(72px, 9vw, 128px); line-height: .9; letter-spacing: -.04em; color: #fff; margin: 0 0 20px; text-transform: uppercase; }
.prod-name .gold { background: linear-gradient(180deg, var(--gold-hi), var(--gold-lo)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.prod-sub { font-family: var(--display); font-weight: 700; font-size: 28px; color: var(--gold); margin: 0 0 20px; letter-spacing: -.01em; }
.prod-desc { font-family: var(--serif); font-size: 20px; line-height: 1.55; color: rgba(255,255,255,.8); max-width: 560px; margin: 0 0 32px; }
.prod-glyph { aspect-ratio: 1; background: linear-gradient(135deg, rgba(0,0,0,.9), rgba(0,17,34,.7)); border: 1px solid rgba(248,178,74,.3); display: grid; place-items: center; position: relative; overflow: hidden; }
.prod-glyph::before { content: attr(data-letter); font-family: var(--display); font-weight: 900; font-size: 280px; color: rgba(248,178,74,.95); line-height: 1; letter-spacing: -.05em; }
.prod-glyph-meta { position: absolute; bottom: 16px; left: 16px; right: 16px; display: flex; justify-content: space-between; font-family: var(--mono); font-size: 10px; letter-spacing: .2em; color: rgba(255,255,255,.5); text-transform: uppercase; }

/* Feature rows ───────────────────────────────────────── */
.feat-rows { display: flex; flex-direction: column; gap: 0; margin-top: 48px; border-top: 1px solid rgba(255,255,255,.08); }
.feat-row { display: grid; grid-template-columns: 80px 280px 1fr; gap: 40px; padding: 36px 0; border-bottom: 1px solid rgba(255,255,255,.08); align-items: start; }
.feat-num { font-family: var(--mono); font-size: 12px; letter-spacing: .25em; color: var(--gold); text-transform: uppercase; padding-top: 6px; }
.feat-row h3 { font-family: var(--display); font-weight: 700; font-size: 26px; color: #fff; margin: 0; letter-spacing: -.01em; line-height: 1.2; }
.feat-row p { font-family: var(--serif); font-size: 16px; line-height: 1.65; color: rgba(255,255,255,.75); margin: 0; }

/* Leadership team grid — used on careers.html and our-story.html */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-top: 56px;
}
.team-card {
  position: relative;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.08);
  cursor: pointer;
  display: flex; flex-direction: column;
  text-align: left;
  transition: border-color .2s ease, background .2s ease, transform .2s ease;
  overflow: hidden;
  font: inherit;
  color: inherit;
  padding: 0;
}
.team-card:hover {
  border-color: rgba(248,178,74,.5);
  background: rgba(248,178,74,.04);
  transform: translateY(-3px);
}
.team-photo {
  aspect-ratio: 287 / 342;
  background:
    linear-gradient(180deg, rgba(248,178,74,.06) 0%, rgba(0,17,34,.6) 100%),
    repeating-linear-gradient(45deg, rgba(255,255,255,.02) 0 1px, transparent 1px 12px);
  border-bottom: 1px solid rgba(248,178,74,.2);
  overflow: hidden;
  position: relative;
}
.team-photo img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center top;
  display: block;
  filter: saturate(1.02);
}
.team-photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(0,17,34,.55) 100%);
  pointer-events: none;
}
.team-meta {
  padding: 20px 22px 22px;
  display: flex; flex-direction: column; gap: 6px;
}
.team-name {
  font-family: var(--display); font-weight: 700; font-size: 18px;
  color: #fff; letter-spacing: -.01em; line-height: 1.2;
}
.team-role {
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: var(--gold); text-transform: uppercase; line-height: 1.4;
}
.team-read {
  margin-top: 10px;
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  color: rgba(255,255,255,.45); text-transform: uppercase;
  display: flex; align-items: center; gap: 8px;
}
.team-card:hover .team-read { color: var(--gold); }
.team-read::after {
  content: ""; flex: 1; height: 1px;
  background: linear-gradient(90deg, rgba(248,178,74,.4), transparent);
}

/* Featured founder card spans full width */
.team-founder {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 0;
  padding: 0;
}
.team-founder .team-photo { aspect-ratio: auto; height: 100%; min-height: 320px; border-bottom: 0; border-right: 1px solid rgba(248,178,74,.2); }
.team-founder .team-meta { padding: 36px 40px; gap: 12px; justify-content: center; }
.team-founder .team-name { font-size: 32px; }
.team-founder .team-role { font-size: 11px; }
.team-founder p { font-family: var(--serif); font-size: 15px; line-height: 1.65; color: rgba(255,255,255,.75); margin: 8px 0 0; max-width: 720px; }
.team-founder .team-tag { font-family: var(--mono); font-size: 10px; letter-spacing: .25em; color: var(--gold); text-transform: uppercase; }

/* Bio modal */
.bio-modal {
  position: fixed; inset: 0; z-index: 100;
  background: rgba(0,8,16,.85);
  backdrop-filter: blur(8px);
  display: none;
  align-items: flex-start; justify-content: center;
  padding: 60px 24px;
  overflow-y: auto;
}
.bio-modal.open { display: flex; }
.bio-card {
  position: relative;
  width: min(880px, 100%);
  background: #001122;
  border: 1px solid rgba(248,178,74,.3);
  box-shadow: 0 40px 80px -20px rgba(0,0,0,.8), 0 0 60px rgba(248,178,74,.06);
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 0;
}
.bio-card-photo {
  background: linear-gradient(180deg, rgba(248,178,74,.06) 0%, rgba(0,17,34,.6) 100%);
  border-right: 1px solid rgba(248,178,74,.2);
  position: relative;
  overflow: hidden;
}
.bio-card-photo img { width: 100%; height: 100%; object-fit: cover; object-position: center top; display: block; }
.bio-card-photo .corner-mark {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--mono); font-size: 9px; letter-spacing: .25em;
  color: rgba(248,178,74,.9); text-transform: uppercase;
  background: rgba(0,17,34,.7); padding: 4px 8px;
  border: 1px solid rgba(248,178,74,.3);
}
.bio-card-body { padding: 40px 44px; display: flex; flex-direction: column; gap: 18px; }
.bio-card-role { font-family: var(--mono); font-size: 10px; letter-spacing: .25em; color: var(--gold); text-transform: uppercase; }
.bio-card-name { font-family: var(--display); font-weight: 900; font-size: 36px; color: #fff; letter-spacing: -.02em; line-height: 1.05; margin: 0; }
.bio-card-contact {
  font-family: var(--mono); font-size: 12px; line-height: 1.65;
  color: rgba(255,255,255,.7);
  padding: 12px 14px;
  background: rgba(255,255,255,.02);
  border-left: 2px solid var(--gold);
  white-space: pre-line;
}
.bio-card-contact a { color: var(--gold); }
.bio-card-bio {
  font-family: var(--serif); font-size: 15px; line-height: 1.7;
  color: rgba(255,255,255,.82);
  max-height: 50vh; overflow-y: auto;
  padding-right: 8px;
}
.bio-card-bio p { margin: 0 0 14px; }
.bio-card-bio p:last-child { margin-bottom: 0; }
.bio-card-bio::-webkit-scrollbar { width: 6px; }
.bio-card-bio::-webkit-scrollbar-thumb { background: rgba(248,178,74,.3); }
.bio-card-bio::-webkit-scrollbar-track { background: rgba(255,255,255,.03); }

.bio-close {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  background: rgba(0,17,34,.8);
  border: 1px solid rgba(255,255,255,.15);
  color: rgba(255,255,255,.85);
  font-family: var(--mono); font-size: 18px;
  cursor: pointer;
  display: grid; place-items: center;
  transition: all .15s ease;
  z-index: 2;
}
.bio-close:hover { background: var(--gold); color: #001122; border-color: var(--gold); }

@media (max-width: 1100px) {
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .team-founder { grid-template-columns: 1fr; }
  .team-founder .team-photo { border-right: 0; border-bottom: 1px solid rgba(248,178,74,.2); aspect-ratio: 287 / 342; height: auto; }
  .bio-card { grid-template-columns: 1fr; }
  .bio-card-photo { aspect-ratio: 287 / 342; border-right: 0; border-bottom: 1px solid rgba(248,178,74,.2); }
  .bio-card-body { padding: 28px; }
}
@media (max-width: 640px) {
  .team-grid { grid-template-columns: 1fr; }
}

/* Adjust responsive */
@media (max-width: 1100px) {
  .job { grid-template-columns: 1fr; gap: 8px; }
  .vh-detail { grid-template-columns: 1fr; }
  .art-grid { grid-template-columns: 1fr; }
  .feat-row { grid-template-columns: 1fr; gap: 16px; }
  .legal { grid-template-columns: 1fr; }
  .legal-toc { position: static; }
  .prod-hero-inner { grid-template-columns: 1fr; }
  .prod-glyph { max-width: 320px; }
  .stage { grid-template-columns: 1fr; }
  .forge-modules { grid-template-columns: 1fr 1fr; }
  .stage-num { border-right: 0; border-bottom: 1px solid rgba(255,255,255,.05); }
  .sdlc { grid-template-columns: repeat(3, 1fr); }
  .sdlc-step::after { display: none; }
  .timeline { padding-left: 60px; }
  .tl-year { position: relative; left: 0; top: 0; text-align: left; width: auto; margin-bottom: 8px; font-size: 32px; }
  .tl-event { padding-left: 30px; }
  .timeline::before { left: 0; }
  .tl-event::before { left: -7px; }
  .leadership, .lab-products, .cap-grid, .case-row { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .values { grid-template-columns: 1fr 1fr; }
  .value:nth-child(4n) { border-right: 1px solid rgba(255,255,255,.08); }
  .value:nth-child(2n) { border-right: 0; }
  .certs { grid-template-columns: repeat(4, 1fr); }
  .svc { grid-template-columns: 1fr; gap: 12px; }
  .sub-hero-inner { grid-template-columns: 1fr; }
  .sub-hero-stats { border-left: 0; padding-left: 0; border-top: 1px solid rgba(248,178,74,.3); padding-top: 24px; flex-direction: row; flex-wrap: wrap; gap: 32px; }
  .mega-inner, .mega-inner[data-cols] { grid-template-columns: 1fr 1fr; }
  .field-row { grid-template-columns: 1fr; }
}

/* ============================================================
   Sub-page responsive overrides (tablet → phone)
============================================================ */
@media (max-width: 900px) {
  .impact-grid,
  .forge-connect-grid,
  .forge-modules { grid-template-columns: 1fr 1fr; }
  .pp-hero-inner,
  .pp-transform-grid { grid-template-columns: 1fr; gap: 40px; }
  .pp-hero-right { text-align: left; align-self: start; }
  .prod-hero-inner { gap: 48px; }
  .sdlc { grid-template-columns: repeat(2, 1fr); }
  .quote-block { grid-template-columns: 56px 1fr; gap: 20px; }
  .quote-mark { font-size: 80px; }
}

@media (max-width: 768px) {
  /* Trim oversized vertical rhythm on sub-pages */
  .section-pad { padding: 80px 0; }
  .pp-section, .pp-specs, .pp-callout-wrap { padding: 56px 0; }
  .pp-transform, .pp-learn { padding: 64px 0; }
  .os-story, .os-leader, .os-founder { padding: 80px 0; }
  .os-cta { padding: 72px 0; }
  .sub-hero { padding: 56px 0; }
  .os-hero { padding: 120px 0 96px; }
  .forge-hero, .prod-hero { padding: 120px 0 80px; }
  .pp-hero { padding: 110px 0 64px; }
  .pp-banner { height: 320px; }

  /* Large sub-page headings → fluid */
  .os-leader-title, .os-founder-text h2, .os-cta h2,
  .pp-section-title, .fed-domains-title, .forge-cta h2 { font-size: clamp(28px, 6vw, 40px); }
  .pp-transform-left h2 { font-size: clamp(30px, 6.5vw, 44px); }
  .pp-callout { padding: 36px 28px; }
  .pp-callout p { font-size: clamp(20px, 3.6vw, 28px); }
  .quote-text { font-size: clamp(20px, 3.6vw, 28px); }
}

@media (max-width: 600px) {
  .impact-grid,
  .forge-connect-grid,
  .forge-modules,
  .forge-modules-grid,
  .pp-caps-grid,
  .pp-specs-grid,
  .pp-transform-right,
  .vh-cards { grid-template-columns: 1fr; }
  .sdlc { grid-template-columns: 1fr 1fr; }
  .values { grid-template-columns: 1fr; }
  .value:nth-child(n) { border-right: 0; }
  .stage-mod { grid-template-columns: 1fr; gap: 4px; }
  .stage-num { padding: 20px 22px; }
  .stage-body { padding: 22px 24px; }
  .quote-block { grid-template-columns: 1fr; gap: 0; }
  .quote-mark { font-size: 60px; line-height: .6; }
  .pp-learn-card { flex-direction: column; align-items: flex-start; gap: 20px; }
  .forge-cta { padding: 40px 24px; }
  /* certs: re-assert below the later ≤1100 block that sets 4-up */
  .certs, .cert-row { grid-template-columns: repeat(2, 1fr) !important; }
  /* Our Story timeline → single rail on phones */
  .os-tl { grid-template-columns: 1fr; gap: 0; }
  .os-tl::before { left: 7px; transform: none; }
  .os-tl-evt.left, .os-tl-evt.right { grid-column: 1; justify-content: flex-start; text-align: left; padding-left: 30px; }
  .os-tl-evt .os-tl-text { max-width: none; }
  .os-tl-evt.left::after, .os-tl-evt.right::after { left: 0; right: auto; }
  .work-case-body, .contact-form, .talent-form { padding: 28px 22px; }
  .pp-hero-title { font-size: clamp(48px, 13vw, 72px); }
  .prod-name { font-size: clamp(56px, 15vw, 96px); }
  .crumb { flex-wrap: wrap; }
  .role-meta { gap: 8px; }
  .lab-product { padding: 28px 24px; }
  .lab-product .lp-meta { flex-wrap: wrap; gap: 14px 24px; }
  .lab-product .lp-meta > div { flex: 1 0 40%; }
}

@media (max-width: 420px) {
  .sdlc { grid-template-columns: 1fr; }
  .sdlc-step { flex-direction: row; align-items: center; gap: 12px; }
  /* Allow grid cells to shrink below content width on tiny screens */
  .os-grid > *, .sub-hero-inner > *, .os-narrative-image, .prod-hero-inner > * { min-width: 0; }
  .os-narrative-image { grid-template-columns: 1fr; }
}

/* ============================================================
   DSD FORGE — Platform Overview (Federal & Commercial)
============================================================ */
.forge-ov-grid {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 64px;
  align-items: center;
}
.forge-ov-eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: var(--serif); font-weight: 700;
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 26px;
}
.forge-ov-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); }
.forge-ov-logo {
  font-family: var(--display); font-weight: 900;
  font-size: clamp(34px, 4.4vw, 50px); line-height: 1;
  letter-spacing: -.01em; text-transform: uppercase;
  display: flex; align-items: baseline; gap: 14px; margin: 0 0 24px;
}
.forge-ov-logo .dsd { color: var(--gold); }
.forge-ov-logo .forge { color: var(--gold); }
.forge-ov-desc {
  font-family: var(--serif); font-size: 18px; line-height: 1.62;
  color: rgba(255,255,255,.7); margin: 0 0 34px; max-width: 640px;
}
.forge-ov-list { display: flex; flex-direction: column; gap: 20px; margin: 0 0 38px; }
.forge-ov-list li { padding-left: 18px; border-left: 2px solid var(--gold); }
.forge-ov-list h4 {
  font-family: var(--sans); font-weight: 800; font-size: 17px;
  letter-spacing: .02em; text-transform: uppercase; color: #fff; margin: 0 0 5px;
}
.forge-ov-list p {
  font-family: var(--serif); font-size: 15px; line-height: 1.5;
  color: rgba(255,255,255,.6); margin: 0;
}
.forge-ov-media {
  align-self: stretch; min-height: 480px; border-radius: 4px;
  background-size: cover; background-position: center;
  border: 1px solid rgba(255,255,255,.08);
}
@media (max-width: 920px) {
  .forge-ov-grid { grid-template-columns: 1fr; gap: 40px; }
  .forge-ov-media { min-height: 340px; order: -1; }
}

/* ============================================================
   DSD FORGE — Modular Architecture + SDLC phase table
============================================================ */
.fp-modular-head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 56px;
  align-items: start; margin-bottom: 64px;
}
.fp-modular-title {
  font-family: var(--display); font-weight: 800; font-size: clamp(26px, 3vw, 32px);
  text-transform: uppercase; color: var(--gold); margin: 0 0 22px; letter-spacing: -.01em;
}
.fp-modular-list { display: flex; flex-direction: column; gap: 12px; }
.fp-modular-list li, .fp-modular-notes li {
  font-family: var(--serif); font-size: 16px; line-height: 1.5; color: rgba(255,255,255,.85);
}
.fp-modular-notes { display: flex; flex-direction: column; gap: 16px; padding-top: 6px; }
.fp-modular-notes li { position: relative; padding-left: 20px; color: rgba(255,255,255,.7); }
.fp-modular-notes li::before {
  content: ""; position: absolute; left: 0; top: 9px; width: 6px; height: 6px;
  border-radius: 50%; background: var(--gold);
}
.fp-forge-mark {
  font-family: var(--display); font-weight: 900; font-size: clamp(36px, 5vw, 48px);
  line-height: 1; margin: 0 0 28px; display: flex; align-items: flex-start; gap: 14px;
}
.fp-forge-mark .dsd { color: var(--gold); }
.fp-forge-mark .forge { color: #fff; }
.fp-forge-mark sup { font-size: .35em; color: rgba(255,255,255,.5); margin-top: .4em; }
.fp-cards {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; margin-bottom: 56px;
}
.fp-card {
  background: #0B0B0B; border: 1px solid rgba(248,178,74,.4); border-radius: 6px;
  padding: 26px;
}
.fp-card-icon { width: 40px; height: 40px; color: var(--gold); margin-bottom: 26px; }
.fp-card-icon svg { width: 100%; height: 100%; }
.fp-card h4 { font-family: var(--sans); font-weight: 700; font-size: 18px; color: #fff; margin: 0 0 6px; }
.fp-card p { font-family: var(--sans); font-weight: 500; font-size: 14px; color: rgba(255,255,255,.7); margin: 0; }

.fp-phases { display: flex; flex-direction: column; gap: 16px; }
.fp-phase { display: grid; grid-template-columns: 240px 1fr; align-items: center; gap: 0; }
.fp-phase-label {
  font-family: var(--serif); font-size: 24px; letter-spacing: -.02em; color: #fff;
}
.fp-phase-body {
  background: rgba(255,255,255,.02); border: 1px solid transparent; padding: 24px 28px;
}
.fp-phase.is-key .fp-phase-body { border-color: var(--gold); }
.fp-goal {
  font-family: var(--sans); font-weight: 700; font-size: 18px; color: var(--amber); margin: 0 0 16px;
}
.fp-phase-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 20px 40px; }
.fp-phase-cols.one { grid-template-columns: 1fr; }
.fp-phase-cols.three { grid-template-columns: repeat(3, 1fr); }
.fp-phase-cols b { display: block; font-family: var(--sans); font-weight: 700; font-size: 18px; color: #fff; margin-bottom: 4px; }
.fp-phase-cols p { font-family: var(--sans); font-weight: 500; font-size: 14px; line-height: 1.5; color: rgba(255,255,255,.7); margin: 0; }
@media (max-width: 920px) {
  .fp-modular-head { grid-template-columns: 1fr; gap: 32px; }
  .fp-cards { grid-template-columns: 1fr 1fr; }
  .fp-phase { grid-template-columns: 1fr; gap: 8px; }
  .fp-phase-label { font-size: 20px; }
}
@media (max-width: 560px) {
  .fp-cards { grid-template-columns: 1fr; }
  .fp-phase-cols, .fp-phase-cols.three { grid-template-columns: 1fr; }
}

/* ── Human verification (CAPTCHA) ─────────────────────────── */
.captcha {
  display: flex; align-items: center; gap: 14px;
  width: max-content; max-width: 100%;
  padding: 14px 18px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 4px;
  font-family: var(--sans);
  user-select: none; cursor: pointer;
  transition: border-color .15s ease;
}
.captcha:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }
.captcha-box {
  width: 26px; height: 26px; flex: none;
  border: 2px solid rgba(255,255,255,.35);
  border-radius: 3px; background: rgba(0,0,0,.3);
  display: grid; place-items: center;
  transition: border-color .15s ease, background .15s ease;
}
.captcha:hover .captcha-box { border-color: var(--gold); }
.captcha-box svg {
  width: 18px; height: 18px; opacity: 0;
  stroke: var(--bg-navy); stroke-width: 3.5; fill: none;
  stroke-dasharray: 26; stroke-dashoffset: 26;
  transition: stroke-dashoffset .35s ease .05s, opacity .12s ease;
}
.captcha.checked .captcha-box { background: var(--gold); border-color: var(--gold); }
.captcha.checked .captcha-box svg { opacity: 1; stroke-dashoffset: 0; }
.captcha-label { font-size: 15px; color: rgba(255,255,255,.85); }
.captcha-brand {
  margin-left: auto; padding-left: 20px;
  display: flex; flex-direction: column; align-items: flex-end; gap: 2px;
  border-left: 1px solid rgba(255,255,255,.1);
}
.captcha-brand .mark { font-family: var(--mono); font-size: 10px; letter-spacing: .14em; color: var(--gold); }
.captcha-brand .sub { font-family: var(--mono); font-size: 8px; letter-spacing: .1em; color: rgba(255,255,255,.4); }
.captcha.error { border-color: rgba(255,99,99,.65); animation: capShake .35s; }
.captcha-msg { display: none; font-family: var(--sans); font-size: 13px; color: #ff8a8a; margin-top: -6px; }
@keyframes capShake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-5px)} 75%{transform:translateX(5px)} }

/* ── Career Roadmap page ──────────────────────────────────── */
.rm-back {
  display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
  font-family: var(--sans); font-weight: 700; font-size: 14px;
  color: rgba(255,255,255,.6);
}
.rm-back:hover { color: var(--gold); }
.rm-divider {
  height: 2px; margin: 56px 0 40px;
  background: linear-gradient(90deg, rgba(0,0,0,0) 0%, rgba(248,178,74,.55) 50%, rgba(0,0,0,0) 100%);
}
.rm-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.rm-benefits { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; }
.rm-benefit {
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px; padding: 32px;
  transition: border-color .2s ease, transform .2s ease;
}
.rm-benefit:hover { border-color: rgba(248,178,74,.4); transform: translateY(-3px); }
.rm-benefit h3 {
  font-family: var(--sans); font-weight: 700; font-size: 24px;
  letter-spacing: -.015em; color: #fff; margin: 0 0 12px;
}
.rm-benefit p {
  font-family: var(--sans); font-size: 16px; line-height: 1.6;
  color: rgba(255,255,255,.7); margin: 0;
}
@media (max-width: 900px) {
  .rm-cards { grid-template-columns: 1fr; }
  .rm-benefits { grid-template-columns: 1fr; }
}

