/* Admin panel styles */
.admin{display:flex;min-height:100vh}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--border);
  border-radius:var(--radius);padding:34px}
.login-card .brand{font-size:22px;margin-bottom:6px}
.login-card form{margin-top:18px;display:flex;flex-direction:column;gap:6px}
.login-card label{font-size:13px;color:var(--muted);margin-top:10px}
.login-card input{background:var(--bg2);border:1px solid var(--border);color:var(--text);
  padding:11px 13px;border-radius:10px;font-size:15px}
.login-card input:focus{outline:0;border-color:var(--accent)}
.hint{margin-top:16px;font-size:12px}
code{background:var(--panel2);padding:2px 6px;border-radius:5px;font-size:12px}

.sidebar{width:230px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);
  padding:24px 18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.sidebar .brand{font-size:19px;margin-bottom:26px}
.side-nav{display:flex;flex-direction:column;gap:4px;flex:1}
.side-nav a{padding:10px 14px;border-radius:10px;color:var(--muted);font-size:15px}
.side-nav a:hover{background:var(--panel2);color:var(--text)}
.side-nav a.on{background:rgba(124,92,255,.15);color:#fff;border:1px solid rgba(124,92,255,.4)}
.side-foot{border-top:1px solid var(--border);padding-top:16px;display:flex;flex-direction:column;gap:8px;font-size:13px}
.logout{color:var(--bad)}

.admin-main{flex:1;padding:34px 40px;max-width:1080px;margin:0 auto;width:100%}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:28px}

.flash{padding:13px 18px;border-radius:11px;margin-bottom:20px;font-size:14px}
.flash.ok{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.4);color:#86efac}
.flash.err{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.4);color:#fca5a5}

.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:16px;margin-bottom:26px}
.stat{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;
  display:flex;flex-direction:column;gap:4px}
.stat-label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.stat-val{font-size:30px;font-weight:800}
.stat-val.sm{font-size:20px}

.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;margin-bottom:22px}
.panel-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.panel-head h2{margin:0;font-size:18px}

.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;
  padding:8px 10px;border-bottom:1px solid var(--border)}
.tbl td{padding:11px 10px;border-bottom:1px solid var(--border)}
.tbl tr:last-child td{border-bottom:0}
.trunc{max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sm{font-size:12px}

.tag{font-size:11px;padding:3px 9px;border-radius:999px;text-transform:capitalize}
.tag.active{background:rgba(34,197,94,.15);color:#86efac;border:1px solid rgba(34,197,94,.4)}
.tag.limited{background:rgba(245,158,11,.15);color:#fcd34d;border:1px solid rgba(245,158,11,.4)}
.tag.disabled{background:rgba(138,138,163,.15);color:var(--muted);border:1px solid var(--border)}

.mini-track{height:6px;background:var(--panel2);border-radius:999px;overflow:hidden;width:160px;max-width:100%}
.mini-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}

label{font-size:13px;color:var(--muted);display:block}
input,select{font-family:inherit}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}
.grid2 input,.grid4 input,.stack input,.key-row input,.key-row select,.stack select{
  width:100%;background:var(--bg2);border:1px solid var(--border);color:var(--text);
  padding:10px 12px;border-radius:9px;font-size:14px;margin-top:5px}
input:focus,select:focus{outline:0;border-color:var(--accent)}
.stack{display:flex;flex-direction:column;gap:12px}
.stack.narrow{max-width:380px}
.check{display:flex;align-items:center;gap:10px;color:var(--text);font-size:14px}
.check input{width:auto;margin:0}

.btn-primary.full{width:100%;margin-top:14px}
.btn-sm{background:var(--accent);color:#fff;border:0;padding:8px 16px;border-radius:9px;
  cursor:pointer;font-size:13px;font-weight:600}
.btn-sm.ghost{background:var(--panel2);border:1px solid var(--border);color:var(--text)}
.btn-sm.danger{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.4);color:#fca5a5}

.key-row{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:14px}
.key-row-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.prio{font-weight:700;color:var(--accent2)}
.f-name{flex:1;background:transparent!important;border:0!important;font-size:16px;font-weight:600;margin:0!important;padding:4px 0!important}
.key-rem{font-weight:700;font-size:15px}
.key-row-track{margin-bottom:12px}
.key-row-fields{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:12px;margin-bottom:12px}
.key-row-fields label{display:flex;flex-direction:column;gap:0}
.key-row-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

@media(max-width:820px){
  .sidebar{width:64px;padding:18px 8px}
  .sidebar .brand span:last-child,.side-foot{display:none}
  .side-nav a{text-align:center;padding:10px 4px;font-size:12px}
  .grid4,.key-row-fields{grid-template-columns:1fr 1fr}
  .admin-main{padding:24px 18px}
}
