:root{
  --bg:#0a0b0e;--panel:#13151b;--panel2:#181b22;--line:#262a33;--txt:#e8eaf0;--mut:#888fa0;--dim:#5b6172;
  --amber:#ffb454;--amber2:#ff9d2f;--green:#62d39a;--red:#ff6f6f;--blue:#7aa2ff;--mag:#ff2bb5;
  --mono:"IBM Plex Mono",ui-monospace,Menlo,monospace;--body:"Hanken Grotesk",system-ui,sans-serif;--disp:"Bricolage Grotesque",var(--body);
}
[data-theme="light"]{
  --bg:#eef1f6;--panel:#ffffff;--panel2:#f4f6fa;--line:#dde2ea;--txt:#15171c;--mut:#5b6472;--dim:#9aa1ad;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:var(--bg);color:var(--txt);font-family:var(--body);font-size:14px}
a{color:var(--blue)}
button{font-family:var(--body)}
.hidden{display:none!important}
.ic{width:14px;height:14px;display:block;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* layout: top bar full width, below = main + activity */
#app{display:flex;flex-direction:column;height:100vh}
.top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 16px;background:var(--panel);border-bottom:1px solid var(--line);flex:none;flex-wrap:wrap}
.brand{font-family:var(--disp);font-weight:800;font-size:21px;letter-spacing:-.03em;color:var(--txt)}
.brand b{color:var(--amber)}
.tools{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.btn{font-size:12.5px;padding:7px 12px;border:1px solid var(--line);background:var(--panel2);border-radius:8px;color:var(--txt);cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.btn:hover{border-color:var(--dim)}
.btn:disabled{opacity:.45;cursor:default}
.btn:disabled:hover{border-color:var(--line)}
/* Top-menu buttons: lighter-grey outline by default, orange on hover. */
.tools .btn{border-color:var(--dim)}
.tools .btn:hover{border-color:var(--amber)}
.filteractions .btn:hover{border-color:var(--amber)}
.btn.primary{background:linear-gradient(180deg,var(--amber),var(--amber2));border:0;color:#1a1206;font-family:var(--disp);font-weight:700}
.btn.primary.discovering,.btn.busy{background:linear-gradient(110deg,var(--amber2),var(--amber),#ffe0a3,var(--amber),var(--amber2));background-size:300% 100%;animation:wavebg 1.1s ease-in-out infinite;color:#1a1206;border-color:transparent;cursor:progress}
.btn.fail{background:var(--red);border-color:var(--red);color:#3a0d0d;font-weight:700}
@keyframes wavebg{0%{background-position:0% 50%}100%{background-position:300% 50%}}
/* fade-in + roll-down reveal (discovery results) */
.reveal{display:grid;grid-template-rows:0fr;opacity:0;transition:grid-template-rows 1s cubic-bezier(.22,1,.36,1),opacity 1s ease}
.reveal>*{overflow:hidden;min-height:0}
.reveal.show{grid-template-rows:1fr;opacity:1}
.btn.icon{padding:7px 9px}
/* theme toggle: dark shows the moon, light shows the sun (mirrors skriinsjot.com) */
#t-theme .ic-sun{display:none}
[data-theme="light"] #t-theme .ic-sun{display:block}
[data-theme="light"] #t-theme .ic-moon{display:none}
.btn.on{border-color:var(--amber);color:var(--amber);background:rgba(255,180,84,.08)}
.sep{width:1px;height:22px;background:var(--line);margin:0 2px}

.below{display:flex;flex:1;min-height:0}
/* No top padding on the scroll container: position:sticky pins to the CONTENT edge
   (below top padding), which would leave a gap where rows peek above the pinned domain
   bar. Move the top gap onto #domains so it scrolls away instead. */
.main{flex:1;min-width:0;overflow:auto;padding:0 16px 16px}
#domains{padding-top:16px}
.filterbar{display:flex;align-items:center;gap:10px;flex-basis:100%}
.topmain{display:flex;align-items:center;gap:0;flex:1;min-width:0;flex-wrap:wrap}
.filteractions{display:flex;gap:8px;flex-basis:100%;flex-wrap:wrap;align-items:center}
.filter{flex:1;min-width:140px;margin:0 50px;padding:7px 11px;border:1px solid var(--amber);border-radius:9px;font-size:13px;background:var(--panel);color:var(--txt)}
.filter::placeholder{color:var(--dim)}
.statusfilter{display:flex;gap:6px;flex-shrink:0}

/* domains */
.dom{background:var(--panel);border:1px solid var(--dim);border-radius:11px;margin-bottom:10px}
/* Sticky domain bar: pins to the top of .main while its own URLs scroll past, then the
   next domain bar pushes it up (each .domhead sticks within its own .dom containing block). */
.domhead{display:flex;align-items:center;gap:10px;padding:12px 13px;cursor:pointer;position:sticky;top:0;z-index:3;background:var(--panel);border-radius:10px 10px 0 0;flex-wrap:wrap}
.dom.collapsed .domhead{border-radius:10px}
.domname{font-family:var(--disp);font-weight:700;font-size:14.5px;white-space:nowrap}
.pills{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.dompills2{display:flex;gap:6px;flex-wrap:wrap;align-items:center;padding:0 13px 11px 39px;margin-top:-4px}
.pill{font-family:var(--mono);font-size:10.5px;padding:3px 9px;border-radius:999px;background:var(--panel2);color:var(--mut);border:1px solid var(--line);white-space:nowrap}
.pill.status{font-weight:600;letter-spacing:.1em}
.pill.ok{background:rgba(98,211,154,.14);color:var(--green);border-color:rgba(98,211,154,.35)}
.pill.changed{background:rgba(255,180,84,.14);color:var(--amber);border-color:rgba(255,180,84,.35)}
.pill.error{background:rgba(255,111,111,.14);color:var(--red);border-color:rgba(255,111,111,.35)}
.pill.pending{background:rgba(122,162,255,.14);color:var(--blue);border-color:rgba(122,162,255,.35)}
.pill.flag{background:rgba(255,43,181,.12);color:var(--mag);border-color:rgba(255,43,181,.35)}
.pill.warn{background:rgba(255,180,84,.14);color:var(--amber);border-color:rgba(255,180,84,.35)}
.domactions{margin-left:auto;display:flex;gap:6px}
.iconbtn{cursor:pointer;border:1px solid var(--line);background:var(--panel2);border-radius:7px;padding:5px 6px;line-height:0;color:var(--txt)}
.iconbtn:hover{border-color:var(--dim)}
.iconbtn.danger:hover{border-color:var(--red);color:var(--red)}

.colhead{display:flex;align-items:center;gap:10px;padding:7px 13px;border-top:1px solid var(--line);background:rgba(127,127,127,.04)}
.ch{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;color:var(--mut)}
.rows{border-top:1px solid var(--line);overflow:hidden;border-radius:0 0 10px 10px}
.row{display:flex;align-items:center;gap:10px;padding:9px 13px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent);font-size:13px}
.row:last-child{border-bottom:0}
.row.hl{background:rgba(255,180,84,.10)}
.num{font-family:var(--mono);color:var(--mut);width:26px;text-align:right;flex:none}
.url{font-family:var(--mono);color:var(--txt);text-decoration:none;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12.5px}
.url:hover{text-decoration:underline}
.right{display:flex;align-items:center;gap:14px;color:var(--mut);font-size:12px}
.col-status{width:96px;display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.col-flags{display:flex;gap:6px;align-items:center;flex-shrink:0}
.urlcell{display:flex;align-items:center;gap:8px;flex:1;min-width:0;overflow:hidden}
.dot{display:inline-flex;align-items:center;gap:5px;font-weight:600;font-size:11.5px;font-family:var(--mono);letter-spacing:.04em;white-space:nowrap}
.dot::before{content:"";width:8px;height:8px;border-radius:50%}
.dot.ok{color:var(--green)}.dot.ok::before{background:var(--green)}
.dot.changed{color:var(--amber)}.dot.changed::before{background:var(--amber)}
.dot.error{color:var(--red)}.dot.error::before{background:var(--red)}
.dot.pending{color:var(--blue)}.dot.pending::before{background:var(--blue)}
.flagbadge{font-family:var(--mono);font-size:9px;padding:1px 5px;border-radius:5px;background:rgba(255,43,181,.14);color:var(--mag);border:1px solid rgba(255,43,181,.4);white-space:nowrap}
.flagbadge.err{background:rgba(255,111,111,.14);color:var(--red);border-color:rgba(255,111,111,.4)}
.scanpill{font-family:var(--mono);font-size:9px;padding:1px 6px;border-radius:5px;border:1px solid;white-space:nowrap}
.scanpill.pending,.scanpill.scanning{background:rgba(122,162,255,.14);color:var(--blue);border-color:rgba(122,162,255,.4)}
.scanpill.clean{background:rgba(98,211,154,.14);color:var(--green);border-color:rgba(98,211,154,.4)}
.pct{font-family:var(--mono);width:60px;text-align:right;color:var(--txt)}
.time{font-family:var(--mono);width:150px;text-align:right;color:var(--mut);font-size:11.5px}
.rowicons{display:flex;gap:6px;width:170px;justify-content:flex-end}

/* skriinsjot amber checkbox */
.chk{display:inline-flex;align-items:center;gap:9px;cursor:pointer;user-select:none}
.chk input{position:absolute;opacity:0;width:0;height:0}
.box{width:18px;height:18px;border-radius:6px;border:1.5px solid var(--amber);background:var(--panel2);display:grid;place-items:center;transition:.15s;flex:none}
.box svg{width:12px;height:12px;stroke:var(--bg);stroke-width:3.2;fill:none;stroke-linecap:round;stroke-linejoin:round;opacity:0;transform:scale(.6);transition:.15s}
[data-theme="light"] .box svg{stroke:#fff}
.chk input:checked+.box{background:var(--amber);border-color:var(--amber)}
.chk input:checked+.box svg{opacity:1;transform:scale(1)}
.chk:hover .box{border-color:var(--amber2);background:rgba(255,180,84,.5)}
.chk:hover input:checked+.box,.chk:hover .box.on,.chk:hover .box.mid{background:var(--amber)}
.box.xbox{border-color:var(--line);background:var(--panel2);color:var(--mut);font-size:12px;line-height:1;cursor:default}
.box.on,.box.mid{background:var(--amber);border-color:var(--amber)}
.box.on svg,.box.mid svg{opacity:1;transform:scale(1)}

/* selection bar */
.selbar{position:sticky;bottom:0;z-index:5;margin-top:14px;background:var(--panel2);border:1px solid var(--line);border-radius:11px;padding:10px 14px;display:flex;align-items:center;gap:12px;box-shadow:0 10px 30px rgba(0,0,0,.4)}
.selbar b{font-family:var(--mono);background:rgba(122,162,255,.16);color:var(--blue);padding:3px 10px;border-radius:999px;font-size:11.5px}
.selbar .sp{margin-left:auto}

/* activity panel */
.activity{width:340px;flex:none;background:var(--panel);border-left:1px solid var(--line);display:flex;flex-direction:column}
.act-resize{width:6px;cursor:col-resize;background:var(--panel2);flex:none}
.act-head{display:flex;align-items:center;gap:8px;padding:11px 13px;border-bottom:1px solid var(--line);flex:none}
.act-title{font-family:var(--disp);font-weight:700;font-size:14px}
.live{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:9px;letter-spacing:.12em;color:var(--green)}
.live .pdot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.act-head .sp{margin-left:auto}
.act-log{flex:1;overflow:auto}
.aln{padding:8px 13px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent)}
.atop{display:flex;align-items:center;gap:8px}
.ats{font-family:var(--mono);font-size:11.5px;color:var(--mut)}
.atag{font-family:var(--mono);font-weight:600;font-size:11.5px}
.atag.info{color:var(--green)}.atag.alert{color:var(--amber)}.atag.error{color:var(--red)}.atag.tick{color:var(--blue)}
.amsg{font-size:12.5px;margin-top:3px;line-height:1.45}
.aurl{display:block;margin-top:4px;color:var(--blue);font-family:var(--mono);font-size:11px;text-decoration:none;word-break:break-all;cursor:pointer}

/* modal */
.backdrop{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:50;padding:18px}
.modal{background:var(--panel);border:1px solid var(--amber);border-radius:14px;box-shadow:0 24px 70px rgba(0,0,0,.6);width:680px;max-width:100%;max-height:92vh;display:flex;flex-direction:column;overflow:hidden}
.modal.wide{width:1000px}
.modal.full{width:100%;height:84vh}
.mhead{display:flex;align-items:center;gap:12px;padding:15px 18px;border-bottom:1px solid var(--line);flex:none}
.mtitle{font-family:var(--disp);font-weight:800;font-size:18px}
.mhead .sp{margin-left:auto}
.mx{cursor:pointer;color:var(--mut);font-size:20px;line-height:1;border:1px solid var(--line);border-radius:8px;padding:2px 9px;background:var(--panel2)}
.mbody{padding:8px 18px 18px;overflow:auto}
.mfoot{display:flex;align-items:center;gap:10px;padding:14px 18px;border-top:1px solid var(--line);flex:none}
.mfoot .sp{margin-left:auto}
.divider{height:1px;background:var(--dim);margin:18px 0 2px}
.sechead{display:flex;align-items:center;gap:9px;margin:16px 0 10px}
.secnum{width:22px;height:22px;border-radius:7px;background:var(--panel2);border:1px solid var(--line);display:grid;place-items:center;font-family:var(--mono);font-size:11px;color:var(--amber)}
.sectitle{font-family:var(--disp);font-weight:700;font-size:14px}
.frow{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:10px 0}
.lbl{font-size:13px}.hint{font-size:13.5px;color:var(--mut)}
.inp{padding:3px 10px;border:1px solid var(--amber);border-radius:9px;background:var(--panel2);color:var(--txt);font-family:var(--mono);font-size:13px;width:100%}
.num-inp{width:64px;padding:2px 8px;border:1px solid var(--amber);border-radius:8px;background:var(--panel2);color:var(--txt);font-family:var(--mono);font-size:13px;text-align:center}
.filter:focus,.inp:focus,.num-inp:focus{outline:none;border-color:var(--amber2);box-shadow:0 0 0 3px rgba(255,180,84,.18)}
input[type="time"]{color-scheme:dark;color:var(--amber)}
input[type="time"]::-webkit-calendar-picker-indicator{filter:brightness(0) saturate(100%) invert(73%) sepia(42%) saturate(900%) hue-rotate(331deg) brightness(103%) contrast(101%);cursor:pointer}
.seg{display:flex;gap:8px;flex-wrap:wrap}
.seg .opt{flex:1;min-width:210px;border:1px solid var(--line);border-radius:10px;padding:11px 12px;cursor:pointer;background:var(--panel2);display:flex;gap:10px;align-items:flex-start}
.seg .opt.active{border-color:var(--amber);box-shadow:0 0 0 3px rgba(255,180,84,.12);background:rgba(255,180,84,.06)}
.seg .opt h4{font-family:var(--disp);font-size:13px;margin:0 0 3px}.seg .opt p{font-size:11px;color:var(--mut);margin:0;line-height:1.3}
.toggle2{display:inline-flex;border:1px solid var(--amber);border-radius:9px;overflow:hidden}
.toggle2 button{padding:0 16px;height:21px;line-height:21px;background:var(--panel2);border:0;color:var(--txt);font-size:12.5px;cursor:pointer}
.toggle2 button.active{background:linear-gradient(180deg,var(--amber),var(--amber2));color:#1a1206;font-weight:700;font-family:var(--disp)}
.checks-col{display:flex;flex-direction:column;gap:11px}
.checks-indent{margin-left:26px}
.mixedlist{margin:4px 0 0;padding-left:20px;list-style:disc}
.mixedlist li{font-family:var(--mono);word-break:break-all;margin:2px 0}
.vsep{color:var(--dim);margin:0 8px}
.section-off{opacity:.45;pointer-events:none}
/* Full-screen screenshot lightbox: scroll to zoom, move cursor to pan, click to close. */
.zoomoverlay{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.92);overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:zoom-out}
.zimg{max-width:100vw;max-height:100vh;transform-origin:center center;will-change:transform;user-select:none;-webkit-user-drag:none}
.chk.lblchk{font-size:13px;color:var(--txt)}
.ulhead{display:flex;align-items:center;gap:9px;margin:8px 0;flex-wrap:wrap}
.ulhead .count{font-family:var(--mono);font-size:11px;color:var(--mut)}
.ulhead .sp{margin-left:auto}
.linklike{color:var(--blue);font-size:11.5px;cursor:pointer;background:none;border:0;padding:0}
.urltree{border:1px solid var(--line);border-radius:10px;height:240px;min-height:120px;max-height:55vh;overflow:auto;background:var(--panel2);resize:vertical}
.tnode{display:flex;align-items:center;gap:8px;padding:6px 11px;border-bottom:1px solid color-mix(in srgb,var(--line) 60%,transparent);font-family:var(--mono);font-size:12px}
.tnode:last-child{border-bottom:0}
.tnode.branch{background:rgba(127,127,127,.04)}
.tchev{width:11px;flex:none;color:var(--mut);cursor:pointer;font-size:9px;text-align:center}
.tchev.leaf{visibility:hidden}
.texp{display:inline-grid;place-items:center;width:16px;height:16px;flex:none;border:1px solid var(--line);border-radius:4px;color:var(--mut);cursor:pointer;font-size:14px;line-height:1;user-select:none;font-family:var(--mono)}
.texp:hover{border-color:var(--amber);color:var(--amber)}
.texp.amber{border-color:var(--amber);color:var(--amber)}
.tname{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
a.tlink{color:var(--blue);text-decoration:none}
a.tlink:hover{text-decoration:underline}
.tsrc{font-family:var(--mono);font-size:9px;letter-spacing:.06em;padding:1px 6px;border-radius:999px;border:1px solid var(--line);color:var(--mut);flex:none}
.tsrc.crawl{color:var(--blue);border-color:rgba(122,162,255,.4)}
.tsrc.sitemap{color:var(--green);border-color:rgba(98,211,154,.4)}
.tsrc\+map,.tsrc.both{color:var(--amber);border-color:rgba(255,180,84,.4)}

/* screenshot viewer */
.cols{display:flex;gap:12px}
.shotcol{flex:1;min-width:0;display:flex;flex-direction:column}
.shothead{display:flex;align-items:baseline;justify-content:center;gap:8px;margin-bottom:7px}
.shotlabel{font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:var(--mut)}
.shotmeta{font-family:var(--mono);font-size:10.5px;color:var(--mut)}
.shotmeta.pct{color:var(--amber);font-weight:600}
.shotframe{border:1px solid var(--line);border-radius:10px;height:54vh;overflow-x:hidden;overflow-y:auto;background:#0e0f13;position:relative}
.shotframe img{width:100%;display:block;cursor:zoom-in}
.shotlens{position:absolute;border-radius:50%;border:2px solid var(--amber);box-shadow:0 6px 24px rgba(0,0,0,.55);background-repeat:no-repeat;background-color:#0e0f13;pointer-events:none;z-index:5}
.lenslabel{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--mono);font-size:10px;background:rgba(0,0,0,.7);color:#fff;padding:1px 7px;border-radius:8px;white-space:nowrap;pointer-events:none}
.lenslabel.ll-right{right:0;transform:translate(50%,-50%)}
.lenslabel.ll-left{left:0;transform:translate(-50%,-50%)}
.navurl{flex:1;min-width:0;text-align:center;font-family:var(--mono);font-size:11px;color:var(--mut);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* screenshot-modal nav: URL info box stacked above each prev/next button */
.navcol{display:flex;flex-direction:column;gap:6px;min-width:0;max-width:44%}
.navcol.next{align-items:flex-end}
.navcol .btn{justify-content:center;white-space:nowrap}
.navurlbox{max-width:100%;font-family:var(--mono);font-size:11px;color:var(--mut);background:var(--panel2);border:1px solid var(--line);border-radius:7px;padding:4px 10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* baseline-history dropdown under the BASELINE image in the screenshot viewer */
.basesel{margin-top:8px;width:100%;max-width:100%;font-family:var(--mono);font-size:11.5px;padding:6px 8px;border:1px solid var(--line);border-radius:8px;background:var(--panel2);color:var(--txt);cursor:pointer}
.basesel:hover{border-color:var(--amber)}
.shotbtn{width:100%;justify-content:center;margin-bottom:7px;border-color:var(--dim)}
.shotbtn:hover{border-color:var(--amber)}
/* Split "Accept … | and close" button: hovering the main text outlines just it;
   hovering "and close" highlights the whole button (it does accept + close). */
.shotsplit{width:100%;margin-bottom:7px;padding:0;border-color:var(--dim);display:flex;align-items:stretch;overflow:hidden}
.shotsplit:has(.split-close:hover){border-color:var(--amber)}
.shotsplit .split-main{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;padding:6px 12px;margin:2px;border:1px solid transparent;border-radius:6px}
.shotsplit .split-main:hover{border-color:var(--amber)}
.shotsplit .split-sep{width:1px;background:var(--dim);align-self:stretch;margin:5px 0}
.shotsplit .split-close{display:flex;align-items:center;justify-content:center;padding:6px 14px;white-space:nowrap;color:var(--mut)}
.shotsplit:has(.split-close:hover) .split-close{color:var(--amber)}
.shotsplit:disabled{opacity:.55;cursor:default}
.zoomslider{accent-color:var(--amber);width:120px;cursor:pointer;vertical-align:middle}

/* debug log */
.subbar{display:flex;align-items:center;gap:8px;padding:7px 16px;border-bottom:1px solid var(--line);flex:none}
.subbar .muted{font-family:var(--mono);font-size:10.5px;color:var(--mut)}
.buffered{font-family:var(--mono);font-size:10.5px;color:var(--amber);font-weight:600}
.tagfilter{font-family:var(--mono);font-size:10px;letter-spacing:.06em;padding:3px 9px;border-radius:999px;border:1px solid var(--line);background:var(--panel2);color:var(--mut);cursor:pointer}
.tagfilter.active.info{color:var(--green);border-color:rgba(98,211,154,.45)}
.tagfilter.active.alert{color:var(--amber);border-color:rgba(255,180,84,.45)}
.tagfilter.active.error{color:var(--red);border-color:rgba(255,111,111,.45)}
.tagfilter.active.tick{color:var(--blue);border-color:rgba(122,162,255,.45)}
.tagfilter.active.ok{color:var(--green);border-color:rgba(98,211,154,.45)}
.tagfilter.active.changed{color:var(--amber);border-color:rgba(255,180,84,.45)}
.tagfilter.active.pending{color:var(--blue);border-color:rgba(122,162,255,.45)}
.tagfilter.off{border-color:var(--dim);color:var(--mut)}
.pillsep{width:1px;height:16px;background:var(--line);margin:0 3px;flex-shrink:0}
.tagfilter.newpill{color:var(--mut)}
.tagfilter.newpill.has{opacity:1;color:var(--amber);border-color:rgba(255,180,84,.45)}
.tagfilter.active.newpill{opacity:1;color:var(--amber);border-color:rgba(255,180,84,.6);background:rgba(255,180,84,.12)}
.tagfilter.issuespill{color:var(--mut)}
.tagfilter.active.issuespill{opacity:1;color:var(--mag);border-color:rgba(255,43,181,.55);background:rgba(255,43,181,.10)}
.log{flex:1;overflow:auto;padding:10px 16px;background:#0b0c10;font-family:var(--mono);font-size:12px}
[data-theme="light"] .log,[data-theme="light"] .shotframe{background:#f4f6fa}
.ln{display:flex;gap:9px;padding:1px 0;line-height:1.65}
.ln .lts{color:var(--mut);flex:none}
.ln .ltag{flex:none;font-weight:600;width:54px}
.ln .ltag.info{color:var(--green)}.ln .ltag.alert{color:var(--amber)}.ln .ltag.error{color:var(--red)}.ln .ltag.tick{color:var(--blue)}
.ln .lmsg{color:var(--txt);white-space:pre-wrap}
.ln .lurl{color:var(--blue);cursor:pointer}

/* login gate */
.gate{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:100}
.gatecard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:30px;width:330px;text-align:center}
.gatecard .brand{font-size:26px;display:block;margin-bottom:6px}
.gatecard input{width:100%;margin:14px 0 10px}
.gateerr{color:var(--red);font-size:12px;min-height:16px}
.empty{color:var(--mut);text-align:center;padding:40px;font-size:13px}
.discover-err{color:var(--red);padding:13px;font-size:12.5px;line-height:1.5}
.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px}
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--amber);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loadtext{color:var(--amber);font-size:13px;text-align:center}
.uptime-badge{font-family:var(--mono);font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:999px;letter-spacing:.04em;white-space:nowrap}
.uptime-badge.up{background:rgba(98,211,154,.14);color:var(--green);border:1px solid rgba(98,211,154,.4)}
.uptime-badge.down{background:rgba(255,111,111,.14);color:var(--red);border:1px solid rgba(255,111,111,.4)}
.uptime-badge.slow{background:rgba(255,180,84,.14);color:var(--amber);border:1px solid rgba(255,180,84,.4)}
.uptime-badge.pending,.uptime-badge.ok{background:var(--panel2);color:var(--mut);border:1px solid var(--line)}
.sparkwrap{position:relative;border:1px solid var(--line);border-radius:8px;background:var(--panel2);margin:8px 0}
.sparksvg{width:100%;height:48px;display:block}
.sparkguide{position:absolute;top:0;height:48px;width:1px;background:var(--dim);opacity:0;pointer-events:none;transition:opacity .08s}
.sparkdot{position:absolute;width:8px;height:8px;border-radius:50%;background:var(--amber);transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 0 0 2px var(--panel2),0 0 0 4px rgba(255,180,84,.25)}
.sparktip{position:absolute;top:52px;transform:translateX(-50%);z-index:10;pointer-events:auto;user-select:text;width:238px;background:var(--panel);border:1px solid var(--amber);border-radius:9px;padding:8px 11px;box-shadow:0 0 0 1px rgba(255,180,84,.15),0 14px 34px -10px rgba(0,0,0,.7);white-space:nowrap;transition:opacity .08s}
.sparktip .stt-url{font-family:var(--mono);font-size:10.5px;color:var(--mut);overflow:hidden;text-overflow:ellipsis}
.sparktip .stt-time{font-weight:600;font-size:12px;margin:2px 0 6px;overflow:hidden;text-overflow:ellipsis}
.sparktip .stt-row{font-family:var(--mono);font-size:11px;color:var(--mut);line-height:1.55;overflow:hidden;text-overflow:ellipsis}
.sparktip .stt-row b{color:var(--txt);font-weight:600}
