/* ═══════════════════════════════════════════
   Puget Sound AI — main.css v3.3.0
   Design: Sora · IBM Plex Sans · IBM Plex Mono
   Tokens match prototype design system.
═══════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  color-scheme: dark;
  --display: 'Sora','Space Grotesk',system-ui,sans-serif;
  --sans:    'IBM Plex Sans','Inter',system-ui,sans-serif;
  --mono:    'IBM Plex Mono','JetBrains Mono',ui-monospace,monospace;

  --accent:       #3b74ff;
  --accent-bright:#5b8dff;
  --accent-hover: #5b8dff;
  --accent-glow:  rgba(59,116,255,.45);
  --accent-tint:  rgba(59,116,255,.10);
  --chip-bg:      rgba(59,116,255,.07);

  --bg:           #080b14;
  --panel:        #0e1426;
  --panel-2:      #0b1020;
  --surface-1:    #0e1426;
  --surface-2:    #0b1020;
  --surface-3:    #111926;

  --edge:         rgba(120,150,255,.12);
  --edge-strong:  rgba(120,150,255,.22);
  --border:       rgba(120,150,255,.12);
  --border-strong:rgba(120,150,255,.22);

  --ink:          #eef2ff;
  --ink-dim:      #9aa6c4;
  --ink-faint:    #5e6a8a;
  --text:         #eef2ff;
  --text-2:       #9aa6c4;
  --text-muted:   #5e6a8a;

  --grid:         rgba(120,150,255,.045);

  --r-sm:  10px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  26px;

  --shadow:       0 24px 60px -24px rgba(0,0,0,.7);
  --shadow-card:  0 8px 32px -12px rgba(0,0,0,.55);

  --verified:#2E9E78;
  --warn:    #C9821B;
  --danger:  #D6453D;
  --white:   #ffffff;
  --focus-ring:#5b8dff;

  --z-base:0;--z-raised:10;--z-overlay:20;--z-drawer:40;--z-nav:100;--z-modal:1000;
  --ease-out:cubic-bezier(.16,1,.3,1);
  --dur-fast:.18s;--dur:.35s;--dur-slow:.6s;
  --nav-height:72px;
}

/* ── BASE ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:auto}
@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}

body{
  font-family:var(--sans);
  font-weight:400;
  color:var(--ink);
  background:
    radial-gradient(1100px 600px at 80% -10%,rgba(59,116,255,.13),transparent 60%),
    radial-gradient(900px 520px at 2% 112%, rgba(59,116,255,.05),transparent 55%),
    var(--bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  min-height:100vh;
}

/* engineering grid */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(circle at 60% 24%,#000 28%,transparent 86%);
  -webkit-mask-image:radial-gradient(circle at 60% 24%,#000 28%,transparent 86%);
}

a{text-decoration:none;color:inherit;transition:color var(--dur-fast) ease}
a:focus-visible,button:focus-visible,input:focus-visible,
textarea:focus-visible,select:focus-visible{
  outline:2px solid var(--focus-ring);outline-offset:3px;border-radius:3px}
a:focus:not(:focus-visible){outline:none}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}

/* ── LAYOUT ── */
.container{max-width:1280px;margin:0 auto;padding:0 32px;position:relative;z-index:1}
@media(max-width:560px){.container{padding:0 20px}}
section{position:relative;overflow:hidden}
.section-light  {background:var(--surface-1)}
.section-gray   {background:var(--surface-2)}
.section-dark   {background:var(--bg)}

/* ── TYPOGRAPHY ── */
.section-tag{
  display:inline-block;font-family:var(--mono);font-size:.72rem;font-weight:500;
  letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.85rem}
.section-title{
  font-family:var(--display);font-weight:700;font-size:clamp(1.75rem,3vw,2.4rem);
  line-height:1.12;letter-spacing:-.022em;color:var(--ink);margin-bottom:1rem}
.section-sub{font-size:1.05rem;color:var(--ink-dim);max-width:58ch;line-height:1.7}
.section-header{margin-bottom:3rem}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45em;
  font-family:var(--sans);font-size:.95rem;font-weight:600;
  padding:.9rem 1.75rem;min-height:48px;min-width:120px;
  border-radius:var(--r-sm);border:1px solid transparent;
  cursor:pointer;touch-action:manipulation;white-space:nowrap;text-decoration:none;
  transition:background var(--dur-fast),color var(--dur-fast),border-color var(--dur-fast),
              transform var(--dur-fast),box-shadow var(--dur-fast)}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn-primary{
  background:var(--accent);color:#fff;border-color:var(--accent);
  box-shadow:0 12px 30px -10px var(--accent-glow)}
.btn-primary:hover{background:var(--accent-bright);border-color:var(--accent-bright);
  box-shadow:0 18px 42px -12px var(--accent-glow);color:#fff}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--edge-strong)}
.btn-ghost:hover{border-color:var(--accent-bright);color:var(--accent-bright);background:var(--chip-bg)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink-faint)}
.btn-outline:hover{border-color:var(--accent-bright);color:var(--accent-bright);background:var(--chip-bg)}
.btn-sm{font-size:.82rem;padding:.55rem 1.1rem;min-height:36px}
.btn-ghost-sm{
  display:inline-flex;align-items:center;font-size:.85rem;font-weight:500;
  padding:.5rem 1rem;border-radius:var(--r-sm);border:1px solid var(--edge-strong);
  color:var(--ink-dim);background:transparent;transition:border-color .15s,color .15s;
  text-decoration:none}
.btn-ghost-sm:hover{border-color:var(--accent-bright);color:var(--accent-bright)}
.link-arrow{font-size:.95rem;font-weight:500;color:var(--accent-bright);transition:color .15s}
.link-arrow:hover{color:var(--accent)}

/* ── NAV ── */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);height:var(--nav-height);
  background:rgba(8,11,20,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--edge);transition:background .3s ease}
.site-nav.scrolled{background:rgba(8,11,20,.97)}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:0 32px;height:100%;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;position:relative}
@media(max-width:768px){.nav-inner{padding:0 20px}}

/* brand + logomark */
.nav-logo{
  display:flex;align-items:center;gap:12px;text-decoration:none;flex-shrink:0}
.nav-logo-mark{width:36px;height:36px;flex:none}

/* custom logo uploaded via WP Customizer */
.custom-logo-link{display:flex;align-items:center;flex-shrink:0}
.custom-logo{
  display:block;height:auto;max-height:72px;width:auto;
  background:transparent;
  color-scheme:dark;
  forced-color-adjust:none;
  filter:none}
.nav-logo-word{display:flex;flex-direction:column;line-height:1}
.nav-logo-word b{
  font-family:var(--display);font-weight:700;font-size:1.1rem;
  letter-spacing:-.012em;color:var(--ink)}
.nav-logo-word small{
  font-family:var(--mono);font-size:.6rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--ink-faint);margin-top:3px}

.nav-links{display:flex;align-items:center;gap:.1rem}
.nav-link{
  font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.01em;
  color:var(--ink-dim);padding:.5rem .6rem;min-height:44px;display:inline-flex;
  align-items:center;border-radius:var(--r-sm);position:relative;white-space:nowrap;
  transition:color var(--dur-fast),background var(--dur-fast)}
.nav-link:hover{background:rgba(255,255,255,.04);color:var(--ink)}
.nav-link.active{color:var(--accent-bright)}
.nav-link.active::after{
  content:'';position:absolute;bottom:0;left:.6rem;right:.6rem;height:2px;
  background:var(--accent-bright);border-radius:1px}
.nav-badge{
  display:inline-flex;align-items:center;padding:.25rem .65rem;
  background:var(--chip-bg);border:1px solid rgba(91,141,255,.3);border-radius:var(--r-sm);
  font-family:var(--mono);font-size:.6rem;font-weight:500;letter-spacing:.05em;
  text-transform:uppercase;color:var(--accent-bright);white-space:nowrap;flex-shrink:0}
@media(max-width:1100px){.nav-badge{display:none}}
@media(max-width:900px){.nav-link{font-size:.73rem;padding:.5rem .45rem}}

/* hamburger */
.nav-hamburger{
  display:none;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  min-width:44px;min-height:44px;background:none;border:none;cursor:pointer;
  padding:8px;border-radius:var(--r-sm);transition:background .2s}
.nav-hamburger:hover{background:rgba(255,255,255,.06)}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .25s,opacity .25s;transform-origin:center}
.nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* scroll progress bar — fixed to viewport, sits at nav bottom edge */
.scroll-progress{
  position:fixed;top:var(--nav-height);left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--accent),var(--accent-bright));
  transition:width .1s linear;z-index:var(--z-nav)}

/* ── MEGA-MENU ── */
.nav-mega-wrap{position:relative;align-self:stretch;display:flex;align-items:center}
.nav-mega-trigger{
  background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.3em;
  font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.01em;
  color:var(--ink-dim);padding:.5rem .6rem;min-height:44px;border-radius:var(--r-sm);
  white-space:nowrap;transition:color var(--dur-fast),background var(--dur-fast);align-self:center}
.nav-mega-trigger:hover{background:rgba(255,255,255,.04);color:var(--ink)}
.nav-mega-caret{flex-shrink:0;transition:transform .2s var(--ease-out)}
.nav-mega-wrap.open .nav-mega-caret,.nav-mega-trigger[aria-expanded="true"] .nav-mega-caret{transform:rotate(180deg)}
.nav-mega-panel{
  position:absolute;top:100%;left:0;min-width:580px;
  background:rgba(14,20,38,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--edge-strong);border-top:2px solid var(--accent-bright);
  border-radius:0 0 var(--r-md) var(--r-md);padding:1.5rem;
  box-shadow:0 32px 64px rgba(0,0,0,.6);
  opacity:0;pointer-events:none;transform:translateY(-6px);
  transition:opacity .2s var(--ease-out),transform .2s var(--ease-out);z-index:var(--z-nav)}
.nav-mega-wrap.open .nav-mega-panel{opacity:1;pointer-events:auto;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){.nav-mega-panel{transition:none}}
.mega-inner{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.mega-col-head{
  font-family:var(--mono);font-size:.6rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);margin-bottom:.85rem;
  padding-bottom:.5rem;border-bottom:1px solid var(--edge)}
.mega-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.1rem}
.mega-link{
  display:flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.85rem;
  font-weight:500;color:var(--ink-dim);padding:.55rem .65rem;border-radius:var(--r-sm);
  transition:color .15s,background .15s;text-decoration:none;min-height:44px}
.mega-link:hover{color:var(--ink);background:rgba(255,255,255,.05)}
.mega-link--flagship{color:var(--accent-bright);font-weight:600}
.mega-link--flagship:hover{color:var(--accent-bright);background:var(--chip-bg)}
.mega-link-badge{
  font-family:var(--mono);font-size:.58rem;font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;color:var(--accent-bright);background:var(--chip-bg);
  border:1px solid rgba(91,141,255,.3);border-radius:3px;padding:.15rem .45rem}
.mega-link--all{margin-top:.35rem;color:var(--accent-bright);font-size:.82rem}
.mega-detail-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.85rem}
.mega-detail-item{display:flex;flex-direction:column;gap:.2rem}
.mega-detail-label{font-family:var(--display);font-size:.8rem;font-weight:600;color:var(--ink)}
.mega-detail-text{font-size:.78rem;color:var(--ink-faint);line-height:1.55}
@media(max-width:768px){.nav-mega-panel{display:none!important}}

/* mobile nav */
.mobile-nav{
  display:none;position:fixed;top:var(--nav-height);left:0;right:0;
  background:rgba(8,11,20,.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  padding:1.5rem 2rem 2rem;border-bottom:1px solid var(--edge);z-index:99;
  transform:translateY(-8px);opacity:0;transition:transform .25s,opacity .25s}
.mobile-nav.open{display:block;transform:translateY(0);opacity:1}
.mobile-nav a{
  display:flex;align-items:center;color:var(--ink-dim);font-family:var(--display);
  font-size:1.05rem;font-weight:600;padding:.85rem 0;border-bottom:1px solid var(--edge);
  min-height:44px;transition:color .15s}
.mobile-nav a:last-child{border-bottom:none}
.mobile-nav a:hover,.mobile-nav a.active{color:var(--accent-bright)}
.mobile-nav-group{border-bottom:1px solid var(--edge)}
.mobile-nav-group-row{display:flex;align-items:center}
.mobile-nav-group-link{
  flex:1;font-family:var(--display);font-size:1.05rem;font-weight:600;color:var(--ink-dim);
  padding:.85rem 0;min-height:44px;display:flex;align-items:center;transition:color .15s;text-decoration:none;border-bottom:none}
.mobile-nav-group-link:hover{color:var(--accent-bright)}
.mobile-nav-accordion-btn{
  background:none;border:none;color:var(--ink-faint);cursor:pointer;
  padding:.75rem .5rem;min-width:44px;min-height:44px;display:flex;align-items:center;
  justify-content:center;transition:color .15s,transform .2s var(--ease-out);border-radius:var(--r-sm)}
.mobile-nav-accordion-btn:hover{color:var(--accent-bright)}
.mobile-nav-accordion-btn[aria-expanded="true"]{transform:rotate(180deg);color:var(--accent-bright)}
.mobile-nav-sub{list-style:none;padding:0 0 .5rem .75rem;margin:0;display:flex;flex-direction:column}
.mobile-nav-sub[hidden]{display:none}
.mobile-nav-sub-link{
  display:flex;align-items:center;font-family:var(--sans);font-size:.9rem;font-weight:500;
  color:var(--ink-dim);padding:.6rem .5rem;min-height:44px;border-bottom:1px solid var(--edge);
  transition:color .15s;text-decoration:none}
.mobile-nav-sub-link:last-child{border-bottom:none}
.mobile-nav-sub-link:hover{color:var(--accent-bright)}

/* ── SKIP LINK ── */
.skip-to-content{
  position:absolute;top:-100%;left:1rem;background:var(--accent-bright);color:#fff;
  font-family:var(--sans);font-weight:700;font-size:.875rem;
  padding:.5rem 1rem;border-radius:0 0 var(--r-sm) var(--r-sm);z-index:9999;
  text-decoration:none;transition:top .2s}
.skip-to-content:focus{top:0}

/* ── VISUALLY HIDDEN ── */
.visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ── HERO ── */
.hero{
  min-height:100dvh;display:flex;align-items:center;
  background:transparent;padding-top:var(--nav-height)}
.hero-inner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:54px;
  align-items:center;padding:70px 0 58px}

/* hero radials */
.hero-radial-1{
  position:absolute;top:-20%;right:-10%;width:70vw;height:70vw;
  background:radial-gradient(ellipse at center,rgba(59,116,255,.18) 0%,transparent 65%);
  pointer-events:none;will-change:transform}
.hero-radial-2{
  position:absolute;bottom:-20%;left:-10%;width:50vw;height:50vw;
  background:radial-gradient(ellipse at center,rgba(8,11,20,.6) 0%,transparent 65%);
  pointer-events:none;will-change:transform}
.hero-grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(59,116,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(59,116,255,.04) 1px,transparent 1px);
  background-size:60px 60px;background-attachment:fixed;pointer-events:none}


.hero-content{position:relative;z-index:1}

/* eyebrow */
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-bright);
  border:1px solid var(--edge-strong);background:var(--chip-bg);border-radius:999px;
  padding:8px 15px;margin-bottom:1.5rem;
  opacity:0;animation:heroRise .7s .05s forwards cubic-bezier(.2,.7,.2,1)}
.hero-eyebrow-dot{
  width:6px;height:6px;border-radius:50%;background:var(--accent-bright);
  box-shadow:0 0 10px var(--accent-glow);flex-shrink:0}

/* H1 */
.hero-title{
  font-family:var(--display);font-weight:800;line-height:1.02;letter-spacing:-.022em;
  font-size:clamp(38px,5vw,66px);color:var(--ink);margin-bottom:0;
  opacity:0;animation:heroRise .8s .12s forwards cubic-bezier(.2,.7,.2,1)}
.hero-title-accent{color:var(--accent-bright);display:block}

/* legacy .hero-title em support */
.hero-title em{font-style:normal;color:var(--accent-bright)}

/* subhead */
.hero-sub{
  margin:24px 0 0;max-width:560px;font-size:clamp(16px,1.35vw,19px);
  line-height:1.58;color:var(--ink-dim);
  opacity:0;animation:heroRise .8s .20s forwards cubic-bezier(.2,.7,.2,1)}
.hero-sub strong{color:var(--ink);font-weight:600}

/* ctas */
.hero-ctas{
  display:flex;flex-wrap:wrap;gap:14px;margin-top:36px;
  opacity:0;animation:heroRise .8s .28s forwards cubic-bezier(.2,.7,.2,1)}

/* procline */
.hero-procline{
  margin-top:22px;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;
  color:var(--ink-faint);display:flex;flex-wrap:wrap;gap:6px 14px;
  opacity:0;animation:heroRise .8s .36s forwards cubic-bezier(.2,.7,.2,1)}
.hero-procline span{color:var(--ink-dim)}

/* hero visual col */
.hero-visual{
  position:relative;display:flex;flex-direction:column;gap:1.25rem;
  opacity:0;animation:heroFade 1.1s .35s forwards}
.hero-svg-wrap{position:relative;width:100%;aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center}
.hero-svg-motif{width:100%;height:100%;overflow:visible}

/* viz caption */
.hero-viz-caption{
  text-align:center;margin-top:.75rem;font-family:var(--mono);
  font-size:.7rem;letter-spacing:.04em;color:var(--ink-dim)}
.hero-viz-caption strong,.hero-viz-caption b{color:var(--accent-bright);font-weight:500}

/* ORCHESTRATION SVG */
.orch-boundary{fill:none;stroke:var(--edge-strong);stroke-width:1.2;stroke-dasharray:7 7}
.orch-boundary-label{font-family:var(--mono);font-size:9px;letter-spacing:.18em;fill:var(--ink-faint)}
.orch-link{
  stroke:var(--accent-bright);stroke-width:1.4;fill:none;opacity:.42;stroke-dasharray:5 7;
  animation:orchFlow 2.8s linear infinite}
.orch-node circle{fill:#0e1426;stroke:#5b8dff;stroke-width:1.4}
.orch-node .orch-halo{
  fill:none;stroke:#5b8dff;stroke-width:1.4;opacity:0;
  transform-origin:center;transform-box:fill-box;animation:orchPulse 3s ease-out infinite}
.orch-node.orch-node--root circle{stroke-width:2}
.orch-node text{
  font-family:'IBM Plex Mono',monospace;font-size:9.5px;letter-spacing:.08em;fill:#eef2ff;
  text-anchor:middle;dominant-baseline:middle}
.orch-node.orch-node--root text{fill:#5b8dff}
.orch-float{animation:orchFloat 7s ease-in-out infinite}
@media(max-width:768px){
  .orch-float{animation:none}
  .orch-node .orch-halo{animation:none;opacity:0}}

/* legacy SVG support */
.svg-node{fill:var(--panel);stroke:rgba(91,141,255,.45);stroke-width:1.4}
.svg-node--root{stroke:var(--accent-bright);stroke-width:2}
.svg-node--primary{stroke:rgba(91,141,255,.6);stroke-width:1.8}
.svg-flow-dot{animation:flowDot 3s linear infinite}
.svg-node-group{cursor:pointer;transition:transform .18s;transform-box:fill-box;transform-origin:center}
.svg-node-group:hover{transform:scale(1.12)}
.svg-tooltip{
  position:absolute;background:rgba(14,20,38,.96);border:1px solid rgba(91,141,255,.4);
  border-radius:var(--r-sm);color:var(--ink);font-family:var(--mono);font-size:.68rem;
  letter-spacing:.03em;padding:.3rem .6rem;pointer-events:none;white-space:nowrap;
  opacity:0;transform:translateY(4px);transition:opacity .15s,transform .15s;z-index:10}
.svg-tooltip.visible{opacity:1;transform:translateY(0)}

/* hero keyframes */
@keyframes heroRise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes heroFade{from{opacity:0}to{opacity:1}}
@keyframes orchFlow{to{stroke-dashoffset:-48}}
@keyframes orchPulse{
  0%{opacity:.5;transform:scale(1)}70%{opacity:0;transform:scale(2.1)}100%{opacity:0;transform:scale(2.1)}}
@keyframes orchFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@keyframes flowDot{0%{offset-distance:0%;opacity:0}5%{opacity:.8}95%{opacity:.8}100%{offset-distance:100%;opacity:0}}
@keyframes nodePulse{0%,100%{opacity:.5;r:5}50%{opacity:1;r:7}}
@keyframes heroGlow{0%,100%{opacity:1}50%{opacity:.7}}

/* hero responsive */
@media(prefers-reduced-motion:no-preference){
  .hero-radial-1{animation:heroGlow 12s ease-in-out infinite}}
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr;padding:56px 0 36px}
  .hero-visual{order:-1}}
@media(max-width:768px){
  .hero-inner{padding:40px 0 28px;gap:28px}
  .hero-svg-wrap{aspect-ratio:4/3;max-height:260px}
  .hero-ctas{flex-direction:column}
  .hero-ctas .btn{text-align:center;justify-content:center}}
@media(max-width:400px){
  .hero-title{font-size:clamp(1.6rem,8vw,2.4rem)}
  .hero-ctas .btn{width:100%}}
@media(prefers-reduced-motion:reduce){
  .hero-eyebrow,.hero-title,.hero-sub,.hero-ctas,.hero-procline,.hero-visual{
    opacity:1;animation:none}
  .orch-link,.orch-halo,.orch-float,.svg-flow-dot,.svg-node,
  .svg-node--root,.svg-node--primary{animation:none}
  .orch-halo{opacity:0}}

/* ── PROOF BAR ── */
.proof-bar{
  margin:0;border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);
  background:linear-gradient(180deg,var(--panel),rgba(11,16,32,.85));
  padding:2.25rem 0;position:relative;z-index:1}
.proof-bar-head{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-bright);text-align:center;margin-bottom:1.75rem;
  display:flex;align-items:center;justify-content:center;gap:14px}
.proof-bar-head::before,.proof-bar-head::after{
  content:'';height:1px;width:44px;background:var(--edge-strong)}
.proof-bar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.proof-stat{text-align:center;position:relative}
.proof-stat:not(:last-child)::after{
  content:'';position:absolute;right:-.75rem;top:12%;height:76%;width:1px;background:var(--edge)}
.proof-num{
  font-family:var(--display);font-weight:700;font-size:clamp(2.2rem,3.5vw,3.25rem);
  color:var(--ink);line-height:1;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.proof-suf{color:var(--accent-bright);font-size:.75em;vertical-align:super}
.proof-lbl{margin-top:.6rem;font-size:.8rem;color:var(--ink-dim);line-height:1.35}
.proof-bar-foot{
  margin-top:1.75rem;text-align:center;font-size:.7rem;color:var(--ink-faint);
  font-family:var(--mono);letter-spacing:.03em}
@media(max-width:900px){
  .proof-bar-grid{grid-template-columns:repeat(2,1fr);gap:2rem 1.25rem}
  .proof-stat:nth-child(2)::after{display:none}}
@media(max-width:480px){
  .proof-bar-grid{grid-template-columns:1fr;gap:1.5rem}
  .proof-stat::after{display:none}
  .proof-bar{padding:1.75rem 0}}

/* ── MARQUEE ── */
.marquee-section{
  overflow:hidden;padding:.8rem 0;background:var(--surface-1);
  border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);user-select:none}
.marquee-wrap{display:flex;overflow:hidden}
.marquee-track{
  display:flex;width:max-content;will-change:transform;
  animation:marqueeScroll 40s linear infinite}
.marquee-section:hover .marquee-track,.marquee-section:focus-within .marquee-track{
  animation-play-state:paused}
@keyframes marqueeScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-set{display:flex;align-items:center;gap:0;flex-shrink:0}
.marquee-item{
  font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.07em;
  text-transform:uppercase;color:var(--ink-faint);white-space:nowrap;padding:0 1.75rem}
.marquee-sep{color:var(--edge-strong);flex-shrink:0;font-size:.5rem;letter-spacing:0}
@media(prefers-reduced-motion:reduce){.marquee-section{display:none}}

/* ── BUYER ROUTER ── */
.buyer-router{padding:5rem 0}
.router-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:1.5rem;margin-top:2.5rem}
.router-card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--edge);
  border-radius:var(--r-md);padding:2rem;display:flex;flex-direction:column;gap:1rem;
  transition:border-color .2s,transform .2s}
.router-card:hover{border-color:var(--edge-strong);transform:translateY(-2px)}
.router-card:active{transform:scale(.98)}
.router-card--primary{
  background:var(--surface-2);border-color:var(--edge-strong);position:relative}
.router-card--primary::before{
  content:'';position:absolute;inset:-1px;border-radius:var(--r-md);
  border:1px solid rgba(91,141,255,.35);pointer-events:none}
.router-badge{
  font-family:var(--mono);font-size:.68rem;font-weight:600;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent-bright);background:var(--chip-bg);
  padding:.3rem .65rem;border-radius:var(--r-sm);display:inline-block;width:fit-content}
.router-title{font-family:var(--display);font-size:1.1rem;font-weight:600;color:var(--ink);line-height:1.4}
.router-card--primary .router-title{font-size:1.25rem}
.router-desc{font-size:.9rem;color:var(--ink-dim);line-height:1.7;flex:1}
.router-actions{display:flex;flex-direction:column-reverse;gap:.75rem;margin-top:auto;padding-top:1rem}
.router-actions .link-arrow{font-size:.88rem}
.router-card--wa{grid-column:1/-1;flex-direction:row;align-items:center;gap:2.5rem}
.router-wa-left{flex:1;display:flex;flex-direction:column;gap:.75rem}
.router-card--wa .router-actions{flex-direction:column;margin-top:0;padding-top:0;min-width:200px;flex-shrink:0}
@media(max-width:900px){
  .router-grid{grid-template-columns:1fr}
  .router-card--primary{order:-1}
  .router-card--wa{flex-direction:column}
  .router-card--wa .router-actions{min-width:0;width:100%}}

/* ── SERVICES PREVIEW ── */
.services-preview{padding:5rem 0}
.services-bento{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2.5rem}
.service-card{
  position:relative;background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--edge);border-radius:var(--r-md);padding:2rem;
  transition:border-color .2s,transform .2s,box-shadow .2s;overflow:hidden}
.service-card:hover,.service-card:focus-within{
  background:var(--surface-3);border-color:var(--accent-bright);
  transform:translateY(-3px);box-shadow:0 16px 40px -16px var(--accent-glow)}
.service-card:active{transform:scale(.98)}
@media(hover:none){.service-card:hover{transform:none;box-shadow:none}}
.service-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;background:var(--chip-bg);border-radius:var(--r-sm);margin-bottom:1rem}
.service-icon svg{stroke:var(--accent-bright);opacity:.9}
.service-icon-lg{width:56px;height:56px;font-size:1.75rem;flex-shrink:0}
.service-icon-lg svg{stroke:var(--accent-bright);opacity:.85}
.service-card-title{
  font-family:var(--display);font-weight:600;font-size:1rem;color:var(--ink);
  margin-bottom:.6rem;line-height:1.3}
.service-card-title a{
  display:inline-flex;align-items:center;color:var(--ink);gap:0}
.service-card-title a::after{
  content:'\00a0→';display:inline-block;opacity:0;transform:translateX(-4px);
  transition:opacity .2s var(--ease-out),transform .2s var(--ease-out)}
.service-card:hover .service-card-title a::after,
.service-card:focus-within .service-card-title a::after{opacity:1;transform:translateX(2px)}
.service-card .service-card-title a::before{
  content:'';position:absolute;inset:0;z-index:1;border-radius:var(--r-md)}
.service-card .btn,.service-card .btn-ghost-sm,.service-card button{position:relative;z-index:2}
.service-card-desc{font-size:.87rem;color:var(--ink-dim);line-height:1.65;margin-bottom:1rem}
.services-cta-row{text-align:center}

/* bento featured card */
.service-bento-featured{
  grid-column:span 2;background:var(--surface-3);border:1px solid rgba(91,141,255,.3);
  border-top:2px solid var(--accent-bright);border-radius:var(--r-md);padding:2rem;
  position:relative;display:flex;flex-direction:column;gap:0;
  transition:border-color .2s,transform .2s}
.service-bento-featured:hover{border-color:rgba(91,141,255,.55);transform:translateY(-2px)}
.service-bento-featured:active{transform:scale(.99)}
.service-bento-featured .service-card-title{font-size:1.2rem;font-weight:700;margin-bottom:.5rem}
.service-bento-featured .service-card-title a{color:var(--ink)}
.service-bento-eyebrow{
  display:inline-block;font-family:var(--mono);font-size:.62rem;font-weight:600;
  letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.75rem}
.service-bento-featured .service-card-desc{
  flex:1;font-size:.9rem;line-height:1.7;color:var(--ink-dim);margin-bottom:1rem}
.service-bento-footer{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  margin-top:1rem;padding-top:1rem;border-top:1px solid var(--edge)}
.service-bento-price{
  font-family:var(--mono);font-variant-numeric:tabular-nums;font-size:1.05rem;
  font-weight:600;color:var(--accent-bright);letter-spacing:.02em}
.service-bento-price-label{
  font-family:var(--mono);font-size:.65rem;font-weight:500;color:var(--ink-faint);
  letter-spacing:.06em;text-transform:uppercase;display:block;margin-bottom:.15rem}

/* bento wide */
.service-bento-wide{
  grid-column:span 3;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.service-bento-wide .service-card-title{font-size:1.05rem}

@media(max-width:1024px){
  .services-bento{grid-template-columns:repeat(2,1fr)}
  .service-bento-featured{grid-column:span 2}
  .service-bento-wide{grid-column:span 2;grid-template-columns:1fr}}
@media(max-width:640px){
  .services-bento{grid-template-columns:1fr}
  .service-bento-featured,.service-bento-wide{grid-column:span 1}
  .service-bento-wide{grid-template-columns:1fr}}

/* ── PROOF / CASE STUDIES (tabbed) ── */
.proof-section{padding:5rem 0}
.proof-head-row{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap;margin-bottom:2rem}
.proof-tabs{
  display:flex;gap:6px;flex-wrap:wrap;background:var(--panel-2);
  border:1px solid var(--edge);border-radius:999px;padding:5px;flex-shrink:0}
.proof-tab{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;
  border:none;background:transparent;color:var(--ink-dim);padding:8px 16px;
  border-radius:999px;cursor:pointer;transition:color .18s,background .18s;white-space:nowrap}
.proof-tab:hover{color:var(--ink)}
.proof-tab.active,.proof-tab[aria-selected="true"]{
  background:var(--accent);color:#fff;box-shadow:0 6px 16px -8px var(--accent-glow)}

/* case grid */
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.case-card{
  border:1px solid var(--edge);border-radius:var(--r-md);
  background:linear-gradient(180deg,var(--panel),var(--panel-2));
  padding:24px 22px 22px;display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;transition:transform .2s,border-color .2s}
.case-card:hover{transform:translateY(-3px);border-color:var(--edge-strong)}
.case-card[hidden]{display:none}
.case-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.case-badge{
  font-family:var(--mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent-bright);border:1px solid var(--edge);background:var(--chip-bg);
  border-radius:var(--r-sm);padding:5px 9px}
.case-stat-pill{font-family:var(--mono);font-size:.72rem;color:var(--ink-faint)}
.case-title{
  font-family:var(--display);font-weight:600;font-size:1.05rem;
  letter-spacing:-.01em;line-height:1.22;color:var(--ink)}
.case-desc{font-size:.85rem;color:var(--ink-dim);line-height:1.55}
.case-stack{display:flex;flex-wrap:wrap;gap:6px}
.case-stack-tag{
  font-family:var(--mono);font-size:.68rem;color:var(--ink-faint);
  border:1px solid var(--edge);border-radius:5px;padding:3px 7px}
.case-result{
  margin-top:auto;display:flex;align-items:baseline;gap:9px;
  padding-top:14px;border-top:1px solid var(--edge)}
.case-result-num{
  font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--ink);letter-spacing:-.01em}
.case-result-label{font-size:.78rem;color:var(--ink-dim);line-height:1.35}
@media(max-width:1024px){.case-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.case-grid{grid-template-columns:1fr}}

/* ── IMPACT / REPRESENTATIVE WORK (non-tabbed alt) ── */
.impact{padding:5rem 0}
.impact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.impact-card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--edge);
  border-radius:var(--r-md);padding:1.75rem;display:flex;flex-direction:column;gap:.6rem;
  transition:border-color .2s,transform .2s}
.impact-card:hover{border-color:var(--edge-strong);transform:translateY(-2px)}
.impact-card:active{transform:scale(.98)}
.impact-label{
  font-family:var(--mono);font-size:.65rem;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent-bright)}
.impact-title{
  font-family:var(--display);font-weight:600;font-size:.95rem;color:var(--ink);line-height:1.3}
.impact-desc{font-size:.83rem;color:var(--ink-dim);line-height:1.65;flex:1}
.impact-stat{
  font-family:var(--mono);font-variant-numeric:tabular-nums;font-weight:500;
  font-size:clamp(1.4rem,2.5vw,1.9rem);color:var(--accent-bright);line-height:1.1;margin-top:.5rem}
.impact-stat-unit{font-size:1rem;font-weight:400;color:var(--ink-dim)}
.impact-stat-sub{font-size:.72rem;color:var(--ink-faint);line-height:1.4}
@media(max-width:1024px){.impact-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.impact-grid{grid-template-columns:1fr}}

/* ── ARCHITECTURE NOTE STRIP ── */
.arch-note-section{
  padding:0;border-top:1px solid var(--edge);border-bottom:1px solid var(--edge);
  background:var(--surface-1)}
.arch-note-card{
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
  padding:1.25rem 0;flex-wrap:wrap}
.arch-note-text{font-size:.85rem;color:var(--ink-dim);line-height:1.6;flex:1;min-width:260px}
.arch-note-label{
  display:block;font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent-bright);margin-bottom:.3rem}
.arch-note-link{
  font-size:.82rem;font-weight:600;color:var(--accent-bright);white-space:nowrap;
  flex-shrink:0;transition:color .15s}
.arch-note-link:hover{color:var(--accent)}

/* ── ARCHITECTURE SECTION ── */
.arch-section{padding:5rem 0}
.arch-diagram-wrap{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-top:1rem}
.arch-diagram{position:relative;width:100%}
.arch-svg{width:100%;height:auto;display:block}
.arch-layers{display:flex;flex-direction:column;gap:1.25rem}
.arch-layer{display:flex;align-items:flex-start;gap:1rem}
.arch-layer-badge{
  font-family:var(--mono);font-size:.72rem;font-weight:500;color:var(--accent-bright);
  background:var(--chip-bg);border:1px solid rgba(91,141,255,.25);border-radius:var(--r-sm);
  padding:.2rem .5rem;flex-shrink:0;margin-top:.15rem;letter-spacing:.04em}
.arch-layer-title{
  font-family:var(--display);font-weight:600;font-size:.9rem;color:var(--ink);margin-bottom:.3rem}
.arch-layer-desc{font-size:.83rem;color:var(--ink-dim);line-height:1.6}
@media(max-width:900px){.arch-diagram-wrap{grid-template-columns:1fr;gap:2.5rem}}

/* ── WHY US ── */
.why-us{padding:5rem 0}
.why-grid{display:flex;flex-direction:column;border-top:1px solid var(--edge)}
.why-card{
  display:grid;grid-template-columns:4rem 1fr;gap:0 2rem;padding:1.5rem 0;
  border-bottom:1px solid var(--edge);background:transparent;overflow:hidden;
  transition:background .2s,border-bottom-color .2s,padding-left .2s;cursor:default}
.why-card:hover{
  background:rgba(59,116,255,.03);border-bottom-color:rgba(91,141,255,.25);padding-left:1rem}
.why-number{
  grid-column:1;grid-row:1/3;align-self:start;font-family:var(--display);font-weight:700;
  font-size:clamp(1.75rem,4vw,3rem);color:var(--edge-strong);line-height:1.2;
  letter-spacing:-.02em;transition:color .2s}
.why-card:hover .why-number{color:rgba(91,141,255,.6)}
.why-title{
  grid-column:2;grid-row:1;font-family:var(--display);font-weight:600;font-size:.95rem;
  color:var(--ink);margin:0;line-height:1.35;align-self:center}
.why-desc{
  grid-column:2;grid-row:2;font-size:.85rem;color:var(--ink-dim);line-height:1.65;
  max-height:0;overflow:hidden;opacity:0;margin:0;padding-top:0;
  transition:max-height .35s,opacity .25s,padding-top .25s}
.why-card:hover .why-desc{max-height:8rem;opacity:1;padding-top:.6rem}

/* ── TRUST BAND ── */
.trust-band{
  padding:3.5rem 0;background:var(--surface-2);
  border-top:2px solid var(--accent-bright);border-bottom:1px solid var(--edge)}
.trust-band-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
.trust-item{display:flex;flex-direction:column;gap:.5rem;padding-left:1rem;border-left:2px solid var(--accent-bright)}
.trust-item-label{font-family:var(--display);font-size:.9rem;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.trust-item-detail{font-size:.85rem;color:var(--ink-dim);line-height:1.7}
@media(max-width:900px){.trust-band-inner{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){
  .trust-band-inner{grid-template-columns:1fr}
  .trust-item{padding-bottom:1.5rem;border-bottom:1px solid var(--edge)}
  .trust-item:last-child{padding-bottom:0;border-bottom:none}}

/* ── COMPLIANCE STRIP ── */
.compliance-strip{padding:2.5rem 0}
.compliance-strip-inner{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.compliance-strip-label{
  font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-bright);white-space:nowrap;flex-shrink:0}
.compliance-list{display:flex;flex-wrap:wrap;gap:.5rem .75rem;flex:1}
.compliance-item{
  font-family:var(--mono);font-size:.7rem;font-weight:500;color:var(--ink-dim);
  border:1px solid var(--edge-strong);border-radius:var(--r-sm);padding:.2rem .55rem;
  white-space:nowrap;letter-spacing:.02em;transition:border-color .2s,color .2s}
.compliance-item:hover{border-color:var(--accent-bright);color:var(--accent-bright)}
.compliance-strip-note{width:100%;font-size:.72rem;color:var(--ink-faint);line-height:1.55;margin-top:.5rem}

/* ── PROC STRIP ── */
.proc-strip-section{padding:3rem 0;border-top:2px solid var(--accent-bright)}
.proc-strip-inner{
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;justify-content:space-between;
  border:1px solid var(--edge);border-radius:var(--r-md);padding:1.5rem 2rem;
  background:var(--surface-2)}
.proc-strip-ids{display:flex;flex-wrap:wrap;align-items:stretch;gap:0}
.proc-strip-item{
  display:flex;flex-direction:column;gap:.3rem;padding:0 2rem 0 0;
  margin-right:2rem;border-right:1px solid var(--edge)}
.proc-strip-item:last-child{border-right:none;padding-right:0;margin-right:0}
.proc-strip-label{
  font-family:var(--mono);font-size:.6rem;font-weight:600;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);white-space:nowrap}
.proc-strip-value{
  font-family:var(--mono);font-size:.85rem;font-weight:500;color:var(--ink);white-space:nowrap}
.proc-strip-links{display:flex;gap:.75rem;flex-wrap:wrap;flex-shrink:0;align-items:center}
@media(max-width:768px){
  .proc-strip-inner{flex-direction:column;align-items:flex-start}
  .proc-strip-ids{gap:1.25rem 0;flex-direction:column}
  .proc-strip-item{border-right:none;padding-right:0;margin-right:0;
    padding-bottom:1.25rem;margin-bottom:0;border-bottom:1px solid var(--edge)}
  .proc-strip-item:last-child{border-bottom:none;padding-bottom:0}}

/* copy-to-clipboard (proc rows) */
.proc-copy-btn{
  padding:.5rem .85rem;margin-right:.75rem;background:transparent;
  border:1px solid var(--edge-strong);border-radius:var(--r-sm);font-family:var(--mono);
  font-size:.68rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-faint);cursor:pointer;transition:border-color .15s,color .15s,background .15s;
  white-space:nowrap;flex-shrink:0}
.proc-copy-btn:hover{border-color:var(--accent-bright);color:var(--accent-bright);background:var(--chip-bg)}
.proc-copy-btn.copied{border-color:var(--verified);color:var(--verified);background:rgba(46,158,120,.1)}
.proc-copy-row{
  display:grid;grid-template-columns:200px 1fr auto;align-items:center;
  border-bottom:1px solid var(--edge);background:var(--surface-1)}
.proc-copy-row:last-child{border-bottom:none}
.proc-copy-label{
  padding:.9rem 1.25rem;font-family:var(--mono);font-size:.72rem;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);
  background:var(--surface-2);border-right:1px solid var(--edge)}
.proc-copy-value{
  padding:.9rem 1.25rem;font-family:var(--mono);font-variant-numeric:tabular-nums;
  font-size:.88rem;color:var(--ink)}
@media(max-width:640px){
  .proc-copy-row{grid-template-columns:1fr}
  .proc-copy-label{border-right:none;border-bottom:1px solid var(--edge)}
  .proc-copy-btn{margin:.25rem .75rem .5rem}}

/* ── FAQ ── */
.faq-section{padding:5rem 0}
.faq-list{margin-top:2.5rem;display:flex;flex-direction:column;gap:.75rem}
.faq-item{}
.faq-details{
  background:var(--panel);border:1px solid var(--edge);border-left:3px solid transparent;
  border-radius:var(--r-md);overflow:hidden;transition:border-color .2s,border-left-color .2s}
.faq-details[open]{border-color:var(--edge-strong);border-left-color:var(--accent-bright)}
.faq-question{
  list-style:none;padding:1.15rem 1.4rem;cursor:pointer;font-family:var(--display);
  font-weight:600;font-size:1rem;color:var(--ink);display:flex;align-items:center;
  justify-content:space-between;gap:1rem;user-select:none;transition:color .15s,background .15s}
.faq-question::-webkit-details-marker{display:none}
.faq-question::after{
  content:'';display:inline-block;width:9px;height:9px;border-right:2px solid var(--accent-bright);
  border-bottom:2px solid var(--accent-bright);transform:rotate(45deg);flex-shrink:0;
  transition:transform .25s;margin-top:-3px}
.faq-details[open] .faq-question::after{transform:rotate(-135deg);margin-top:4px}
.faq-details[open] .faq-question{background:var(--surface-3);color:var(--ink)}
.faq-question:hover{color:var(--accent-bright)}
.faq-answer{padding:0 1.4rem 1.4rem;border-top:1px solid var(--edge)}
.faq-answer p{font-size:.94rem;color:var(--ink-dim);line-height:1.8;margin:0;padding-top:1rem}
.faq-more{margin-top:2rem;text-align:center}
@media(max-width:640px){
  .faq-question{font-size:.93rem;padding:1rem 1.1rem}
  .faq-answer{padding:0 1.1rem 1rem}}

/* ── CTA STRIP ── */
.cta-strip{padding:5rem 0}
.cta-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem}
.cta-title{
  font-family:var(--display);font-weight:700;font-size:clamp(1.5rem,3vw,2.25rem);
  color:var(--ink);max-width:700px}
.cta-sub{font-size:1rem;color:var(--ink-dim)}
.cta-sub a{color:var(--accent-bright)}
.cta-sub a:hover{color:var(--accent)}
.cta-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}

/* ── FOOTER ── */
.site-footer{
  background:var(--surface-1);border-top:1px solid var(--edge);
  position:relative;overflow:hidden}

/* footstrip layout */
.footstrip{
  padding:28px 0 48px;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:20px;flex-wrap:wrap;position:relative;z-index:1;text-align:center}
.foot-creds{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.foot-cred{
  display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.06em;color:var(--ink-dim);border:1px solid var(--edge);
  border-radius:var(--r-md);padding:7px 12px;background:var(--panel-2);transition:border-color .18s}
.foot-cred:hover{border-color:var(--edge-strong)}
.foot-cred svg{flex:none;color:var(--accent-bright)}
.foot-copy{font-family:var(--mono);font-size:.7rem;color:var(--ink-faint);letter-spacing:.04em}

/* legacy footer rows */
.footer-top{padding:1.25rem 0;border-bottom:1px solid var(--edge)}
.footer-top-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;flex-wrap:wrap;position:relative;z-index:1}
.footer-nav{display:flex;align-items:center;gap:1.75rem;flex-wrap:wrap}
.footer-nav a{font-size:.83rem;color:var(--ink-dim);transition:color .15s}
.footer-nav a:hover{color:var(--ink)}
.footer-cap-link{font-size:.78rem;font-weight:500;color:var(--accent-bright);white-space:nowrap;transition:color .15s}
.footer-cap-link:hover{color:var(--accent)}
.footer-bottom{padding:1rem 0;position:relative;z-index:1}
.footer-bottom-inner{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.footer-copy,.footer-ids,.footer-social{font-size:.75rem;color:var(--ink-faint);white-space:nowrap}
.footer-ids a{color:var(--ink-faint);transition:color .15s}
.footer-ids a:hover{color:var(--ink)}
.footer-social{display:flex;gap:.6rem;align-items:center}
.footer-social a{color:var(--ink-faint);transition:color .15s}
.footer-social a:hover{color:var(--ink)}
@media(max-width:768px){
  .footer-top-inner,.footer-bottom-inner{flex-direction:column;align-items:flex-start;gap:.75rem}
  .footer-copy,.footer-ids,.footer-social{white-space:normal}
  .footstrip{flex-direction:column;align-items:center}}

/* ── PAGE HERO (inner pages) ── */
.page-hero{
  padding:calc(var(--nav-height) + 4rem) 0 4rem;background:var(--bg);
  position:relative;overflow:hidden}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 60% at 70% 50%,rgba(59,116,255,.12) 0%,transparent 70%);
  pointer-events:none}
.page-hero-inner{position:relative;z-index:1}
.breadcrumb{font-size:.8rem;color:var(--ink-faint);margin-bottom:1.25rem;
  display:flex;align-items:center;gap:.5rem}
.breadcrumb a{color:var(--ink-dim)}
.breadcrumb a:hover{color:var(--accent-bright)}
.page-hero-title{
  font-family:var(--display);font-weight:700;font-size:clamp(1.75rem,3.5vw,2.75rem);
  color:var(--ink);line-height:1.15;max-width:760px;margin-bottom:.75rem}
.page-hero-sub{font-size:1.05rem;color:var(--ink-dim);max-width:600px;line-height:1.7}

/* ── SERVICES DETAIL ── */
.services-detail{padding:4rem 0}
.service-detail-card{
  position:relative;background:linear-gradient(180deg,var(--panel),var(--panel-2));
  border:1px solid var(--edge);border-radius:var(--r-md);padding:2.5rem;margin-bottom:2rem;
  transition:border-color .2s;overflow:hidden}
.service-detail-card:hover{border-color:var(--edge-strong)}
.service-detail-card--flagship{
  border-color:rgba(91,141,255,.35);border-top:2px solid var(--accent-bright);background:var(--surface-2)}
.service-detail-card--flagship:hover{border-color:rgba(91,141,255,.6)}
.sdc-header{display:flex;align-items:flex-start;gap:1.25rem;margin-bottom:1.25rem}
.sdc-title{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--ink);margin-bottom:.25rem}
.sdc-tagline{font-size:.88rem;color:var(--accent-bright);font-weight:500}
.sdc-desc{font-size:.95rem;color:var(--ink-dim);line-height:1.75;margin-bottom:1.25rem}
.sdc-list{display:grid;grid-template-columns:repeat(2,1fr);gap:.35rem 1.5rem;margin-bottom:1.75rem}
.sdc-list li{font-size:.87rem;color:var(--ink-dim);padding-left:1.1em;position:relative;line-height:1.55}
.sdc-list li::before{content:'▪';position:absolute;left:0;color:var(--accent-bright);font-size:.7em;top:.22em}
.sdc-cta{margin-top:1.5rem;display:inline-flex}
@media(max-width:768px){.sdc-list{grid-template-columns:1fr}}

/* ── PSAI CALLOUT ── */
.psai-callout{
  margin-top:2rem;padding:1.1rem 1.4rem;background:var(--surface-2);
  border:1px solid var(--edge);border-left:3px solid var(--accent-bright);
  border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:.93rem;color:var(--ink-dim);line-height:1.75}
.psai-callout strong{color:var(--accent-bright);font-weight:600}

/* ── PRICING ── */
.pricing-section{padding:5rem 0}
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem;margin-bottom:1.5rem}
.pricing-card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--edge);
  border-radius:var(--r-md);padding:1.75rem 1.25rem;text-align:center}
.pricing-type{
  font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink-faint);margin-bottom:.75rem}
.pricing-range{
  font-family:var(--mono);font-variant-numeric:tabular-nums;font-weight:500;
  font-size:1.4rem;color:var(--accent-bright);line-height:1.2;margin-bottom:.5rem}
.pricing-duration{font-size:.85rem;color:var(--ink-dim);margin-bottom:.25rem}
.pricing-note{font-size:.78rem;color:var(--ink-faint)}
.pricing-note-global{font-size:.875rem;color:var(--ink-dim);text-align:center;max-width:600px;margin:0 auto}
@media(max-width:1024px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.pricing-grid{grid-template-columns:1fr}}

/* ── CAPABILITY ROTATOR ── */
.capabilities-rotator{padding:5rem 0}
.cap-rotator{
  display:grid;grid-template-columns:260px 1fr;gap:0;border:1px solid var(--edge);
  border-radius:var(--r-md);overflow:hidden;margin-top:2.5rem;background:var(--surface-1)}
.cap-tab-list{
  list-style:none;padding:.5rem 0;margin:0;background:var(--surface-2);
  border-right:1px solid var(--edge);display:flex;flex-direction:column}
.cap-tab{
  width:100%;text-align:left;background:none;border:none;border-right:2px solid transparent;
  margin-right:-1px;padding:.9rem 1.25rem;cursor:pointer;display:flex;flex-direction:column;
  gap:.25rem;color:var(--ink-dim);transition:color .15s,background .15s,border-color .15s;
  min-height:44px;justify-content:center}
.cap-tab:hover{color:var(--ink);background:rgba(255,255,255,.03)}
.cap-tab[aria-selected="true"]{color:var(--accent-bright);border-right-color:var(--accent-bright);background:var(--chip-bg)}
.cap-tab-num{
  font-family:var(--mono);font-size:.58rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--ink-faint);line-height:1;transition:color .15s}
.cap-tab[aria-selected="true"] .cap-tab-num{color:rgba(91,141,255,.65)}
.cap-tab-title{font-family:var(--display);font-size:.85rem;font-weight:600;line-height:1.25}
.cap-panels{padding:2rem;min-height:320px;position:relative}
.cap-panel{display:none}
.cap-panel.active{display:block}
@media(prefers-reduced-motion:no-preference){
  .cap-panel.active{animation:capFadeIn .22s var(--ease-out) both}
  @keyframes capFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}}
.cap-panel-eyebrow{
  font-family:var(--mono);font-size:.65rem;font-weight:500;letter-spacing:.1em;
  text-transform:uppercase;color:var(--accent-bright);margin-bottom:.65rem}
.cap-panel-title{
  font-family:var(--display);font-weight:700;font-size:clamp(1.1rem,2vw,1.35rem);
  color:var(--ink);line-height:1.2;margin-bottom:.75rem}
.cap-panel-desc{font-size:.93rem;color:var(--ink-dim);line-height:1.75;margin-bottom:1.25rem;max-width:58ch}
.cap-panel-list{
  display:grid;grid-template-columns:1fr 1fr;gap:.3rem 1.5rem;list-style:none;padding:0;margin:0 0 1.5rem}
.cap-panel-list li{font-size:.84rem;color:var(--ink-dim);padding-left:1.1em;position:relative;line-height:1.5}
.cap-panel-list li::before{content:'▪';position:absolute;left:0;color:var(--accent-bright);font-size:.7em;top:.22em}
.cap-panel-footer{
  display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;
  padding-top:1rem;border-top:1px solid var(--edge)}
.cap-panel-price{font-family:var(--mono);font-size:.9rem;font-weight:500;color:var(--accent-bright);letter-spacing:.02em}
@media(max-width:768px){
  .cap-rotator{grid-template-columns:1fr}
  .cap-tab-list{flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--edge);
    gap:0;padding:0;-webkit-overflow-scrolling:touch}
  .cap-tab{flex-direction:row;align-items:center;gap:.5rem;flex-shrink:0;border-right:none;
    border-bottom:2px solid transparent;margin-right:0;margin-bottom:-1px;
    padding:.65rem 1rem;white-space:nowrap}
  .cap-tab[aria-selected="true"]{border-bottom-color:var(--accent-bright);border-right-color:transparent}
  .cap-panel-list{grid-template-columns:1fr}
  .cap-panels{padding:1.5rem;min-height:0}}

/* ── ENGAGEMENT FLOW ── */
.engage-flow{padding:5rem 0}
.engage-steps{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:2rem;margin-top:3rem;counter-reset:step}
.engage-step{display:flex;flex-direction:column;gap:1rem;position:relative}
.engage-step+.engage-step::before{
  content:'';position:absolute;top:1.5rem;left:-1.1rem;width:.2rem;height:60%;
  background:linear-gradient(to bottom,var(--accent-bright),transparent);opacity:.3}
.engage-step-num{
  font-family:var(--mono);font-size:2.5rem;font-weight:600;color:var(--accent-bright);
  opacity:.25;line-height:1;letter-spacing:-.04em}
.engage-step:hover .engage-step-num{opacity:.6;transition:opacity .2s}
.engage-step-title{font-family:var(--display);font-weight:600;font-size:1rem;color:var(--ink);margin-bottom:.4rem}
.engage-step-desc{font-size:.85rem;color:var(--ink-dim);line-height:1.7}

/* ── CONTACT ── */
.contact-section{padding:4rem 0 5rem}
.contact-grid{display:grid;grid-template-columns:380px 1fr;gap:4rem;align-items:flex-start}
.contact-info-title{
  font-family:var(--display);font-weight:700;font-size:1.4rem;color:var(--ink);margin-bottom:.75rem}
.contact-info-sub{font-size:.92rem;color:var(--ink-dim);line-height:1.75;margin-bottom:1.75rem}
.contact-details{display:flex;flex-direction:column;gap:.85rem;margin-bottom:2rem}
.contact-detail-item{display:flex;align-items:center;gap:.75rem;font-size:.9rem;color:var(--ink)}
.contact-detail-icon{width:1.5rem;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.contact-detail-icon svg{stroke:var(--accent-bright);opacity:.8}
.contact-detail-link{color:var(--accent-bright)}
.contact-detail-link:hover{color:var(--accent)}
.procurement-id-box{
  background:var(--surface-1);border:1px solid var(--edge);border-radius:var(--r-md);
  padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}
.proc-id-row{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}
.proc-id-label{
  font-family:var(--mono);color:var(--ink-faint);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}
.proc-id-value{font-family:var(--mono);font-variant-numeric:tabular-nums;color:var(--accent-bright);font-size:.85rem}
.proc-id-divider{height:1px;background:var(--edge);margin:.35rem 0}
.contact-form-wrap{
  background:var(--panel);border:1px solid var(--edge);border-radius:var(--r-md);padding:2.5rem}
.contact-form{display:flex;flex-direction:column;gap:1.25rem}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-label{font-size:.85rem;font-weight:500;color:var(--ink)}
.required{color:var(--accent-bright)}
.form-input{
  font-family:var(--sans);font-size:.9rem;color:var(--ink);background:var(--surface-2);
  border:1px solid var(--edge);border-radius:var(--r-sm);padding:.7rem .9rem;
  transition:border-color .15s,box-shadow .15s;width:100%;appearance:none}
.form-input:focus{outline:none;border-color:var(--accent-bright);box-shadow:0 0 0 3px var(--chip-bg)}
.form-input.invalid{border-color:var(--danger);box-shadow:0 0 0 3px rgba(214,69,61,.12)}
.form-select{
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239AA4B2' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.5rem}
.form-textarea{resize:vertical;min-height:140px}
.btn-submit{align-self:flex-start;font-size:.95rem;gap:.6rem}
.btn-submit.loading{opacity:.75;cursor:not-allowed;pointer-events:none}
.psai-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
.form-message{padding:1rem 1.25rem;border-radius:var(--r-sm);font-size:.9rem;margin-bottom:1.25rem;border-left:4px solid}
.form-success{background:rgba(46,158,120,.1);border-color:var(--verified);color:#7eeecb}
.form-error{background:rgba(214,69,61,.1);border-color:var(--danger);color:#f5a89a}
.form-error-msg{color:#f5a89a;font-size:.8rem;margin-top:.3rem;display:block}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.spin{animation:spin .8s linear infinite;display:inline-block}
.submit-spinner{display:none;line-height:0}
.submit-spinner.active{display:inline-flex}
@media(max-width:1024px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
@media(max-width:768px){
  .contact-form-wrap{padding:1.5rem}
  .btn-submit{width:100%;justify-content:center}}

/* ── PROCUREMENT TABLE ── */
.procurement-section,.procurement-detail{padding:4rem 0 5rem}
.procurement-detail-inner{max-width:860px;margin:0 auto}
.procurement-table,.proc-table-light{
  max-width:700px;border:1px solid var(--edge);border-radius:var(--r-md);overflow:hidden}
.proc-row{display:grid;grid-template-columns:200px 1fr;border-bottom:1px solid var(--edge)}
.proc-row:last-child{border-bottom:none}
.proc-label{
  padding:.9rem 1.25rem;font-family:var(--mono);font-size:.72rem;font-weight:500;
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);
  background:var(--surface-2);border-right:1px solid var(--edge)}
.proc-value{
  padding:.9rem 1.25rem;font-family:var(--mono);font-variant-numeric:tabular-nums;
  font-size:.88rem;color:var(--ink);background:var(--surface-1)}
.proc-detail-block{margin-bottom:3rem}
.proc-detail-title{
  font-family:var(--display);font-weight:700;font-size:1.2rem;color:var(--ink);
  margin-bottom:1rem;letter-spacing:-.02em}
.proc-detail-desc{font-size:.93rem;color:var(--ink-dim);line-height:1.75;margin-bottom:.75rem;max-width:68ch}
.proc-row-section .proc-section-head{
  grid-column:1/-1;font-family:var(--mono);font-weight:500;font-size:.68rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--accent-bright)!important;background:var(--chip-bg)!important;
  padding:.6rem 1.25rem;border-right:none!important}
.award-path-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-top:1.5rem}
.award-path-card{background:var(--panel);border:1px solid var(--edge);border-radius:var(--r-sm);padding:1.25rem}
.award-path-title{font-family:var(--display);font-weight:600;font-size:.95rem;color:var(--ink);margin-bottom:.25rem}
.award-path-threshold{
  font-family:var(--mono);font-size:.68rem;font-weight:500;color:var(--accent-bright);
  letter-spacing:.04em;margin-bottom:.75rem;text-transform:uppercase}
.award-path-desc{font-size:.82rem;color:var(--ink-dim);line-height:1.65}

/* award path cards using why-card style */
.award-path-why-grid{display:flex;flex-direction:column;border-top:1px solid var(--edge)}
.award-path-why-grid .why-title{align-self:start}
.award-path-why-grid .why-card:hover .why-desc{max-height:16rem}

@media(max-width:768px){
  .proc-row{grid-template-columns:1fr}
  .proc-label{border-right:none;border-bottom:1px solid var(--edge)}}

/* ── ABOUT PAGE ── */
.ab-section{padding:5rem 0}
.ab-grid{display:grid;grid-template-columns:290px 1fr;gap:4.5rem;align-items:start}
.ab-card{
  position:sticky;top:calc(var(--nav-height) + 1.5rem);background:var(--panel);
  border:1px solid var(--edge);border-top:2px solid var(--accent-bright);
  border-radius:var(--r-md);padding:2rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem}
.ab-mono{
  width:72px;height:72px;background:var(--chip-bg);border:1px solid rgba(91,141,255,.3);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-weight:700;font-size:1.35rem;color:var(--accent-bright);letter-spacing:.02em}
.ab-name{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--ink);line-height:1.2;margin-bottom:-.5rem}
.ab-role{font-size:.82rem;color:var(--ink-dim);line-height:1.6}
.ab-badge{
  display:inline-flex;align-items:center;gap:.4rem;font-family:var(--mono);font-size:.62rem;
  font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--accent-bright);
  background:var(--chip-bg);border:1px solid rgba(91,141,255,.28);border-radius:var(--r-sm);padding:.25rem .65rem}
.ab-divider{height:1px;background:var(--edge)}
.ab-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem .75rem}
.ab-stat-n{font-family:var(--mono);font-weight:600;font-size:1.3rem;color:var(--accent-bright);line-height:1;margin-bottom:.2rem}
.ab-stat-l{font-size:.68rem;color:var(--ink-faint);line-height:1.35}
.ab-skills{display:flex;flex-direction:column;gap:1rem}
.ab-skill-row{display:flex;flex-direction:column;gap:.35rem}
.ab-skill-cat{font-family:var(--mono);font-size:.6rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--ink-faint)}
.ab-skill-tags{display:flex;flex-wrap:wrap;gap:.3rem}
.ab-skill-tags span{
  font-family:var(--mono);font-size:.65rem;font-weight:500;color:var(--accent-bright);
  background:var(--chip-bg);border:1px solid rgba(91,141,255,.2);border-radius:3px;padding:.2rem .5rem;white-space:nowrap}
.ab-skill-tag--clear{color:var(--verified)!important;background:rgba(46,158,120,.08)!important;border-color:rgba(46,158,120,.28)!important}
.skill-tag-clearance{background:rgba(91,141,255,.15)!important;border-color:rgba(91,141,255,.35)!important;color:var(--accent-bright)!important}
.ab-linkedin{
  display:flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.72rem;
  font-weight:500;color:var(--accent-bright);padding:.55rem .9rem;border:1px solid var(--edge);
  border-radius:var(--r-sm);transition:border-color .2s,background .2s;justify-content:center}
.ab-linkedin:hover{border-color:var(--accent-bright);background:var(--chip-bg)}
.ab-narrative{padding-top:.5rem}
.ab-h2{font-family:var(--display);font-weight:600;font-size:1.2rem;color:var(--ink);letter-spacing:-.02em;margin-bottom:1rem}
.ab-p{font-size:1rem;color:var(--ink-dim);line-height:1.85;margin-bottom:1rem}
.ab-rule{height:1px;background:var(--edge);margin:2.5rem 0}
.ab-market{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.75rem}
.ab-market-card{background:var(--surface-2);border:1px solid var(--edge);border-radius:var(--r-sm);padding:1.25rem}
.ab-market-label{font-family:var(--mono);font-size:.63rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.65rem}
.ab-market-card p{font-size:.875rem;color:var(--ink-dim);line-height:1.7;margin:0}
.ab-disclosure{font-size:.8rem;color:var(--ink-faint);line-height:1.65;padding:1rem 1.25rem;
  background:var(--surface-1);border:1px solid var(--edge);border-left:2px solid var(--edge-strong);border-radius:0 5px 5px 0;margin-top:.25rem}
.ab-values-section{padding:5rem 0}
.ab-values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.25rem;margin-top:2.5rem}
.ab-value-card{background:var(--surface-2);border:1px solid var(--edge);border-radius:var(--r-md);padding:1.5rem}
.ab-value-label{font-family:var(--mono);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.75rem}
.ab-value-desc{font-size:.875rem;color:var(--ink-dim);line-height:1.75;margin:0}
.ab-procurement-section{padding:5rem 0}
.ab-proc-grid{max-width:700px;border:1px solid var(--edge);border-radius:var(--r-md);overflow:hidden;margin-top:2.5rem}
.ab-proc-row{display:grid;grid-template-columns:180px 1fr;border-bottom:1px solid var(--edge)}
.ab-proc-row:last-child{border-bottom:none}
.ab-proc-label{
  padding:.9rem 1.25rem;font-family:var(--mono);font-size:.72rem;font-weight:500;
  color:var(--ink-faint);letter-spacing:.06em;text-transform:uppercase;
  background:var(--surface-2);border-right:1px solid var(--edge)}
.ab-proc-value{padding:.9rem 1.25rem;font-size:.875rem;color:var(--ink)}
.ab-proc-cta{margin-top:2rem}
.about-disclosure-note{
  font-size:.8rem!important;color:var(--ink-faint)!important;line-height:1.65!important;
  border-top:1px solid var(--edge);padding-top:1rem;margin-top:.25rem;font-style:italic}
.bio-clearance{border-top:1px solid var(--edge);padding-top:.85rem;margin-bottom:1.1rem}
.bio-clearance-label{font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.25rem;opacity:.7}
.bio-clearance-text{font-size:.78rem;color:var(--ink-dim);line-height:1.55}
.bio-linkedin{margin-bottom:1.25rem}
.bio-linkedin a{display:inline-flex;align-items:center;font-size:.8rem;font-weight:500;color:var(--accent-bright);transition:color .15s}
.bio-linkedin a:hover{color:var(--accent)}
@media(max-width:1024px){.ab-grid{grid-template-columns:260px 1fr;gap:3rem}.ab-card{position:static}}
@media(max-width:768px){.ab-grid{grid-template-columns:1fr;gap:2rem}.ab-market{grid-template-columns:1fr}}

/* ── CAPABILITY STATEMENT ── */
.capstat-section{padding:4rem 0 5rem}
.capstat-inner{max-width:900px;margin:0 auto}
.capstat-block{margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid var(--edge)}
.capstat-block:last-child{border-bottom:none}
.capstat-heading{
  font-family:var(--display);font-weight:700;font-size:1.15rem;color:var(--ink);
  letter-spacing:-.02em;margin-bottom:1rem;padding-bottom:.5rem;
  border-bottom:2px solid var(--accent-bright);display:inline-block}
.capstat-para{font-size:.93rem;color:var(--ink-dim);line-height:1.8;margin-bottom:.85rem;max-width:72ch}
.capstat-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.65rem}
.capstat-list li{font-size:.9rem;color:var(--ink-dim);line-height:1.65;padding-left:1.25em;position:relative}
.capstat-list li::before{content:'▸';position:absolute;left:0;color:var(--accent-bright);font-size:.75em;top:.2em}
.capstat-note{font-size:.8rem;color:var(--ink-faint);font-style:italic;margin-bottom:1.25rem}
.capstat-solutions{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.capstat-solution-item{background:var(--surface-2);border:1px solid var(--edge);border-radius:var(--r-md);padding:1rem 1.25rem}
.capstat-solution-title{font-family:var(--display);font-weight:600;font-size:.88rem;color:var(--ink);margin-bottom:.35rem}
.capstat-solution-desc{font-size:.82rem;color:var(--ink-dim);line-height:1.6}
.capstat-contact-grid{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap}
.capstat-contact-name{font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--ink);margin-bottom:.2rem}
.capstat-contact-title{font-size:.85rem;color:var(--accent-bright);font-weight:500;margin-bottom:.75rem}
.capstat-contact-detail{font-size:.88rem;color:var(--ink-dim);margin-bottom:.3rem}
.capstat-contact-detail a{color:var(--accent-bright)}
.capstat-contact-detail a:hover{color:var(--accent)}
.capstat-cta-col{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem;flex-shrink:0}
@media(max-width:768px){.capstat-solutions{grid-template-columns:1fr}.capstat-contact-grid{flex-direction:column}}

/* ── TRAINING / GCC JUMPSTART ── */
.timeline-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-top:2rem}
.timeline-phase{background:var(--panel);border:1px solid var(--edge);border-radius:var(--r-md);padding:1.25rem 1.5rem;position:relative}
.timeline-phase-num{font-family:var(--display);font-weight:700;font-size:2rem;color:var(--accent-bright);opacity:.2;line-height:1;margin-bottom:.35rem}
.timeline-phase-label{font-family:var(--display);font-weight:600;font-size:.95rem;color:var(--ink);margin-bottom:.5rem}
.timeline-phase-weeks{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.5rem}
.timeline-phase-desc{font-size:.85rem;color:var(--ink-dim);line-height:1.6}
.readiness-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:.65rem}
.readiness-list li{display:flex;align-items:flex-start;gap:.65rem;font-size:.93rem;color:var(--ink-dim);line-height:1.55}
.readiness-list li::before{content:'✓';color:var(--verified);font-weight:700;flex-shrink:0;margin-top:.05em}
.local-services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.25rem;margin-top:1.5rem}
.local-service-card{background:var(--panel);border:1px solid var(--edge);border-radius:var(--r-md);padding:1.25rem 1.5rem}
.local-service-card h3{font-family:var(--display);font-weight:600;font-size:.95rem;color:var(--ink);margin-bottom:.5rem}
.local-service-card p{font-size:.85rem;color:var(--ink-dim);line-height:1.65}

/* ── BLOG / INSIGHTS ── */
.posts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem;margin:3rem 0}
.post-card{
  background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--edge);
  border-radius:var(--r-md);padding:1.75rem;transition:border-color .2s;position:relative;overflow:hidden}
.post-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-bright);
  opacity:0;transition:opacity .2s}
.post-card:hover{border-color:var(--edge-strong)}
.post-card:hover::before{opacity:1}
.post-meta{font-family:var(--mono);font-size:.72rem;color:var(--accent-bright);font-weight:500;margin-bottom:.5rem;letter-spacing:.04em}
.post-title{font-family:var(--display);font-size:1.1rem;font-weight:600;margin-bottom:.75rem;line-height:1.3;letter-spacing:-.015em}
.post-title a{color:var(--ink)}
.post-title a:hover{color:var(--accent-bright)}
.post-excerpt{font-size:.875rem;color:var(--ink-dim);line-height:1.65;margin-bottom:1rem}
.post-read-more{font-size:.85rem;color:var(--accent-bright);font-weight:500;min-height:44px;display:inline-flex;align-items:center}
.post-read-more:hover{color:var(--accent)}
.nav-links.posts-pagination{display:flex;gap:.5rem;justify-content:center;margin-top:2rem}

/* single post */
.post-body-section{padding:3.5rem 0 5rem}
.post-body-container{display:grid;grid-template-columns:1fr 300px;gap:3rem;align-items:start}
.post-content-col{min-width:0}
.post-prose{max-width:70ch;font-size:1.02rem;line-height:1.85;color:var(--ink-dim)}
.post-prose h2{font-family:var(--display);font-weight:700;font-size:1.4rem;color:var(--ink);margin:2.5rem 0 .75rem;letter-spacing:-.02em}
.post-prose h3{font-family:var(--display);font-weight:600;font-size:1.1rem;color:var(--ink);margin:2rem 0 .6rem}
.post-prose p{margin-bottom:1.25rem}
.post-prose ul,.post-prose ol{padding-left:1.5rem;margin-bottom:1.25rem}
.post-prose ul{list-style:disc}
.post-prose ol{list-style:decimal}
.post-prose li{margin-bottom:.4rem}
.post-prose strong{font-weight:600;color:var(--ink)}
.post-prose em{font-style:italic}
.post-prose a{color:var(--accent-bright);font-weight:500}
.post-prose a:hover{color:var(--accent)}
.post-prose blockquote{border-left:3px solid var(--accent-bright);padding:.75rem 1.25rem;margin:1.5rem 0;background:var(--surface-2);border-radius:0 var(--r-sm) var(--r-sm) 0;font-style:italic;color:var(--ink-dim)}
.post-prose code{font-family:var(--mono);font-size:.85em;background:var(--surface-2);padding:.15em .4em;border-radius:3px;color:var(--accent-bright);border:1px solid var(--edge)}
.post-prose pre{background:var(--surface-1);border:1px solid var(--edge);color:var(--ink-dim);padding:1.25rem 1.5rem;border-radius:var(--r-md);overflow-x:auto;margin-bottom:1.5rem;font-size:.85rem;line-height:1.7}
.post-prose pre code{background:none;padding:0;color:var(--accent-bright);font-size:inherit;border:none}
.post-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--edge)}
.post-tag{font-family:var(--mono);font-size:.72rem;font-weight:500;padding:.3rem .75rem;background:var(--surface-2);border:1px solid var(--edge);border-radius:var(--r-sm);color:var(--accent-bright);transition:background .15s,border-color .15s}
.post-tag:hover{background:var(--chip-bg);border-color:var(--accent-bright)}
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--edge)}
.post-nav-prev{text-align:left}
.post-nav-next{text-align:right}
.post-nav a{font-size:.85rem;font-weight:500;color:var(--accent-bright);display:block;line-height:1.5}
.post-nav a:hover{color:var(--accent)}
.post-nav-label{display:block;font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:.2rem}
.post-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:calc(var(--nav-height) + 1.5rem)}
.author-box{background:var(--surface-1);border:1px solid var(--edge);border-radius:var(--r-md);padding:1.5rem}
.author-box-header{font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.5rem;opacity:.75}
.author-box-name{font-family:var(--display);font-weight:700;font-size:1.1rem;color:var(--ink);margin-bottom:.2rem}
.author-box-title{font-size:.78rem;color:var(--ink-dim);margin-bottom:.85rem;line-height:1.5}
.author-box-bio{font-size:.82rem;color:var(--ink-dim);line-height:1.65;margin-bottom:.85rem}
.author-box-links{display:flex;gap:.5rem;align-items:center;font-size:.78rem}
.author-link{color:var(--accent-bright);font-weight:500}
.author-link:hover{color:var(--accent)}
.author-box-links span{color:var(--edge-strong)}
.sidebar-cta{background:var(--surface-2);border:1px solid var(--edge);border-radius:var(--r-md);padding:1.25rem;text-align:center}
.sidebar-cta-label{font-size:.82rem;color:var(--ink-dim);margin-bottom:.85rem;line-height:1.5;font-weight:500}
.sidebar-cta .btn-sm{padding:.6rem 1.25rem;font-size:.85rem;width:100%;display:block;margin-bottom:.6rem}
.sidebar-cta-secondary{display:block;font-size:.78rem;color:var(--ink-dim);text-align:center}
.sidebar-cta-secondary:hover{color:var(--accent-bright)}
.sidebar-services{background:var(--surface-1);border:1px solid var(--edge);border-radius:var(--r-md);padding:1.25rem}
.sidebar-services-label{font-family:var(--mono);font-size:.62rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-bright);margin-bottom:.75rem}
.sidebar-service-list{display:flex;flex-direction:column;gap:.5rem}
.sidebar-service-list li{list-style:none}
.sidebar-service-list a{font-size:.85rem;color:var(--ink-dim);font-weight:500;display:flex;align-items:center;gap:.4rem}
.sidebar-service-list a::before{content:'›';color:var(--accent-bright);font-size:1em}
.sidebar-service-list a:hover{color:var(--accent-bright)}
.related-posts{padding:3.5rem 0}
.related-posts-title{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--ink);margin-bottom:2rem;letter-spacing:-.02em}
.post-hero-title{font-size:clamp(1.6rem,4vw,2.4rem)}
.post-hero-meta{display:flex;gap:.5rem;align-items:center;font-family:var(--mono);font-size:.78rem;color:var(--ink-faint);margin-bottom:1rem;flex-wrap:wrap}
.post-hero-meta .meta-sep{color:var(--edge-strong)}
@media(max-width:960px){.post-body-container{grid-template-columns:1fr}.post-sidebar{position:static;flex-direction:row;flex-wrap:wrap}}
@media(max-width:600px){.post-sidebar{flex-direction:column}.post-nav{grid-template-columns:1fr}.post-nav-next{text-align:left}}

/* ── PAGE CONTENT (generic page.php / single.php) ── */
.page-content-section{padding:4rem 0 5rem;background:var(--bg)}
.page-content-inner{max-width:860px;margin:0 auto}
.page-content-inner h2{font-family:var(--display);font-size:1.5rem;font-weight:700;color:var(--ink);margin:2rem 0 .75rem;letter-spacing:-.02em}
.page-content-inner h3{font-family:var(--display);font-size:1.2rem;font-weight:600;color:var(--ink);margin:1.5rem 0 .5rem}
.page-content-inner p{font-size:.975rem;color:var(--ink-dim);line-height:1.8;margin-bottom:1rem;max-width:68ch}
.page-content-inner ul,.page-content-inner ol{padding-left:1.5rem;margin-bottom:1rem}
.page-content-inner li{font-size:.975rem;color:var(--ink-dim);line-height:1.7;margin-bottom:.35rem}
.page-content-inner a{color:var(--accent-bright)}
.page-content-inner a:hover{color:var(--accent)}
.page-content-inner strong{color:var(--ink);font-weight:600}
.page-content-inner blockquote{border-left:3px solid var(--accent-bright);padding:.75rem 1.5rem;margin:1.5rem 0;background:var(--surface-2);border-radius:0 var(--r-sm) var(--r-sm) 0}
.page-content-inner blockquote p{color:var(--ink-dim);font-style:italic}

/* ── 404 ── */
.not-found{min-height:100vh;display:flex;align-items:center;padding-top:var(--nav-height);background:var(--bg)}
.not-found-inner{text-align:center;position:relative;z-index:1;padding:4rem 2rem}
.not-found-404{font-family:var(--display);font-weight:700;font-size:clamp(6rem,15vw,10rem);color:var(--accent-bright);line-height:1;margin-bottom:.5rem;letter-spacing:-.04em;opacity:.35}
.not-found-title{font-family:var(--display);font-weight:700;font-size:2rem;color:var(--ink);margin-bottom:.75rem}
.not-found-sub{font-size:1rem;color:var(--ink-dim);margin-bottom:2rem}
.not-found-links{display:flex;justify-content:center;flex-wrap:wrap;gap:1rem}

/* ── INSIGHTS STUB ── */
.insights-stub{max-width:720px;margin:0 auto}
.insights-placeholder{cursor:default;pointer-events:none;opacity:.85}
.insights-cta{margin-top:2.5rem;text-align:center}
.insights-cta p{font-size:.93rem;color:var(--ink-dim);margin-bottom:1.25rem;line-height:1.7}

/* ── DATA-REVEAL (scroll-triggered) ── */
@media(prefers-reduced-motion:no-preference){
  [data-reveal]{
    opacity:0;transform:translateY(16px);
    transition:opacity var(--dur) var(--ease-out),transform var(--dur) var(--ease-out)}
  [data-reveal].revealed{opacity:1;transform:translateY(0)}}
.reveal-instant [data-reveal],.reveal-instant[data-reveal]{opacity:1!important;transform:none!important;transition:none!important}
.fade-up{opacity:0;transform:translateY(16px);transition:opacity .5s ease-out,transform .5s ease-out}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-up:nth-child(2){transition-delay:.04s}
.fade-up:nth-child(3){transition-delay:.08s}
.fade-up:nth-child(4){transition-delay:.12s}
.fade-up:nth-child(5){transition-delay:.16s}
.fade-up:nth-child(6){transition-delay:.20s}

/* ── SMOOTH SCROLL + ANCHOR OFFSET ── */
[id]{scroll-margin-top:calc(var(--nav-height) + 1.5rem)}

/* ── RESPONSIVE GLOBAL ── */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .impact-grid{grid-template-columns:repeat(2,1fr)}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .custom-logo{max-height:44px}
  .custom-logo-link{max-width:calc(100% - 60px)}
  .services-grid{grid-template-columns:1fr}
  .impact-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}}

/* ── REDUCED MOTION GLOBAL ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001s!important;animation-iteration-count:1!important;
    transition-duration:.001s!important;scroll-behavior:auto!important}
  [data-reveal],.fade-up{opacity:1!important;transform:none!important;transition:none!important}}
