/* === AV product LP — shared base =============================================
   Shared stylesheet. Tokens from AVTrade Design System.
   Palette: dark navy + silver. Per-product accent via index.html :root override.
   ============================================================================= */

@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); }

.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); }
.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 ─────────────────────────────────────────────── */
.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; transition:border-color .2s,background .2s; }
.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,opacity .15s; }
.footer-col ul li a:hover { color:var(--silver-0); opacity:1; }
.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}

/* ── Mobile nav burger ───────────────────────────────────────── */
.nav-burger { display:none; 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; }
.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; }
.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); }

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; }
html[data-device="desktop"] .nav-burger { display:none; }
html[data-device="desktop"] .nav-links,
html[data-device="desktop"] .nav-cta { display:flex; }
.nav-open .nav-links,
.nav-open .nav-cta { display:flex; flex-direction:column; align-items:flex-start; gap:4px; }
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; }
.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; }
.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 ───────────────────────────────────── */
html[data-touch="true"] .card:hover { background:var(--grad-card); border-color:var(--line); }
html[data-touch="true"] .card-feature:hover { border-color:var(--line); }

/* ── Tablet ──────────────────────────────────────────────────── */
@media(max-width:1099px) {
  .wrap{padding:0 20px}
  .section{padding:var(--s-8) 0}
  .sh{margin-bottom:40px}
  .page-hero-grid{grid-template-columns:1fr;gap:32px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-bottom{align-items:flex-start}
  .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}
  .cta-band{flex-direction:column;align-items:flex-start;padding:48px 40px}
}

/* ── Mobile ──────────────────────────────────────────────────── */
@media(max-width:767px) {
  :root { --fs-h2:clamp(24px,7vw,36px); --fs-h3:24px; }
  .wrap{padding:0 16px}
  .section{padding:var(--s-7) 0}
  .section-sm{padding:var(--s-6) 0}
  .sh{margin-bottom:32px;gap:12px}
  .nav-row{height:60px}
  .hero{padding:56px 0 48px}
  .orb-stage{overflow:hidden}
  .page-hero{padding:48px 0 40px}
  .page-hero-grid{grid-template-columns:1fr;gap:24px}
  .card{padding:20px 24px}
  .card-feature{padding:24px 28px}
  .hgrid{grid-template-columns:1fr !important}
  .stat-strip{grid-template-columns:1fr}
  .stat-cell{border-right:none;border-top:1px solid var(--line)}
  .stat-cell:first-child{border-top:none}
  .email-form{flex-direction:column;max-width:100%}
  .email-form input{width:100%}
  .email-form button{width:100%;justify-content:center}
  .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}
  .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 h2{font-size:19px;margin-top:36px}
  .prose h3{font-size:16px}
  .steps-row,.pillar-grid,.pricing-row,.pricing-grid,.svc-overview-grid,.testi-grid{grid-template-columns:1fr !important}
  .trust-grid{grid-template-columns:1fr !important}
  .stat-cell{padding:20px 16px}
}

/* ── Accessibility & micro-interactions ──────────────────────── */
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; }
.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; }
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); }
.btn-silver:hover { transform:translateY(-1px); }
.btn:active,.btn-silver:active { transform:translateY(0); }
.price-card.featured { box-shadow:0 0 0 1px rgba(207,214,226,.15),0 24px 64px rgba(0,0,0,.5); }
html:not([data-touch="true"]) .glyph:hover { border-color:var(--line-strong); background:rgba(13,26,54,.8); }

@media(prefers-reduced-motion:reduce) {
  .orb,.ring-dash,.live-dot,.live-dot-accent { animation:none; }
  [data-reveal] { transition:none; }
  html { scroll-behavior:auto; }
}

@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; }
html { scroll-behavior:smooth; }
::selection { background:rgba(169,184,212,.25); color:var(--silver-0); }
.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; }

@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; }
  * { backdrop-filter:none !important; -webkit-backdrop-filter:none !important; }
}
