﻿/*
 * PSD2 Broker Client Portal UI — Design System CSS
 * Tracked AssetMapper source using the mock tokens with portal-specific overrides.
 * Portal identity: teal accent, dark navy topbar, no sidebar.
 */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&family=IBM+Plex+Serif:ital,wght@0,400;1,400&display=swap');

/* Portal-specific overrides */
.sidebar { display: none !important; }
.layout { grid-template-columns: 1fr; }

/* Portal shell layout */
.portal-layout { display: flex; flex-direction: column; min-height: 100vh; background: var(--bg); }
.portal-main { flex: 1; padding: 28px 24px; max-width: 960px; margin: 0 auto; width: 100%; }
.topbar--portal { background: oklch(0.18 0.07 230); border-color: oklch(0.24 0.06 230); color: oklch(0.92 0.02 230); }
.topbar--portal .btn-ghost, .topbar--portal .btn { color: oklch(0.88 0.04 230); border-color: oklch(0.30 0.06 230); background: transparent; }
.topbar--portal .btn-ghost:hover { background: oklch(0.25 0.06 230); }
.topbar-left { display: flex; align-items: center; gap: 14px; }
.topbar-right { display: flex; align-items: center; gap: 8px; }
.topbar-brand { font-family: "IBM Plex Serif", Georgia, serif; font-weight: 600; font-size: 16px; letter-spacing: -0.01em; color: inherit; }
.topbar-client-name { color: oklch(0.72 0.04 230); font-size: 13px; }

:root {
  --bg: #FAF8F4;
  --bg-panel: #FFFFFF;
  --bg-sunken: #F3F0E9;
  --bg-row-hover: #F6F3EC;
  --ink: #15140F;
  --ink-2: #3A382F;
  --ink-3: #6B6857;
  --ink-4: #9C9784;
  --rule: #E3DFD3;
  --rule-strong: #C9C3B0;
  --accent: oklch(0.52 0.16 210);
  --accent-ink: oklch(0.30 0.12 210);
  --accent-soft: oklch(0.94 0.04 210);
  --accent-rule: oklch(0.80 0.09 210);
  --danger: oklch(0.52 0.18 28);
  --danger-soft: oklch(0.95 0.04 28);
  --danger-rule: oklch(0.84 0.10 28);
  --warn: oklch(0.72 0.14 75);
  --warn-soft: oklch(0.95 0.05 75);
  --warn-ink: oklch(0.42 0.10 75);
  --shadow-1: 0 1px 0 rgba(20,18,10,0.04), 0 1px 2px rgba(20,18,10,0.04);
  --shadow-2: 0 8px 24px -8px rgba(20,18,10,0.18), 0 2px 6px rgba(20,18,10,0.06);
  --shadow-pop: 0 24px 60px -20px rgba(20,18,10,0.35), 0 6px 16px rgba(20,18,10,0.10);
  --sb-bg: #F3F0E9;
  --sb-ink: #15140F;
  --sb-ink-muted: #3A382F;
  --sb-ink-dim: #6B6857;
  --sb-rule: #E3DFD3;
  --sb-hover: #E8E3D2;
  --sb-brand: #15140F;
  --row-pad-y: 13px;
  --card-pad: 18px;
}

[data-theme="dark"] {
  --bg: #0F0E0B;
  --bg-panel: #1A1916;
  --bg-sunken: #15140F;
  --bg-row-hover: #232118;
  --ink: #F2EFE4;
  --ink-2: #D4D0C1;
  --ink-3: #9A9583;
  --ink-4: #6B6857;
  --rule: #2A2920;
  --rule-strong: #3A382F;
  --accent: oklch(0.65 0.16 210);
  --accent-ink: oklch(0.85 0.10 210);
  --accent-soft: oklch(0.26 0.07 210);
  --accent-rule: oklch(0.40 0.12 210);
  --danger: oklch(0.72 0.16 28);
  --danger-soft: oklch(0.26 0.08 28);
  --danger-rule: oklch(0.42 0.12 28);
  --warn: oklch(0.78 0.14 75);
  --warn-soft: oklch(0.28 0.06 75);
  --warn-ink: oklch(0.82 0.12 75);
  --shadow-1: 0 1px 0 rgba(0,0,0,0.4), 0 1px 2px rgba(0,0,0,0.3);
  --shadow-2: 0 8px 24px -8px rgba(0,0,0,0.6), 0 2px 6px rgba(0,0,0,0.4);
  --shadow-pop: 0 24px 60px -20px rgba(0,0,0,0.75), 0 6px 16px rgba(0,0,0,0.5);
  --sb-bg: #08070A;
  --sb-ink: #E7E3D3;
  --sb-ink-muted: #B4B0A0;
  --sb-ink-dim: #6B6857;
  --sb-rule: #1C1B17;
  --sb-hover: #15140F;
  --sb-brand: #FAF8F4;
}

[data-density="compact"] {
  --row-pad-y: 8px;
  --card-pad: 14px;
}

html,
body {
  min-height: 100%;
  margin: 0;
}

* { box-sizing: border-box; }
button, input, textarea { font: inherit; }

.broker-ui {
  min-height: 100vh;
  background: var(--bg);
  color: var(--ink);
  font-family: "IBM Plex Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: 14px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  transition: background 180ms ease, color 180ms ease;
}

.mono { font-family: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.icon { width: 16px; height: 16px; flex: 0 0 auto; }

.app { display: grid; grid-template-columns: 232px 1fr; min-height: 100vh; }
.sidebar { background: var(--sb-bg); color: var(--sb-ink); border-right: 1px solid var(--sb-rule); display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; }
.brand { display: flex; align-items: center; gap: 10px; padding: 18px; border-bottom: 1px solid var(--sb-rule); }
.brand-mark { width: 28px; height: 28px; border-radius: 50%; background: #FAF8F4; display: grid; place-items: center; color: #15140F; }
.brand-title { font-family: "IBM Plex Serif", Georgia, serif; font-weight: 600; font-size: 16px; letter-spacing: -0.01em; color: var(--sb-brand); }
.brand-sub { font-size: 11px; color: var(--sb-ink-dim); letter-spacing: 0.06em; text-transform: uppercase; margin-top: 1px; }
.nav { padding: 12px 8px; display: flex; flex-direction: column; gap: 1px; flex: 1; overflow: auto; }
.nav-section { font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--sb-ink-dim); padding: 14px 12px 6px; }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 7px 12px; border-radius: 6px; color: var(--sb-ink-muted); cursor: pointer; border: none; background: transparent; width: 100%; text-align: left; font-size: 13.5px; }
.nav-item:hover { background: var(--sb-hover); color: var(--sb-brand); }
.nav-item.active { background: var(--sb-hover); color: var(--sb-brand); box-shadow: inset 2px 0 0 var(--accent); }
.sidebar-foot { border-top: 1px solid var(--sb-rule); padding: 14px 18px; font-size: 12px; color: var(--sb-ink-dim); display: grid; gap: 4px; }

.main { min-width: 0; padding: 20px 24px 42px; }
.topbar { position: sticky; top: 0; z-index: 4; background: color-mix(in oklab, var(--bg) 92%, transparent); backdrop-filter: blur(8px); border-bottom: 1px solid var(--rule); margin: -20px -24px 22px; padding: 12px 24px; display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.breadcrumb { color: var(--ink-3); font-size: 13px; }
.tweaks { display: flex; align-items: center; gap: 8px; }
.theme-toggle { width: 48px; height: 28px; border: 1px solid var(--rule-strong); border-radius: 999px; background: var(--bg-panel); color: var(--accent-ink); cursor: pointer; box-shadow: var(--shadow-1); padding: 3px; display: inline-flex; align-items: center; transition: background 160ms ease, border-color 160ms ease; }
.theme-toggle:hover { box-shadow: var(--shadow-2); }
.theme-toggle-track { width: 100%; display: flex; align-items: center; justify-content: space-between; position: relative; }
.theme-toggle-thumb { width: 20px; height: 20px; border-radius: 999px; background: var(--accent-soft); border: 1px solid var(--accent-rule); display: grid; place-items: center; transition: transform 180ms ease, background 180ms ease; }
.theme-toggle.dark .theme-toggle-thumb { transform: translateX(18px); }
.theme-toggle .icon { width: 13px; height: 13px; }

.page-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 20px; margin-bottom: 18px; }
.page-head h1 { font-family: "IBM Plex Serif", Georgia, serif; margin: 0; font-size: 28px; line-height: 1.15; letter-spacing: -0.025em; }
.page-head p { margin: 8px 0 0; max-width: 760px; color: var(--ink-3); }
.eyebrow { font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-4); margin-bottom: 6px; }
.page-actions, .button-row { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.button-row.tight { gap: 5px; }
.button-grid { display: grid; gap: 8px; }

.card { background: var(--bg-panel); border: 1px solid var(--rule); border-radius: 14px; padding: var(--card-pad); box-shadow: var(--shadow-1); margin-bottom: 16px; }
.card.ink { background: var(--ink); color: var(--bg); border-color: color-mix(in oklab, var(--ink) 86%, white); }
.card h2 { margin: 0 0 10px; font-size: 17px; letter-spacing: -0.01em; }
.card p { color: var(--ink-3); margin: 4px 0 14px; }
.card.ink p { color: color-mix(in oklab, var(--bg) 70%, transparent); }
.card-title-row, .card-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.card-title-row { justify-content: flex-start; }
.card-toolbar.top { align-items: flex-start; }
.small-title { font-size: 13px; }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 7px; border: 1px solid var(--rule-strong); border-radius: 8px; padding: 7px 10px; cursor: pointer; background: var(--bg-panel); color: var(--ink-2); box-shadow: var(--shadow-1); transition: 120ms ease; }
.btn:hover:not(:disabled) { transform: translateY(-1px); box-shadow: var(--shadow-2); }
.btn:disabled { opacity: .52; cursor: not-allowed; }
.btn.default { background: var(--accent); color: white; border-color: var(--accent); }
.btn.secondary { background: var(--bg-panel); color: var(--ink-2); }
.btn.danger { background: var(--danger); color: white; border-color: var(--danger); }
.btn.warn { background: var(--warn); color: #20180A; border-color: var(--warn); }

.badge { display: inline-flex; align-items: center; border: 1px solid var(--rule); border-radius: 999px; padding: 3px 8px; font-size: 12px; line-height: 1; white-space: nowrap; background: var(--bg-sunken); color: var(--ink-3); }
.badge.success, .badge.green { background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-rule); }
.badge.accent { background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-rule); }
.badge.warn, .badge.amber { background: var(--warn-soft); color: var(--warn-ink); border-color: color-mix(in oklab, var(--warn) 50%, var(--rule)); }
.badge.danger, .badge.red { background: var(--danger-soft); color: var(--danger); border-color: var(--danger-rule); }
.badge.neutral { background: var(--bg-sunken); color: var(--ink-3); }
.badge-row { display: flex; gap: 5px; flex-wrap: wrap; }

.table-wrap { overflow: auto; border: 1px solid var(--rule); border-radius: 10px; }
table { border-collapse: collapse; width: 100%; min-width: 720px; }
th { color: var(--ink-4); font-size: 11px; text-transform: uppercase; letter-spacing: .09em; text-align: left; background: var(--bg-sunken); padding: 10px 12px; border-bottom: 1px solid var(--rule); }
td { padding: var(--row-pad-y) 12px; border-bottom: 1px solid var(--rule); vertical-align: middle; }
tr:hover td { background: var(--bg-row-hover); }
td small { display: block; color: var(--ink-3); margin-top: 2px; }
.expand-row pre { margin: 0; background: var(--bg-sunken); border: 1px solid var(--rule); border-radius: 10px; padding: 12px; color: var(--ink-2); }

.split { display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr); gap: 16px; align-items: start; }
.detail-grid { grid-template-columns: minmax(0, 1fr) 340px; }
.rotation-grid { grid-template-columns: 340px minmax(0, 1fr); }
.auth-grid { grid-template-columns: 320px minmax(0, 1fr); }
.portal-grid { grid-template-columns: minmax(0, 1fr) 390px; }
.stack { display: grid; gap: 16px; }
.card-grid { display: grid; gap: 16px; }
.card-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.compact-cards { margin-top: 12px; }

.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin-bottom: 12px; }
.form-grid.two { align-items: start; }
.form-stack { display: grid; gap: 12px; margin: 14px 0; }
.field { display: grid; gap: 6px; margin-bottom: 12px; }
.field span, .field label, .field-label { font-size: 12px; color: var(--ink-3); font-weight: 600; display: block; margin-bottom: 6px; }
.field input, .field textarea { width: 100%; border: 1px solid var(--rule-strong); border-radius: 8px; padding: 9px 10px; background: var(--bg-panel); color: var(--ink); outline: none; }
.field input:focus, .field textarea:focus { border-color: var(--accent-rule); box-shadow: 0 0 0 3px var(--accent-soft); }
.choice-row { display: flex; gap: 8px; flex-wrap: wrap; }
.choice { border: 1px solid var(--rule); border-radius: 8px; padding: 8px 10px; background: var(--bg-sunken); display: inline-flex; align-items: center; gap: 7px; color: var(--ink-2); }

.info-box { background: var(--bg-sunken); border: 1px solid var(--rule); border-radius: 10px; padding: 12px; display: grid; gap: 5px; margin: 12px 0; }
.info-box.inverted { background: color-mix(in oklab, var(--bg) 10%, transparent); border-color: color-mix(in oklab, var(--bg) 25%, transparent); }
.code-block { white-space: pre; overflow: auto; background: rgba(0,0,0,.28); border: 1px solid rgba(255,255,255,.12); border-radius: 10px; padding: 12px; color: #FAF8F4; font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 12px; line-height: 1.55; }
.code-block.light { color: var(--ink-2); background: var(--bg-panel); border-color: var(--rule); }
.secret-code { display: block; background: var(--bg-sunken); border: 1px solid var(--rule); border-radius: 8px; padding: 8px; margin: 8px 0; }

.reveal-box { border-radius: 10px; padding: 11px 12px; margin: 12px 0; display: grid; gap: 4px; }
.reveal-box.warm { background: var(--warn-soft); border: 1px solid color-mix(in oklab, var(--warn) 55%, var(--rule)); color: var(--warn-ink); }
.reveal-box.muted { background: var(--bg-sunken); border: 1px solid var(--rule); color: var(--ink-3); }
.reveal-box code { font-family: "IBM Plex Mono", ui-monospace, monospace; overflow-wrap: anywhere; color: var(--ink); }

.flash { border: 1px solid var(--rule); border-radius: 12px; padding: 12px 14px; margin-bottom: 16px; background: var(--bg-panel); }
.flash.warn { background: var(--warn-soft); border-color: color-mix(in oklab, var(--warn) 50%, var(--rule)); color: var(--warn-ink); }
.flash.danger { background: var(--danger-soft); border-color: var(--danger-rule); color: var(--danger); }
.flash ul { margin: 8px 0 0; padding-left: 20px; }

.metric-list { display: grid; gap: 9px; margin: 14px 0; }
.metric-list div { display: flex; align-items: center; justify-content: space-between; gap: 14px; border-bottom: 1px dashed var(--rule); padding-bottom: 7px; }
.metric-list dt { color: var(--ink-3); }
.metric-list dd { margin: 0; font-weight: 600; }
.danger-text { color: var(--danger); }
.success-text { color: var(--accent-ink); }

.progress-track { height: 10px; border-radius: 999px; background: var(--bg-sunken); border: 1px solid var(--rule); overflow: hidden; margin: 16px 0 8px; }
.progress-bar { height: 100%; background: var(--accent); border-radius: 999px; transition: width .45s ease; }
.poll-note { font-size: 12px; color: var(--ink-3); }
.wizard-steps { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 16px; }
.wizard-step { border: 1px solid var(--rule); border-radius: 12px; padding: 12px; background: var(--bg-sunken); }
.wizard-step.active { border-color: var(--accent-rule); background: var(--accent-soft); color: var(--accent-ink); }
.wizard-step span { width: 26px; height: 26px; border-radius: 50%; display: grid; place-items: center; background: var(--bg-panel); border: 1px solid var(--rule); margin-bottom: 9px; font-weight: 700; }
.wizard-step p { margin: 5px 0 0; font-size: 12px; color: var(--ink-3); }

.vertical-tabs { display: grid; gap: 6px; }
.vertical-tabs button { border: 1px solid var(--rule); background: var(--bg-sunken); color: var(--ink-2); border-radius: 8px; padding: 10px; text-align: left; cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.vertical-tabs button.active { background: var(--accent-soft); color: var(--accent-ink); border-color: var(--accent-rule); box-shadow: inset 2px 0 0 var(--accent); }
.vertical-tabs span { color: var(--ink-4); font-size: 12px; }
.auth-panel { max-width: 560px; margin: 0 auto; border: 1px solid var(--rule); border-radius: 16px; padding: 22px; background: var(--bg-panel); box-shadow: var(--shadow-1); }
.auth-panel.wide { max-width: 680px; }
.auth-wrap > .split { width: 100%; max-width: 780px; }
.auth-title { margin-bottom: 16px; }
.auth-subtitle { margin-bottom: 18px; }
.hero-icon { width: 32px; height: 32px; color: var(--accent-ink); margin-bottom: 12px; }
.otp-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 8px; margin: 18px 0; max-width: 360px; }
.otp-grid span { height: 44px; border-radius: 9px; background: var(--bg-sunken); border: 1px solid var(--rule-strong); }
.qr-row { display: grid; grid-template-columns: 150px 1fr; gap: 18px; align-items: center; }
.qr-box { aspect-ratio: 1; border: 1px solid var(--rule); border-radius: 12px; background: var(--bg-sunken); display: grid; place-items: center; color: var(--ink-4); font-weight: 700; }
.backup-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; background: var(--bg-sunken); border: 1px solid var(--rule); border-radius: 12px; padding: 12px; margin: 14px 0; }
.link-button { border: none; background: transparent; color: var(--accent-ink); text-decoration: underline; cursor: pointer; padding: 0; margin-top: 8px; }

.modal-veil { position: fixed; inset: 0; z-index: 50; background: rgba(20, 18, 10, .38); display: grid; place-items: center; padding: 22px; }
.modal { width: min(520px, 100%); background: var(--bg-panel); border: 1px solid var(--rule); border-radius: 18px; padding: 20px; box-shadow: var(--shadow-pop); }
.modal.static { box-shadow: var(--shadow-2); }
.modal-stage { min-height: 520px; display: grid; place-items: center; background: var(--bg-sunken); border: 1px solid var(--rule); border-radius: 18px; padding: 20px; }
.modal-head { display: flex; gap: 12px; align-items: flex-start; }
.modal-head h2 { margin: 0 0 4px; }
.modal-head p { margin: 0; color: var(--ink-3); }
.modal-icon { width: 38px; height: 38px; border-radius: 12px; display: grid; place-items: center; background: var(--accent-soft); color: var(--accent-ink); }
.modal-icon.warn { background: var(--warn-soft); color: var(--warn-ink); }
.modal-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 18px; }

.filter-row { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)) auto; gap: 10px; align-items: end; margin-bottom: 14px; }
.secret-cell { min-width: 170px; border: 1px solid var(--rule); border-radius: 9px; padding: 8px 9px; display: grid; gap: 3px; }
.secret-cell.hidden { background: var(--bg-sunken); color: var(--ink-4); }
.secret-cell.revealed { background: var(--warn-soft); border-color: color-mix(in oklab, var(--warn) 55%, var(--rule)); color: var(--warn-ink); }
.secret-cell strong { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.secret-cell code { font-family: "IBM Plex Mono", ui-monospace, monospace; font-size: 11px; color: inherit; overflow-wrap: anywhere; }
.poller-panel { display: grid; gap: 7px; margin-top: 12px; }
.poller-panel div { display: flex; justify-content: space-between; gap: 10px; border: 1px solid var(--rule); border-radius: 9px; background: var(--bg-sunken); padding: 8px 10px; }
.poller-panel span { color: var(--ink-3); }
.run-log { border: 1px solid var(--rule); border-radius: 12px; background: var(--bg-sunken); padding: 12px; margin-bottom: 14px; }
.run-log-head { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-bottom: 8px; }
.run-log ol { margin: 0; padding-left: 20px; color: var(--ink-3); }
.run-log li { margin: 4px 0; }
.run-log li.done { color: var(--accent-ink); font-weight: 600; }
.metadata-panel { border: 1px solid var(--accent-rule); border-radius: 12px; background: var(--accent-soft); padding: 12px; }
.metadata-panel strong { display: block; margin-bottom: 8px; color: var(--accent-ink); }
.metadata-panel pre { margin: 0; background: var(--bg-panel); border: 1px solid var(--rule); border-radius: 10px; padding: 12px; color: var(--ink-2); }
.key-list { display: grid; gap: 10px; }
.key-card { border: 1px solid var(--rule); border-radius: 12px; background: var(--bg-sunken); padding: 12px; display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.key-card small { display: block; color: var(--ink-3); margin-top: 2px; }
.timeline { display: grid; gap: 9px; margin: 14px 0; }
.timeline div { border: 1px solid var(--rule); background: var(--bg-sunken); color: var(--ink-2); border-radius: 10px; padding: 11px; }

@media (max-width: 980px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { position: relative; height: auto; }
  .split, .detail-grid, .rotation-grid, .auth-grid, .portal-grid, .card-grid.three { grid-template-columns: 1fr; }
  .page-head, .topbar { flex-direction: column; align-items: flex-start; }
  .filter-row, .form-grid, .wizard-steps { grid-template-columns: 1fr; }
}

/* ===================================================================
   Template compatibility layer (mirrored from admin.css)
   =================================================================== */
.btn-primary { background: var(--accent); color: white; border-color: var(--accent); }
.btn-primary:hover:not(:disabled) { filter: brightness(1.08); }
.btn-ghost { background: transparent; color: var(--ink-2); border-color: var(--rule); box-shadow: none; }
.btn-ghost:hover:not(:disabled) { background: var(--bg-sunken); box-shadow: none; }
.btn-danger { background: var(--danger); color: white; border-color: var(--danger); }
.btn-sm { padding: 5px 8px; font-size: 12.5px; border-radius: 7px; }
.btn-full { width: 100%; justify-content: center; }

.font-mono { font-family: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }
.text-sm  { font-size: 12.5px; }
.text-xs  { font-size: 11px; }
.text-muted { color: var(--ink-3); }
.text-danger { color: var(--danger); }
.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; }

.flash--danger  { background: var(--danger-soft); border-color: var(--danger-rule); color: var(--danger); }
.flash--warn    { background: var(--warn-soft); border-color: color-mix(in oklab, var(--warn) 50%, var(--rule)); color: var(--warn-ink); }
.flash--info    { background: var(--accent-soft); border-color: var(--accent-rule); color: var(--accent-ink); }
.flash--success { background: var(--accent-soft); border-color: var(--accent-rule); color: var(--accent-ink); }
.flash-secret { display: flex; align-items: center; gap: 8px; margin-top: 8px; }

.card--flush { padding: 0; overflow: hidden; }
.card-section-title { font-size: 14px; font-weight: 600; margin: 0 0 8px; color: var(--ink); }

.auth-wrap { display: grid; place-items: center; min-height: 72vh; padding: 24px; }
.auth-wrap--wide .auth-card { max-width: 640px; }
.auth-card { width: 100%; max-width: 480px; }
.auth-header { margin-bottom: 20px; }
.auth-title { font-family: "IBM Plex Serif", Georgia, serif; font-size: 22px; margin: 0 0 16px; }
.auth-subtitle { color: var(--ink-3); margin: 0 0 18px; font-size: 14px; }
.auth-alt-actions { margin-top: 14px; display: flex; justify-content: center; }

.field-input { width: 100%; border: 1px solid var(--rule-strong); border-radius: 8px; padding: 9px 10px; background: var(--bg-panel); color: var(--ink); outline: none; font: inherit; }
.field-input:focus { border-color: var(--accent-rule); box-shadow: 0 0 0 3px var(--accent-soft); }
.field-input--mono  { font-family: "IBM Plex Mono", ui-monospace, monospace; letter-spacing: 0.12em; }
.field-input--center { text-align: center; }
.field-hint  { font-size: 12px; color: var(--ink-4); margin: 4px 0 0; }
.field-error { color: var(--danger); font-size: 12px; margin: 4px 0 0; }

.page-head-title    { font-family: "IBM Plex Serif", Georgia, serif; margin: 0; font-size: 24px; line-height: 1.15; }
.page-head-actions  { display: flex; gap: 8px; align-items: center; }

.table { border-collapse: collapse; width: 100%; }
tr:last-child td { border-bottom: none; }

.key-card-wrap { display: grid; gap: 10px; }
.action-row { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.inline-form { display: inline; }
.empty-state { padding: 36px 24px; text-align: center; color: var(--ink-3); }
.rate-limit-notice { color: var(--danger); font-size: 13px; }
.divider { border: none; border-top: 1px solid var(--rule); margin: 20px 0; }

.portal-layout > .topbar {
  margin: 0;
  padding: 12px 24px;
  border-bottom: 1px solid oklch(0.24 0.06 230);
}

.topbar--portal {
  background: oklch(0.18 0.07 230);
  border-color: oklch(0.24 0.06 230);
  color: oklch(0.92 0.02 230);
}

.topbar--portal .btn-ghost,
.topbar--portal .btn {
  color: oklch(0.88 0.04 230);
  border-color: oklch(0.30 0.06 230);
  background: transparent;
}

.topbar--portal .btn-ghost:hover {
  background: oklch(0.25 0.06 230);
}

.theme-toggle.dark .theme-toggle-thumb,
[data-theme="dark"] .theme-toggle .theme-toggle-thumb {
  transform: translateX(18px);
}

.wp-config-block {
  white-space: pre;
  overflow: auto;
  background: var(--bg-panel);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: 12px;
  color: var(--ink-2);
  line-height: 1.55;
}
