/*
 * Admin app shell — extends the design tokens in tokens.css (colors, .btn,
 * spacing) with the layout pieces the client-facing pages don't need:
 * sidebar nav, data tables, status badges, forms, audit timeline.
 */
.admin-shell { display: flex; min-height: 100vh; padding: 0; align-items: stretch; }
.admin-sidebar {
  width: 220px; flex: none; background: var(--card); border-right: 1px solid var(--border);
  padding: 20px 14px; position: sticky; top: 0; height: 100vh; overflow-y: auto;
}
.admin-sidebar .brand { font-size: 15.5px; font-weight: 700; margin-bottom: 20px; padding: 0 8px; }
.admin-sidebar nav a {
  display: block; padding: 8px 10px; border-radius: 8px; font-size: 13.5px; font-weight: 550;
  color: var(--muted); text-decoration: none; margin-bottom: 2px;
}
.admin-sidebar nav a:hover { background: var(--ground); color: var(--ink); }
.admin-sidebar nav a.active { background: var(--accent-tint); color: var(--accent-dark); }
/* STORYBOOK.md "Nav count pill" — hidden entirely at zero (template omits the span). */
.nav-count-pill {
  margin-left: auto; background: var(--amber-tint); color: var(--amber); font-size: 10px; font-weight: 700;
  padding: 1px 7px; border-radius: 99px; line-height: 1.5;
}
.admin-sidebar .section-label {
  font-size: 11px; text-transform: uppercase; letter-spacing: .04em; color: var(--faint);
  margin: 16px 8px 6px;
}
.admin-user-menu { margin-top: 20px; padding: 10px 8px; border-top: 1px solid var(--border); font-size: 12.5px; color: var(--muted); }
.admin-user-menu form { margin-top: 6px; }
.admin-user-menu button.linklike {
  background: none; border: none; padding: 0; font: inherit; color: var(--accent); cursor: pointer; text-decoration: underline;
}
.admin-footer { margin-top: 12px; padding: 0 8px; font-size: 11.5px; color: var(--faint); }
.admin-footer a { color: var(--faint); }

.admin-main { flex: 1; padding: 28px 32px 64px; max-width: 1200px; }
.admin-main h1 { font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.admin-main .page-sub { font-size: 13px; color: var(--muted); margin-bottom: 20px; }

.admin-flash { padding: 10px 14px; border-radius: 8px; font-size: 13px; margin-bottom: 16px; }
.admin-flash.success { background: var(--accent-tint); color: var(--accent-dark); }
.admin-flash.error { background: var(--red-tint); color: var(--red); }

/*
 * Shared toast — STORYBOOK.md "Toasts": dark pill, bottom-center, ~2s
 * auto-dismiss, error variant solid red. This is the ONE toast component for
 * every admin async action (resend/void/refund/mark-wire-received/retry-
 * sync/pause/resume/…) — server sets flashToast (routes/admin/middleware.ts
 * setFlashToast, or subscriptions.ts's renderDetail), base.njk renders it
 * once, public/js/admin.js auto-dismisses it. Never invent a page-scoped
 * toast variant — .cd-toast/.doc-toast were the old ad-hoc versions this
 * replaces at the shared level (BUG-030).
 */
.toast {
  position: fixed; left: 50%; bottom: 26px; transform: translateX(-50%);
  background: var(--ink); color: #ffffff; font-size: 12.5px; font-weight: 600;
  border-radius: 99px; padding: 8px 16px; box-shadow: 0 8px 24px -8px rgba(23,37,28,.4);
  z-index: 80; white-space: nowrap; animation: toast-in .18s ease;
}
.toast.toast-error { background: var(--red); }
@keyframes toast-in { from { opacity: 0; transform: translate(-50%, 8px); } to { opacity: 1; transform: translate(-50%, 0); } }

.filters { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }

table.data-table { width: 100%; border-collapse: collapse; background: var(--card); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
table.data-table th, table.data-table td { padding: 10px 14px; text-align: left; font-size: 13px; border-bottom: 1px solid var(--border); }
table.data-table th { background: var(--ground); font-weight: 650; color: var(--muted); font-size: 11.5px; text-transform: uppercase; letter-spacing: .03em; }
table.data-table tr:last-child td { border-bottom: none; }
table.data-table tr:hover td { background: var(--ground); }
table.data-table a { color: var(--accent-dark); text-decoration: none; font-weight: 550; }
table.data-table a:hover { text-decoration: underline; }

.badge { display: inline-block; padding: 3px 9px; border-radius: 99px; font-size: 11.5px; font-weight: 650; }
.badge.gray { background: var(--border-faint); color: var(--muted); }
.badge.green { background: var(--accent-tint); color: var(--accent-dark); }
.badge.amber { background: var(--amber-tint); color: var(--amber); }
.badge.red { background: var(--red-tint); color: var(--red); }
.badge.blue { background: var(--blue-tint); color: var(--blue); }

.card { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 20px; margin-bottom: 20px; }
.card h2 { font-size: 15.5px; font-weight: 700; margin-bottom: 12px; }

.detail-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 24px; font-size: 13px; }
.detail-grid dt { color: var(--muted); }
.detail-grid dd { font-weight: 550; }

.timeline { list-style: none; padding: 0; }
.timeline li { padding: 8px 0 8px 20px; border-left: 2px solid var(--border); position: relative; font-size: 13px; }
.timeline li::before { content: ''; position: absolute; left: -5px; top: 12px; width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }
.timeline li .action { font-weight: 650; }
.timeline li .meta { color: var(--faint); font-size: 12px; }

.actions-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.actions-row form { display: inline; }

form.stack { display: flex; flex-direction: column; gap: 12px; max-width: 480px; }
form.stack label { font-size: 12.5px; font-weight: 600; color: var(--muted); display: block; margin-bottom: 4px; }
form.stack input, form.stack select, form.stack textarea {
  width: 100%; padding: 8px 10px; border: 1px solid var(--border); border-radius: 8px; font: inherit; font-size: 13.5px;
}
form.stack .field { display: flex; flex-direction: column; }
form.stack .row { display: flex; gap: 12px; }
form.stack .row > .field { flex: 1; }

.btn.danger { background: var(--red); }
.btn.danger:hover { background: var(--red-deep); }
.btn.small { padding: 6px 12px; font-size: 12.5px; }

.line-items-table { width: 100%; border-collapse: collapse; margin: 10px 0; }
.line-items-table th, .line-items-table td { padding: 6px 8px; font-size: 12.5px; text-align: left; border-bottom: 1px solid var(--border); }
.line-items-table td.num { text-align: right; }

/*
 * Login / TOTP screens (BUILD_SPECS.md §10, §10b — B-C. Admin App.dc.html
 * "10 · LOGIN" / "10b · TWO-FACTOR (TOTP)"). Centered 380px card, no sidebar
 * shell — login.njk/2fa-verify.njk/2fa-enroll.njk extend base.njk's `body`
 * block directly rather than `admin_body`.
 */
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.login-wrap { width: 380px; max-width: 100%; margin: 80px auto; padding: 0 16px; }
.login-wrap .card { padding: 26px; }
.login-wrap h1 { font-size: 17px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 3px; }
.login-wrap .subtitle { font-size: 12.5px; color: var(--faint); margin-bottom: 18px; }
.login-wrap .helper-text { text-align: center; font-size: 12px; color: var(--faint); margin-top: 14px; }
.login-wrap .totp-links { display: flex; justify-content: space-between; margin-top: 14px; font-size: 12px; }
.login-wrap .totp-links button.linklike {
  font: inherit; font-size: 12px; font-weight: 600; color: var(--faint); background: none; border: none;
  cursor: pointer; padding: 0;
}
.login-wrap .totp-links button.linklike:hover { color: var(--ink); }
.login-wrap .totp-links a.linklike {
  font-size: 12px; font-weight: 600; color: var(--accent-dark); text-decoration: none;
}
.login-wrap .totp-links a.linklike:hover { text-decoration: underline; }
.login-wrap input.code-input {
  width: 100%; font-size: 26px; font-weight: 700; letter-spacing: .45em; text-align: center;
  font-variant-numeric: tabular-nums; border: 1px solid var(--border); border-radius: 10px; padding: 12px;
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
}

/* Phase 7C — settings screens (E. Settings & Dashboard.dc.html) */

.badge.gray-outline { background: var(--card); color: var(--faint); border: 1px solid var(--border); }

.integration-card { display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
.integration-card.warning { border-color: var(--amber-border); border-width: 1.5px; }
.integration-card .icon {
  width: 38px; height: 38px; border-radius: 9px; display: grid; place-items: center;
  font-size: 14px; font-weight: 800; flex: none; background: var(--ground); color: var(--muted);
}
.integration-card .body { flex: 1; min-width: 220px; }
.integration-card .name-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.integration-card .name-row strong { font-size: 14px; font-weight: 700; }
.integration-card .headline { display: block; font-size: 12.5px; color: var(--muted); margin-top: 3px; line-height: 1.5; }
.integration-card .meta { display: block; font-size: 12px; color: var(--faint); margin-top: 6px; }

.health-feed-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; margin-bottom: 14px; }
.health-feed-card { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 14px 16px; }
.health-feed-card .top-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.health-feed-card .name { font-size: 12.5px; font-weight: 700; }
.health-feed-card .detail { font-size: 11.5px; color: var(--faint); margin-top: 5px; line-height: 1.5; }

.event-row { display: flex; align-items: center; gap: 12px; padding: 9px 16px; border-bottom: 1px solid var(--border); font-size: 12.5px; }
.event-row:last-child { border-bottom: none; }
.event-row .dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.event-row .dot.ok { background: var(--accent); }
.event-row .dot.error { background: var(--red); }
.event-row .at { font-family: ui-monospace, 'SF Mono', Menlo, monospace; font-size: 11px; color: var(--faint); width: 160px; flex: none; }
.event-row .event { font-weight: 600; flex: 1; min-width: 0; }
.event-row .source { color: var(--faint); font-size: 11.5px; white-space: nowrap; }

.filters select, .filters input { font: inherit; font-size: 12.5px; border: 1px solid var(--border); border-radius: 8px; padding: 8px 10px; background: var(--card); }

/*
 * Frozen-client banner (STORYBOOK.md "Frozen client badge/banner") — client
 * detail page, informational-but-loud like danger-zone but not destructive.
 */
.frozen-banner {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  background: var(--red-tint); border: 1.5px solid var(--red-border); border-radius: 12px;
  padding: 14px 16px; margin-bottom: 20px;
}
.frozen-banner .frozen-meta { font-size: 12px; color: var(--muted); }
.frozen-banner .actions { margin-left: auto; }

.empty-state { text-align: center; padding: 40px 16px; color: var(--faint); }
.empty-state .title { font-size: 14px; font-weight: 650; color: var(--ink); margin-bottom: 4px; }
.empty-state .sub { font-size: 12.5px; }

.pagination { display: flex; justify-content: space-between; align-items: center; padding: 10px 14px; font-size: 12.5px; color: var(--faint); }
.pagination a { color: var(--accent-dark); text-decoration: none; font-weight: 600; }

.kv-grid { display: grid; gap: 10px; font-size: 12.5px; }
.kv-grid .row { display: flex; justify-content: space-between; align-items: center; gap: 10px; border-bottom: 1px dashed var(--border); padding-bottom: 9px; }
.kv-grid .row:last-child { border-bottom: none; padding-bottom: 0; }
.kv-grid .row .sub { display: block; font-size: 11.5px; color: var(--faint); }
