/* Sonn admin — internal tool. Matches the main app's dark editorial palette. */
:root{
  --bg:#0a0a0b; --panel:#151518; --panel-2:#1b1b1f;
  --ink:#f3f0e9; --soft:#cbc8c0; --muted:#85868e; --faint:#4f5057;
  --line:rgba(255,255,255,.09); --line-2:rgba(255,255,255,.05);
  --green:#74e0a0; --red:#e58478;
  --sans:"Archivo",system-ui,sans-serif;
  --body:"IBM Plex Sans",system-ui,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased}
body{background:var(--bg);color:var(--ink);font-family:var(--body);font-size:15px;line-height:1.5;min-height:100vh}
a{color:inherit;text-decoration:none}

/* --- brand mark (same as the app) --- */
.brand{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:800;font-size:18px;letter-spacing:-.03em}
.brand .mark{width:19px;height:19px;border-radius:6px;background:var(--ink);position:relative;flex-shrink:0}
.brand .mark::after{content:"";position:absolute;inset:6px 6px auto auto;width:5px;height:5px;border-radius:50%;background:var(--bg)}
.brand .tag{font-family:var(--body);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.14em;
  color:var(--green);border:1px solid rgba(116,224,160,.4);border-radius:100px;padding:2px 8px;margin-left:2px}

/* ---------------- login ---------------- */
.login{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(--line);border-radius:18px;padding:34px 30px}
.login-card .brand{margin-bottom:26px}
.login-card h1{font-family:var(--sans);font-weight:800;font-size:30px;letter-spacing:-.03em}
.login-card .lead{color:var(--muted);margin-top:6px;font-size:14px}
.login-card form{display:flex;flex-direction:column;gap:14px;margin-top:24px}
label{display:flex;flex-direction:column;gap:7px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
input,select{font-family:var(--body);font-size:15px;color:var(--ink);background:var(--bg);
  border:1px solid var(--line);border-radius:10px;padding:12px 14px;width:100%}
input::placeholder{color:var(--faint)}
input:focus,select:focus{outline:none;border-color:var(--soft)}
select{cursor:pointer;text-transform:none;letter-spacing:normal}
button{font-family:var(--body);font-weight:600;font-size:14.5px;cursor:pointer;border:1px solid transparent;border-radius:10px;
  background:var(--ink);color:var(--bg);padding:12px 18px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:box-shadow .25s,background .2s}
button:hover{box-shadow:0 12px 32px -12px rgba(243,240,233,.4)}
button.ghost{background:transparent;color:var(--ink);border-color:var(--line);padding:9px 15px;font-size:13.5px}
button.ghost:hover{border-color:var(--soft);background:rgba(255,255,255,.04);box-shadow:none}
.ar{transition:transform .3s}
button:hover .ar{transform:translateX(3px)}

.msg{border-radius:10px;padding:11px 14px;font-size:13.5px;margin-top:16px}
.msg.error{background:rgba(229,132,120,.1);border:1px solid rgba(229,132,120,.4);color:#f0b5ad}
.msg.warn{background:rgba(224,196,116,.08);border:1px solid rgba(224,196,116,.35);color:#e6d29a}

/* ---------------- admin page ---------------- */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(10,10,11,.85);backdrop-filter:blur(8px);z-index:5}
.topbar .who{display:flex;align-items:center;gap:16px}
.topbar .email{color:var(--muted);font-size:13px;font-family:var(--mono)}
.wrap{max-width:1240px;margin:0 auto;padding:36px 32px 80px}
.wrap>h1{font-family:var(--sans);font-weight:900;font-size:clamp(30px,4vw,46px);letter-spacing:-.04em;margin-bottom:26px}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:30px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 22px}
.stat .num{font-family:var(--sans);font-weight:900;font-size:38px;letter-spacing:-.04em;line-height:1}
.stat .lbl{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-top:10px}

.filters{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:18px}
.filters label{font-size:11px}
.filters select{min-width:210px}
.filters .clear{color:var(--muted);font-size:13px;border:1px solid var(--line);border-radius:8px;padding:11px 14px}
.filters .clear:hover{color:var(--ink);border-color:var(--soft)}
.filters .count{margin-left:auto;color:var(--muted);font-size:13px;font-family:var(--mono)}

.tablewrap{border:1px solid var(--line);border-radius:14px;overflow:auto;background:var(--panel)}
table{width:100%;border-collapse:collapse;font-size:14px;min-width:900px}
thead th{text-align:left;font-family:var(--body);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);padding:14px 18px;border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0;background:var(--panel-2)}
tbody td{padding:13px 18px;border-bottom:1px solid var(--line-2);color:var(--soft);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td{background:rgba(255,255,255,.02)}
td.mono{font-family:var(--mono);font-size:13px;color:var(--ink)}
td.nowrap,.nowrap{white-space:nowrap}
td.empty{text-align:center;color:var(--muted);padding:34px}
.ok{color:var(--green)}
.muted{color:var(--faint)}

.pill{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.03em;border-radius:100px;padding:3px 10px;border:1px solid var(--line);color:var(--soft)}
.pill.s-referral{color:var(--green);border-color:rgba(116,224,160,.4);background:rgba(116,224,160,.08)}
.pill.s-review-pool{color:#e6d29a;border-color:rgba(224,196,116,.35);background:rgba(224,196,116,.07)}

.foot{color:var(--faint);font-size:12px;margin-top:16px}

/* pagination */
.pager{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:20px}
.pager a{color:var(--ink);font-size:13.5px;font-weight:600;border:1px solid var(--line);border-radius:9px;padding:9px 16px;transition:border-color .2s,background .2s}
.pager a:hover{border-color:var(--soft);background:rgba(255,255,255,.04)}
.pager .pg-off{color:var(--faint);font-size:13.5px;font-weight:600;border:1px solid var(--line-2);border-radius:9px;padding:9px 16px;cursor:default}
.pager .pg-info{color:var(--muted);font-size:13px;font-family:var(--mono)}

/* ---------------- nav + role ---------------- */
.topbar .nav{display:flex;gap:6px;margin-right:auto;margin-left:28px}
.topbar .nav a{color:var(--muted);font-size:13.5px;font-weight:600;padding:7px 12px;border-radius:8px}
.topbar .nav a:hover{color:var(--ink);background:rgba(255,255,255,.04)}
.topbar .nav a.active{color:var(--ink);background:rgba(255,255,255,.06)}
.rolechip{font-family:var(--body);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--green);
  border:1px solid rgba(116,224,160,.4);border-radius:100px;padding:1px 7px;margin-left:4px}
.topbar .who-link{color:var(--muted);font-size:13px;font-weight:600;padding:9px 13px;border-radius:8px;border:1px solid var(--line)}
.topbar .who-link:hover{color:var(--ink);border-color:var(--soft)}
.wrap>.sub{color:var(--muted);font-size:14px;margin:-14px 0 26px;max-width:640px}

/* ---------------- admins page ---------------- */
.create-admin{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:24px;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:20px 22px}
.create-admin label{font-size:11px;flex:1;min-width:260px}
.msg.ok-msg{background:rgba(116,224,160,.08);border:1px solid rgba(116,224,160,.4);color:#bfe9cf}
.msg.ok-msg b{color:var(--ink)}
.msg.ok-msg p{margin-top:6px;font-size:13px;color:var(--soft)}
.msg .cred{margin-top:12px;display:inline-flex;align-items:center;gap:10px}
.msg .cred code{font-family:var(--mono);font-size:15px;color:var(--ink);background:var(--bg);
  border:1px solid var(--line);border-radius:8px;padding:9px 13px;display:inline-block;user-select:all}
.copy-btn{font-family:var(--body);font-size:12.5px;font-weight:600;cursor:pointer;border:1px solid var(--line);
  border-radius:8px;background:transparent;color:var(--soft);padding:9px 14px;transition:color .2s,border-color .2s}
.copy-btn:hover{color:var(--ink);border-color:var(--soft)}
.copy-btn.done{color:var(--green);border-color:rgba(116,224,160,.4);background:rgba(116,224,160,.08)}
.pill.s-active{color:var(--green);border-color:rgba(116,224,160,.4);background:rgba(116,224,160,.08)}
.pill.s-inactive{color:var(--muted)}
.row-actions{display:flex;gap:8px;justify-content:flex-end}
.row-actions form{display:inline}
button.sm{padding:6px 11px;font-size:12.5px}
button.ghost.danger{color:var(--red);border-color:rgba(229,132,120,.35)}
button.ghost.danger:hover{border-color:var(--red);background:rgba(229,132,120,.08)}

/* change-password card extras */
.login-card .cta{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-weight:600;color:var(--ink)}
.login-card .cta:hover .ar{transform:translateX(3px)}
.login-card .alt{margin-top:16px;font-size:13px;color:var(--muted)}
.login-card .alt a:hover{color:var(--ink)}

@media(max-width:760px){
  .stats{grid-template-columns:repeat(2,1fr)}
  .wrap,.topbar{padding-left:20px;padding-right:20px}
}
