:root{
  --bg:#0b0f14; --bg2:#0f151c; --panel:#121a22; --panel2:#16202a;
  --brd:#1f2c38; --brd2:#283845;
  --tx:#e7eef5; --tx2:#9fb0bf; --tx3:#5f7384;
  --accent:#2dd4bf; --accent-d:#0f766e;
  --green:#34d399; --amber:#f5b651; --red:#f87171; --blue:#60a5fa; --cyan:#56cfe1;
  --shadow:0 18px 40px -18px rgba(0,0,0,.7);
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:
    radial-gradient(1100px 540px at 88% -8%, rgba(45,212,191,.07), transparent 60%),
    radial-gradient(900px 520px at -6% 108%, rgba(96,165,250,.06), transparent 60%),
    var(--bg);
  color:var(--tx); font-family:'Manrope',system-ui,sans-serif;
  font-size:14px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.brandname{font-family:'Sora',sans-serif;letter-spacing:-.01em}
.mono{font-family:var(--mono)}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
::selection{background:rgba(45,212,191,.28)}

/* ---------- login wall ---------- */
#login-wall{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(1000px 600px at 50% -10%, rgba(45,212,191,.10), transparent 55%), var(--bg);}
.plog{width:380px;max-width:92vw;background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--brd);border-radius:18px;padding:34px 30px;box-shadow:var(--shadow)}
.plog .mark{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#04201c;font-weight:700;
  font-family:'Sora';font-size:1.25rem;box-shadow:0 8px 22px -8px rgba(45,212,191,.6)}
.plog h1{font-size:1.18rem;margin:16px 0 2px}
.plog .sub{color:var(--tx3);font-size:.76rem;letter-spacing:.14em;text-transform:uppercase}
.field{margin-top:16px}
.field label{display:block;font-size:.72rem;color:var(--tx2);margin-bottom:6px;letter-spacing:.04em}
.inp{width:100%;background:var(--bg);border:1px solid var(--brd2);border-radius:10px;
  padding:11px 13px;color:var(--tx);font-size:.92rem;outline:none;transition:border .15s,box-shadow .15s}
.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,212,191,.15)}
.btn{border:1px solid var(--brd2);background:var(--panel2);color:var(--tx);
  padding:9px 14px;border-radius:9px;font-size:.84rem;font-weight:600;transition:.12s;display:inline-flex;
  align-items:center;gap:7px}
.btn:hover{border-color:var(--accent);color:#fff}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-d));border:none;color:#04201c}
.btn-primary:hover{filter:brightness(1.08);color:#04201c}
.btn-green{background:rgba(52,211,153,.12);border-color:rgba(52,211,153,.3);color:var(--green)}
.btn-amber{background:rgba(245,182,81,.12);border-color:rgba(245,182,81,.3);color:var(--amber)}
.btn-red{background:rgba(248,113,113,.1);border-color:rgba(248,113,113,.3);color:var(--red)}
.btn-xs{padding:5px 9px;font-size:.72rem;border-radius:7px}
.btn-block{width:100%;justify-content:center;margin-top:20px;padding:11px}
.err{display:none;margin-top:14px;background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.3);
  color:var(--red);padding:9px 12px;border-radius:9px;font-size:.8rem}
@keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-7px)}40%,80%{transform:translateX(7px)}}

/* ---------- shell ---------- */
#app{display:none;min-height:100%}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;
  padding:0 22px;height:58px;background:rgba(11,15,20,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--brd)}
.topbar .mark{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--accent),var(--accent-d));color:#04201c;font-weight:700;font-family:'Sora'}
.brandname{font-size:1rem;font-weight:700}
.brandname small{color:var(--tx3);font-weight:500;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;margin-left:8px}
.topbar .spacer{flex:1}
.who{display:flex;align-items:center;gap:9px;font-size:.8rem;color:var(--tx2)}
.who .av{width:28px;height:28px;border-radius:50%;background:var(--panel2);border:1px solid var(--brd2);
  display:grid;place-items:center;font-size:.72rem;font-weight:700;color:var(--accent)}
.tabs{display:flex;gap:4px;padding:0 18px;border-bottom:1px solid var(--brd);background:var(--bg2)}
.tab{padding:13px 16px;font-size:.84rem;font-weight:600;color:var(--tx3);border:none;background:none;
  border-bottom:2px solid transparent;transition:.12s}
.tab:hover{color:var(--tx2)}
.tab.active{color:var(--tx);border-bottom-color:var(--accent)}
.wrap{max-width:1240px;margin:0 auto;padding:24px 22px 60px}
section.view{display:none;animation:fade .25s ease}
section.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.view-h{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}
.view-h h2{font-size:1.14rem;margin:0}
.view-h p{margin:3px 0 0;color:var(--tx3);font-size:.8rem}

/* ---------- kpis ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.kpi{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--brd);
  border-radius:14px;padding:16px 18px;position:relative;overflow:hidden}
.kpi::after{content:"";position:absolute;right:-20px;top:-20px;width:70px;height:70px;border-radius:50%;
  background:var(--c,rgba(45,212,191,.12));filter:blur(8px)}
.kpi .lab{font-size:.7rem;color:var(--tx3);letter-spacing:.1em;text-transform:uppercase}
.kpi .val{font-family:'Sora';font-size:2rem;font-weight:700;margin-top:6px;line-height:1}
.kpi.c-total .val{color:var(--tx)} .kpi.c-active .val{color:var(--green)}
.kpi.c-expiring .val{color:var(--amber)} .kpi.c-expired .val{color:var(--red)}

/* ---------- panel + table ---------- */
.panel{background:var(--panel);border:1px solid var(--brd);border-radius:14px;overflow:hidden;margin-bottom:20px}
.panel-h{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--brd);flex-wrap:wrap}
.panel-h h3{font-size:.92rem;margin:0}
.panel-h .spacer{flex:1}
.count{font-size:.74rem;color:var(--tx3)}
.tbl-scroll{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.8rem}
thead th{text-align:left;padding:10px 14px;font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;
  color:var(--tx3);font-weight:600;border-bottom:1px solid var(--brd);white-space:nowrap;background:var(--bg2)}
tbody td{padding:11px 14px;border-bottom:1px solid var(--brd);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--panel2)}
.empty{text-align:center;color:var(--tx3);padding:30px}
.k{font-family:var(--mono);font-size:.74rem;letter-spacing:.5px;color:var(--cyan)}
.sub2{color:var(--tx3);font-size:.72rem}

/* badges */
.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.68rem;font-weight:700;
  border:1px solid transparent;white-space:nowrap}
.b-green{background:rgba(52,211,153,.13);color:var(--green);border-color:rgba(52,211,153,.3)}
.b-amber{background:rgba(245,182,81,.13);color:var(--amber);border-color:rgba(245,182,81,.3)}
.b-red{background:rgba(248,113,113,.12);color:var(--red);border-color:rgba(248,113,113,.3)}
.b-blue{background:rgba(96,165,250,.13);color:var(--blue);border-color:rgba(96,165,250,.3)}
.b-gray{background:var(--panel2);color:var(--tx2);border-color:var(--brd2)}
.b-cyan{background:rgba(86,207,225,.13);color:var(--cyan);border-color:rgba(86,207,225,.3)}
.state{font-family:var(--mono);font-size:.68rem;background:var(--panel2);border:1px solid var(--brd2);
  border-radius:6px;padding:1px 6px;color:var(--tx2)}

/* filters / forms */
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.toolbar .inp{padding:8px 11px;font-size:.82rem;width:auto}
.search{min-width:220px;flex:1}
.formgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:18px}
.formgrid .field{margin:0}
.formgrid .span2{grid-column:span 2}
.row-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.help{color:var(--tx3);font-size:.74rem}

/* sites editor */
#sites-tbody td{padding:7px 10px}
#sites-tbody .inp{padding:6px 8px;font-size:.78rem;width:100%;min-width:80px}
.sumbar{display:flex;gap:22px;padding:12px 18px;border-top:1px solid var(--brd);background:var(--bg2);flex-wrap:wrap}
.sumbar b{font-family:'Sora';color:var(--tx)}
.results{padding:16px 18px;border-top:1px solid var(--brd)}
.reskey{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--brd2);
  border-radius:9px;margin-bottom:8px;background:var(--bg2)}
.reskey .k{flex:1;font-size:.86rem}

/* modal */
.modal{position:fixed;inset:0;z-index:50;display:none;align-items:center;justify-content:center;
  background:rgba(4,8,12,.7);backdrop-filter:blur(3px)}
.modal.show{display:flex}
.modal-box{width:460px;max-width:94vw;background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--brd2);border-radius:16px;box-shadow:var(--shadow);overflow:hidden}
.modal-h{padding:16px 20px;border-bottom:1px solid var(--brd);font-family:'Sora';font-weight:600}
.modal-b{padding:20px}
.modal-f{padding:14px 20px;border-top:1px solid var(--brd);display:flex;gap:10px;justify-content:flex-end}
.info-card{background:var(--bg);border:1px solid var(--brd);border-radius:10px;padding:12px 14px;
  font-size:.82rem;margin-bottom:16px;line-height:1.7}

/* toast */
#toast{position:fixed;right:22px;bottom:22px;z-index:80;display:flex;flex-direction:column;gap:8px}
.tst{background:var(--panel2);border:1px solid var(--brd2);border-left-width:3px;border-radius:9px;
  padding:11px 15px;font-size:.82rem;box-shadow:var(--shadow);min-width:240px;animation:slide .25s ease}
.tst.ok{border-left-color:var(--green)} .tst.err{border-left-color:var(--red)}
.tst.warn{border-left-color:var(--amber)}
@keyframes slide{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

@media(max-width:860px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .formgrid{grid-template-columns:repeat(2,1fr)}
  .formgrid .span2{grid-column:span 2}
}
