/* SRSW Admin Bar — control-room skin.
 *
 * Mobile-first (Devin runs this from his phone). Colors, spacing, radius and
 * motion come ONLY from tokens.css variables — no hardcoded hex, no blue/green,
 * no emojis. The look is a calm premium dashboard: dark surfaces, gold accents,
 * generous tap targets (>=44px), legible type. Not a debug panel. */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

#admin {
  display: block;
  max-width: 720px;
  margin: 0 auto;
  padding: calc(var(--safe-top) + var(--space-4)) var(--space-4)
           calc(var(--safe-bottom) + var(--space-8));
}

.boot {
  padding: var(--space-9) var(--space-4);
  text-align: center;
  color: var(--fg-dim);
  font-size: var(--text-base);
}

/* ── shared controls ─────────────────────────────────────────────────────── */
.btn {
  font-size: var(--text-base);
  font-weight: 600;
  line-height: 1;
  min-height: 44px;             /* tap target */
  padding: 0 var(--space-4);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: var(--bg-3);
  color: var(--fg);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease),
              opacity var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease);
}
.btn:active { transform: translateY(1px); }
.btn:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}
.btn:disabled,
.btn.is-busy {
  opacity: 0.5;
  cursor: default;
}

.btn-gold {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--bg);
}
.btn-ghost {
  background: transparent;
  color: var(--fg-dim);
}
.btn-ghost:active { color: var(--fg); }
.btn-danger {
  background: transparent;
  border-color: var(--bad);
  color: var(--bad);
}

.is-hidden { display: none !important; }

/* ════════════════════════════════════════════════════════════════════════════
   SCREEN 1 — EMAIL LOGIN
   ════════════════════════════════════════════════════════════════════════════ */
.auth {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 80dvh;
  text-align: center;
  gap: var(--space-3);
}
.auth-brand {
  font-size: var(--text-3xl);
  font-weight: 700;
  letter-spacing: 0.22em;
  color: var(--gold);
}
.auth-sub {
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-mute);
  margin-bottom: var(--space-5);
}
.auth-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
  width: 100%;
  max-width: 300px;
  text-align: left;
  transition: opacity var(--t-slow) var(--ease);
}
.auth-form.is-dim { opacity: 0.55; }
.auth-step-code { margin-top: var(--space-2); }

.auth-label {
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.auth-input {
  font-size: var(--text-xl);     /* >=16px: no iOS focus-zoom */
  min-height: 52px;
  padding: 0 var(--space-4);
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--fg);
  width: 100%;
}
.auth-input::placeholder { color: var(--fg-mute); }
.auth-input:focus {
  outline: none;
  border-color: var(--gold);
}
.auth-input:read-only { opacity: 0.7; }
.auth-code {
  text-align: center;
  letter-spacing: 0.32em;
  font-variant-numeric: tabular-nums;
}
.auth-submit { width: 100%; margin-top: var(--space-1); }

.auth-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: var(--space-1);
}
.auth-link {
  background: none;
  border: none;
  padding: var(--space-1) 0;
  font-size: var(--text-sm);
  color: var(--fg-dim);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.auth-link:hover { color: var(--gold); }
.auth-link:disabled {
  color: var(--fg-mute);
  cursor: default;
  text-decoration: none;
}
.auth-link:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}

.auth-note {
  min-height: 1.4em;
  max-width: 300px;
  font-size: var(--text-sm);
  color: var(--fg-dim);
  text-align: center;
}

/* ════════════════════════════════════════════════════════════════════════════
   SCREEN 2 — CONTROL ROOM (board)
   ════════════════════════════════════════════════════════════════════════════ */
.board-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}
.board-brand { display: flex; flex-direction: column; gap: var(--space-1); }
.board-mark {
  font-size: var(--text-2xl);
  font-weight: 700;
  letter-spacing: 0.18em;
  color: var(--gold);
}
.board-sub {
  font-size: var(--text-2xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.board-nav {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.board-nav-btn {
  min-height: 40px;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
}

/* ── cards ───────────────────────────────────────────────────────────────── */
.card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}
.card-head {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.card-title {
  margin: 0;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-dim);
}
.card-count {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--gold);
}
.card-body { display: flex; flex-direction: column; gap: var(--space-3); }

.empty {
  font-size: var(--text-sm);
  color: var(--fg-mute);
  padding: var(--space-2) 0;
}

/* ── rows (one person / request / blacklist entry) ───────────────────────── */
.row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2-5);
  padding: var(--space-3-5);
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.row-compact { gap: var(--space-2); padding: var(--space-3); }

.row-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.row-name {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-1-5);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--fg);
}
.row-when {
  flex: none;
  font-size: var(--text-2xs);
  color: var(--fg-mute);
  white-space: nowrap;
}

.row-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1-5) var(--space-4);
}
.kv { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.kv .k {
  font-size: var(--text-2xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.kv .v {
  font-size: var(--text-md);
  color: var(--fg-dim);
  word-break: break-word;
}

.row-acts {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.row-acts .btn { flex: 1 1 auto; }

/* ── tags / status pills ─────────────────────────────────────────────────── */
.tag {
  font-size: var(--text-2xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px var(--space-1-5);
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  color: var(--fg-dim);
}
.tag-gold {
  color: var(--gold);
  border-color: var(--gold);
  background: var(--gold-faint);
}
.tag-mute { color: var(--fg-mute); }
.tag-approved { color: var(--gold); border-color: var(--gold); }
.tag-pending { color: var(--warn); border-color: var(--line); }
.tag-banned { color: var(--bad); border-color: var(--bad); }

.bl-value {
  font-size: var(--text-md);
  color: var(--fg);
  word-break: break-all;
}

/* ── add form (blacklist) ────────────────────────────────────────────────── */
.add-form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  padding-bottom: var(--space-1);
}
.add-form .add-kind,
.add-form .add-value,
.add-form .add-reason {
  font-size: var(--text-xl);     /* >=16px: no iOS focus-zoom */
  min-height: 44px;
  padding: 0 var(--space-3);
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--fg);
}
.add-form .add-kind { flex: 0 0 auto; }
.add-form .add-value { flex: 1 1 100%; }
.add-form .add-reason { flex: 1 1 100%; }
.add-form .btn { flex: 1 1 auto; }
.add-form select:focus,
.add-form input:focus {
  outline: none;
  border-color: var(--gold);
}

/* ── audit log ───────────────────────────────────────────────────────────── */
.audit { display: flex; flex-direction: column; gap: var(--space-1-5); }
.audit-line {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--space-1-5) var(--space-2);
  padding: var(--space-1-5) 0;
  border-bottom: 1px solid var(--line);
  font-size: var(--text-sm);
}
.audit-line:last-child { border-bottom: none; }
.audit-event {
  font-weight: 600;
  color: var(--fg);
  letter-spacing: 0.04em;
}
.audit-detail {
  flex: 1 1 auto;
  color: var(--fg-dim);
  word-break: break-word;
}
.audit-when {
  flex: none;
  color: var(--fg-mute);
  font-size: var(--text-2xs);
  white-space: nowrap;
}

/* ════════════════════════════════════════════════════════════════════════════
   SCREEN 3 — SETTINGS
   ════════════════════════════════════════════════════════════════════════════ */
.set-loading {
  padding: var(--space-8) var(--space-4);
  text-align: center;
  color: var(--fg-dim);
  font-size: var(--text-base);
}
.set-screen-head { margin-bottom: var(--space-4); }
.set-screen-title {
  margin: 0;
  font-size: var(--text-3xl);
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--fg);
}

.set-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}
.set-head { margin-bottom: var(--space-1); }
.set-title {
  margin: 0;
  font-size: var(--text-2xl);
  font-weight: 600;
  color: var(--fg);
}
.set-sub {
  margin: 0 0 var(--space-3);
  font-size: var(--text-sm);
  color: var(--fg-mute);
}
.set-body { display: flex; flex-direction: column; gap: var(--space-3); }

.set-hint {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--fg-mute);
  line-height: 1.5;
}
.set-note {
  min-height: 1.2em;
  font-size: var(--text-sm);
  color: var(--fg-dim);
}
.set-field-label {
  font-size: var(--text-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--fg-mute);
}
.set-input {
  font-size: var(--text-xl);     /* >=16px: no iOS focus-zoom */
  min-height: 48px;
  padding: 0 var(--space-3);
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--fg);
  width: 100%;
}
.set-input::placeholder { color: var(--fg-mute); }
.set-input:focus {
  outline: none;
  border-color: var(--gold);
}

/* ── manage admins ───────────────────────────────────────────────────────── */
.admin-list { display: flex; flex-direction: column; gap: var(--space-2); }
.admin-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3);
  background: var(--bg-3);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
}
.admin-info {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}
.admin-email {
  font-size: var(--text-base);
  color: var(--fg);
  word-break: break-all;
}
.admin-meta {
  font-size: var(--text-2xs);
  color: var(--fg-mute);
}
.admin-row .btn {
  flex: none;
  min-height: 40px;
  padding: 0 var(--space-3);
  font-size: var(--text-sm);
}
.admin-add {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-1);
  padding-top: var(--space-3);
  border-top: 1px solid var(--line);
}
.admin-add .btn { width: 100%; }

/* ── toggle row (email backup) ───────────────────────────────────────────── */
.toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.toggle-text { display: flex; flex-direction: column; gap: var(--space-1); min-width: 0; }
.toggle-label {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--fg);
}
.toggle-help {
  font-size: var(--text-sm);
  color: var(--fg-mute);
  line-height: 1.4;
}

/* Accessible switch: a role="switch" button with a sliding knob. */
.switch {
  flex: none;
  position: relative;
  width: 52px;
  height: 30px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--bg-3);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease);
}
.switch-knob {
  position: absolute;
  top: 50%;
  left: 3px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--fg-dim);
  transform: translate(0, -50%);
  transition: transform var(--t-fast) var(--ease),
              background var(--t-fast) var(--ease);
}
.switch.is-on {
  background: var(--gold-faint);
  border-color: var(--gold);
}
.switch.is-on .switch-knob {
  background: var(--gold);
  transform: translate(22px, -50%);
}
.switch:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}
.switch:disabled { opacity: 0.5; cursor: default; }

/* ── phone push ──────────────────────────────────────────────────────────── */
.push-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.push-actions .btn { width: 100%; }
.push-on {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--fg);
}
.push-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--gold);
  box-shadow: 0 0 0 4px var(--gold-faint);
}
.push-on-label { color: var(--gold); }
.push-btns {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.push-btns .btn { flex: 1 1 auto; }

/* ── slightly roomier on wider phones / tablets ──────────────────────────── */
@media (min-width: 540px) {
  .row-acts .btn { flex: 0 1 auto; min-width: 120px; }
  .add-form .add-value { flex: 1 1 auto; }
  .add-form .add-reason { flex: 1 1 auto; }
  .admin-add {
    flex-direction: row;
    align-items: center;
  }
  .admin-add .set-field-label { display: none; }
  .admin-add .set-input { flex: 1 1 auto; }
  .admin-add .btn { width: auto; flex: none; }
  .push-btns .btn { flex: 0 1 auto; min-width: 120px; }
}
