/* =========================================================
   KAPU SOLUTIONS — DARK EDITORIAL DESIGN SYSTEM
   - Display:  Archivo Black (poster caps, headlines)
   - Body:     Manrope
   - Mono:     JetBrains Mono (eyebrows, micro-labels)
   - Accent:   Pacific navy #3a7ee0 (Peraton-aligned, lifted for dark mode)
   - Bg:       Near-black #0a0a0a / elevated #121212
   ========================================================= */

/* ---------- TOKENS ---------- */
:root{
  /* Surfaces */
  --paper:        #0a0a0a;     /* default page bg */
  --paper-2:      #121212;     /* warm rhythm bg */
  --paper-3:      #050505;     /* deeper inverted blocks */
  --ink:          #ffffff;     /* headlines */
  --ink-2:        #e8ebed;     /* secondary heading */
  --rule:         #2a2a2a;     /* hairlines */
  --rule-2:       #1d1d1d;     /* subtle dividers */
  --muted:        #b8b8b8;     /* body copy */
  --muted-2:      #888888;     /* captions, micro-labels */
  --muted-3:      #5a5a5a;     /* very dim */

  /* Brand — Pacific navy (Peraton-aligned #003388, lifted for dark backgrounds) */
  --accent:       #3a7ee0;     /* primary accent — navy lifted for dark */
  --accent-hover: #5a99e8;     /* lifted on hover */
  --accent-deep:  #1d5fb8;     /* deeper variant for eyebrows on alt sections */
  --accent-glow:  rgba(58,126,224,0.20);

  /* Elevated Company-tab additions */
  --ink-3:        #b8c0c8;     /* lede body on dark */
  --paper-elev:   #1a1a1a;     /* elevated cards */
  --ease-out:     cubic-bezier(0.16, 1, 0.3, 1);

  /* Legacy aliases — keep so inner pages don't break */
  --bg: var(--paper);
  --bg-elev: var(--paper-2);
  --bg-elev-2: #1a1a1a;
  --text: var(--ink);
  --text-dim: var(--muted);
  --text-muted: var(--muted-2);
  --border: var(--rule);
  --shadow: 0 10px 30px rgba(0,0,0,0.4);
  --header-h: 72px;
  --radius: 0;

  /* Layout — wide, full-bleed feel; generous gutters keep edges from touching */
  --maxw:      1840px;
  --gutter:    clamp(24px, 5vw, 100px);
  --pad-y:     clamp(72px, 9vw, 128px);

  /* Type stacks */
  --display:   "Archivo Black", "Helvetica Neue", Arial, sans-serif;
  --body:      "Manrope", "Inter", "Helvetica Neue", Arial, sans-serif;
  --mono:      "JetBrains Mono", ui-monospace, Menlo, monospace;

  /* Motion */
  --ease:      cubic-bezier(0.2, 0.6, 0.2, 1);
}

*,*::before,*::after{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  scroll-padding-top:var(--header-h);
}
html, body{margin:0;padding:0;background:var(--paper);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}

/* Inner pages: gentle proximity snap on section starts */
html{scroll-snap-type:y proximity}
main > section, footer.site-footer{scroll-snap-align:start;scroll-snap-stop:normal}

/* =========================================================
   HOMEPAGE FULL-SCREEN PRESENTATION MODE
   Each section is exactly one viewport tall and locks into
   place as you scroll — Peraton-style panel presentation.
   ========================================================= */
html:has(body[data-page="home"]){scroll-snap-type:y mandatory}
body[data-page="home"] main > section:not(.hero){
  min-height:100vh;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  scroll-snap-align:start;
  scroll-snap-stop:always;
  padding-block:clamp(96px, 12vh, 140px);
}
body[data-page="home"] .hero{scroll-snap-align:start;scroll-snap-stop:always}
/* Panels must span the full panel width, not shrink-wrap to centered content */
body[data-page="home"] main > section > .wrap{width:100%}
body[data-page="home"] footer.site-footer{scroll-snap-align:start}
/* Duo tiles must fit two-up inside a single panel */
body[data-page="home"] .duo .tile{aspect-ratio:auto;height:min(56vh, 600px)}

@media (prefers-reduced-motion: reduce){
  html, html:has(body[data-page="home"]){scroll-snap-type:none}
  body[data-page="home"] main > section:not(.hero){min-height:0}
}
/* On short viewports, release the mandatory snap so tall content isn't trapped */
@media (max-height: 640px){
  html:has(body[data-page="home"]){scroll-snap-type:y proximity}
  body[data-page="home"] main > section:not(.hero){min-height:0}
}
img, video{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;padding:0}
::selection{background:var(--accent);color:var(--paper)}

/* ---------- FOCUS VISIBILITY (keyboard) ---------- */
:focus-visible{outline:2px solid var(--accent-hover, #5a99e8);outline-offset:2px;border-radius:2px}
/* Don't show the ring on mouse/touch clicks, only keyboard */
:focus:not(:focus-visible){outline:none}

/* ---------- SKIP LINK ---------- */
.skip-link{
  position:absolute;left:12px;top:-48px;z-index:200;
  background:var(--ink);color:var(--paper);
  padding:10px 18px;border-radius:0 0 6px 6px;
  font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:0;color:var(--paper)}

/* Screen-reader-only utility */
.visually-hidden{
  position:absolute !important;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);
  white-space:nowrap;border:0;
}

/* ---------- TYPE PRIMITIVES ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;align-items:center;gap:10px;
  font-weight:500;
}
.eyebrow::before{
  content:"";
  width:24px;height:1px;
  background:var(--accent);
  display:inline-block;
}

.display{
  font-family:var(--display);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:-.02em;
  line-height:.92;
  color:var(--ink);
}
h1.display{font-size:clamp(44px,7.5vw,96px);line-height:.9;letter-spacing:-.025em}
h2.display{font-size:clamp(36px,5.2vw,72px);line-height:.96;letter-spacing:-.02em}
h3.display{font-size:clamp(26px,3vw,42px);line-height:1;letter-spacing:-.015em}
h4.display{font-size:clamp(20px,1.8vw,28px);line-height:1.05;letter-spacing:-.01em}

p.lede{
  font-size:clamp(17px,1.3vw,20px);
  line-height:1.6;
  max-width:60ch;
  color:var(--muted);
  font-weight:400;
  margin:0;
}
p.body{
  font-size:17px;
  line-height:1.7;
  max-width:60ch;
  color:var(--muted);
  margin:0;
}
p.body em, p.lede em{font-style:italic;color:var(--ink-2)}

.mono{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--muted-2)}

.link-arrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:14px;font-weight:600;letter-spacing:.04em;
  color:var(--ink);
  padding-bottom:4px;
  position:relative;
  text-transform:uppercase;
  font-family:var(--body);
  white-space:nowrap;
}
.link-arrow::after{
  content:"";position:absolute;left:0;right:30%;bottom:0;height:1px;background:var(--ink);
  transform-origin:left;transition:transform .35s var(--ease);
}
.link-arrow:hover::after{transform:scaleX(calc(10/7))}
.link-arrow .arr{transition:transform .3s var(--ease);display:inline-block}
.link-arrow:hover .arr{transform:translateX(6px)}

/* ---------- LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter)}
section{padding-block:var(--pad-y)}
section.tight{padding-block:clamp(64px,9vw,120px)}
.bg-paper-2{background:var(--paper-2)}
.bg-deep{background:var(--paper-3)}
.bg-accent{background:var(--accent);color:var(--paper)}
.bg-accent .display, .bg-accent h2, .bg-accent h3, .bg-accent h4{color:var(--paper)}
.bg-accent p, .bg-accent .body, .bg-accent .lede{color:rgba(10,10,10,0.78)}
.bg-accent .eyebrow{color:rgba(10,10,10,0.78)}
.bg-accent .eyebrow::before{background:var(--paper)}

/* =========================================================
   1) TOP NAV + MEGA MENU
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  background:rgba(10,10,10,0.85);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  transition:box-shadow .3s var(--ease), background .3s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(10,10,10,0.96);
  box-shadow:0 8px 24px -18px rgba(0,0,0,0.7);
  border-bottom-color:var(--rule);
}
.nav .row{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);
}
.nav .brand{display:flex;align-items:center;color:var(--ink)}
.nav .brand img{height:56px;width:auto;transition:opacity .2s var(--ease)}
.nav .brand:hover img{opacity:0.85}

.nav ul.primary{
  list-style:none;
  display:flex;gap:36px;
  margin:0;padding:0;
}
.nav ul.primary > li > a,
.nav ul.primary > li > button{
  font-family:var(--body);
  font-size:14px;font-weight:600;letter-spacing:.02em;
  color:var(--ink);
  padding:24px 0;
  display:inline-block;
  position:relative;
}
.nav ul.primary > li > a::after,
.nav ul.primary > li > button::after{
  content:"";position:absolute;left:0;right:0;bottom:18px;height:2px;
  background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s var(--ease);
}
.nav ul.primary > li:hover > a::after,
.nav ul.primary > li:hover > button::after,
.nav ul.primary > li[data-open="true"] > button::after{transform:scaleX(1)}

.nav .utility{display:flex;align-items:center;gap:18px}
.nav .utility .cta{
  font-family:var(--body);
  font-size:13px;font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;
  padding:10px 18px;
  border:1px solid var(--ink);
  border-radius:999px;
  color:var(--ink);
  transition:background .2s var(--ease), color .2s var(--ease);
}
.nav .utility .cta:hover{background:var(--ink);color:var(--paper)}

/* Mega menu panel */
.megapanel{
  position:absolute;left:0;right:0;top:100%;
  background:var(--paper);
  border-top:1px solid var(--rule);
  box-shadow:0 24px 40px -28px rgba(0,0,0,0.7);
  opacity:0;transform:translateY(-8px);
  pointer-events:none;
  transition:opacity .22s var(--ease), transform .22s var(--ease);
}
.nav-item[data-open="true"] .megapanel{opacity:1;transform:translateY(0);pointer-events:auto}
.megapanel .mega{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:48px;
  padding-block:48px;
}
.megapanel .feature{display:flex;flex-direction:column;gap:18px;color:var(--ink)}
.megapanel .feature .ph{
  aspect-ratio:16/10;
  background:linear-gradient(135deg, #1a1a1a 0%, #0e0e0e 100%);
  background-size:cover;background-position:center;
  border:1px solid var(--rule);
  position:relative;overflow:hidden;
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:24px;
  box-shadow:inset 0 -90px 70px -40px rgba(5,5,5,0.9);
}
.megapanel .feature .ph::before{
  content:"";position:absolute;top:24px;left:24px;width:1px;height:36px;
  background:var(--accent);
}
.megapanel .feature .ph__label{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted-2);
}
.megapanel .feature h4{
  font-family:var(--display);
  text-transform:uppercase;
  font-size:22px;
  letter-spacing:-.01em;
  line-height:1.05;
  margin:0;
  color:var(--ink);
}
.megapanel .feature p{
  font-size:14.5px;line-height:1.55;
  color:var(--muted);
  margin:0;max-width:42ch;
}
.megapanel .feature:hover .ph{opacity:0.9}

.megapanel .col h5{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted-2);
  margin:0 0 14px;
  font-weight:500;
}
.megapanel .col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.megapanel .col a{
  font-family:var(--body);
  font-size:15px;font-weight:500;
  color:var(--ink);
  display:inline-block;padding:2px 0;
  position:relative;
}
.megapanel .col a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--accent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .25s var(--ease);
}
.megapanel .col a:hover::after{transform:scaleX(1)}

/* Nav toggle (mobile) */
.nav-toggle{
  display:none;
  width:44px;height:44px;
  background:transparent;border:0;color:var(--ink);
  cursor:pointer;padding:0;
}
.nav-toggle span{
  display:block;width:24px;height:2px;background:var(--ink);
  margin:5px auto;
  transition:transform .3s, opacity .3s;
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* =========================================================
   2) HERO — image-free, text-led
   ========================================================= */
.hero{
  position:relative;
  isolation:isolate;            /* own stacking context so the video layer can't paint over the headline */
  min-height:max(100vh, 760px);
  display:flex;align-items:flex-end;
  color:var(--ink);
  overflow:hidden;
  background:#050505;
  /* Reserve generous space for the fixed nav so the headline never crowds it */
  padding-top:calc(var(--header-h) + 80px);
}
/* Looping background video (decorative) — bottom layer, behind scrim + content */
.hero__video{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;
  object-fit:cover;
  pointer-events:none;
}
/* Tonal scrim over the video: navy glow + heavy darkening toward the bottom so
   the headline stays legible; light up top so the footage reads through. Also
   the dark fallback if the video is blocked or still loading. */
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse at 15% 85%, rgba(58,126,224,0.20), transparent 55%),
    radial-gradient(ellipse at 90% 12%, rgba(255,255,255,0.04), transparent 50%),
    linear-gradient(180deg, rgba(5,6,10,0.42) 0%, rgba(5,6,10,0.40) 38%, rgba(2,3,6,0.72) 78%, rgba(0,0,0,0.88) 100%);
}
/* Thin grid texture, kept subtle so it reads as an overlay, not noise */
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size:88px 88px;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 75%);
  opacity:0.4;
}
/* Vertical accent line on the left edge — quiet but distinctive */
.hero .accent-rail{
  position:absolute;top:25%;bottom:25%;left:0;width:2px;
  background:linear-gradient(180deg, transparent, var(--accent) 30%, var(--accent) 70%, transparent);
  z-index:2;
  opacity:0.7;
}
.hero .wrap{
  position:relative;z-index:3;
  width:100%;
  padding-bottom:clamp(80px,12vh,140px);
}
.hero .eyebrow{color:var(--ink);opacity:.85}
.hero .eyebrow::before{background:var(--accent)}
.hero h1{
  font-family:var(--display);font-weight:400;
  text-transform:uppercase;
  font-size:clamp(44px,8vw,112px);
  line-height:.9;letter-spacing:-.025em;
  color:var(--ink);
  margin:22px 0 28px;
  max-width:16ch;
}
/* On phones the 44px floor let the longest word ("COMMERCIAL" ≈ 7.3× the font
   size in width) overflow the screen. Scale the hero headline with the viewport
   below 600px; the 48px cap equals the size at the 600px boundary (8vw) so the
   transition to the desktop clamp is seamless. */
@media (max-width:600px){
  .hero h1{font-size:clamp(30px,11vw,48px)}
}
.hero h1 .accent{color:var(--accent)}
.hero .subhero{
  font-size:clamp(16px,1.3vw,20px);
  line-height:1.6;max-width:58ch;
  color:#c9d0d7;font-weight:400;
  margin:0;
}
.hero .meta-row{
  position:absolute;left:var(--gutter);right:var(--gutter);bottom:32px;
  display:flex;justify-content:space-between;align-items:flex-end;
  z-index:3;color:var(--ink);
}
.hero .next{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}
.hero .next .down{width:1px;height:48px;background:var(--ink);position:relative;overflow:hidden}
.hero .next .down::after{
  content:"";position:absolute;left:-2px;top:-48px;width:5px;height:48px;
  background:var(--accent);
  animation:dropline 2.6s var(--ease) infinite;
}
@keyframes dropline{0%{top:-48px}80%{top:48px}100%{top:48px}}
.hero .timestamp{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#b7c1cb}

/* =========================================================
   3) STATEMENT BLOCK
   ========================================================= */
.statement .grid{display:grid;grid-template-columns:5fr 7fr;gap:64px;align-items:start}
.statement h2{margin:18px 0 0;max-width:14ch}
.statement .body{margin-top:8px}

/* =========================================================
   4) DUO — text-led tiles (image-free placeholders)
   ========================================================= */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.duo .tile{
  position:relative;
  display:block;
  aspect-ratio:4/5;
  overflow:hidden;
  background:linear-gradient(180deg, #161616 0%, #0c0c0c 100%);
  border:1px solid var(--rule);
  transition:border-color .35s var(--ease);
}
.duo .tile.wide{aspect-ratio:16/11}
.duo .tile:hover{border-color:var(--accent)}
/* Optional image still works if provided */
.duo .tile img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease);
  filter:saturate(.9) brightness(.7);
}
.duo .tile:hover img{transform:scale(1.04)}
.duo .tile .label{
  position:absolute;left:28px;bottom:28px;right:28px;
  font-family:var(--display);
  text-transform:uppercase;
  font-size:clamp(36px,4.5vw,64px);
  letter-spacing:-.015em;
  line-height:.95;
  color:var(--ink);
  z-index:2;
}
.duo .tile .corner{
  position:absolute;right:28px;top:28px;
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;
  color:var(--muted-2);
  z-index:2;
}
/* Accent rail on each tile — quiet visual interest in lieu of imagery */
.duo .tile .rail{
  position:absolute;left:28px;top:28px;width:1px;height:64px;
  background:var(--accent);
  z-index:2;
}
.duo .tile:nth-child(even) .rail{
  width:64px;height:1px;
  top:28px;left:28px;
}
.duo .tile::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 45%, rgba(0,0,0,0.6));
  z-index:1;
}

/* =========================================================
   5) PRESS RELEASE — text-led; placeholder for image slot
   ========================================================= */
.press{display:grid;grid-template-columns:6fr 6fr;gap:80px;align-items:center}
.press .img{
  position:relative;
  aspect-ratio:5/4;
  background:linear-gradient(135deg, #1a1a1a 0%, #0c0c0c 100%);
  background-size:cover;background-position:center;
  border:1px solid var(--rule);
  /* bottom vignette keeps the label readable when a photo is set */
  box-shadow:inset 0 -120px 90px -50px rgba(5,5,5,0.9);
}
.press .img::before{
  content:"";position:absolute;top:28px;left:28px;width:1px;height:48px;
  background:var(--accent);
}
.press .img__label{
  position:absolute;left:28px;bottom:28px;
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted-2);
}
.press h3{margin:14px 0 22px;max-width:18ch}
.press p{margin:0 0 26px}
/* Reversed variant — image on the right */
.press--reverse .img{order:2}

/* =========================================================
   6) MISSION — placeholder for image slot
   ========================================================= */
.mission{display:grid;grid-template-columns:6fr 6fr;gap:80px;align-items:center}
.mission .img{
  position:relative;
  aspect-ratio:5/6;
  background-color:#0a0a0a;      /* fallback before the photo paints */
  background-size:cover;
  background-position:center;
  overflow:hidden;
  border:1px solid var(--rule);
  box-shadow:inset 0 -60px 90px -40px rgba(0,0,0,.75);  /* anchors the caption */
}
/* Tonal overlay — darkens top (label) + bottom (caption), navy tint on-brand */
.mission .img::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(5,8,16,.45) 0%, rgba(5,8,16,.10) 32%, rgba(5,8,16,.34) 62%, rgba(5,8,16,.90) 100%),
    linear-gradient(118deg, rgba(58,126,224,.22) 0%, rgba(58,126,224,0) 52%);
}
.mission .img::before{
  content:"";position:absolute;top:32px;left:32px;width:48px;height:1px;z-index:2;
  background:var(--accent);
}
.mission .img__label{
  position:absolute;right:32px;top:32px;z-index:2;
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-3);
  text-shadow:0 1px 10px rgba(0,0,0,.55);
}
.mission .img__caption{
  position:absolute;left:32px;bottom:32px;right:32px;z-index:2;
  font-family:var(--display);
  text-transform:uppercase;
  font-size:clamp(20px,2vw,28px);
  letter-spacing:-.01em;
  line-height:1;
  color:var(--ink);
  text-shadow:0 1px 14px rgba(0,0,0,.5);
}
.mission .copy{padding-inline:clamp(0px,2vw,32px)}
.mission h2{max-width:11ch;margin:18px 0;font-size:clamp(32px,4.4vw,60px);line-height:.98}

/* =========================================================
   7) STORY — "Tradition. Engineered."
   ========================================================= */
.story{display:grid;grid-template-columns:5fr 7fr;gap:64px;align-items:start}
.story .stack{
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:-.015em;
  line-height:.9;
  font-size:clamp(56px,8vw,116px);
}
.story .stack span{display:block}
.story .stack .a{color:var(--ink)}
.story .stack .b{color:var(--accent)}
.story .copy{padding-top:8px}

/* =========================================================
   8) PILLARS
   ========================================================= */
.pillars h2{max-width:18ch;margin-bottom:28px}
.pillars .head{
  display:grid;grid-template-columns:7fr 5fr;gap:64px;
  align-items:end;
}

/* =========================================================
   8b) CAPABILITIES STRIP — poster-word band (Peraton-style)
   ========================================================= */
.capstrip{text-align:center}
.capstrip__words{
  display:flex;flex-wrap:wrap;gap:8px 44px;
  justify-content:center;
  margin-bottom:44px;
}
.capstrip__words a{
  font-family:var(--display);
  text-transform:uppercase;
  font-size:clamp(28px,4.6vw,58px);
  letter-spacing:-.02em;
  line-height:1.02;
  color:var(--ink);
  transition:color .25s var(--ease);
  position:relative;
}
.capstrip__words a:hover{color:var(--accent)}
.capstrip .body{max-width:60ch;margin:0 auto;text-align:center;color:var(--muted)}
.capstrip .eyebrow{justify-content:center;margin-bottom:32px}

/* =========================================================
   PANEL PROGRESS DOTS (homepage presentation)
   ========================================================= */
.panel-dots{
  position:fixed;right:26px;top:50%;transform:translateY(-50%);
  z-index:50;
  display:flex;flex-direction:column;gap:14px;
  opacity:0;transition:opacity .4s var(--ease);
}
.panel-dots.is-visible{opacity:1}
.panel-dots a{
  width:9px;height:9px;border-radius:50%;
  border:1px solid var(--muted-2);
  background:transparent;
  transition:background .25s var(--ease), border-color .25s var(--ease), transform .25s var(--ease);
}
.panel-dots a:hover{border-color:var(--accent)}
.panel-dots a.is-active{
  background:var(--accent);border-color:var(--accent);
  transform:scale(1.25);
}
@media (max-width: 980px){.panel-dots{display:none}}

/* =========================================================
   8b) CAPABILITIES STRIP — Peraton-style category row
   ========================================================= */
.capstrip{padding-block:clamp(96px,12vw,160px)}
.capstrip__row{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  margin-bottom:64px;
}
@media (max-width:900px){.capstrip__row{grid-template-columns:repeat(2, 1fr)}}
@media (max-width:560px){.capstrip__row{grid-template-columns:1fr}}
.capstrip__item{
  padding:48px 24px;
  border-right:1px solid var(--rule);
  text-align:center;
  font-family:var(--display);
  font-size:clamp(18px,1.8vw,26px);
  letter-spacing:0;
  text-transform:uppercase;
  color:var(--ink);
  transition:background .25s var(--ease), color .25s var(--ease);
  display:flex;align-items:center;justify-content:center;
  min-height:140px;
}
.capstrip__item:last-child{border-right:0}
.capstrip__item:hover{background:var(--paper-2);color:var(--accent)}
@media (max-width:900px){
  .capstrip__item:nth-child(2n){border-right:0}
  .capstrip__item{border-bottom:1px solid var(--rule)}
}
.capstrip__body{max-width:62ch;color:var(--muted);font-size:1.05rem;line-height:1.65}
.capstrip__link{margin-top:24px}

/* =========================================================
   9) TRANSITION
   ========================================================= */
.transition{padding-block:clamp(80px,12vw,140px);text-align:left;background:var(--paper-3)}
.transition h2{max-width:14ch;color:var(--ink)}
.transition p{margin-top:18px;max-width:55ch;color:var(--muted)}

/* =========================================================
   10) PULL QUOTE
   ========================================================= */
.pullquote{
  padding-block:clamp(140px,18vw,220px);
  text-align:center;
  background:var(--paper-2);
}
.pullquote q{
  display:block;
  font-family:var(--display);
  font-weight:400;
  text-transform:uppercase;
  font-size:clamp(32px,5.5vw,72px);
  letter-spacing:-.02em;
  line-height:1.02;
  color:var(--ink);
  max-width:22ch;
  margin:0 auto;
  quotes:"\201C" "\201D";
}
.pullquote q::before, .pullquote q::after{color:var(--accent)}
.pullquote .attrib{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:40px;
}
.pullquote .attrib strong{color:var(--ink);font-weight:600}

/* =========================================================
   11) AWARDS
   ========================================================= */
.awards .head{
  display:grid;grid-template-columns:7fr 5fr;gap:64px;
  align-items:end;margin-bottom:80px;
}
.awards h2{max-width:16ch}
.awards .grid4{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--rule);
}
.awards .cell{
  padding:40px 28px 36px;
  border-bottom:1px solid var(--rule);
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;gap:18px;
  min-height:240px;
  transition:background .25s var(--ease);
}
.awards .cell:nth-child(4n){border-right:0}
.awards .cell:hover{background:var(--paper-2)}
.awards .cell .num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--accent)}
.awards .cell .name{
  font-family:var(--display);
  text-transform:uppercase;
  font-size:22px;letter-spacing:-.01em;line-height:1.05;
  color:var(--ink);
  margin-top:auto;
}
.awards .cell .src{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* =========================================================
   12) CONTACT CTA
   ========================================================= */
.contactcta{padding-block:clamp(100px,14vw,160px)}
.contactcta .row{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:end;
}
.contactcta h2{
  font-family:var(--display);
  text-transform:uppercase;
  font-size:clamp(36px,5vw,64px);
  letter-spacing:-.015em;
  line-height:1;
  margin:14px 0 0;
  color:var(--ink);
}
.contactcta .btn{
  display:inline-flex;align-items:center;gap:14px;
  border:1px solid var(--ink);
  border-radius:999px;
  padding:18px 28px;
  font-family:var(--body);
  font-size:14px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;
  white-space:nowrap;
  color:var(--ink);
  transition:background .2s var(--ease), color .2s var(--ease);
}
.contactcta .btn:hover{background:var(--ink);color:var(--paper)}
.contactcta .btn .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}

/* =========================================================
   13) FOOTER (dark editorial)
   ========================================================= */
footer.site-footer{
  background:var(--paper-3);
  color:var(--muted);
  padding-block:96px 40px;
}
footer.site-footer .top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr 1fr;
  gap:48px;
  padding-bottom:72px;
  border-bottom:1px solid var(--rule);
}
/* Let columns shrink below their content's intrinsic width on narrow screens so
   the long email token can't push the grid (and page) wider than the viewport. */
footer.site-footer .top > *{min-width:0}
footer.site-footer h6{
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted-2);
  margin:0 0 18px;
  font-weight:500;
}
footer.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
footer.site-footer a{color:#d9dee3;font-size:14.5px;overflow-wrap:break-word}
footer.site-footer a:hover{color:var(--accent)}
footer.site-footer .brand{display:flex;flex-direction:column;align-items:flex-start;gap:18px;max-width:34ch}
footer.site-footer .brand img{height:56px;width:auto;align-self:flex-start}
footer.site-footer .brand p{font-size:14px;line-height:1.55;color:#94a0ac;margin:0}
footer.site-footer .brand .meta{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:.12em;
  color:var(--muted-2);
}
footer.site-footer .bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:32px;flex-wrap:wrap;gap:24px;
}
footer.site-footer .legal{display:flex;gap:24px;flex-wrap:wrap}
footer.site-footer .legal a{font-size:12.5px;color:var(--muted-2)}
footer.site-footer .social{display:flex;gap:14px}
footer.site-footer .social a{
  width:38px;height:38px;
  border:1px solid var(--rule);border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--muted);
  transition:border-color .2s var(--ease), color .2s var(--ease);
}
footer.site-footer .social a:hover{border-color:var(--accent);color:var(--accent)}
footer.site-footer .copy{
  font-size:12.5px;color:var(--muted-2);
  font-family:var(--mono);letter-spacing:.05em;
}

/* ---------- SCROLL FADE ---------- */
.fadeup{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease), transform .8s var(--ease)}
.fadeup.in{opacity:1;transform:none}
.fadeup.d1{transition-delay:.08s}
.fadeup.d2{transition-delay:.16s}
.fadeup.d3{transition-delay:.24s}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important}
  .fadeup{opacity:1;transform:none}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px){
  .nav .utility .cta{display:none}
  /* Pin the hamburger to the far right (margin-left:auto eats the free space to
     its left so the empty nav/utility items don't center it). */
  .nav-toggle{display:block;margin-left:auto}

  /* Mobile nav: list is hidden until the hamburger toggles .is-open,
     then drops down as a full-width panel below the fixed header. */
  .nav ul.primary{display:none}
  .nav ul.primary.is-open{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:fixed;left:0;right:0;top:var(--header-h);z-index:60;
    background:var(--paper);border-top:1px solid var(--rule);
    box-shadow:0 24px 40px -28px rgba(0,0,0,0.7);
    padding:8px var(--gutter) 24px;
    max-height:calc(100dvh - var(--header-h));overflow-y:auto;
  }
  .nav ul.primary > li{border-bottom:1px solid var(--rule)}
  .nav ul.primary > li:last-child{border-bottom:0}
  .nav ul.primary > li > a,
  .nav ul.primary > li > button{
    display:block;width:100%;text-align:left;
    padding:16px 2px;font-size:16px;
  }
  .nav ul.primary > li > button{background:none;border:0;color:var(--ink);cursor:pointer}
  .nav ul.primary > li > a::after,
  .nav ul.primary > li > button::after{display:none}

  /* Mega panels become inline accordions, revealed when the parent is open. */
  .megapanel{
    position:static;opacity:1;transform:none;pointer-events:auto;
    box-shadow:none;border-top:0;
    display:none !important;
  }
  .nav-item[data-open="true"] .megapanel{display:block !important}
  .megapanel .mega{display:block;padding:0 0 12px;gap:0}
  .megapanel .feature{margin:0 0 6px}
  .megapanel .feature .ph{display:none}
  .megapanel .feature h4{font-size:15px;margin:0}
  .megapanel .feature p{display:none}
  .megapanel .col{margin-top:4px}
  .megapanel .col h5{margin:10px 0 4px}
  .megapanel .col ul{gap:2px}
  .megapanel .col a{padding:9px 0 9px 12px;font-size:15px}

  .statement .grid,
  .press,
  .mission,
  .story,
  .pillars .head,
  .awards .head,
  .contactcta .row{
    grid-template-columns:1fr;gap:32px;
  }
  .duo{grid-template-columns:1fr}
  /* Shrink the giant "Tradition./Engineered." headline so the longest word
     ("ENGINEERED." ≈ 7.5× the font size in width) scales with the viewport
     instead of overflowing narrow phones — the old 56px clamp floor was wider
     than a ~360px screen. 10.5vw keeps a comfortable margin from 320px up. */
  .story .stack{font-size:clamp(30px,10.5vw,76px)}
  .awards .grid4{grid-template-columns:repeat(2,1fr)}
  .awards .cell:nth-child(2n){border-right:0}
  .awards .cell:nth-child(4n){border-right:1px solid var(--rule)}
  footer.site-footer .top{grid-template-columns:1fr 1fr;gap:40px}
}

/* ============ Phone-width fixes (homepage) ============
   Placed AFTER the max-width:980px block so these win at phone widths.
   Root cause of the horizontal page-scroll on phones was the AWARDS grid:
   at 22px the longest award names ("OPTIMIZATION", "CONSULTING") are ~179px
   wide, so two 1fr columns could not fit a ~390px screen and pushed the page
   ~58px wider than the viewport (the fixed header then stretched to match). */
@media (max-width:560px){
  .awards .grid4{grid-template-columns:1fr}   /* one column: each cell gets full width, text wraps */
  .awards .grid4 .cell{border-right:0}
}
@media (max-width:600px){
  /* "What we do" words wrapped unevenly with big 44px gaps and read as a run-on
     ("ENGINEERING CYBER MANAGED ..."). Stack them as a clean centered list. */
  .capstrip__words{flex-direction:column;align-items:center;gap:14px}
}

/* =========================================================
   LEGACY COMPONENTS — keep inner pages working
   (cover-hero, tile-grid, etc.)
   ========================================================= */

main{padding-top:0}

/* Buttons (legacy) */
.btn{
  display:inline-block;
  padding:14px 28px;
  font-family:var(--body);
  font-weight:600;
  font-size:0.95rem;
  letter-spacing:0.5px;
  text-transform:uppercase;
  border:2px solid transparent;
  cursor:pointer;
  transition:all 0.25s var(--ease);
  text-decoration:none;
  border-radius:0;
}
.btn--primary{background:var(--accent);color:var(--paper)}
.btn--primary:hover{background:var(--accent-hover);color:#fff;transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--outline:hover{background:var(--ink);color:var(--paper)}

/* Cover-hero (inner pages) — editorial, image-free, left-aligned */
.cover-hero{
  position:relative;
  min-height:max(58vh, 480px);
  display:flex;align-items:flex-end;
  text-align:left;
  background-color:#050505;
  background-size:cover;background-position:center;
  overflow:hidden;
  padding:calc(var(--header-h) + 80px) var(--gutter) 80px;
}
/* Heavy semi-transparent scrim: clean dark when no image, moody when a photo is set */
.cover-hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse at 12% 88%, rgba(58,126,224,0.12), transparent 60%),
    linear-gradient(180deg, rgba(8,8,8,0.82) 0%, rgba(6,6,6,0.72) 55%, rgba(0,0,0,0.93) 100%);
}
.cover-hero::after{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size:88px 88px;
  mask-image:radial-gradient(ellipse at center, #000 28%, transparent 72%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 28%, transparent 72%);
  opacity:0.55;
}
/* Vertical accent rail mirroring the homepage hero */
.cover-hero::before, .cover-hero::after { pointer-events:none; }
.cover-hero .rail{
  position:absolute;top:30%;bottom:30%;left:0;width:2px;
  background:linear-gradient(180deg, transparent, var(--accent) 30%, var(--accent) 70%, transparent);
  z-index:1;opacity:0.7;
}
.cover-hero__content{
  position:relative;z-index:2;
  width:100%;
  max-width:var(--maxw);
  margin:0 auto;
  text-align:left;
}
.cover-hero h1{
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(2.4rem, 6vw, 5rem);
  text-transform:uppercase;
  letter-spacing:-.02em;
  line-height:.95;
  color:var(--ink);
  margin:22px 0 28px;
  max-width:18ch;
}
.cover-hero .eyebrow{margin-bottom:0}
.cover-hero p{
  font-size:clamp(1rem,1.3vw,1.2rem);
  color:#c9d0d7;
  margin:0 0 16px;
  max-width:62ch;
  line-height:1.6;
}
.cover-hero p + p{margin-top:6px}
.cover-hero .btn{margin-top:36px}

/* Section intro (used on sub-services) — structured header with divider */
.section__intro{
  text-align:center;
  max-width:760px;
  margin:0 auto 72px;
  padding-bottom:40px;
  border-bottom:1px solid var(--rule);
}
.section__intro .eyebrow{justify-content:center;margin-bottom:20px}
.section__intro h2{
  color:var(--ink);
  font-family:var(--display);
  font-size:clamp(1.9rem,3.2vw,2.8rem);
  text-transform:uppercase;
  letter-spacing:-.02em;
  line-height:.95;
  margin-bottom:18px;
  font-weight:400;
}
.section__intro p{color:var(--muted);font-size:1.05rem;line-height:1.7;max-width:680px;margin:0 auto}

/* Tile grid (sub-services) — structured: accent top-rule + auto number + caps heading */
.tile-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:52px 56px;
  max-width:1400px;margin:0 auto;
  counter-reset:tile;
}
@media (max-width:900px){.tile-grid{grid-template-columns:repeat(2,1fr);gap:48px}}
@media (max-width:600px){.tile-grid{grid-template-columns:1fr;gap:44px}}
.tile{
  counter-increment:tile;
  border-top:2px solid var(--accent);
  padding-top:24px;
}
.tile h3{
  color:var(--ink);
  font-family:var(--display);
  font-size:clamp(1.1rem,1.4vw,1.35rem);
  font-weight:400;
  margin:0 0 14px;
  letter-spacing:-.01em;
  text-transform:uppercase;
  line-height:1.05;
}
.tile h3::before{
  content:counter(tile, decimal-leading-zero);
  display:block;
  font-family:var(--mono);
  font-size:11px;letter-spacing:.22em;
  color:var(--accent);
  margin-bottom:18px;
  font-weight:500;
}
.tile p{color:var(--muted);font-size:0.95rem;line-height:1.7;margin:0}
.tile p strong{color:var(--ink-2);font-weight:600}

/* Section bg variants */
.section{padding:clamp(72px,9vw,128px) 0}
.section--alt{background:var(--paper-2)}
.section--dark{background:var(--paper-3)}
.section--accent{
  background:var(--accent);
  color:var(--paper);
}
.section--accent h1,
.section--accent h2,
.section--accent h3,
.section--accent h4{color:var(--paper);font-family:var(--display)}
.section--accent p{color:rgba(10,10,10,0.85)}
.section--accent a{color:var(--paper);text-decoration:underline}
.section--accent .eyebrow{color:rgba(10,10,10,0.7)}
.section--accent .eyebrow::before{background:var(--paper)}
.section--accent .bullet-list{color:rgba(10,10,10,0.9)}
@media (max-width:768px){.section{padding:70px 0}}

/* Container variants */
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.container--narrow{max-width:880px}
/* Keep direct prose in section containers at a readable measure (not stretched to 1840px) */
.section > .container > h2,
.section > .container > h3,
.section > .container > p,
.section > .container > ul{max-width:72ch}

/* Media-text split layout (used on home + sub-services) */
.media-text{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:64px;
  align-items:center;
  padding:0;
}
.media-text--reverse .media-text__media{order:2}
.media-text__media img,
.media-text__media video{
  width:100%;
  border-radius:0;
}
.media-text__body h2{margin-top:0}
.media-text__body p{color:var(--muted);font-size:1.05rem}
@media (max-width: 800px){
  .media-text{grid-template-columns:1fr;gap:32px}
  .media-text--reverse .media-text__media{order:0}
}

/* Section header style */
.section__head{text-align:center;margin-bottom:56px}
.section__head h2{font-family:var(--display);text-transform:uppercase;letter-spacing:-.01em}

/* Grid utilities */
.grid{display:grid;gap:24px}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.grid--3, .grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid--2, .grid--3, .grid--4{grid-template-columns:1fr}}

/* Card */
.card{
  background:var(--paper-2);
  border:1px solid var(--rule);
  padding:32px 28px;
  transition:transform 0.25s var(--ease), border-color 0.25s var(--ease);
}
.card:hover{transform:translateY(-4px);border-color:var(--accent)}
.card h3{margin-bottom:12px;font-family:var(--body);text-transform:none;letter-spacing:0;font-weight:700}
.card p{color:var(--muted);margin-bottom:16px}
.card .text-accent{color:var(--accent)}

/* Lists */
.list-clean{list-style:none;padding:0;margin:0}
.list-clean li{padding:10px 0;border-bottom:1px solid var(--rule);color:var(--muted)}
.list-clean li:last-child{border:0}
.bullet-list{padding-left:1.2em;margin:0 0 1em;color:var(--muted)}
.bullet-list li{margin-bottom:6px}

/* Pricing cards */
.pricing-card{
  background:var(--paper-2);
  border:1px solid var(--rule);
  padding:32px;
  display:flex;flex-direction:column;
}
.pricing-card--featured{border-color:var(--accent);position:relative}
.pricing-card--featured::before{
  content:"Popular";
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:var(--paper);
  padding:4px 16px;
  font-family:var(--mono);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
}
.pricing-card__name{
  font-family:var(--display);
  font-size:1.4rem;
  letter-spacing:.04em;text-transform:uppercase;
  color:var(--accent);
  margin-bottom:8px;
}
.pricing-card__price{
  font-family:var(--display);
  font-size:2.5rem;
  font-weight:400;
  margin-bottom:4px;
  letter-spacing:-.01em;
}
.pricing-card__price small{font-family:var(--body);font-size:0.9rem;font-weight:400;color:var(--muted-2)}
.pricing-card__sub{color:var(--muted-2);font-size:0.9rem;margin-bottom:24px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em}
.pricing-card .list-clean{flex:1;margin-bottom:24px}
.pricing-card .list-clean li{color:var(--ink);font-size:0.95rem;border-color:var(--rule-2)}

/* MSP features (nested) */
.msp-features{list-style:none;padding:0;margin:0 0 20px;text-align:left}
.msp-features > li{padding:12px 0;border-bottom:1px solid var(--rule);font-size:0.95rem}
.msp-features > li:last-child{border-bottom:0}
.msp-features > li > strong{color:var(--accent);display:block;margin-bottom:6px}
.msp-features ul{list-style:disc;padding-left:20px;margin:6px 0 0}
.msp-features ul li{color:var(--muted);font-size:0.85rem;padding:4px 0;line-height:1.5}
.msp-features ul li strong{color:var(--ink);font-weight:600}
.pricing-card__note{color:var(--muted-2);font-size:0.85rem;margin:12px 0 20px;font-style:italic;text-align:center}

/* Team portrait grid */
.team-card{text-align:left}
.team-card__photo{
  aspect-ratio:2/3;
  background:#1a1a1a;
  border:0;border-radius:0;
  margin-bottom:20px;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;color:var(--muted-2);font-weight:800;letter-spacing:4px;
}
.team-card__photo img{width:100%;height:100%;object-fit:cover;border-radius:0}
.team-card__name{font-family:var(--display);font-size:1.5rem;margin-bottom:8px;line-height:1.2;font-weight:400;color:var(--ink);text-transform:uppercase;letter-spacing:-.01em}
.team-card__role{color:#a8a08a;text-transform:none;letter-spacing:0;font-size:0.95rem;font-weight:400;margin-bottom:18px;font-family:var(--mono);letter-spacing:.05em}
.team-card__bio{color:var(--muted);font-size:0.95rem;line-height:1.6}
.team-card__social{margin-top:16px}
.team-card__social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;
  border:1px solid var(--rule);
  border-radius:50%;
  color:var(--muted);
  transition:background 0.2s, color 0.2s, border-color 0.2s;
}
.team-card__social a:hover{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.team-card__social svg{width:16px;height:16px}

/* Mission/Vision/Values 3-col */
.mvv{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
@media (max-width:768px){.mvv{grid-template-columns:1fr}}
.mvv__col h3{
  font-family:var(--display);
  font-size:1.6rem;
  text-transform:uppercase;
  letter-spacing:-.01em;
  color:var(--accent);
  margin-bottom:16px;
  font-weight:400;
}
.mvv__col p{color:var(--muted);font-size:1.05rem;line-height:1.7}

/* Stats laurel */
.stat-laurel{display:flex;flex-direction:column;align-items:center}
.stat-laurel__row{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:12px}
.stat-laurel__wreath{font-size:2.4rem;color:rgba(255,255,255,0.65);line-height:1}
.stat-laurel__num{font-family:var(--display);font-size:clamp(2.5rem,4vw,3.5rem);font-weight:400;color:var(--paper);line-height:1;letter-spacing:-.01em}
.stat-laurel__label{color:var(--paper);text-transform:uppercase;letter-spacing:1.5px;font-size:0.95rem;font-weight:600;font-family:var(--mono)}

/* Form */
.form{display:grid;gap:20px;max-width:640px;margin:0 auto}
.form__status{padding:14px 18px;font-size:0.95rem;display:none;margin-bottom:32px;max-width:780px;border-radius:2px}
.form__status.is-success{display:block;background:rgba(58,126,224,0.14);color:var(--accent);border:1px solid var(--accent)}
.form__status.is-error{display:block;background:rgba(220,53,69,0.12);color:#ff6b7a;border:1px solid #dc3545}
.form__hp{position:absolute;left:-9999px;opacity:0;pointer-events:none}

/* Contact split */
.contact-split{display:grid;grid-template-columns:2fr 1fr;gap:64px;align-items:start}
@media (max-width:900px){.contact-split{grid-template-columns:1fr;gap:40px}}
.contact-split__info h3{color:var(--ink);text-transform:none;letter-spacing:0;font-size:1.1rem;font-weight:700;margin-bottom:12px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase}
.contact-split__info p{color:var(--muted);margin-bottom:8px;line-height:1.6}
.contact-split__info a{color:var(--muted);text-decoration:none}
.contact-split__info a:hover{color:var(--accent)}

/* Utilities */
.text-center{text-align:center}
.text-accent{color:var(--accent)}
.text-dim{color:var(--muted)}
.text-uppercase{text-transform:uppercase;letter-spacing:1px}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.mt-4{margin-top:32px}.mb-2{margin-bottom:16px}.mb-3{margin-bottom:24px}.mb-4{margin-bottom:32px}

/* Reveal animation (legacy alias) */
.reveal{opacity:0;transform:translateY(20px);transition:opacity 0.7s var(--ease), transform 0.7s var(--ease)}
.reveal.is-visible, .reveal.in{opacity:1;transform:translateY(0)}
.reveal.d1{transition-delay:.06s}
.reveal.d2{transition-delay:.12s}
.reveal.d3{transition-delay:.18s}
.reveal.d4{transition-delay:.24s}
.reveal.d5{transition-delay:.30s}
.reveal.d6{transition-delay:.36s}

/* =========================================================
   COMPANY TAB — ELEVATED COMPONENTS
   Ported from the design handoff. Scoped under .page-root so
   they never collide with the homepage or service pages.
   ========================================================= */

.page-root{animation:pageIn .55s var(--ease-out) both}
@keyframes pageIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* Kinetic title — letters slide up in succession */
.kinetic span{display:inline-block;opacity:0;transform:translateY(.4em);animation:letterIn .9s var(--ease-out) forwards}
@keyframes letterIn{to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){
  .kinetic span{opacity:1;transform:none;animation:none}
  .page-root{animation:none}
}

/* ---------- COVER HERO (Company pages) ---------- */
.cover{
  position:relative;
  min-height:max(82vh, 700px);
  display:flex;align-items:flex-end;
  background:#050505;
  overflow:hidden;
  padding:calc(var(--header-h) + 100px) var(--gutter) clamp(72px,9vw,120px);
}
.cover__photo{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;
  opacity:.38;
  filter:saturate(.72) brightness(.6) contrast(1.05);
  transform:scale(1.05);
  animation:slowZoom 22s var(--ease) both;
}
@keyframes slowZoom{from{transform:scale(1.12)}to{transform:scale(1.0)}}
.cover__scrim{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(6,6,6,.55) 0%, rgba(6,6,6,.65) 55%, rgba(0,0,0,.96) 100%),
    radial-gradient(ellipse at 8% 92%, rgba(58,126,224,.22), transparent 55%);
}
.cover__grid{
  position:absolute;inset:0;z-index:1;
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(0deg,  rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:96px 96px;
  -webkit-mask-image:radial-gradient(ellipse at center, #000 35%, transparent 78%);
          mask-image:radial-gradient(ellipse at center, #000 35%, transparent 78%);
  opacity:.55;
}
.cover__rail{
  position:absolute;top:24%;bottom:24%;left:0;width:2px;z-index:1;
  background:linear-gradient(180deg, transparent, var(--accent) 22%, var(--accent) 78%, transparent);
  opacity:.8;
}
.cover__content{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr;gap:0}
.cover__crumbs{display:flex;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:34px;flex-wrap:wrap}
.cover__crumbs em{color:var(--ink);font-style:normal}
.cover__crumbs span{color:var(--accent)}
.cover__crumbs span::before{content:"\203A\00A0";color:var(--muted-2)}
.cover h1.display{margin:18px 0 24px;max-width:18ch}
.cover h1 .accent{color:var(--accent)}
.cover .lede{max-width:60ch;color:var(--ink-3);margin-bottom:36px}
.cover__meta{
  position:absolute;left:var(--gutter);right:var(--gutter);bottom:30px;
  display:flex;justify-content:space-between;align-items:flex-end;z-index:3;color:var(--ink);
}
.cover__meta .timestamp{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.cover__meta .next{display:inline-flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink)}
.cover__meta .down{width:1px;height:48px;background:var(--rule);position:relative;overflow:hidden}
.cover__meta .down::after{content:"";position:absolute;left:-2px;top:-48px;width:5px;height:48px;background:var(--accent);animation:dropline 2.6s var(--ease) infinite}
.cover--minimal .cover__photo{display:none}
.cover--minimal{background:linear-gradient(180deg,#080808 0%,#040404 100%)}
.cover--split .cover__content{grid-template-columns:1.4fr 1fr;gap:64px;align-items:end}
.cover__numpanel{border-left:1px solid var(--rule);padding:32px 0 32px 40px;display:flex;flex-direction:column;gap:28px}
.cover__numpanel .row{display:flex;flex-direction:column;gap:6px}
.cover__numpanel .row .v{font-family:var(--display);font-size:clamp(28px,3vw,46px);color:var(--ink);text-transform:uppercase;line-height:1;letter-spacing:-.01em}
.cover__numpanel .row .v .s{font-size:.55em;color:var(--accent);margin-left:8px;vertical-align:middle}
.cover__numpanel .row .k{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2)}
@media (max-width:980px){.cover--split .cover__content{grid-template-columns:1fr;gap:36px}.cover__numpanel{border-left:0;border-top:1px solid var(--rule);padding:28px 0 0}}
@media (prefers-reduced-motion: reduce){.cover__photo{animation:none}}

/* ---------- STATEMENT (5/7 split) — scoped to avoid homepage clash ---------- */
.page-root .statement{display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:start}
.page-root .statement .left .num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.page-root .statement .left h2{margin:14px 0 0;max-width:13ch}
.page-root .statement .right{padding-top:8px}
.page-root .statement .right .lede{margin-bottom:24px}
.page-root .statement .right .body{color:var(--muted);max-width:64ch}
@media (max-width:980px){.page-root .statement{grid-template-columns:1fr;gap:32px}}

/* ---------- SECTION HEAD (6/6) ---------- */
.section-head{display:grid;grid-template-columns:6fr 6fr;gap:60px;align-items:end;margin-bottom:64px}
.section-head h2{max-width:14ch;margin:14px 0 0}
.section-head .meta p{color:var(--muted);font-size:16.5px;line-height:1.65;max-width:52ch;margin:0}
@media (max-width:980px){.section-head{grid-template-columns:1fr;gap:24px}}

/* ---------- STAT BLOCK ---------- */
.statblock{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.statblock__cell{padding:60px 40px;border-right:1px solid var(--rule);position:relative}
.statblock__cell:last-child{border-right:0}
.statblock__cell .k{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);margin-bottom:18px}
.statblock__cell .v{font-family:var(--display);font-size:clamp(56px,7vw,108px);line-height:.9;letter-spacing:-.03em;color:var(--ink);text-transform:uppercase;display:flex;align-items:baseline;gap:10px}
.statblock__cell .v .plus{color:var(--accent);font-size:.7em}
.statblock__cell .l{color:var(--muted);font-size:14.5px;line-height:1.5;margin-top:18px;max-width:32ch}
@media (max-width:900px){.statblock{grid-template-columns:1fr}.statblock__cell{border-right:0;border-bottom:1px solid var(--rule)}.statblock__cell:last-child{border-bottom:0}}

/* ---------- MVV (elevated, scoped) ---------- */
.page-root .mvv{display:grid;grid-template-columns:repeat(3,1fr);gap:56px;align-items:start;position:relative}
.page-root .mvv::before{content:"";position:absolute;top:38px;left:0;right:0;height:1px;background:var(--rule)}
.page-root .mvv__col{position:relative;padding-top:74px}
.page-root .mvv__col .k{position:absolute;top:0;left:0;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.page-root .mvv__col .k .dot{display:inline-block;width:8px;height:8px;background:var(--accent);margin-right:10px;vertical-align:middle;border-radius:50%}
.page-root .mvv__col h3{font-family:var(--display);font-size:clamp(26px,2.4vw,36px);text-transform:uppercase;letter-spacing:-.01em;line-height:1.08;color:var(--ink);margin:0 0 22px;font-weight:400}
.page-root .mvv__col p{color:var(--ink-3);font-size:16.5px;line-height:1.65;margin:0}
@media (max-width:980px){.page-root .mvv{grid-template-columns:1fr;gap:36px}.page-root .mvv::before{display:none}}

/* ---------- LEADERS ---------- */
.leaders{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;max-width:1320px;margin:0 auto}
@media (max-width:1100px){.leaders{grid-template-columns:repeat(2,1fr);gap:32px}}
@media (max-width:560px){.leaders{grid-template-columns:1fr;gap:32px}}
.leader{position:relative;color:var(--ink);transition:transform .35s var(--ease)}
.leader__photo{position:relative;aspect-ratio:4/5;background:#101010;border:1px solid var(--rule);overflow:hidden}
.leader__photo img{width:100%;height:100%;object-fit:cover;filter:grayscale(35%) contrast(1.05) brightness(.92);transition:filter .5s var(--ease), transform .8s var(--ease)}
.leader:hover .leader__photo img{filter:grayscale(0%) contrast(1.05);transform:scale(1.04)}
.leader__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.9));pointer-events:none}
.leader__photo .corner{position:absolute;top:18px;left:18px;width:1px;height:38px;background:var(--accent);z-index:2}
.leader__photo .index{position:absolute;top:18px;right:18px;font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--ink);opacity:.7;z-index:2}
.leader__photo .name-overlay{position:absolute;left:20px;right:20px;bottom:18px;z-index:2;display:flex;flex-direction:column;gap:4px}
.leader__photo .name-overlay .role{font-family:var(--mono);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
.leader__photo .name-overlay h3{font-family:var(--display);font-size:clamp(18px,1.5vw,22px);text-transform:uppercase;letter-spacing:-.01em;line-height:1;color:var(--ink);margin:0;font-weight:400}
.leader__bio{margin-top:18px;color:var(--muted);font-size:14.5px;line-height:1.65}
.leader__social{margin-top:14px;display:flex;gap:10px}
.leader__social a{width:34px;height:34px;border:1px solid var(--rule);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);transition:background .2s, color .2s, border-color .2s}
.leader__social a:hover{background:var(--accent);color:var(--paper);border-color:var(--accent)}
.leader__social svg{width:15px;height:15px}

/* ---------- CERT GRID ---------- */
.cert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule)}
.cert{padding:32px 24px;border-bottom:1px solid var(--rule);border-right:1px solid var(--rule);display:flex;flex-direction:column;gap:14px;min-height:170px;transition:background .2s var(--ease)}
.cert:nth-child(4n){border-right:0}
.cert:hover{background:var(--paper-2)}
.cert .k{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--muted-2)}
.cert .name{font-family:var(--display);text-transform:uppercase;font-size:20px;letter-spacing:-.005em;line-height:1.05;color:var(--ink);margin-top:auto}
.cert .desc{font-family:var(--body);font-size:13.5px;color:var(--muted);line-height:1.55}
@media (max-width:980px){.cert-grid{grid-template-columns:repeat(2,1fr)}.cert:nth-child(2n){border-right:0}.cert:nth-child(4n){border-right:1px solid var(--rule)}}
@media (max-width:560px){.cert-grid{grid-template-columns:1fr}.cert,.cert:nth-child(4n){border-right:0}}

/* ---------- PROGRAMS ---------- */
.programs{display:flex;flex-direction:column;border-top:1px solid var(--rule)}
.program{display:grid;grid-template-columns:0.6fr 1.4fr 3fr 0.4fr;gap:32px;align-items:start;padding:34px 4px;border-bottom:1px solid var(--rule);transition:background .2s var(--ease), padding-left .25s var(--ease)}
.program:hover{background:var(--paper-2);padding-left:18px}
.program .idx{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--accent);padding-top:6px}
.program .agency{font-family:var(--mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);padding-top:6px}
.program .title{display:flex;flex-direction:column;gap:10px}
.program .title h4{font-family:var(--display);text-transform:uppercase;font-size:clamp(20px,1.7vw,28px);letter-spacing:-.005em;line-height:1.1;color:var(--ink);margin:0;font-weight:400}
.program .title p{color:var(--muted);font-size:15px;line-height:1.65;margin:0}
.program .arrow{font-family:var(--mono);font-size:18px;color:var(--muted-2);padding-top:6px;text-align:right;transition:color .2s var(--ease), transform .25s var(--ease)}
.program:hover .arrow{color:var(--accent);transform:translateX(4px)}
@media (max-width:980px){.program{grid-template-columns:1fr;gap:8px}.program .arrow{display:none}}

/* ---------- LOGO WALL ---------- */
.logowall{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}
.logowall__cell{padding:36px 24px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:center;aspect-ratio:1.6/1;transition:background .2s var(--ease)}
.logowall__cell:hover{background:var(--paper-2)}
.logowall__cell img{max-height:60px;max-width:80%;object-fit:contain;filter:brightness(.95) saturate(.85);opacity:.85;transition:opacity .2s var(--ease), filter .2s var(--ease)}
.logowall__cell:hover img{opacity:1;filter:none}
.logowall__cell:nth-child(6n){border-right:0}
@media (max-width:980px){.logowall{grid-template-columns:repeat(3,1fr)}.logowall__cell:nth-child(6n){border-right:1px solid var(--rule)}.logowall__cell:nth-child(3n){border-right:0}}
@media (max-width:560px){.logowall{grid-template-columns:repeat(2,1fr)}.logowall__cell:nth-child(3n){border-right:1px solid var(--rule)}.logowall__cell:nth-child(2n){border-right:0}}
/* Text variant — customer names rendered in the same grid/cell rhythm as the logo wall */
.logowall__name{font-family:var(--mono);font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);text-align:center;line-height:1.45}
.logowall__cell:hover .logowall__name{color:var(--ink)}
/* Seal variant — full-color customer/agency seals (no desaturation, larger) */
.logowall--seals .logowall__cell img{max-height:84px;max-width:84%;filter:none;opacity:.92}
.logowall--seals .logowall__cell:hover img{opacity:1}

/* ---------- NAICS TABLES ---------- */
.naics{display:grid;grid-template-columns:1fr 1fr;gap:56px}
@media (max-width:900px){.naics{grid-template-columns:1fr;gap:36px}}
.naics h3{font-family:var(--mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 18px;font-weight:500}
.naics ul{list-style:none;padding:0;margin:0 0 36px}
.naics ul li{display:grid;grid-template-columns:110px 1fr auto;gap:18px;padding:14px 0;border-bottom:1px solid var(--rule);font-size:15px;color:var(--ink-3)}
.naics ul li strong{font-family:var(--mono);color:var(--ink);letter-spacing:.04em;font-weight:600}
.naics ul li .tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);align-self:center}
.naics ul li:last-child{border-bottom:0}
.naics ul li a{color:var(--ink);border-bottom:1px solid var(--rule)}
.naics ul li a:hover{color:var(--accent);border-color:var(--accent)}

/* ---------- VALUES GRID ---------- */
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule)}
.value-tile{padding:48px 32px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:18px;transition:background .2s var(--ease)}
.value-tile:hover{background:var(--paper-2)}
.value-tile:nth-child(3n){border-right:0}
.value-tile .idx{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--accent)}
.value-tile h3{font-family:var(--display);text-transform:uppercase;font-size:24px;letter-spacing:-.01em;line-height:1.05;margin:0;color:var(--ink);font-weight:400}
.value-tile p{color:var(--muted);font-size:15px;line-height:1.7;margin:0}
@media (max-width:980px){.values-grid{grid-template-columns:repeat(2,1fr)}.value-tile:nth-child(3n){border-right:1px solid var(--rule)}.value-tile:nth-child(2n){border-right:0}}
@media (max-width:560px){.values-grid{grid-template-columns:1fr}.value-tile{border-right:0 !important}}

/* ---------- ARTICLES ---------- */
.articles{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule)}
.article{padding:36px 32px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);display:flex;flex-direction:column;gap:18px;min-height:300px;transition:background .2s var(--ease)}
.article:hover{background:var(--paper-2)}
.article:nth-child(3n){border-right:0}
.article .k{display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2)}
.article .k .tag{color:var(--accent)}
.article h3{font-family:var(--display);text-transform:uppercase;font-size:20px;letter-spacing:-.005em;line-height:1.15;margin:0;color:var(--ink);font-weight:400;flex:1}
.article .link{font-family:var(--body);font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink);display:inline-flex;align-items:center;gap:8px;margin-top:auto}
.article .link .arr{transition:transform .25s var(--ease)}
.article:hover .link .arr{transform:translateX(4px);color:var(--accent)}
.article:hover h3{color:var(--accent)}
@media (max-width:980px){.articles{grid-template-columns:repeat(2,1fr)}.article:nth-child(3n){border-right:1px solid var(--rule)}.article:nth-child(2n){border-right:0}}
@media (max-width:560px){.articles{grid-template-columns:1fr}.article{border-right:0 !important}}

/* ---------- CONTACT SPLIT (elevated, scoped) ---------- */
.page-root .contact-split{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:start}
@media (max-width:980px){.page-root .contact-split{grid-template-columns:1fr;gap:40px}}
.page-root .form{display:grid;gap:24px;max-width:780px}
.page-root .field{display:flex;flex-direction:column;gap:8px}
.page-root .field label{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.page-root .field label .req{color:var(--accent);margin-left:4px}
.page-root .field input,.page-root .field textarea{background:transparent;border:0;border-bottom:1px solid var(--rule);color:var(--ink);padding:12px 0;font-family:var(--body);font-size:16px;transition:border-color .2s var(--ease);border-radius:0}
.page-root .field input:focus,.page-root .field textarea:focus{outline:none;border-bottom-color:var(--accent)}
.page-root .field input:focus-visible,.page-root .field textarea:focus-visible{box-shadow:0 0 0 3px rgba(58,126,224,.3)}
.page-root .field textarea{resize:vertical;min-height:120px}
.contact-info{border-left:1px solid var(--rule);padding-left:40px}
@media (max-width:980px){.contact-info{border-left:0;border-top:1px solid var(--rule);padding-left:0;padding-top:32px}}
.contact-info h3{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:0 0 14px;font-weight:500}
.contact-info p{color:var(--ink-3);font-size:15.5px;line-height:1.7;margin:0 0 32px}
.contact-info a{color:var(--ink);border-bottom:1px solid var(--rule);transition:border-color .2s var(--ease)}
.contact-info a:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- ELEVATED BUTTONS ---------- */
.btn-outline{display:inline-flex;align-items:center;gap:12px;border:1px solid var(--ink);border-radius:999px;padding:14px 26px;font-family:var(--body);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);transition:background .2s var(--ease), color .2s var(--ease);cursor:pointer}
.btn-outline:hover{background:var(--ink);color:var(--paper)}
.btn-outline .dot{width:8px;height:8px;border-radius:50%;background:var(--accent)}
.btn-solid{display:inline-flex;align-items:center;gap:12px;background:var(--accent);border-radius:999px;padding:15px 28px;font-family:var(--body);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#fff;transition:background .2s var(--ease), transform .2s var(--ease);cursor:pointer;border:0}
.btn-solid:hover{background:var(--accent-hover);transform:translateY(-1px)}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;font-family:var(--body);font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);padding:6px 0;position:relative;cursor:pointer}
.btn-ghost::after{content:"";position:absolute;left:0;right:30%;bottom:0;height:1px;background:var(--ink);transform-origin:left;transition:transform .35s var(--ease)}
.btn-ghost:hover::after{transform:scaleX(calc(10/7))}
.btn-ghost .arr{transition:transform .25s var(--ease)}
.btn-ghost:hover .arr{transform:translateX(6px)}
