:root {
  --bg: #ece2cf;
  --card: #fdfaf3;
  --ink: #2a2620;
  --muted: #5f584c;
  --subtle: #6f6757;
  --line: #e7ddc9;
  --accent: #5b53e6;
  --accent-hover: #6f67ee;
  --accent-solid: #5b53e6;
  --code-bg: #f4ecdc;
  --code-ink: #4a4034;
  --btn-bg: #fdfaf3;
  --btn-border: #e4dcce;
  --btn-hover: #f6f1e7;
  --banner-bg: #f6efe0;
  --banner-ink: #5a4632;
  --banner-border: #e8dcc4;
  --banner-strong: #4a3826;
  --ai-bg: #faf4e9;
  --ai-border: #ece1cd;
  --ai-tag-bg: #eae7fb;
  --ai-tag-ink: #4b46c4;
  --lock-bg: #efe7d6;
  --lock-ink: #4b46c4;
  --pro-bg: #e6f3ea;
  --pro-ink: #1d7a52;
  --err: #b3261e;
  --overlay: rgba(42, 36, 28, .5);
  --seg-track: #efe7d6;
  --score-on: #ffffff;
  --sev-critical: #b42318;
  --sev-serious: #a8430f;
  --sev-moderate: #8a5e00;
  --sev-minor: #5f5e5a;
  --score-good: #15805e;
  --score-mid: #8a5e00;
  --score-bad: #b42318;
  --shadow-1: rgba(60, 50, 32, .05);
  --shadow-2: rgba(60, 50, 32, .10);
  --shadow-h: rgba(60, 50, 32, .09);
}
:root[data-theme="dark"] {
  --bg: #15171b;
  --card: #1e2127;
  --ink: #e6e9ef;
  --muted: #98a0ac;
  --subtle: #868d99;
  --line: #2c313a;
  --accent: #a6a0ff;
  --accent-hover: #bbb6ff;
  --accent-solid: #635bff;
  --code-bg: #1a1d23;
  --code-ink: #c4c9d2;
  --btn-bg: #1a1d23;
  --btn-border: #2c313a;
  --btn-hover: #232730;
  --banner-bg: #1c2028;
  --banner-ink: #d7dbe3;
  --banner-border: #2c313a;
  --banner-strong: #eef0f4;
  --ai-bg: #1b1c2b;
  --ai-border: #2f3147;
  --ai-tag-bg: #2a2742;
  --ai-tag-ink: #cfcaff;
  --lock-bg: #2a2742;
  --lock-ink: #cfcaff;
  --pro-bg: #162e22;
  --pro-ink: #7fd3a8;
  --err: #f3a39b;
  --overlay: rgba(0, 0, 0, .66);
  --seg-track: #1a1d23;
  --score-on: #10131a;
  --sev-critical: #f0958c;
  --sev-serious: #f0a163;
  --sev-moderate: #dcb44e;
  --sev-minor: #b0a89a;
  --score-good: #5cc79a;
  --score-mid: #dcb44e;
  --score-bad: #f0958c;
  --shadow-1: rgba(0, 0, 0, .25);
  --shadow-2: rgba(0, 0, 0, .4);
  --shadow-h: rgba(0, 0, 0, .45);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  line-height: 1.55;
  padding: 40px 16px;
  -webkit-font-smoothing: antialiased;
}
.report {
  max-width: 800px; margin: 0 auto; background: var(--card);
  border-radius: 18px; padding: 36px 40px;
  box-shadow: 0 1px 1px var(--shadow-1), 0 8px 28px var(--shadow-2);
}
.banner { background: var(--banner-bg); color: var(--banner-ink); border: 1px solid var(--banner-border); border-radius: 10px; padding: 11px 15px; font-size: 13px; line-height: 1.5; margin-bottom: 20px; }
.banner strong { color: var(--banner-strong); }
.rpt-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.rpt-head-r { display: flex; align-items: center; gap: 14px; }
.brand { display: flex; align-items: center; gap: 10px; }
.wordmark { font-family: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif; font-weight: 700; font-size: 22px; letter-spacing: -.01em; color: var(--ink); line-height: 1; }
.wm-o { display: inline-block; width: .57em; height: .57em; vertical-align: -.03em; color: var(--accent); }
.theme-seg { display: inline-flex; align-items: center; gap: 2px; padding: 3px; background: var(--seg-track); border: 1px solid var(--btn-border); border-radius: 999px; }
.seg-btn { appearance: none; border: 0; background: transparent; color: var(--subtle); width: 30px; height: 26px; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: background .15s ease, color .15s ease; }
.seg-btn:hover { color: var(--accent); }
.seg-btn[aria-pressed="true"] { background: var(--card); color: var(--accent); box-shadow: 0 1px 2px var(--shadow-2); }
.seg-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.seg-btn svg { display: block; }
.score { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; color: var(--c); }
.score-cap { font-size: 10px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--subtle); }
.score-row { display: flex; align-items: center; gap: 8px; }
.score-n { font-size: 40px; font-weight: 700; line-height: 1; letter-spacing: -.02em; }
.score-g { font-size: 17px; font-weight: 700; color: var(--score-on); background: var(--c); border-radius: 9px; padding: 4px 12px; line-height: 1.15; }
.title { font-size: 27px; margin: 6px 0 4px; font-weight: 600; letter-spacing: -.02em; color: var(--ink); }
.meta { color: var(--subtle); font-size: 14px; margin: 0 0 18px; overflow-wrap: anywhere; }
.meta-url { color: var(--ink); }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 8px; }
.chip { font-size: 12px; font-weight: 600; color: var(--c); background: color-mix(in srgb, var(--c) 11%, var(--card)); border-radius: 999px; padding: 4px 11px; }
.sec { margin-top: 26px; }
.sec-h { font-size: 12px; font-weight: 600; letter-spacing: .06em; text-transform: uppercase; color: var(--c); margin: 0 0 12px; }
.v { background: var(--card); border: 1px solid var(--line); border-radius: 12px; padding: 16px 18px; margin: 10px 0; transition: box-shadow .15s ease; }
.v:hover { box-shadow: 0 4px 16px var(--shadow-h); }
.v-top { display: flex; align-items: center; gap: 10px; }
.dot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.v-help { font-size: 16px; font-weight: 600; margin: 0; flex: 1; color: var(--ink); }
.v-n { font-size: 12px; color: var(--subtle); white-space: nowrap; }
.v-desc { margin: 8px 0; color: var(--muted); }
.v-link { display: inline-block; color: var(--accent); font-weight: 600; text-decoration: none; font-size: 14px; margin-bottom: 8px; }
.v-link:hover { color: var(--accent-hover); text-decoration: underline; }
.nodes { list-style: none; margin: 8px 0 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.node { border-left: 2px solid var(--line); padding: 2px 0 2px 12px; }
.sel { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; color: var(--accent); font-weight: 600; word-break: break-all; }
.html { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; background: var(--code-bg); border: 1px solid var(--line); border-radius: 6px; padding: 7px 9px; margin: 6px 0; overflow-x: auto; white-space: pre-wrap; word-break: break-all; color: var(--code-ink); }
.why { font-size: 13px; color: var(--muted); margin: 4px 0 0; white-space: pre-wrap; }
.more { font-size: 12px; color: var(--subtle); margin: 8px 0 0; }
.empty { padding: 28px; text-align: center; color: var(--muted); }
.rpt-foot { margin-top: 30px; padding-top: 16px; border-top: 1px solid var(--line); font-size: 13px; color: var(--subtle); }
.rpt-foot strong { color: var(--ink); }
.ai { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.ai-btn { appearance: none; font-size: 12px; font-weight: 600; color: var(--accent); background: var(--btn-bg); border: 1px solid var(--btn-border); border-radius: 8px; padding: 6px 11px; cursor: pointer; transition: border-color .15s ease, background .15s ease; }
.ai-btn:hover { border-color: var(--accent); background: var(--btn-hover); }
.ai-btn:disabled { opacity: .55; cursor: default; }
.ai-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.ai-out { width: 100%; }
.ai-loading { margin-top: 8px; font-size: 13px; color: var(--subtle); }
.ai-err { margin-top: 8px; font-size: 13px; color: var(--err); }
.ai-card { margin-top: 10px; background: var(--ai-bg); border: 1px solid var(--ai-border); border-radius: 10px; padding: 12px 14px; }
.ai-tag { display: inline-block; font-size: 11px; font-weight: 600; color: var(--ai-tag-ink); background: var(--ai-tag-bg); border-radius: 6px; padding: 2px 8px; margin-bottom: 8px; }
.ai-text { font-size: 13px; color: var(--ink); white-space: pre-wrap; line-height: 1.55; }
.rpt-actions { margin: 6px 0 2px; display: flex; flex-wrap: wrap; gap: 8px; }
.pdf-btn, .save-btn, .saved-btn { appearance: none; font-size: 13px; font-weight: 600; color: var(--accent); background: var(--btn-bg); border: 1px solid var(--btn-border); border-radius: 8px; padding: 7px 13px; cursor: pointer; transition: border-color .15s ease, background .15s ease; }
.pdf-btn:hover, .save-btn:hover, .saved-btn:hover { border-color: var(--accent); background: var(--btn-hover); }
.pdf-btn:focus-visible, .save-btn:focus-visible, .saved-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.saved-btn { color: var(--muted); }
@media print {
  :root, :root[data-theme="dark"] {
    --bg: #fff; --card: #fff; --ink: #2a2620; --muted: #5f584c; --subtle: #6f6757; --line: #e7ddc9;
    --accent: #5b53e6; --code-bg: #f4ecdc; --code-ink: #4a4034;
    --ai-bg: #fff; --ai-tag-bg: #eae7fb; --ai-tag-ink: #4b46c4;
    --lock-bg: #efe7d6; --lock-ink: #4b46c4; --pro-bg: #e6f3ea; --pro-ink: #1d7a52;
    --sev-critical: #b42318; --sev-serious: #a8430f; --sev-moderate: #8a5e00; --sev-minor: #5f5e5a;
    --score-good: #15805e; --score-mid: #8a5e00; --score-bad: #b42318; --score-on: #ffffff;
  }
  body { background: #fff; padding: 0; }
  .report { box-shadow: none; border: 0; border-radius: 0; max-width: none; padding: 0; background: #fff; }
  .v { break-inside: avoid; background: #fff; }
  .v:hover { box-shadow: none; }
  .ai-btn, .pdf-btn, .rpt-actions, .banner, .rpt-foot, .theme-seg { display: none !important; }
  .ai-card { background: #fff !important; }
  .v-link { color: var(--ink) !important; }
}
@page { margin: 16mm; }

.lock { font-size: 10px; font-weight: 600; color: var(--lock-ink); background: var(--lock-bg); border-radius: 5px; padding: 1px 6px; margin-left: 4px; }
.pro-badge { font-size: 11px; font-weight: 600; color: var(--pro-ink); background: var(--pro-bg); border-radius: 6px; padding: 2px 7px; margin-left: 6px; vertical-align: middle; }
.upg-back { display: none; position: fixed; inset: 0; background: var(--overlay); z-index: 9999; align-items: center; justify-content: center; padding: 16px; }
.upg { background: var(--card); border-radius: 16px; padding: 24px; width: 100%; max-width: 380px; box-shadow: 0 20px 60px rgba(20, 16, 10, .32); position: relative; }
.upg-x { position: absolute; top: 12px; right: 12px; appearance: none; border: 0; background: transparent; font-size: 22px; color: var(--subtle); cursor: pointer; line-height: 1; }
.upg-h { font-size: 20px; font-weight: 600; color: var(--ink); }
.upg-price { font-size: 14px; color: var(--accent); font-weight: 600; margin: 2px 0 14px; }
.upg-list { list-style: none; margin: 0 0 16px; padding: 0; }
.upg-list li { font-size: 13px; color: var(--muted); padding: 5px 0 5px 22px; position: relative; }
.upg-list li:before { content: "\2713"; position: absolute; left: 0; color: var(--accent); font-weight: 700; }
.upg-buy { width: 100%; appearance: none; border: 0; border-radius: 10px; background: var(--accent-solid); color: #fff; font-size: 15px; font-weight: 600; padding: 11px; cursor: pointer; transition: filter .15s ease; }
.upg-buy:hover { filter: brightness(1.06); }
.upg-div { text-align: center; font-size: 12px; color: var(--subtle); margin: 16px 0 10px; }
.upg-key { display: flex; gap: 8px; }
.upg-input { flex: 1; min-width: 0; font-size: 13px; padding: 9px 11px; border: 1px solid var(--line); border-radius: 8px; font-family: ui-monospace, Menlo, Consolas, monospace; background: var(--card); color: var(--ink); }
.upg-input:focus { outline: 2px solid var(--accent); outline-offset: 1px; border-color: var(--accent); }
.upg-unlock { appearance: none; border: 1px solid var(--accent); background: var(--btn-bg); color: var(--accent); font-size: 13px; font-weight: 600; border-radius: 8px; padding: 9px 14px; cursor: pointer; }
.upg-unlock:hover { background: var(--btn-hover); }
.upg-unlock:disabled { opacity: .6; cursor: default; }
.upg-msg { font-size: 12px; margin-top: 10px; min-height: 16px; color: var(--subtle); }
.pr-list { margin-top: 8px; max-height: 50vh; overflow-y: auto; }
.pr-row { display: flex; align-items: center; gap: 10px; padding: 10px 0; border-bottom: 1px solid var(--line); }
.pr-info { flex: 1; min-width: 0; }
.pr-name { font-size: 14px; font-weight: 500; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pr-url { font-size: 12px; color: var(--subtle); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pr-open { appearance: none; border: 1px solid var(--accent); background: var(--btn-bg); color: var(--accent); font-size: 12px; font-weight: 600; border-radius: 7px; padding: 6px 12px; cursor: pointer; flex: none; }
.pr-open:hover { background: var(--btn-hover); }
.pr-del { appearance: none; border: 0; background: transparent; color: var(--subtle); font-size: 18px; cursor: pointer; line-height: 1; padding: 0 4px; flex: none; }
.pr-empty { font-size: 13px; color: var(--subtle); padding: 16px 0; text-align: center; }
.page { margin-top: 22px; }
.page-h { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; padding-bottom: 8px; border-bottom: 2px solid var(--line); margin: 0 0 4px; }
.page-url { font-size: 15px; font-weight: 600; color: var(--ink); word-break: break-all; }
.page-n { font-size: 12px; color: var(--subtle); white-space: nowrap; }
