/* ============ Scanner-specific styles ============ */
.scan-shell{max-width:980px;margin-inline:auto}
.dropzone{
  border:2px dashed var(--line);border-radius:var(--radius-lg);background:#fff;
  padding:clamp(2rem,5vw,3.4rem);text-align:center;transition:border-color .2s,background .2s;cursor:pointer;
}
.dropzone.drag{border-color:var(--accent);background:#fff8f6}
.dropzone .ico{width:64px;height:64px;margin:0 auto 1rem}
.scan-tabs{display:flex;gap:.4rem;background:var(--paper-2);padding:.35rem;border-radius:100px;width:max-content;margin:0 auto 1.6rem}
.scan-tabs button{border:0;background:transparent;font-family:var(--body);font-weight:600;font-size:.95rem;padding:.6em 1.4em;border-radius:100px;cursor:pointer;color:var(--text-soft);transition:.18s}
.scan-tabs button.active{background:var(--ink);color:var(--on-ink)}
.url-row{display:flex;gap:.6rem;flex-wrap:wrap}
.url-row input{flex:1;min-width:240px;font-family:var(--mono);font-size:1rem;padding:.95em 1.1em;border:1px solid var(--line);border-radius:100px}
.url-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(255,77,46,.12)}

/* Result */
.verdict-head{display:grid;grid-template-columns:auto 1fr;gap:1.6rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.4rem,3vw,2rem)}
@media(max-width:560px){.verdict-head{grid-template-columns:1fr;text-align:center}}
.score-ring{position:relative;width:140px;height:140px;flex:0 0 auto;margin-inline:auto}
.score-ring svg{transform:rotate(-90deg)}
.score-ring .val{position:absolute;inset:0;display:grid;place-content:center;text-align:center}
.score-ring .val b{font-family:var(--display);font-size:2.4rem;font-weight:600;line-height:1;display:block}
.score-ring .val span{font-family:var(--mono);font-size:.7rem;color:var(--text-mut);letter-spacing:.08em}
.v-clean{--c:#1f8a5b}.v-suspicious{--c:#e8a400}.v-malicious{--c:#ff4d2e}
.verdict-label{font-family:var(--display);font-size:clamp(1.6rem,4vw,2.3rem);font-weight:600;text-transform:capitalize;color:var(--c)}
.meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-top:1.2rem}
.meta-grid div{background:var(--paper-2);border-radius:10px;padding:.8rem 1rem}
.meta-grid .k{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;color:var(--text-mut);text-transform:uppercase}
.meta-grid .vv{font-weight:600;font-size:1.05rem;word-break:break-all}

.detect-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden}
.detect-table th,.detect-table td{text-align:left;padding:.85rem 1.1rem;border-bottom:1px solid var(--line);font-size:.95rem}
.detect-table th{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mut);background:var(--paper-2)}
.detect-table tr:last-child td{border-bottom:0}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:.5em;vertical-align:middle}
.dot-mal{background:#ff4d2e}.dot-sus{background:#e8a400}.dot-ok{background:#1f8a5b}

.vote-box{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.4rem}
.vote-btn{display:inline-flex;align-items:center;gap:.5em;border:2px solid var(--line);background:#fff;border-radius:100px;padding:.7em 1.3em;font-weight:600;cursor:pointer;font-family:var(--body);font-size:.95rem;transition:.15s}
.vote-btn:hover{transform:translateY(-2px)}
.vote-btn.mal.active{border-color:var(--accent);background:var(--accent);color:#fff}
.vote-btn.safe.active{border-color:var(--accent-2);background:var(--accent-2);color:#fff}
.vote-bar{flex:1;min-width:160px;height:12px;border-radius:100px;background:var(--accent-2);overflow:hidden;position:relative}
.vote-bar i{position:absolute;left:0;top:0;bottom:0;background:var(--accent);transition:width .4s}

.comment{display:grid;grid-template-columns:auto 1fr;gap:.9rem;padding:1.1rem 0;border-bottom:1px solid var(--line)}
.comment .av{width:40px;height:40px;border-radius:50%;background:var(--ink);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600}
.comment .who{font-weight:600}.comment .when{font-family:var(--mono);font-size:.75rem;color:var(--text-mut)}
.comment p{margin:.3rem 0 0;color:var(--text-soft)}

.list-row{display:flex;align-items:center;gap:1rem;padding:.9rem 0;border-bottom:1px solid var(--line)}
.list-row:last-child{border-bottom:0}
.list-row .badge{flex:0 0 auto}
.list-row a{font-family:var(--mono);font-size:.9rem;word-break:break-all}
.list-row .sc{margin-left:auto;font-family:var(--display);font-weight:600;flex:0 0 auto}
.tab-pane{display:none}.tab-pane.active{display:block}
.spinner{width:46px;height:46px;border:4px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin:1.5rem auto}
@keyframes spin{to{transform:rotate(360deg)}}
.scan-progress{font-family:var(--mono);font-size:.85rem;color:var(--text-mut);text-align:center}
