/* ==========================================================================
   Test Runner — marketing site design system
   Aesthetic: "release gate" — an engineering report rendered as a website.
   Dark graphite, violet accent (matches the app), mono data labels,
   hairline rules, grid texture, serif display accents.
   ========================================================================== */

:root{
  /* Surfaces — slightly deeper than the app so app mocks pop */
  --bg:        #141416;
  --bg-2:      #18181B;
  --panel:     #1E1E21;
  --panel-hi:  #242428;
  --line:      #2C2C31;
  --line-soft: #232328;

  /* App-true tokens, used inside product mocks */
  --app-bg:    #1E1E1E;
  --app-card:  #272727;

  /* Type */
  --t1: #F4F3F1;
  --t2: rgba(244,243,241,.66);
  --t3: rgba(244,243,241,.42);
  --t4: rgba(244,243,241,.26);

  /* Brand */
  --vio:       #8B7BFF;
  --vio-2:     #6755E8;
  --vio-soft:  rgba(139,123,255,.13);
  --vio-line:  rgba(139,123,255,.38);
  --vio-text:  #C9BFFF;

  --pass:      #4DCC82;
  --pass-soft: rgba(77,204,130,.13);
  --pass-line: rgba(77,204,130,.36);
  --fail:      #F76B72;
  --fail-soft: rgba(247,107,114,.12);
  --amber:     #FFBD36;

  --r-lg: 16px;
  --r-md: 11px;
  --r-sm: 7px;
  --r-pill: 999px;

  --serif: "Instrument Serif", Georgia, serif;
  --sans:  "Instrument Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --wrap: 1140px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *, *::before, *::after{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}

body{
  margin:0;
  background:var(--bg);
  color:var(--t1);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* Grain + graph-paper atmosphere */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(244,243,241,.022) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(244,243,241,.022) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(1200px 800px at 50% 0%, #000 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(1200px 800px at 50% 0%, #000 0%, transparent 75%);
}
body::after{
  content:""; position:fixed; inset:-50%; z-index:1; pointer-events:none; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.05'/%3E%3C/svg%3E");
}
main, nav, footer{ position:relative; z-index:2; }

a{ color:inherit; text-decoration:none; }
img, video{ max-width:100%; display:block; }
.wrap{ width:min(var(--wrap), 92vw); margin:0 auto; }

::selection{ background:rgba(139,123,255,.32); }

/* ===== Type helpers ===== */
.mono-label{
  font-family:var(--mono); font-size:11.5px; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase; color:var(--t3);
}
.mono-label .idx{ color:var(--vio); }
.serif-it{ font-family:var(--serif); font-style:italic; font-weight:400; letter-spacing:0; }

h1,h2,h3,h4{ margin:0; font-weight:600; letter-spacing:-.02em; }

/* ===== Buttons ===== */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  padding:13px 22px; border-radius:var(--r-sm);
  font-family:var(--sans); font-size:15px; font-weight:600; letter-spacing:-.01em;
  cursor:pointer; border:1px solid transparent; white-space:nowrap;
  transition:transform .14s ease, filter .15s ease, background .15s ease, border-color .15s ease;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{
  background:linear-gradient(165deg, #9486FF, var(--vio-2));
  color:#fff;
  box-shadow:0 1px 0 rgba(255,255,255,.18) inset, 0 8px 26px -8px rgba(139,123,255,.55);
}
.btn-primary:hover{ filter:brightness(1.07); }
.btn-ghost{
  background:rgba(255,255,255,.035); border-color:var(--line); color:var(--t1);
}
.btn-ghost:hover{ background:rgba(255,255,255,.07); border-color:var(--vio-line); }
.btn .kbd{
  font-family:var(--mono); font-size:11px; color:rgba(255,255,255,.75);
  border:1px solid rgba(255,255,255,.28); border-radius:4px; padding:1px 5px;
}

/* ===== Status chips (shared with mocks) ===== */
.chip-status{
  font-family:var(--mono); font-size:10.5px; font-weight:600; letter-spacing:.08em;
  padding:2.5px 7px; border-radius:4px;
}
.chip-status.pass{ color:var(--pass); background:var(--pass-soft); border:1px solid var(--pass-line); }
.chip-status.fail{ color:var(--fail); background:var(--fail-soft); border:1px solid rgba(247,107,114,.34); }
.chip-status.run { color:var(--amber); background:rgba(255,189,54,.12); border:1px solid rgba(255,189,54,.3); }

/* ===== Nav ===== */
nav.site{
  position:sticky; top:0; z-index:60;
  background:rgba(20,20,22,.78);
  backdrop-filter:blur(16px) saturate(150%);
  -webkit-backdrop-filter:blur(16px) saturate(150%);
  border-bottom:1px solid var(--line-soft);
}
.nav-in{ display:flex; align-items:center; justify-content:space-between; height:62px; }
.brand{ display:flex; align-items:center; gap:11px; }
.brand-mark{
  width:30px; height:30px; border-radius:8px; flex:0 0 auto;
  background:linear-gradient(160deg, #9486FF, var(--vio-2));
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 10px rgba(139,123,255,.4);
}
.brand-mark svg{ width:16px; height:16px; color:#fff; }
.brand-name{ font-size:15.5px; font-weight:650; letter-spacing:-.01em; }
.brand-ver{
  font-family:var(--mono); font-size:10px; color:var(--t3);
  border:1px solid var(--line); border-radius:4px; padding:1px 6px; margin-left:2px;
}
.nav-links{ display:flex; align-items:center; gap:28px; }
.nav-links a{ font-size:14px; color:var(--t2); font-weight:500; transition:color .15s; }
.nav-links a:hover{ color:var(--t1); }
.nav-cta{ display:flex; align-items:center; gap:10px; }
.nav-cta .btn{ padding:9px 16px; font-size:13.5px; }

/* ===== Hero ===== */
.hero{ position:relative; padding:88px 0 72px; }
.hero::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(820px 420px at 18% -8%, rgba(139,123,255,.16), transparent 70%),
    radial-gradient(540px 320px at 92% 12%, rgba(77,204,130,.05), transparent 70%);
}
.hero-grid{
  position:relative;
  display:grid; grid-template-columns: 1.05fr .95fr; gap:56px; align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--vio-text);
  padding:7px 13px; border-radius:var(--r-pill);
  background:var(--vio-soft); border:1px solid var(--vio-line);
  margin-bottom:26px;
}
.eyebrow .pulse{
  width:6px; height:6px; border-radius:50%; background:var(--pass);
  box-shadow:0 0 0 0 rgba(77,204,130,.5); animation:pulse 2.2s infinite;
}
@keyframes pulse{ 70%{ box-shadow:0 0 0 7px rgba(77,204,130,0);} 100%{ box-shadow:0 0 0 0 rgba(77,204,130,0);} }

.hero h1{
  font-size:clamp(38px, 4.6vw, 62px);
  line-height:1.02; letter-spacing:-.03em; font-weight:600;
  margin:0 0 22px;
}
.hero h1 .serif-it{
  font-size:1.04em;
  background:linear-gradient(105deg, #CFC6FF, var(--vio) 70%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero .sub{ font-size:17.5px; color:var(--t2); max-width:54ch; margin:0 0 32px; }
.hero .sub strong{ color:var(--t1); font-weight:600; }
.hero-cta{ display:flex; gap:13px; flex-wrap:wrap; margin-bottom:30px; }
.hero-note{ font-family:var(--mono); font-size:12px; color:var(--t3); letter-spacing:.02em; }
.hero-note b{ color:var(--t2); font-weight:500; }

.hero-facts{ display:flex; gap:22px; flex-wrap:wrap; margin-top:34px; padding-top:26px; border-top:1px solid var(--line-soft); }
.fact{ display:flex; align-items:center; gap:8px; font-size:13px; color:var(--t2); }
.fact svg{ width:15px; height:15px; color:var(--vio); flex:0 0 auto; }

/* Hero load-in choreography */
.hero .reveal-load{ opacity:0; transform:translateY(14px); animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards; }
.hero .d1{ animation-delay:.05s } .hero .d2{ animation-delay:.15s } .hero .d3{ animation-delay:.25s }
.hero .d4{ animation-delay:.35s } .hero .d5{ animation-delay:.45s } .hero .d6{ animation-delay:.6s }
@keyframes rise{ to{ opacity:1; transform:none; } }

/* ===== Hero mock: live suite run ===== */
.runcard{
  position:relative;
  background:var(--app-bg);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  box-shadow:0 30px 80px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.02) inset;
  overflow:hidden;
}
.runcard-bar{
  display:flex; align-items:center; gap:8px;
  padding:11px 14px; border-bottom:1px solid var(--line-soft);
  background:rgba(255,255,255,.015);
}
.runcard-bar .dots{ display:flex; gap:6px; }
.runcard-bar .dots i{ width:10px; height:10px; border-radius:50%; background:#3A3A3E; }
.runcard-bar .title{
  margin-left:8px; font-family:var(--mono); font-size:11px; color:var(--t3); letter-spacing:.04em;
}
.runcard-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:15px 18px 13px;
}
.runcard-head .suite{ font-size:14.5px; font-weight:600; letter-spacing:-.01em; }
.runcard-head .meta{ font-family:var(--mono); font-size:10.5px; color:var(--t3); margin-top:3px; }
.flowrow{
  display:flex; align-items:center; gap:12px;
  padding:11px 18px; border-top:1px solid var(--line-soft);
  opacity:0; transform:translateX(-8px);
  animation:flowin .5s ease forwards;
}
.flowrow .nm{ font-family:var(--mono); font-size:12.5px; color:var(--t2); flex:1; }
.flowrow .tm{ font-family:var(--mono); font-size:11px; color:var(--t4); }
.flowrow .chip-status{ min-width:46px; text-align:center; }
.flowrow .chip-status.flip{ animation:flip .3s ease forwards; animation-delay:inherit; }
@keyframes flowin{ to{ opacity:1; transform:none; } }

/* Each row slides in, runs amber, then flips to PASS via a second pseudo-state */
.flowrow .st{ position:relative; min-width:48px; height:20px; }
.flowrow .st .chip-status{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; }
.flowrow .st .run{ opacity:1; }
.flowrow .st .pass{ opacity:0; }
.flowrow.done .st .run{ animation:fadeout .25s ease forwards; }
.flowrow.done .st .pass{ animation:fadein .25s ease forwards; }
@keyframes fadeout{ to{ opacity:0; } }
@keyframes fadein{ to{ opacity:1; } }

.runcard-gate{
  display:flex; align-items:center; justify-content:space-between;
  margin:14px; margin-top:10px; padding:13px 16px;
  border:1px dashed var(--pass-line); border-radius:var(--r-md);
  background:var(--pass-soft);
  opacity:0; transform:scale(.96);
  animation:stamp .45s cubic-bezier(.2,.9,.3,1.4) forwards;
}
.runcard-gate .g1{ font-family:var(--mono); font-size:11px; letter-spacing:.12em; color:var(--pass); font-weight:700; }
.runcard-gate .g2{ font-size:12.5px; color:var(--t2); }
@keyframes stamp{ to{ opacity:1; transform:none; } }

.runcard-foot{
  display:flex; gap:14px; padding:0 14px 14px;
  font-family:var(--mono); font-size:10.5px; color:var(--t4);
}
.runcard-foot span b{ color:var(--t3); font-weight:500; }

/* floating matrix mini-card */
.matrixcard{
  position:absolute; right:-26px; bottom:-30px; z-index:3;
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r-md);
  padding:13px 15px; box-shadow:0 22px 50px -18px rgba(0,0,0,.75);
  animation:floaty 7s ease-in-out infinite;
}
@keyframes floaty{ 50%{ transform:translateY(-7px);} }
.matrixcard .ml{ font-family:var(--mono); font-size:10px; letter-spacing:.12em; color:var(--t3); text-transform:uppercase; margin-bottom:9px; }
.matrixgrid{ display:grid; grid-template-columns:repeat(6, 14px); gap:5px; }
.matrixgrid i{ width:14px; height:14px; border-radius:3.5px; background:var(--pass-soft); border:1px solid var(--pass-line); }
.matrixgrid i.f{ background:var(--fail-soft); border-color:rgba(247,107,114,.34); }
.matrixgrid i.p{ background:rgba(255,255,255,.04); border-color:var(--line); }

/* ===== Sections ===== */
section{ padding:96px 0; position:relative; }
.sec-rule{ border-top:1px solid var(--line-soft); }
.sec-head{ max-width:64ch; margin-bottom:56px; }
.sec-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.sec-head .mono-label{ display:block; margin-bottom:16px; }
.sec-head h2{ font-size:clamp(28px, 3.4vw, 42px); line-height:1.08; letter-spacing:-.025em; margin-bottom:16px; }
.sec-head h2 .serif-it{ color:var(--vio-text); }
.sec-head p{ font-size:16.5px; color:var(--t2); margin:0; }

/* Scroll reveal — hidden state only applies once JS has tagged <html class="js">,
   so content is fully visible without JavaScript */
.js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.js .reveal.in{ opacity:1; transform:none; }

/* ===== Demo ===== */
.demo-frame{
  position:relative;
  border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  background:var(--app-bg);
  box-shadow:0 40px 110px -40px rgba(0,0,0,.8);
}
.demo-frame video{ width:100%; height:auto; }
.demo-cap{
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  margin-top:18px; font-family:var(--mono); font-size:11.5px; color:var(--t3); letter-spacing:.03em;
}

/* ===== Workflow ledger (feature groups) ===== */
.ledger{ border-top:1px solid var(--line); }
.ledger-row{
  display:grid; grid-template-columns: 200px 1fr 1fr; gap:40px;
  padding:44px 0; border-bottom:1px solid var(--line);
}
.ledger-row .idx{
  font-family:var(--mono); font-size:12px; color:var(--vio); letter-spacing:.14em;
}
.ledger-row .idx .ttl{
  display:block; margin-top:10px;
  font-family:var(--sans); font-size:21px; font-weight:600; color:var(--t1); letter-spacing:-.02em;
}
.ledger-row .desc{ font-size:15px; color:var(--t2); margin:0; }
.ledger-row .desc strong{ color:var(--t1); font-weight:600; }
.ledger-row ul{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:10px;
}
.ledger-row li{
  display:flex; gap:10px; align-items:baseline;
  font-size:13.5px; color:var(--t2);
}
.ledger-row li::before{
  content:"▸"; color:var(--vio); font-size:11px; flex:0 0 auto;
}

/* ===== Spec sheet ===== */
.spec{
  border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
  background:var(--panel);
}
.spec-row{
  display:grid; grid-template-columns: 240px 1fr; gap:24px;
  padding:18px 26px; border-top:1px solid var(--line-soft);
}
.spec-row:first-child{ border-top:none; }
.spec-row .k{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--t3); padding-top:2px; }
.spec-row .v{ font-size:14.5px; color:var(--t1); }
.spec-row .v .dim{ color:var(--t3); }

/* ===== Privacy band ===== */
.band{
  position:relative; overflow:hidden;
  border:1px solid var(--vio-line); border-radius:20px;
  padding:54px 50px;
  background:
    radial-gradient(640px 280px at 12% 0%, rgba(139,123,255,.16), transparent 70%),
    var(--panel);
  display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap;
}
.band h2{ font-size:clamp(26px, 3vw, 36px); margin-bottom:12px; letter-spacing:-.02em; }
.band p{ color:var(--t2); max-width:52ch; margin:0; font-size:16px; }
.band-stats{ display:flex; gap:44px; }
.bstat .n{ font-size:34px; font-weight:650; letter-spacing:-.03em; }
.bstat .n em{ font-family:var(--serif); font-style:italic; color:var(--vio-text); }
.bstat .l{ font-family:var(--mono); font-size:11px; color:var(--t3); letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }

/* ===== Pricing ===== */
.price-grid{ display:grid; grid-template-columns: 1.15fr .85fr; gap:20px; align-items:stretch; }
.price-card{
  position:relative;
  background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:36px 34px; display:flex; flex-direction:column;
}
.price-card.featured{
  border-color:var(--vio-line);
  background:
    radial-gradient(480px 240px at 80% -10%, rgba(139,123,255,.14), transparent 70%),
    var(--panel);
  box-shadow:0 30px 80px -40px rgba(139,123,255,.35);
}
.price-card .plan{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.price-card .plan h3{ font-size:19px; font-weight:650; letter-spacing:-.015em; }
.price-card .plan .tag{
  font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--vio-text); background:var(--vio-soft); border:1px solid var(--vio-line);
  padding:3px 9px; border-radius:var(--r-pill);
}
.price-card .plan .tag.soon{ color:var(--t3); background:rgba(255,255,255,.03); border-color:var(--line); }
.price-card .blurb{ font-size:14px; color:var(--t2); margin:0 0 26px; }
.price-num{ display:flex; align-items:baseline; gap:10px; margin-bottom:4px; }
.price-num .cur{ font-size:20px; color:var(--t2); font-weight:500; }
.price-num .n{ font-size:56px; font-weight:650; letter-spacing:-.04em; line-height:1; }
.price-num .per{ font-family:var(--mono); font-size:12px; color:var(--t3); }
.price-alt{ font-family:var(--mono); font-size:12px; color:var(--t3); margin-bottom:28px; }
.price-alt b{ color:var(--pass); font-weight:500; }
.price-feats{ list-style:none; margin:0 0 30px; padding:26px 0 0; border-top:1px solid var(--line-soft); display:flex; flex-direction:column; gap:11px; flex:1; }
.price-feats li{ display:flex; gap:11px; font-size:14px; color:var(--t2); align-items:baseline; }
.price-feats li svg{ width:14px; height:14px; color:var(--pass); flex:0 0 auto; transform:translateY(2px); }
.price-feats li.dim{ color:var(--t3); }
.price-feats li.dim svg{ color:var(--t4); }
.price-card .btn{ justify-content:center; }
.price-foot{
  margin-top:26px; text-align:center;
  font-family:var(--mono); font-size:11.5px; color:var(--t3); letter-spacing:.03em;
}

/* ===== Buying facts ===== */
.buyfacts{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:20px; }
.buyfact{
  background:var(--bg-2); border:1px solid var(--line-soft); border-radius:var(--r-md);
  padding:18px 19px;
}
.buyfact .k{ font-family:var(--mono); font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--t3); margin-bottom:7px; }
.buyfact .v{ font-size:13.5px; color:var(--t1); line-height:1.45; }

/* ===== FAQ ===== */
.faq{ max-width:760px; margin:0 auto; }
.faq details{
  border-bottom:1px solid var(--line);
  padding:4px 0;
}
.faq details:first-of-type{ border-top:1px solid var(--line); }
.faq summary{
  cursor:pointer; list-style:none;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:20px 4px; font-size:16px; font-weight:550; letter-spacing:-.01em;
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ind{
  font-family:var(--mono); color:var(--vio); font-size:16px; flex:0 0 auto;
  transition:transform .25s ease;
}
.faq details[open] summary .ind{ transform:rotate(45deg); }
.faq .a{ padding:0 4px 22px; color:var(--t2); font-size:14.5px; max-width:64ch; }
.faq .a a{ color:var(--vio-text); border-bottom:1px solid var(--vio-line); }

/* ===== Final CTA ===== */
.final{ text-align:center; padding:110px 0 120px; }
.final h2{ font-size:clamp(30px, 4vw, 50px); letter-spacing:-.03em; max-width:20ch; margin:0 auto 18px; }
.final p{ color:var(--t2); max-width:50ch; margin:0 auto 34px; font-size:16.5px; }
.final .hero-cta{ justify-content:center; }

/* ===== Footer ===== */
footer.site{
  border-top:1px solid var(--line-soft);
  padding:44px 0 50px;
  background:var(--bg-2);
}
.foot-grid{ display:flex; justify-content:space-between; gap:36px; flex-wrap:wrap; }
.foot-brand p{ font-size:13px; color:var(--t3); max-width:34ch; margin:12px 0 0; }
.foot-cols{ display:flex; gap:64px; flex-wrap:wrap; }
.foot-col .h{ font-family:var(--mono); font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--t3); margin-bottom:14px; }
.foot-col a{ display:block; font-size:13.5px; color:var(--t2); margin-bottom:9px; transition:color .15s; }
.foot-col a:hover{ color:var(--t1); }
.foot-base{
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  margin-top:40px; padding-top:22px; border-top:1px solid var(--line-soft);
  font-family:var(--mono); font-size:11px; color:var(--t4); letter-spacing:.03em;
}

/* ===== Legal pages ===== */
.legal{ padding:72px 0 100px; }
.legal-doc{ max-width:760px; margin:0 auto; }
.legal-doc .mono-label{ margin-bottom:18px; display:block; }
.legal-doc h1{ font-size:clamp(30px, 4vw, 44px); letter-spacing:-.025em; margin-bottom:10px; }
.legal-doc .updated{ font-family:var(--mono); font-size:12px; color:var(--t3); margin-bottom:46px; }
.legal-doc h2{ font-size:21px; letter-spacing:-.015em; margin:44px 0 14px; }
.legal-doc h2 .no{ font-family:var(--mono); font-size:13px; color:var(--vio); margin-right:10px; }
.legal-doc p, .legal-doc li{ font-size:15px; color:var(--t2); }
.legal-doc strong{ color:var(--t1); font-weight:600; }
.legal-doc ul{ padding-left:22px; }
.legal-doc li{ margin-bottom:8px; }
.legal-doc a{ color:var(--vio-text); border-bottom:1px solid var(--vio-line); }
.legal-doc .callout{
  border:1px solid var(--vio-line); background:var(--vio-soft); border-radius:var(--r-md);
  padding:18px 20px; font-size:14px; color:var(--t1); margin:26px 0;
}

/* ===== Responsive ===== */
@media (max-width: 1020px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .matrixcard{ right:8px; bottom:-24px; }
  .ledger-row{ grid-template-columns:1fr; gap:18px; padding:36px 0; }
  .price-grid{ grid-template-columns:1fr; }
  .buyfacts{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 720px){
  .nav-links{ display:none; }
  section{ padding:68px 0; }
  .hero{ padding:64px 0 56px; }
  .band{ padding:38px 28px; }
  .band-stats{ gap:28px; flex-wrap:wrap; }
  .spec-row{ grid-template-columns:1fr; gap:6px; }
  .buyfacts{ grid-template-columns:1fr; }
  .hero-facts{ gap:14px; }
}
