/* =====================================================================
   anticheat.cloud — Console
   Redesigned with Vercel's Geist design system
   Pure-black security console: hairline borders, Geist Sans/Mono,
   inverted primary buttons, tinted status badges.
   (All class names / IDs preserved for app.js + i18n.js.)
   ===================================================================== */
/* Self-hosted official Geist (Vercel `geist` package) — no Google Fonts. */
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:300 800;font-display:swap;src:url('/fonts/HankenGrotesk-Variable.woff2?v=1') format('woff2')}
@font-face{font-family:'Geist Mono';font-style:normal;font-weight:100 900;font-display:swap;src:url('/fonts/GeistMono-Variable.woff2') format('woff2')}

:root{
  /* surfaces */
  --bg:#000000;
  --bg2:#0a0a0a;
  --panel:#0a0a0a;
  --panel2:#111111;
  --elevated:#161616;
  /* lines */
  --line:#1f1f1f;
  --line2:#2e2e2e;
  --line3:#454545;
  /* text */
  --txt:#ededed;
  --muted:#8f8f8f;
  --muted2:#5a5a5a;
  /* brand + status */
  --accent:#0070f3;
  --accent2:#3291ff;
  --clean:#0cce6b;
  --review:#f5a623;
  --susp:#f97316;
  --crit:#ff5c5c;
  /* misc */
  --shadow:0 8px 30px rgba(0,0,0,.6);
  --r:10px;
  --r-sm:7px;
  --sans:'Hanken Grotesk','Geist',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --mono:'Geist Mono','SF Mono','JetBrains Mono',Consolas,'Liberation Mono',monospace;
  font-family:var(--sans);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg);
  color:var(--txt);
  min-height:100vh;
  font-feature-settings:"ss01","cv01","cv03";
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  /* faint security-grid backdrop */
  background-image:
    radial-gradient(900px 500px at 100% -10%, rgba(0,112,243,.06), transparent 60%),
    linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:auto, 44px 44px, 44px 44px;
}
.hidden{display:none !important}
.muted{color:var(--muted)}
::selection{background:rgba(0,112,243,.35);color:#fff}

/* brand mark (shield SVG lives inside this span) */
.brand-fish{display:inline-flex;align-items:center;color:var(--accent);line-height:0}
.brand-fish svg{width:1.05em;height:1.05em}

/* ===== BUTTONS (Geist) ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  border:1px solid var(--line2);background:transparent;color:var(--txt);
  padding:0 15px;height:38px;border-radius:var(--r-sm);
  cursor:pointer;font-family:var(--sans);font-size:14px;font-weight:500;text-decoration:none;
  transition:background .15s,border-color .15s,color .15s,opacity .15s;white-space:nowrap}
.btn svg{flex:none}
.btn:hover{border-color:var(--line3);background:#161616}
.btn:active{background:#1f1f1f}
.btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}
.btn.primary{background:#ededed;border-color:#ededed;color:#000;font-weight:600}
.btn.primary:hover{background:#fff;border-color:#fff}
.btn.ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn.ghost:hover{background:#161616;color:var(--txt);border-color:transparent}
.btn.sm{height:30px;padding:0 11px;font-size:13px;border-radius:6px}
.btn.danger{border-color:rgba(255,92,92,.35);color:var(--crit);background:transparent}
.btn.danger:hover{background:rgba(255,92,92,.1);border-color:var(--crit)}

/* ===== LANGUAGE SWITCH ===== */
.lang-switch{position:fixed;top:14px;right:16px;z-index:100;display:flex;gap:2px;
  background:rgba(10,10,10,.85);backdrop-filter:blur(8px);border:1px solid var(--line2);
  border-radius:999px;padding:3px}
.lang-btn{border:0;background:transparent;color:var(--muted);font-family:var(--mono);font-weight:600;
  font-size:11px;padding:5px 11px;border-radius:999px;cursor:pointer;letter-spacing:.5px;transition:.15s}
.lang-btn:hover{color:var(--txt)}
.lang-btn.active{background:#ededed;color:#000}

/* ===== LOGIN ===== */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{width:380px;max-width:100%;background:linear-gradient(180deg,#0c0c0c,#070707);
  border:1px solid var(--line);border-radius:16px;padding:34px 30px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:15px}
.login-brand{display:flex;align-items:center;justify-content:center;gap:10px;font-size:21px;font-weight:600;
  letter-spacing:-.02em}
.login-brand .brand-fish svg{width:26px;height:26px}
.login-sub{text-align:center;color:var(--muted);margin:-9px 0 8px;font-size:13px}
.fld{display:flex;flex-direction:column;gap:7px;font-size:13px;color:var(--muted);font-weight:500}
.fld input{background:#050505;border:1px solid var(--line2);border-radius:var(--r-sm);
  padding:11px 13px;color:var(--txt);font-size:14px;font-family:var(--sans);transition:border-color .15s,box-shadow .15s}
.fld input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,112,243,.2)}
.form-err{color:var(--crit);font-size:13px;min-height:16px;text-align:center}
.login-home{display:block;text-align:center;color:var(--muted);font-size:13px;margin-top:2px;text-decoration:none}
.login-home:hover{color:var(--txt)}

/* ===== APP SHELL ===== */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh;transition:grid-template-columns .2s ease}
.app[data-side="closed"]{grid-template-columns:0 1fr}
.sidebar{background:var(--bg2);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 12px;position:sticky;top:0;height:100vh;
  min-width:0;overflow-x:hidden;transition:transform .2s ease}
.app[data-side="closed"] .sidebar{transform:translateX(-100%)}
/* collapse handle: sits on the sidebar edge when open, at the screen edge when closed */
.side-toggle{position:fixed;top:14px;left:222px;z-index:120;width:26px;height:26px;padding:0;
  display:flex;align-items:center;justify-content:center;border:1px solid var(--line2);
  background:var(--panel);color:var(--muted);border-radius:7px;cursor:pointer;font-size:16px;line-height:1;
  transition:left .2s ease,background .15s,color .15s}
.side-toggle:hover{background:var(--elevated);color:var(--txt)}
.side-toggle::before{content:"\2039"}
.app[data-side="closed"] .side-toggle{left:10px}
.app[data-side="closed"] .side-toggle::before{content:"\203A"}
.side-brand{display:flex;align-items:center;gap:10px;font-weight:600;font-size:16px;
  letter-spacing:-.01em;padding:8px 10px 16px}
.side-brand .brand-fish svg{width:20px;height:20px}
.side-name{color:var(--txt)}
/* sidebar search — jumps to Checks and focuses the search field ( / shortcut ) */
.side-search{display:flex;align-items:center;gap:10px;margin:0 0 10px;height:40px;padding:0 12px;
  width:100%;background:var(--panel2);border:1px solid var(--line);border-radius:var(--r);cursor:pointer;
  color:var(--muted);font:inherit;font-size:13.5px;transition:background .15s,border-color .15s}
.side-search:hover{background:var(--elevated);border-color:var(--line2)}
.side-search svg{width:16px;height:16px;flex:0 0 auto}
.side-search span{flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.side-search kbd{font:inherit;font-size:11px;color:var(--muted2);border:1px solid var(--line2);
  border-radius:5px;padding:1px 6px;line-height:1.4}
.side-sec-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--muted2);padding:2px 11px 8px}
.side-nav{display:flex;flex-direction:column;gap:2px;flex:1 1 auto;overflow-y:auto;min-height:0}
.nav-count{margin-left:auto;font-size:11.5px;font-weight:600;color:var(--muted);font-variant-numeric:tabular-nums;
  background:rgba(255,255,255,.05);border-radius:999px;padding:1px 8px;min-width:22px;text-align:center}
.nav-item.active .nav-count{color:var(--accent2);background:rgba(255,255,255,.09)}
.nav-item{display:flex;align-items:center;gap:11px;background:transparent;border:0;color:var(--muted);
  text-align:left;padding:9px 11px;border-radius:var(--r-sm);cursor:pointer;font-size:14px;font-weight:500;
  font-family:var(--sans);transition:background .12s,color .12s;text-decoration:none}
.nav-item .ni-ic{display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center}
.nav-item .ni-ic svg{width:17px;height:17px;stroke-width:1.8}
.nav-item:hover{background:#141414;color:var(--txt)}
.nav-item.active{background:#1a1a1a;color:#fff}
.nav-item:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}
.tab:focus-visible{outline:none;box-shadow:0 0 0 2px var(--bg),0 0 0 4px var(--accent)}
.side-foot{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:14px;
  margin-top:auto;border-top:1px solid var(--line)}
.who{display:flex;align-items:center;gap:10px}
.who-av{width:32px;height:32px;border-radius:8px;background:#1a1a1a;border:1px solid var(--line2);
  color:var(--txt);display:grid;place-items:center;font-weight:600;font-size:13px;text-transform:uppercase}
.who-name{font-weight:600;font-size:14px}
.who-role{font-size:12px;color:var(--muted);font-family:var(--mono)}

.content{padding:34px 40px;overflow:auto;max-width:1280px}
.view-head h1{margin:0;font-size:26px;font-weight:600;letter-spacing:-.02em}
.view-head p{margin:6px 0 26px;color:var(--muted);font-size:14px;max-width:64ch}
.sec-title{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;
  font-weight:600;margin:30px 0 14px}

/* ===== STAT CARDS ===== */
.stat-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.stat-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:18px 18px 16px;
  cursor:pointer;transition:border-color .15s,background .15s,transform .15s;position:relative;overflow:hidden}
.stat-card:hover{border-color:var(--line3);background:var(--panel2)}
.sc-n{font-size:30px;font-weight:600;line-height:1;font-family:var(--mono);letter-spacing:-.02em}
.stat-card.cat-CLEAN .sc-n{color:var(--clean)}
.stat-card.cat-REVIEW .sc-n{color:var(--review)}
.stat-card.cat-SUSPICIOUS .sc-n{color:var(--susp)}
.stat-card.cat-CRITICAL .sc-n{color:var(--crit)}
.sc-l{color:var(--muted);font-size:12.5px;margin-top:9px;font-weight:500}
.sc-sub{color:var(--muted2);font-size:11px;margin-top:3px;font-family:var(--mono)}
.stat-card.forensic .sc-n{color:var(--accent2)}
.stat-card.forensic.hot .sc-n{color:var(--crit)}

/* ===== FILTER CHIPS ===== */
.filterbar{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}
.chip{border:1px solid var(--line2);background:transparent;color:var(--muted);padding:6px 14px;border-radius:999px;
  cursor:pointer;font-size:13px;font-weight:500;font-family:var(--sans);transition:.15s}
.chip:hover{color:var(--txt);border-color:var(--line3)}
.chip.active{background:#ededed;color:#000;border-color:#ededed}
.chip.c-CLEAN.active{background:var(--clean);border-color:var(--clean);color:#04130c}
.chip.c-REVIEW.active{background:var(--review);border-color:var(--review);color:#1a1200}
.chip.c-SUSPICIOUS.active{background:var(--susp);border-color:var(--susp);color:#1a0d00}
.chip.c-CRITICAL.active{background:var(--crit);border-color:var(--crit);color:#1a0606}

/* ===== CHECK / DL / AGENT ROWS ===== */
.check-list,.dl-list{display:flex;flex-direction:column;gap:8px}
/* reports-by-country widget */
.country-list{display:flex;flex-direction:column;gap:7px;max-width:560px}
.country-row{display:grid;grid-template-columns:24px minmax(90px,1fr) 2fr 40px;align-items:center;gap:12px}
.cy-flag{font-size:16px;line-height:1;text-align:center}
.cy-name{font-size:13.5px;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cy-bar{position:relative;height:8px;border-radius:999px;background:var(--elevated);overflow:hidden}
.cy-fill{position:absolute;inset:0 auto 0 0;border-radius:999px;background:var(--accent);min-width:3px}
.cy-n{font-size:13px;color:var(--muted);text-align:right;font-variant-numeric:tabular-nums}
.check-row{display:grid;grid-template-columns:40px 1fr auto auto auto;align-items:center;gap:14px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:13px 16px;
  cursor:pointer;transition:border-color .15s,background .15s}
.check-row:hover{border-color:var(--line3);background:var(--panel2)}
.cr-ic{width:40px;height:40px;border-radius:9px;display:grid;place-items:center;font-size:17px;
  background:#141414;border:1px solid var(--line)}
.cr-main .cr-host{font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cr-main .cr-sub{color:var(--muted);font-size:12.5px;margin-top:3px;font-family:var(--mono)}
.cr-score{font-weight:600;font-size:18px;text-align:right;font-family:var(--mono)}
.cr-score small{display:block;font-weight:500;font-size:10.5px;color:var(--muted);font-family:var(--sans);
  text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.cr-actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.row-between{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}
.agent-row,.dl-row{cursor:default}

/* ===== PILLS / TAGS / DOTS ===== */
.pill{padding:4px 11px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.01em;
  border:1px solid transparent;white-space:nowrap}
.pill.CLEAN{background:rgba(12,206,107,.12);color:var(--clean);border-color:rgba(12,206,107,.25)}
.pill.REVIEW{background:rgba(245,166,35,.12);color:var(--review);border-color:rgba(245,166,35,.25)}
.pill.SUSPICIOUS{background:rgba(249,115,22,.13);color:var(--susp);border-color:rgba(249,115,22,.28)}
.pill.CRITICAL{background:rgba(255,92,92,.12);color:var(--crit);border-color:rgba(255,92,92,.3)}
.pill.UNKNOWN{background:rgba(143,143,143,.1);color:var(--muted);border-color:rgba(143,143,143,.22)}
.tag{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:2px 7px;
  border-radius:5px;font-family:var(--mono)}
.tag.test{background:rgba(0,112,243,.16);color:var(--accent2)}
.tag.hidden-tag{background:rgba(143,143,143,.14);color:var(--muted)}
.nav-badge{margin-left:auto;background:var(--clean);color:#04130c;border-radius:999px;font-size:11px;
  font-weight:700;padding:1px 8px;font-family:var(--mono)}
.live-dot{width:9px;height:9px;border-radius:50%;display:inline-block;background:var(--muted2)}
.live-dot.ok{background:var(--clean);box-shadow:0 0 0 3px rgba(12,206,107,.18)}
.live-dot.warn{background:var(--review);box-shadow:0 0 0 3px rgba(245,166,35,.18)}
.live-dot.off{background:var(--muted2)}
.empty-list{color:var(--muted);padding:44px;text-align:center;border:1px dashed var(--line2);
  border-radius:var(--r);font-size:14px}

/* ===== START CHECK ===== */
.gen-card{display:flex;gap:12px;align-items:center;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:16px;flex-wrap:wrap}
.gen-note{flex:1;min-width:240px;background:#050505;border:1px solid var(--line2);border-radius:var(--r-sm);
  padding:11px 13px;color:var(--txt);font-size:14px;font-family:var(--sans)}
.gen-note:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,112,243,.2)}
.gen-result{margin-top:14px;background:rgba(12,206,107,.05);border:1px solid rgba(12,206,107,.3);
  border-radius:var(--r);padding:16px}
.gen-result-label{font-size:13px;color:var(--clean);font-weight:600;margin-bottom:10px}
.gen-link-row{display:flex;gap:10px}
.gen-link{flex:1;background:#050505;border:1px solid var(--line2);border-radius:var(--r-sm);padding:11px 13px;
  color:var(--txt);font-size:13px;font-family:var(--mono)}

/* ===== DETAIL VIEW ===== */
.back-btn{margin-bottom:18px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--r)}
.machine{padding:20px 22px;margin-bottom:18px}
.machine-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px 24px}
.mi{display:flex;flex-direction:column;gap:5px}
.mi .k{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;font-weight:600}
.mi .v{font-size:14px;font-weight:500;font-family:var(--mono)}
.mi .v .country-mismatch{color:var(--muted);font-size:12px;font-weight:500}
.badge{padding:4px 10px;border-radius:7px;font-size:12.5px;font-weight:600;background:#1a1a1a;border:1px solid var(--line2)}
.badge.CLEAN{color:var(--clean);border-color:rgba(12,206,107,.3)}
.badge.REVIEW{color:var(--review);border-color:rgba(245,166,35,.3)}
.badge.SUSPICIOUS{color:var(--susp);border-color:rgba(249,115,22,.3)}
.badge.CRITICAL{color:var(--crit);border-color:rgba(255,92,92,.3)}

.layout{display:grid;grid-template-columns:290px 1fr;gap:16px}
.results{padding:18px}
.results-head{display:flex;gap:12px;align-items:center;margin-bottom:16px}
.shield{font-size:22px;color:var(--accent)}
.results-title{font-weight:600;font-size:15px}
.results-sub{font-size:12px;color:var(--muted);font-family:var(--mono);margin-top:2px}
.tabs{display:flex;flex-direction:column;gap:2px}
.tab{display:flex;align-items:center;gap:10px;background:transparent;border:0;color:var(--muted);text-align:left;
  padding:10px 11px;border-radius:var(--r-sm);cursor:pointer;font-size:14px;font-weight:500;
  font-family:var(--sans);transition:background .12s,color .12s}
.tab:hover{background:#161616;color:var(--txt)}
.tab.active{background:#1a1a1a;color:#fff}
.tab .count{margin-left:auto;background:#000;border:1px solid var(--line2);border-radius:999px;
  padding:1px 9px;font-size:12px;color:var(--muted);font-family:var(--mono)}
.tab.active .count{color:var(--txt)}
.tab.ai .ai-badge{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700;font-size:10px;letter-spacing:.05em}
.tab-confirmed{color:var(--crit)}
.tab-confirmed.active{background:rgba(255,92,92,.09);color:#fff}
.tab-confirmed .count{color:var(--crit);border-color:rgba(255,92,92,.3)}
.confirmed-banner{margin:0 0 14px;padding:12px 14px;border-radius:var(--r-sm);
  background:rgba(255,92,92,.09);border:1px solid rgba(255,92,92,.35);color:#ffdada;
  font-weight:600;font-size:13px;line-height:1.45}
.confirmed-banner.hidden{display:none}
.tab-evasion{color:var(--susp)}
.tab-evasion.active{background:rgba(249,115,22,.09);color:#fff}
.tab-evasion .count{color:var(--susp);border-color:rgba(249,115,22,.3)}
.evasion-banner{margin:0 0 14px;padding:12px 14px;border-radius:var(--r-sm);
  background:rgba(249,115,22,.09);border:1px solid rgba(249,115,22,.35);color:#ffe5c9;
  font-weight:600;font-size:13px;line-height:1.45}
.evasion-banner[data-sev="Critical"]{background:rgba(255,92,92,.09);border-color:rgba(255,92,92,.35);color:#ffdada}
.evasion-banner.hidden{display:none}
.chip{display:inline-block;margin:3px 6px 0 0;padding:2px 8px;border-radius:999px;
  font-size:11px;font-family:var(--mono);border:1px solid var(--line2);color:var(--muted)}
.chip.sev-Critical{color:var(--crit);border-color:rgba(255,92,92,.35);background:rgba(255,92,92,.06)}
.chip.sev-High{color:var(--susp);border-color:rgba(249,115,22,.35);background:rgba(249,115,22,.06)}
.chip.sev-Medium{color:var(--review);border-color:rgba(245,166,35,.35);background:rgba(245,166,35,.06)}
.ipclass{font-family:var(--mono);font-size:12px}
.ipclass-datacenter{color:var(--crit)}
.ipclass-vpn,.ipclass-proxy,.ipclass-tor{color:var(--susp)}
.ipclass-mobile{color:var(--review)}
.ipclass-residential{color:var(--clean)}
.ipclass-unknown{color:var(--muted)}
.detail-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}
.newban{display:flex;flex-direction:column;gap:12px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:16px 18px;margin-bottom:18px}
.newban .ban-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px 14px}
.newban .ban-reason{grid-column:1/-1}
.newban .ban-actions{display:flex;align-items:center;gap:12px}
.c-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.ban-table{display:flex;flex-direction:column;gap:2px}
.ban-head{background:var(--panel2);color:var(--muted);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.ban-head,.ban-row{display:grid;grid-template-columns:2fr 1fr auto auto;gap:12px;padding:10px 14px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);align-items:center}
.ban-row .mono{font-family:var(--mono);font-size:12px;color:var(--txt);white-space:normal;line-height:1.5}
.mono.multi-acc{color:var(--crit);position:relative}
.mono.multi-acc::after{content:"MULTI";margin-left:8px;padding:1px 6px;border-radius:999px;
  background:rgba(255,92,92,.15);border:1px solid rgba(255,92,92,.35);color:var(--crit);
  font-size:10px;font-family:var(--sans);font-weight:600;letter-spacing:.05em}
.t-ic{display:inline-flex;width:16px;justify-content:center}
.t-ic.ok{color:var(--clean)} .t-ic.warn{color:var(--crit)} .t-ic.amber{color:var(--review)} .t-ic.eye{color:var(--accent2)}

.detail{padding:20px;min-height:440px}
.detail-head{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;margin-bottom:18px;
  padding-bottom:14px;border-bottom:1px solid var(--line)}
.detail-ic{display:inline-flex;color:var(--muted)}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:12px}
.dcard{background:#0c0c0c;border:1px solid var(--line);border-radius:var(--r);padding:15px;
  transition:border-color .15s,background .15s;cursor:pointer}
.dcard:hover{border-color:var(--line3)}
.dcard.sev-Critical{border-color:rgba(255,92,92,.35);background:rgba(255,92,92,.05)}
.dcard.sev-High{border-color:rgba(249,115,22,.32);background:rgba(249,115,22,.05)}
.dcard.sev-Medium{border-color:rgba(245,166,35,.28);background:rgba(245,166,35,.04)}
.dcard.sev-Low{border-color:rgba(0,112,243,.28);background:rgba(0,112,243,.04)}
.dcard.sev-Info{border-color:var(--line)}
.c-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.c-ic{font-size:18px}
.inst{font-size:11px;color:var(--muted);background:#000;border:1px solid var(--line);padding:3px 8px;
  border-radius:5px;font-family:var(--mono)}
.c-title{font-weight:600;font-size:14px;margin-bottom:7px;letter-spacing:-.01em}
.c-meta{font-size:12.5px;color:var(--muted);white-space:pre-wrap;line-height:1.5;font-family:var(--mono)}
.c-conf{margin-top:11px;padding-top:10px;border-top:1px solid var(--line);font-size:12px;color:var(--muted2)}
.ai-pane{white-space:pre-wrap;line-height:1.65;font-size:14px;background:#0c0c0c;border:1px solid var(--line);
  border-radius:var(--r);padding:20px}
.empty{color:var(--muted);padding:54px;text-align:center}

/* ===== USERS ===== */
.newuser{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:24px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:16px}
.newuser input,.newuser select{background:#050505;border:1px solid var(--line2);border-radius:var(--r-sm);
  padding:10px 12px;color:var(--txt);font-size:14px;font-family:var(--sans)}
.newuser input:focus,.newuser select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,112,243,.2)}
.newuser input{min-width:170px}
.form-msg{font-size:13px}
.form-msg.ok{color:var(--clean)} .form-msg.err{color:var(--crit)}
.user-table{display:flex;flex-direction:column;gap:8px}
.user-row{display:grid;grid-template-columns:40px 1fr 110px 1fr auto;align-items:center;gap:14px;
  background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:12px 16px}
.user-row .uname{font-weight:600}
.role-tag{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:999px;justify-self:start;
  border:1px solid transparent}
.role-tag.admin{background:rgba(0,112,243,.14);color:var(--accent2);border-color:rgba(0,112,243,.3)}
.role-tag.viewer{background:rgba(143,143,143,.12);color:var(--muted);border-color:rgba(143,143,143,.22)}
.urow-meta{font-size:12px;color:var(--muted);font-family:var(--mono)}
.proj-chip{font-family:var(--mono);font-size:11px;color:var(--accent2);vertical-align:middle;
  background:rgba(0,112,243,.08);border:1px solid rgba(0,112,243,.28);border-radius:5px;padding:1px 6px;margin-left:6px}
.nu-suffix{font-family:var(--mono);font-size:12.5px;color:var(--muted);align-self:center;margin-left:-4px}

/* ===== CHECKS TOOLBAR / SEARCH ===== */
.checks-toolbar{display:flex;align-items:center;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.search-wrap{position:relative;flex:1;min-width:230px;max-width:420px}
.search-ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted);pointer-events:none}
.search-input{width:100%;background:#050505;border:1px solid var(--line2);border-radius:var(--r-sm);
  padding:9px 12px 9px 36px;color:var(--txt);font-size:14px;font-family:var(--sans)}
.search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,112,243,.2)}
.checks-toolbar .filterbar{margin:0}

/* ===== PER-CHECK NOTE ===== */
.cr-note{color:var(--accent2);font-weight:500;font-size:13px}

/* ===== IDENTITY & NETWORK PANEL ===== */
.identity{padding:18px 22px;margin-bottom:18px}
.identity-head{display:flex;align-items:center;gap:9px;font-weight:600;font-size:15px;margin-bottom:16px;
  padding-bottom:14px;border-bottom:1px solid var(--line)}
.identity-ic{font-size:18px}
.identity-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px 24px}
.identity-grid .mi.sc{grid-column:1 / -1}
.v.mono{font-family:var(--mono);font-size:13px;word-break:break-all}
#d-socialclub{font-family:var(--mono);font-size:13.5px;word-break:break-all;color:var(--clean)}

/* ===== "?" HELP BUTTON + EXPLANATION POPOVER ===== */
.qbtn{width:18px;height:18px;flex:0 0 18px;border-radius:50%;border:1px solid var(--line3);background:transparent;
  color:var(--muted);font-size:11px;font-weight:700;line-height:1;cursor:pointer;display:inline-flex;
  align-items:center;justify-content:center;padding:0;transition:.15s;font-family:var(--mono)}
.qbtn:hover{color:var(--txt);border-color:var(--accent);background:rgba(0,112,243,.14)}
.identity-head .qbtn{margin-left:2px}
.c-top-r{display:inline-flex;align-items:center;gap:8px}
.explain-pop{position:absolute;z-index:200;max-width:340px;background:#0c0c0c;border:1px solid var(--line2);
  border-radius:var(--r);padding:13px 15px;box-shadow:var(--shadow);animation:popIn .12s ease}
.ep-title{font-size:11.5px;font-weight:600;color:var(--accent2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:7px}
.ep-body{font-size:13px;line-height:1.55;color:var(--txt)}
@keyframes popIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}

/* ===== CARD OVERFLOW FIX + CLICK-TO-EXPAND ===== */
.t-ic.net{color:var(--accent2)}
.card-grid{max-height:62vh;overflow-y:auto;padding-right:4px}
.dcard{cursor:pointer}
.c-title{overflow-wrap:anywhere}
.c-meta{overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}

/* ===== CONNECTION TIMELINE ===== */
.conn-pane{display:flex;flex-direction:column}
.conn-head{font-size:12.5px;color:var(--muted);margin-bottom:12px;line-height:1.55}
.conn-list{display:flex;flex-direction:column;gap:4px;max-height:58vh;overflow-y:auto;padding-right:4px}
.conn-row{display:grid;grid-template-columns:80px 1fr auto minmax(0,150px);align-items:center;gap:12px;
  background:#0c0c0c;border:1px solid var(--line);border-radius:8px;padding:9px 12px;cursor:pointer;
  font-size:13px;transition:border-color .12s,background .12s}
.conn-row:hover{border-color:var(--line3);background:var(--panel2)}
.conn-time{font-family:var(--mono);color:var(--muted);font-size:12px}
.conn-main{min-width:0;display:flex;flex-direction:column;gap:1px}
.conn-host{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.conn-ip{font-family:var(--mono);font-size:11px;color:var(--muted2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.conn-port{font-family:var(--mono);color:var(--muted);font-size:12px}
.conn-proc{font-family:var(--mono);font-size:12px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.conn-row.conn-altv{border-color:rgba(0,112,243,.55);background:rgba(0,112,243,.10)}
.conn-row.conn-altv:hover{background:rgba(0,112,243,.16)}
.conn-row.conn-altv .conn-host{color:var(--accent2)}

/* ===== EXPANDABLE DIALOG ===== */
.modal-back{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.66);backdrop-filter:blur(3px);
  display:grid;place-items:center;padding:24px;animation:mfade .15s ease}
@keyframes mfade{from{opacity:0}to{opacity:1}}
.modal{position:relative;width:580px;max-width:100%;max-height:84vh;overflow-y:auto;
  background:#0c0c0c;border:1px solid var(--line2);border-radius:14px;padding:24px 26px;box-shadow:var(--shadow);
  animation:popIn .16s ease}
.modal-x{position:absolute;top:14px;right:16px;width:30px;height:30px;border:0;background:transparent;
  color:var(--muted);font-size:22px;line-height:1;cursor:pointer;border-radius:7px}
.modal-x:hover{background:#1a1a1a;color:var(--txt)}
.dlg-head{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-right:30px}
.dlg-ic{font-size:20px}
.dlg-cat{font-family:var(--mono);font-size:12px;color:var(--muted)}
.sevtag{font-size:10.5px;font-weight:700;letter-spacing:.04em;padding:3px 8px;border-radius:6px;
  text-transform:uppercase;font-family:var(--mono)}
.sevtag.s-Critical,.sevtag.s-High{background:rgba(255,92,92,.14);color:var(--crit)}
.sevtag.s-Medium{background:rgba(245,166,35,.14);color:var(--review)}
.sevtag.s-Low{background:rgba(0,112,243,.16);color:var(--accent2)}
.sevtag.s-Info{background:rgba(143,143,143,.14);color:var(--muted)}
.sevtag.altv{background:rgba(0,112,243,.16);color:var(--accent2)}
.dlg-title{font-size:18px;font-weight:600;letter-spacing:-.01em;margin:0 0 14px;overflow-wrap:anywhere}
.dlg-detail{font-size:13.5px;line-height:1.6;color:var(--txt);white-space:pre-wrap;overflow-wrap:anywhere;
  background:#000;border:1px solid var(--line);border-radius:9px;padding:14px;margin-bottom:14px}
.dlg-kv{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.kv{display:flex;justify-content:space-between;gap:16px;font-size:13px;border-bottom:1px solid var(--line);padding-bottom:8px}
.kv:last-child{border-bottom:0}
.kv-k{color:var(--muted)}
.kv-v{font-weight:500;text-align:right;overflow-wrap:anywhere}
.kv-v.mono{font-family:var(--mono);font-size:12.5px}
.dlg-explain{background:rgba(0,112,243,.05);border:1px solid rgba(0,112,243,.2);border-radius:9px;padding:13px 15px}
.dlg-ev{margin-bottom:14px}
.dlg-ev .ep-title{margin-bottom:8px}
.vt-link{color:var(--accent2);text-decoration:none;border-bottom:1px solid rgba(50,145,255,.35);word-break:break-all}
.vt-link:hover{border-bottom-color:var(--accent2)}

/* ===== 2FA / SECURITY ===== */
/* Security + Support share the top row; Sign out spans full width below, so
   three actions never cram into one line. */
.side-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.side-actions .btn{flex:none;min-width:0}
.side-actions #logoutBtn{grid-column:1 / -1}
/* Support button -> popover with Email / Telegram options */
.support-wrap{position:relative;min-width:0}
.support-wrap>.btn{width:100%}
/* position:fixed so the popover escapes the sidebar's overflow-x:hidden (which
   otherwise clips it); exact left/bottom are set in JS from the button rect. */
.support-menu{position:fixed;min-width:190px;z-index:200;
  background:#141414;border:1px solid var(--line);border-radius:8px;padding:6px;
  display:flex;flex-direction:column;gap:2px;box-shadow:0 12px 34px rgba(0,0,0,.55)}
.support-menu.hidden{display:none}
.support-opt{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;
  color:var(--txt);text-decoration:none;font-size:13px;white-space:nowrap}
.support-opt:hover{background:#1e1e1e}
.support-opt svg{flex:none;color:var(--muted)}
.support-opt:hover svg{color:var(--txt)}
html[data-theme="light"] .support-menu{background:#fff;border-color:var(--line)}
html[data-theme="light"] .support-opt:hover{background:#eef0f3}
.dlg-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:6px}
.twofa-qr{background:#fff;padding:12px;border-radius:10px;width:max-content;max-width:100%;margin:6px auto 16px}
.twofa-qr svg{display:block;width:184px;height:184px}
.twofa-key{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-size:13px;color:var(--muted)}
.twofa-key code{font-family:var(--mono);font-size:13px;background:#111;border:1px solid var(--line);border-radius:6px;padding:5px 9px;color:var(--txt);word-break:break-all;user-select:all}
.tf-on{color:var(--clean);font-weight:500}
#twofaCode,#login2fa{letter-spacing:.3em;font-family:var(--mono);text-align:center}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .identity-grid{grid-template-columns:1fr}
  .conn-row{grid-template-columns:70px 1fr auto}
  .conn-proc{display:none}
  .app,.app[data-side="closed"]{grid-template-columns:1fr}
  .app[data-side="closed"] .sidebar{transform:none}
  .side-toggle{display:none}
  .side-nav{overflow:visible}
  .sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center}
  .side-search{width:auto;flex:1;min-width:180px;margin:0}
  .side-sec-label{display:none}
  .side-nav{flex-direction:row;flex-wrap:wrap}
  .side-foot{margin:0;border:0;padding:0;flex-direction:row;align-items:center;margin-left:auto}
  .content{padding:24px 20px}
  .stat-row{grid-template-columns:repeat(2,1fr)}
  .layout{grid-template-columns:1fr}
  .machine-grid{grid-template-columns:repeat(2,1fr)}
}

/* =====================================================================
   THEME TOGGLE + LIGHT THEME
   Dark is the default (bare :root). Adding data-theme="light" on <html>
   flips the design tokens and patches the handful of hardcoded surfaces.
   ===================================================================== */
.theme-toggle{
  position:fixed;top:52px;right:16px;z-index:100;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line2);background:var(--panel);color:var(--txt);
  border-radius:999px;cursor:pointer;font-size:15px;line-height:1;padding:0;
  transition:background .15s,border-color .15s,transform .15s}
.theme-toggle:hover{border-color:var(--line3);transform:translateY(-1px)}
.theme-toggle::before{content:"\2600\FE0F"}          /* ☀ shown in dark mode: click for light */
html[data-theme="light"] .theme-toggle::before{content:"\1F319"}  /* 🌙 shown in light mode: click for dark */

/* Majestic skin toggle — shares the theme-toggle slot; only one is visible at a time.
   Lives outside the majestic scope so it still renders when the skin is toggled off. */
.skin-toggle{
  position:fixed;top:52px;right:16px;z-index:100;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line2);background:var(--panel);
  border-radius:999px;cursor:pointer;padding:0;
  transition:background .15s,border-color .15s,transform .15s}
.skin-toggle:hover{border-color:var(--line3);transform:translateY(-1px)}
.skin-toggle::before{content:"";width:14px;height:14px;border-radius:50%;background:#5a5a5a;
  transition:background .15s,box-shadow .15s}
.skin-toggle[aria-pressed="true"]::before{background:#e81c5a;box-shadow:0 0 0 3px rgba(232,28,90,.28)}

html[data-theme="light"]{
  --bg:#f6f7f9; --bg2:#ffffff; --panel:#ffffff; --panel2:#f3f4f6; --elevated:#eceef1;
  --line:#e4e6ea; --line2:#d6d9df; --line3:#b7bcc6;
  --txt:#171a20; --muted:#5b626d; --muted2:#8a909b;
  --accent:#0068e0; --accent2:#0a5ad0;
  --clean:#0a9d54; --review:#b26a00; --susp:#d2600f; --crit:#d92d2d;
  --shadow:0 8px 30px rgba(15,23,42,.12);
}
/* soften the security-grid backdrop for light */
html[data-theme="light"] body{
  background-image:
    radial-gradient(900px 500px at 100% -10%, rgba(0,112,243,.05), transparent 60%),
    linear-gradient(rgba(15,23,42,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15,23,42,.045) 1px, transparent 1px);
}
html[data-theme="light"] ::selection{background:rgba(0,112,243,.25);color:#0b1220}
/* inverted controls: keep them high-contrast (dark on light) */
html[data-theme="light"] .btn.primary{background:#171a20;border-color:#171a20;color:#fff}
html[data-theme="light"] .btn.primary:hover{background:#000;border-color:#000}
html[data-theme="light"] .chip.active{background:#171a20;color:#fff;border-color:#171a20}
html[data-theme="light"] .lang-btn.active{background:#171a20;color:#fff}
/* hovers that used near-black */
html[data-theme="light"] .btn:hover{background:#eef0f3}
html[data-theme="light"] .btn.ghost:hover{background:#eef0f3;color:var(--txt)}
html[data-theme="light"] .nav-item:hover,
html[data-theme="light"] .tab:hover{background:#eef0f3;color:var(--txt)}
/* active nav/tab: accent-tinted instead of near-black + white text */
html[data-theme="light"] .nav-item.active,
html[data-theme="light"] .tab.active{background:#e7eefb;color:#0b1220}
/* input / field surfaces that were near-black */
html[data-theme="light"] .fld input,
html[data-theme="light"] .newuser input,
html[data-theme="light"] .newuser select,
html[data-theme="light"] .search-input,
html[data-theme="light"] .gen-note,
html[data-theme="light"] .gen-link{background:#ffffff}
/* cards / panes / popovers / modals that were near-black */
html[data-theme="light"] .dcard,
html[data-theme="light"] .ai-pane,
html[data-theme="light"] .explain-pop,
html[data-theme="light"] .qbtn,
html[data-theme="light"] .modal{background:#ffffff}
html[data-theme="light"] .login-card{background:linear-gradient(180deg,#ffffff,#f5f6f8)}
/* small chips that used pure black */
html[data-theme="light"] .inst,
html[data-theme="light"] .tab .count,
html[data-theme="light"] .twofa-box,
html[data-theme="light"] .twofa-key code{background:#f3f4f6;color:var(--txt)}

/* =====================================================================
   PER-PROJECT SKIN — MAJESTIC (data-project="majestic" on <html>)
   Applied by app.js only when the signed-in operator belongs to the
   "majestic" project. Every other project (and the global/owner scope)
   keeps the default pure-black console above. Tokens mirror the real
   Majestic admin design system: soft-black #0e0e0e surfaces, the exact
   #141414/#181818/#1e1e1e elevation ramp, .625rem radius scale, and the
   pink #e81c5a brand accent (white ink reads at ~4.6:1 on it). Purely
   additive + comes last, so it also pins this identity over light mode.
   ===================================================================== */
html[data-project="majestic"]{
  --bg:#0e0e0e; --bg2:#111111; --panel:#141414; --panel2:#181818; --elevated:#1e1e1e;
  --line:#212121; --line2:#2e2e2e; --line3:#3a3a3a;
  --txt:#ffffff; --muted:#8a8a8a; --muted2:#5f5f5f;
  --accent:#e81c5a; --accent2:#ff4d7d; --accent-ink:#ffffff;
  --r:10px; --r-sm:8px;
  --sans:'Majestic Font','Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
/* soft-black surface + downward-fading Majestic "M" watermark + pink corner glow */
html[data-project="majestic"] body{
  background-color:var(--bg);
  background-image:
    radial-gradient(120% 70% at 100% -8%, rgba(232,28,90,.12), transparent 55%),
    linear-gradient(180deg, transparent 0%, rgba(14,14,14,.55) 52%, #0e0e0e 100%),
    url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='49'%20height='64'%20viewBox='0%200%2049%2064'%20fill='none'%3E%3Cpath%20d='M18.4226%2016H14.2367L16.5973%205.42129L10.1239%2016H8.27434L6.54646%205.42129L4.18584%2016H0L3.57743%200H9.24779L10.6593%208.85157L16.0376%200H22L18.4226%2016Z'%20fill='%232b2b2b'%20fill-opacity='.6'/%3E%3Cpath%20d='M45.4226%2048H41.2367L43.5973%2037.4213L37.1239%2048H35.2743L33.5465%2037.4213L31.1858%2048H27L30.5774%2032H36.2478L37.6593%2040.8516L43.0376%2032H49L45.4226%2048Z'%20fill='%232b2b2b'%20fill-opacity='.6'/%3E%3C/svg%3E");
  background-repeat:no-repeat,no-repeat,repeat;
  background-size:auto,auto,49px 64px;
  background-attachment:fixed;
}
html[data-project="majestic"] ::selection{background:rgba(232,28,90,.32);color:#fff}
/* the Majestic skin is a fixed dark identity — hide the light/dark toggle */
html[data-project="majestic"] .theme-toggle{display:none}

/* primary action + active pills use pink with white ink (matches real Majestic) */
html[data-project="majestic"] .btn.primary{background:var(--accent);border-color:var(--accent);color:var(--accent-ink);font-weight:650}
html[data-project="majestic"] .btn.primary:hover{background:var(--accent2);border-color:var(--accent2)}
html[data-project="majestic"] #catFilter .chip.active:not([class*="c-"]){background:var(--accent);border-color:var(--accent);color:var(--accent-ink)}
html[data-project="majestic"] .lang-btn.active{background:var(--accent);color:var(--accent-ink)}
/* active nav item lights its icon pink */
html[data-project="majestic"] .nav-item.active .ni-ic{color:var(--accent)}

/* pink focus rings (border already follows --accent) */
html[data-project="majestic"] .fld input:focus,
html[data-project="majestic"] .gen-note:focus,
html[data-project="majestic"] .newuser input:focus,
html[data-project="majestic"] .newuser select:focus,
html[data-project="majestic"] .search-input:focus{box-shadow:0 0 0 3px rgba(232,28,90,.2)}

/* accent-tinted surfaces that were hardcoded blue → pink */
html[data-project="majestic"] .tag.test{background:rgba(232,28,90,.16);color:var(--accent2)}
html[data-project="majestic"] .role-tag.admin{background:rgba(232,28,90,.14);color:var(--accent2);border-color:rgba(232,28,90,.32)}
html[data-project="majestic"] .proj-chip{background:rgba(232,28,90,.1);color:var(--accent2);border-color:rgba(232,28,90,.3)}
html[data-project="majestic"] .qbtn:hover{background:rgba(232,28,90,.14)}
html[data-project="majestic"] .dcard.sev-Low{border-color:rgba(232,28,90,.3);background:rgba(232,28,90,.05)}
html[data-project="majestic"] .sevtag.s-Low,
html[data-project="majestic"] .sevtag.altv{background:rgba(232,28,90,.16);color:var(--accent2)}
html[data-project="majestic"] .conn-row.conn-altv{border-color:rgba(232,28,90,.5);background:rgba(232,28,90,.1)}
html[data-project="majestic"] .conn-row.conn-altv:hover{background:rgba(232,28,90,.16)}
html[data-project="majestic"] .dlg-explain{background:rgba(232,28,90,.06);border-color:rgba(232,28,90,.22)}
html[data-project="majestic"] .vt-link{border-bottom-color:rgba(255,77,125,.4)}
