/* === AVBOOST Agency · site.css ===================================================
   Shared stylesheet for all pages. Tokens lifted directly from AVTrade Design System.
   Palette: dark navy + silver · No chromatic accents.
   ================================================================================ */

@import url("https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600&display=swap");

@font-face { font-family:"Grift"; font-weight:100; font-style:normal; font-display:swap; src:url("fonts/grift-thin.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:300; font-style:normal; font-display:swap; src:url("fonts/grift-light.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:400; font-style:normal; font-display:swap; src:url("fonts/grift-regular.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:400; font-style:italic; font-display:swap; src:url("fonts/grift-italic.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:500; font-style:normal; font-display:swap; src:url("fonts/grift-medium.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:600; font-style:normal; font-display:swap; src:url("fonts/grift-semibold.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:600; font-style:italic; font-display:swap; src:url("fonts/grift-semibolditalic.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:700; font-style:normal; font-display:swap; src:url("fonts/grift-bold.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:800; font-style:normal; font-display:swap; src:url("fonts/grift-extrabold.otf") format("opentype"); }
@font-face { font-family:"Grift"; font-weight:900; font-style:normal; font-display:swap; src:url("fonts/grift-black.otf") format("opentype"); }

/* ── Tokens ─────────────────────────────────────────────────── */
:root {
  --bg-0:#05070d; --bg-1:#0a0f1c; --bg-2:#0f1729; --bg-3:#15244a;
  --navy-deep:#070d1c; --navy-900:#0a1740; --navy-800:#0d1a36;
  --navy-700:#15244a; --navy-600:#1a2647; --navy-500:#2a3656; --navy-400:#3b4a6e;
  --silver-0:#f4f6fa; --silver-1:#cfd6e2; --silver-2:#8b94a6;
  --silver-3:#6e7a8e; --silver-blue:#a9b8d4; --accent:#dfe6f2;
  --line:rgba(207,214,226,.12); --line-strong:rgba(207,214,226,.22); --line-bright:rgba(207,214,226,.45);
  --ok:#9be3b1; --ok-glow:rgba(155,227,177,.6); --warn:#e5b557; --danger:#ff8a8a;
  --grad-page:
    radial-gradient(1200px 800px at 70% -10%,#15244a 0%,transparent 60%),
    radial-gradient(900px 700px at 10% 20%,#0a1740 0%,transparent 55%),
    linear-gradient(180deg,#05070d 0%,#060a16 35%,#05070d 100%);
  --grad-card:linear-gradient(180deg,rgba(15,23,41,.6),rgba(7,13,28,.8));
  --grad-card-hover:linear-gradient(180deg,rgba(25,35,60,.8),rgba(12,20,40,.9));
  --grad-feature:
    radial-gradient(800px 400px at 90% 20%,rgba(40,70,130,.25),transparent 60%),
    linear-gradient(180deg,rgba(15,23,41,.6),rgba(7,13,28,.7));
  --grad-silver:linear-gradient(180deg,#f4f6fa 0%,#cfd6e2 60%,#8b94a6 100%);
  --grad-text-primary:linear-gradient(180deg,#ffffff 0%,#cfd6e2 45%,#6b7385 100%);
  --grad-text-muted:linear-gradient(180deg,#fff,#8b94a6);
  --grad-text-blue:linear-gradient(180deg,#a9b8d4,#3b4a6e);
  --grad-orb:conic-gradient(from 220deg,#f4f6fa,#8b94a6 30%,#1a2647 55%,#f4f6fa 80%,#cfd6e2);
  --shadow-sm:0 6px 18px rgba(0,0,0,.5);
  --shadow-md:0 8px 28px rgba(180,200,235,.20),inset 0 1px 0 rgba(255,255,255,.7);
  --shadow-lg:0 30px 60px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.04);
  --shadow-orb:0 40px 120px rgba(80,120,200,.25),inset 0 -40px 120px rgba(0,0,0,.6),inset 0 30px 60px rgba(255,255,255,.1);
  --shadow-silver-hover:0 10px 36px rgba(180,200,235,.35),inset 0 1px 0 rgba(255,255,255,.9);
  --r-xs:6px; --r-sm:8px; --r-md:10px; --r-lg:14px; --r-xl:18px; --r-2xl:24px; --r-pill:999px;
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px; --s-7:48px; --s-8:64px; --s-9:96px; --s-10:120px;
  --font-sans:"Grift",system-ui,-apple-system,"Helvetica Neue",sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,"SF Mono",monospace;
  --fs-display:clamp(56px,7.5vw,112px);
  --fs-h1:clamp(44px,6vw,84px);
  --fs-h2:clamp(30px,4vw,52px);
  --fs-h3:32px; --fs-h4:22px; --fs-lede:18px; --fs-body:15px;
  --fs-small:14px; --fs-meta:13px; --fs-caption:12px;
  --fs-mono-sm:11px; --fs-mono-xs:10px;
  --lh-tight:.96; --lh-snug:1.05; --lh-body:1.55; --lh-prose:1.75;
  --tracking-display:-.03em; --tracking-h:-.02em;
  --tracking-mono:.04em; --tracking-eyebrow:.18em; --tracking-label:.18em;
}

/* ── Reset ───────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html,body {
  background:var(--bg-0); color:var(--silver-1);
  font-family:var(--font-sans); -webkit-font-smoothing:antialiased;
}
html { overflow-x: hidden; }
body { overflow-x: hidden; }
a { color:inherit; text-decoration:none; }
button { font-family:inherit; cursor:pointer; border:none; background:none; }
input,textarea,select { font-family:inherit; }

/* ── Background layers ───────────────────────────────────────── */
.bg-field { position:fixed; inset:0; z-index:-3; background:var(--grad-page); }
.bg-grid {
  position:fixed; inset:0; z-index:-2; opacity:.32;
  background-image:
    linear-gradient(to right,rgba(207,214,226,.05) 1px,transparent 1px),
    linear-gradient(to bottom,rgba(207,214,226,.05) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse at 50% 25%,#000 20%,transparent 72%);
}
.bg-noise {
  position:fixed; inset:0; z-index:-1; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/%3E%3C/svg%3E");
}

/* ── Layout ──────────────────────────────────────────────────── */
.wrap { max-width:1280px; margin:0 auto; padding:0 32px; }
.section { padding:var(--s-10) 0; }
.section-sm { padding:var(--s-8) 0; }
.section-border { border-top:1px solid var(--line); }

/* ── Navigation ──────────────────────────────────────────────── */
.site-nav {
  position:sticky; top:0; z-index:100;
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  background:rgba(5,7,13,.65); border-bottom:1px solid var(--line);
  transition:background 0.25s ease, box-shadow 0.25s ease;
}
.site-nav.nav-scrolled {
  background:rgba(5,7,13,.88);
  box-shadow:0 1px 0 rgba(207,214,226,.08), 0 4px 24px rgba(0,0,0,.35);
}
.site-nav.nav-open {
  z-index:101;
}
.nav-row {
  display:flex; align-items:center; justify-content:space-between;
  height:72px; gap:32px;
}
.nav-brand {
  display:flex; align-items:center; gap:11px;
  font-weight:600; letter-spacing:-.02em; font-size:17px;
  color:var(--silver-0); flex-shrink:0;
}
.nav-orb {
  width:28px; height:28px; border-radius:50%;
  background:var(--grad-orb);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.25),0 4px 16px rgba(120,150,200,.25);
  position:relative; flex-shrink:0;
}
.nav-orb::after {
  content:""; position:absolute; inset:22%; border-radius:50%;
  background:radial-gradient(circle at 35% 35%,rgba(255,255,255,.6),transparent 55%);
  mix-blend-mode:screen;
}
.nav-wordmark b { font-weight:800; }
.nav-wordmark .dot { color:var(--silver-3); margin:0 2px; }
.nav-wordmark .sub { font-weight:400; font-size:13px; color:var(--silver-2); letter-spacing:0; }
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-links a {
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--silver-2); padding:8px 14px; border-radius:var(--r-pill);
  transition:color .15s,background .15s,transform .15s;
}
.nav-links a:hover,.nav-links a.active { color:var(--silver-0); background:rgba(255,255,255,.05); }
.nav-cta { display:flex; align-items:center; gap:8px; flex-shrink:0; }

/* ── Buttons ─────────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:11px 22px; border-radius:var(--r-pill);
  font-family:var(--font-sans); font-size:14px; font-weight:500;
  letter-spacing:-.01em; cursor:pointer;
  border:1px solid var(--line-strong);
  background:rgba(255,255,255,.03); color:var(--silver-0);
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.btn:hover { border-color:rgba(255,255,255,.35); background:rgba(255,255,255,.06); }
.btn-silver {
  background:linear-gradient(180deg,#f4f6fa,#cfd6e2 60%,#a0abbe);
  color:#05070d; border:1px solid rgba(255,255,255,.45); font-weight:600;
  box-shadow:0 8px 28px rgba(180,200,235,.2),inset 0 1px 0 rgba(255,255,255,.7);
}
.btn-silver:hover { box-shadow:var(--shadow-silver-hover); }
.btn-sm { padding:8px 16px; font-size:13px; min-height:44px; min-width:44px; }
.btn-lg { padding:14px 28px; font-size:16px; }
.btn .arr { opacity:.55; transition:transform .2s,opacity .2s; }
.btn:hover .arr { transform:translateX(3px); opacity:1; }

/* ── Type ────────────────────────────────────────────────────── */
.t-display {
  font-size:var(--fs-display); line-height:var(--lh-tight);
  letter-spacing:var(--tracking-display); font-weight:600; text-wrap:balance;
}
.t-h1 {
  font-size:var(--fs-h1); line-height:.98;
  letter-spacing:var(--tracking-display); font-weight:600; text-wrap:balance;
}
.t-h2 {
  font-size:var(--fs-h2); line-height:1;
  letter-spacing:var(--tracking-h); font-weight:600; text-wrap:balance;
}
.t-h3 { font-size:var(--fs-h3); font-weight:600; letter-spacing:var(--tracking-h); text-wrap:balance; }
.t-h4 { font-size:var(--fs-h4); font-weight:600; letter-spacing:-.01em; }
.t-lede { font-size:var(--fs-lede); line-height:var(--lh-body); color:var(--silver-1); text-wrap:pretty; }
.t-body { font-size:var(--fs-body); line-height:var(--lh-body); color:var(--silver-1); text-wrap:pretty; }
.t-small { font-size:var(--fs-small); color:var(--silver-1); line-height:var(--lh-body); }
.t-meta { font-size:var(--fs-meta); color:var(--silver-2); line-height:var(--lh-body); }
.t-kicker {
  font-family:var(--font-mono); font-size:var(--fs-mono-sm);
  letter-spacing:var(--tracking-eyebrow); text-transform:uppercase;
  color:var(--silver-2); display:inline-flex; align-items:center; gap:10px;
}
.t-kicker::before { content:""; width:28px; height:1px; background:currentColor; opacity:.45; }
.t-mono { font-family:var(--font-mono); font-size:var(--fs-mono-sm); letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; color:var(--silver-3); }

/* Gradient text */
.text-grad { background:var(--grad-text-primary); -webkit-background-clip:text; background-clip:text; color:transparent; }
.text-grad-muted { background:var(--grad-text-muted); -webkit-background-clip:text; background-clip:text; color:transparent; }
.text-grad-blue { background:var(--grad-text-blue); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ── Cards ───────────────────────────────────────────────────── */
.card {
  border:1px solid var(--line); border-radius:var(--r-xl);
  background:var(--grad-card); padding:28px 32px;
  transition:border-color .25s,background .25s,transform .2s,box-shadow .25s;
}
.card:hover { border-color:var(--line-strong); background:var(--grad-card-hover); }
.card-feature {
  border:1px solid var(--line); border-radius:var(--r-2xl);
  background:var(--grad-feature); padding:36px 40px;
  box-shadow:var(--shadow-lg); transition:border-color .25s,background .25s,transform .2s,box-shadow .25s;
}
.card-feature:hover { border-color:var(--line-strong); }

/* Hairline grid (card grids) */
.hgrid { background:var(--line); display:grid; gap:1px; }
.hgrid > * { background:var(--bg-0); }

/* ── Stat strip ──────────────────────────────────────────────── */
.stat-strip { display:grid; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stat-cell { padding:24px 32px; border-right:1px solid var(--line); }
.stat-cell:last-child { border-right:none; }
.stat-label { font-family:var(--font-mono); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--silver-3); margin-bottom:8px; }
.stat-value { font-family:var(--font-sans); font-size:30px; font-weight:600; letter-spacing:-.025em; background:var(--grad-text-muted); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat-sub { font-size:12px; color:var(--silver-3); margin-top:4px; }

/* ── Tags / badges ───────────────────────────────────────────── */
.tag {
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:var(--r-pill);
  border:1px solid var(--line-strong); background:rgba(255,255,255,.02);
  font-family:var(--font-mono); font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--silver-2);
}
.tag-ok { border-color:rgba(155,227,177,.28); color:var(--ok); background:rgba(155,227,177,.06); }
.tag-warn { border-color:rgba(229,181,87,.25); color:var(--warn); background:rgba(229,181,87,.06); }
.tag-auto { border-color:rgba(169,184,212,.2); color:var(--silver-blue); background:rgba(169,184,212,.06); }

/* ── Pill kicker ─────────────────────────────────────────────── */
.pill-kicker {
  display:inline-flex; align-items:center; gap:8px;
  padding:5px 14px 5px 10px; border-radius:var(--r-pill);
  border:1px solid var(--line-strong); background:rgba(255,255,255,.02);
  font-family:var(--font-mono); font-size:10px; letter-spacing:var(--tracking-eyebrow); text-transform:uppercase; color:var(--silver-2);
}

/* ── Glyph plate (icon container) ────────────────────────────── */
.glyph {
  width:44px; height:44px; border-radius:var(--r-lg);
  border:1px solid var(--line-strong); background:rgba(13,26,54,.5);
  display:flex; align-items:center; justify-content:center;
  color:var(--silver-1); flex-shrink:0;
}
.glyph svg { width:20px; height:20px; }

/* ── Orb ─────────────────────────────────────────────────────── */
.orb {
  border-radius:50%; position:relative;
  background:radial-gradient(circle at 35% 30%,#f8faff 0%,#cfd6e2 18%,#6b7794 40%,#1a2647 65%,#050913 90%);
  box-shadow:var(--shadow-orb);
  animation:orb-spin 32s linear infinite;
}
.orb::before {
  content:""; position:absolute; inset:8%; border-radius:50%;
  border:1px solid rgba(207,214,226,.18);
  background:conic-gradient(from 0deg,transparent 0deg,rgba(207,214,226,.08) 60deg,transparent 120deg,rgba(207,214,226,.12) 180deg,transparent 240deg,rgba(207,214,226,.06) 300deg,transparent 360deg);
}
.orb::after { content:""; position:absolute; inset:-2%; border-radius:50%; border:1px solid rgba(207,214,226,.07); }
.ring-dash {
  position:absolute; border-radius:50%;
  border:1px dashed rgba(207,214,226,.11);
  animation:orb-spin 60s linear infinite reverse;
  pointer-events:none;
}
@keyframes orb-spin { to { transform:rotate(360deg); } }

/* ── Live pulse ──────────────────────────────────────────────── */
.live-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--ok); box-shadow:0 0 10px var(--ok);
  animation:ldot 2.2s ease-in-out infinite alternate;
}
.live-dot-accent {
  width:7px; height:7px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 10px var(--accent);
  animation:ldot 2s ease-in-out infinite alternate;
}
@keyframes ldot { 0%{opacity:.3} 100%{opacity:1} }

/* ── Step number prefix ──────────────────────────────────────── */
.step-num {
  font-family:var(--font-mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--silver-3); margin-bottom:20px;
}

/* ── Section heading group ───────────────────────────────────── */
.sh { display:flex; flex-direction:column; gap:16px; margin-bottom:56px; }
.sh .eyebrow { display:flex; align-items:center; gap:12px; }

/* ── Form elements ───────────────────────────────────────────── */
.form-field { display:flex; flex-direction:column; gap:8px; }
.form-label { font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver-3); }
.form-input {
  background:rgba(255,255,255,.03); border:1px solid var(--line-strong);
  border-radius:var(--r-md); padding:12px 16px;
  font-size:15px; color:var(--silver-0); outline:none;
  transition:border-color .2s,box-shadow .2s;
}
.form-input:focus { border-color:var(--line-bright); box-shadow:0 0 0 4px rgba(223,230,242,.06); }
.form-input::placeholder { color:var(--silver-3); }
textarea.form-input { resize:vertical; min-height:120px; }
select.form-input { cursor:pointer; appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%238b94a6' stroke-width='1.5'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:calc(100% - 14px) 50%; padding-right:40px; }

/* ── Table ───────────────────────────────────────────────────── */
.data-table { width:100%; border-collapse:collapse; }
.data-table th { font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver-3); padding:12px 20px; border-bottom:1px solid var(--line); text-align:left; font-weight:500; }
.data-table td { padding:16px 20px; border-bottom:1px solid var(--line); font-size:14px; color:var(--silver-1); vertical-align:top; }
.data-table tr:last-child td { border-bottom:none; }
.data-table tr:hover td { background:rgba(255,255,255,.02); }

/* ── Divider ─────────────────────────────────────────────────── */
.divider { border:none; border-top:1px solid var(--line); margin:0; }

/* ── Prose (legal pages) ─────────────────────────────────────── */
.prose { max-width:720px; }
.prose h2 { font-size:22px; font-weight:600; color:var(--silver-0); margin-top:48px; margin-bottom:16px; }
.prose h3 { font-size:17px; font-weight:600; color:var(--silver-0); margin-top:32px; margin-bottom:12px; }
.prose p { font-size:15px; line-height:1.75; color:var(--silver-1); margin-bottom:16px; text-wrap:pretty; }
.prose ul,.prose ol { padding-left:24px; margin-bottom:16px; display:flex; flex-direction:column; gap:8px; }
.prose li { font-size:15px; line-height:1.65; color:var(--silver-1); }
.prose a { color:var(--silver-0); border-bottom:1px solid rgba(223,230,242,.2); transition:border-color .15s; }
.prose a:hover { border-bottom-color:var(--accent); }
.prose .effective { font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver-3); margin-bottom:40px; }
.prose strong { color:var(--silver-0); font-weight:600; }

/* ── Footer ──────────────────────────────────────────────────── */
.site-footer { border-top:1px solid var(--line); padding:64px 0 48px; margin-top:80px; }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; margin-bottom:56px; }
.footer-desc { font-size:14px; line-height:1.7; color:var(--silver-2); max-width:280px; margin-top:16px; text-wrap:pretty; }
.footer-col h5,
.footer-col .footer-heading { font-family:var(--font-mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--silver-3); margin-bottom:20px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { font-size:14px; color:var(--silver-2); transition:color .15s; }
.footer-col ul li a:hover { color:var(--silver-0); }
.footer-bottom { display:flex; justify-content:space-between; align-items:flex-end; padding-top:32px; border-top:1px solid var(--line); gap:32px; }
.footer-legal { font-size:13px; color:var(--silver-3); line-height:1.65; }
.footer-meta { font-family:var(--font-mono); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--silver-3); white-space:nowrap; }

/* ── Accordion (FAQ) ─────────────────────────────────────────── */
.accordion-item { border-bottom:1px solid var(--line); }
.accordion-trigger {
  width:100%; display:flex; justify-content:space-between; align-items:center;
  padding:24px 0; background:none; cursor:pointer; text-align:left;
  font-family:var(--font-sans); font-size:17px; font-weight:500;
  color:var(--silver-0); gap:24px; transition:color .15s;
}
.accordion-trigger:hover { color:#fff; }
.accordion-marker { font-size:22px; line-height:1; color:var(--silver-3); flex-shrink:0; transition:transform .25s; }
.accordion-item.open .accordion-marker { transform:rotate(45deg); }
.accordion-body { overflow:hidden; max-height:0; transition:max-height .3s cubic-bezier(.22,1,.36,1); }
.accordion-body-inner { padding-bottom:24px; font-size:15px; line-height:1.75; color:var(--silver-2); max-width:680px; }
.accordion-item.open .accordion-body { max-height:400px; }

/* ── Page hero (inner pages) ─────────────────────────────────── */
.page-hero { padding:80px 0 64px; border-bottom:1px solid var(--line); }
.page-hero-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:end; }

/* ── Utility ─────────────────────────────────────────────────── */
.flex { display:flex; } .flex-col { display:flex; flex-direction:column; }
.items-center { align-items:center; } .justify-between { justify-content:space-between; }
.gap-1{gap:4px} .gap-2{gap:8px} .gap-3{gap:12px} .gap-4{gap:16px} .gap-5{gap:24px} .gap-6{gap:32px} .gap-7{gap:48px}
.mt-1{margin-top:4px} .mt-2{margin-top:8px} .mt-3{margin-top:12px} .mt-4{margin-top:16px}
.mt-5{margin-top:24px} .mt-6{margin-top:32px} .mt-7{margin-top:48px} .mt-8{margin-top:64px}
.mb-2{margin-bottom:8px} .mb-3{margin-bottom:12px} .mb-4{margin-bottom:16px}
.mb-5{margin-bottom:24px} .mb-6{margin-bottom:32px} .mb-7{margin-bottom:48px}
.text-muted{color:var(--silver-2)} .text-dim{color:var(--silver-3)} .text-white{color:var(--silver-0)}
.text-ok{color:var(--ok)} .text-warn{color:var(--warn)}
.font-mono{font-family:var(--font-mono);letter-spacing:var(--tracking-mono)}
.w-full{width:100%} .max-w-prose{max-width:720px}

/* ── Responsive ──────────────────────────────────────────────────────────── */

/* ── Mobile nav burger ──────────────────────────────── */
.nav-burger {
  display: none;                     /* hidden by default; shown via device gate below */
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  padding: 0;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line-strong);
  cursor: pointer;
  flex-shrink: 0;
  transition: background .15s, border-color .15s;
  margin-left: auto;                 /* push to the right of brand on mobile */
}
.nav-burger:hover { background: rgba(255,255,255,.08); border-color: var(--line-bright); }
.nb-line {
  display: block;
  width: 18px;
  height: 1.5px;
  border-radius: 2px;
  background: var(--silver-1);
  transition: transform .25s ease, opacity .25s ease;
}

/* Animated X state when nav is open */
.nav-open .nb-line:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-open .nb-line:nth-child(2) { opacity: 0; transform: scaleX(0); }
.nav-open .nb-line:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── Device-gate: show/hide nav elements ────────────── */

/* On mobile and tablet: hide horizontal nav, show burger */
html[data-device="mobile"] .nav-burger,
html[data-device="tablet"] .nav-burger {
  display: flex;
}

html[data-device="mobile"] .nav-links,
html[data-device="mobile"] .nav-cta,
html[data-device="tablet"] .nav-links,
html[data-device="tablet"] .nav-cta {
  display: none;
}

/* On desktop: always show nav links, hide burger */
html[data-device="desktop"] .nav-burger { display: none; }
html[data-device="desktop"] .nav-links,
html[data-device="desktop"] .nav-cta   { display: flex; }

/* ── Open nav drawer (mobile/tablet) ────────────────── */
.nav-open .nav-links,
.nav-open .nav-cta {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

/* Full-width nav drawer layout */
html[data-device="mobile"] .nav-open .nav-links,
html[data-device="tablet"] .nav-open .nav-links,
html[data-device="mobile"] .nav-open .nav-cta,
html[data-device="tablet"] .nav-open .nav-cta {
  display: flex;
}

/* Make the nav-row a column container when drawer is open */
.nav-open .nav-row {
  flex-wrap: wrap;
  height: auto;
  padding-bottom: 16px;
}

.nav-open .nav-links {
  width: 100%;
  padding-top: 8px;
  border-top: 1px solid var(--line);
  order: 3;
}

.nav-open .nav-cta {
  width: 100%;
  padding-bottom: 8px;
  order: 4;
  flex-direction: row;
  flex-wrap: wrap;
}

/* Full-width links in the drawer */
.nav-open .nav-links a {
  padding: 12px 16px;
  width: 100%;
  font-size: 13px;
  border-radius: var(--r-sm);
}

/* ── Scroll-reveal animation ────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .5s cubic-bezier(.22,1,.36,1), transform .5s cubic-bezier(.22,1,.36,1);
}
[data-reveal].revealed {
  opacity: 1;
  transform: none;
}

/* ── Touch: suppress hover effects on cards ─────────── */
html[data-touch="true"] .card:hover {
  background: var(--grad-card);
  border-color: var(--line);
}
html[data-touch="true"] .svc-ov-card:hover {
  background: var(--grad-card);
  border-color: var(--line);
}
html[data-touch="true"] .card-feature:hover { border-color: var(--line); }
html[data-touch="true"] .pillar-card:hover  { border-color: var(--line); }

/* ── Tablet breakpoint (768–1099px) ─────────────────── */
@media (max-width: 1099px) {
  /* Layout */
  .wrap { padding: 0 20px; }
  .section { padding: var(--s-8) 0; }

  /* Section heading spacing */
  .sh { margin-bottom: 40px; }

  /* Page hero */
  .page-hero-grid { grid-template-columns: 1fr; gap: 32px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .footer-bottom { align-items: flex-start; }

  /* Stat strip: 2 columns */
  .stat-strip { grid-template-columns: 1fr 1fr; }
  .stat-cell:nth-child(2) { border-right: none; }
  .stat-cell:nth-child(3) { border-top: 1px solid var(--line); }
  .stat-cell:nth-child(4) { border-top: 1px solid var(--line); border-right: none; }

  /* Comparison table: enable horizontal scroll */
  .compare-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* CTA band: stack */
  .cta-band { flex-direction: column; align-items: flex-start; padding: 48px 40px; }

  /* Stat callout */
  .stat-callout { flex-direction: row; }
}

/* ── Mobile breakpoint (<=767px) ────────────────────── */
@media (max-width: 767px) {
  /* Custom property overrides for smaller type */
  :root {
    --fs-h2: clamp(24px, 7vw, 36px);
    --fs-h3: 24px;
  }

  /* Layout */
  .wrap { padding: 0 16px; }
  .section { padding: var(--s-7) 0; }
  .section-sm { padding: var(--s-6) 0; }

  /* Section heading */
  .sh { margin-bottom: 32px; gap: 12px; }

  /* Nav row height */
  .nav-row { height: 60px; }

  /* Hero on index.html (handled by inline @media on that page, reinforced here) */
  .hero { padding: 56px 0 48px; }
  /* Clip decorative rings so they don't bleed past viewport edge */
  .orb-stage { overflow: hidden; }

  /* Page hero */
  .page-hero { padding: 48px 0 40px; }
  .page-hero-grid { grid-template-columns: 1fr; gap: 24px; }

  /* Cards */
  .card { padding: 20px 24px; }
  .card-feature { padding: 24px 28px; }

  /* Hairline grids: single column */
  .hgrid { grid-template-columns: 1fr !important; }

  /* Stat strip: single column */
  .stat-strip { grid-template-columns: 1fr; }
  .stat-cell { border-right: none; border-top: 1px solid var(--line); }
  .stat-cell:first-child { border-top: none; }

  /* Comparison table: horizontal scroll */
  .compare-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .compare-table { min-width: 620px; }

  /* Email form: stack to column */
  .email-form { flex-direction: column; max-width: 100%; }
  .email-form input { width: 100%; }
  .email-form button { width: 100%; justify-content: center; }

  /* CTA band: stack, reduce padding */
  .cta-band {
    flex-direction: column;
    align-items: flex-start;
    padding: 32px 24px;
    gap: 24px;
  }
  .cta-band > div:last-child { width: 100%; }
  .cta-band > div:last-child .btn { width: 100%; justify-content: center; }

  /* Urgency block */
  .urgency-block { padding: 32px 24px; }

  /* Stat callout: stack to column */
  .stat-callout {
    flex-direction: column;
    padding: 24px;
    gap: 16px;
    align-items: flex-start;
  }
  .stat-callout .big-num { font-size: 48px; }

  /* Footer */
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .footer-bottom {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
  .footer-desc { max-width: 100%; }

  /* Prose pages */
  .prose h2 { font-size: 19px; margin-top: 36px; }
  .prose h3 { font-size: 16px; }

  /* Steps / pillars / pricing grids (already collapsed by inline media on index.html;
     reinforce here for other pages that share these classes) */
  .steps-row,
  .pillar-grid,
  .pricing-row,
  .pricing-grid,
  .svc-overview-grid,
  .testi-grid { grid-template-columns: 1fr !important; }

  /* Pain grid: single column on mobile */
  .pain-grid { grid-template-columns: 1fr !important; }

  /* About grid */
  .about-grid { grid-template-columns: 1fr; gap: 48px; }

  /* Sticky aside: remove sticky on mobile */
  .sticky-aside { position: static; }

  /* FAQ two-col layout on index */
  .wrap[style*="grid-template-columns:1fr 1.4fr"],
  .wrap[style*="grid-template-columns: 1fr 1.4fr"] {
    display: block !important;
  }

  /* Stat cell padding */
  .stat-cell { padding: 20px 16px; }

  /* Mission block */
  .mission-block { padding: 32px 24px; }

  /* Value grid: single column */
  .value-grid { grid-template-columns: 1fr !important; }

  /* Trust grid: single column */
  .trust-grid { grid-template-columns: 1fr !important; }
}

/* ════════════════════════════════════════════════════════════════════════════
   ENHANCEMENT LAYER — Accessibility, micro-interactions, animation quality
   Added after responsive agent. No existing rules removed.
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Skip-to-content link ─────────────────────────────────────────────────── */
a.skip-link {
  position: absolute;
  top: 0;
  left: 0;
  transform: translateY(-100%);
  z-index: 9999;
  padding: 10px 20px;
  background: var(--silver-0);
  color: var(--bg-0);
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .05em;
  text-decoration: none;
  border-radius: 0 0 var(--r-sm) 0;
  transition: transform .2s cubic-bezier(.22,1,.36,1);
}
a.skip-link:focus {
  transform: translateY(0);
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}

/* ── Focus-visible rings (WCAG AA keyboard navigation) ────────────────────── */
.btn:focus-visible {
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}
.nav-links a:focus-visible {
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}
.accordion-trigger:focus-visible {
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}
.form-input:focus-visible {
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}
.footer-col a:focus-visible {
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}
.nav-burger:focus-visible {
  outline: 2px solid rgba(207,214,226,.6);
  outline-offset: 3px;
}

/* ── Micro-interaction: card lift (non-touch only) ────────────────────────── */
html:not([data-touch="true"]) .card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}
html:not([data-touch="true"]) .card-feature:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}

/* ── Micro-interaction: secondary card types (non-touch only) ─────────────── */
html:not([data-touch="true"]) .svc-ov-card {
  transition: border-color .25s, background .25s, transform .2s, box-shadow .25s;
}
html:not([data-touch="true"]) .svc-ov-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
}
html:not([data-touch="true"]) .pillar-card {
  transition: border-color .25s, background .25s, transform .2s, box-shadow .25s;
}
html:not([data-touch="true"]) .pillar-card:hover {
  transform: translateY(-2px);
}
html:not([data-touch="true"]) .testi-card {
  transition: border-color .25s, background .25s, transform .2s, box-shadow .25s;
}
html:not([data-touch="true"]) .testi-card:hover {
  transform: translateY(-2px);
}
html:not([data-touch="true"]) .step-box {
  transition: border-color .25s, background .25s, transform .2s, box-shadow .25s;
}
html:not([data-touch="true"]) .step-box:hover {
  transform: translateY(-2px);
}

/* ── Micro-interaction: btn-silver vertical nudge ─────────────────────────── */
.btn-silver:hover { transform: translateY(-1px); }
.btn:active, .btn-silver:active { transform: translateY(0); }

/* ── Micro-interaction: footer link subtle shift ──────────────────────────── */
.footer-col ul li a {
  transition: color .15s, opacity .15s;
}
.footer-col ul li a:hover {
  color: var(--silver-0);
  opacity: 1;
}

/* ── Featured price card glow ─────────────────────────────────────────────── */
.price-card.featured {
  box-shadow: 0 0 0 1px rgba(207,214,226,.15), 0 24px 64px rgba(0,0,0,.5);
}

/* ── Glyph hover (non-touch only) ─────────────────────────────────────────── */
.glyph {
  transition: border-color .2s, background .2s;
}
html:not([data-touch="true"]) .glyph:hover {
  border-color: var(--line-strong);
  background: rgba(13,26,54,.8);
}

/* ── Prefers-reduced-motion: pause all decorative animations ──────────────── */
@media (prefers-reduced-motion: reduce) {
  .orb,
  .ring-dash,
  .live-dot,
  .live-dot-accent {
    animation: none;
  }
  [data-reveal] {
    transition: none;
  }
}

/* ── Mobile nav drawer fade-in-down animation ─────────────────────────────── */
@keyframes fade-in-down {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.nav-open .nav-links,
.nav-open .nav-cta {
  animation: fade-in-down .22s cubic-bezier(.22,1,.36,1) both;
}

/* ── Smooth scrolling (respects prefers-reduced-motion) ───────────────────── */
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

/* ── Text selection color ─────────────────────────────────────────────────── */
::selection { background: rgba(169,184,212,.25); color: var(--silver-0); }

/* ── Visually hidden utility (accessible to screen readers) ───────────────── */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* ── Print media query ────────────────────────────────────────────────────── */
@media print {
  .bg-field,
  .bg-grid,
  .bg-noise,
  .site-nav,
  .site-footer,
  .nav-burger,
  [data-reveal] {
    display: none !important;
  }

  body {
    background: white !important;
    color: black !important;
  }

  /* Remove all backdrop-filter for print rendering */
  .site-nav,
  .ticker-chip,
  * {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}
