:root{
  --bg:#0f1419; --panel:#171e26; --panel2:#1d2731; --line:#2a3744;
  --text:#e6edf3; --muted:#8b9aa8; --accent:#2f81f7; --accent2:#238636;
  --warn:#d29922; --danger:#da3633; --chip:#21303d;
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}
a{color:var(--accent)}
h1,h2,h3{margin:0 0 .5rem}
button{font-family:inherit;font-size:14px;cursor:pointer;border:0;border-radius:8px;
  padding:.55rem .9rem;background:var(--accent);color:#fff;font-weight:600}
button.sec{background:var(--panel2);color:var(--text);border:1px solid var(--line)}
button.ok{background:var(--accent2)}
button.warn{background:var(--warn);color:#161b22}
button.danger{background:var(--danger)}
button:disabled{opacity:.5;cursor:not-allowed}
button.small{padding:.3rem .6rem;font-size:13px}
input,select,textarea{font-family:inherit;font-size:14px;width:100%;padding:.55rem .65rem;
  background:var(--panel2);border:1px solid var(--line);border-radius:8px;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:0;border-color:var(--accent)}
label{display:block;font-size:12px;color:var(--muted);margin:0 0 .25rem}
.field{margin-bottom:.8rem}
.row{display:flex;gap:.8rem;flex-wrap:wrap}
.row>.field{flex:1;min-width:160px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1.1rem;margin-bottom:1rem}
.muted{color:var(--muted)}
.chip{display:inline-block;padding:.15rem .55rem;border-radius:999px;background:var(--chip);
  font-size:12px;border:1px solid var(--line)}
.chip.in{color:#3fb950;border-color:#23512f}
.chip.used{color:var(--muted)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}
.login-box{width:100%;max-width:360px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:1.6rem}
.login-box h1{font-size:1.2rem}

/* App layout */
header.top{display:flex;align-items:center;gap:1rem;padding:.7rem 1.1rem;background:var(--panel);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
header.top .brand{font-weight:700}
header.top .spacer{flex:1}
nav.tabs{display:flex;gap:.3rem;flex-wrap:wrap;padding:.6rem 1.1rem;background:var(--panel);
  border-bottom:1px solid var(--line);position:sticky;top:49px;z-index:9}
nav.tabs button{background:transparent;color:var(--muted);font-weight:600;border-radius:8px}
nav.tabs button.active{background:var(--panel2);color:var(--text)}
main{max-width:1100px;margin:0 auto;padding:1.1rem}
.tab{display:none}
.tab.active{display:block}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.8rem}
.stat{background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:1rem}
.stat .n{font-size:1.7rem;font-weight:700}
.stat .l{color:var(--muted);font-size:12px}

/* Table */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:.55rem .6rem;border-bottom:1px solid var(--line);white-space:nowrap}
th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.03em}
tr:hover td{background:var(--panel2)}
td.wrap,th.wrap{white-space:normal}
tr.grp{cursor:pointer;user-select:none}
tr.grp td{background:var(--panel2);font-size:14px}
tr.grp:hover td{background:var(--line)}
.caret{display:inline-block;width:1.1em;color:var(--muted)}
tr.item td{background:transparent}

.toast{position:fixed;bottom:1rem;left:50%;transform:translateX(-50%);background:var(--panel2);
  border:1px solid var(--line);padding:.7rem 1.1rem;border-radius:10px;z-index:50;max-width:90%;display:none}
.toast.show{display:block}
.toast.err{border-color:var(--danger)}
.toast.ok{border-color:var(--accent2)}

.serials-out{max-height:200px;overflow:auto;background:var(--panel2);border:1px solid var(--line);
  border-radius:8px;padding:.6rem;font-size:13px}
.hint{font-size:12px;color:var(--muted);margin-top:.3rem}
.err{color:#ff7b72;font-size:13px;min-height:1.1em}