:root{
  --bg:#f4f6fb;
  --panel:#ffffff;
  --border:rgba(0,0,0,.08);
  --text:#111827;
  --muted:#6b7280;
  --accent:#2563eb;
  --bad:#ef4444;
  --ok:#16a34a;
  --shadow:0 10px 35px rgba(0,0,0,.10);
  --radius:14px;
  --max:1100px;
  --font: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
body{margin:0;font-family:var(--font);color:var(--text)}
.bg{background:var(--bg)}
.wrap{max-width:var(--max);margin:26px auto;padding:0 16px}

.topbar{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:10}
.topbar-inner{max-width:var(--max);margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between}
.brand{font-weight:700}
.right{display:flex;gap:12px;align-items:center}
.link{color:var(--accent);text-decoration:none}
.link:hover{text-decoration:underline}
.muted{color:var(--muted);font-size:14px}

.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
h2{margin:0 0 12px 0;font-size:18px}

.scanrow{display:flex;gap:10px;align-items:center}
.scan{flex:1;padding:12px 12px;border:2px solid #f0a36a;border-radius:10px;font-size:16px;outline:none}
.scan:focus{box-shadow:0 0 0 4px rgba(37,99,235,.12);border-color:rgba(37,99,235,.45)}
.iconbtn{
  width:44px;
  height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  border-radius:10px;
  background:#fff;
  cursor:pointer;
  user-select:none;
  font-size:18px;
  line-height:1;
}
.iconbtn:hover{filter:brightness(.98)}
.iconbtn:active{transform:translateY(1px)}
.btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:12px 14px;font-weight:700;cursor:pointer}
.btn-login{margin-top: 20px; display:block; width: 100%;}
.btn:hover{filter:brightness(.95)}
.btn:active{transform:translateY(1px)}

.msg{margin-top:12px;min-height:20px;font-size:14px}
.msg.bad{color:var(--bad)}
.msg.ok{color:var(--ok)}

.result{margin-top:14px;border-top:1px solid var(--border);padding-top:14px}
.row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.col{padding:10px;border:1px solid var(--border);border-radius:12px;background:#fafafa}
.k{font-size:12px;color:var(--muted);margin-bottom:4px}
.v{font-weight:700; font-size: 1.1em;}
.mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}

/* ===========================
   TABLE (FIX: 5 columns)
   =========================== */
.table{
  margin-top:12px;
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;

  /* ✅ було 4 колонки, стало 5: № + 4 поля */
  --cols: 64px 1.6fr .5fr .6fr .6fr;
}

.thead{
  display:grid;
  grid-template-columns:var(--cols);
  background:#f3f4f6;
  font-weight:800;
}

.thead > div{
  padding:10px;
  border-right:1px solid var(--border);
}
.thead > div:last-child{border-right:none}

.tbody .tr{
  display:grid;
  grid-template-columns:var(--cols);
}
.tbody .tr > div{
  padding:10px;
  border-top:1px solid var(--border);
  border-right:1px solid var(--border);
}
.tbody .tr > div:last-child{border-right:none}

/* ✅ колонка № */
.num{
  text-align:center;
  color:var(--muted);
  font-weight:800;
}

/* назва (2-а колонка) жирна як було */
.tbody .tr > div:nth-child(2){
  font-weight:800;
}

/* щоб довгі назви не ламали сітку */
.tbody .tr > div:nth-child(2){
  min-width:0;
  word-break:break-word;
}

.tbody .tr:nth-child(even){background:#fafafa}

.actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}

details.inline{display:block;margin:0}
details.inline > summary{list-style:none}
details.inline > summary::-webkit-details-marker{display:none}
details.inline[open]{margin-top:6px}
form.mini{margin-top:8px;display:grid;gap:8px;max-width:360px;padding:10px;border:1px dashed var(--border);border-radius:12px;background:#fff}

/* Logs: make table readable on dark background */
.logbox .table{border-color:rgba(255,255,255,.10)}
.logbox .thead{background:rgba(255,255,255,.06)}
.logbox .thead > div{border-right:1px solid rgba(255,255,255,.08)}
.logbox .tbody .tr > div{border-top:1px solid rgba(255,255,255,.08);border-right:1px solid rgba(255,255,255,.06)}
.logbox .tbody .tr:nth-child(even){background:rgba(255,255,255,.03)}

/* Auth */
.authbg{
  background:
    radial-gradient(1000px 600px at 20% 10%, rgba(37,99,235,.14), transparent 55%),
    radial-gradient(900px 500px at 80% 30%, rgba(240,163,106,.18), transparent 55%),
    var(--bg);
}
.authwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.card.auth{max-width:440px;width:100%;padding:18px;border-radius:18px;background:rgba(255,255,255,.92);backdrop-filter: blur(8px);border:1px solid var(--border);box-shadow:0 20px 60px rgba(0,0,0,.12)}
.authhead{display:flex;gap:12px;align-items:center;margin-bottom:12px}
.logo{width:42px;height:42px;border-radius:14px;background:linear-gradient(135deg, rgba(37,99,235,1), rgba(37,99,235,.25));box-shadow:0 10px 25px rgba(37,99,235,.25)}
.apptitle{font-weight:900;font-size:18px;line-height:1.1}
.subtitle{color:var(--muted);font-size:13px;margin-top:2px}
.authform{margin-top:6px}
label{display:block;margin:10px 0 6px;font-size:13px;color:var(--muted)}
input,select{width:100%;padding:12px 12px;border:1px solid var(--border);border-radius:12px;font-size:14px;background:#fff;outline:none}
input:focus,select:focus{box-shadow:0 0 0 4px rgba(37,99,235,.12);border-color:rgba(37,99,235,.45)}
.hint{margin-top:10px;color:var(--muted);font-size:12px}
.hint .mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace}

.alert{background:#fee2e2;border:1px solid #fecaca;color:#991b1b;padding:10px;border-radius:12px;margin:10px 0}
.ok{background:#dcfce7;border:1px solid #bbf7d0;color:#166534;padding:10px;border-radius:12px;margin:10px 0}
.warn{
    margin-bottom: 12px;
    padding: 10px 12px;
    border: 1px solid rgb(255 197 197 / 55%);
    background: rgb(240 23 23 / 8%);
    color: #ce3939;
    border-radius: 12px;
    font-size: 14px;
}
.tfooter{
  display:flex;
  justify-content:flex-end;
  padding: 10px;
  border-top:1px solid var(--border);
}
.tfooter-inner{
  display:flex;
  gap: 10px;
  align-items: baseline;
  font-size: 16px;
}
.adminnav{display:flex;gap:10px;flex-wrap:wrap}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.linkbtn{background:transparent;border:none;color:var(--accent);cursor:pointer;padding:0;font:inherit}
.linkbtn.danger{color:var(--bad)}
details.inline{display:inline-block;margin:0 10px}
form.mini{margin-top:8px;display:grid;gap:8px;max-width:320px}

.logbox{margin-top:10px;background:#0b1220;color:#e5e7eb;border-radius:12px;padding:10px;max-height:60vh;overflow:auto;border:1px solid rgba(255,255,255,.08)}
.logline{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;font-size:12px;padding:6px 2px;border-bottom:1px dashed rgba(255,255,255,.08)}

@media (max-width: 980px){
  .row{grid-template-columns:1fr 1fr}
}

/* ✅ на вузьких екранах стискаємо колонки таблиці, але залишаємо 5 */
@media (max-width: 720px){
  .table{
    --cols: 44px 1.4fr .5fr .6fr .6fr;
  }
}

@media (max-width: 560px){
  .scanrow{flex-direction:column;align-items:stretch}
  .row{grid-template-columns:1fr}
  .grid2{grid-template-columns:1fr}
}

