/* ── PHANTOM SYSTEMS — styles.css ── */

/* ══════════════════════════════════════════
   TOKENS
══════════════════════════════════════════ */
:root {
  --bg:    #000;
  --bg2:   #0a0a0a;
  --bg3:   #111;
  --ink:   #e8dcc8;
  --dim:   rgba(232,220,200,.52);
  --soft:  rgba(232,220,200,.26);
  --mute:  rgba(232,220,200,.11);
  --gb:    #e8521c;
  --gm:    #c43f0f;
  --gl:    #ff6628;
  --gd:    rgba(232,82,28,.14);
  --gd2:   rgba(232,82,28,.06);
  --line:  rgba(232,82,28,.12);
  --line2: rgba(232,82,28,.22);
  --line3: rgba(232,82,28,.40);
  --max:   1440px;
  --gap:   clamp(1.5rem,4vw,4rem);
  --font:  "IBM Plex Sans","Segoe UI",system-ui,sans-serif;
  --disp:  "Barlow Condensed","Arial Narrow",sans-serif;
}

/* ══════════════════════════════════════════
   RESET
══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html{overflow-x:hidden;background:var(--bg);scrollbar-color:var(--gm) var(--bg);scrollbar-width:thin;scroll-behavior:auto}
body{min-height:100svh;overflow-x:hidden;font-family:var(--font);font-size:1rem;line-height:1.65;color:var(--ink);background:var(--bg)}
::-webkit-scrollbar{width:2px;background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gb);border-radius:0}
a{color:inherit;text-decoration:none}
button,input,textarea,select{font:inherit;color:inherit;background:transparent;border:none;outline:none}
img,video{max-width:100%;display:block}
fieldset{border:none}
:focus-visible{outline:1px solid var(--gb);outline-offset:3px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:1rem;top:1rem;z-index:999;background:var(--gb);color:#fff;padding:.5rem 1rem}

/* ══════════════════════════════════════════
   KEYFRAMES
══════════════════════════════════════════ */
@keyframes char-build{
  0%  {opacity:0;transform:translateX(24px) skewX(-6deg)}
  100%{opacity:1;transform:none}
}
@keyframes word-drop{
  0%  {opacity:0;transform:translateY(-72px);filter:blur(8px)}
  55% {filter:blur(0)}
  100%{opacity:1;transform:none;filter:blur(0)}
}
@keyframes cert-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes glow-pulse  {0%,100%{opacity:.35}50%{opacity:.8}}
@keyframes btn-shine   {from{left:-100%}to{left:220%}}
@keyframes scan-move   {0%{top:-1px}100%{top:100%}}
@keyframes pulse-dot   {0%,100%{opacity:.2}50%{opacity:1}}

/* ══════════════════════════════════════════
   HERO ANIMATION — class-triggered
══════════════════════════════════════════ */
/* PS chars hidden until hero-ready */
.ps-char{display:inline-block;opacity:0}
html.hero-ready .ps-char{
  animation:char-build .28s cubic-bezier(.22,1,.36,1) forwards;
}
/* title words hidden until hero-ready */
.wi--drop{opacity:0}
html.hero-ready .wi--drop{
  animation:word-drop .72s cubic-bezier(.22,1,.36,1) both;
  animation-delay:var(--d,.3s);
}
.reduced-motion .ps-char,
.reduced-motion .wi--drop{opacity:1!important;animation:none!important}

/* ══════════════════════════════════════════
   SCROLL REVEAL
══════════════════════════════════════════ */
.rv {opacity:0;transform:translateY(20px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.rv.v{opacity:1;transform:none}
.rv3{opacity:0;transform:translateY(24px);transition:opacity .75s cubic-bezier(.22,1,.36,1),transform .75s cubic-bezier(.22,1,.36,1)}
.rv3.v{opacity:1;transform:none}
.rg>*{opacity:0;transform:translateY(18px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1)}
.rg>*.v{opacity:1;transform:none}
.rg>*:nth-child(1){transition-delay:.04s}
.rg>*:nth-child(2){transition-delay:.11s}
.rg>*:nth-child(3){transition-delay:.18s}
.rg>*:nth-child(4){transition-delay:.25s}
.reduced-motion .rv,.reduced-motion .rv3,.reduced-motion .rg>*{
  opacity:1!important;transform:none!important;transition:none!important
}

/* ══════════════════════════════════════════
   SHARED KICKER
══════════════════════════════════════════ */
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--disp);font-size:.66rem;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;color:var(--gb);
  margin-bottom:.9rem;
}
.kicker::before{content:"";width:24px;height:1px;background:var(--gb);flex-shrink:0}

/* ══════════════════════════════════════════
   HEADER
══════════════════════════════════════════ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  height:54px;
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:2rem;
  padding:0 clamp(1rem,2vw,1.8rem) 0 var(--gap);
  background:transparent;border-bottom:1px solid transparent;
  transition:transform .4s cubic-bezier(.22,1,.36,1),background .25s,border-color .25s;
}
.site-header.scrolled{
  background:rgba(0,0,0,.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom-color:rgba(232,82,28,.14);
  box-shadow:0 1px 0 rgba(232,82,28,.06),0 4px 24px rgba(0,0,0,.9);
}
.site-header.nav-hidden{transform:translateY(-100%)}
.brand{display:flex;align-items:center}
.brand img{height:34px;width:auto;display:block}
.site-nav{display:flex;align-items:center;justify-content:flex-end;gap:clamp(.8rem,2vw,2rem)}
.nav-link{
  font-family:var(--disp);font-size:.76rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:rgba(232,220,200,.36);white-space:nowrap;
  transition:color .14s;position:relative;padding-bottom:2px;
}
.nav-link::after{
  content:"";position:absolute;bottom:-2px;left:0;right:0;
  height:1px;background:var(--gb);
  transform:scaleX(0);transform-origin:left;
  transition:transform .2s cubic-bezier(.22,1,.36,1);
}
.nav-link:hover{color:var(--ink)}
.nav-link:hover::after,.nav-link[aria-current]::after{transform:scaleX(1)}
.nav-link[aria-current]{color:rgba(232,220,200,.72)}
.nav-cta{
  display:inline-flex;align-items:center;
  padding:.28rem .85rem;
  font-family:var(--disp);font-size:.72rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;white-space:nowrap;
  border:1px solid rgba(232,82,28,.34);color:var(--gb);
  transition:background .14s,color .14s,border-color .14s;
}
.nav-cta:hover{background:var(--gb);color:#fff;border-color:var(--gb)}
.nav-toggle{display:none;flex-direction:column;gap:5px;width:26px;cursor:pointer;padding:3px;flex-shrink:0}
.nav-toggle span{display:block;height:1px;background:var(--ink);transition:all .24s}

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.hero-btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.42rem;position:relative;overflow:hidden;
  font-family:var(--disp);font-size:.78rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  padding:.58rem 1.45rem;cursor:pointer;border-radius:0;
  transition:transform .12s,box-shadow .16s,background .14s,border-color .14s,color .14s;
  white-space:nowrap;
}
.hero-btn span{position:relative;z-index:1}
.hero-btn svg{position:relative;z-index:1;flex-shrink:0}
.hero-btn::before{
  content:"";position:absolute;top:0;left:-100%;width:55%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.06),transparent);
}
.hero-btn:hover::before{animation:btn-shine .44s ease forwards}
.hero-btn:active{transform:scale(.97)}
.hero-btn--solid{
  background:var(--gb);color:#fff;border:1px solid var(--gb);
  box-shadow:0 2px 16px rgba(232,82,28,.3);
}
.hero-btn--solid:hover{
  background:var(--gl);border-color:var(--gl);
  box-shadow:0 4px 24px rgba(232,82,28,.46);transform:translateY(-1px);
}
.hero-btn--ghost{
  background:transparent;color:var(--ink);border:1px solid var(--line3);
}
.hero-btn--ghost:hover{
  border-color:var(--gb);color:var(--gb);background:var(--gd2);transform:translateY(-1px);
}

/* text link button — arrow style */
.text-link{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--disp);font-size:.78rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gb);
  transition:gap .18s,color .14s;
}
.text-link svg{transition:transform .18s}
.text-link:hover{color:var(--gl);gap:.85rem}
.text-link:hover svg{transform:translateX(3px)}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero__video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:0;will-change:transform;
}
.hero__scrim{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    108deg,
    rgba(0,0,0,.97) 0%,
    rgba(0,0,0,.88) 30%,
    rgba(0,0,0,.48) 60%,
    rgba(0,0,0,.10) 100%
  );
}
.hero__scrim2{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.55) 0%,
    transparent 18%,
    transparent 55%,
    rgba(0,0,0,1) 100%
  );
}
.hero__glow{
  position:absolute;z-index:2;pointer-events:none;
  left:0;top:0;width:60%;height:100%;
  background:radial-gradient(ellipse at 14% 52%,rgba(232,82,28,.08) 0%,transparent 52%);
  animation:glow-pulse 9s ease-in-out infinite;
}
.hero__noise{
  position:absolute;inset:0;z-index:2;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity:.5;mix-blend-mode:overlay;
}
.hero__scan{
  position:absolute;left:0;right:0;height:1px;z-index:5;pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(232,82,28,.5),transparent);
  animation:scan-move 10s linear infinite;opacity:.28;
}

/* PHANTOM SYSTEMS — right wall, two stacked words, sequential char build */
.hero__ps-band{
  position:absolute;
  right:0;
  bottom:clamp(4rem,10vh,9rem);
  z-index:3;pointer-events:none;
  display:flex;flex-direction:column;align-items:flex-end;
  gap:.02em;
  padding-right:clamp(.5rem,1vw,2rem);
}
.hero__ps-line{
  display:flex;justify-content:flex-end;line-height:.8;
}
.hero__ps-text{
  font-family:var(--disp);
  font-size:clamp(7rem,13vw,19rem);
  font-weight:900;
  letter-spacing:.04em;
  text-transform:uppercase;
  /* stroke style — same visual language as SUPPLY */
  -webkit-text-stroke:2px rgba(232,82,28,.78);
  color:transparent;
  line-height:.8;
  filter:drop-shadow(0 0 60px rgba(232,82,28,.1));
}

/* HERO CONTENT — left, vertically centered by parent flex */
.hero__content{
  position:relative;z-index:4;
  padding-left:clamp(2rem,5vw,7rem);
  display:flex;flex-direction:column;align-items:flex-start;
  max-width:58%;
}

/* EYEBROW — wide rule that extends past title width */
.hero__eyebrow-wrap{
  display:flex;align-items:center;
  width:calc(100% + clamp(3rem,6vw,8rem)); /* bleeds past content box */
  margin-bottom:1.8rem;
  gap:14px;
}
.hero__eyebrow-line{
  width:44px;height:1px;background:var(--gb);flex-shrink:0;
}
.hero__eyebrow-text{
  font-family:var(--disp);font-size:1.05rem;font-weight:700;
  letter-spacing:.26em;text-transform:uppercase;color:var(--gb);
  white-space:nowrap;
}
.hero__eyebrow-tail{
  flex:1;height:1px;
  background:linear-gradient(90deg,rgba(232,82,28,.5),rgba(232,82,28,.05));
}

/* TITLE */
.hero__title{
  font-family:var(--disp);
  font-size:clamp(5.5rem,9.5vw,12rem);
  font-weight:900;text-transform:uppercase;
  line-height:.8;letter-spacing:-.02em;
  margin-bottom:2.8rem;
  align-self:stretch;
}
.wi{display:block;line-height:.82}
.wi--white{color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.95)}
.wi--accent{
  color:var(--gb);
  text-shadow:0 2px 0 rgba(60,8,0,.9),0 0 40px rgba(232,82,28,.18);
}
.wi--stroke{
  -webkit-text-stroke:2px rgba(232,220,200,.17);
  color:transparent;
}

/* HERO BUTTONS */
.hero__btns{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:1.8rem;align-items:center}

/* hero cred pills */
.hero__creds{display:flex;align-items:center;flex-wrap:wrap;gap:.2rem .4rem}
.hero__cred-pill{
  font-family:var(--disp);font-size:.58rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:rgba(232,82,28,.48);
}
.hero__cred-sep{color:rgba(232,82,28,.2);font-size:.46rem}

/* scroll indicator */
.hero__scroll{
  position:absolute;bottom:2.2rem;left:clamp(2rem,5vw,7rem);z-index:4;
  display:flex;align-items:center;gap:.7rem;
}
.hero__scroll-label{
  font-family:var(--disp);font-size:.5rem;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;color:var(--soft);
}
.hero__scroll-line{
  width:42px;height:1px;transform-origin:left;
  background:linear-gradient(90deg,var(--gb),transparent);
  animation:pulse-dot 2.4s ease-in-out infinite;
}

/* ══════════════════════════════════════════
   CAP STRIP
══════════════════════════════════════════ */
.cap-strip{
  width:100%;background:var(--bg2);
  border-top:1px solid var(--gb);
  border-bottom:1px solid rgba(232,82,28,.08);
  padding:.7rem var(--gap);
}
.cap-strip__inner{
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:center;gap:.26rem .7rem;
}
.cap-item{
  font-family:var(--disp);font-size:.7rem;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--dim);white-space:nowrap;transition:color .13s;
}
.cap-item:hover{color:var(--ink)}
.cap-item--accent{color:var(--gb)}
.cap-sep{font-size:.32rem;color:rgba(232,82,28,.36);flex-shrink:0}

/* ══════════════════════════════════════════
   INTEL STRIP — compact stat bar
══════════════════════════════════════════ */
/* ══════════════════════════════════════════
   INTEL STRIP — 4 stats, horizontal bar
══════════════════════════════════════════ */
.intel-strip{
  background:var(--bg);
  border-top:2px solid var(--gb);
  border-bottom:1px solid rgba(232,82,28,.1);
}
.intel-strip__inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:stretch;
}
.ist{
  flex:1;text-align:center;
  padding:clamp(2rem,3.5vw,3.5rem) clamp(1rem,2vw,2rem);
  border-right:1px solid rgba(232,82,28,.1);
  transition:background .18s;position:relative;
}
.ist:last-child{border-right:none}
.ist:hover{background:rgba(232,82,28,.03)}
.ist__n{
  font-family:var(--disp);
  font-size:clamp(2.8rem,5vw,5.5rem);
  font-weight:900;line-height:.85;letter-spacing:-.02em;
  color:var(--ink);display:block;margin-bottom:.4rem;
}
.ist__n sup{font-size:.4em;color:var(--gb);vertical-align:super;line-height:0}
.ist__l{
  font-family:var(--disp);font-size:.64rem;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;color:var(--gb);
  display:block;margin-bottom:.12rem;
}
.ist__s{
  font-family:var(--font);font-size:.58rem;font-weight:300;
  color:var(--soft);display:block;
}

/* ══════════════════════════════════════════
   OPS ROWS — full-width service rows
══════════════════════════════════════════ */
.ops-rows{
  background:var(--bg2);
  border-bottom:1px solid rgba(232,82,28,.08);
  padding:clamp(5rem,9vw,9rem) var(--gap);
}
.ops-rows__inner{max-width:var(--max);margin:0 auto}
.ops-rows__head{
  display:grid;grid-template-columns:1fr auto;
  align-items:end;gap:2rem;
  border-bottom:1px solid rgba(232,82,28,.12);
  padding-bottom:clamp(1.5rem,2.5vw,2.5rem);
  margin-bottom:0;
}
.ops-rows__h2{
  font-family:var(--disp);
  font-size:clamp(3rem,6.5vw,7rem);
  font-weight:900;text-transform:uppercase;
  line-height:.8;letter-spacing:-.02em;color:var(--ink);
  margin-top:.5rem;
}
.ops-rows__h2 em{font-style:normal;color:var(--gb)}
.ops-rows__intro{
  font-family:var(--font);font-size:.8rem;font-weight:300;
  color:var(--dim);line-height:1.88;max-width:28ch;
  text-align:right;
}
.ops-row{
  display:grid;
  grid-template-columns:clamp(8rem,14vw,14rem) 1fr clamp(8rem,16vw,18rem);
  align-items:center;gap:clamp(2rem,4vw,5rem);
  padding:clamp(1.8rem,3vw,3rem) 0;
  border-bottom:1px solid rgba(232,82,28,.08);
  position:relative;overflow:hidden;
  transition:background .15s;
  cursor:default;
}
.ops-row:hover{background:rgba(232,82,28,.02)}
.ops-row::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,var(--gb),rgba(232,82,28,.1),transparent);
  transform:scaleX(0);transform-origin:left;
  transition:transform .44s cubic-bezier(.22,1,.36,1);
}
.ops-row:hover::after{transform:scaleX(1)}
.ops-row__num{
  font-family:var(--disp);
  font-size:clamp(3.5rem,6vw,6.5rem);
  font-weight:900;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(232,82,28,.22);
  letter-spacing:-.02em;
  transition:-webkit-text-stroke-color .22s;
}
.ops-row:hover .ops-row__num{-webkit-text-stroke-color:rgba(232,82,28,.7)}
.ops-row__mid h3{
  font-family:var(--disp);font-size:clamp(1.3rem,2.2vw,2rem);
  font-weight:800;text-transform:uppercase;letter-spacing:.04em;
  line-height:1;margin-bottom:.55rem;
}
.ops-row__mid p{
  font-family:var(--font);font-size:.79rem;font-weight:300;
  color:var(--dim);line-height:1.88;
}
.ops-row__tag{
  font-family:var(--disp);font-size:.58rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gb);
  text-align:right;
}

/* ══════════════════════════════════════════
   MISSION STMT — full-width centered quote
══════════════════════════════════════════ */
.mission-stmt{
  padding:clamp(7rem,12vw,12rem) var(--gap);
  background:var(--bg);
  border-bottom:1px solid rgba(232,82,28,.08);
  position:relative;
}
.mission-stmt::before{
  content:"";position:absolute;top:0;left:var(--gap);
  width:clamp(40px,6vw,80px);height:2px;background:var(--gb);
}
.mission-stmt__inner{max-width:var(--max);margin:0 auto}
.mission-stmt__quote{
  font-family:var(--disp);
  font-size:clamp(2.2rem,4.5vw,4.2rem);
  font-weight:700;line-height:1.24;
  color:var(--ink);margin-bottom:3rem;
  font-style:normal;max-width:900px;
}
.mission-stmt__quote em{font-style:normal;color:var(--gb)}

/* ══════════════════════════════════════════
   RFQ SECTION
══════════════════════════════════════════ */
.rfq-section{
  padding:clamp(5.5rem,9vw,9rem) var(--gap);
  background:var(--bg2);
  border-bottom:1px solid rgba(232,82,28,.08);
  position:relative;overflow:hidden;
}
.rfq-section::after{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,82,28,.48),transparent);
}
.rfq-section__inner{position:relative;z-index:1;max-width:900px;margin:0 auto}
.rfq-header{margin-bottom:clamp(2.5rem,4vw,4rem)}
.rfq-header h2{
  font-family:var(--disp);font-size:clamp(2rem,3.8vw,3rem);
  font-weight:900;text-transform:uppercase;
  line-height:.84;margin-bottom:1rem;letter-spacing:-.01em;
}
.rfq-header__desc{
  font-family:var(--font);font-size:.84rem;font-weight:300;
  color:var(--dim);line-height:1.92;max-width:52ch;margin-bottom:1rem;
}
.rfq-restrict{
  display:flex;align-items:flex-start;gap:.5rem;
  font-family:var(--font);font-size:.7rem;font-weight:300;
  line-height:1.68;color:rgba(232,82,28,.7);
  background:rgba(232,82,28,.04);border-left:2px solid var(--gb);
  padding:.58rem .8rem;max-width:54ch;
}
.rfq-restrict svg{flex-shrink:0;margin-top:.04rem;color:var(--gb)}

/* form */
.rfq-form{display:flex;flex-direction:column;gap:1px;background:rgba(232,82,28,.1)}
.rfq-panel{border:none;background:var(--bg);overflow:hidden}
.rfq-panel__head{
  padding:.68rem 1.1rem;
  border-bottom:1px solid rgba(232,82,28,.08);
  background:rgba(232,82,28,.03);
  font-family:var(--disp);font-size:.6rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gb);
  display:flex;align-items:center;gap:.44rem;
}
.rfq-panel__head::before{content:"";width:4px;height:4px;background:var(--gb);flex-shrink:0}
.rfq-panel__opt{font-family:var(--font);font-weight:300;font-size:.58rem;text-transform:none;letter-spacing:.02em;color:var(--mute);margin-left:.18rem}
.rfq-panel__body{padding:1.2rem 1.1rem;display:flex;flex-direction:column;gap:.95rem}
.rfq-submit-panel{
  border:none;background:var(--bg);
  padding:1.2rem 1.1rem;display:flex;flex-direction:column;gap:.95rem;
  border-top:1px solid rgba(232,82,28,.1);
}
.fl-row{display:grid;grid-template-columns:1fr 1fr;gap:.95rem}
.fl{display:flex;flex-direction:column;gap:.28rem}
.fl--full{grid-column:1/-1}
.fl__label{font-family:var(--disp);font-size:.58rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--soft)}
.fl__opt{font-family:var(--font);font-weight:300;font-size:.58rem;letter-spacing:.02em;text-transform:none;color:var(--mute);margin-left:.18rem}
.fl input,.fl select,.fl textarea{
  padding:.65rem .85rem;background:rgba(10,10,10,.95);border:1px solid rgba(232,82,28,.18);
  color:var(--ink);font-family:var(--font);font-size:.83rem;font-weight:300;
  border-radius:0;transition:border-color .14s,background .14s,box-shadow .14s;
}
.fl input::placeholder,.fl textarea::placeholder{color:var(--soft);font-weight:300}
.fl input:focus,.fl select:focus,.fl textarea:focus{
  border-color:var(--gb);background:rgba(0,0,0,1);
  box-shadow:0 0 0 2px rgba(232,82,28,.07);outline:none;
}
.fl input.err,.fl select.err,.fl textarea.err{border-color:var(--gb);background:rgba(232,82,28,.04)}
.fl textarea{min-height:148px;resize:vertical;line-height:1.7}
.fl select option{background:var(--bg3);color:var(--ink)}

.file-upload{display:flex;flex-direction:column;gap:.55rem}
.file-upload__zone{
  border:1px dashed rgba(232,82,28,.18);padding:1.3rem 1rem;text-align:center;cursor:pointer;
  transition:border-color .14s,background .14s;
  position:relative;display:flex;flex-direction:column;align-items:center;gap:.26rem;
}
.file-upload__zone:hover,.file-upload__zone.over{border-color:rgba(232,82,28,.38);background:var(--gd2)}
.file-upload__zone input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.file-upload__icon{color:var(--soft)}
.file-upload__text{font-family:var(--font);font-size:.76rem;font-weight:300;color:var(--soft)}
.file-upload__sub{font-family:var(--font);font-size:.63rem;font-weight:300;color:var(--mute)}
.file-list{display:flex;flex-direction:column;gap:.26rem}
.file-item{
  display:flex;align-items:center;gap:.46rem;padding:.34rem .56rem;
  background:rgba(232,82,28,.04);border:1px solid rgba(232,82,28,.14);
}
.file-item__icon{color:var(--soft);flex-shrink:0}
.file-item__name{font-family:var(--font);font-size:.74rem;font-weight:300;color:var(--dim);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.file-item__size{font-family:var(--font);font-size:.63rem;color:var(--mute);flex-shrink:0}
.file-item__remove{font-size:.62rem;color:var(--soft);cursor:pointer;flex-shrink:0;padding:.08rem .24rem;transition:color .12s}
.file-item__remove:hover{color:var(--gb)}
.file-notice{font-family:var(--font);font-size:.65rem;font-weight:300;color:var(--mute);line-height:1.65}

.cage-group{display:flex;flex-direction:column;gap:.44rem}
.cage-input-wrap{overflow:hidden;transition:max-height .25s,opacity .25s}
.cage-input-wrap.hidden{max-height:0;opacity:0;pointer-events:none}
.cage-input-wrap.visible{max-height:80px;opacity:1}
.co-wrap{position:relative}
.co-list{
  position:absolute;top:calc(100% + 2px);left:0;right:0;
  background:var(--bg3);border:1px solid rgba(232,82,28,.18);
  z-index:50;display:none;flex-direction:column;
  max-height:185px;overflow-y:auto;
  box-shadow:0 8px 28px rgba(0,0,0,.9);
}
.co-list.open{display:flex}
.co-list button{
  padding:.46rem .84rem;text-align:left;
  font-family:var(--font);font-size:.79rem;font-weight:300;
  color:var(--dim);transition:background .11s;
}
.co-list button:hover{background:var(--gd);color:var(--ink)}
.fl--ack{
  display:flex;flex-direction:row;align-items:flex-start;
  gap:.52rem;cursor:pointer;
  font-family:var(--font);font-size:.72rem;font-weight:300;
  color:var(--dim);line-height:1.68;
}
.fl--ack input[type="checkbox"]{width:13px;height:13px;flex-shrink:0;margin-top:.2rem;accent-color:var(--gb)}
.fl--ack.err{color:rgba(232,82,28,.8)}
.rfq-actions{display:flex;gap:.875rem;flex-wrap:wrap}
.rfq-errors{font-family:var(--font);font-size:.72rem;color:rgba(232,82,28,.8);padding:.45rem .65rem;background:rgba(232,82,28,.05);border-left:2px solid var(--gb)}
.rfq-success{
  text-align:center;padding:4.5rem 2rem;
  display:flex;flex-direction:column;align-items:center;gap:1.4rem;
  background:rgba(0,0,0,.65);border:1px solid rgba(232,82,28,.18);
}
.rfq-success__icon{
  width:60px;height:60px;background:rgba(232,82,28,.06);border:1px solid var(--gb);
  display:flex;align-items:center;justify-content:center;color:var(--gb);
}
.rfq-success h3{font-family:var(--disp);font-size:2rem;font-weight:900;text-transform:uppercase}
.rfq-success p{font-family:var(--font);font-weight:300;color:var(--dim);max-width:44ch;line-height:1.9;font-size:.84rem}
.rfq-success__fine{font-size:.67rem;color:var(--soft);max-width:36ch}

/* ══════════════════════════════════════════
   CERT BANNER — with SAM.gov seal wrapper
══════════════════════════════════════════ */
.cert-banner{
  padding:1.2rem 0 1.4rem;
  border-top:1px solid rgba(232,82,28,.08);
  border-bottom:1px solid rgba(232,82,28,.08);
  background:var(--bg2);overflow:hidden;
}
.cert-banner__head{text-align:center;margin-bottom:.85rem;padding:0 var(--gap)}
.cert-banner__track{overflow:hidden;position:relative}
.cert-banner__track::before,.cert-banner__track::after{
  content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.cert-banner__track::before{left:0;background:linear-gradient(90deg,var(--bg2),transparent)}
.cert-banner__track::after {right:0;background:linear-gradient(-90deg,var(--bg2),transparent)}
.cert-banner__inner{display:flex;width:max-content;animation:cert-scroll 30s linear infinite}
.cert-item{
  display:flex;align-items:center;gap:.7rem;
  padding:.4rem 1.3rem;border-right:1px solid rgba(232,82,28,.08);flex-shrink:0;
}
.cert-item__img-wrap{display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cert-item__logo{
  height:28px;width:auto;max-width:72px;
  object-fit:contain;flex-shrink:0;
  opacity:.8;transition:opacity .14s;
  filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));
}
.cert-item__logo--lg{height:38px;max-width:90px}
.cert-item:hover .cert-item__logo{opacity:1}
/* White-bg logos converted to white silhouette for dark bg */
.cert-item__logo--invert{
  filter:brightness(0) invert(1);
  opacity:.65;
}
.cert-item:hover .cert-item__logo--invert{opacity:.9}
.cert-item__text{display:flex;flex-direction:column;gap:.04rem}
.cert-item__name{font-family:var(--disp);font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink);white-space:nowrap}
.cert-item__sub{font-family:var(--font);font-size:.56rem;font-weight:300;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);white-space:nowrap}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
.footer{
  background:var(--bg);
  border-top:1px solid rgba(232,82,28,.18);
  padding:clamp(2.5rem,4vw,3.5rem) var(--gap) 0;
  position:relative;
}
.footer::before{
  content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:680px;max-width:100%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,82,28,.7),transparent);
}
.footer__inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:clamp(1.5rem,3vw,3rem);
  padding-bottom:2rem;
  border-bottom:1px solid rgba(232,82,28,.08);
}
.footer__brand{display:flex;flex-direction:column;gap:.62rem}
.footer__brand-logo{height:14px;width:auto;display:block;object-fit:contain;object-position:left center}
.footer__tagline{font-family:var(--font);font-size:.7rem;font-weight:300;color:var(--soft);line-height:1.78}
.footer__tags{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.06rem}
.footer__tags span{
  font-family:var(--disp);font-size:.53rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  padding:.12rem .36rem;border:1px solid rgba(232,82,28,.1);
  color:var(--soft);cursor:default;transition:border-color .12s,color .12s;
}
.footer__tags span:hover{border-color:rgba(232,82,28,.34);color:rgba(232,82,28,.78)}
.footer__social{display:flex;gap:.32rem;margin-top:.18rem}
.footer__social-btn{
  display:flex;align-items:center;justify-content:center;
  width:25px;height:25px;
  border:1px solid rgba(232,82,28,.1);color:var(--soft);
  transition:border-color .12s,color .12s,background .12s;
}
.footer__social-btn:hover{border-color:rgba(232,82,28,.38);color:var(--gb);background:var(--gd2)}
.footer__col{display:flex;flex-direction:column;gap:.5rem}
.footer__col-head{
  font-family:var(--disp);font-size:.58rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;color:var(--gb);
  padding-bottom:.34rem;border-bottom:1px solid rgba(232,82,28,.1);margin-bottom:.04rem;
}
.footer__col a{
  font-family:var(--font);font-size:.72rem;font-weight:300;color:var(--dim);
  transition:color .12s,padding-left .14s;display:block;
}
.footer__col a:hover{color:var(--ink);padding-left:3px}
.footer__warn{
  font-family:var(--font);font-size:.62rem;font-weight:300;
  color:var(--mute);line-height:1.65;
  border-left:1px solid rgba(232,82,28,.1);padding-left:.46rem;margin-top:.18rem;
}
.footer__bottom{
  max-width:var(--max);margin:0 auto;
  padding:.72rem 0 1.25rem;display:flex;flex-direction:column;gap:.44rem;
}
.footer__divider-line{
  display:flex;align-items:center;gap:2rem;
  padding-bottom:.5rem;border-bottom:1px solid rgba(232,82,28,.08);
}
.footer__divider-line::before,.footer__divider-line::after{
  content:"";flex:1;height:1px;
  background:linear-gradient(90deg,transparent,rgba(232,82,28,.18),transparent);
}
.footer__divider-text{
  font-family:var(--disp);font-size:1rem;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;
  color:rgba(232,82,28,.32);white-space:nowrap;flex-shrink:0;
}
.footer__bottom-row{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.36rem;
}
.footer__copy{font-family:var(--font);font-size:.65rem;font-weight:300;color:rgba(232,220,200,.26)}
.footer__terms{font-family:var(--font);font-size:.65rem;font-weight:300;color:rgba(232,220,200,.26);transition:color .12s}
.footer__terms:hover{color:var(--gb)}

/* ══════════════════════════════════════════
   INNER PAGES
══════════════════════════════════════════ */
.page-hero{max-width:var(--max);margin:0 auto;padding:clamp(7rem,12vw,10rem) var(--gap) clamp(3rem,5vw,4rem)}
.page-hero h1{font-family:var(--disp);font-size:clamp(3rem,6vw,5.5rem);font-weight:900;text-transform:uppercase;line-height:.84;margin-bottom:1.5rem;letter-spacing:-.01em}
.page-hero p{font-family:var(--font);font-size:.9rem;font-weight:300;color:var(--dim);max-width:56ch;line-height:1.92;margin-bottom:1rem}
.detail-grid{
  max-width:var(--max);margin:0 auto;
  padding:0 var(--gap) clamp(5rem,9vw,9rem);
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:rgba(232,82,28,.1);
  border:1px solid rgba(232,82,28,.1);overflow:hidden;
}
.dcard{padding:2.4rem 2rem;background:var(--bg);position:relative;overflow:hidden;transition:background .16s}
.dcard:hover{background:var(--bg2)}
.dcard::after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gb),transparent);transform:scaleX(0);transform-origin:left;transition:transform .34s cubic-bezier(.22,1,.36,1)}
.dcard:hover::after{transform:scaleX(1)}
.dcard__num{display:inline-block;font-family:var(--disp);font-size:.55rem;font-weight:700;letter-spacing:.22em;color:var(--gb);margin-bottom:.9rem;padding:.12rem .42rem;border:1px solid rgba(232,82,28,.22);background:rgba(232,82,28,.05)}
.dcard h2{font-family:var(--disp);font-size:1.18rem;font-weight:800;text-transform:uppercase;margin-bottom:.55rem}
.dcard p{font-family:var(--font);font-size:.8rem;font-weight:300;color:var(--dim);line-height:1.88}

.contact-page{max-width:760px;margin:0 auto;padding:clamp(7rem,12vw,10rem) var(--gap) clamp(5rem,9vw,9rem)}
.contact-page h1{font-family:var(--disp);font-size:clamp(2.5rem,5vw,4.5rem);font-weight:900;text-transform:uppercase;line-height:.86;margin-bottom:1.5rem;letter-spacing:-.01em}
.contact-page p{font-family:var(--font);font-size:.9rem;font-weight:300;color:var(--dim);max-width:54ch;line-height:1.92;margin-bottom:1.5rem}
.contact-email{display:block;font-family:var(--disp);font-size:clamp(1.3rem,3vw,2rem);font-weight:700;color:var(--gb);margin:2rem 0;letter-spacing:.04em;transition:color .12s}
.contact-email:hover{color:var(--ink)}
.page-warning{font-family:var(--font);font-size:.76rem;font-weight:300;color:var(--soft);line-height:1.78;border-left:2px solid rgba(232,82,28,.14);padding-left:.9rem}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1100px){
  .ops-rows__head{grid-template-columns:1fr}
  .ops-rows__intro{text-align:left;max-width:100%}
  .ops-row{grid-template-columns:clamp(5rem,10vw,8rem) 1fr}
  .ops-row__tag{display:none}
  .hero__content{max-width:70%}
  .footer__inner{grid-template-columns:1fr 1fr}
  .detail-grid{grid-template-columns:1fr}
}
@media(max-width:900px){
  .hero__ps-band{display:none}
  .hero__content{max-width:92%}
  .hero__eyebrow-wrap{width:100%}
}
@media(max-width:768px){
  .site-nav{
    display:none;position:fixed;inset:0;top:54px;
    background:rgba(0,0,0,.98);backdrop-filter:blur(16px);
    flex-direction:column;align-items:flex-start;
    padding:2.5rem var(--gap);gap:1.2rem;
    z-index:190;overflow-y:auto;border-top:1px solid rgba(232,82,28,.14);
  }
  .site-nav.open{display:flex}
  .nav-link{font-size:1.3rem;font-weight:700;color:var(--ink);letter-spacing:.1em}
  .nav-link::after{display:none}
  .nav-cta{width:100%;justify-content:center;font-size:.88rem;padding:.64rem 1.4rem}
  .nav-toggle{display:flex}
  .hero__title{font-size:clamp(3.5rem,13vw,7rem)}
  .fl-row{grid-template-columns:1fr}
  .footer__inner{grid-template-columns:1fr}
  .intel-strip__inner{flex-direction:column}
  .ist{border-right:none;border-bottom:1px solid rgba(232,82,28,.08);text-align:left;padding:1.4rem var(--gap)}
  .ist:last-child{border-bottom:none}
  .ops-row{grid-template-columns:3.5rem 1fr;gap:1.2rem}
}
@media(max-width:480px){
  .hero__btns{flex-direction:column;align-items:stretch}
  .hero__btns .hero-btn{width:100%;justify-content:center}
  .cap-strip__inner{justify-content:flex-start}
}
