/* QUIET — operator aesthetic, dialed down
   Same dark palette as Overwatch. Less chrome. Bigger silence.
*/

/* ============ Accessibility primitives (added 2026-05-01) ============ */
/* Skip-to-content link — visible only when keyboard-focused. */
.q-skip{
  position:absolute;top:-100px;left:8px;
  background:#FF5A1F;color:#0A0B0D;
  padding:10px 16px;border-radius:0 0 8px 8px;
  font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.08em;
  text-transform:uppercase;font-weight:600;
  z-index:10000;text-decoration:none;
  transition:top .15s ease;
}
.q-skip:focus{top:0;outline:2px solid #E8E4D8;outline-offset:2px;}

/* Visible focus indicator for keyboard users (no visual change for mouse users). */
*:focus-visible{outline:2px solid #FF5A1F;outline-offset:2px;}

/* Contact form / newsletter inputs — orange underline on focus.
   Replaces inline onfocus/onblur handlers (CFG-6 / FE-7) so a strict
   CSP can drop 'unsafe-inline' from script-src in future. */
.q-input-line{
  background:transparent;border:0;border-bottom:1px solid #3A3A3A;
  padding:8px 0;color:inherit;font-family:inherit;font-size:16px;
  outline:none;transition:border-color .15s ease;
}
.q-input-line:focus,.q-input-line:focus-visible{border-bottom-color:#FF5A1F;outline:none;}

/* Contact-card hover state — replaces inline onmouseover/onmouseout. */
.q-contact-row{transition:background .15s ease;}
.q-contact-row:hover,.q-contact-row:focus-visible{background:#1F1F1F;}

/* Respect user motion preference — disables animations system-wide. */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
}

@import url('/fonts/fonts.css');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --ink:#0A0B0D;
  --ink-2:#111318;
  --ink-3:#16191F;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.14);
  --bone:#E8E4D8;
  --bone-dim:#9A9686;
  --mute:#5E626B;
  --signal:#FF5A1F;
  --signal-2:#FFB199;
  --ok:#6DDC9A;
  --maxw:1320px;
}
html,body{background:var(--ink);color:var(--bone);}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img,svg{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}
.serif{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;}
.mono{font-family:'JetBrains Mono',monospace;letter-spacing:.06em;}

/* ============ Nav ============ */
.q-nav{
  position:sticky;top:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  padding:20px 32px;
  background:rgba(10,11,13,0.78);backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.q-brand{
  display:flex;align-items:center;gap:12px;
  font-family:'JetBrains Mono',monospace;
  font-size:12.5px;letter-spacing:.05em;
}
.q-brand-mark{
  width:24px;height:24px;border-radius:5px;background:var(--signal);
  display:grid;place-items:center;color:var(--ink);
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:13px;
  position:relative;
}
.q-brand-mark::after{
  content:"";position:absolute;inset:2px;border:1px solid rgba(0,0,0,0.18);border-radius:3px;
}
.q-brand-name{color:var(--bone);}
.q-brand-sep{color:var(--mute);}
.q-brand-id{color:var(--bone-dim);}
.q-nav-c{
  display:flex;gap:6px;justify-self:center;
  font-size:13px;
  border:1px solid var(--line);border-radius:999px;padding:4px;background:var(--ink-2);
}
.q-nav-c a{padding:7px 14px;border-radius:999px;color:var(--bone-dim);transition:all .15s;}
.q-nav-c a:hover{color:var(--bone);}
.q-nav-c a.active{background:var(--ink-3);color:var(--bone);box-shadow:inset 0 0 0 1px var(--line-2);}

/* ============ Dropdown nav ============ */
.q-nav-dd{position:relative;padding-bottom:14px;margin-bottom:-14px;}
.q-nav-dd-btn{
  padding:7px 14px;border-radius:999px;color:var(--bone-dim);
  display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  font-family:inherit;font-size:13px;background:none;border:none;
}
.q-nav-dd-btn::after{content:"▾";font-size:9px;opacity:.7;}
.q-nav-dd-btn:hover{color:var(--bone);}
.q-nav-dd.open .q-nav-dd-btn,
.q-nav-dd:hover .q-nav-dd-btn{color:var(--bone);}
.q-nav-dd-panel{
  position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(-4px);
  min-width:280px;
  background:var(--ink-2);
  border:1px solid var(--line-2);
  border-radius:14px;
  padding:10px;
  opacity:0;pointer-events:none;
  transition:opacity .18s,transform .18s;
  box-shadow:0 24px 48px -12px rgba(0,0,0,.6);
  z-index:100;
}
.q-nav-dd:hover .q-nav-dd-panel,
.q-nav-dd.open .q-nav-dd-panel,
.q-nav-dd:focus-within .q-nav-dd-panel{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
.q-nav-dd-panel::before{
  content:"";position:absolute;top:-12px;left:0;right:0;height:12px;
}
.q-nav-dd-panel a{
  display:grid;grid-template-columns:24px 1fr;gap:12px;
  padding:10px 14px;border-radius:8px;
  color:var(--bone-dim);font-size:13.5px;
  align-items:center;line-height:1.3;
}
.q-nav-dd-panel a:hover{background:var(--ink-3);color:var(--bone);}
.q-nav-dd-panel a .num{
  font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--mute);letter-spacing:.08em;
}
.q-nav-dd-panel a:hover .num{color:var(--signal);}
.q-nav-dd-panel-h{
  font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mute);
  padding:8px 14px 4px;
}

/* ============ Mobile nav (hamburger + drawer) ============ */
/* Hidden on desktop. */
.q-nav-toggle{
  display:none;
  background:transparent;border:1px solid var(--line);border-radius:8px;
  width:42px;height:42px;cursor:pointer;
  align-items:center;justify-content:center;
  color:var(--bone);font-family:inherit;
  position:relative;
}
.q-nav-toggle:focus-visible{outline:2px solid var(--signal);outline-offset:2px;}
.q-nav-toggle .bar{
  display:block;width:18px;height:1.5px;background:currentColor;
  position:relative;transition:transform .2s,opacity .2s;
}
.q-nav-toggle .bar::before,
.q-nav-toggle .bar::after{
  content:"";position:absolute;left:0;width:18px;height:1.5px;background:currentColor;
  transition:transform .2s,top .2s;
}
.q-nav-toggle .bar::before{top:-6px;}
.q-nav-toggle .bar::after{top:6px;}
.q-nav-open .q-nav-toggle .bar{background:transparent;}
.q-nav-open .q-nav-toggle .bar::before{top:0;transform:rotate(45deg);}
.q-nav-open .q-nav-toggle .bar::after{top:0;transform:rotate(-45deg);}

/* ============ Solution / Industry page primitives ============ */
.q-sol-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:80px;
  padding:120px 0;border-bottom:1px solid var(--line);
  align-items:start;
}
.q-sol-grid .lede{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:32px;line-height:1.35;color:var(--bone);margin-bottom:32px;
}
.q-sol-grid p{font-size:16.5px;line-height:1.7;color:var(--bone-dim);margin-bottom:18px;}
.q-sol-grid h3{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:28px;line-height:1.2;letter-spacing:-0.015em;
  color:var(--bone);margin:40px 0 14px;
}
.q-sol-grid h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--signal);}
.q-sol-side{
  position:sticky;top:96px;
  border:1px solid var(--line);background:var(--ink-2);border-radius:10px;padding:24px;
}
.q-sol-side h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mute);margin-bottom:14px;
}
.q-sol-side ul{list-style:none;display:grid;gap:10px;}
.q-sol-side ul li{
  padding:10px 0;font-size:14px;color:var(--bone-dim);
  display:grid;grid-template-columns:18px 1fr;gap:10px;line-height:1.4;
  border-bottom:1px dashed var(--line);
}
.q-sol-side ul li:last-child{border-bottom:0;}
.q-sol-side ul li::before{content:"+";color:var(--signal);font-family:'JetBrains Mono',monospace;}
.q-faq{padding:120px 0;border-bottom:1px solid var(--line);}
.q-faq h2{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:-0.03em;
  color:var(--bone);margin-bottom:48px;
}
.q-faq h2 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--signal);}
.q-faq-list{display:grid;gap:0;border-top:1px solid var(--line);}
.q-faq-list details{
  border-bottom:1px solid var(--line);padding:28px 0;
}
.q-faq-list summary{
  cursor:pointer;list-style:none;
  display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;
  font-family:'Space Grotesk',sans-serif;font-weight:500;font-size:22px;
  color:var(--bone);letter-spacing:-0.015em;
}
.q-faq-list summary::-webkit-details-marker{display:none;}
.q-faq-list summary::after{content:"+";font-family:'JetBrains Mono',monospace;color:var(--signal);font-size:24px;}
.q-faq-list details[open] summary::after{content:"−";}
.q-faq-list details p{
  margin-top:18px;color:var(--bone-dim);line-height:1.7;font-size:15.5px;max-width:70ch;
}
.q-cta-strip{
  padding:120px 0;text-align:center;
  background:radial-gradient(800px 400px at 50% 50%,rgba(255,90,31,0.06),transparent 70%);
  border-bottom:1px solid var(--line);
}
.q-cta-strip h2{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(48px,6vw,88px);line-height:1.02;letter-spacing:-0.035em;
  color:var(--bone);max-width:18ch;margin:0 auto 32px;
}
.q-cta-strip h2 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--signal);}
.q-cta-strip p{color:var(--bone-dim);margin-bottom:32px;font-size:17px;}

/* breadcrumb */
.q-crumbs{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);
  padding:24px 0 0;
}
.q-crumbs a{color:var(--bone-dim);}
.q-crumbs a:hover{color:var(--signal);}
.q-crumbs span{margin:0 8px;color:var(--mute);}

@media (max-width:980px){
  .q-nav-dd-panel{display:none;}
  .q-sol-grid{grid-template-columns:1fr;gap:48px;}
  .q-sol-side{position:static;}
}
.q-cta{
  justify-self:end;
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px 8px 10px;border-radius:999px;
  background:var(--bone);color:var(--ink);
  font-size:13px;font-weight:600;
  transition:transform .15s;
}
.q-cta:hover{transform:translateY(-1px);}
.q-cta .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(109,220,154,.18);}

/* ============ Hero — quieter than overwatch, but unmistakably operator ============ */
.q-hero{
  min-height:88vh;
  padding:100px 0 80px;
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.q-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(1200px 600px at 80% 50%, rgba(255,90,31,0.07), transparent 60%),
    radial-gradient(900px 600px at 20% 30%, rgba(255,90,31,0.04), transparent 60%);
  pointer-events:none;
}
.q-hero .wrap{position:relative;z-index:1;width:100%;}
.q-hero-meta{
  display:flex;gap:32px;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--mute);
  padding-bottom:48px;
  border-bottom:1px solid var(--line);
}
.q-hero-meta .live{color:var(--ok);}
.q-hero-meta .live::before{
  content:"●";margin-right:6px;
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.4;}}
.q-hero-grid{
  display:grid;grid-template-columns:1.3fr 1fr;gap:80px;
  padding-top:80px;
  align-items:center;
}
.q-display{
  font-family:'Space Grotesk',sans-serif;
  font-weight:500;
  font-size:clamp(64px,9vw,144px);
  line-height:0.92;
  letter-spacing:-0.04em;
  color:var(--bone);
}
.q-display em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-hero-sub{
  margin-top:36px;
  font-size:18px;line-height:1.55;color:var(--bone-dim);
  max-width:42ch;
}
.q-hero-actions{
  margin-top:40px;
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
}
.q-btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  background:var(--bone);color:var(--ink);
  border-radius:999px;
  font-size:14px;font-weight:600;
  transition:all .2s;
}
.q-btn-primary:hover{background:var(--signal);color:var(--ink);transform:translateY(-1px);}
.q-btn-ghost{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 22px;
  border:1px solid var(--line-2);
  border-radius:999px;
  font-size:14px;color:var(--bone);
  transition:all .2s;
}
.q-btn-ghost:hover{border-color:var(--bone);background:var(--ink-2);}

/* Operator board — node map */
.opboard{
  border:1px solid var(--line);
  border-radius:14px;
  background:var(--ink-2);
  padding:20px;
  position:relative;overflow:hidden;
  width:100%;max-width:560px;justify-self:end;
}
.opboard::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(var(--line) 1px, transparent 1px),
    linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:24px 24px;
  background-position:-1px -1px;
  opacity:.35;pointer-events:none;
}
.opboard-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:14px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;
  color:var(--bone-dim);
  position:relative;
}
.opboard-head .tabs{display:flex;gap:4px;}
.opboard-head .tab{padding:4px 9px;border-radius:4px;border:1px solid var(--line);}
.opboard-head .tab.on{background:var(--ink-3);color:var(--bone);border-color:var(--line-2);}
.opboard-svg{position:relative;aspect-ratio:5/4.1;}
.opboard-foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:14px;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;
  color:var(--bone-dim);
  position:relative;
}
.opboard-foot .blink{
  display:inline-block;width:8px;height:8px;border-radius:50%;
  background:var(--ok);margin-right:8px;
  animation:blink 1.6s ease-in-out infinite;
}
@keyframes blink{
  0%,100%{opacity:1;box-shadow:0 0 0 3px rgba(109,220,154,.2);}
  50%{opacity:.4;box-shadow:0 0 0 0 rgba(109,220,154,0);}
}

/* ============ Section primitives ============ */
.q-section{padding:140px 0;border-bottom:1px solid var(--line);position:relative;}
.q-section-meta{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--signal);
  margin-bottom:32px;
}
.q-section-h{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(48px,6vw,96px);
  line-height:0.96;letter-spacing:-0.03em;
  max-width:14ch;
}
.q-section-h em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-section-sub{
  margin-top:28px;
  font-size:18px;color:var(--bone-dim);
  max-width:54ch;line-height:1.6;
}

/* ============ Services — minimal, operator ============ */
.q-svc-list{display:grid;gap:0;margin-top:80px;}
.q-svc{
  display:grid;grid-template-columns:60px 1fr 1.4fr 80px;
  gap:48px;align-items:center;
  padding:48px 0;
  border-top:1px solid var(--line);
  transition:padding .25s;
}
.q-svc:last-child{border-bottom:1px solid var(--line);}
.q-svc:hover{padding-left:8px;background:rgba(255,255,255,0.012);}
.q-svc-num{
  font-family:'JetBrains Mono',monospace;font-size:13px;
  letter-spacing:.1em;color:var(--mute);
}
.q-svc-name{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(32px,3.4vw,56px);
  letter-spacing:-0.02em;line-height:1;
  color:var(--bone);
}
.q-svc-name em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-svc-desc{
  font-size:16px;color:var(--bone-dim);line-height:1.55;max-width:46ch;
}
.q-svc-arr{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:36px;color:var(--mute);justify-self:end;
  transition:color .2s,transform .2s;
}
.q-svc:hover .q-svc-arr{color:var(--signal);transform:translateX(6px);}

/* ============ Statement (big quiet line) ============ */
.q-statement{
  padding:180px 0;
  text-align:center;
  border-bottom:1px solid var(--line);
  background:radial-gradient(800px 400px at 50% 50%,rgba(255,90,31,0.05),transparent 70%);
}
.q-statement h2{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(48px,7vw,108px);
  line-height:1.05;letter-spacing:-0.035em;
  max-width:18ch;margin:0 auto;
  color:var(--bone);
}
.q-statement h2 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-statement-sub{
  margin-top:36px;
  font-size:16px;color:var(--mute);
  max-width:48ch;margin-left:auto;margin-right:auto;
  font-family:'JetBrains Mono',monospace;
  letter-spacing:.04em;
}

/* ============ Trust strip — three numbers, big ============ */
.q-trust{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.q-trust-cell{
  padding:64px 40px;
  border-right:1px solid var(--line);
}
.q-trust-cell:last-child{border-right:0;}
.q-trust-label{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mute);margin-bottom:18px;
}
.q-trust-num{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(56px,6vw,108px);
  line-height:1;letter-spacing:-0.04em;
  color:var(--bone);
}
.q-trust-num .unit{font-size:0.4em;color:var(--bone-dim);margin-left:8px;}
.q-trust-cap{
  margin-top:12px;font-size:14px;color:var(--bone-dim);max-width:30ch;line-height:1.5;
}

/* ============ Footer ============ */
.q-footer{
  padding:80px 0 36px;
}
.q-footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  margin-bottom:64px;
}
.q-footer-brand-big{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:64px;letter-spacing:-0.04em;line-height:1;
  margin-bottom:18px;color:var(--bone);
}
.q-footer-brand-big span{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-footer-brand p{color:var(--bone-dim);max-width:36ch;font-size:14.5px;line-height:1.55;}
.q-footer h3,.q-footer h5{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--mute);margin-bottom:16px;font-weight:500;
}
.q-footer ul{list-style:none;display:grid;gap:8px;}
.q-footer ul a,.q-footer ul li{color:var(--bone-dim);font-size:14px;}
.q-footer ul a:hover{color:var(--signal);}
.q-footer-bottom{
  padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--mute);
}

/* ============ Page hero (services) ============ */
.q-page-hero{
  padding:100px 0 80px;
  border-bottom:1px solid var(--line);
}
.q-page-hero h1{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(56px,8vw,128px);
  line-height:0.94;letter-spacing:-0.04em;
  max-width:14ch;
  color:var(--bone);
}
.q-page-hero h1 em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-page-hero p{
  margin-top:32px;font-size:18px;color:var(--bone-dim);
  max-width:50ch;line-height:1.55;
}

/* ============ Service detail (services.html) ============ */
.q-detail{padding:120px 0;border-bottom:1px solid var(--line);}
.q-detail-head{
  display:grid;grid-template-columns:60px auto 1fr;align-items:baseline;gap:32px;
  margin-bottom:48px;
}
.q-detail-num{
  font-family:'JetBrains Mono',monospace;
  font-size:13px;letter-spacing:.1em;color:var(--mute);
}
.q-detail-name{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:-0.025em;
  color:var(--bone);
}
.q-detail-name em{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--signal);}
.q-detail-tagline{
  justify-self:end;align-self:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--signal);
}
.q-detail-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:start;
}
.q-detail-lede{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  font-size:24px;line-height:1.4;color:var(--bone);
  margin-bottom:24px;
}
.q-detail-body p{
  font-size:16px;color:var(--bone-dim);line-height:1.65;margin-bottom:14px;
}
.q-detail-list{
  list-style:none;display:grid;gap:0;
  border:1px solid var(--line);border-radius:6px;
  background:var(--ink-2);
}
.q-detail-list li{
  padding:18px 24px;
  display:grid;grid-template-columns:24px 1fr;gap:16px;
  font-size:14.5px;color:var(--bone);line-height:1.5;
  border-bottom:1px solid var(--line);
}
.q-detail-list li:last-child{border-bottom:0;}
.q-detail-list li::before{
  content:"+";font-family:'JetBrains Mono',monospace;
  color:var(--signal);font-weight:600;
}

@media (max-width:980px){
  /* Hamburger replaces the inline rail. */
  .q-nav-toggle{display:inline-flex;}
  .q-nav .q-cta{display:none;}

  /* Drawer: pinned below the header bar, fills the rest of the viewport. */
  .q-nav-c{
    position:fixed;
    top:64px;left:0;right:0;
    max-height:calc(100vh - 64px);
    background:var(--ink);
    border:0;border-top:1px solid var(--line);border-radius:0;
    flex-direction:column;align-items:stretch;justify-self:stretch;
    padding:24px;gap:6px;
    overflow-y:auto;overscroll-behavior:contain;
    z-index:200;
    /* Hidden by default; revealed when header has .q-nav-open. */
    transform:translateY(-100%);
    visibility:hidden;
    transition:transform .25s ease,visibility 0s linear .25s;
    font-size:16px;
  }
  .q-nav-open .q-nav-c{
    transform:translateY(0);
    visibility:visible;
    transition:transform .25s ease,visibility 0s linear 0s;
    display:flex;
  }
  /* Drawer link/button reset for vertical layout. */
  .q-nav-c > a,
  .q-nav-c .q-nav-dd{
    width:100%;
    padding:0;
    border-radius:10px;
  }
  .q-nav-c > a{
    padding:14px 16px;color:var(--bone);
    border-bottom:1px solid var(--line);border-radius:0;
  }
  .q-nav-c > a.active{background:var(--ink-2);box-shadow:none;color:var(--bone);}
  .q-nav-c > a:last-child{border-bottom:0;}

  /* Add a "Take a brief" CTA at the bottom of the drawer (cloned via :after isn't reliable;
     instead, we already include /contact link as the last <a> — keep that prominent). */

  /* Dropdowns become accordions inside the drawer. */
  .q-nav-c .q-nav-dd{
    display:block;padding-bottom:0;margin:0;border-bottom:1px solid var(--line);
  }
  .q-nav-c .q-nav-dd-btn{
    width:100%;justify-content:space-between;
    padding:14px 16px;font-size:16px;color:var(--bone);
    border-radius:0;
  }
  .q-nav-c .q-nav-dd-btn::after{margin-left:auto;font-size:11px;}
  .q-nav-c .q-nav-dd.open .q-nav-dd-btn::after{content:"▴";}
  .q-nav-c .q-nav-dd-panel{
    /* Override the legacy mobile rule (line 262: .q-nav-dd-panel{display:none})
       which was for the old-style desktop dropdowns hidden on small screens.
       Inside the drawer we want them visible (collapsed via max-height). */
    display:block;
    position:static;
    transform:none;
    min-width:0;
    background:var(--ink-2);
    border:0;border-radius:0;
    padding:6px 10px 12px;margin:0;
    opacity:0;
    max-height:0;
    overflow:hidden;
    pointer-events:none;
    transition:opacity .15s,max-height .2s ease;
    box-shadow:none;
  }
  .q-nav-c .q-nav-dd.open .q-nav-dd-panel,
  .q-nav-c .q-nav-dd:hover .q-nav-dd-panel,
  .q-nav-c .q-nav-dd:focus-within .q-nav-dd-panel{
    /* Override the desktop hover/open rule which sets
       transform:translateX(-50%) translateY(0) — that pushes the
       expanded panel off-screen on mobile where the panel is
       position:static inside a narrow drawer. */
    transform:none;
    opacity:1;
    max-height:600px;
    pointer-events:auto;
  }
  .q-nav-c .q-nav-dd-panel::before{display:none;}
  .q-nav-c .q-nav-dd-panel a{padding:12px 14px;font-size:14.5px;}

  /* Existing layout adaptations preserved below. */
  .q-hero-grid{grid-template-columns:1fr;gap:64px;}
  .q-pulse{max-width:320px;justify-self:start;}
  .q-svc{grid-template-columns:auto 1fr;gap:24px;}
  .q-svc-desc,.q-svc-arr{display:none;}
  .q-trust{grid-template-columns:1fr;}
  .q-trust-cell{border-right:0;border-bottom:1px solid var(--line);}
  .q-trust-cell:last-child{border-bottom:0;}
  .q-footer-grid{grid-template-columns:1fr 1fr;}
  .q-detail-head{grid-template-columns:1fr;gap:8px;}
  .q-detail-tagline{justify-self:start;}
  .q-detail-grid{grid-template-columns:1fr;gap:32px;}
}


/* ============ Blog ============ */
.q-blog-index{padding:80px 0 120px;}
.q-blog-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:40px;
  margin-top:48px;
}
.q-blog-card{
  border:1px solid var(--line);background:var(--ink-2);
  border-radius:14px;padding:36px;
  transition:all .25s;
  display:block;
}
.q-blog-card:hover{border-color:var(--line-2);transform:translateY(-2px);}
.q-blog-card .meta{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);margin-bottom:18px;
  display:flex;gap:16px;align-items:center;
}
.q-blog-card .meta .cat{color:var(--signal);}
.q-blog-card h3{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:28px;line-height:1.2;letter-spacing:-0.02em;
  color:var(--bone);margin-bottom:14px;
}
.q-blog-card h3 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--signal);}
.q-blog-card p{color:var(--bone-dim);font-size:15px;line-height:1.55;}
.q-blog-card .arr{
  font-family:'Instrument Serif',serif;font-style:italic;
  color:var(--signal);font-size:24px;margin-top:24px;
}
@media (max-width:880px){.q-blog-grid{grid-template-columns:1fr;}}

/* Article */
.q-art{padding:80px 0 120px;}
.q-art-head{max-width:760px;margin:0 auto 64px;}
.q-art-head .meta{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--mute);margin-bottom:24px;
  display:flex;gap:16px;flex-wrap:wrap;
}
.q-art-head .meta .cat{color:var(--signal);}
.q-art-head h1{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:clamp(40px,5vw,72px);line-height:1.05;letter-spacing:-0.03em;
  color:var(--bone);margin-bottom:20px;
}
.q-art-head h1 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--signal);}
.q-art-head .lede{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:24px;line-height:1.45;color:var(--bone-dim);
}
.q-art-body{max-width:680px;margin:0 auto;}
.q-art-body p{font-size:17px;line-height:1.75;color:var(--bone);margin-bottom:22px;}
.q-art-body h2{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:32px;line-height:1.2;letter-spacing:-0.02em;
  margin:56px 0 18px;color:var(--bone);
}
.q-art-body h2 em{font-family:'Instrument Serif',serif;font-style:italic;color:var(--signal);}
.q-art-body h3{
  font-family:'Space Grotesk',sans-serif;font-weight:500;
  font-size:22px;line-height:1.25;
  margin:36px 0 12px;color:var(--bone);
}
.q-art-body ul{margin:0 0 22px 24px;color:var(--bone);}
.q-art-body ul li{margin-bottom:8px;line-height:1.65;font-size:16.5px;}
.q-art-body strong{color:var(--bone);font-weight:600;}
.q-art-body blockquote{
  border-left:3px solid var(--signal);
  padding:8px 0 8px 24px;margin:32px 0;
  font-family:'Instrument Serif',serif;font-style:italic;font-size:22px;
  color:var(--bone);line-height:1.45;
}
.q-art-body a{color:var(--signal);border-bottom:1px solid rgba(255,90,31,.4);}
.q-art-body a:hover{border-bottom-color:var(--signal);}
.q-art-related{
  max-width:760px;margin:80px auto 0;
  border-top:1px solid var(--line);padding-top:48px;
}
.q-art-related h4{
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--mute);margin-bottom:18px;
}
.q-art-related ul{list-style:none;display:grid;gap:8px;}
.q-art-related ul a{color:var(--bone-dim);font-size:15px;}
.q-art-related ul a:hover{color:var(--signal);}