/* ═══ Reset + tokens ═══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--fg);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.55;
  overflow-x:hidden;
}
:root{
  --bg:#07081a;
  --bg-2:#0c0e24;
  --panel:#10122a;
  --panel-2:#161937;
  --panel-hi:#1b1f46;
  --border:rgba(255,255,255,.08);
  --border-hi:rgba(255,255,255,.14);
  --fg:#e7e9f6;
  --fg-dim:#9fa3c5;
  --fg-muted:#6f7499;
  --brand:#7c5cff;
  --brand-2:#4ad3ff;
  --accent:#ffb34d;
  --good:#3ddc9d;
  --warn:#ffb34d;
  --bad:#ff6e7f;
  --shadow-glow:0 0 60px -10px rgba(124,92,255,.55);
  --radius:16px;
  --radius-lg:22px;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
::selection{background:rgba(124,92,255,.35);color:#fff}

a{color:inherit;text-decoration:none}
h1,h2,h3,h4{margin:0;line-height:1.15;letter-spacing:-.02em}
p{margin:0}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:0}
.hidden{display:none !important}

/* ═══ Nav ══════════════════════════════════════════════════════ */
.nav{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;gap:32px;
  padding:18px 32px;
  background:rgba(7,8,26,.7);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:17px;letter-spacing:-.01em}
.brand-mark{width:100px;height:100px;object-fit:contain;background:#07081a;border-radius:50%;padding:6px;box-sizing:border-box;box-shadow:0 0 18px rgba(124,92,255,.55),0 0 36px rgba(74,211,255,.35)}
.brand-dot{color:var(--brand-2)}
.nav-links{display:flex;gap:28px;margin-left:20px;color:var(--fg-dim);font-size:14px;font-weight:500}
.nav-links a{transition:color .18s,text-shadow .18s;position:relative;text-shadow:0 0 6px rgba(124,92,255,.35),0 0 14px rgba(74,211,255,.2)}
.nav-links a::after{
  content:'';
  position:absolute;
  left:0;
  right:0;
  bottom:-2px;
  height:1px;
  background:rgba(124,92,255,.5);
  box-shadow:0 0 6px rgba(124,92,255,.7), 0 0 12px rgba(74,211,255,.3);
  pointer-events:none;
  animation:navDividerPulse 2.8s ease-in-out infinite;
}
.nav-links a:nth-child(1)::after{animation-delay:0s}
.nav-links a:nth-child(2)::after{animation-delay:.18s}
.nav-links a:nth-child(3)::after{animation-delay:.36s}
.nav-links a:nth-child(4)::after{animation-delay:.54s}
.nav-links a:nth-child(5)::after{animation-delay:.72s}
.nav-links a:nth-child(6)::after{animation-delay:.9s}
.nav-links a:nth-child(7)::after{animation-delay:1.08s}
.nav-links a:nth-child(8)::after{animation-delay:1.26s}
.nav-links a:nth-child(9)::after{animation-delay:1.44s}
.nav-links a:nth-child(10)::after{animation-delay:1.62s}
.nav-links a:nth-child(11)::after{animation-delay:1.8s}
.nav-links a:nth-child(12)::after{animation-delay:1.98s}
@keyframes navDividerPulse{
  0%,100%{
    background:rgba(124,92,255,.15);
    box-shadow:0 0 2px rgba(124,92,255,.2), 0 0 4px rgba(74,211,255,.1);
  }
  50%{
    background:rgba(180,150,255,.95);
    box-shadow:0 0 10px rgba(124,92,255,.95), 0 0 22px rgba(74,211,255,.7), 0 0 38px rgba(124,92,255,.35);
  }
}
.nav-links a:hover{color:#fff;text-shadow:0 0 10px rgba(124,92,255,.85),0 0 22px rgba(74,211,255,.55),0 0 36px rgba(124,92,255,.3)}
.nav-cta{margin-left:auto;display:flex;align-items:center;gap:10px}

/* Floating "Scan my site" CTA — moved out of the header next to EN/TR to avoid
   the click-target collision + visual crowding the user reported. Bottom-right
   so it stays visible without fighting the language toggle. */
.scan-fab{
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:60;
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 20px;
  border-radius:999px;
  font-weight:700;font-size:14px;letter-spacing:.01em;
  color:#fff;
  background:linear-gradient(135deg,var(--brand) 0%,#5e82ff 55%,var(--brand-2) 100%);
  box-shadow:0 14px 36px -10px rgba(124,92,255,.75), 0 0 0 1px rgba(255,255,255,.06);
  transition:transform .15s ease, box-shadow .2s ease, opacity .2s ease;
}
.scan-fab::before{
  content:"";
  width:8px;height:8px;border-radius:50%;
  background:#fff;
  box-shadow:0 0 10px rgba(255,255,255,.9);
  animation:scanFabPulse 1.8s ease-in-out infinite;
}
.scan-fab:hover{transform:translateY(-2px);box-shadow:0 18px 44px -10px rgba(124,92,255,.9)}
.scan-fab:active{transform:translateY(0)}
@keyframes scanFabPulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%    {opacity:.55;transform:scale(1.25)}
}
@media (max-width:640px){
  .scan-fab{right:14px;bottom:14px;padding:10px 16px;font-size:13px}
}
/* Hide during PDF capture so it doesn't land on the rendered report. */
.pdf-rendering ~ .scan-fab, body:has(.pdf-rendering) .scan-fab{display:none}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 18px;border-radius:12px;
  font-size:14px;font-weight:600;
  transition:transform .1s ease,box-shadow .2s,background .2s,border-color .2s;
  border:1px solid transparent;
}
.btn-ghost{background:rgba(255,255,255,.04);border-color:var(--border)}
.btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--border-hi)}
.btn-primary{
  background:linear-gradient(135deg,var(--brand) 0%,#5e82ff 55%,var(--brand-2) 100%);
  color:#fff;box-shadow:0 10px 30px -10px rgba(124,92,255,.7);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 14px 40px -10px rgba(124,92,255,.85)}
.btn-primary:active{transform:translateY(0)}
.btn-arrow{width:18px;height:18px;transition:transform .2s}
.btn-primary:hover .btn-arrow{transform:translateX(3px)}

/* ═══ Hero ═════════════════════════════════════════════════════ */
.hero{
  position:relative;overflow:hidden;
  padding:90px 32px 60px;
  text-align:center;
}
.hero-orbs{position:absolute;inset:0;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55}
.o1{width:520px;height:520px;background:radial-gradient(circle,var(--brand) 0%,transparent 60%);top:-80px;left:-120px}
.o2{width:480px;height:480px;background:radial-gradient(circle,var(--brand-2) 0%,transparent 60%);top:20%;right:-140px}
.o3{width:420px;height:420px;background:radial-gradient(circle,#ff6bd6 0%,transparent 60%);bottom:-120px;left:30%;opacity:.35}
.hero-inner{position:relative;max-width:920px;margin:0 auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:6px 14px;border-radius:99px;
  background:rgba(255,255,255,.05);
  border:1px solid var(--border);
  font-size:12.5px;color:var(--fg-dim);font-weight:500;
  margin-bottom:22px;
}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:#ff4d4d;box-shadow:0 0 12px #ff4d4d;animation:dotCycle 4.5s ease-in-out infinite}
@keyframes dotCycle{
  0%  {background:#ff4d4d;box-shadow:0 0 12px #ff4d4d}
  33% {background:#ffd84d;box-shadow:0 0 12px #ffd84d}
  66% {background:#4ad3ff;box-shadow:0 0 12px #4ad3ff}
  100%{background:#ff4d4d;box-shadow:0 0 12px #ff4d4d}
}
.eyebrow.dark{background:rgba(0,0,0,.25)}
.h1{font-size:clamp(34px,5.2vw,64px);font-weight:800;letter-spacing:-.035em}
.grad{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 60%,#ff6bd6 110%);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-sub{margin:22px auto 0;max-width:680px;color:var(--fg-dim);font-size:17px}
.scan{margin:36px auto 18px;max-width:720px}
.scan-row{
  display:grid;grid-template-columns:auto 1.3fr 1fr auto;gap:8px;align-items:center;
  background:rgba(17,20,49,.72);border:1px solid var(--border-hi);
  padding:8px;border-radius:16px;
  box-shadow:0 25px 60px -20px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.04);
}
.scan-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;color:var(--fg-dim)}
.scan-icon svg{width:18px;height:18px}
.scan-row input{
  background:transparent;border:0;color:#fff;font-size:15px;font-weight:500;
  padding:10px 6px;outline:0;min-width:0;
}
.scan-row input::placeholder{color:var(--fg-muted)}
.scan-row input:not(:last-of-type){border-right:1px solid var(--border)}
.scan-hint{margin-top:10px;color:var(--fg-muted);font-size:12.5px}
.trust-row{display:flex;justify-content:center;gap:44px;margin-top:40px;flex-wrap:wrap}
.trust-item{display:flex;flex-direction:column;align-items:center}
.trust-item b{font-size:26px;font-weight:700;color:#fff}
.trust-item span{font-size:12px;color:var(--fg-muted);margin-top:2px;letter-spacing:.06em;text-transform:uppercase}

@media (max-width:720px){
  .nav{padding:14px 18px;gap:12px}
  .nav-links{display:none}
  .hero{padding:60px 18px 40px}
  .scan-row{grid-template-columns:auto 1fr;grid-auto-rows:auto}
  .scan-row input:not(:last-of-type){border-right:0;border-bottom:1px solid var(--border)}
  .scan-row .btn{grid-column:1/-1;justify-content:center}
}

/* ═══ Stage (scanning + report) ═══════════════════════════════ */
.stage{padding:0 32px 60px;min-height:120px}
.scanning{max-width:920px;margin:0 auto 40px}
.scan-card{
  background:linear-gradient(160deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--border-hi);
  border-radius:var(--radius-lg);
  padding:28px 28px 32px;
  box-shadow:0 40px 80px -40px rgba(0,0,0,.5);
}
.scan-title{font-size:16px;color:var(--fg-dim);margin-bottom:18px}
.scan-title b{color:#fff}
.scan-steps{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:8px}
.scan-steps li{
  display:flex;align-items:center;gap:10px;
  font-size:14px;color:var(--fg-muted);
  padding:8px 12px;border-radius:10px;
  transition:background .2s,color .2s;
}
.scan-steps li::before{
  content:'';width:12px;height:12px;border-radius:50%;
  border:2px solid var(--fg-muted);background:transparent;
  transition:border-color .2s,background .2s,box-shadow .2s;
}
.scan-steps li.active{color:#fff;background:rgba(124,92,255,.08)}
.scan-steps li.active::before{border-color:var(--brand);background:var(--brand);box-shadow:0 0 12px var(--brand)}
.scan-steps li.done{color:var(--fg-dim)}
.scan-steps li.done::before{border-color:var(--good);background:var(--good)}
.scan-bar{width:100%;height:4px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.scan-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--brand) 0%,var(--brand-2) 100%);transition:width .5s ease}

/* ═══ Report ═══════════════════════════════════════════════════ */
.report{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;gap:24px}

.report-head{
  display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:center;
  background:linear-gradient(160deg,var(--panel) 0%,var(--panel-hi) 100%);
  border:1px solid var(--border-hi);
  border-radius:var(--radius-lg);
  padding:28px 32px;
  box-shadow:0 40px 80px -40px rgba(0,0,0,.5);
}
.score-ring{position:relative;width:160px;height:160px}
.score-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.score-ring .ring-bg{fill:none;stroke:rgba(255,255,255,.06);stroke-width:12}
.score-ring .ring-fg{fill:none;stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset 1.1s cubic-bezier(.2,.8,.2,1)}
.score-ring .ring-val{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  flex-direction:column;font-weight:800;
}
.score-ring .ring-num{font-size:46px;letter-spacing:-.04em;line-height:1}
.score-ring .ring-lab{font-size:11px;color:var(--fg-muted);letter-spacing:.12em;text-transform:uppercase;margin-top:6px}
.grade-A .ring-fg{stroke:url(#gA)}
.grade-B .ring-fg{stroke:url(#gB)}
.grade-C .ring-fg{stroke:url(#gC)}
.grade-D .ring-fg{stroke:url(#gD)}
.grade-F .ring-fg{stroke:url(#gF)}
.grade-pill{
  display:inline-block;padding:4px 10px;border-radius:99px;
  font-size:12px;font-weight:700;letter-spacing:.05em;
  background:rgba(255,255,255,.06);border:1px solid var(--border);
  margin-left:10px;vertical-align:middle;
}
.grade-pill.A{color:#12c58c;border-color:rgba(61,220,157,.35)}
.grade-pill.B{color:#6fb6ff;border-color:rgba(111,182,255,.35)}
.grade-pill.C{color:#ffd36b;border-color:rgba(255,211,107,.35)}
.grade-pill.D{color:#ffa673;border-color:rgba(255,166,115,.35)}
.grade-pill.F{color:#ff6e7f;border-color:rgba(255,110,127,.4)}

.report-headline .domain-row{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--fg-muted)}
.report-headline h2{font-size:26px;margin-top:4px;letter-spacing:-.02em}
.report-headline .summary{color:var(--fg-dim);margin-top:6px;font-size:15px}
.report-headline .meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.meta-chip{
  font-size:11.5px;padding:5px 10px;border-radius:99px;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--fg-dim);font-weight:500;
}
.meta-chip b{color:#fff;margin-left:4px}

/* Score meaning explainer */
.score-meaning{
  background:rgba(124,92,255,.06);border:1px solid rgba(124,92,255,.28);
  border-radius:12px;padding:16px 20px;margin:12px 0 18px;
}
.score-meaning h4{margin:0 0 8px;font-size:14px;color:#c6bcff;letter-spacing:.2px;font-weight:700}
.score-meaning p{margin:0 0 10px;font-size:13.5px;color:var(--fg-dim);line-height:1.55}
.score-meaning p b{color:var(--fg)}
.score-meaning .score-bands{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 6px}
.score-meaning .band{
  font:700 11.5px/1 'JetBrains Mono', monospace;letter-spacing:.3px;
  padding:5px 9px;border-radius:6px;
}
.score-meaning .band.A{background:rgba(92,255,157,.14);color:#5cff9d}
.score-meaning .band.B{background:rgba(92,255,157,.10);color:#a8e6b8}
.score-meaning .band.C{background:rgba(255,207,122,.14);color:#ffcf7a}
.score-meaning .band.D{background:rgba(255,180,84,.14);color:#ffb454}
.score-meaning .band.F{background:rgba(255,122,144,.14);color:#ff7a90}
.score-meaning .score-band-msg{margin-top:6px}
.score-meaning .score-how{margin-top:6px;font-size:13px;color:var(--fg-muted)}

/* Platform-specific score badges (one per LLM) */
.platform-scores{
  background:rgba(124,92,255,.05);border:1px solid rgba(124,92,255,.22);
  border-radius:14px;padding:18px 20px;margin:12px 0 18px;
}
.platform-scores-header{margin-bottom:14px}
.platform-scores-title{
  margin:0 0 4px;font-size:15px;color:#d4ccff;letter-spacing:.2px;font-weight:700;
}
.platform-scores-sub{
  margin:0;font-size:12.5px;color:var(--fg-muted);line-height:1.5;
}
.platform-scores-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:4px 0 12px;
}
@media (max-width:760px){
  .platform-scores-grid{grid-template-columns:repeat(2,1fr)}
}
.platform-badge{
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);
  border-radius:10px;padding:12px 10px;text-align:center;
  transition:transform .12s ease,border-color .12s ease;
}
.platform-badge:hover{transform:translateY(-1px);border-color:rgba(124,92,255,.5)}
.platform-badge-head{
  display:flex;align-items:center;justify-content:center;gap:5px;
  margin-bottom:6px;
}
.platform-badge-icon{
  font-size:14px;color:#b8a9ff;font-weight:700;
}
.platform-badge-label{
  font:700 11px/1.2 'JetBrains Mono',monospace;color:#d4ccff;letter-spacing:.3px;
  text-transform:uppercase;
}
.platform-badge-score{
  font:800 26px/1 'Inter',sans-serif;margin:4px 0;letter-spacing:-.02em;
  color:var(--fg);
}
.platform-badge.band-A .platform-badge-score{color:#5cff9d}
.platform-badge.band-B .platform-badge-score{color:#a8e6b8}
.platform-badge.band-C .platform-badge-score{color:#ffcf7a}
.platform-badge.band-D .platform-badge-score{color:#ffb454}
.platform-badge.band-F .platform-badge-score{color:#ff7a90}
.platform-badge-delta{
  font:600 10.5px/1 'JetBrains Mono',monospace;letter-spacing:.2px;
  color:var(--fg-muted);margin-top:3px;
}
.platform-badge-delta.up{color:#5cff9d}
.platform-badge-delta.down{color:#ff7a90}
.platform-badge-delta.flat{color:var(--fg-muted)}
.platform-scores-insight{
  margin:8px 2px 0;font-size:12.5px;color:var(--fg-dim);line-height:1.55;
}
.platform-scores-insight b{color:var(--fg)}

/* Component grid */
.section-title{
  display:flex;align-items:baseline;justify-content:space-between;gap:12px;
  margin:4px 2px -4px;
}
.section-title h3{font-size:18px;letter-spacing:-.015em}
.section-title .sub{color:var(--fg-muted);font-size:13px}

.components{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.comp{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius);padding:18px 20px;
  display:flex;flex-direction:column;gap:10px;
  position:relative;overflow:hidden;
}
.comp::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--brand) 0%,var(--brand-2) 100%);
  opacity:.8;
}
.comp-head{display:flex;align-items:center;justify-content:space-between}
.comp-name{font-weight:600;font-size:14px}
.comp-weight{font-size:11px;color:var(--fg-muted);letter-spacing:.05em;text-transform:uppercase}
.comp-score{display:flex;align-items:baseline;gap:6px}
.comp-score b{font-size:28px;font-weight:700;letter-spacing:-.02em}
.comp-score i{font-style:normal;color:var(--fg-muted);font-size:12px}
.comp-bar{height:6px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.comp-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-2));transition:width 1s ease}
.comp-reasons{font-size:12.5px;color:var(--fg-dim);display:flex;flex-direction:column;gap:4px;margin-top:4px}
.comp-reasons li{list-style:none;padding-left:12px;position:relative}
.comp-reasons li::before{content:'';position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--fg-muted)}

/* Degraded-mode cluster (bag-of-words fallback) */
.comp-degraded{border-color:rgba(255,170,60,.32)}
.comp-degraded::before{background:linear-gradient(180deg,#ffb34a 0%,#ff7a90 100%)}
.comp-badge-bow{
  display:inline-block;margin-left:8px;padding:2px 7px;border-radius:999px;
  font-size:10px;letter-spacing:.04em;font-weight:700;
  color:#0f1220;background:#ffc36a;border:1px solid #ffb34a;
  vertical-align:middle;cursor:help;
}
.comp-degraded-hint{
  margin-top:8px;padding:8px 10px;border-radius:8px;
  background:rgba(255,170,60,.06);border:1px dashed rgba(255,170,60,.4);
  font-size:11.5px;color:#f4c27a;line-height:1.45;
}
.probe-warn{
  margin:10px 0 14px;padding:12px 14px;border-radius:10px;
  background:rgba(255,170,60,.06);border:1px solid rgba(255,170,60,.4);
  color:#f4c27a;font-size:13px;line-height:1.55;
}

/* LLM probe panel */
.probes{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:22px 24px;
}
.probe-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:16px}
.probe-card{
  background:var(--panel-2);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px 18px;
}
.probe-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.probe-dot{width:10px;height:10px;border-radius:50%}
.probe-dot.chatgpt{background:#10a37f;box-shadow:0 0 10px #10a37f}
.probe-dot.claude{background:#cc785c;box-shadow:0 0 10px #cc785c}
.probe-dot.gemini{background:#4285f4;box-shadow:0 0 10px #4285f4}
.probe-name{font-weight:600;font-size:14px}
.probe-stats{display:flex;gap:14px;margin-bottom:12px;flex-wrap:wrap}
.probe-stat{font-size:12px;color:var(--fg-muted)}
.probe-stat b{color:#fff;font-size:16px;font-weight:700;display:block;letter-spacing:-.01em}
.probe-queries{max-height:240px;overflow:auto;display:flex;flex-direction:column;gap:6px;padding-right:4px}
.pq{
  display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;
  padding:8px 10px;border-radius:10px;
  background:rgba(255,255,255,.02);border:1px solid var(--border);
  font-size:12.5px;
}
.pq-q{color:var(--fg-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pq-tag{font-size:10.5px;padding:3px 8px;border-radius:99px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.pq-tag.cited{background:rgba(61,220,157,.12);color:var(--good);border:1px solid rgba(61,220,157,.3)}
.pq-tag.mention{background:rgba(255,179,77,.1);color:var(--warn);border:1px solid rgba(255,179,77,.28)}
.pq-tag.miss{background:rgba(255,110,127,.08);color:var(--bad);border:1px solid rgba(255,110,127,.25)}
.pq-pos{font-family:var(--mono);font-size:11px;color:var(--fg-muted)}

/* RAG readiness checklist */
.rag-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:18px}
.rag-col{
  background:var(--panel-2);border:1px solid var(--border);
  border-radius:var(--radius);padding:16px 18px;
}
.rag-col-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.rag-col-title{font-weight:600;font-size:14px}
.rag-col-count{font-family:var(--mono);font-size:12px;color:var(--brand-2);padding:2px 8px;border-radius:99px;background:rgba(74,211,255,.1);border:1px solid rgba(74,211,255,.25)}
.rag-col-hint{color:var(--fg-muted);font-size:11.5px;margin:4px 0 12px}
.rag-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.rag-item{
  display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;
  padding:9px 12px;border-radius:10px;
  background:rgba(255,255,255,.02);border:1px solid var(--border);
  font-size:12.5px;
  transition:transform .15s ease, border-color .2s ease, background .2s ease;
}
.rag-item:hover{transform:translateX(2px)}
.rag-item.ok{
  background:linear-gradient(90deg, rgba(61,220,157,.10) 0%, rgba(61,220,157,.02) 70%);
  border-color:rgba(61,220,157,.25);
}
.rag-item.ok:hover{border-color:rgba(61,220,157,.55)}
.rag-item.fail{
  background:linear-gradient(90deg, rgba(255,110,127,.08) 0%, rgba(255,110,127,.02) 70%);
  border-color:rgba(255,110,127,.22);
}
.rag-item.fail:hover{border-color:rgba(255,110,127,.55)}
.rag-tick{
  font-family:var(--mono);font-weight:800;font-size:13px;
  width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:6px;
  transition:box-shadow .25s ease, transform .2s ease;
}
.rag-item.ok .rag-tick{
  color:#0a1b14;
  background:linear-gradient(135deg,#3ddc9d 0%,#4ad3ff 100%);
  box-shadow:0 0 0 1px rgba(61,220,157,.55), 0 0 14px rgba(61,220,157,.55), 0 0 28px rgba(74,211,255,.35);
  animation:tick-pulse-ok 3.2s ease-in-out infinite;
}
.rag-item.fail .rag-tick{
  color:#2a0811;
  background:linear-gradient(135deg,#ff8a8a 0%,#ff6e7f 100%);
  box-shadow:0 0 0 1px rgba(255,110,127,.55), 0 0 14px rgba(255,110,127,.55), 0 0 28px rgba(255,138,138,.35);
  animation:tick-pulse-fail 3.6s ease-in-out infinite;
}
.rag-item.ok:hover .rag-tick{transform:scale(1.1);box-shadow:0 0 0 1px rgba(61,220,157,.75), 0 0 22px rgba(61,220,157,.85), 0 0 42px rgba(74,211,255,.55)}
.rag-item.fail:hover .rag-tick{transform:scale(1.1);box-shadow:0 0 0 1px rgba(255,110,127,.75), 0 0 22px rgba(255,110,127,.85), 0 0 42px rgba(255,138,138,.55)}
@keyframes tick-pulse-ok{
  0%,100%{box-shadow:0 0 0 1px rgba(61,220,157,.55), 0 0 10px rgba(61,220,157,.40), 0 0 20px rgba(74,211,255,.25)}
  50%    {box-shadow:0 0 0 1px rgba(61,220,157,.70), 0 0 18px rgba(61,220,157,.65), 0 0 36px rgba(74,211,255,.45)}
}
@keyframes tick-pulse-fail{
  0%,100%{box-shadow:0 0 0 1px rgba(255,110,127,.50), 0 0 10px rgba(255,110,127,.35), 0 0 20px rgba(255,138,138,.22)}
  50%    {box-shadow:0 0 0 1px rgba(255,110,127,.70), 0 0 18px rgba(255,110,127,.60), 0 0 36px rgba(255,138,138,.42)}
}
.rag-label{color:var(--fg);font-weight:500}
.rag-item.fail .rag-label{color:var(--fg-dim)}
.rag-detail{font-family:var(--mono);font-size:10.5px;color:var(--fg-muted);text-align:right;white-space:nowrap}
.rag-item.ok .rag-detail{color:rgba(61,220,157,.85)}
.rag-item.fail .rag-detail{color:rgba(255,110,127,.80)}

/* Intent decomposition */
.intents{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:18px}
.intent-card{
  background:var(--panel-2);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 16px;
}
.intent-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.intent-label{font-weight:600;font-size:13px}
.intent-count{
  font-family:var(--mono);font-size:11px;color:var(--brand-2);
  padding:2px 8px;border-radius:99px;background:rgba(74,211,255,.1);border:1px solid rgba(74,211,255,.25);
}
.intent-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.intent-list li{font-size:12.5px;color:var(--fg-dim);padding-left:12px;position:relative}
.intent-list li::before{content:'';position:absolute;left:0;top:8px;width:4px;height:4px;border-radius:50%;background:var(--brand)}
.intent-list li.more{color:var(--fg-muted);font-style:italic}
.intent-list li.more::before{background:var(--fg-muted)}

/* Entity authority graph */
.graph-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:18px}
@media (max-width:720px){.graph-grid{grid-template-columns:1fr}}
.graph-col-title{font-size:12px;color:var(--fg-muted);letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.graph-col-title b{color:var(--brand-2);text-transform:none;letter-spacing:0;font-size:13px}
.tag-list{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:6px}
.tag{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 10px;border-radius:99px;
  background:var(--panel-2);border:1px solid var(--border);
  font-size:12px;color:var(--fg);
}
.tag i{font-style:normal;color:var(--fg-muted);font-size:10.5px;font-family:var(--mono)}
.edge-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.edge{
  display:grid;grid-template-columns:1fr 2fr auto;gap:10px;align-items:center;
  padding:7px 10px;border-radius:8px;
  background:var(--panel-2);border:1px solid var(--border);
  font-size:12.5px;
}
.edge-name{color:var(--fg);font-weight:500}
.edge-bar{height:6px;background:rgba(255,255,255,.05);border-radius:4px;overflow:hidden;position:relative}
.edge-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-2))}
.edge-num{font-family:var(--mono);font-size:11px;color:var(--fg-muted);text-align:right}
.edge-list .empty{color:var(--fg-muted);font-size:12.5px;padding:10px 0}
.graph-note{margin-top:14px;font-size:12px;color:var(--fg-dim);padding:10px 12px;background:rgba(74,211,255,.06);border:1px solid rgba(74,211,255,.2);border-radius:8px}
.graph-note b{color:#fff}

/* Knowledge trust */
.trust-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;margin-top:18px}
.trust-cell{
  background:var(--panel-2);border:1px solid var(--border);
  border-radius:12px;padding:14px 16px;
  border-left:3px solid var(--fg-muted);
}
.trust-cell.good{border-left-color:var(--good)}
.trust-cell.bad{border-left-color:var(--bad)}
.trust-label{font-size:11.5px;color:var(--fg-muted);letter-spacing:.04em;text-transform:uppercase}
.trust-value{font-size:26px;font-weight:700;letter-spacing:-.02em;margin-top:6px;color:#fff}
.trust-state{font-size:11.5px;color:var(--fg-dim);margin-top:4px}
.trust-cell.good .trust-state{color:var(--good)}
.trust-cell.bad .trust-state{color:var(--bad)}

/* Fixes list */
.fixes{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:22px 24px;
}
.fix-list{display:flex;flex-direction:column;gap:10px;margin-top:14px;padding:0;list-style:none}

/* Princeton GEO tactic card — applied/unclaimed tactic audit with published uplifts. */
.princeton-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px 24px;margin-top:20px}
.princeton-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:12px}
@media (max-width:820px){.princeton-grid{grid-template-columns:1fr}}
.princeton-tactics{display:flex;flex-direction:column;gap:8px}
.princeton-row{display:grid;grid-template-columns:1fr 120px 56px;gap:10px;align-items:center;font-size:13px;padding:6px 0;border-bottom:1px dashed rgba(148,163,184,.12)}
.princeton-row:last-child{border-bottom:0}
.princeton-row.is-applied .princeton-name{color:var(--fg)}
.princeton-name{color:var(--fg-muted);display:flex;align-items:center;gap:8px}
.princeton-dot{width:8px;height:8px;border-radius:50%;background:rgba(148,163,184,.4);display:inline-block;flex:0 0 auto}
.princeton-dot.ok{background:#4ade80}
.princeton-dot.warn{background:#f59e0b}
.princeton-bar-wrap{background:rgba(15,23,42,.55);border-radius:4px;height:6px;overflow:hidden}
.princeton-bar{height:100%;background:linear-gradient(90deg,#4ad3ff,#7c5cff);border-radius:4px;transition:width .3s ease}
.princeton-row.is-penalty .princeton-bar{background:linear-gradient(90deg,#f87171,#fb923c)}
.princeton-uplift{text-align:right;font-variant-numeric:tabular-nums;font-size:12px;color:var(--fg-muted);font-family:var(--mono)}
.princeton-wins-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);margin-bottom:10px;font-weight:600}
.princeton-wins-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.princeton-win{display:grid;grid-template-columns:auto 1fr;gap:12px;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:10px}
.princeton-win-rank{font-family:var(--mono);font-weight:700;color:var(--fg-muted);font-size:13px}
.princeton-win-tactic{font-weight:600;font-size:13px;color:var(--fg);display:flex;align-items:center;gap:8px}
.princeton-win-lift{background:rgba(74,222,128,.14);color:#86efac;padding:1px 7px;border-radius:999px;font-size:11px;font-weight:700;font-family:var(--mono)}
.princeton-win-do{color:var(--fg-muted);font-size:12px;margin-top:4px;line-height:1.45}
.princeton-win-empty{color:var(--fg-muted);font-style:italic;font-size:13px;padding:8px 0}
.princeton-source{margin-top:12px;font-size:11px;color:var(--fg-muted);font-style:italic}
.fix{
  display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  padding:14px 16px;border-radius:12px;
  background:var(--panel-2);border:1px solid var(--border);
  transition:border-color .15s,background .15s,transform .1s;
}
.fix:hover{border-color:var(--border-hi);transform:translateY(-1px)}
.fix-rank{
  font-family:var(--mono);font-weight:700;font-size:14px;color:var(--fg-muted);
  width:28px;text-align:center;
}
.fix-text{font-size:14px;color:var(--fg)}
.fix-text small{display:block;color:var(--fg-muted);font-size:11.5px;margin-top:3px;letter-spacing:.04em;text-transform:uppercase}
.fix-impact{font-size:11px;font-weight:600;padding:5px 10px;border-radius:99px;color:var(--fg-dim);background:rgba(255,255,255,.04);border:1px solid var(--border);white-space:nowrap}

/* Sections below report */
.how,.model,.faq{padding:80px 32px;max-width:1100px;margin:0 auto}
.how-head,.model-head,.faq-head{text-align:center;max-width:720px;margin:0 auto 44px}
.h2{font-size:clamp(26px,3.4vw,40px);font-weight:800;letter-spacing:-.03em}
.h2-sub{margin-top:14px;color:var(--fg-dim);font-size:16px}

.how-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.how-card{
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:24px;
  position:relative;overflow:hidden;
  transition:border-color .15s,transform .15s;
}
.how-card:hover{border-color:var(--border-hi);transform:translateY(-2px)}
.how-num{font-family:var(--mono);font-size:12px;color:var(--brand-2);margin-bottom:10px;letter-spacing:.1em}
.how-card h3{font-size:17px;margin-bottom:8px}
.how-card p{color:var(--fg-dim);font-size:14px}

.model-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:24px}
.formula{
  background:#05060f;border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:24px;
  overflow:auto;
}
.formula pre{margin:0}
.formula code{font-family:var(--mono);font-size:13px;color:var(--fg-dim);line-height:1.7;white-space:pre}
.tok-name{color:#fff;font-weight:700}
.tok-key{color:var(--brand-2)}
.tok-num{color:var(--accent)}
.tok-comment{color:var(--fg-muted);font-style:italic}
.sig-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.sig-list li{
  background:var(--panel);border:1px solid var(--border);
  border-radius:12px;padding:14px 16px;
  font-size:14px;color:var(--fg-dim);
}
.sig-list b{color:#fff}
@media (max-width:780px){.model-grid{grid-template-columns:1fr}}

.faq-item{
  background:var(--panel);border:1px solid var(--border);
  border-radius:12px;padding:16px 20px;margin-bottom:10px;
  transition:border-color .15s;
}
.faq-item[open]{border-color:var(--border-hi)}
.faq-item summary{font-weight:600;cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:10px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-family:var(--mono);color:var(--fg-muted);font-size:20px;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg);color:var(--brand-2)}
.faq-item p{color:var(--fg-dim);margin-top:10px;font-size:14.5px}

/* Footer */
.foot{padding:40px 32px 60px;border-top:1px solid var(--border);margin-top:40px}
.foot-inner{max-width:1100px;margin:0 auto;display:flex;justify-content:space-between;gap:16px;color:var(--fg-muted);font-size:13px;flex-wrap:wrap}
.foot-tag{font-family:var(--mono);font-size:11.5px;letter-spacing:.08em;text-transform:uppercase}

/* ═══ Error ════════════════════════════════════════════════════ */
.err{
  background:rgba(255,110,127,.08);border:1px solid rgba(255,110,127,.35);
  color:#ffcfd4;padding:16px 20px;border-radius:14px;font-size:14px;
  max-width:720px;margin:0 auto;
}

/* ═══ Hard-filter banner + Penalty list ═══════════════════════════ */
.hard-filter{
  margin:20px 0 8px;padding:14px 18px;border-radius:var(--radius);
  font-size:14px;line-height:1.55;
}
.hard-filter.pass{
  background:rgba(61,220,157,.06);border:1px solid rgba(61,220,157,.30);color:#c6f3df;
}
.hard-filter.fail{
  background:rgba(255,110,127,.08);border:1px solid rgba(255,110,127,.35);color:#ffd7dc;
}
.hard-filter b{color:#fff}
.hard-filter ul{margin:8px 0 4px 20px;padding:0}
.hard-filter li{margin:2px 0;color:#ffc0c7}
.hard-filter small{display:block;margin-top:6px;color:var(--fg-muted);font-size:12.5px}

.penalty-list{list-style:none;padding:0;margin:10px 0 0;display:grid;gap:8px}
.penalty-list li{
  background:rgba(255,179,77,.06);border:1px solid rgba(255,179,77,.25);
  color:#ffe4b8;padding:10px 14px;border-radius:10px;font-size:13.5px;
}

/* ═══ Signals grid (ten-cluster card section on homepage) ═══════ */
.sig-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:14px;margin-top:28px;
}
.sig-card{
  background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius);padding:18px 18px 16px;
  transition:transform .2s ease, border-color .2s ease, box-shadow .25s ease;
  position:relative;overflow:hidden;
}
.sig-card::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(180px 80px at top left, rgba(124,92,255,.14), transparent 70%);
  pointer-events:none;opacity:0;transition:opacity .3s;
}
.sig-card:hover{transform:translateY(-3px);border-color:var(--border-hi);box-shadow:0 18px 50px -20px rgba(124,92,255,.35)}
.sig-card:hover::before{opacity:1}
.sig-card h3{
  font-size:14px;font-weight:600;margin-bottom:8px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.sig-card h3 span{
  font-family:var(--mono);font-size:11px;font-weight:600;
  color:var(--brand-2);padding:3px 9px;border-radius:99px;
  background:rgba(74,211,255,.1);border:1px solid rgba(74,211,255,.25);
}
.sig-card p{font-size:12.5px;color:var(--fg-dim);line-height:1.55}

/* ═══ Report toolbar (PDF export + actions) ═══════════════════ */
.report-actions{
  display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;
  margin:0 0 16px;
}
.rep-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:9px 14px;border-radius:10px;
  background:var(--panel-2);border:1px solid var(--border-hi);
  color:var(--fg);font-size:13px;font-weight:500;cursor:pointer;
  transition:transform .15s ease, border-color .2s ease, box-shadow .25s ease;
}
.rep-btn:hover{transform:translateY(-1px);border-color:var(--brand);box-shadow:0 0 0 1px rgba(124,92,255,.35), 0 0 24px -4px rgba(124,92,255,.35)}
.rep-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}
.rep-btn.primary{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-2) 100%);border-color:transparent;color:#0a0b1e;font-weight:600}
.rep-btn.primary:hover{box-shadow:0 0 0 1px rgba(124,92,255,.55), 0 0 30px -2px rgba(74,211,255,.55)}
.rep-btn[disabled]{opacity:.6;cursor:progress}

/* ═══ Copy-fix button + fix card enhancements ═════════════════ */
.fix{position:relative}
.fix-copy{
  position:absolute;top:10px;right:12px;
  display:inline-flex;align-items:center;gap:5px;
  padding:5px 9px;border-radius:7px;
  background:rgba(255,255,255,.04);border:1px solid var(--border);
  color:var(--fg-muted);font-size:11px;font-family:var(--mono);cursor:pointer;
  transition:all .2s ease;opacity:0;
}
.fix:hover .fix-copy{opacity:1}
.fix-copy:hover{color:#fff;border-color:var(--brand-2);background:rgba(74,211,255,.08)}
.fix-copy.copied{color:var(--good);border-color:rgba(61,220,157,.5);background:rgba(61,220,157,.1)}
.fix-copy svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2}

/* ═══ AI recommendations (Claude-generated) ═══════════════════ */
.recos{margin-top:28px}
.reco-list{display:grid;gap:12px;margin-top:14px;padding:0;list-style:none}
.reco{
  background:linear-gradient(135deg, rgba(124,92,255,.08) 0%, rgba(74,211,255,.04) 100%);
  border:1px solid rgba(124,92,255,.25);
  border-radius:var(--radius);padding:16px 18px;
  position:relative;
}
.reco-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.reco-badge{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;
  padding:3px 9px;border-radius:99px;color:#0a0b1e;font-weight:700;
  background:linear-gradient(135deg,#7c5cff 0%,#4ad3ff 100%);
  text-transform:uppercase;
}
.reco-cluster{font-size:12px;color:var(--fg-dim);font-weight:500}
.reco-title{font-size:14.5px;font-weight:600;margin-bottom:8px}
.reco-rewrite{
  font-family:var(--mono);font-size:12.5px;line-height:1.6;
  background:rgba(0,0,0,.25);border:1px solid var(--border);border-left:3px solid var(--brand-2);
  padding:12px 14px;border-radius:8px;color:#dfe3ff;white-space:pre-wrap;
}
.reco-why{font-size:12px;color:var(--fg-muted);margin-top:10px;font-style:italic}
.reco-empty{
  padding:18px;border:1px dashed var(--border-hi);border-radius:var(--radius);
  text-align:center;color:var(--fg-muted);font-size:13px;
}

/* RAG radar chart */
.rag-radar-wrap{
  display:grid;grid-template-columns:minmax(320px,400px) 1fr;gap:28px;align-items:center;
  padding:18px;margin-bottom:18px;
  background:linear-gradient(180deg,rgba(74,211,255,.04),rgba(61,220,157,.02));
  border:1px solid var(--border);border-radius:var(--radius);
}
@media (max-width:720px){
  .rag-radar-wrap{grid-template-columns:1fr}
}
.rag-radar{width:100%;max-width:400px;height:auto;display:block;margin:0 auto}
.radar-ring{fill:none;stroke:rgba(255,255,255,.07);stroke-width:1}
.radar-spoke{stroke:rgba(255,255,255,.05);stroke-width:1}
.radar-area{
  fill:url(#radarFill);
  stroke:#4ad3ff;stroke-width:1.6;stroke-linejoin:round;
  filter:drop-shadow(0 0 8px rgba(74,211,255,.45));
}
.radar-dot{stroke:#0b0d24;stroke-width:1.5}
.radar-dot.ok{fill:#3ddc9d;filter:drop-shadow(0 0 6px rgba(61,220,157,.8))}
.radar-dot.mid{fill:#f6c560;filter:drop-shadow(0 0 6px rgba(246,197,96,.8))}
.radar-dot.low{fill:#ff6b6b;filter:drop-shadow(0 0 6px rgba(255,107,107,.9))}
.radar-label{
  fill:#cfd4ff;font-size:11.5px;font-weight:600;
  font-family:var(--sans);letter-spacing:.02em;
}
.rag-radar-legend{display:flex;flex-direction:column;gap:10px}
.rag-radar-leg-item{
  display:grid;grid-template-columns:14px 1fr auto;gap:10px;align-items:center;
  padding:8px 10px;border-radius:8px;background:rgba(255,255,255,.02);
  border:1px solid var(--border);
}
.rag-radar-dot{
  width:10px;height:10px;border-radius:50%;
  background:linear-gradient(135deg,#ff6b6b,#f6c560 40%,#3ddc9d 80%);
  box-shadow:0 0 8px rgba(61,220,157,calc(var(--r, 0.5) * 0.9));
  transform:scale(calc(0.6 + var(--r, 0.5) * 0.6));
}
.rag-radar-leg-label{font-size:13px;color:#e6eaff;font-weight:500}
.rag-radar-leg-count{font-size:12px;color:var(--fg-muted);font-family:var(--mono)}

/* Competitor comparison panel */
.compare-panel{
  margin:0 0 18px;padding:16px 18px;
  background:linear-gradient(180deg,rgba(74,211,255,.05),rgba(61,220,157,.02));
  border:1px solid var(--border);border-radius:var(--radius);
}
.compare-panel.hidden{display:none}
.compare-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.compare-form input{
  flex:1;min-width:220px;padding:10px 12px;border-radius:8px;
  background:rgba(0,0,0,.25);border:1px solid var(--border-hi);color:var(--fg);
  font:14px/1.4 var(--sans);
}
.compare-form input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 2px rgba(74,211,255,.25)}
.compare-loading{margin-top:14px;color:var(--fg-muted);font-size:13px;text-align:center;padding:18px}
.compare-result:empty{display:none}
.cmp-head{
  display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center;
  padding:14px;margin-top:14px;border-radius:10px;
  background:rgba(0,0,0,.2);border:1px solid var(--border);
}
.cmp-head-cell{text-align:center}
.cmp-head-domain{font-size:13px;color:var(--fg-muted);margin-bottom:6px;word-break:break-all}
.cmp-head-score{
  font:700 40px/1 var(--sans);color:var(--fg);
  display:flex;flex-direction:column;align-items:center;gap:4px;
}
.cmp-head-grade{font-size:11px;font-weight:600;color:var(--fg-muted);letter-spacing:.04em}
.cmp-delta{
  padding:8px 14px;border-radius:999px;font-weight:600;font-size:13px;
  background:rgba(255,255,255,.05);border:1px solid var(--border);
  white-space:nowrap;
}
.cmp-delta.win{color:var(--good);background:rgba(61,220,157,.12);border-color:rgba(61,220,157,.3)}
.cmp-delta.lose{color:var(--bad);background:rgba(255,107,107,.12);border-color:rgba(255,107,107,.3)}
.cmp-delta.tie{color:var(--fg-muted)}
.cmp-body{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.cmp-row{
  display:grid;grid-template-columns:160px 1fr 1fr;gap:12px;align-items:center;
  padding:8px 10px;border-radius:8px;background:rgba(255,255,255,.02);
}
.cmp-row-label{font-size:12.5px;color:#cfd4ff;font-weight:500}
.cmp-cell{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center;padding:4px 6px;border-radius:6px}
.cmp-cell.win{background:rgba(61,220,157,.08);box-shadow:inset 0 0 0 1px rgba(61,220,157,.3)}
.cmp-cell.lose{opacity:.6}
.cmp-num{font:600 12px/1 var(--mono);color:#e6eaff;min-width:28px;text-align:right}
.cmp-foot{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;
  margin-top:12px;padding-top:12px;border-top:1px solid var(--border);
  font-size:12px;color:var(--fg-muted);
}
@media (max-width:640px){
  .cmp-row{grid-template-columns:1fr;gap:6px}
  .cmp-head{grid-template-columns:1fr}
  .cmp-delta{justify-self:center}
}

/* Multi-page crawl panel */
.crawl-panel{
  margin:0 0 18px;padding:16px 18px;
  background:linear-gradient(180deg,rgba(187,139,255,.05),rgba(74,211,255,.02));
  border:1px solid var(--border);border-radius:var(--radius);
}
.crawl-panel.hidden{display:none}
.crawl-head{margin-bottom:12px}
.crawl-title{font-weight:600;color:#e6eaff;font-size:14px}
.crawl-sub{color:var(--fg-muted);font-size:12px;margin-top:2px}
.crawl-summary{
  display:flex;gap:18px;flex-wrap:wrap;align-items:center;
  padding:14px;border-radius:10px;background:rgba(0,0,0,.2);border:1px solid var(--border);
  margin-bottom:14px;
}
.crawl-summary-main{display:flex;gap:24px;flex-wrap:wrap;width:100%;align-items:center}
.crawl-avg{
  font:700 44px/1 var(--sans);display:flex;flex-direction:column;gap:4px;
  padding-right:20px;border-right:1px solid var(--border);
}
.crawl-avg span{font:500 11px/1 var(--sans);color:var(--fg-muted);letter-spacing:.04em}
.crawl-range{display:flex;gap:14px;flex-wrap:wrap;flex:1}
.crawl-range-item{
  display:flex;flex-direction:column;gap:2px;padding:8px 12px;border-radius:8px;
  background:rgba(255,255,255,.02);border:1px solid var(--border);min-width:160px;
}
.crawl-range-item b{font-size:11px;letter-spacing:.04em;text-transform:uppercase}
.crawl-range-item.good b{color:var(--good)}
.crawl-range-item.bad b{color:var(--bad)}
.crawl-range-item span{font-size:12.5px;color:#e6eaff;font-family:var(--mono);word-break:break-all}
.crawl-table{
  width:100%;border-collapse:collapse;margin-top:4px;
  font-size:13px;
}
.crawl-table th{
  text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);
  color:var(--fg-muted);font-weight:500;font-size:11.5px;letter-spacing:.04em;text-transform:uppercase;
}
.crawl-table td{
  padding:12px;border-bottom:1px solid var(--border);
  color:#dfe3ff;vertical-align:top;
}
.crawl-table tr:last-child td{border-bottom:none}
.crawl-table a{color:var(--brand-2);text-decoration:none;word-break:break-all;font-family:var(--mono);font-size:12.5px}
.crawl-table a:hover{text-decoration:underline}
.crawl-title-text{color:var(--fg-muted);font-size:11.5px;margin-top:2px}
.crawl-score{font:700 15px/1 var(--sans)}
.crawl-weak{color:var(--fg-muted);font-size:12px}
@media (max-width:640px){
  .crawl-table th:nth-child(4),.crawl-table td:nth-child(4){display:none}
  .crawl-avg{font-size:32px}
}

/* Expanded AI-assistant panel banner */
.panel-banner{
  padding:18px;margin-bottom:18px;border-radius:var(--radius);
  background:
    radial-gradient(circle at 0% 0%,rgba(74,211,255,.12),transparent 40%),
    radial-gradient(circle at 100% 100%,rgba(187,139,255,.10),transparent 40%),
    rgba(0,0,0,.25);
  border:1px solid var(--border-hi);
}
.panel-banner-head{display:flex;gap:18px;align-items:center;margin-bottom:14px}
.panel-banner-count{
  font:800 44px/1 var(--sans);
  background:linear-gradient(135deg,#4ad3ff,#3ddc9d 60%,#bb8bff);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:0 0 24px rgba(74,211,255,.3);
}
.panel-banner-title{font-size:15px;font-weight:700;color:#e6eaff}
.panel-banner-sub{font-size:12.5px;color:var(--fg-muted);margin-top:2px;max-width:540px}
.panel-banner-chips{
  display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;
  padding:10px;border-radius:10px;background:rgba(0,0,0,.2);border:1px solid var(--border);
}
.panel-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px;border-radius:999px;
  font-size:11.5px;font-weight:500;letter-spacing:.01em;
  background:rgba(255,255,255,.04);border:1px solid var(--border);color:#cfd4ff;
  transition:background .2s,border-color .2s;
}
.panel-chip:hover{background:rgba(255,255,255,.08);border-color:var(--border-hi)}
.panel-chip-dot{width:6px;height:6px;border-radius:50%;background:#6b7299}
.panel-chip.live{border-color:rgba(61,220,157,.35);background:rgba(61,220,157,.08);color:#d7ffef}
.panel-chip.live .panel-chip-dot{background:#3ddc9d;box-shadow:0 0 8px rgba(61,220,157,.8)}
.panel-chip.est .panel-chip-dot{background:#bb8bff;box-shadow:0 0 6px rgba(187,139,255,.5)}
.panel-banner-legend{
  display:flex;gap:18px;flex-wrap:wrap;font-size:11.5px;color:var(--fg-muted);
}
.panel-banner-legend .dot{
  display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;vertical-align:middle;
}
.panel-banner-legend .dot.live{background:#3ddc9d;box-shadow:0 0 6px rgba(61,220,157,.7)}
.panel-banner-legend .dot.est{background:#bb8bff}

.probe-subhead{
  margin:18px 0 10px;font-size:12px;font-weight:600;
  color:#cfd4ff;letter-spacing:.06em;text-transform:uppercase;
}
.probe-subhead-hint{font-weight:400;color:var(--fg-muted);text-transform:none;letter-spacing:0}
.probe-grid.estimated .probe-card{background:rgba(187,139,255,.04);border-color:rgba(187,139,255,.15)}
.probe-card.is-estimate{opacity:.96}
.probe-badge{
  margin-left:auto;padding:2px 8px;border-radius:999px;
  font:700 9.5px/1.4 var(--sans);letter-spacing:.08em;
}
.probe-badge.live{color:#3ddc9d;background:rgba(61,220,157,.12);border:1px solid rgba(61,220,157,.3)}
.probe-badge.est{color:#bb8bff;background:rgba(187,139,255,.12);border:1px solid rgba(187,139,255,.3)}
.probe-family{
  font-size:10.5px;color:var(--fg-muted);letter-spacing:.04em;
  margin:4px 0 8px;text-transform:uppercase;font-weight:500;
}
.probe-reason{
  margin-top:10px;padding:8px 10px;border-radius:6px;
  background:rgba(187,139,255,.05);border-left:2px solid rgba(187,139,255,.4);
  font-size:11.5px;color:var(--fg-muted);font-style:italic;line-height:1.5;
}

/* Print-safe styles for html2pdf rendering */
@media print{
  .nav,.hero,.how,.model,.faq,.foot,.scanning{display:none !important}
  body{background:#fff;color:#111}
}
.pdf-rendering .rep-btn{visibility:hidden}
/* Kill all animations/transitions during PDF capture so html2canvas renders a stable frame. */
.pdf-rendering, .pdf-rendering *, .pdf-rendering *::before, .pdf-rendering *::after{
  animation:none !important;
  transition:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
/* html2canvas can't parse conic-gradient — flatten to solid cyan border ring during PDF. */
.pdf-rendering .fanout-ring{
  background:#0f1220 !important;
  border:3px solid #4ad3ff !important;
  box-shadow:none !important;
}

/* History / trend section */
.history-section{margin-top:28px}
.history-grid{display:grid;grid-template-columns:minmax(320px,1fr) 1.4fr;gap:14px}
@media (max-width:820px){.history-grid{grid-template-columns:1fr}}
.history-card{background:linear-gradient(180deg,rgba(20,28,42,.85),rgba(14,20,32,.7));border:1px solid rgba(120,140,180,.18);border-radius:14px;padding:16px}
.spark-card{display:flex;flex-direction:column;gap:10px}
.spark-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.spark-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#8aa;opacity:.8}
.spark-value{font-size:34px;font-weight:700;color:#fff;line-height:1.1}
.spark-deltas{display:flex;flex-direction:column;gap:6px;align-items:flex-end}
.spark-deltas > div{display:flex;align-items:center;gap:6px;font-size:12px}
.delta-chip{font-size:12px;font-weight:600;padding:2px 8px;border-radius:999px;display:inline-block}
.delta-chip.up{background:rgba(34,227,168,.15);color:#22e3a8;border:1px solid rgba(34,227,168,.35)}
.delta-chip.down{background:rgba(255,110,120,.15);color:#ff8a94;border:1px solid rgba(255,110,120,.35)}
.delta-chip.flat{background:rgba(160,170,190,.12);color:#b8c2d6;border:1px solid rgba(160,170,190,.25)}
.spark{width:100%;height:70px;display:block}
.spark-empty{padding:18px 8px;color:#8aa;font-size:13px;text-align:center;font-style:italic}
.history-table{width:100%;border-collapse:collapse;font-size:13px}
.history-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#8aa;font-weight:600;padding:6px 8px;border-bottom:1px solid rgba(120,140,180,.18)}
.history-table td{padding:8px;border-bottom:1px solid rgba(120,140,180,.08);color:#d8def0}
.history-table tr:last-child td{border-bottom:0}
.history-table .muted{color:#8aa;font-size:12px}
.history-table .truncate{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ═══ Neon numbers — interior keeps normal text colour, outline + glow are neon ═══ */
.neon-num{
  color:#f4f7ff;
  -webkit-text-stroke:1px rgba(74,211,255,.55);
  filter:drop-shadow(0 0 6px rgba(74,211,255,.55)) drop-shadow(0 0 14px rgba(124,92,255,.40));
  animation:neon-num-pulse 3.4s ease-in-out infinite;
  font-variant-numeric:tabular-nums;
}
.neon-num.warn{-webkit-text-stroke-color:rgba(255,170,80,.6);filter:drop-shadow(0 0 6px rgba(255,170,80,.6)) drop-shadow(0 0 14px rgba(246,197,96,.35))}
.neon-num.bad{-webkit-text-stroke-color:rgba(255,110,127,.65);filter:drop-shadow(0 0 6px rgba(255,110,127,.65)) drop-shadow(0 0 14px rgba(255,138,138,.4))}
.neon-num.good{-webkit-text-stroke-color:rgba(61,220,157,.6);filter:drop-shadow(0 0 6px rgba(61,220,157,.6)) drop-shadow(0 0 14px rgba(74,211,255,.35))}
@keyframes neon-num-pulse{
  0%,100%{filter:drop-shadow(0 0 5px rgba(74,211,255,.45)) drop-shadow(0 0 12px rgba(124,92,255,.28))}
  50%    {filter:drop-shadow(0 0 11px rgba(74,211,255,.85)) drop-shadow(0 0 22px rgba(124,92,255,.6))}
}
/* Apply the same interior-normal / outline-neon treatment automatically */
.score-ring .ring-num,
.comp-score b,
.trust-item b,
.spark-value,
.how-num,
.sig-card h3 span,
.tok-num,
.panel-banner-count{
  color:#f4f7ff;
  -webkit-text-stroke:1px rgba(74,211,255,.55);
  filter:drop-shadow(0 0 6px rgba(74,211,255,.55)) drop-shadow(0 0 14px rgba(124,92,255,.35));
  animation:neon-num-pulse 3.4s ease-in-out infinite;
}
.meta-chip b{
  color:#f4f7ff;
  -webkit-text-stroke:.75px rgba(74,211,255,.55);
  filter:drop-shadow(0 0 4px rgba(74,211,255,.55));
}
.grade-pill.A{text-shadow:0 0 8px rgba(61,220,157,.65),0 0 18px rgba(61,220,157,.35)}
.grade-pill.B{text-shadow:0 0 8px rgba(111,182,255,.65),0 0 18px rgba(111,182,255,.35)}
.grade-pill.C{text-shadow:0 0 8px rgba(255,211,107,.65),0 0 18px rgba(255,211,107,.35)}
.grade-pill.D{text-shadow:0 0 8px rgba(255,166,115,.65),0 0 18px rgba(255,166,115,.35)}
.grade-pill.F{text-shadow:0 0 8px rgba(255,110,127,.65),0 0 18px rgba(255,110,127,.35)}

/* ═══ Neon report-action buttons (sweep light + pulsing border) ═══ */
.report-actions .rep-btn{
  position:relative;overflow:hidden;isolation:isolate;
  border-color:rgba(74,211,255,.35);
  box-shadow:0 0 0 1px rgba(74,211,255,.15), 0 0 14px -6px rgba(124,92,255,.45);
  animation:rep-btn-glow 3.8s ease-in-out infinite;
}
.report-actions .rep-btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,
    transparent 0%,
    rgba(74,211,255,.06) 38%,
    rgba(124,92,255,.22) 48%,
    rgba(34,227,168,.18) 52%,
    rgba(74,211,255,.06) 62%,
    transparent 100%);
  transform:translateX(-120%);
  animation:rep-btn-sweep 3.2s ease-in-out infinite;
  pointer-events:none;
}
.report-actions .rep-btn::after{
  content:"";position:absolute;left:10%;right:10%;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,#4ad3ff 50%,transparent 100%);
  opacity:.55;
  animation:rep-btn-line 3.2s ease-in-out infinite;
  pointer-events:none;
}
.report-actions .rep-btn.primary{
  animation:rep-btn-glow-primary 3.2s ease-in-out infinite;
}
@keyframes rep-btn-glow{
  0%,100%{box-shadow:0 0 0 1px rgba(74,211,255,.18), 0 0 10px -4px rgba(124,92,255,.3)}
  50%    {box-shadow:0 0 0 1px rgba(74,211,255,.55), 0 0 22px -4px rgba(124,92,255,.65), 0 0 34px -6px rgba(34,227,168,.35)}
}
@keyframes rep-btn-glow-primary{
  0%,100%{box-shadow:0 0 0 1px rgba(124,92,255,.45), 0 0 14px -4px rgba(74,211,255,.55)}
  50%    {box-shadow:0 0 0 1px rgba(124,92,255,.75), 0 0 28px -4px rgba(74,211,255,.85), 0 0 42px -6px rgba(124,92,255,.6)}
}
@keyframes rep-btn-sweep{
  0%  {transform:translateX(-120%)}
  55%,100%{transform:translateX(120%)}
}
@keyframes rep-btn-line{
  0%,100%{opacity:.15}
  50%    {opacity:.75}
}
.report-actions .rep-btn:hover{
  border-color:#4ad3ff;
  box-shadow:0 0 0 1px rgba(74,211,255,.7), 0 0 32px -4px rgba(124,92,255,.9);
}
/* Keep scan CTA in sync with the new neon language */
.btn-primary{position:relative;overflow:hidden;isolation:isolate;animation:rep-btn-glow-primary 3.2s ease-in-out infinite}
.btn-primary::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.18) 48%,rgba(255,255,255,.28) 52%,transparent 100%);
  transform:translateX(-120%);
  animation:rep-btn-sweep 3.6s ease-in-out infinite;
  pointer-events:none;
}
@media (prefers-reduced-motion: reduce){
  .neon-num,.score-ring .ring-num,.comp-score b,.trust-item b,.how-num,.sig-card h3 span,.tok-num,.panel-banner-count,.report-actions .rep-btn,.btn-primary{animation:none !important}
  .report-actions .rep-btn::before,.report-actions .rep-btn::after,.btn-primary::before{display:none}
}

/* ═══ Language toggle in header ═══ */
.lang-toggle{
  display:inline-flex;align-items:center;gap:0;margin-right:10px;
  border:1px solid var(--border);border-radius:10px;padding:3px;
  background:var(--panel-2);
}
.lang-toggle button{
  background:transparent;border:0;cursor:pointer;
  padding:5px 10px;border-radius:7px;
  color:var(--fg-muted);font-size:12px;font-weight:600;font-family:var(--mono);
  letter-spacing:.05em;transition:all .2s ease;
}
.lang-toggle button:hover{color:#fff}
.lang-toggle button.active{
  background:linear-gradient(135deg,rgba(74,211,255,.18),rgba(124,92,255,.18));
  color:#fff;
  box-shadow:0 0 0 1px rgba(74,211,255,.4), 0 0 14px -4px rgba(124,92,255,.5);
}

/* ── Spider swarm panel ─────────────────────────────────────────── */
.spider-panel{
  margin-top:22px;padding:22px;border-radius:16px;
  background:linear-gradient(180deg,rgba(18,20,44,.85),rgba(10,12,28,.92));
  border:1px solid rgba(124,92,255,.28);
  position:relative;overflow:hidden;
}
.spider-panel::before{
  content:"";position:absolute;inset:-1px;border-radius:16px;pointer-events:none;
  background:linear-gradient(110deg,transparent 30%,rgba(74,211,255,.14) 50%,transparent 70%);
  animation:spider-sweep 6s ease-in-out infinite;
}
@keyframes spider-sweep{
  0%{transform:translateX(-40%);opacity:0}
  25%{opacity:.8}
  60%{opacity:.8}
  100%{transform:translateX(40%);opacity:0}
}
.spider-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap;position:relative;z-index:1}
.spider-head h3{margin:0;font-size:18px;font-weight:700;letter-spacing:-.01em}
.spider-head .sub{color:var(--fg-muted);font-size:13px;line-height:1.55;margin-top:4px;display:block;max-width:680px}
.spider-corpus{
  font-family:var(--mono);font-size:11px;padding:6px 10px;border-radius:8px;
  background:rgba(74,211,255,.08);border:1px solid rgba(74,211,255,.22);
  color:#9de1ff;white-space:nowrap;align-self:center;
}

.spider-summary{
  display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px;
  position:relative;z-index:1;
}
.spider-stat{
  padding:12px 14px;border-radius:12px;
  background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06);
}
.spider-stat .k{font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.08em;font-family:var(--mono)}
.spider-stat .v{
  font-size:22px;font-weight:800;margin-top:3px;display:block;
  background:linear-gradient(135deg,#4ad3ff 0%,#7c5cff 50%,#5cff9d 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 6px rgba(74,211,255,.4));
  animation:neon-pulse 3.5s ease-in-out infinite;
}
.spider-stat .s{font-size:11px;color:var(--fg-muted);margin-top:2px;display:block}

.spider-narrative{
  padding:12px 14px;border-radius:12px;margin-bottom:16px;
  background:linear-gradient(90deg,rgba(124,92,255,.12),rgba(74,211,255,.08));
  border-left:3px solid #7c5cff;color:#e6e7ff;font-size:13.5px;line-height:1.55;
  position:relative;z-index:1;
}

.spider-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;
  position:relative;z-index:1;
}
.spider-card{
  padding:14px;border-radius:14px;
  background:rgba(10,12,28,.7);border:1px solid rgba(124,92,255,.18);
  position:relative;overflow:hidden;transition:border-color .2s ease;
}
.spider-card::before{
  content:"";position:absolute;inset:-1px;border-radius:14px;pointer-events:none;
  background:linear-gradient(130deg,transparent 40%,rgba(74,211,255,.12) 50%,transparent 60%);
  transform:translateX(-50%);animation:spider-card-sweep 4s ease-in-out infinite;
}
@keyframes spider-card-sweep{
  0%{transform:translateX(-60%)}
  50%{transform:translateX(60%)}
  100%{transform:translateX(-60%)}
}
.spider-card:hover{border-color:rgba(74,211,255,.5)}
.spider-card.v-excellent{border-color:rgba(92,255,157,.5)}
.spider-card.v-solid{border-color:rgba(74,211,255,.4)}
.spider-card.v-borderline{border-color:rgba(255,200,90,.4)}
.spider-card.v-weak,.spider-card.v-invisible,.spider-card.v-gated,.spider-card.v-penalised{border-color:rgba(255,94,120,.5)}

.spider-card-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;position:relative;z-index:1}
.spider-emoji{font-size:22px;filter:drop-shadow(0 0 6px rgba(74,211,255,.5))}
.spider-name{font-weight:700;font-size:14px;letter-spacing:-.01em}
.spider-focus{color:var(--fg-muted);font-size:11px;line-height:1.4;margin-bottom:10px;position:relative;z-index:1}

.spider-score-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:8px;position:relative;z-index:1}
.spider-score{
  font-size:32px;font-weight:800;line-height:1;
  background:linear-gradient(135deg,#4ad3ff 0%,#7c5cff 50%,#5cff9d 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 8px rgba(74,211,255,.45));
  animation:neon-pulse 3s ease-in-out infinite;
}
.spider-grade{
  font-family:var(--mono);font-size:12px;font-weight:700;padding:3px 8px;border-radius:6px;
  background:rgba(255,255,255,.06);
}
.spider-verdict{
  display:inline-block;font-family:var(--mono);font-size:10.5px;font-weight:700;
  padding:4px 8px;border-radius:6px;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:10px;position:relative;z-index:1;
}
.v-excellent .spider-verdict{background:rgba(92,255,157,.14);color:#5cff9d;box-shadow:0 0 12px -4px rgba(92,255,157,.5)}
.v-solid .spider-verdict{background:rgba(74,211,255,.14);color:#4ad3ff;box-shadow:0 0 12px -4px rgba(74,211,255,.5)}
.v-borderline .spider-verdict{background:rgba(255,200,90,.14);color:#ffc85a}
.v-weak .spider-verdict,.v-invisible .spider-verdict,.v-gated .spider-verdict,.v-penalised .spider-verdict{
  background:rgba(255,94,120,.14);color:#ff7a90;box-shadow:0 0 12px -4px rgba(255,94,120,.5)
}

.spider-reasoning{
  font-size:12px;line-height:1.45;color:#d8def0;
  background:linear-gradient(135deg,rgba(74,211,255,.08),rgba(124,92,255,.08));
  border-left:2px solid rgba(124,92,255,.55);
  padding:7px 9px;border-radius:6px;margin-bottom:10px;position:relative;z-index:1;
  cursor:help;
}
.spider-meta{display:grid;gap:4px;position:relative;z-index:1}
.spider-meta-row{display:flex;justify-content:space-between;font-size:11.5px;color:var(--fg-muted);gap:8px}
.spider-meta-row b{color:#e6e7ff;font-weight:600}
.spider-bar{
  height:4px;border-radius:2px;background:rgba(255,255,255,.06);margin-top:6px;overflow:hidden;position:relative;
}
.spider-bar-fill{
  height:100%;background:linear-gradient(90deg,#4ad3ff,#7c5cff,#5cff9d);
  box-shadow:0 0 8px rgba(74,211,255,.6);
  transition:width .6s cubic-bezier(.4,0,.2,1);
}

.spider-percentile{
  font-family:var(--mono);font-size:10.5px;color:#9de1ff;margin-top:8px;
  padding:4px 8px;border-radius:6px;background:rgba(74,211,255,.08);
  display:inline-block;position:relative;z-index:1;
}

.spider-learn{
  margin-top:16px;padding:12px 14px;border-radius:12px;
  background:rgba(92,255,157,.05);border:1px solid rgba(92,255,157,.18);
  font-size:12.5px;color:#b5f5cf;line-height:1.55;position:relative;z-index:1;
}
.spider-learn b{color:#5cff9d;font-weight:700}
.spider-learn-bar{
  height:6px;border-radius:3px;background:rgba(255,255,255,.06);margin:8px 0;overflow:hidden;
}
.spider-learn-bar-fill{
  height:100%;background:linear-gradient(90deg,#5cff9d,#4ad3ff);
  box-shadow:0 0 10px rgba(92,255,157,.6);
  transition:width .6s ease;
}

@media (max-width:760px){
  .spider-summary{grid-template-columns:repeat(2,1fr)}
}
@media (prefers-reduced-motion:reduce){
  .spider-panel::before,.spider-card::before,.spider-stat .v,.spider-score{animation:none}
}

/* Elements with an explanatory tooltip get a subtle dotted underline hint. */
.has-hint{
  text-decoration:underline dotted rgba(255,255,255,.28);
  text-underline-offset:3px;cursor:help;
}
.has-hint:hover{text-decoration-color:rgba(92,255,157,.8)}

/* ═══ Phase-2 sections: citation test, chunks, fanout, embIntent, fixSim, compGap, brandK, schedule ═══ */
.phase2{
  margin:22px 0;padding:18px 20px;border-radius:14px;
  background:linear-gradient(180deg,rgba(124,92,255,.06),rgba(74,211,255,.02));
  border:1px solid rgba(124,92,255,.18);
}
.phase2 .section-title{margin-bottom:12px}
.phase2 h3{margin:0;font-size:16px}
.phase2 .sub{color:var(--fg-muted);font-size:12.5px;display:block;margin-top:4px}
.phase2 .btn{padding:7px 14px;font-size:13px;border-radius:8px;border:1px solid rgba(74,211,255,.35);background:rgba(74,211,255,.06);color:#d8def0;cursor:pointer}
.phase2 .btn.primary{background:linear-gradient(135deg,rgba(74,211,255,.25),rgba(124,92,255,.25));border-color:rgba(124,92,255,.55)}
.phase2 .btn:hover{border-color:rgba(92,255,157,.55)}
.phase2 .pill{display:inline-block;padding:3px 8px;font-size:11px;border-radius:5px;background:rgba(255,255,255,.06);color:#c8d0e8;margin-right:4px}
.phase2 .pill.good{background:rgba(61,220,157,.16);color:#5cff9d}
.phase2 .pill.warn{background:rgba(255,200,90,.14);color:#ffc85a}
.phase2 .muted{color:var(--fg-muted)}
.phase2 .err{color:#ff7a90;padding:10px}
.phase2 table.ct-table{width:100%;border-collapse:collapse;font-size:12.5px;margin-top:10px}
.phase2 table.ct-table th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:#8aa;padding:6px 8px;border-bottom:1px solid rgba(120,140,180,.2)}
.phase2 table.ct-table td{padding:6px 8px;border-bottom:1px solid rgba(120,140,180,.08);color:#d8def0}
.phase2 table.ct-table td.num{font-family:var(--mono);text-align:right}

/* Citation test */
.ct-verdict{display:flex;align-items:center;gap:14px;padding:10px 14px;margin:8px 0 12px;border-radius:10px;background:rgba(255,255,255,.03)}
.ct-verdict.v-cited{background:rgba(61,220,157,.10);border:1px solid rgba(61,220,157,.4)}
.ct-verdict.v-onlyMentioned{background:rgba(255,200,90,.08);border:1px solid rgba(255,200,90,.35)}
.ct-verdict.v-invisible{background:rgba(255,110,127,.08);border:1px solid rgba(255,110,127,.35)}
.ct-verdict.v-noLiveModels{background:rgba(120,140,180,.08);border:1px solid rgba(120,140,180,.25)}
.ct-verdict b{font-size:14px}
.ct-verdict span{color:var(--fg-muted);font-size:12.5px}
.ct-queries{margin-top:12px}
.ct-queries summary{cursor:pointer;color:#4ad3ff;font-size:12.5px;padding:6px 0}

/* Chunk heatmap */
.chunk-summary{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.heat-strip{display:flex;gap:2px;height:54px;border-radius:6px;overflow:hidden;margin-bottom:10px}
.heat-cell{position:relative;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:700;color:#fff;cursor:help}
.heat-cell.hot{background:linear-gradient(180deg,#3ddc9d,#22c080)}
.heat-cell.warm{background:linear-gradient(180deg,#4ad3ff,#2594c4)}
.heat-cell.cool{background:linear-gradient(180deg,#ffb34d,#d68a2e)}
.heat-cell.cold{background:linear-gradient(180deg,#ff7a90,#c44460)}
.heat-cell .heat-score{text-shadow:0 1px 2px rgba(0,0,0,.6)}
.chunk-quotables{margin-top:12px}
.chunk-quotables h4{font-size:12.5px;margin:0 0 6px;color:#c8d0e8;text-transform:uppercase;letter-spacing:.06em}
.chunk-quotables ol{margin:0;padding-left:20px;font-size:13px;line-height:1.5}

/* Fanout */
.fanout-summary{display:flex;align-items:center;gap:18px;margin-bottom:12px}
.fanout-ring{
  width:88px;height:88px;border-radius:50%;
  background:conic-gradient(#4ad3ff calc(var(--pct,0)*1%),rgba(120,140,180,.12) 0);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;
}
.fanout-ring::after{content:"";position:absolute;inset:6px;border-radius:50%;background:#0f1220}
.fanout-ring b,.fanout-ring span{position:relative;z-index:1}
.fanout-ring b{font-size:18px;font-weight:700}
.fanout-ring span{font-size:10.5px;color:var(--fg-muted)}
.fanout-meta{display:grid;gap:6px;font-size:12.5px}
.fanout-meta div{display:flex;gap:10px;color:var(--fg-muted)}
.fanout-meta b{color:#e6e7ff}
.fanout-table{width:100%;border-collapse:collapse;font-size:11.5px;margin-top:8px}
.fanout-table th,.fanout-table td{padding:5px 6px;border-bottom:1px solid rgba(120,140,180,.08);text-align:left}
.fanout-table th{color:#8aa;text-transform:uppercase;font-size:10px;letter-spacing:.05em}

/* Embedding intent */
.ei-head{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.ei-rows{display:grid;gap:6px}
.ei-row{display:grid;grid-template-columns:200px 1fr auto;gap:12px;align-items:center;padding:6px 8px;border-radius:6px;background:rgba(255,255,255,.03)}
.ei-name b{font-size:12.5px}
.ei-bar{height:6px;border-radius:3px;background:rgba(120,140,180,.15);overflow:hidden}
.ei-bar span{display:block;height:100%;background:linear-gradient(90deg,#4ad3ff,#7c5cff,#3ddc9d)}
.ei-q{font-family:var(--mono);font-size:11px;color:var(--fg-muted);display:flex;gap:6px}
.ei-strong .ei-bar span{background:linear-gradient(90deg,#3ddc9d,#22c080)}
.ei-weak .ei-bar span{background:linear-gradient(90deg,#ff7a90,#c44460)}

/* Fix simulator */
.fixsim-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.fixsim-controls label{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--fg-muted)}
.fixsim-controls input[type=number]{width:60px;background:rgba(255,255,255,.04);color:#e6e7ff;border:1px solid rgba(120,140,180,.3);border-radius:6px;padding:4px 8px}
.fixsim-controls input[type=range]{width:140px}
.fs-bands{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:10px;margin-bottom:12px}
.fs-bands>div{padding:12px;border-radius:10px;background:rgba(255,255,255,.03);text-align:center}
.fs-bands>div.main{background:linear-gradient(135deg,rgba(74,211,255,.15),rgba(124,92,255,.15));border:1px solid rgba(74,211,255,.4)}
.fs-bands span{display:block;font-size:11px;color:var(--fg-muted);text-transform:uppercase;letter-spacing:.06em}
.fs-bands b{font-size:32px;font-family:var(--mono);display:block;margin:4px 0}
.fs-bands small{font-size:12px;color:#5cff9d}
.delta-up{color:#5cff9d}
.delta-down{color:#ff7a90}

/* Competitor gap */
.cg-head{display:flex;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.compgap-body h4{font-size:12.5px;margin:14px 0 6px;color:#c8d0e8;text-transform:uppercase;letter-spacing:.06em}
.pill.grade-A{background:rgba(61,220,157,.14);color:#5cff9d}
.pill.grade-B{background:rgba(111,182,255,.14);color:#6fb6ff}
.pill.grade-C{background:rgba(255,211,107,.14);color:#ffc85a}
.pill.grade-D{background:rgba(255,166,115,.14);color:#ffa673}
.pill.grade-F{background:rgba(255,110,127,.14);color:#ff7a90}

/* Brand knowledge */
.bk-agreement{padding:10px 14px;border-radius:10px;margin-bottom:12px;background:rgba(255,255,255,.03)}
.bk-agreement.bk-consistent{border:1px solid rgba(61,220,157,.4);background:rgba(61,220,157,.08)}
.bk-agreement.bk-partial{border:1px solid rgba(255,200,90,.35);background:rgba(255,200,90,.06)}
.bk-agreement.bk-divergent{border:1px solid rgba(255,110,127,.4);background:rgba(255,110,127,.08)}
.bk-shared{margin-top:8px}
.bk-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.bk-card{padding:12px 14px;border-radius:10px;background:rgba(255,255,255,.03);border:1px solid rgba(120,140,180,.15)}
.bk-card header{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid rgba(120,140,180,.1)}
.bk-card.bk-err{border-color:rgba(255,110,127,.35)}
.bk-text{font-size:12.5px;line-height:1.5;color:#d8def0}

/* Schedule */
.schedule-controls{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.schedule-controls label{display:flex;align-items:center;gap:6px;font-size:12.5px;color:var(--fg-muted)}
.schedule-controls select{background:rgba(255,255,255,.04);color:#e6e7ff;border:1px solid rgba(120,140,180,.3);border-radius:6px;padding:5px 8px}
.sched-item{display:flex;gap:14px;padding:8px 10px;border-radius:6px;background:rgba(255,255,255,.03);margin-bottom:6px;font-size:12.5px;align-items:center;flex-wrap:wrap}
.sched-mine{background:rgba(74,211,255,.06);border:1px solid rgba(74,211,255,.25)}
.sched-alert{padding:8px 10px;border-radius:6px;margin-bottom:6px;font-size:12.5px;display:flex;gap:10px;align-items:center}
.sched-alert.v-bigDrop,.sched-alert.v-regressed{background:rgba(255,110,127,.08);border-left:3px solid #ff7a90}
.sched-alert.v-bigWin,.sched-alert.v-improved{background:rgba(61,220,157,.08);border-left:3px solid #5cff9d}
.sched-alert.v-stable{background:rgba(120,140,180,.08);border-left:3px solid #8aa}
.schedule-body h4{font-size:12px;margin:14px 0 6px;color:#8aa;text-transform:uppercase;letter-spacing:.06em}

/* ── Agents panel ─────────────────────────────────────── */
.agents .agents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:10px}
.agent-card{background:rgba(255,255,255,.03);border:1px solid rgba(120,140,180,.18);border-radius:10px;padding:14px 14px 12px;display:flex;flex-direction:column;gap:8px;transition:border .2s}
.agent-card.sev-notice{border-left:3px solid #ffb454}
.agent-card.sev-warning{border-left:3px solid #ff7a90;background:rgba(255,122,144,.05)}
.agent-card.sev-critical{border-left:3px solid #ff7a90;background:rgba(255,122,144,.1)}
.agent-head{display:flex;gap:10px;align-items:flex-start}
.agent-icon{font-size:22px;line-height:1}
.agent-name{font-weight:700;font-size:13.5px}
.agent-role{font-size:11.5px;line-height:1.4}
.agent-meta{display:flex;gap:10px;font-size:11.5px;color:#8aa;flex-wrap:wrap}
.agent-summary{font-size:12.5px;line-height:1.5;color:#d8def0;display:flex;gap:7px;align-items:flex-start}
.sev-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.agent-run{align-self:flex-start;padding:5px 12px;font-size:11.5px;border-radius:6px;background:rgba(124,92,255,.18);color:#d8def0;border:1px solid rgba(124,92,255,.4);cursor:pointer}
.agent-run:disabled{opacity:.5;cursor:wait}
.agents-feed-head{display:flex;justify-content:space-between;align-items:center;margin-top:18px;margin-bottom:8px;border-top:1px solid rgba(120,140,180,.12);padding-top:14px}
.agents-feed-head h4{font-size:12px;margin:0;color:#8aa;text-transform:uppercase;letter-spacing:.06em}
.agents-feed-head .btn{padding:5px 12px;font-size:11.5px;border-radius:6px;background:rgba(255,255,255,.05);border:1px solid rgba(120,140,180,.25);color:#d8def0;cursor:pointer}
.agents-feed{display:flex;flex-direction:column;gap:4px;max-height:360px;overflow-y:auto}
.feed-row{display:grid;grid-template-columns:14px 24px 1fr auto;gap:10px;align-items:flex-start;padding:8px 10px;border-radius:6px;font-size:12.5px;background:rgba(255,255,255,.02)}
.feed-row.sev-warning{background:rgba(255,180,84,.06);border-left:2px solid #ffb454}
.feed-row.sev-critical{background:rgba(255,122,144,.08);border-left:2px solid #ff7a90}
.feed-row.sev-notice{background:rgba(255,180,84,.04);border-left:2px solid #ffb454}
.feed-agent{font-size:16px}
.feed-title{font-weight:600}
.feed-sum{font-size:11.5px;margin-top:2px}
.feed-when{color:#8aa;font-size:11.5px;white-space:nowrap}

/* History diff */
.diff-check{margin-right:6px;font-size:11px;color:var(--fg-muted)}
.diff-check input{margin-right:3px}
.diff-controls{margin-top:10px;padding-top:10px;border-top:1px solid rgba(120,140,180,.1)}
.diff-controls .btn{padding:6px 12px;font-size:12.5px;border-radius:6px;border:1px solid rgba(74,211,255,.35);background:rgba(74,211,255,.08);color:#d8def0;cursor:pointer}
.diff-body{margin-top:10px}
.diff-verdict{padding:10px 14px;border-radius:8px;margin-bottom:10px;background:rgba(255,255,255,.03);display:flex;gap:14px;align-items:center}
.diff-verdict.v-bigWin,.diff-verdict.v-improved{background:rgba(61,220,157,.08);border:1px solid rgba(61,220,157,.35)}
.diff-verdict.v-bigDrop,.diff-verdict.v-regressed{background:rgba(255,110,127,.08);border:1px solid rgba(255,110,127,.35)}
.diff-verdict.v-stable{background:rgba(120,140,180,.06);border:1px solid rgba(120,140,180,.2)}

/* Why-this-score panel: the first thing a user reads after the ring.
   Explains the score in plain language + lists the 3 highest-uplift fixes. */
.why-score{margin:18px 0 22px;padding:18px 22px;border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.035),rgba(255,255,255,.015));border:1px solid rgba(120,140,180,.18);position:relative}
.why-score::before{content:'';position:absolute;left:0;top:10px;bottom:10px;width:3px;border-radius:3px;background:var(--accent)}
.why-score.fail::before{background:#ff6e7f}
.why-score.weak::before{background:#ffb34d}
.why-score.mid::before{background:#ffdc66}
.why-score.strong::before{background:#3ddc9d}
.why-score-title{margin:0 0 6px;font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);font-weight:600}
.why-score-headline{margin:0 0 10px;font-size:17px;line-height:1.35;color:#e8ecf5;font-weight:600}
.why-score.fail .why-score-headline{color:#ffd0d5}
.why-score-detail{list-style:none;padding:0;margin:0 0 14px;display:flex;flex-direction:column;gap:4px}
.why-score-detail li{position:relative;padding-left:16px;font-size:13.5px;line-height:1.45;color:#cdd3e2}
.why-score-detail li::before{content:'▸';position:absolute;left:0;top:0;color:var(--accent);font-size:11px;line-height:20px}
.why-score.fail .why-score-detail li::before{color:#ff6e7f}
.why-score-fixes{margin-top:14px;padding-top:14px;border-top:1px dashed rgba(120,140,180,.2)}
.why-score-fixes-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--fg-muted);margin-bottom:10px;font-weight:600}
.why-score-fix-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;counter-reset:whyfix}
.why-fix{display:grid;grid-template-columns:28px 1fr auto;gap:12px;align-items:center;padding:10px 12px;border-radius:10px;background:rgba(255,255,255,.025);border:1px solid rgba(120,140,180,.12)}
.why-fix-num{width:24px;height:24px;border-radius:50%;background:var(--accent);color:#201301;font-weight:700;font-size:12.5px;display:flex;align-items:center;justify-content:center}
.why-fix-body{min-width:0}
.why-fix-title{font-size:14px;font-weight:600;color:#e8ecf5;line-height:1.3}
.why-fix-sub{font-size:12.5px;color:var(--fg-muted);line-height:1.4;margin-top:2px}
.why-fix-uplift{font-size:12px;font-weight:600;color:#3ddc9d;background:rgba(61,220,157,.1);padding:4px 10px;border-radius:999px;white-space:nowrap}
.why-score-nofix{font-size:13px;color:var(--fg-muted);margin:12px 0 0}
@media (max-width:600px){
  .why-score{padding:14px 16px}
  .why-score-headline{font-size:15.5px}
  .why-fix{grid-template-columns:24px 1fr;row-gap:4px}
  .why-fix-uplift{grid-column:2;justify-self:start}
}
.diff-verdict span{color:var(--fg-muted);font-size:12px}
