/* ============================================================
   LOUPE — optical inspection bench
   Fraunces (display) · Hanken Grotesk (UI) · JetBrains Mono (data)
   ============================================================ */

:root{
  --bg:        #0b0b0d;
  --bg-2:      #0f0f12;
  --panel:     #131316;
  --panel-2:   #17171b;
  --line:      rgba(255,255,255,0.09);
  --line-soft: rgba(255,255,255,0.05);

  --ink:       #ece7db;       /* warm off-white */
  --ink-mut:   #9a958a;
  --ink-dim:   #6a665d;

  --gold:      #e6b450;
  --gold-2:    #f4cd78;
  --gold-deep: #b88a2e;

  --safe:   #46c46a;
  --warn:   #e0a93b;
  --danger: #f0584f;
  --info:   #7aa2d6;

  --r-lg: 18px;
  --r-md: 12px;
  --r-sm: 8px;

  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --f-disp: "Fraunces", Georgia, serif;
  --f-ui:   "Hanken Grotesk", system-ui, sans-serif;
  --f-mono: "JetBrains Mono", ui-monospace, monospace;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-ui);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
::selection{ background:var(--gold); color:#1a1407; }

/* ---------- atmosphere ---------- */
.bg-grid{
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--line-soft) 1px, transparent 1px),
    linear-gradient(90deg, var(--line-soft) 1px, transparent 1px);
  background-size:54px 54px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 78%);
}
.bg-grid::after{ /* warm lens glow */
  content:""; position:absolute; top:-20%; left:50%; transform:translateX(-50%);
  width:900px; height:620px;
  background:radial-gradient(closest-side, rgba(230,180,80,.16), transparent 70%);
  filter:blur(20px);
}
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.045; 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='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
main, .site-header, .site-footer{ position:relative; z-index:2; }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:28px;
  padding:16px clamp(18px,4vw,40px);
  backdrop-filter:blur(12px);
  background:linear-gradient(180deg, rgba(11,11,13,.86), rgba(11,11,13,.55));
  border-bottom:1px solid var(--line-soft);
}
.brand{ display:flex; align-items:center; gap:10px; }
.brand-mark{ color:var(--gold); display:grid; place-items:center; }
.brand-name{ font-family:var(--f-disp); font-weight:600; font-size:1.35rem; letter-spacing:.2px; }
.site-nav{ display:flex; gap:24px; margin-left:auto; font-size:.92rem; }
.site-nav a{ color:var(--ink-mut); transition:color .2s; }
.site-nav a:hover{ color:var(--ink); }
.header-badge{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-mut); border:1px solid var(--line); border-radius:100px; padding:6px 12px;
}
.header-badge .dot{ width:7px; height:7px; border-radius:50%; background:var(--safe);
  box-shadow:0 0 0 0 rgba(70,196,106,.5); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(70,196,106,.5);} 70%{box-shadow:0 0 0 7px rgba(70,196,106,0);} 100%{box-shadow:0 0 0 0 rgba(70,196,106,0);} }

/* ---------- shared ---------- */
.eyebrow{
  font-family:var(--f-mono); font-size:.74rem; letter-spacing:.22em; text-transform:uppercase;
  color:var(--gold); margin:0 0 14px;
}
.panel-label{
  font-family:var(--f-mono); font-size:.7rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-mut);
}
.panel-label.muted{ color:var(--ink-dim); }

/* ---------- hero ---------- */
.hero{
  max-width:var(--maxw); margin:0 auto;
  padding:clamp(48px,9vw,96px) clamp(18px,4vw,40px) 60px;
  display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(32px,5vw,64px); align-items:center;
}
.hero h1{
  font-family:var(--f-disp); font-weight:600; font-optical-sizing:auto;
  font-size:clamp(2.5rem,5.4vw,4.4rem); line-height:1.02; letter-spacing:-.018em; margin:0 0 22px;
}
.hero h1 em{ color:var(--gold-2); font-style:italic; }
.lede{ font-size:1.12rem; color:var(--ink-mut); max-width:38ch; margin:0 0 26px; }
.lede strong{ color:var(--ink); font-weight:600; }
.hero-points{ list-style:none; padding:0; margin:0; display:grid; gap:9px; font-size:.96rem; }
.hero-points li{ display:flex; align-items:center; gap:11px; color:var(--ink); }
.hero-points span{ color:var(--gold); font-size:.7rem; }

/* ---------- instrument ---------- */
.instrument{
  position:relative; background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line); border-radius:var(--r-lg);
  padding:20px; box-shadow:0 30px 80px -40px rgba(0,0,0,.9), inset 0 1px 0 rgba(255,255,255,.04);
}
.instrument-corners i{
  position:absolute; width:13px; height:13px; border:2px solid var(--gold); opacity:.55;
}
.instrument-corners i:nth-child(1){ top:9px; left:9px; border-right:0; border-bottom:0; }
.instrument-corners i:nth-child(2){ top:9px; right:9px; border-left:0; border-bottom:0; }
.instrument-corners i:nth-child(3){ bottom:9px; left:9px; border-right:0; border-top:0; }
.instrument-corners i:nth-child(4){ bottom:9px; right:9px; border-left:0; border-top:0; }
.instrument-head{ display:flex; justify-content:space-between; align-items:center; padding:2px 4px 12px; }

.dropzone{ position:relative; }
#input{
  width:100%; height:230px; resize:vertical;
  background:#0a0a0c; color:var(--ink); border:1px solid var(--line);
  border-radius:var(--r-md); padding:16px; font-family:var(--f-mono); font-size:.82rem; line-height:1.6;
  outline:none; transition:border-color .2s, box-shadow .2s;
}
#input::placeholder{ color:var(--ink-dim); }
#input:focus{ border-color:var(--gold-deep); box-shadow:0 0 0 3px rgba(230,180,80,.14); }
.drop-overlay{
  position:absolute; inset:0; display:none; place-items:center; border-radius:var(--r-md);
  background:rgba(230,180,80,.12); border:2px dashed var(--gold); color:var(--gold-2);
  font-family:var(--f-mono); letter-spacing:.1em; text-transform:uppercase; font-size:.8rem;
}
.dropzone.dragging .drop-overlay{ display:grid; }

.instrument-actions{ display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin-top:16px; }
.btn{
  font-family:var(--f-ui); font-weight:600; font-size:.95rem; cursor:pointer;
  border:none; border-radius:var(--r-sm); padding:12px 20px; display:inline-flex; align-items:center; gap:10px;
  transition:transform .12s var(--ease), box-shadow .2s, background .2s;
}
.btn-primary{ background:linear-gradient(180deg,var(--gold-2),var(--gold)); color:#241a06;
  box-shadow:0 10px 30px -12px rgba(230,180,80,.7); }
.btn-primary:hover{ transform:translateY(-1px); box-shadow:0 14px 34px -12px rgba(230,180,80,.85); }
.btn-primary:active{ transform:translateY(0); }
.loupe-spin{ width:14px; height:14px; border-radius:50%; border:2px solid rgba(36,26,6,.4); border-top-color:#241a06; display:inline-block; }
.btn-primary.busy .loupe-spin{ animation:spin .7s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.example-group{ display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.ex-label{ font-family:var(--f-mono); font-size:.72rem; color:var(--ink-dim); }
.btn-ghost{
  font-family:var(--f-mono); font-size:.76rem; cursor:pointer; color:var(--ink-mut);
  background:transparent; border:1px solid var(--line); border-radius:100px; padding:7px 13px;
  transition:color .2s, border-color .2s, background .2s;
}
.btn-ghost:hover{ color:var(--ink); border-color:var(--gold-deep); background:rgba(230,180,80,.07); }
.btn-clear{ margin-left:auto; }
.parse-error{
  margin:14px 4px 2px; font-family:var(--f-mono); font-size:.82rem; color:var(--danger);
  background:rgba(240,88,79,.08); border:1px solid rgba(240,88,79,.3); border-radius:var(--r-sm); padding:10px 12px;
}

/* ---------- report ---------- */
.report{
  max-width:var(--maxw); margin:0 auto; padding:20px clamp(18px,4vw,40px) 80px;
  animation:fadeUp .6s var(--ease) both;
}
@keyframes fadeUp{ from{ opacity:0; transform:translateY(24px);} to{ opacity:1; transform:none;} }
.report-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:20px;
  flex-wrap:wrap; border-top:1px solid var(--line); padding-top:30px; }
#report-title{ font-family:var(--f-disp); font-weight:600; font-size:clamp(1.6rem,3vw,2.3rem); margin:8px 0 4px; }
.report-sub{ color:var(--ink-mut); font-family:var(--f-mono); font-size:.82rem; margin:0; }
.report-actions{ display:flex; gap:10px; flex-wrap:wrap; }

.report-grid-top{ display:grid; grid-template-columns:auto 1fr; gap:26px; align-items:center; margin:30px 0 22px; }
.score-card{ position:relative; width:150px; height:150px; display:grid; place-items:center; }
.score-ring{ position:absolute; inset:0; transform:rotate(-90deg); }
.ring-track{ fill:none; stroke:var(--line); stroke-width:9; }
.ring-fill{ fill:none; stroke:var(--gold); stroke-width:9; stroke-linecap:round;
  stroke-dasharray:327; stroke-dashoffset:327; transition:stroke-dashoffset 1.1s var(--ease), stroke .6s; }
.score-num{ font-family:var(--f-disp); font-size:2.6rem; font-weight:600; line-height:1; }
.score-num small{ font-family:var(--f-mono); font-size:.8rem; color:var(--ink-mut); }
.score-label{ position:absolute; bottom:18px; font-family:var(--f-mono); font-size:.62rem; letter-spacing:.16em; color:var(--ink-mut); }
.verdict{ font-size:1.18rem; line-height:1.5; }
.verdict b{ font-family:var(--f-disp); font-weight:600; }
.verdict .v-tag{ display:inline-block; font-family:var(--f-mono); font-size:.72rem; letter-spacing:.1em;
  text-transform:uppercase; padding:4px 11px; border-radius:100px; margin-bottom:10px; }

.statstrip{ display:grid; grid-template-columns:repeat(auto-fit,minmax(120px,1fr)); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; margin-bottom:26px; }
.statstrip .stat{ background:var(--panel); padding:16px 18px; }
.statstrip .stat .v{ font-family:var(--f-disp); font-size:1.7rem; font-weight:600; display:block; }
.statstrip .stat .k{ font-family:var(--f-mono); font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-mut); }

/* cards */
.report-cols{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:20px; align-items:start; }
.report-cols > *{ min-width:0; }   /* let wide flow-map scroll instead of blowing out the grid track */
.card{ background:var(--panel); border:1px solid var(--line); border-radius:var(--r-md); padding:22px 24px; }
.card h3{ font-family:var(--f-ui); font-weight:600; font-size:1.02rem; margin:0 0 16px; display:flex; align-items:center; gap:10px; }
.card-ico{ color:var(--gold); font-size:1.05rem; }
.narrative{ font-size:1.02rem; line-height:1.65; margin:0 0 16px; color:var(--ink); }
.steps{ margin:0; padding-left:0; list-style:none; counter-reset:s; display:grid; gap:10px; }
.steps li{ counter-increment:s; position:relative; padding-left:38px; font-size:.92rem; color:var(--ink-mut); }
.steps li::before{ content:counter(s,decimal-leading-zero); position:absolute; left:0; top:0;
  font-family:var(--f-mono); font-size:.74rem; color:var(--gold); border:1px solid var(--line);
  width:26px; height:26px; border-radius:6px; display:grid; place-items:center; }
.steps li b{ color:var(--ink); font-weight:600; }

/* map */
.map-wrap{ width:100%; min-width:0; overflow:auto; border:1px solid var(--line-soft); border-radius:var(--r-sm);
  background:#0a0a0c; background-image:radial-gradient(var(--line-soft) 1px, transparent 1px); background-size:20px 20px; }
.map-node:hover .node-box{ filter:brightness(1.3); }
.step-flash{ animation:stepflash 1.6s var(--ease); }
@keyframes stepflash{ 0%,100%{ background:transparent; } 18%{ background:rgba(230,180,80,.16); } }
.map-wrap svg{ display:block; width:100%; height:auto; }
.map-hint{ font-family:var(--f-mono); font-size:.72rem; color:var(--ink-dim); margin:12px 0 0; }
.node-box{ rx:8; }
.edge{ fill:none; stroke:var(--ink-dim); stroke-width:1.6; opacity:.7; }
.edge-arrow{ fill:var(--ink-dim); opacity:.8; }

/* findings */
.findings{ display:grid; gap:10px; }
.finding{ display:grid; grid-template-columns:auto 1fr; gap:14px; align-items:start;
  border:1px solid var(--line); border-radius:var(--r-sm); padding:13px 15px; background:var(--panel-2); }
.finding .sev{ font-family:var(--f-mono); font-size:.62rem; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 8px; border-radius:5px; white-space:nowrap; align-self:start; margin-top:2px; }
.sev-critical{ background:rgba(240,88,79,.16); color:#ff8a82; border:1px solid rgba(240,88,79,.4); }
.sev-high{ background:rgba(240,88,79,.1); color:var(--danger); border:1px solid rgba(240,88,79,.3); }
.sev-medium{ background:rgba(224,169,59,.12); color:var(--warn); border:1px solid rgba(224,169,59,.3); }
.sev-low{ background:rgba(122,162,214,.12); color:var(--info); border:1px solid rgba(122,162,214,.3); }
.sev-ok{ background:rgba(70,196,106,.12); color:var(--safe); border:1px solid rgba(70,196,106,.3); }
.finding .f-body b{ font-weight:600; }
.finding .f-where{ font-family:var(--f-mono); font-size:.74rem; color:var(--ink-mut); margin-top:4px; word-break:break-word; }
.finding .f-where code{ color:var(--gold-2); background:rgba(230,180,80,.08); padding:1px 5px; border-radius:4px; }
.finding .f-rec{ font-size:.86rem; color:var(--ink-mut); margin-top:6px; }

/* readiness */
.readiness{ display:grid; gap:18px; }
.ready-group h4{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase;
  color:var(--ink-mut); margin:0 0 9px; }
.ready-group ul{ list-style:none; margin:0; padding:0; display:grid; gap:7px; }
.ready-group li{ display:flex; align-items:center; gap:10px; font-size:.92rem; }
.ready-group li .chip{ font-family:var(--f-mono); font-size:.7rem; color:var(--gold-2);
  border:1px solid var(--line); border-radius:5px; padding:2px 7px; }
.ready-empty{ color:var(--ink-dim); font-size:.9rem; }

/* cost */
.cost-big{ font-family:var(--f-disp); font-size:2.6rem; font-weight:600; line-height:1; }
.cost-big small{ font-family:var(--f-ui); font-size:1rem; color:var(--ink-mut); font-weight:400; }
.cost-row{ display:flex; justify-content:space-between; padding:9px 0; border-bottom:1px solid var(--line-soft);
  font-size:.9rem; }
.cost-row:last-child{ border-bottom:0; }
.cost-row .k{ color:var(--ink-mut); }
.cost-note{ font-size:.84rem; color:var(--ink-dim); margin-top:12px; }

.report-footnote{ font-family:var(--f-mono); font-size:.74rem; color:var(--ink-dim); text-align:center;
  margin:32px auto 0; max-width:60ch; line-height:1.6; }

/* verdict + legend */
.verdict-wrap{ display:flex; flex-direction:column; gap:16px; }
.score-legend{ display:flex; flex-wrap:wrap; gap:18px; font-family:var(--f-mono); font-size:.72rem; color:var(--ink-mut); }
.score-legend span{ display:inline-flex; align-items:center; gap:7px; }
.score-legend i{ width:9px; height:9px; border-radius:50%; display:inline-block; }
.dot-danger{ background:var(--danger); } .dot-warn{ background:var(--warn); } .dot-safe{ background:var(--safe); }

/* next steps */
.nextsteps{ border:1px solid var(--line); border-left:3px solid var(--gold); border-radius:var(--r-md);
  background:linear-gradient(180deg, rgba(230,180,80,.06), transparent); padding:22px 24px; margin-bottom:26px; }
.nextsteps h3{ font-family:var(--f-ui); font-weight:600; font-size:1.02rem; margin:0 0 14px; display:flex; align-items:center; gap:10px; }
.nextsteps ol{ margin:0; padding:0; list-style:none; counter-reset:ns; display:grid; gap:11px; }
.nextsteps li{ counter-increment:ns; display:grid; grid-template-columns:auto 1fr; gap:13px; align-items:start; font-size:.96rem; }
.nextsteps li .ns-i{ font-family:var(--f-mono); font-size:.72rem; color:var(--gold); border:1px solid var(--line);
  width:26px; height:26px; border-radius:6px; display:grid; place-items:center; flex:0 0 auto; }
.nextsteps li b{ color:var(--gold-2); font-weight:600; }

/* badge panel */
.badge-panel{ display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:center;
  border:1px solid var(--line); border-radius:var(--r-md); background:var(--panel); padding:22px 24px; margin-bottom:8px; }
.badge-preview{ display:grid; place-items:center; min-width:200px; }
.badge-tools p{ margin:0 0 12px; color:var(--ink-mut); font-size:.94rem; }
.badge-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:12px; }
.badge-snippet{ display:block; font-family:var(--f-mono); font-size:.74rem; color:var(--ink-mut);
  background:#0a0a0c; border:1px solid var(--line); border-radius:var(--r-sm); padding:11px 13px; word-break:break-all; }

/* how-to-get */
.how-to-get{ margin-top:12px; border:1px solid var(--line-soft); border-radius:var(--r-sm); }
.how-to-get summary{ cursor:pointer; list-style:none; padding:10px 14px; font-family:var(--f-mono);
  font-size:.78rem; color:var(--ink-mut); display:flex; align-items:center; gap:8px; }
.how-to-get summary::-webkit-details-marker{ display:none; }
.how-to-get summary::before{ content:"?"; color:var(--gold); border:1px solid var(--line); border-radius:50%;
  width:18px; height:18px; display:grid; place-items:center; font-size:.7rem; }
.how-to-get[open] summary{ border-bottom:1px solid var(--line-soft); }
.how-to-get-body{ padding:12px 14px; }
.how-to-get-body p{ margin:0 0 8px; font-size:.86rem; color:var(--ink-mut); }
.how-to-get-body p:last-child{ margin-bottom:0; }
.how-to-get-body b{ color:var(--ink); }

/* ---------- bands ---------- */
.band{ border-top:1px solid var(--line-soft); }
.band-inner{ max-width:var(--maxw); margin:0 auto; padding:clamp(56px,9vw,104px) clamp(18px,4vw,40px); }
.band-title{ font-family:var(--f-disp); font-weight:600; font-size:clamp(1.9rem,4vw,3rem);
  letter-spacing:-.015em; line-height:1.05; margin:0 0 40px; max-width:18ch; }

.why-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:26px; }
.why-grid article{ border-left:2px solid var(--gold-deep); padding-left:18px; }
.why-num{ font-family:var(--f-disp); font-size:2rem; font-weight:600; color:var(--gold-2); display:block; margin-bottom:8px; }
.why-grid p{ color:var(--ink-mut); margin:0; font-size:.96rem; }
.why-foot{ font-family:var(--f-disp); font-size:1.4rem; margin:46px 0 0; color:var(--ink); }
.why-foot em{ color:var(--gold-2); }

.how-steps{ list-style:none; margin:0; padding:0; display:grid; grid-template-columns:repeat(3,1fr); gap:26px; counter-reset:h; }
.how-steps li{ position:relative; padding-top:18px; border-top:1px solid var(--line); }
.how-n{ font-family:var(--f-mono); font-size:.8rem; color:var(--gold); letter-spacing:.1em; }
.how-steps h3{ font-family:var(--f-disp); font-weight:600; font-size:1.3rem; margin:14px 0 8px; }
.how-steps p{ color:var(--ink-mut); margin:0; font-size:.94rem; }

.checks-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; }
.check{ background:var(--bg-2); padding:28px 26px; transition:background .25s; }
.check:hover{ background:var(--panel-2); }
.check h3{ font-family:var(--f-disp); font-weight:600; font-size:1.22rem; margin:0 0 10px; }
.check h3::before{ content:"◆"; color:var(--gold); font-size:.7rem; margin-right:10px; vertical-align:middle; }
.check p{ color:var(--ink-mut); margin:0; font-size:.93rem; }

.privacy-inner{ display:flex; gap:36px; align-items:center; flex-wrap:wrap; }
.privacy-glyph{ color:var(--gold); flex:0 0 auto; opacity:.85; }
.privacy-copy{ color:var(--ink-mut); font-size:1.05rem; max-width:62ch; margin:0; }

.faq-list{ display:grid; gap:0; }
.faq-list details{ border-top:1px solid var(--line); padding:20px 0; }
.faq-list details:last-child{ border-bottom:1px solid var(--line); }
.faq-list summary{ font-family:var(--f-disp); font-size:1.2rem; cursor:pointer; list-style:none;
  display:flex; justify-content:space-between; align-items:center; gap:16px; }
.faq-list summary::-webkit-details-marker{ display:none; }
.faq-list summary::after{ content:"+"; color:var(--gold); font-family:var(--f-mono); font-size:1.4rem; transition:transform .25s; }
.faq-list details[open] summary::after{ transform:rotate(45deg); }
.faq-list p{ color:var(--ink-mut); margin:14px 0 0; max-width:75ch; }

/* ---------- footer ---------- */
.site-footer{ border-top:1px solid var(--line); background:var(--bg-2); }
.footer-inner{ max-width:var(--maxw); margin:0 auto; padding:48px clamp(18px,4vw,40px); text-align:center; }
.footer-brand{ display:inline-flex; align-items:center; gap:9px; color:var(--gold);
  font-family:var(--f-disp); font-size:1.3rem; font-weight:600; }
.footer-brand span:last-child{ color:var(--ink); }
.footer-tag{ font-family:var(--f-disp); font-style:italic; font-size:1.1rem; color:var(--ink-mut); margin:10px 0 18px; }
.footer-fine{ font-family:var(--f-mono); font-size:.72rem; color:var(--ink-dim); max-width:70ch; margin:0 auto; line-height:1.7; }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(20px); animation:reveal .7s var(--ease) forwards; animation-delay:calc(var(--d,0) * .1s); }
@keyframes reveal{ to{ opacity:1; transform:none; } }

/* ---------- responsive ---------- */
@media (max-width:920px){
  .hero{ grid-template-columns:1fr; }
  .report-cols{ grid-template-columns:1fr; }
  .how-steps{ grid-template-columns:1fr; }
  .checks-grid{ grid-template-columns:1fr 1fr; }
  .report-grid-top{ grid-template-columns:1fr; justify-items:center; text-align:center; }
  .verdict-wrap{ align-items:center; }
  .badge-panel{ grid-template-columns:1fr; text-align:center; }
  .badge-preview{ min-width:0; }
  .site-nav{ display:none; }
}
@media (max-width:540px){
  .header-badge{ display:none; }
  .report-grid-top{ justify-items:start; text-align:left; }
  .verdict-wrap{ align-items:flex-start; }
  .checks-grid{ grid-template-columns:1fr; }
  .instrument-actions{ gap:10px; }
  .btn-clear{ margin-left:0; }
}
@media print{
  .site-header,.hero,.band,.site-footer,.report-actions,.grain,.bg-grid{ display:none !important; }
  body{ background:#fff; color:#111; }
  .card,.statstrip{ break-inside:avoid; }
}
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto; }
  .reveal{ opacity:1; transform:none; }
}
