:root{
  --navy:#0b2545; --navy-deep:#08182f; --navy-soft:#13315c;
  --accent:#2f80ed; --accent-2:#56ccf2; --gold:#f4b740;
  --ink:#0f1b2d; --muted:#5b6b82; --line:#e6ebf2; --bg:#f6f8fb; --white:#fff;
  --red:#e0533d; --amber:#e6a417; --green:#1f9d6b;
  --radius:16px; --shadow:0 20px 50px -20px rgba(11,37,69,.35);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.55}
h1,h2,h3{line-height:1.15;letter-spacing:-.02em;margin:0}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:1120px;margin:0 auto;padding:0 24px}
.narrow{max-width:760px}
.hidden{display:none !important}
.center{text-align:center}
.center-block{display:block;margin:18px auto 0}
.muted{color:var(--muted)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:15px;padding:13px 22px;border-radius:12px;cursor:pointer;border:1px solid transparent;transition:.18s ease;white-space:nowrap;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 20px -8px var(--accent)}
.btn-primary:hover{background:#1f6fe0;transform:translateY(-1px)}
.btn-primary:disabled{opacity:.6;cursor:wait;transform:none}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.22)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-outline{background:#fff;color:var(--accent);border-color:var(--accent)}
.btn-outline:hover{background:#eef5ff}
.btn-link{background:none;color:var(--accent);border:none}
.btn-block{width:100%;padding:16px;font-size:16px}

/* Nav */
.nav{position:sticky;top:0;z-index:20;background:var(--navy-deep)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-weight:800;font-size:20px;color:#fff;letter-spacing:-.03em;display:flex;align-items:center;gap:6px}
.brand-mark{color:var(--accent-2)}
.brand-sub{font-weight:500;font-size:14px;color:#9fb3cf}

/* Hero */
.hero{background:radial-gradient(1200px 500px at 80% -10%,var(--navy-soft),transparent 60%),var(--navy);color:#eaf1fb;padding:60px 0 70px}
.pill{display:inline-block;font-size:13px;font-weight:600;color:var(--accent-2);background:rgba(86,204,242,.12);border:1px solid rgba(86,204,242,.25);padding:6px 14px;border-radius:999px;margin-bottom:18px}
.hero h1{font-size:clamp(32px,5vw,50px);font-weight:800;color:#fff}
.accent{color:var(--accent-2)}
.lede{font-size:18px;color:#bdcde2;margin:18px 0 26px;max-width:32em}
.lede strong{color:#fff;font-weight:600}
.scan-box{display:flex;gap:10px;background:#fff;padding:8px;border-radius:14px;box-shadow:var(--shadow);max-width:560px}
.scan-box input{flex:1;border:none;outline:none;font-size:16px;padding:12px 14px;color:var(--ink);font-family:inherit;min-width:0}
.micro{font-size:13px;color:#9fb3cf;margin-top:12px}
.micro.center{color:var(--muted);text-align:center}

/* Cards / main */
main{padding:32px 0 60px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:22px}
.card-error{border-color:var(--red);color:var(--red);font-weight:600}

/* Loading */
.spinner{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:14px}
@keyframes spin{to{transform:rotate(360deg)}}
.steps{margin:0;padding-left:18px;color:var(--muted)}
.steps li{margin:4px 0;animation:fade .5s ease both}
.steps li:nth-child(2){animation-delay:.3s}
.steps li:nth-child(3){animation-delay:.6s}
.steps li:nth-child(4){animation-delay:.9s}
@keyframes fade{from{opacity:.2}to{opacity:1}}

/* Result head + gauge */
.result-head{display:flex;align-items:center;gap:26px}
.gauge{flex:0 0 auto;width:120px;height:120px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;box-shadow:inset 0 0 0 6px rgba(255,255,255,.25)}
.gauge.alto{background:var(--red)}
.gauge.medio{background:var(--amber)}
.gauge.baixo{background:var(--green)}
.gauge-score{font-size:40px;font-weight:800;line-height:1}
.gauge-cap{font-size:13px;opacity:.85}
.result-url{font-weight:700;font-size:18px;word-break:break-all}
.risk{font-weight:700;margin-top:6px}
.risk.alto{color:var(--red)} .risk.medio{color:var(--amber)} .risk.baixo{color:var(--green)}
.result-sub{color:var(--muted);font-size:14px;margin-top:4px}

.notice{background:#fff7e6;border:1px solid var(--amber);color:#8a5a00;border-radius:12px;padding:12px 16px;font-size:14px;margin-bottom:18px}
.sec-title{font-size:20px;margin:6px 0 14px}

/* Findings */
.finding{border:1px solid var(--line);border-left-width:5px;border-radius:12px;padding:16px 18px;margin-bottom:12px;background:#fff}
.finding.alta{border-left-color:var(--red)}
.finding.media{border-left-color:var(--amber)}
.finding.baixa{border-left-color:var(--gold)}
.finding h4{font-size:16px;margin:0 0 8px;display:flex;gap:8px;align-items:baseline}
.sev-tag{font-size:11px;font-weight:700;text-transform:uppercase;padding:2px 8px;border-radius:999px;color:#fff;flex:0 0 auto}
.sev-tag.alta{background:var(--red)} .sev-tag.media{background:var(--amber)} .sev-tag.baixa{background:var(--gold);color:#5a4300}
.finding p{margin:6px 0;font-size:14.5px}
.finding .lbl{font-weight:600;color:var(--ink)}
.finding .ev{color:var(--muted);font-family:ui-monospace,monospace;font-size:13px;word-break:break-word}
.finding .base{color:var(--muted);font-size:12.5px;font-style:italic}
.nat-tag{display:inline-block;margin-top:10px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px}
.nat-documento{background:#eef5ff;color:var(--accent)}
.nat-banner{background:#e9f8f0;color:var(--green)}
.nat-infra{background:#fff7e6;color:#8a5a00}
.resolve{background:#f4f9ff;border:1px solid var(--line)}
.resolve ul{margin:10px 0 0;padding-left:4px;list-style:none}
.resolve li{margin:8px 0;font-size:14.5px;padding-left:2px}

/* Paywall */
.locked{position:relative;border:1px dashed var(--accent);border-radius:12px;padding:20px;margin:6px 0 20px;overflow:hidden;background:#f4f9ff}
.locked-blur{filter:blur(5px);opacity:.5;user-select:none}
.lock-row{height:14px;background:var(--line);border-radius:6px;margin:8px 0}
.lock-row.short{width:60%}
.locked-cta{position:relative;text-align:center;margin-top:10px}
.locked-cta strong{display:block;color:var(--accent);font-size:16px}
.locked-cta span{color:var(--muted);font-size:14px}
.cta-main{margin-top:6px}

/* Celebração (site 100/100) */
.celebrate{text-align:center;border:1px solid var(--green);background:linear-gradient(180deg,#eafaf2,#fff)}
.celebrate-emoji{font-size:48px;line-height:1}
.celebrate h2{font-size:24px;color:var(--green);margin:8px 0 6px}
.celebrate>p{color:var(--ink);font-size:15.5px;margin:0 auto;max-width:34em}
.celebrate .cross-title{margin-top:22px;font-weight:600;color:var(--muted)}
.prod-cards{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-top:14px;text-align:left}
.prod-card{display:block;border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff;transition:.15s}
.prod-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 24px -14px var(--accent)}
.prod-card strong{display:block;color:var(--navy);font-size:14.5px;margin-bottom:5px}
.prod-card span{color:var(--muted);font-size:13px}
@media(max-width:560px){ .prod-cards{grid-template-columns:1fr} }

/* Router */
.router h3{font-size:18px}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}
.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit}
.chip:hover{border-color:var(--accent);color:var(--accent)}
.chip.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.rota{background:#f6f8fb;border:1px solid var(--line);border-radius:12px;padding:16px;margin-top:10px;font-size:14.5px}
.rota .btn{margin-top:12px}

/* Footer */
.foot{border-top:1px solid var(--line);padding:24px 0;color:var(--muted);font-size:13px;background:#fff}
.foot a{color:var(--accent);font-weight:600}
.foot p{margin:0 0 8px}

@media(max-width:560px){
  .result-head{flex-direction:column;text-align:center;gap:14px}
  .scan-box{flex-direction:column}
}

/* ===== Admin ===== */
.admin-title{font-size:26px;margin:28px 0 4px}
textarea#urls{width:100%;border:1px solid var(--line);border-radius:12px;padding:14px;font-family:ui-monospace,monospace;font-size:14px;resize:vertical;outline:none}
textarea#urls:focus{border-color:var(--accent)}
.admin-actions{display:flex;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap}
.summary{display:flex;gap:14px;flex-wrap:wrap;margin:6px 0 20px}
.stat{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 22px;text-align:center;min-width:110px}
.stat b{display:block;font-size:26px;color:var(--navy)}
.stat span{font-size:13px;color:var(--muted)}

.admin-tbl{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.admin-tbl th,.admin-tbl td{padding:11px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:14px}
.admin-tbl th{background:var(--navy-deep);color:#fff;font-weight:600;font-size:13px}
.admin-tbl tr:last-child td{border-bottom:none}
.admin-tbl .site{word-break:break-all;color:var(--muted)}
.admin-tbl .risk{font-weight:700;text-transform:capitalize}
.score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:30px;border-radius:8px;color:#fff;font-weight:800;padding:0 8px}
.score-badge.alto{background:var(--red)} .score-badge.medio{background:var(--amber)} .score-badge.baixo{background:var(--green)} .score-badge.na{background:var(--muted)}
.acts{display:flex;gap:6px;flex-wrap:wrap}
.btn-mini{border:1px solid var(--line);background:#fff;border-radius:8px;padding:5px 10px;font-size:12.5px;font-weight:600;cursor:pointer;color:var(--accent);font-family:inherit;transition:.15s}
.btn-mini:hover{border-color:var(--accent);background:#eef5ff}
.spin-sm{display:inline-block;width:16px;height:16px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}

/* modal */
.modal{position:fixed;inset:0;background:rgba(8,24,47,.55);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow-y:auto}
.modal-box{background:#fff;border-radius:var(--radius);max-width:680px;width:100%;padding:28px;position:relative;box-shadow:var(--shadow)}
.modal-close{position:absolute;top:14px;right:16px;border:none;background:none;font-size:20px;cursor:pointer;color:var(--muted)}
.modal-box h2{font-size:20px;word-break:break-all;margin-bottom:8px}
.modal-box .btn{margin-top:10px}
