*{box-sizing:border-box}
:root{
  --bg1:#fbf7f8;--bg2:#f4e8ee;--card:rgba(255,255,255,.92);--text:#591536;--muted:#7f5b6c;
  --accent:#97124b;--accent2:#d64b87;--border:rgba(151,18,75,.12);--shadow:0 18px 48px rgba(89,21,54,.12);
  --ok:#0d8b61;--error:#b42318;--radius:28px
}
html,body{height:100%}
body{
  margin:0;font-family:"Segoe UI",Arial,sans-serif;color:var(--text);
  background:
    radial-gradient(circle at top left,rgba(214,75,135,.10),transparent 28%),
    radial-gradient(circle at bottom right,rgba(151,18,75,.08),transparent 30%),
    linear-gradient(180deg,var(--bg1),var(--bg2));
}
.public-body,.admin-body,.login-body{padding:24px}
.app-shell,.admin-shell{
  width:min(1180px,100%);margin:0 auto;background:var(--card);backdrop-filter:blur(16px);
  border-radius:34px;border:1px solid rgba(255,255,255,.7);box-shadow:var(--shadow);overflow:hidden
}
.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 24px;
  border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(255,255,255,.66))
}
.brand{display:flex;align-items:center;gap:16px;min-width:0}
.brand h1{margin:0;font-size:1.2rem}
.brand p{margin:5px 0 0;color:var(--muted)}
.brand-logo{width:72px;height:72px;object-fit:contain;border-radius:20px;padding:8px;background:#fff;box-shadow:0 10px 24px rgba(151,18,75,.10)}
.brand-logo.large{width:92px;height:92px}
.toolbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{
  appearance:none;border:1px solid rgba(151,18,75,.15);background:#fff;color:var(--text);
  padding:11px 16px;border-radius:16px;font:inherit;font-weight:700;cursor:pointer;text-decoration:none;
  transition:transform .15s ease,box-shadow .15s ease
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 12px 28px rgba(151,18,75,.18)}
.btn-danger{background:#fff1f1;color:var(--error);border-color:#ffd7d2}
.content-grid,.admin-grid{display:grid;gap:24px;padding:28px}
.content-grid{grid-template-columns:1.2fr .8fr}
.admin-grid{grid-template-columns:1fr}
.card{background:rgba(255,255,255,.96);border:1px solid var(--border);border-radius:var(--radius);padding:28px}
.hero-card h2{margin:0;font-size:clamp(2rem,4.7vw,3.25rem);line-height:1.02;letter-spacing:-.03em}
.lead{margin:14px 0 24px;color:var(--muted);font-size:1.08rem;line-height:1.55;max-width:54ch}
.label{display:block;margin-bottom:10px;color:var(--muted);font-weight:700;font-size:.96rem}
.scan-input{
  width:100%;border:2px solid rgba(151,18,75,.13);background:#fff;color:var(--text);border-radius:24px;
  padding:20px 22px;outline:none;font-size:clamp(1.55rem,3.7vw,2.35rem);text-align:center;letter-spacing:.04em
}
.scan-input:focus,input:focus,select:focus{
  border-color:rgba(151,18,75,.42);box-shadow:0 0 0 5px rgba(151,18,75,.08)
}
.status{min-height:24px;margin-top:14px;font-size:1rem;color:var(--muted)}
.status.success,.alert.success{color:var(--ok)}
.status.error,.alert.error{color:var(--error)}
.helper,.muted{color:var(--muted)}
.side-card{display:flex;align-items:center;justify-content:center;min-height:230px}
.hero-logo{width:min(100%,440px);max-height:260px;object-fit:contain;filter:drop-shadow(0 12px 26px rgba(151,18,75,.10))}
.login-card{
  width:min(480px,100%);margin:40px auto;background:var(--card);padding:32px;border-radius:28px;
  box-shadow:var(--shadow);text-align:center;border:1px solid var(--border)
}
.form-grid{display:grid;gap:16px}
.field{display:grid;gap:7px}
.field label{color:var(--muted);font-size:.92rem;font-weight:700}
.field input,.field select{
  width:100%;padding:13px 14px;border-radius:16px;border:1px solid rgba(151,18,75,.14);
  outline:none;font:inherit;background:#fff;color:var(--text)
}
.checkbox-field{display:flex;align-items:end}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.table-wrap{margin-top:20px;background:#fff;border:1px solid var(--border);border-radius:24px;overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:14px 12px;border-bottom:1px solid rgba(151,18,75,.08);vertical-align:top;font-size:.94rem}
th{background:#fdf8fa;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}
tr:last-child td{border-bottom:none}
.row-actions{display:flex;flex-wrap:wrap;gap:8px}
.row-actions form{margin:0}
.pill{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:.8rem;font-weight:700;background:rgba(13,139,97,.08);color:var(--ok)}
.pill.off{background:rgba(180,35,24,.08);color:var(--error)}
.alert{padding:12px 14px;border-radius:14px;background:#fff7f7;border:1px solid #ffe0dc;margin:12px 0}
.alert.success{background:#f3fff8;border-color:#cfeedd}
.mono{font-family:Consolas,Monaco,monospace;font-size:.88rem}
.token-cell{max-width:260px;word-break:break-all}
@media (max-width:940px){
  .content-grid{grid-template-columns:1fr}
  .topbar{padding:16px 18px}
  .brand-logo{width:58px;height:58px}
  .public-body,.admin-body,.login-body{padding:14px}
  .content-grid,.admin-grid{padding:18px}
}
