:root{
  --bg:#15140f; --bg2:#1c1b15; --bg3:#24221a; --line:#34322a; --line2:#43412f;
  --ink:#ECE9DD; --ink2:#A8A492; --ink3:#726f5d;
  --accent:#C6F24E; --accent-dim:#8fae39;
  --good:#A8E063; --mid:#E8B23A; --bad:#EC6A4C;
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--ink); font-family:var(--sans); line-height:1.6; font-size:16px;
  background-image:radial-gradient(circle at 12% -10%, rgba(198,242,78,.06), transparent 45%);
  min-height:100vh;
}
.wrap{max-width:980px;margin:0 auto;padding:42px 22px 90px}
.kick{font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent-dim)}
h1{font-family:var(--mono);font-weight:600;font-size:clamp(34px,7vw,58px);letter-spacing:-.02em;margin:6px 0 8px;line-height:1}
h1 .b{color:var(--accent)}
.tag{color:var(--ink2);max-width:68ch;font-size:15px}

.panel{background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:20px;margin-top:26px}
.form-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.f-url{flex:1;min-width:260px}.f-pages{width:96px}
label.fld{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink2);margin:0 0 7px}
input{width:100%;background:var(--bg);border:1px solid var(--line2);border-radius:9px;color:var(--ink);font-family:var(--sans);font-size:15px;padding:12px 13px;outline:none;transition:border-color .15s,box-shadow .15s}
input:focus{border-color:var(--accent-dim);box-shadow:0 0 0 3px rgba(198,242,78,.12)}
.hint{color:var(--ink3);font-size:12.5px;margin:12px 0 0}
button{font-family:var(--mono);font-weight:600;font-size:13px;letter-spacing:.04em;border:none;border-radius:9px;padding:12px 18px;cursor:pointer;transition:transform .08s,background .15s,border-color .15s}
button:active{transform:translateY(1px)}
button:disabled{opacity:.55;cursor:default}
.btn-pri{background:var(--accent);color:#1a1c08}.btn-pri:hover{background:#d4ff63}
.btn-sec{background:transparent;color:var(--ink);border:1px solid var(--line2)}.btn-sec:hover{border-color:var(--ink2)}
.btn-ghost{background:transparent;color:var(--ink2);border:none;text-decoration:underline;text-underline-offset:3px;padding:8px 4px}.btn-ghost:hover{color:var(--accent)}

#status{font-family:var(--mono);font-size:12.5px;color:var(--ink2);margin-top:14px;min-height:18px}
#status.err{color:var(--bad)}
.spin{display:inline-block;width:11px;height:11px;border:2px solid var(--line2);border-top-color:var(--accent);border-radius:50%;animation:sp .7s linear infinite;vertical-align:-1px;margin-right:7px}
@keyframes sp{to{transform:rotate(360deg)}}

#results{margin-top:30px;display:none}

/* site scorecard */
.scorecard{display:flex;gap:24px;align-items:center;flex-wrap:wrap;background:var(--bg2);border:1px solid var(--line);border-radius:14px;padding:24px}
.ring{position:relative;width:124px;height:124px;flex:0 0 auto}
.ring svg{transform:rotate(-90deg)}
.ring .num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ring .num b{font-family:var(--mono);font-size:36px;font-weight:600;line-height:1}
.ring .num span{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--ink2);margin-top:3px}
.cats{flex:1;min-width:260px;display:flex;flex-direction:column;gap:11px}
.catrow{display:grid;grid-template-columns:96px 1fr 44px;align-items:center;gap:12px}
.catrow .cl{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink2)}
.catbar{height:8px;background:var(--bg);border-radius:5px;overflow:hidden}
.catbar i{display:block;height:100%;border-radius:5px;transition:width .9s ease .1s}
.catrow .cv{font-family:var(--mono);font-size:14px;text-align:right}

.sitemeta{display:flex;gap:18px;flex-wrap:wrap;margin-top:16px;font-family:var(--mono);font-size:12px;color:var(--ink2)}
.sitemeta b{color:var(--ink)}
.sitemeta .tagdot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:6px;vertical-align:1px}

/* export bar */
.export{margin-top:18px}
.export h3,.list-head h3{font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink2);margin:0 0 8px}
.export p{color:var(--ink2);font-size:14px;margin:0 0 15px;max-width:66ch}
.exp-btns{display:flex;gap:10px;flex-wrap:wrap}
.exp-msg{font-family:var(--mono);font-size:12.5px;color:var(--accent);margin-top:13px;min-height:16px;opacity:0;transition:opacity .25s}

/* page accordion */
.list-head{margin:30px 0 14px}
.page{background:var(--bg2);border:1px solid var(--line);border-radius:13px;margin-bottom:13px;overflow:hidden}
.page.failed{border-color:rgba(236,106,76,.4)}
.phead{display:flex;align-items:center;gap:14px;padding:16px 18px;cursor:pointer;user-select:none}
.phead:hover{background:var(--bg3)}
.psc{font-family:var(--mono);font-size:22px;font-weight:600;min-width:46px}
.purl{flex:1;min-width:0;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.purl small{display:block;font-family:var(--mono);font-size:11px;color:var(--ink3);margin-top:2px}
.pdots{display:flex;gap:5px}
.pdot{width:9px;height:9px;border-radius:2px}
.chev{color:var(--ink3);font-family:var(--mono);transition:transform .2s}
.page.open .chev{transform:rotate(90deg)}
.pbody{display:none;padding:4px 18px 20px;border-top:1px solid var(--line)}
.page.open .pbody{display:block}

.catblock{margin-top:18px}
.catblock h4{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-dim);margin:0 0 10px}
.check{display:flex;gap:11px;padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}
.check:last-child{border-bottom:none}
.badge{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:.1em;padding:3px 6px;border-radius:4px;height:fit-content;margin-top:2px;flex:0 0 auto}
.badge.pass{background:rgba(168,224,99,.14);color:var(--good)}
.badge.warn{background:rgba(232,178,58,.14);color:var(--mid)}
.badge.fail{background:rgba(236,106,76,.16);color:var(--bad)}
.check .ctext{flex:1}
.check .cid{font-family:var(--mono);font-size:11px;color:var(--ink3)}
.check .crec{color:var(--ink2);font-size:13px;margin-top:3px}

/* passage cards */
.pass-wrap{margin-top:22px}
.pcard{background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:15px 16px;margin-bottom:11px}
.pcard .ptop{display:flex;align-items:center;gap:12px;margin-bottom:9px}
.pcard .ptop .sc{font-family:var(--mono);font-size:18px;font-weight:600;min-width:38px}
.pbar{flex:1;height:6px;background:var(--bg3);border-radius:4px;overflow:hidden}.pbar i{display:block;height:100%}
.ctype{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink3);border:1px solid var(--line2);padding:3px 6px;border-radius:5px}
.phd{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-dim);margin:0 0 7px}
.phd.lead::after{content:" · lead";color:var(--ink3)}
.ptext{font-size:14px;color:var(--ink);background:var(--bg3);border-left:2px solid var(--line2);padding:10px 12px;border-radius:0 7px 7px 0;white-space:pre-wrap}
.pchips{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.pchip{font-family:var(--mono);font-size:10px;padding:3px 8px;border-radius:6px;border:1px solid var(--line2);color:var(--ink2)}
.pchip b{font-weight:600}
.pissues{margin:10px 0 0;padding:0;list-style:none}
.pissues li{display:flex;gap:8px;font-size:13px;color:var(--ink2);padding:4px 0}
.pissues li .dot{width:6px;height:6px;border-radius:50%;margin-top:6px;flex:0 0 auto}

.foot{margin-top:36px;color:var(--ink3);font-size:12.5px;border-top:1px solid var(--line);padding-top:16px;line-height:1.65;max-width:80ch}
.foot code{font-family:var(--mono);background:var(--bg3);padding:1px 5px;border-radius:4px;color:var(--ink2)}
