:root{
  --bg:#0b0b0f;
  --bg-panel:#131318;
  --bg-panel-2:#16161c;
  --bg-input:#0e0e13;
  --border:rgba(255,255,255,.09);
  --border-strong:rgba(255,255,255,.16);
  --text:#f4f4f6;
  --muted:#9a9aa6;
  --faint:#6a6a78;
  --accent:#ed2027;
  --accent-2:#ff3b45;
  --accent-pink:#c8141b;
  --danger:#f87171;
  --success:#34d399;
  --radius:12px;
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --sans:"Inter", system-ui, -apple-system, sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
html,body{height:100%;}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  position:relative;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed; inset:0; z-index:0;
  background-image:radial-gradient(rgba(255,255,255,.04) 1px, transparent 1px);
  background-size:26px 26px;
  mask-image:radial-gradient(ellipse 80% 50% at 50% 0%, #000 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 80% 50% at 50% 0%, #000 30%, transparent 75%);
}
body::after{
  content:"";
  position:fixed; top:-30%; left:50%; transform:translateX(-50%);
  width:70vmax; height:50vmax; z-index:0; pointer-events:none;
  background:radial-gradient(circle, rgba(237,32,39,.20), rgba(255,59,69,.07) 40%, transparent 70%);
  filter:blur(20px);
}
.wrap-x{ max-width:1180px; margin:0 auto; padding:0 24px; position:relative; z-index:1; }
.wrap-n{ max-width:880px; margin:0 auto; padding:0 24px; position:relative; z-index:1; }
a{ color:inherit; }
img{ max-width:100%; display:block; }
ul{ list-style:none; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 22px; font-family:var(--sans); font-size:14.5px; font-weight:600;
  color:#fff; background:linear-gradient(135deg, var(--accent), var(--accent-2));
  border:none; border-radius:9px; cursor:pointer; text-decoration:none;
  transition:filter .16s, transform .1s; box-shadow:0 8px 24px -10px var(--accent);
  white-space:nowrap;
}
.btn:hover{ filter:brightness(1.08); }
.btn:active{ transform:translateY(1px); }
.btn-ghost{
  background:var(--bg-input); color:var(--text);
  border:1px solid var(--border-strong); box-shadow:none;
}
.btn-ghost:hover{ filter:none; background:rgba(255,255,255,.06); }
.btn-sm{ padding:9px 16px; font-size:13.5px; }

/* ---------- nav ---------- */
header.nav{
  position:sticky; top:0; z-index:40;
  background:rgba(11,11,15,.72); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; padding:14px 24px; max-width:1180px; margin:0 auto; gap:18px; }
.brand{ display:flex; align-items:center; gap:9px; text-decoration:none; flex:none; }
.brand-mark{ width:26px; height:26px; flex:none; }
.brand-word{ font-weight:800; font-size:16.5px; letter-spacing:-.3px; }
.nav-links{ display:flex; align-items:center; gap:26px; }
.nav-links a{ font-size:13.5px; color:var(--muted); text-decoration:none; font-weight:500; transition:color .15s; white-space:nowrap; }
.nav-links a:hover, .nav-links a.active{ color:var(--text); }
.nav-cta{ display:flex; align-items:center; gap:10px; flex:none; }
.nav-burger{ display:none; background:none; border:1px solid var(--border-strong); border-radius:8px; width:38px; height:38px; color:var(--text); cursor:pointer; flex:none; }
.mobile-menu{ display:none; flex-direction:column; gap:2px; padding:8px 24px 18px; border-bottom:1px solid var(--border); background:var(--bg); }
.mobile-menu a{ padding:12px 4px; font-size:14.5px; color:var(--muted); text-decoration:none; border-bottom:1px solid var(--border); }
.mobile-menu .btn{ margin-top:12px; }

@media (max-width:980px){
  .nav-links{ display:none; }
  .nav-cta .btn-ghost{ display:none; }
  .nav-burger{ display:block; }
  body.menu-open .mobile-menu{ display:flex; }
}

/* ---------- eyebrow / section heads ---------- */
.eyebrow{
  font-family:var(--mono); font-size:11px; letter-spacing:1.6px; text-transform:uppercase;
  color:var(--accent); margin-bottom:14px; display:flex; align-items:center; gap:8px;
}
.eyebrow::before{ content:""; width:14px; height:1px; background:var(--accent); }
.section{ padding:96px 0; position:relative; z-index:1; }
.section.tight{ padding:64px 0; }
.section-head{ max-width:620px; margin-bottom:52px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head.center .eyebrow{ justify-content:center; }
.section-head h2{ font-size:clamp(26px,3.4vw,36px); font-weight:700; letter-spacing:-.6px; margin-bottom:14px; }
.section-head p{ color:var(--muted); font-size:15.5px; line-height:1.7; }
.alt-bg{ background:var(--bg-panel-2); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }

/* ---------- page header (inner pages) ---------- */
.page-head{ padding:64px 0 56px; position:relative; z-index:1; border-bottom:1px solid var(--border); }
.page-head .crumb{ font-family:var(--mono); font-size:11.5px; color:var(--faint); margin-bottom:16px; }
.page-head .crumb a{ color:var(--faint); text-decoration:none; }
.page-head .crumb a:hover{ color:var(--muted); }
.page-head h1{ font-size:clamp(30px,4.4vw,46px); font-weight:800; letter-spacing:-1.1px; line-height:1.08; max-width:760px; }
.page-head .lead{ color:var(--muted); font-size:16px; line-height:1.7; max-width:620px; margin-top:18px; }

/* ---------- hero ---------- */
.hero{ padding:84px 0 70px; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
@media (max-width:980px){ .hero-grid{ grid-template-columns:1fr; } }
.hero h1{ font-size:clamp(34px,4.6vw,54px); font-weight:800; letter-spacing:-1.4px; line-height:1.07; margin-bottom:20px; }
.hero h1 em{ font-style:normal; color:var(--accent); }
.hero .lead{ color:var(--muted); font-size:16.5px; line-height:1.7; max-width:480px; margin-bottom:30px; }
.hero-actions{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:18px; }
.hero-note{ font-size:12.5px; color:var(--faint); font-family:var(--mono); }

/* ---------- roster mock (signature) ---------- */
.roster-card{
  background:var(--bg-panel); border:1px solid var(--border-strong); border-radius:16px;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset, 0 30px 70px -24px rgba(0,0,0,.85);
  padding:20px 20px 16px; position:relative; overflow:hidden;
}
.roster-card::before{
  content:""; position:absolute; top:-40%; right:-30%; width:60%; height:120%;
  background:radial-gradient(circle, rgba(237,32,39,.16), transparent 70%); pointer-events:none;
}
.roster-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; position:relative; }
.roster-top .rt-left{ display:flex; align-items:center; gap:8px; }
.dot3{ display:flex; gap:5px; }
.dot3 span{ width:7px; height:7px; border-radius:50%; background:var(--border-strong); }
.roster-top .title{ font-size:13px; font-weight:600; }
.roster-top .date{ font-family:var(--mono); font-size:11px; color:var(--accent); }
.roster-rows{ display:flex; flex-direction:column; gap:8px; position:relative; }
.roster-row{
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  background:var(--bg-input); border:1px solid var(--border); border-radius:10px; padding:11px 13px;
}
.roster-row .who{ display:flex; align-items:center; gap:10px; }
.avatar{ width:28px; height:28px; border-radius:8px; background:linear-gradient(135deg,#26262e,#1a1a20); display:grid; place-items:center; font-family:var(--mono); font-size:10.5px; color:var(--muted); flex:none; border:1px solid var(--border); }
.roster-row .nm{ font-size:13px; font-weight:600; }
.roster-row .loc{ font-size:10.5px; color:var(--faint); font-family:var(--mono); }
.pill{ display:inline-flex; align-items:center; gap:6px; padding:5px 10px; border-radius:999px; font-size:11px; font-family:var(--mono); white-space:nowrap; }
.pill.done{ background:rgba(52,211,153,.12); color:var(--success); border:1px solid rgba(52,211,153,.3); }
.pill.wait{ color:var(--faint); border:1px solid var(--border); }
.pill.pulse{ animation:pillpulse 2.6s ease-in-out infinite; }
@keyframes pillpulse{ 0%,100%{ opacity:1;} 50%{ opacity:.45;} }
.roster-foot{ margin-top:14px; display:flex; align-items:center; justify-content:space-between; font-size:11px; color:var(--faint); font-family:var(--mono); }
@media (prefers-reduced-motion: reduce){ .pill.pulse{ animation:none; } }

/* ---------- photo collage (hero) ---------- */
.photo-collage-wrap{ position:relative; }
.photo-collage-wrap::before{
  content:""; position:absolute; top:-15%; right:-15%; width:65%; height:130%;
  background:radial-gradient(circle, rgba(237,32,39,.22), transparent 70%); pointer-events:none; z-index:0;
}
.photo-collage{ position:relative; z-index:1; display:grid; grid-template-columns:1.2fr 1fr; grid-template-rows:1fr 1fr; gap:14px; height:440px; }
.photo-collage .ph{ border-radius:16px; overflow:hidden; border:1px solid var(--border-strong); box-shadow:0 20px 50px -18px rgba(0,0,0,.75); position:relative; }
.photo-collage .ph img{ width:100%; height:100%; object-fit:cover; display:block; }
.photo-collage .ph.main{ grid-row:1 / span 2; }
.photo-collage .ph .cap{ position:absolute; left:12px; bottom:12px; right:12px; font-family:var(--mono); font-size:10.5px; color:#fff; background:rgba(11,11,15,.55); backdrop-filter:blur(4px); border:1px solid rgba(255,255,255,.14); padding:6px 10px; border-radius:8px; }
@media (max-width:560px){ .photo-collage{ height:340px; } }

/* ---------- feature photo panel (with icon chips) ---------- */
.feature-photo{ position:relative; border-radius:18px; overflow:hidden; border:1px solid var(--border-strong); box-shadow:0 30px 70px -24px rgba(0,0,0,.85); aspect-ratio:4/5; }
.feature-photo img{ width:100%; height:100%; object-fit:cover; display:block; }
.feature-photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 35%, rgba(11,11,15,.94) 100%); pointer-events:none; }
.feature-photo .chips{ position:absolute; left:16px; right:16px; bottom:16px; display:flex; flex-direction:column; gap:9px; z-index:2; }
.chip-row{ display:flex; align-items:center; gap:10px; background:rgba(11,11,15,.55); border:1px solid var(--border-strong); backdrop-filter:blur(6px); -webkit-backdrop-filter:blur(6px); padding:9px 12px; border-radius:10px; font-size:12.5px; color:var(--text); }
.chip-row .ico{ width:24px; height:24px; border-radius:7px; background:rgba(237,32,39,.18); border:1px solid rgba(237,32,39,.4); display:grid; place-items:center; color:var(--accent-2); flex:none; }
@media (max-width:560px){ .feature-photo{ aspect-ratio:4/3.4; } }

/* ---------- capability / stats strip ---------- */
.strip{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.strip-item{ background:var(--bg-panel); padding:26px 22px; }
.strip-item .big{ font-family:var(--mono); font-size:25px; font-weight:600; color:var(--accent); margin-bottom:6px; }
.strip-item .lbl{ font-size:12.5px; color:var(--muted); line-height:1.55; }
@media (max-width:860px){ .strip{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .strip{ grid-template-columns:1fr; } }

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

.card{ background:var(--bg-panel); border:1px solid var(--border); border-radius:var(--radius); padding:24px 22px; transition:border-color .15s, transform .15s; }
.card:hover{ border-color:var(--border-strong); transform:translateY(-2px); }
.card .ico{ width:38px; height:38px; border-radius:9px; background:rgba(237,32,39,.1); border:1px solid rgba(237,32,39,.25); display:grid; place-items:center; margin-bottom:16px; color:var(--accent); flex:none; }
.card h3{ font-size:15.5px; font-weight:600; margin-bottom:8px; letter-spacing:-.2px; }
.card p{ font-size:13.5px; color:var(--muted); line-height:1.65; }
.card .tag{ display:inline-block; font-family:var(--mono); font-size:10.5px; color:var(--accent); border:1px solid rgba(237,32,39,.3); background:rgba(237,32,39,.08); padding:3px 9px; border-radius:999px; margin-bottom:14px; }
.card ul.bullets{ margin-top:14px; display:flex; flex-direction:column; gap:9px; }
.card ul.bullets li{ font-size:13px; color:var(--text); display:flex; gap:8px; align-items:flex-start; }
.card ul.bullets li::before{ content:"✓"; color:var(--success); font-weight:700; flex:none; }
.card .more{ display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:13px; font-weight:600; color:var(--text); text-decoration:none; }
.card .more:hover{ color:var(--accent); }

/* ---------- steps ---------- */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media (max-width:860px){ .steps{ grid-template-columns:1fr; } }
.step{ position:relative; background:var(--bg-panel); border:1px solid var(--border); border-radius:var(--radius); padding:28px 22px 24px; }
.step .num{ font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:1px; margin-bottom:14px; }
.step h3{ font-size:16px; font-weight:600; margin-bottom:8px; }
.step p{ font-size:13.5px; color:var(--muted); line-height:1.65; }
.step-arrow{ position:absolute; top:50%; right:-26px; transform:translateY(-50%); color:var(--faint); font-size:18px; }
@media (max-width:860px){ .step-arrow{ display:none; } }

/* ---------- timeline ---------- */
.timeline{ position:relative; padding-left:26px; border-left:1px solid var(--border); display:flex; flex-direction:column; gap:30px; }
.timeline .t-item{ position:relative; }
.timeline .t-item::before{ content:""; position:absolute; left:-31px; top:3px; width:9px; height:9px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px rgba(237,32,39,.18); }
.timeline .yr{ font-family:var(--mono); font-size:12px; color:var(--accent); margin-bottom:6px; }
.timeline h3{ font-size:15.5px; font-weight:600; margin-bottom:6px; }
.timeline p{ font-size:13.5px; color:var(--muted); line-height:1.65; max-width:560px; }

/* ---------- people / office cards ---------- */
.person{ background:var(--bg-panel); border:1px solid var(--border); border-radius:var(--radius); padding:22px; text-align:left; }
.person .pav{ width:52px; height:52px; border-radius:12px; background:linear-gradient(135deg,#26262e,#1a1a20); border:1px solid var(--border-strong); display:grid; place-items:center; font-family:var(--mono); font-size:15px; color:var(--accent); margin-bottom:14px; }
.person h3{ font-size:14.5px; font-weight:600; margin-bottom:3px; }
.person .role{ font-size:12px; color:var(--accent); font-family:var(--mono); margin-bottom:10px; }
.person p{ font-size:13px; color:var(--muted); line-height:1.6; }

.office{ background:var(--bg-panel); border:1px solid var(--border); border-radius:var(--radius); padding:22px; }
.office h3{ font-size:14.5px; font-weight:600; margin-bottom:10px; }
.office p{ font-size:13px; color:var(--muted); line-height:1.7; }
.office a{ color:var(--accent); text-decoration:none; font-size:13px; }

/* ---------- terminal / security block ---------- */
.term{
  background:var(--bg-input); border:1px solid var(--border-strong); border-radius:var(--radius);
  font-family:var(--mono); font-size:12.5px; line-height:2; padding:22px 22px 20px; color:var(--muted);
  box-shadow:0 24px 60px -24px rgba(0,0,0,.8);
}
.term .term-bar{ display:flex; gap:6px; margin-bottom:14px; }
.term .term-bar span{ width:9px; height:9px; border-radius:50%; background:var(--border-strong); }
.term .ln{ white-space:pre-wrap; word-break:break-word; }
.term .k{ color:var(--accent-2); }
.term .v{ color:var(--success); }

/* ---------- checklist ---------- */
.sec-list{ display:flex; flex-direction:column; gap:18px; }
.sec-list li{ display:flex; gap:14px; align-items:flex-start; font-size:14px; }
.sec-list .chk{ flex:none; width:20px; height:20px; border-radius:6px; background:rgba(52,211,153,.12); border:1px solid rgba(52,211,153,.3); display:grid; place-items:center; color:var(--success); margin-top:1px; font-size:11px; }
.sec-list b{ display:block; margin-bottom:3px; }
.sec-list span{ color:var(--muted); font-size:13.5px; line-height:1.6; }

/* ---------- quote ---------- */
.quote-card{ max-width:760px; margin:0 auto; text-align:center; background:var(--bg-panel); border:1px solid var(--border); border-radius:18px; padding:52px 44px; }
.quote-card blockquote{ font-size:clamp(18px,2.4vw,23px); font-weight:600; letter-spacing:-.3px; line-height:1.55; margin-bottom:26px; }
.quote-card cite{ font-style:normal; font-size:13.5px; color:var(--muted); }
.quote-card cite b{ color:var(--text); }
.quote-mark{ font-family:var(--mono); font-size:40px; color:var(--accent); line-height:1; margin-bottom:8px; }

/* ---------- faq ---------- */
.faq{ max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px; }
.faq details{ background:var(--bg-panel); border:1px solid var(--border); border-radius:12px; padding:18px 20px; }
.faq summary{ cursor:pointer; list-style:none; font-size:14.5px; font-weight:600; display:flex; justify-content:space-between; align-items:center; gap:14px; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--mono); font-size:18px; color:var(--accent); flex:none; transition:transform .2s; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq p{ margin-top:12px; font-size:13.5px; color:var(--muted); line-height:1.7; }

/* ---------- final cta band ---------- */
.cta-band{ position:relative; border-radius:22px; overflow:hidden; padding:60px 40px; text-align:center; background:var(--bg-panel); border:1px solid var(--border-strong); }
.cta-band::after{ content:""; position:absolute; inset:0; background:radial-gradient(ellipse 70% 100% at 50% 0%, rgba(237,32,39,.25), transparent 65%); pointer-events:none; }
.cta-band h2{ position:relative; font-size:clamp(24px,3.2vw,32px); font-weight:700; letter-spacing:-.6px; margin-bottom:12px; }
.cta-band p{ position:relative; color:var(--muted); font-size:15px; margin-bottom:28px; max-width:520px; margin-left:auto; margin-right:auto; }
.cta-band .hero-actions{ position:relative; justify-content:center; }
.cta-split{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:760px){ .cta-split{ grid-template-columns:1fr; } }

/* ---------- forms ---------- */
.form-card{ background:var(--bg-panel); border:1px solid var(--border); border-radius:var(--radius); padding:30px; }
.field{ margin-bottom:16px; }
.field label{ display:block; font-size:12.5px; font-weight:500; color:var(--muted); margin-bottom:7px; }
.field input, .field select, .field textarea{
  width:100%; padding:12px 14px; font-family:var(--sans); font-size:14.5px; color:var(--text);
  background:var(--bg-input); border:1px solid var(--border); border-radius:9px;
  transition:border-color .16s, box-shadow .16s;
}
.field textarea{ resize:vertical; min-height:110px; }
.field input::placeholder, .field textarea::placeholder{ color:var(--faint); }
.field input:focus, .field select:focus, .field textarea:focus{
  outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(237,32,39,.18);
}
.row2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
@media (max-width:480px){ .row2{ grid-template-columns:1fr; } }
.form-msg{ display:none; font-size:13px; padding:10px 13px; border-radius:9px; margin-bottom:18px; line-height:1.55; }
.form-msg.show{ display:block; background:rgba(52,211,153,.1); color:var(--success); border:1px solid rgba(52,211,153,.28); }

/* ---------- footer ---------- */
footer{ border-top:1px solid var(--border); padding:60px 0 30px; position:relative; z-index:1; }
.foot-top{ display:grid; grid-template-columns:1.4fr repeat(4,1fr); gap:36px; margin-bottom:50px; }
@media (max-width:900px){ .foot-top{ grid-template-columns:1fr 1fr; } }
.foot-brand .brand{ margin-bottom:14px; }
.foot-brand p{ font-size:13px; color:var(--muted); max-width:240px; line-height:1.6; }
.foot-col h4{ font-size:12px; text-transform:uppercase; letter-spacing:1px; color:var(--faint); margin-bottom:16px; font-family:var(--mono); font-weight:500; }
.foot-col ul{ display:flex; flex-direction:column; gap:11px; }
.foot-col a{ font-size:13.5px; color:var(--muted); text-decoration:none; }
.foot-col a:hover{ color:var(--text); }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; padding-top:26px; border-top:1px solid var(--border); }
.foot-bottom span{ font-size:12.5px; color:var(--faint); font-family:var(--mono); }

/* ---------- misc ---------- */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
.reveal.show{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center; }
@media (max-width:900px){ .split{ grid-template-columns:1fr; } }

.badge-row{ display:flex; flex-wrap:wrap; gap:10px; }
.badge{ font-family:var(--mono); font-size:11.5px; color:var(--muted); border:1px solid var(--border-strong); padding:7px 13px; border-radius:999px; background:var(--bg-input); }

.imgblock{ border-radius:16px; overflow:hidden; border:1px solid var(--border-strong); aspect-ratio:4/3; }
.imgblock img{ width:100%; height:100%; object-fit:cover; }
