/* Covren Console Design System (FRD 85 §3.1) — single file, no build */

/* --- Fonts (self-hosted, Latin subset) --- */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/static/console/fonts/inter-latin-400-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/static/console/fonts/inter-latin-500-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/static/console/fonts/inter-latin-600-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/static/console/fonts/inter-latin-700-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/static/console/fonts/jetbrains-mono-latin-400-normal.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* --- Variables --- */
:root {
  /* Backgrounds */
  --bg: #0f1419;
  --surface: #1a2332;
  --surface-hover: #1f2937;
  --surface-raised: #243044;

  /* Text */
  --text: #e6edf3;
  --text-secondary: #8b949e;
  --text-tertiary: #848d97;
  --muted: #8b949e;

  /* Accent — Process Teal (Covren brand) */
  --accent: #12B08A;
  --accent-hover: #0E8A6A;
  --accent-muted: rgba(18, 176, 138, 0.12);
  --accent-rgb: 18, 176, 138;
  --accent-text: #0B1D38;

  /* Semantic */
  --success: #238636;
  --success-bg: rgba(35, 134, 54, 0.15);
  --warning: #d29922;
  --warning-bg: rgba(210, 153, 34, 0.15);
  --danger: #da3633;
  --danger-hover: #b62324;
  --danger-bg: rgba(218, 54, 51, 0.15);
  --info: #818cf8;
  --info-bg: rgba(129, 140, 248, 0.15);

  /* Borders */
  --border: #30363d;
  --border-hover: #484f58;
  --border-input: #6e7681;

  /* Spacing (4px base) */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;

  /* Typography */
  --font-family: 'Inter', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', Consolas, monospace;
  --text-xs: 0.75rem;
  --text-sm: 0.875rem;
  --text-base: 1rem;
  --text-lg: 1.25rem;
  --text-xl: 1.5rem;
  --text-2xl: 1.75rem;
  --text-3xl: 2.125rem;
  --text-4xl: 3rem;
  --weight-normal: 400;
  --weight-medium: 500;
  --weight-semibold: 600;
  --weight-bold: 700;
  --leading-tight: 1.2;
  --leading-snug: 1.35;
  --leading-normal: 1.55;
  --leading-relaxed: 1.75;
  --tracking-tighter: -0.035em;
  --tracking-tight: -0.025em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;

  /* Constant colors */
  --color-white: #fff;

  /* Opacity scale */
  --opacity-disabled: 0.5;
  --opacity-muted: 0.6;
  --opacity-hover: 0.8;

  /* Radius */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 8px;
  --radius-xl: 12px;
  --radius-full: 999px;

  /* Shadows */
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.2);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.25), 0 1px 2px rgba(0, 0, 0, 0.15);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -2px rgba(0, 0, 0, 0.2);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -4px rgba(0, 0, 0, 0.2);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.2);
  --shadow-accent: 0 0 0 3px rgba(var(--accent-rgb), 0.15);
  --shadow-accent-lg: 0 0 0 4px rgba(var(--accent-rgb), 0.12), 0 4px 12px rgba(var(--accent-rgb), 0.08);

  /* Elevation */
  --surface-gradient: linear-gradient(135deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 95%, var(--accent) 5%) 100%);
  --surface-overlay: rgba(0, 0, 0, 0.45);
  --surface-scrim: rgba(0, 0, 0, 0.65);

  /* Easing */
  --ease-default: cubic-bezier(0.2, 0, 0.38, 0.9);
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.38, 0.9);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* Durations */
  --duration-fast: 120ms;
  --duration-normal: 200ms;
  --duration-slow: 350ms;
  --duration-slower: 500ms;

  /* Transitions (composed — backward-compatible names) */
  --transition-fast: var(--duration-fast) var(--ease-default);
  --transition-normal: var(--duration-normal) var(--ease-default);
  --transition-slow: var(--duration-slow) var(--ease-out);

  /* Z-index scale */
  --z-dropdown: 10;
  --z-sticky: 100;
  --z-overlay: 200;
  --z-drawer: 500;
  --z-sidebar: 1000;
  --z-sidebar-toggle: 1001;
  --z-mobile-nav: 900;
  --z-toast: 9999;

  /* Inbox layout (FRD 86 §4.1) */
  --inbox-header-max-height: 220px;
  --inbox-list-min-width: 560px;
  --inbox-rail-width: 300px;
  --inbox-rail-width-max: 340px;
}

/* --- Base --- */
* { box-sizing: border-box; }
[hidden] { display: none !important; }

html {
  overflow-x: hidden; /* Prevent horizontal scroll from fixed overlays */
}
body {
  font-family: var(--font-family);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
  background: var(--bg);
  color: var(--text);
  margin: 0;
  min-height: 100vh;
  overflow-x: hidden;
}

a {
  color: var(--accent);
  text-decoration: none;
  transition: color var(--transition-fast);
}
a:hover { text-decoration: underline; }

.muted { color: var(--muted); }

/* Skip-to-main link (WCAG 2.4.1) — hidden until focused via Tab */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  background: var(--accent);
  color: var(--bg);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-weight: var(--weight-semibold);
  font-size: var(--text-sm);
  z-index: 99999;
  text-decoration: none;
  transition: top var(--duration-fast) var(--ease-default);
}
.skip-link:focus {
  top: var(--space-2);
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* --- Flash messages (query-param confirmations on change detail) --- */
.flash-message { color: var(--accent); margin-bottom: var(--space-3); background: var(--accent-muted); border-left: 3px solid var(--accent); padding: var(--space-3); border-radius: var(--radius-md); }
.flash-message--sm { color: var(--accent); margin-bottom: var(--space-3); font-size: var(--text-sm); background: var(--accent-muted); border-left: 3px solid var(--accent); padding: var(--space-3); border-radius: var(--radius-md); }
/* --- Flash banners (inline status/error/success alerts) --- */
.flash { padding: var(--space-3); border-radius: var(--radius-md); margin-bottom: var(--space-3); border-left: 3px solid currentColor; font-size: var(--text-sm); }
.flash a { color: inherit; text-decoration: underline; }
.flash--success { color: var(--success); background: var(--success-bg); }
.flash--error { color: var(--danger); background: var(--danger-bg); }
.flash--warning { color: var(--warning); background: var(--warning-bg); }

/* --- Typography hierarchy --- */
h1, .text-xl { font-weight: var(--weight-semibold); letter-spacing: var(--tracking-tight); line-height: var(--leading-tight); }
h2, .text-lg { font-weight: var(--weight-semibold); letter-spacing: var(--tracking-tight); line-height: var(--leading-snug); }
h3, .text-md { font-weight: var(--weight-medium); letter-spacing: -0.01em; line-height: var(--leading-snug); }
.text-base { font-size: var(--text-base); }
.text-sm { font-size: var(--text-sm); }
.text-xs { font-size: var(--text-xs); }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-6);
}
.container--narrow { max-width: 780px; }
.container--form { max-width: 38rem; }
.container--inbox { max-width: none; margin: 0; padding: var(--space-4) 0 0; }

/* Inbox layout: optional right rail (FRD 86 §4.1) */
.inbox-layout {
  padding-left: var(--space-8);
  padding-right: var(--space-8);
  overflow: hidden;
}
.inbox-layout__main { min-width: 0; }
.inbox-layout .page-header {
  padding: var(--space-3) 0;
  margin-bottom: var(--space-3);
}
.inbox-layout .page-header h1 { font-size: var(--text-xl); }
/* FRD 86 §4.1, 87 §4.2.3: single onboarding representation — rail at ≥1200px, banner at <1200px (not both). */
@media (min-width: 1200px) {
  .inbox-layout {
    display: grid;
    grid-template-columns: minmax(var(--inbox-list-min-width), 1fr) var(--inbox-rail-width);
    gap: var(--space-8);
  }
}
@media (min-width: 1200px) {
  .inbox-layout:not(:has(.inbox-layout__rail)) {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 1199px) {
  .inbox-layout__rail { display: none; }
}

/* Inbox header cap and onboarding banner (FRD 86 §4.3) */
.inbox-header {
  max-height: var(--inbox-header-max-height);
  overflow: visible;
}
.onboarding-banner-inbox {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  min-height: 44px;
  max-height: 56px;
  padding: var(--space-2) 0;
  margin-bottom: var(--space-4);
  border-bottom: 1px solid var(--border);
}
.onboarding-banner-inbox__text { flex-shrink: 0; }
.onboarding-banner-inbox__actions { display: flex; align-items: center; gap: var(--space-2); flex-shrink: 0; }
@media (max-width: 480px) {
  .onboarding-banner-inbox { flex-wrap: wrap; max-height: none; gap: var(--space-2); }
  .onboarding-banner-inbox__actions { flex-shrink: 1; }
}
@media (min-width: 1200px) {
  .onboarding-banner-inbox { display: none; }
}
.inbox-rail-onboarding { position: sticky; top: var(--space-4); }

/* Inbox toolbar and list single container (FRD 86 §4.4) */
.inbox-toolbar-and-list {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

/* Content panel — raised surface for page content areas (FRD 101) */
.content-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  padding: var(--space-4);
  animation: fade-up var(--duration-normal) var(--ease-default) both;
}
.content-panel__title { margin: 0 0 var(--space-1); font-size: var(--text-base); font-weight: 600; color: var(--text-primary); }
.content-panel__subtitle { margin: 0 0 var(--space-4); font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.5; }
.content-panel .review-card:last-child { margin-bottom: 0; }

.inbox-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
}
.inbox-toolbar__filters {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex: 1;
  min-width: 0;
}
.inbox-toolbar__search { flex: 1; max-width: 300px; min-width: 200px; }
.inbox-toolbar__select { width: 140px; min-width: 0; }
.inbox-more-filters {
  padding: var(--space-4);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
.inbox-more-filters__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}
.inbox-more-filters__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}
.inbox-list {
  background: var(--surface);
  min-height: 200px;
}

/* Inbox table (FRD 86 §4.6) */
.inbox-table { width: 100%; border-collapse: collapse; }
.inbox-table th, .inbox-table td { padding: var(--space-3) var(--space-4); text-align: left; vertical-align: middle; border-bottom: 1px solid var(--border); }
.inbox-table th { font-weight: var(--weight-medium); color: var(--text-secondary); font-size: var(--text-sm); }
.inbox-table__row { min-height: 48px; transition: background var(--transition-fast); }
.inbox-table__row:hover { background: var(--surface-hover); }
.inbox-table__row--highlighted { background: var(--accent-muted); border-left: 3px solid var(--accent); }
.inbox-table__headline { min-width: 0; max-width: 320px; }
.inbox-table__headline .inbox-card__headline { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; transition: color var(--transition-fast); }
.inbox-table__headline a:hover { color: var(--accent); }
.inbox-table__severity, .inbox-table__status { width: 1%; white-space: nowrap; }
.inbox-table__updated, .inbox-table__owner { font-size: var(--text-sm); color: var(--text-secondary); }
.inbox-table__actions { white-space: nowrap; }
.inbox-table__actions .inline-form { display: inline; }
.btn-sm { font-size: var(--text-xs); padding: var(--space-1) var(--space-2); min-height: 36px; }

.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;
}

/* --- Layout utilities --- */
.section-gap { margin-top: var(--space-8); }

@media (max-width: 640px) {
  .container { padding: var(--space-4); }
}

/* --- Nav (migrated from base; sidebar in 85-02) --- */
nav {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: var(--space-3) var(--space-6);
}
nav .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0;
}
nav a { margin-right: var(--space-4); }

.onboarding-banner {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: var(--space-3) var(--space-6);
}

/* --- Billing banner (LP-07) --- */
.billing-banner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
  padding: var(--space-2) var(--space-6);
  font-size: var(--text-sm);
}
.billing-banner--danger { background: var(--danger-bg); color: var(--danger); }
.billing-banner--warning { background: var(--warning-bg); color: var(--warning); }
.billing-banner--info { background: var(--info-bg); color: var(--text); }

/* --- Upgrade page (LP-07) --- */
.upgrade-page { max-width: 640px; margin: var(--space-12) auto; text-align: center; }
.upgrade-page h1 { margin-bottom: var(--space-2); }
.upgrade-page .muted { margin-bottom: var(--space-8); }
.upgrade-cards { display: flex; gap: var(--space-6); justify-content: center; flex-wrap: wrap; margin: var(--space-8) 0; }
.upgrade-card {
  flex: 1; min-width: 240px; max-width: 280px;
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: var(--space-8) var(--space-6); background: var(--surface);
  transition: transform var(--duration-fast) var(--ease-spring),
              box-shadow var(--duration-normal) var(--ease-default),
              border-color var(--duration-fast) var(--ease-default);
}
.upgrade-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); border-color: var(--border-hover); }
.upgrade-card--recommended { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent); }
.upgrade-card--recommended:hover { box-shadow: var(--shadow-lg), var(--shadow-accent-lg); border-color: var(--accent-hover); }
.upgrade-card h3 { margin: 0 0 var(--space-1); font-size: var(--text-base); }
.upgrade-card .price { font-size: var(--text-3xl); font-weight: var(--weight-bold); margin: var(--space-2) 0 var(--space-1); }
.upgrade-card .price-note { font-size: var(--text-sm); color: var(--text-secondary); margin-bottom: var(--space-4); }
.upgrade-card .btn-primary,
.upgrade-card .btn-secondary { width: 100%; margin-top: var(--space-2); }
.upgrade-features { text-align: left; margin: var(--space-8) auto; max-width: 400px; }
.upgrade-features li { padding: var(--space-1) 0; color: var(--text-secondary); }
.upgrade-features li::marker { color: var(--accent); }

/* --- Billing status section (LP-07) --- */
.billing-status-card { margin-bottom: var(--space-6); }
.billing-status-card h2 { margin-top: 0; }
.billing-actions { margin-top: var(--space-4); display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: center; }

/* --- Buttons --- */
.btn-primary,
.btn-secondary,
.btn-ghost,
.btn-danger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-family);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  line-height: 1.25;
  padding: var(--space-2) var(--space-5);
  min-height: 44px;  /* WCAG 2.5.5 touch target */
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), transform var(--duration-fast, 120ms) var(--ease-default, ease);
}
.btn-primary:focus-visible,
.btn-secondary:focus-visible,
.btn-ghost:focus-visible,
.btn-danger:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.btn-primary:disabled,
.btn-secondary:disabled,
.btn-ghost:disabled,
.btn-danger:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--accent);
  color: var(--accent-text);
  border-color: var(--accent);
}
.btn-primary:hover:not(:disabled) {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.btn-secondary {
  background: transparent;
  color: var(--accent);
  border-color: var(--accent);
}
.btn-secondary:hover:not(:disabled) {
  background: var(--accent-muted);
}

.btn-ghost {
  background: transparent;
  color: var(--accent);
  border-color: transparent;
}
.btn-ghost:hover:not(:disabled) {
  background: var(--accent-muted);
}
.btn-ghost--active {
  background: var(--accent-muted);
  color: var(--accent);
  font-weight: var(--weight-medium);
}

.btn-danger {
  background: var(--danger);
  color: var(--color-white);
  border-color: var(--danger);
}
.btn-danger:hover:not(:disabled) {
  background: var(--danger-hover);
  border-color: var(--danger-hover);
}
/* Button press feedback — subtle scale on click */
.btn-primary:active:not(:disabled),
.btn-secondary:active:not(:disabled),
.btn-ghost:active:not(:disabled),
.btn-danger:active:not(:disabled) {
  transform: scale(0.97);
}

.btn--loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.btn--loading::after {
  content: '';
  position: absolute;
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: btn-spin 0.6s linear infinite;
}
.btn-primary.btn--loading::after { border-color: var(--accent-text); border-right-color: transparent; }
.btn-danger.btn--loading::after { border-color: var(--color-white); border-right-color: transparent; }
@keyframes btn-spin { to { transform: rotate(360deg); } }

/* --- Form --- */
.form-group {
  margin-bottom: var(--space-4);
}
.form-label {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text);
  margin-bottom: var(--space-2);
}
.form-label--required::after {
  content: " *";
  color: var(--danger);
  font-weight: 600;
}
.form-input,
.form-select {
  width: 100%;
  height: 40px;
  padding: 0 var(--space-3);
  font-family: var(--font-family);
  font-size: var(--text-sm);
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--border-input);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.form-input:focus,
.form-select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);
}
/* Global form control polish */
.form-input:hover,
.form-select:hover {
  border-color: var(--border-hover);
}
.form-input::placeholder { color: var(--text-muted, var(--text-tertiary)); opacity: var(--opacity-muted); }
.form-input:disabled,
.form-select:disabled {
  opacity: var(--opacity-disabled);
  cursor: not-allowed;
  background: var(--surface);
}
/* Override Chrome autofill background to match theme (93-04 S-5) */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus {
  -webkit-box-shadow: 0 0 0 1000px var(--surface) inset;
  -webkit-text-fill-color: var(--text);
  transition: background-color 5000s ease-in-out 0s;
}
/* Remove focus ring on mouse click; show on keyboard nav (93-04 S-6) */
summary:focus { outline: none; }
summary:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.form-select {
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
  padding-right: 2rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5l5 5 5-5' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 12px 8px;
}
.ds-table .form-select { width: auto; }
.inbox-toolbar__select:not(.has-value) { color: var(--text-tertiary); }
/* Owner combobox (FRD 103) */
.owner-combobox { position: relative; min-width: 160px; }
.owner-combobox__input { width: 100%; }
.owner-combobox__list {
  position: absolute; top: 100%; left: 0; right: 0;
  background: var(--surface-raised); border: 1px solid var(--border);
  border-radius: var(--radius-md); margin-top: var(--space-1);
  padding: var(--space-1) 0; box-shadow: var(--shadow-md);
  z-index: 20; max-height: 240px; overflow-y: auto;
  list-style: none;
}
.owner-combobox__list [role="option"] {
  padding: var(--space-2) var(--space-3); cursor: pointer;
  font-size: var(--text-sm); color: var(--text);
  min-height: 44px; display: flex; align-items: center;
}
.owner-combobox__list [role="option"]:hover,
.owner-combobox__item--active {
  background: rgba(var(--accent-rgb), 0.08);
}
.owner-combobox__list [role="option"][hidden] { display: none; }
/* Assign popover (FRD 103) */
.assign-popover {
  width: 240px; background: var(--surface-raised); border: 1px solid var(--border);
  border-radius: var(--radius-md); box-shadow: var(--shadow-md); z-index: 30;
  overflow: hidden;
}
.assign-popover__search { padding: var(--space-2); border-bottom: 1px solid var(--border); }
.assign-popover__input { min-height: 44px; font-size: var(--text-sm); }
.assign-popover__list {
  list-style: none; padding: var(--space-1) 0; margin: 0;
  max-height: 200px; overflow-y: auto;
}
.assign-popover__item {
  padding: var(--space-2) var(--space-3); cursor: pointer;
  font-size: var(--text-sm); color: var(--text);
}
.assign-popover__item:hover,
.assign-popover__item--active { background: rgba(var(--accent-rgb), 0.08); }
.assign-popover__item--current { font-weight: var(--weight-medium); }
.assign-popover__item[hidden] { display: none; }
/* Assignable owner cell */
.list-row__owner--assignable { cursor: pointer; text-decoration: underline dashed; text-underline-offset: 2px; }
.list-row__owner--assignable:hover { color: var(--accent); }
.list-row__owner--empty { color: var(--text-tertiary); font-style: italic; }
.form-checkbox {
  width: 1rem;
  height: 1rem;
  accent-color: var(--accent);
  cursor: pointer;
}
.form-hint {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: var(--space-1);
}
.form-error {
  font-size: var(--text-sm);
  color: var(--danger);
  margin-top: var(--space-1);
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
}
.form-error::before {
  content: "\26A0";
  font-size: var(--text-sm);
  flex-shrink: 0;
}
textarea.form-input {
  height: auto;
  padding: var(--space-2) var(--space-3);
  resize: vertical;
}
.inline-form { display: inline-block; }
.copy-btn {
  font-size: var(--text-xs);
  padding: var(--space-1) var(--space-2);
  min-height: 44px;
  min-width: 44px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface);
  color: var(--text-secondary);
  cursor: pointer;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.copy-btn:hover:not(:disabled) { color: var(--text); border-color: var(--accent); }
.copy-btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.copy-btn:disabled { opacity: var(--opacity-disabled); cursor: not-allowed; }

/* --- Settings page --- */
.settings-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}
.settings-header h1 { margin: 0; }
.settings-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.settings-panel__section {
  padding: var(--space-4);
  border-top: 1px solid var(--border);
}
.settings-panel__section:first-child { border-top: none; }
.settings-panel__inline {
  display: flex;
  align-items: center;
  padding: var(--space-4);
  border-top: 1px solid var(--border);
  min-height: 56px;
}
.settings-inline-row {
  display: flex;
  align-items: center;
  column-gap: var(--space-3);
  width: 100%;
}
.settings-inline-row > .form-label {
  min-width: 130px;
  flex-shrink: 0;
  margin-bottom: 0;
}
.settings-inline-row .form-input {
  flex: 1;
  min-width: 160px;
  max-width: 320px;
}
.settings-inline-row .theme-picker {
  margin-top: 0;
}
.settings-theme-row {
  margin-top: var(--space-6);
}
.settings-form-narrow {
  max-width: 32rem;
}
.settings-panel__section .card h3:first-child {
  margin-top: 0;
}
.section-head__hint {
  margin-left: auto;
  font-size: var(--text-sm);
  font-weight: var(--weight-normal);
  color: var(--text-secondary);
}
.section-head__onboarding {
  font-size: var(--text-sm);
  color: var(--text-tertiary, var(--text-secondary));
  margin: 0 0 var(--space-3) 0;
  font-style: italic;
}
/* Collapsible sub-sections inside a settings section */
.settings-subsection {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  margin-top: var(--space-3);
  overflow: hidden;
}
.settings-subsection:first-child { margin-top: 0; }
.subsection-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  cursor: pointer;
}
.subsection-head:hover { color: var(--accent); }
.subsection-head::after { content: '▼'; font-size: 0.6em; opacity: 0.6; transition: transform var(--transition-fast); margin-left: var(--space-3); flex-shrink: 0; }
details:not([open]) > .subsection-head::after { transform: rotate(-90deg); }
.subsection-body { padding: var(--space-2) var(--space-3) var(--space-3); }

/* Connectors table column control */
.ds-table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.ds-table--connectors { table-layout: fixed; min-width: 720px; }
.ds-table--connectors th:nth-child(1),
.ds-table--connectors td:nth-child(1) { width: 9%; }
.ds-table--connectors th:nth-child(2),
.ds-table--connectors td:nth-child(2) { width: 28%; }
.ds-table--connectors th:nth-child(3),
.ds-table--connectors td:nth-child(3) { width: 11%; }
.ds-table--connectors th:nth-child(4),
.ds-table--connectors td:nth-child(4) { width: 8%; }
.ds-table--connectors th:nth-child(5),
.ds-table--connectors td:nth-child(5) { width: 11%; }
.ds-table--connectors th:nth-child(6),
.ds-table--connectors td:nth-child(6) { width: 7%; }
.ds-table--connectors th:nth-child(7),
.ds-table--connectors td:nth-child(7) { width: 26%; }
.td-url { overflow: hidden; }
.td-url code { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.td-url .copy-btn { margin-top: var(--space-1); font-size: var(--text-xs); }
.td-actions .inline-form { display: block; margin-bottom: var(--space-1); }
.td-actions .inline-form:last-child { margin-bottom: 0; }
.td-actions .btn-sm { white-space: nowrap; width: 100%; }

/* Connectors: desktop table / mobile cards switching */
.connectors-table-desktop { display: block; }
.connectors-cards-mobile { display: none; }

/* Metric card grid component */
.metric-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-5);
}
.metric-card-grid .card {
  transition: box-shadow var(--duration-normal) var(--ease-default),
              border-color var(--duration-fast) var(--ease-default);
}
.metric-card-grid .card:hover { box-shadow: var(--shadow-md); border-color: var(--border-hover); }
.metric-card-grid__value {
  margin: var(--space-2) 0 0;
  font-size: var(--text-xl);
}
.metric-value {
  font-size: var(--text-xl);
  font-weight: var(--weight-semibold);
  margin: var(--space-2) 0 var(--space-1);
}
/* Metric card component (FRD 204) */
.metric-card { padding: var(--space-4); }
.metric-card__label { font-size: var(--text-sm); color: var(--text-muted); font-weight: var(--weight-medium); }
.metric-card__value { font-size: var(--text-xl); font-weight: var(--weight-semibold); margin-top: var(--space-1); }
.metric-card__secondary { font-size: var(--text-sm); color: var(--text-muted); font-weight: var(--weight-normal); margin-left: var(--space-1); }

/* Timeline entry (FRD 204) */
.timeline-list { display: flex; flex-direction: column; gap: var(--space-3); }
.timeline-entry {
  padding: var(--space-4);
  border-left: 3px solid var(--border);
  background: var(--surface-gradient);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-fast);
}
.timeline-entry:hover { border-left-color: var(--accent); }
.timeline-entry--breaking { border-left-color: var(--color-warning); }
.timeline-entry--superseded { opacity: var(--opacity-muted); }
.timeline-entry__header { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-2); }
.timeline-entry__time { font-size: var(--text-sm); color: var(--text-muted); margin-left: auto; }
.timeline-entry__statement { font-size: var(--text-base); margin: 0 0 var(--space-1); }
.timeline-entry__source { font-size: var(--text-sm); color: var(--text-muted); margin: 0; }
.timeline-entry__meta { font-size: var(--text-sm); color: var(--text-muted); margin: var(--space-1) 0 0; }
.timeline-entry__superseded { font-size: var(--text-sm); color: var(--text-muted); margin: var(--space-1) 0 0; }
@media (prefers-reduced-motion: reduce) {
  .timeline-entry { transition: none; }
}

/* Health score badge (FRD 204) */
.health-score {
  display: inline-block;
  padding: var(--space-0-5) var(--space-2);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
}
.health-score--good { background: color-mix(in srgb, var(--color-success) 15%, transparent); color: var(--color-success); }
.health-score--fair { background: color-mix(in srgb, var(--color-warning) 15%, transparent); color: var(--color-warning); }
.health-score--poor { background: color-mix(in srgb, var(--color-error) 15%, transparent); color: var(--color-error); }

/* Lineage flow (FRD 204) */
.lineage-flow { display: flex; flex-direction: column; gap: var(--space-3); }
.lineage-step {
  padding: var(--space-4);
  background: var(--surface-gradient);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--accent);
}
.lineage-step__label { font-size: var(--text-sm); color: var(--text-muted); font-weight: var(--weight-semibold); text-transform: uppercase; letter-spacing: var(--tracking-tight); margin-bottom: var(--space-1); }

/* Distribution page (FRD 97) */
.distribution-keys-table-desktop { display: block; }
.distribution-keys-cards-mobile { display: none; }
.distribution-events-table-desktop { display: block; }
.distribution-events-cards-mobile { display: none; }
/* --- Distribution tab layout (FRD 103) --- */
.moment-grid { display: grid; gap: var(--space-3); }
.moment-card__toggle { display: flex; align-items: flex-start; gap: 0.75rem; }
.moment-card__toggle input[type="checkbox"] { margin-top: 0.25rem; }
.moment-card__desc { color: var(--muted); font-size: var(--text-sm); }
.moment-card { transition: box-shadow var(--duration-normal) var(--ease-default), border-color var(--duration-fast) var(--ease-default); }
.moment-card:hover { box-shadow: var(--shadow-md); border-color: var(--border-hover); }
.moment-card--active { border-left: 3px solid var(--accent); background: var(--surface-gradient); }

/* --- Automation card (Settings > Automation tab) --- */
.automation-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
  transition: box-shadow var(--duration-normal) var(--ease-default), border-color var(--duration-fast) var(--ease-default), border-left-color var(--duration-fast) var(--ease-default);
  border-left: 3px solid transparent;
}
.automation-card:hover { box-shadow: var(--shadow-md); border-color: var(--border-hover); }
.automation-card--active { border-left-color: var(--accent); background: var(--surface-gradient); }
.automation-card--active:hover { border-left-color: var(--accent); }
.automation-card__header { display: flex; align-items: center; gap: var(--space-2); }
.automation-card__header label { display: flex; align-items: center; gap: var(--space-2); cursor: pointer; flex: 1; min-height: 44px; }
.automation-card__status {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-full);
  line-height: 1.2;
  flex-shrink: 0;
}
.automation-card__status--on { color: var(--accent); background: var(--accent-muted); }
.automation-card__status--off { color: var(--text-secondary); background: var(--surface-secondary); }
.automation-card__pipeline {
  display: inline-block;
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: var(--space-1);
}
.automation-card__desc { color: var(--muted); font-size: var(--text-sm); margin: var(--space-2) 0 0; line-height: 1.5; }
.automation-card__sub {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
}
.automation-card__sub .form-input { max-width: 120px; }
@media (prefers-reduced-motion: reduce) {
  .automation-card { transition: none; }
}

/* Integration status (Settings > Integrations tab) */
.integration-status-row { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); }
.integration-status-row__badge { margin-left: auto; }
.integration-actions { margin-top: var(--space-3); }
.integration-desc { font-size: var(--text-sm); margin-bottom: var(--space-3); }

/* Suggested surfaces (auto-discovery from widget telemetry) */
.suggested-surfaces-section { margin-bottom: var(--space-6); }
.suggested-surfaces-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-4);
}
.suggested-surface-card {
  padding: var(--space-4);
  border: 1px dashed var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-gradient);
  transition: box-shadow var(--duration-normal) var(--ease-default), border-color var(--duration-fast) var(--ease-default);
}
.suggested-surface-card:hover { box-shadow: var(--shadow-accent); border-color: var(--accent-muted); }
.suggested-surface-card__header { display: flex; flex-direction: column; gap: var(--space-1); margin-bottom: var(--space-3); }
.suggested-surface-card__id { font-size: var(--text-sm); word-break: break-all; }
.suggested-surface-card__metrics { display: flex; gap: var(--space-4); margin-bottom: var(--space-3); font-size: var(--text-sm); }
.suggested-surface-card__metric--warn { color: var(--amber); }
.suggested-surface-card__actions { display: flex; gap: var(--space-2); align-items: center; }
@media (prefers-reduced-motion: reduce) {
  .suggested-surface-card { transition: none; }
}

/* Reusable form action bar (buttons below a table or form) */
.form-actions { display: flex; gap: var(--space-2); align-items: center; margin-top: var(--space-4); }
/* Action bar: consistent container for primary action buttons at top of content sections */
.action-bar { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); margin-bottom: var(--space-4); background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); }
.action-bar .muted { font-size: var(--text-sm); }
.distribution-add-surface-form { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; margin-bottom: var(--space-3); }
.appearance-preview { width: 120px; height: 64px; border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center; font-size: var(--text-sm); margin-bottom: var(--space-3); border: 2px solid var(--border); background: var(--surface); color: var(--text); box-shadow: var(--shadow-sm); transition: box-shadow var(--duration-normal) var(--ease-default); }
.appearance-preview:hover { box-shadow: var(--shadow-md); }
.appearance-controls { display: grid; gap: 0.75rem; max-width: 400px; }

/* Connector card (mobile) */
.connector-card { border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--space-4); margin-bottom: var(--space-3); }
.connector-card:last-child { margin-bottom: 0; }
.connector-card__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-3); }
.connector-card__name { font-weight: var(--weight-semibold); font-size: var(--text-base); }
.connector-card__row { display: flex; flex-direction: column; gap: var(--space-1); margin-bottom: var(--space-3); }
.connector-card__label { font-size: var(--text-xs); color: var(--muted); text-transform: uppercase; letter-spacing: 0.04em; }
.connector-card__value { font-size: var(--text-sm); word-break: break-all; }
.connector-card__value code { font-size: var(--text-sm); }
.connector-card__meta { display: flex; gap: var(--space-4); font-size: var(--text-sm); color: var(--muted); margin-bottom: var(--space-3); }
.connector-card__actions { display: flex; gap: var(--space-2); }
.connector-card__actions .btn-secondary { flex: 1; }

/* Provider picker (FRD 104) */
.provider-picker { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); padding: var(--space-4) 0; }
.provider-card { border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); text-align: center; background: var(--surface); display: flex; flex-direction: column; align-items: center; gap: var(--space-3); }
.provider-card:hover { border-color: var(--accent); }
.provider-card:active { box-shadow: inset 0 0 0 1px var(--accent); }
.provider-card:has(button:focus-visible) { outline: 2px solid var(--accent); outline-offset: 2px; }
.provider-card__name { font-weight: var(--weight-semibold); }

.theme-picker { display: flex; gap: var(--space-3); margin-top: var(--space-3); }
.code-block {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  overflow-x: auto;
  font-size: var(--text-sm);
}

/* --- Card --- */
.card {
  background: var(--surface-gradient);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.card--interactive {
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-spring),
              box-shadow var(--duration-normal) var(--ease-default),
              border-color var(--duration-fast) var(--ease-default),
              background-color var(--duration-fast) var(--ease-default);
}
.card--interactive:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg), var(--shadow-accent);
  border-color: var(--border-hover);
  background: var(--surface-hover);
}
.card--interactive:active {
  transform: translateY(0) scale(0.99);
  transition-duration: 60ms;
}
.card--interactive:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.card--highlighted {
  border-left: 3px solid var(--accent);
  box-shadow: var(--shadow-accent);
}


/* --- Badge --- */
.badge {
  display: inline-block;
  padding: 0.2em 0.5em;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
}
.badge-ready { background: var(--success); color: var(--color-white); }
.badge-warn, .badge--warning { background: var(--warning); color: #0f1419; }
.badge-muted { background: var(--surface-raised); color: var(--text-secondary); border: 1px solid var(--border); }
.badge-accent { background: color-mix(in srgb, var(--accent) 15%, transparent); color: var(--accent); }
.badge-danger { background: var(--danger); color: var(--color-white); }
/* Semantic success/error aliases — used by compliance, distribution, claim badges */
.badge-success, .badge--success { background: var(--success); color: var(--color-white); }
.badge-error, .badge--error { background: var(--danger); color: var(--color-white); }
.badge-needs-revision { background: #EAEAE8; color: #3D3D3B; }
.badge-coming-soon { background: color-mix(in srgb, var(--text-secondary) 12%, transparent); color: var(--text-secondary); font-style: italic; }
.confidence-badge {
  display: inline-block;
  padding: 0.2em 0.5em;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  margin-left: var(--space-1);
}

/* --- Error box --- */
.error-box {
  background: var(--danger-bg);
  border: 1px solid var(--danger);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin: var(--space-4) 0;
}
.error-box .support-id {
  font-size: var(--text-sm);
  color: var(--muted);
  margin-top: var(--space-2);
}
.success-box {
  background: var(--success-bg);
  border: 1px solid var(--success);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  margin: var(--space-4) 0;
}

/* --- Toast (container; JS creates items) --- */
.toast-container {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  pointer-events: none;
}
.toast {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  box-shadow: var(--shadow-lg);
  pointer-events: auto;
  animation: toast-in 0.25s ease;
}
.toast__close {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  font-size: var(--text-lg);
  padding: 0 0 0 var(--space-3);
  opacity: 0.7;
  transition: opacity var(--transition-fast);
  line-height: 1;
  flex-shrink: 0;
}
.toast__close:hover { opacity: 1; }
@keyframes toast-in {
  0% { opacity: 0; transform: translateY(8px) scale(0.96); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
.toast--success { background: var(--success); color: var(--color-white); }
.toast--error { background: var(--danger); color: var(--color-white); }
.toast--info { background: var(--info); color: var(--color-white); }

/* --- Sidebar (85-02) --- */
.app-layout {
  display: flex;
  min-height: 100vh;
}
.sidebar {
  width: 260px;
  min-width: 260px;
  padding: 0; /* Reset bare nav{} rule from landing CSS */
  border-bottom: none; /* Reset bare nav{} rule */
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  height: 100vh;
  overflow-y: auto;
  z-index: var(--z-sticky);
}
.sidebar__head {
  padding: var(--space-3) var(--space-4) var(--space-2);
  border-bottom: 1px solid var(--border);
}
.sidebar__logo {
  display: block;
  color: var(--text);
  text-decoration: none;
  font-weight: var(--weight-semibold);
  font-size: var(--text-lg);
}
.sidebar__logo:hover { color: var(--accent); text-decoration: none; filter: drop-shadow(0 0 6px rgba(var(--accent-rgb), 0.3)); }
.sidebar__logo-img { display: block; height: 28px; width: auto; transition: filter 200ms ease; }
.sidebar__logo:hover .sidebar__logo-img { filter: brightness(1.2); }
.sidebar__sections { list-style: none; margin: 0; padding: var(--space-3) 0; flex: 1; overflow: auto; }
.sidebar__section { margin-bottom: var(--space-2); }
.sidebar__section-title {
  font-size: 0.6875rem;
  font-weight: var(--weight-medium);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 0 var(--space-4);
  margin-bottom: var(--space-2);
}
.sidebar__section--sep { border-top: 1px solid var(--border); padding-top: var(--space-3); margin-top: var(--space-3); }
.sidebar__links { list-style: none; margin: 0; padding: 0; }
.sidebar__links li { margin: 0; }
.sidebar-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  color: var(--text-secondary);
  text-decoration: none;
  font-size: var(--text-sm);
  transition: transform 120ms ease, background-color 120ms ease, color 120ms ease, border-color 120ms ease;
  border-left: 3px solid transparent;
}
.sidebar-link:hover { color: var(--text); background: var(--surface-hover); text-decoration: none; transform: translateX(2px); }
.sidebar-link:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.sidebar-link--active {
  color: var(--accent);
  background: rgba(var(--accent-rgb), 0.10);
  box-shadow: inset 3px 0 0 var(--accent);
  border-left-color: transparent;
  font-weight: var(--weight-semibold);
}
.sidebar__badge {
  background: var(--accent);
  color: var(--color-white);
  font-size: 0.7rem;
  font-weight: var(--weight-semibold);
  padding: 0.1em 0.4em;
  border-radius: var(--radius-sm);
  min-width: 1.2em;
  text-align: center;
  animation: badge-pop var(--duration-normal) var(--ease-spring) both;
}
@keyframes badge-pop {
  0% { transform: scale(0); }
  70% { transform: scale(1.15); }
  100% { transform: scale(1); }
}
/* Sidebar label group — left-aligned icon+text, badge pushed right via space-between */
.sidebar-link__label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
}
/* Sidebar icon styles */
.sidebar-link__icon {
  display: inline-flex;
  align-items: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  opacity: var(--opacity-disabled);
  transition: opacity var(--duration-fast, 120ms) var(--ease-default, ease),
              color var(--duration-fast, 120ms) var(--ease-default, ease);
}
.sidebar-link:hover .sidebar-link__icon { opacity: var(--opacity-hover); }
.sidebar-link--active .sidebar-link__icon { opacity: 1; color: var(--accent); }
/* Nav section separator */
.sidebar__nav {
  border-bottom: 1px solid var(--border);
  padding-bottom: var(--space-2);
  margin-bottom: var(--space-3);
}
.sidebar__footer {
  margin-top: auto;
  padding: var(--space-4);
  border-top: 1px solid var(--border);
  font-size: var(--text-xs);
}
.sidebar__footer-account { margin-bottom: var(--space-3); }
.sidebar__footer-tenant { display: block; font-weight: var(--weight-semibold); color: var(--text); text-decoration: none; font-size: var(--text-sm); margin-bottom: var(--space-1); }
.sidebar__footer-tenant:hover { color: var(--accent); }
.sidebar__footer-user { word-break: break-all; color: var(--text-secondary); }
.sidebar__footer-email { color: inherit; text-decoration: none; }
.sidebar__footer-email:hover { color: var(--text); }
.sidebar__role-badge { display: inline-block; font-size: var(--text-xs); padding: 1px 6px; border-radius: var(--radius-sm); background: color-mix(in srgb, var(--accent) 15%, transparent); color: var(--accent); font-weight: var(--weight-medium); margin-left: var(--space-1); vertical-align: middle; }
.sidebar__role-badge--super { background: color-mix(in srgb, #f59e0b 15%, transparent); color: #f59e0b; }
[data-theme="light"] .sidebar__role-badge--super { background: color-mix(in srgb, #d97706 15%, transparent); color: #d97706; }
.sidebar__sign-out { display: block; color: var(--text-secondary); text-decoration: none; font-size: var(--text-xs); padding: var(--space-2) 0; border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); margin-bottom: var(--space-3); }
.sidebar__sign-out:hover { color: var(--text); }
.sidebar__footer-legal { display: flex; gap: var(--space-3); }
.sidebar__footer-legal a { color: var(--text-tertiary); text-decoration: none; font-size: var(--text-xs); }
.sidebar__footer-legal a:hover { color: var(--text-secondary); }
.sidebar__footer a:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.app-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  margin-left: 260px;
}
.app-main .container { flex: 1; max-width: 100%; width: 100%; }
.sidebar-toggle {
  display: none;
  position: fixed;
  top: var(--space-2);
  left: var(--space-2);
  z-index: var(--z-sidebar-toggle);
  width: 40px;
  height: 40px;
  padding: 0;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  font-size: 1.25rem;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
}
.sidebar-toggle:hover { background: var(--surface-hover); }
.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: calc(var(--z-sidebar) - 1);
}
@media (max-width: 1023px) {
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    z-index: var(--z-sidebar);
    transform: translateX(-100%);
    transition: transform var(--transition-normal);
  }
  .sidebar.is-open { transform: translateX(0); }
  .sidebar-toggle { display: flex; }
  .sidebar-backdrop.is-visible { display: block; }
  .app-main { margin-left: 0; }
}
@media (min-width: 1024px) {
  .sidebar-toggle[hidden],
  .sidebar-backdrop[hidden] { display: none !important; }
}

/* --- Reading layout (legal/long-form public pages) --- */
/* Header uses landing-nav from landing.css — only content and footer are here */
.reading-content {
  max-width: 780px;
  margin: 0 auto;
  padding: var(--space-6) var(--space-4);
  color: var(--text-primary);
  font-size: var(--text-lg);
  line-height: 1.7;
}
.reading-content h1 { font-size: var(--text-2xl); font-weight: var(--weight-bold); margin-bottom: var(--space-2); letter-spacing: var(--tracking-tight); }
.reading-content h2 { font-size: var(--text-lg); font-weight: var(--weight-semibold); margin-top: var(--space-5); margin-bottom: var(--space-2); color: var(--text-primary); }
.reading-content p { margin-bottom: var(--space-3); color: var(--text-secondary); }
.reading-content a { color: var(--accent); text-decoration: underline; text-underline-offset: 2px; }
.reading-content a:hover { opacity: var(--opacity-hover); }
.reading-content .muted { color: var(--text-muted); font-size: var(--text-sm); }
.reading-footer {
  max-width: 780px;
  margin: 0 auto;
  padding: var(--space-4);
  border-top: 1px solid var(--border);
  text-align: center;
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.reading-footer a { color: var(--text-secondary); text-decoration: none; }
.reading-footer a:hover { color: var(--text-primary); }

/* --- Auth pages (85-03) --- */
.auth-page { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: var(--space-4); position: relative; overflow: hidden; }
.auth-page::before {
  content: '';
  position: absolute;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--accent-rgb), 0.12) 0%, rgba(var(--accent-rgb), 0.04) 40%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  animation: auth-glow-drift 8s var(--ease-default) infinite;
}
.auth-card { width: 100%; max-width: 400px; position: relative; z-index: 1; box-shadow: var(--shadow-lg); animation: fade-up var(--duration-slow) var(--ease-spring) both; }
.auth-card__head { text-align: center; margin-bottom: var(--space-6); }
.auth-card__logo { color: var(--text); display: inline-block; transition: color var(--transition-normal), transform var(--duration-normal) var(--ease-spring); }
.auth-card__logo:hover { color: var(--accent); transform: scale(1.04); }
.auth-card__title { margin-top: 0; margin-bottom: var(--space-4); font-size: var(--text-xl); }
.auth-card__error { margin-bottom: var(--space-4); }
.auth-card__submit { width: 100%; margin-top: var(--space-2); }
.auth-card .btn-primary:hover:not(:disabled) { box-shadow: var(--shadow-accent-lg); }
.auth-card .form-input:hover:not(:focus) { border-color: var(--border-hover); }
.auth-card .form-input:focus { background-color: color-mix(in srgb, var(--bg) 97%, var(--accent) 3%); }
.auth-card__divider { margin-top: var(--space-6); text-align: center; }
.auth-card__links { margin-top: var(--space-6); margin-bottom: 0; }
.auth-card__support { margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--border); }
.auth-card__success { margin-bottom: var(--space-4); }
.auth-error-icon { width: 48px; height: 48px; border-radius: 50%; background: var(--danger-bg); color: var(--danger); display: flex; align-items: center; justify-content: center; font-size: 1.5rem; font-weight: bold; margin: 0 auto var(--space-4); box-shadow: 0 0 0 4px rgba(218, 54, 51, 0.12); }
.auth-error-icon--info { background: var(--info-bg); color: var(--info); box-shadow: 0 0 0 4px rgba(129, 140, 248, 0.12); }
.auth-error-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-4); }
/* Auth page vertical action stack (FRD 147) */
.auth-actions { margin-top: var(--space-4); display: flex; flex-direction: column; gap: var(--space-3); align-items: center; }
.auth-actions > .btn-primary,
.auth-actions > .btn-secondary,
.auth-actions > .btn-ghost { width: 100%; text-align: center; }
/* Password toggle wrap & button (FRD 113) */
.form-input-toggle-wrap { position: relative; display: flex; }
.form-input-toggle-wrap .form-input { flex: 1; }
.form-input-toggle-btn { position: absolute; right: 0; top: 0; bottom: 0; padding: 0 var(--space-2); background: none; border: none; color: var(--text-secondary); cursor: pointer; font-size: var(--text-sm); }
.form-input-toggle-btn:hover { color: var(--text); }
/* Auth form hint variants (FRD 113) */
.form-hint--sm { font-size: var(--text-sm); }
.form-hint--strength { margin-top: 0.25rem; font-size: var(--text-sm); }
.auth-card__error p { margin: 0; }
.auth-card__error p + p { margin-top: var(--space-2); }
/* Sidebar footer legal links — styled via .sidebar__footer-legal in footer block */

/* --- Inbox (85-04) --- */
.inbox-filter-panel { margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--border); }
.inbox-filter-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-4); }
@media (max-width: 640px) { .inbox-filter-grid { grid-template-columns: 1fr; } }
.inbox-card__row1 { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-2); }
.inbox-card__headline { font-weight: var(--weight-medium); color: var(--text); }
.inbox-card__headline:hover { color: var(--accent); text-decoration: none; }
.inbox-card__row2 { font-size: var(--text-sm); margin-bottom: var(--space-4); }
.inbox-card__actions { display: flex; align-items: center; gap: var(--space-2); flex-wrap: wrap; }
.inbox-card__overflow { position: relative; display: inline-block; }
.inbox-card__overflow-menu { position: absolute; right: 0; top: 100%; margin-top: var(--space-1); background: var(--surface-raised); border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--space-2); box-shadow: var(--shadow-md); z-index: 10; display: flex; flex-direction: column; gap: var(--space-1); min-width: 10rem; }
.inbox-card__overflow-menu a { white-space: nowrap; }
.inbox-filter-actions { display: flex; flex-wrap: wrap; gap: var(--space-4); align-items: center; margin-top: var(--space-4); }
.inbox-filter-actions .form-label { margin: 0; display: flex; align-items: center; gap: var(--space-2); }
.inbox-empty { text-align: center; padding: var(--space-8) var(--space-4); max-width: 400px; margin: 0 auto; }
.inbox-empty-icon { font-size: 3rem; margin-bottom: var(--space-4); display: block; }

/* --- Pipeline status dots --- */
.pipeline-dots { display: flex; gap: 4px; align-items: center; }
.pipeline-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--border); transition: background 200ms ease; }
.pipeline-dot--filled { background: var(--success); }

/* --- Help pill (fixed overlay — never shifts layout) --- */
.help-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 8px 16px;
  border-radius: var(--radius-full);
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  font-family: var(--font-family);
  font-size: 0.8125rem;
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: border-color var(--transition-normal), box-shadow var(--transition-normal), color var(--transition-normal);
  position: fixed;
  bottom: var(--space-4);
  right: var(--space-4);
  z-index: var(--z-mobile-nav);
  box-shadow: var(--shadow-sm);
  /* Prevent any contribution to scroll width or layout */
  contain: layout;
}
.help-pill:hover {
  border-color: var(--accent);
  color: var(--accent);
  box-shadow: var(--shadow-accent);
}
.help-pill:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.help-pill__icon { flex-shrink: 0; }

/* --- Empty state (reusable) --- */
.empty-state { text-align: center; padding: var(--space-8) var(--space-4); max-width: 400px; margin: 0 auto; animation: fade-up var(--duration-normal) var(--ease-default) both; }
.empty-state__icon { color: var(--text-tertiary); margin-bottom: var(--space-4); }
.empty-state__title { margin: 0 0 var(--space-2); }
.empty-state__desc { margin: 0 0 var(--space-5); font-size: var(--text-sm); line-height: 1.6; }
.empty-state__actions { display: flex; flex-direction: column; align-items: center; gap: var(--space-2); }
.empty-state__text { font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.5; }
/* Empty state icon breathing animation */
@keyframes empty-state-breathe {
  0%, 100% { transform: scale(1); opacity: 0.7; }
  50% { transform: scale(1.05); opacity: 1; }
}
.empty-state svg,
.empty-state .empty-state__icon {
  animation: empty-state-breathe 3s var(--ease-default) infinite;
}
.empty-state .diagram-step {
  border-left: 2px solid var(--accent);
  padding-left: var(--space-3);
}

/* --- Tables (85-05) --- */
.ds-table { width: 100%; border-collapse: collapse; }
.ds-table th,
.ds-table td { padding: var(--space-2) var(--space-3); text-align: left; border-bottom: 1px solid var(--border); vertical-align: middle; }
.ds-table th { font-weight: var(--weight-semibold); color: var(--text-secondary); font-size: var(--text-sm); }
.ds-table tbody tr:hover { background: var(--surface-hover); }
.ds-table tbody tr:nth-child(even) { background: rgba(255, 255, 255, 0.02); }
.ds-table tbody tr:nth-child(even):hover { background: var(--surface-hover); }
.ds-table .status-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; }
.ds-table .status-dot--bound { background: var(--success); }
.ds-table .status-dot--unbound { background: var(--text-tertiary); }
.status-indicator { display: inline-flex; align-items: center; gap: var(--space-1); font-size: var(--text-sm); }
.status-indicator--bound { color: var(--success); }
.status-indicator--unbound { color: var(--text-secondary); }

/* --- Section collapse (85-05) --- */
.section-head { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: var(--space-2) 0; background: none; border: none; color: var(--text); font-size: var(--text-base); font-weight: var(--weight-medium); cursor: pointer; text-align: left; }
.section-head:hover { color: var(--accent); }
.section-head::after { content: '▼'; font-size: 0.7em; opacity: 0.7; transition: transform var(--transition-fast); margin-left: var(--space-3); flex-shrink: 0; }
details:not([open]) .section-head::after { transform: rotate(-90deg); }
.section-body { padding-top: var(--space-3); }
.section-body[hidden] { display: none; }

/* --- Review queue / approval (85-05) --- */
.review-warn-banner { background: var(--warning-bg); border-left: 4px solid var(--warning); padding: var(--space-3); border-radius: var(--radius-md); margin-bottom: var(--space-3); font-size: var(--text-sm); }
.review-actions { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; }
.review-empty { text-align: center; padding: var(--space-8); color: var(--text-secondary); }
.review-card { background: var(--surface-gradient); border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--space-4); margin-bottom: var(--space-3); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition-normal); }
.review-card:hover { box-shadow: var(--shadow-md); }
.review-card__action-bar .btn-primary { box-shadow: var(--shadow-accent); }
.review-card__content { margin-bottom: var(--space-3); }
.review-card__head h3 { margin: 0 0 var(--space-2) 0; }
.review-card__meta { display: flex; gap: var(--space-2); flex-wrap: wrap; font-size: 0.9em; color: var(--muted); }
.review-card__blockers { margin: var(--space-2) 0 0; font-size: 0.9em; }
.review-card__footer { border-top: 1px solid var(--border); padding-top: var(--space-3); margin-top: var(--space-3); }
.review-card__ack { font-size: var(--text-sm); display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); }
.review-card__action-bar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap; }
.review-card__reject-group { display: flex; align-items: center; gap: var(--space-2); }
.review-card__reject-group .review-card__reason.form-input { min-width: 120px; flex: 1; max-width: 240px; height: 32px; font-size: var(--text-sm); }
.review-card__hint { display: block; font-size: var(--text-xs); margin-top: var(--space-1); }
/* FRD 201: Claims progress in review cards */
.review-card__claims-progress {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.review-card__claims-progress .claims-progress-bar { flex: 1; max-width: 200px; }
.review-card__claims-label { font-size: var(--text-xs); color: var(--text-secondary); white-space: nowrap; }

/* FRD 220: Per-claim review card enhancements */
.review-card--claim .review-card__claim-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}
.review-card__change-link { text-decoration: none; }
.review-card__change-link:hover { text-decoration: underline; }
.review-card__team { margin-top: var(--space-2); font-size: var(--text-sm); }
.review-card--claim .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* FRD 220: Audit trail on change detail */
.audit-trail {
  display: flex;
  flex-direction: column;
  gap: 0;
  position: relative;
}
.audit-trail__entry {
  display: flex;
  gap: var(--space-3);
  padding-bottom: var(--space-4);
  position: relative;
}
.audit-trail__entry:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 3px;
  top: 12px;
  bottom: 0;
  width: 2px;
  background: var(--border);
}
.audit-trail__dot {
  width: 8px;
  height: 8px;
  min-width: 8px;
  border-radius: var(--radius-full);
  background: var(--accent);
  margin-top: 6px;
  flex-shrink: 0;
  z-index: 1;
}
.audit-trail__action {
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.audit-trail__time {
  font-size: var(--text-xs);
  margin-top: 2px;
}

/* FRD 202: Features tree */
.feature-tree { list-style: none; padding: 0; margin: 0; }
.feature-tree__item { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.feature-tree__item:last-child { border-bottom: none; }
.feature-tree__item--child { padding-left: var(--space-8); }
.feature-tree__name { font-weight: 500; flex: 1; }
.feature-tree__meta { display: flex; align-items: center; gap: var(--space-2); color: var(--text-secondary); font-size: var(--text-sm); }
.feature-tree__actions { display: flex; gap: var(--space-1); }
.feature-tree__actions .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* FRD 202: Audience list */
.audience-list { padding: 0; margin: 0; }
.audience-list__item { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); }
.audience-list__item:last-child { border-bottom: none; }
.audience-list__name { font-weight: 500; flex: 1; }
.audience-list__meta { display: flex; align-items: center; gap: var(--space-2); color: var(--text-secondary); font-size: var(--text-sm); }
.audience-list__actions { display: flex; gap: var(--space-1); }
.audience-list__actions .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* FRD 202: Persona type badges */
.badge-persona { font-size: var(--text-xs); font-weight: 500; text-transform: capitalize; }
.badge-persona--customer { background: color-mix(in srgb, #10b981 15%, transparent); color: #10b981; }
.badge-persona--internal { background: color-mix(in srgb, #6366f1 15%, transparent); color: #6366f1; }
.badge-persona--partner { background: color-mix(in srgb, #f59e0b 15%, transparent); color: #f59e0b; }

/* FRD 219: Module-grouped sidebar navigation */
.sidebar__module { margin-top: var(--space-3); }
.sidebar__module:first-child { margin-top: 0; }
.sidebar__section-label { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2) var(--space-3); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-secondary); margin-top: 0; border-left: 3px solid var(--module-color, transparent); padding-left: calc(var(--space-3) - 3px); }
.sidebar__module-icon { width: 20px; height: 20px; flex-shrink: 0; opacity: 0.7; filter: brightness(0) invert(1); }
[data-theme="light"] .sidebar__module-icon { filter: brightness(0); opacity: 0.55; }
.sidebar__module--active .sidebar__section-label { color: var(--module-color, var(--text-secondary)); }
.sidebar__module--active .sidebar__module-icon { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  .sidebar__module-icon { transition: none; }
  .sidebar__section-label { transition: none; }
}
.sidebar__section-toggle { all: unset; display: flex; align-items: center; gap: var(--space-2); width: 100%; box-sizing: border-box; padding: var(--space-2) var(--space-3); padding-left: calc(var(--space-3) - 3px); border-left: 3px solid var(--module-color, transparent); cursor: pointer; color: var(--text-secondary); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; }
.sidebar__section-toggle:hover { color: var(--text); background: var(--surface-hover); }
.sidebar__section-toggle:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; border-radius: var(--radius-sm); }
.sidebar__chevron { margin-left: auto; flex-shrink: 0; opacity: 0.4; transition: transform var(--transition-fast), opacity var(--transition-fast); }
.sidebar__chevron--open { transform: rotate(180deg); }
.sidebar__section-toggle:hover .sidebar__chevron { opacity: 0.8; }
@media (prefers-reduced-motion: reduce) {
  .sidebar__chevron { transition: none; }
}
.sidebar__nav--sub { padding: 0; border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.sidebar-link--sub { padding: var(--space-1) var(--space-4) var(--space-1) var(--space-6); font-size: var(--text-sm); }

/* FRD 202: Claim card feature/audience canonical sections */
.claim-card__features { display: flex; flex-wrap: wrap; gap: var(--space-1); margin-top: var(--space-2); }
.claim-card__features-label { font-size: var(--text-xs); font-weight: 600; color: var(--text-secondary); margin-right: var(--space-1); }
.claim-card__audiences-canonical { display: flex; flex-wrap: wrap; gap: var(--space-1); margin-top: var(--space-2); }
.badge--unconfirmed { opacity: var(--opacity-muted); border: 1px dashed var(--border); }

/* --- Period selector --- */
.period-selector { display: flex; gap: var(--space-1); }
.period-selector a,
.period-selector .period-btn { padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); font-size: var(--text-sm); text-decoration: none; color: var(--text-secondary); border: 1px solid transparent; background: transparent; cursor: pointer; }
.period-selector a:hover,
.period-selector .period-btn:hover { color: var(--text); background: var(--surface-hover); }
.period-selector a.active,
.period-selector .period-btn.active,
.period-selector a.period-selector__item--active,
.period-selector .period-selector__item--active { color: var(--accent); border-color: var(--accent); background: var(--accent-muted); }
.period-selector a:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
/* 87-18: focus rings for tab-style nav links (e.g. widget sub-nav) */
.app-main p a:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* --- Onboarding checklist (compact next-step card) --- */
.onboarding-checklist {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}
.onboarding-checklist__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
}
.onboarding-checklist__title { font-size: var(--text-base); font-weight: var(--weight-semibold); }
.onboarding-checklist__progress-label { color: var(--text-secondary); font-size: var(--text-xs); display: block; margin-bottom: var(--space-2); }
.onboarding-checklist__btn {
  background: none;
  color: var(--text-secondary);
  border: none;
  padding: 0;
  cursor: pointer;
  font-size: var(--text-xs);
}
.onboarding-checklist__btn:hover { color: var(--text); text-decoration: underline; }
.onboarding-checklist__btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: var(--radius-sm); }
.onboarding__progress { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; margin-bottom: var(--space-3); }
.onboarding__progress-bar { height: 100%; background: var(--success); border-radius: 2px; transition: width var(--duration-normal) var(--ease-default); }

/* Next step card (stacked layout) */
.onboarding__next-step {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-3);
  box-shadow: 0 0 0 1px rgba(var(--accent-rgb), 0.12);
}
.onboarding__next-step-header { display: flex; align-items: center; gap: var(--space-2); }
.onboarding__next-step-icon { flex-shrink: 0; }
.onboarding__next-step-title { font-weight: var(--weight-semibold); font-size: var(--text-base); }
.onboarding__next-step-desc { font-size: var(--text-sm); color: var(--text-secondary); margin: var(--space-2) 0 0; line-height: var(--leading-normal); }
.onboarding__next-step-action { margin-top: var(--space-3); width: 100%; text-align: center; }
.onboarding__next-step-options { display: flex; gap: var(--space-2); margin-top: var(--space-3); }
.onboarding__next-step-options .onboarding__next-step-action { margin-top: 0; flex: 1; }

/* Toggle all steps button */
.onboarding__toggle-all {
  background: none;
  border: none;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: var(--text-xs);
  padding: 0;
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.onboarding__toggle-all:hover { color: var(--accent); }
.onboarding__toggle-all:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: var(--radius-sm); }
.onboarding__toggle-all svg { transition: transform var(--transition-fast); }

/* Expanded step list — vertical rhythm so done / current / upcoming read as distinct blocks */
.onboarding-checklist__steps {
  list-style: none;
  margin: var(--space-4) 0 0;
  padding: var(--space-4) 0 0;
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.onboarding__step {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: 0;
  font-size: var(--text-xs);
}
.onboarding__step .check-icon { flex-shrink: 0; }
.onboarding__step-title { font-weight: var(--weight-medium); font-size: var(--text-xs); }
.onboarding__step--done { opacity: 0.8; }
.onboarding__step--done .onboarding__step-title { color: var(--text-secondary); }
.onboarding__step .check-icon--done { color: var(--success); }
.onboarding__step .check-icon--pending { color: var(--border); }
.onboarding__step .btn-sm { font-size: var(--text-xs); padding: 2px var(--space-2); flex-shrink: 0; }
.onboarding__step-content { display: flex; flex-direction: column; gap: 0.125rem; min-width: 0; }
.onboarding-step__desc { display: block; font-size: 0.85rem; color: var(--text-secondary); margin-top: 0.25rem; }
.onboarding-step__time { display: inline-block; font-size: 0.75rem; color: var(--text-tertiary); background: var(--surface-secondary); padding: 0.125rem 0.5rem; border-radius: 0.25rem; margin-top: 0.25rem; width: fit-content; }
.onboarding__step--current {
  display: block;
  border-bottom: none;
  padding: var(--space-2) 0 var(--space-1);
  margin: 0;
}
.onboarding__step--current .onboarding__next-step {
  margin: 0;
  border-color: rgba(var(--accent-rgb), 0.35);
}

/* --- Command palette --- */
.cmd-palette__backdrop { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.5); z-index: var(--z-overlay); }
.cmd-palette__dialog { position: fixed; top: 20%; left: 50%; transform: translateX(-50%); width: 90%; max-width: 520px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: 0 16px 48px rgba(0, 0, 0, 0.3); z-index: 201; overflow: hidden; }
.cmd-palette__input { width: 100%; padding: var(--space-4); border: none; border-bottom: 1px solid var(--border); font-family: var(--font-family); font-size: var(--text-base); background: transparent; color: var(--text); outline: none; }
.cmd-palette__input::placeholder { color: var(--text-tertiary); }
.cmd-palette__results { list-style: none; padding: var(--space-2); margin: 0; max-height: 320px; overflow-y: auto; }
.cmd-palette__result { padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); cursor: pointer; display: flex; align-items: center; gap: var(--space-2); color: var(--text); font-size: var(--text-sm); }
.cmd-palette__result:hover,
.cmd-palette__result--active { background: rgba(var(--accent-rgb), 0.08); }
.cmd-palette__result kbd { margin-left: auto; font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-tertiary); background: var(--bg); padding: 2px 6px; border-radius: var(--radius-sm); border: 1px solid var(--border); }
.cmd-palette__empty { color: var(--text-tertiary); cursor: default; }
.cmd-palette__category { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); font-weight: 600; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: 0.05em; cursor: default; border-top: 1px solid var(--border); margin-top: var(--space-1); }
.cmd-palette__footer { padding: var(--space-2) var(--space-3); border-top: 1px solid var(--border); font-size: var(--text-xs); color: var(--text-tertiary); }
.cmd-palette__footer kbd { font-family: var(--font-mono); background: var(--bg); padding: 1px 4px; border-radius: 3px; border: 1px solid var(--border); margin: 0 2px; }

/* Card focus (keyboard navigation) */
.card--focused { outline: 2px solid var(--accent); outline-offset: -2px; }

/* Keyboard help overlay */
.kbd-help-overlay__backdrop { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.5); z-index: var(--z-overlay); }
.kbd-help-overlay__dialog { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 90%; max-width: 360px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-xl); box-shadow: 0 16px 48px rgba(0, 0, 0, 0.3); z-index: 201; padding: var(--space-6); }
.kbd-help-overlay__dialog h3 { margin: 0 0 var(--space-4); }
.kbd-help-list { margin: 0; padding: 0; }
.kbd-help-list > div { display: flex; justify-content: space-between; align-items: center; padding: var(--space-2) 0; border-bottom: 1px solid var(--border); }
.kbd-help-list > div:last-child { border-bottom: none; }
.kbd-help-list dt { font-size: var(--text-sm); }
.kbd-help-list dd { margin: 0; font-size: var(--text-sm); color: var(--text-secondary); }
.kbd-help-list kbd { font-family: var(--font-mono); font-size: var(--text-xs); background: var(--bg); padding: 2px 6px; border-radius: var(--radius-sm); border: 1px solid var(--border); }
.kbd-help-close { margin-top: var(--space-4); }

/* Sidebar shortcut hint */
.sidebar__shortcut-hint { display: block; padding: var(--space-2) var(--space-4); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-tertiary); border: none; background: none; }
.sidebar__search {
  display: block;
  width: 100%;
  margin-top: var(--space-2);
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-family);
  font-size: var(--text-sm);
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
}
.sidebar__search::placeholder { color: var(--text-tertiary); }
.sidebar__search:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-muted); }
.sidebar__search:hover { border-color: var(--border-hover); }
.sidebar__search:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* --- Skeleton loader utility --- */
@keyframes shimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.skeleton {
  background: linear-gradient(90deg, var(--surface) 25%, var(--border) 50%, var(--surface) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: var(--radius-sm);
}
/* Skeleton variants for loading states (ENH-002) */
.skeleton-text { height: 1em; margin-bottom: 0.5em; }
.skeleton-text--title { height: 1.5em; width: 60%; margin-bottom: 0.75em; }
.skeleton-text--short { width: 40%; }
.skeleton-row {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border);
}
.skeleton-row__avatar { width: 32px; height: 32px; border-radius: var(--radius-full); flex-shrink: 0; }
.skeleton-row__lines { flex: 1; display: flex; flex-direction: column; gap: 0.375rem; }
.skeleton-row__line { height: 0.75em; }
.skeleton-row__line--long { width: 80%; }
.skeleton-row__line--short { width: 35%; }
.skeleton-card {
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column; gap: var(--space-3);
}
.skeleton-metric { height: 80px; border-radius: var(--radius-lg); }

/* --- Responsive: inbox toolbar mobile (FRD 111 R-1) --- */
@media (max-width: 640px) {
  .inbox-toolbar__search { min-width: 0; width: 100%; }
  .inbox-toolbar__filters { flex-direction: column; width: 100%; }
}

/* 87-18: mobile reflow at 375px — avoid clipping of "Create change", "No changes" */
@media (max-width: 400px) {
  .inbox-toolbar { flex-wrap: wrap; gap: var(--space-2); }
  .inbox-toolbar__actions { flex-wrap: wrap; }
  .inbox-toolbar .btn-primary,
  .inbox-toolbar .btn-ghost { white-space: normal; min-width: 0; }
  .empty-state__title { font-size: 1rem; word-break: break-word; }
}

/* ============================================================
   UX REDESIGN — Phase 1 + Phase 2
   ============================================================ */

/* --- Alpine.js: hide elements with x-cloak until Alpine initialises --- */
[x-cloak] { display: none !important; }

/* --- Light mode tokens --- */
[data-theme="light"] {
  --bg: #ffffff;
  --surface: #f6f8fa;
  --surface-hover: #eaeef2;
  --surface-raised: #ffffff;
  --text: #1f2328;
  --text-secondary: #656d76;
  --text-tertiary: #687078;
  --muted: #656d76;
  --accent: #0E8A6A;
  --accent-hover: #0B7259;
  --accent-muted: rgba(14, 138, 106, 0.10);
  --accent-rgb: 14, 138, 106;
  --accent-text: #fff;
  --success: #1a7f37;
  --success-bg: rgba(26, 127, 55, 0.12);
  --warning: #9a6700;
  --warning-bg: rgba(154, 103, 0, 0.12);
  --danger: #cf222e;
  --danger-hover: #a40e26;
  --danger-bg: rgba(207, 34, 46, 0.12);
  --info: #4f46e5;
  --info-bg: rgba(79, 70, 229, 0.12);
  --border: #d0d7de;
  --border-hover: #afb8c1;
  --border-input: #afb8c1;
  --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.08), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.04);
  --surface-gradient: linear-gradient(135deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 95%, var(--accent) 5%) 100%);
  --surface-overlay: rgba(0, 0, 0, 0.25);
  --surface-scrim: rgba(0, 0, 0, 0.45);
}
/* Respect system preference when no explicit theme override */
@media (prefers-color-scheme: light) {
  :root:not([data-theme="dark"]) {
    --bg: #ffffff;
    --surface: #f6f8fa;
    --surface-hover: #eaeef2;
    --surface-raised: #ffffff;
    --text: #1f2328;
    --text-secondary: #656d76;
    --text-tertiary: #687078;
    --muted: #656d76;
    --accent: #0E8A6A;
    --accent-hover: #0B7259;
    --accent-muted: rgba(14, 138, 106, 0.10);
    --accent-rgb: 14, 138, 106;
    --accent-text: #fff;
    --success: #1a7f37;
    --success-bg: rgba(26, 127, 55, 0.12);
    --warning: #9a6700;
    --warning-bg: rgba(154, 103, 0, 0.12);
    --danger: #cf222e;
    --danger-hover: #a40e26;
    --danger-bg: rgba(207, 34, 46, 0.12);
    --info: #4f46e5;
    --info-bg: rgba(79, 70, 229, 0.12);
    --border: #d0d7de;
    --border-hover: #afb8c1;
    --border-input: #afb8c1;
    --shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
    --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.08), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
    --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.05);
    --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.04);
    --surface-gradient: linear-gradient(135deg, var(--surface) 0%, color-mix(in srgb, var(--surface) 95%, var(--accent) 5%) 100%);
    --surface-overlay: rgba(0, 0, 0, 0.25);
    --surface-scrim: rgba(0, 0, 0, 0.45);
  }
}
/* Light mode: auth page glow dimmed */
[data-theme="light"] .auth-page::before { opacity: var(--opacity-disabled); }


/* --- Utility: monospace (Details/IDs only) --- */
.font-mono { font-family: var(--font-mono); font-size: var(--text-sm); }

/* --- Utility: button that looks like a link --- */
.link-btn {
  background: none;
  border: none;
  padding: 0;
  color: var(--accent);
  font-family: var(--font-family);
  font-size: inherit;
  cursor: pointer;
  text-decoration: none;
}
.link-btn:hover { text-decoration: underline; color: var(--accent-hover); }

/* --- Utility: form actions row --- */
.form-actions { display: flex; gap: var(--space-3); align-items: center; margin-top: var(--space-6); flex-wrap: wrap; }

/* --- Textarea auto-height --- */
textarea.form-input { height: auto; padding: var(--space-2) var(--space-3); resize: vertical; }

/* --- Status chip (system health, inline status) --- */
.status-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.2em 0.6em;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
}
.status-chip::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.status-chip--success { background: var(--success-bg); color: var(--success); }
.status-chip--warning { background: var(--warning-bg); color: var(--warning); }
.status-chip--danger { background: var(--danger-bg); color: var(--danger); }
.status-chip--neutral { background: var(--surface-raised); color: var(--text-secondary); border: 1px solid var(--border); }

/* --- Impact badge (replaces raw severity badge in queue) --- */
.impact-badge {
  display: inline-block;
  padding: 0.2em 0.55em;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
}
.impact-badge--high { background: var(--danger-bg); color: var(--danger); border: 1px solid var(--danger); }
.impact-badge--med  { background: var(--warning-bg); color: var(--warning); border: 1px solid var(--warning); }
.impact-badge--low  { background: var(--surface-raised); color: var(--text-secondary); border: 1px solid var(--border); }

/* --- Persona tags (classification-derived audience chips) --- */
.persona-tag {
  display: inline-block;
  padding: 0.15em 0.5em;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-normal);
  background: var(--accent-muted, rgba(37, 99, 235, 0.1));
  color: var(--accent, #2563eb);
  white-space: nowrap;
  box-shadow: var(--shadow-xs);
}
.persona-tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: var(--space-1);
}

/* --- Breadcrumb --- */
.breadcrumb { margin-bottom: var(--space-2); }
.breadcrumb__list {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: var(--text-sm);
}
.breadcrumb__link { color: var(--muted); text-decoration: none; }
.breadcrumb__link:hover { color: var(--text); text-decoration: underline; }
.breadcrumb__sep { color: var(--border); }
.breadcrumb__current { color: var(--text); }

/* ── Utility: section label (uppercase heading — FRD 109) ── */
.section-label {
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  margin-bottom: var(--space-3);
}

/* ── Utility: pre-wrap content block ── */
.pre-wrap {
  white-space: pre-wrap;
  font-family: inherit;
  font-size: var(--text-sm);
}

/* ── Draft content: rendered markdown ── */
.draft-content { font-size: var(--text-sm); line-height: 1.6; }
.draft-content h1, .draft-content h2, .draft-content h3 { margin-top: 1rem; margin-bottom: 0.5rem; }
.draft-content h1 { font-size: var(--text-lg); font-weight: var(--weight-bold); }
.draft-content h2 { font-size: var(--text-base); font-weight: var(--weight-semibold); }
.draft-content h3 { font-size: var(--text-sm); font-weight: var(--weight-semibold); }
.draft-content p { margin-bottom: 0.5rem; }
.draft-content a { color: var(--accent); text-decoration: underline; }
.draft-content ul, .draft-content ol { padding-left: 1.5rem; margin-bottom: 0.5rem; }
.draft-content li { margin-bottom: 0.25rem; }
.draft-content strong { font-weight: var(--weight-semibold); }
.draft-content code { background: var(--surface); padding: 0.125rem 0.375rem; border-radius: 0.25rem; font-size: 0.85em; }
.draft-content pre { background: var(--surface); padding: 0.75rem; border-radius: 0.25rem; overflow-x: auto; margin-bottom: 0.5rem; }
.draft-content pre code { background: none; padding: 0; }
.draft-content table { border-collapse: collapse; width: 100%; margin-bottom: 0.5rem; }
.draft-content th, .draft-content td { border: 1px solid var(--border); padding: 0.375rem 0.625rem; font-size: var(--text-xs); }
.draft-content th { background: var(--surface); font-weight: var(--weight-semibold); }

/* ── Utility: form grid layout ── */
.form-grid {
  display: grid;
  gap: var(--space-3);
  max-width: 36rem;
}

/* ── Utility: detail metadata table ── */
.detail-table {
  font-size: var(--text-sm);
  border-collapse: collapse;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.detail-table td {
  padding: 3px var(--space-4) 3px 0;
}
.detail-table td:first-child {
  color: var(--text-secondary);
}

/* ── Technical details collapsible (FRD 171) ── */
.technical-details summary {
  cursor: pointer;
  font-weight: var(--font-weight-semibold);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  padding: var(--space-2) 0;
}
.technical-details summary:hover { color: var(--text-primary); }
.technical-details summary:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.technical-details[open] summary { margin-bottom: var(--space-3); }
@media (prefers-reduced-motion: reduce) {
  .technical-details summary { transition: none; }
}

/* ── Progress bar (usage — FRD 109) ── */
.progress-wrap {
  background: var(--surface-raised);
  border-radius: var(--radius-sm);
  height: 1.25rem;
  overflow: hidden;
}
.progress-bar {
  height: 100%;
  border-radius: var(--radius-sm);
  transition: width var(--transition-normal);
}
.progress-bar--ok      { background: var(--success); }
.progress-bar--warning { background: var(--warning); }
.progress-bar--limit   { background: var(--danger); }
@keyframes progress-fill { from { width: 0; } }
.progress-bar { animation: progress-fill var(--duration-slow) var(--ease-default) forwards; }
.usage-ok              { color: var(--success); }
.usage-warning         { color: var(--warning); }
.usage-limit-reached   { color: var(--danger); }

/* --- Enhanced page header --- */
.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
  padding: var(--space-3) 0;
}
.page-header h1 { margin: 0; font-size: var(--text-xl); letter-spacing: var(--tracking-tight); }
.page-header__subtitle { margin: var(--space-1) 0 0; font-size: var(--text-sm); }
.page-header__chips { display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; padding-top: var(--space-1); }
.page-header__actions { display: flex; gap: var(--space-2); align-items: center; flex-shrink: 0; }
.page-header__text { min-width: 0; flex: 1; }
.page-header--sticky {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  background: color-mix(in srgb, var(--bg) 90%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  margin-bottom: 0;
  padding: var(--space-3) var(--space-6);
  align-items: center;
}
.page-header--sticky h1 { font-size: var(--text-lg); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.page-header--sticky .page-header__subtitle { display: none; }
/* FRD 219: Module lockup above page title — category label */
.page-header__module-lockup { display: flex; align-items: center; gap: var(--space-1); margin-bottom: var(--space-1); }
.page-header__module-name { font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: var(--tracking-tight); color: var(--module-color, var(--text-secondary)); }
.page-header--sticky .page-header__module-lockup { display: none; }

/* --- Sub-nav (horizontal section links) --- */
.sub-nav { display: flex; align-items: center; margin-top: var(--space-1); overflow-x: auto; -webkit-overflow-scrolling: touch; }
.sub-nav__separator { flex: 0 0 auto; padding: 0 var(--space-1); color: var(--muted); }
.sub-nav__item { flex: 0 1 auto; text-align: center; color: var(--accent); text-decoration: none; font-size: var(--text-sm); white-space: nowrap; padding: var(--space-2) var(--space-3); }
.sub-nav__item:hover { text-decoration: underline; }
.sub-nav__item:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: var(--radius-sm); }
.sub-nav__item--active { color: var(--text); font-weight: 600; }

/* --- Task panel (gate checklist on update detail) --- */
.task-panel {
  background: var(--surface-gradient);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  position: sticky;
  top: calc(3.5rem + var(--space-4)); /* below sticky header */
  box-shadow: var(--shadow-sm);
}
.task-panel__title {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-secondary);
  margin: 0 0 var(--space-4);
}
.task-panel__list {
  list-style: none;
  margin: 0 0 var(--space-4);
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.task-panel__item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--text-sm);
}
.task-panel__check {
  width: 18px;
  height: 18px;
  min-width: 18px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.625rem;
  margin-top: 1px;
  flex-shrink: 0;
  color: var(--color-white);
}
.task-panel__item--done .task-panel__check { background: var(--success); border-color: var(--success); box-shadow: 0 0 0 3px rgba(35, 134, 54, 0.2); }
.task-panel__item--done .task-panel__label { color: var(--text-secondary); transition: opacity var(--transition-fast); }
.task-panel__item--blocked .task-panel__check { border-color: var(--danger); }
.task-panel__why { display: block; margin-top: var(--space-1); font-size: var(--text-xs); }
.task-panel__action { margin-top: var(--space-3); padding-top: var(--space-3); border-top: 1px solid var(--border); }
.task-panel__label--link { cursor: pointer; color: var(--accent); text-decoration: none; background: none; border: none; padding: 0; font: inherit; }
.task-panel__label--link:hover { text-decoration: underline; }
.task-panel__secondary-action { margin-top: var(--space-2); }

/* Assign owner row (used in detail actions row) */
.panel-assign-row { display: flex; gap: var(--space-2); align-items: center; }
.panel-assign-row .form-input { flex: 1; min-width: 0; }

/* --- Draft artifact card (FRD 132 polish) --- */
.draft-artifact { background: var(--surface-gradient); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); margin-bottom: var(--space-4); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition-normal); }
.draft-artifact:hover { box-shadow: var(--shadow-md); }
.draft-artifact__header { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); padding-bottom: var(--space-3); border-bottom: 1px solid var(--border); }
.draft-artifact__title { font-size: var(--text-base); font-weight: var(--weight-semibold); margin: 0; }
.draft-artifact__content { margin-bottom: var(--space-3); max-height: 32rem; overflow-y: auto; }
.draft-artifact__edit { border-top: 1px solid var(--border); padding-top: var(--space-3); margin-top: var(--space-3); }
.draft-artifact__edit summary { cursor: pointer; font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text-secondary); }
.draft-artifact__edit summary:hover { color: var(--text); }
.draft-compact-row { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-3) var(--space-4); background: var(--surface-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); margin-bottom: var(--space-4); font-size: var(--text-sm); transition: background var(--transition-fast); }
.draft-compact-row:hover { background: var(--surface-hover); }
.approval-actions { background: var(--surface-raised); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--space-4); margin-bottom: var(--space-4); }
.approval-actions__heading { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text-secondary); margin-bottom: var(--space-4); text-transform: uppercase; letter-spacing: 0.05em; }

/* --- Action-needed card (questions section visual wrapper) --- */
.action-needed-card { border: 1px solid var(--warning); border-left: 3px solid var(--warning); border-radius: var(--radius-lg); padding: var(--space-4); background: var(--warning-bg); margin-bottom: var(--space-5); box-shadow: var(--shadow-sm); transition: box-shadow var(--transition-normal); }
.action-needed-card:hover { box-shadow: var(--shadow-md); }
.action-needed-card__header { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-2); }
.action-needed-card__icon { display: inline-flex; align-items: center; justify-content: center; width: 20px; height: 20px; border-radius: 50%; background: var(--warning); color: var(--surface); font-size: var(--text-xs); font-weight: var(--weight-bold); flex-shrink: 0; }
.action-needed-card__title { font-size: var(--text-sm); font-weight: var(--weight-semibold); color: var(--warning); text-transform: uppercase; letter-spacing: 0.05em; margin: 0; }
.action-needed-card__description { font-size: var(--text-sm); color: var(--text-secondary); margin-bottom: var(--space-3); }

/* --- Question cards (FRD 133) --- */
.question-card { padding: var(--space-3) var(--space-4); border: 1px solid var(--border); border-radius: var(--radius-md); margin-bottom: var(--space-3); }
.question-card__section { font-weight: var(--weight-medium); font-size: var(--text-sm); margin-bottom: var(--space-1); }
.question-card__question { font-size: var(--text-sm); margin-bottom: var(--space-1); }
.question-card__claim { font-size: var(--text-xs); }

/* --- Evidence drawer (FRD 132) --- */
.confidence-bar { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; box-shadow: inset 0 1px 2px rgba(0,0,0,0.1); }
.confidence-bar__fill { height: 100%; border-radius: 3px; transition: width 0.3s; }
.confidence-bar__fill--high { background: var(--success); box-shadow: 0 0 8px rgba(35, 134, 54, 0.3); }
.confidence-bar__fill--medium { background: var(--warning); box-shadow: 0 0 8px rgba(210, 153, 34, 0.3); }
.confidence-bar__fill--low { background: var(--danger); box-shadow: 0 0 8px rgba(218, 54, 51, 0.3); }

/* Confidence factor lists (FRD 156) */
.confidence-factors { list-style: none; padding-left: 0; margin: var(--space-2) 0; }
.confidence-factors li { padding: var(--space-1) 0; padding-left: var(--space-4); position: relative; font-size: var(--text-sm); color: var(--text-secondary); }
.confidence-factors--positive li::before { content: "+"; position: absolute; left: var(--space-1); color: var(--success); font-weight: 600; }
.confidence-factors--improvement li::before { content: "\2192"; position: absolute; left: var(--space-1); color: var(--warning); font-weight: 600; }
.drawer__subtitle { font-size: var(--text-sm); color: var(--text-secondary); margin-top: var(--space-3); margin-bottom: var(--space-1); font-weight: 600; }

/* Confidence badge variants (FRD 156) */
.confidence-badge--high { background: color-mix(in srgb, var(--success) 15%, transparent); color: var(--success); }
.confidence-badge--medium { background: color-mix(in srgb, var(--warning) 15%, transparent); color: var(--warning); }
.confidence-badge--low { background: color-mix(in srgb, var(--danger) 15%, transparent); color: var(--danger); }

.evidence-source-list { list-style: none; padding: 0; margin: 0; }
.evidence-source { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-2); border-bottom: 1px solid var(--border); font-size: var(--text-sm); border-radius: var(--radius-sm); transition: background var(--transition-fast); margin: 0 calc(-1 * var(--space-2)); }
.evidence-source:hover { background: var(--surface-hover); }
.evidence-source__link { color: var(--accent); text-decoration: none; }
.evidence-source__link:hover { text-decoration: underline; }
.evidence-source__badge { font-size: var(--text-xs); padding: 0.125rem 0.375rem; background: var(--surface-raised); border: 1px solid var(--border); border-radius: var(--radius-sm); color: var(--text-secondary); white-space: nowrap; }
.evidence-claim-list { list-style: none; padding: 0; margin: 0; }
.evidence-claim { padding: var(--space-2) 0; border-bottom: 1px solid var(--border); font-size: var(--text-sm); }
.evidence-claim__status { display: inline-block; font-size: var(--text-xs); font-weight: var(--weight-medium); padding: 0.125rem 0.375rem; border-radius: var(--radius-sm); margin-right: var(--space-2); }
.evidence-claim--supported .evidence-claim__status { background: var(--success-bg); color: var(--success); box-shadow: 0 0 0 3px rgba(35, 134, 54, 0.12); }
.evidence-claim--needs_confirmation .evidence-claim__status { background: var(--warning-bg); color: var(--warning); box-shadow: 0 0 0 3px rgba(210, 153, 34, 0.12); }
.evidence-claim__text { display: block; margin-top: var(--space-1); }
.evidence-claim__cite { display: block; font-size: var(--text-xs); color: var(--text-secondary); margin-top: var(--space-1); }

/* --- Drawer (evidence + details slide-in) --- */
.drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-drawer);
  display: flex;
  justify-content: flex-end;
}
.drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
}
.drawer {
  position: relative;
  z-index: 1;
  width: 440px;
  max-width: 92vw;
  height: 100%;
  background: var(--surface-gradient);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-lg);
  animation: drawer-in 200ms ease;
}
@keyframes drawer-in {
  from { transform: translateX(100%); opacity: 0.8; }
  to   { transform: translateX(0); opacity: 1; }
}
.drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.drawer__title { margin: 0; font-size: var(--text-base); font-weight: var(--weight-semibold); }
.drawer__close {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 1.375rem;
  line-height: 1;
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
}
.drawer__close:hover { background: var(--surface-hover); color: var(--text); }
.drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.drawer__section { display: flex; flex-direction: column; gap: var(--space-2); }
.drawer__section-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--text-secondary);
  margin: 0;
}
.drawer__section-content { font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-relaxed); }
.drawer--evidence .drawer__section-content { color: var(--text); }
/* Collapsible drawer section (progressive disclosure) */
details.drawer__section--collapsible { border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--space-3); }
details.drawer__section--collapsible > .drawer__section-toggle { cursor: pointer; list-style: none; display: flex; align-items: center; gap: var(--space-2); }
details.drawer__section--collapsible > .drawer__section-toggle::-webkit-details-marker { display: none; }
details.drawer__section--collapsible > .drawer__section-toggle::before { content: "▸"; font-size: var(--text-xs); transition: transform var(--duration-fast) var(--ease-default); }
details.drawer__section--collapsible[open] > .drawer__section-toggle::before { transform: rotate(90deg); }
.drawer__section-count { font-weight: var(--weight-normal); color: var(--text-secondary); font-size: var(--text-xs); }

/* ══════════════════════════════════════════════════════════════════
   Unified console tabs — single tab component for all pages.
   Unified tab component for all console pages (FRD 172)
   Two variants: button tabs (Alpine.js, same-page) and link tabs (server routes)
   ══════════════════════════════════════════════════════════════════ */
.console-tabs-wrap { position: relative; }
.console-tabs-wrap::after {
  content: '';
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 32px;
  background: linear-gradient(to right, transparent, var(--bg));
  pointer-events: none;
  z-index: 1;
  display: none;
}
@media (max-width: 600px) {
  .console-tabs-wrap::after { display: block; }
}
.console-tabs {
  display: flex;
  align-items: stretch;
  gap: 0;
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  position: relative;
}
.console-tabs::-webkit-scrollbar { display: none; }
.console-tabs__list {
  display: flex;
  gap: 0;
  flex: 1 1 auto;
  min-width: 0;
}
.console-tab {
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-family);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.console-tab:hover { color: var(--text); }
.console-tab:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }
.console-tab--active {
  color: var(--text);
  border-bottom: 3px solid var(--accent);
  font-weight: var(--weight-semibold);
}
/* Badge inside a tab (count indicator) */
.console-tab__badge {
  margin-left: 0.375rem;
  min-width: 20px;
  text-align: center;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  background: var(--accent-muted);
  color: var(--accent);
  border-radius: var(--radius-full);
  padding: 0.125rem 0.375rem;
  line-height: 1;
}
/* Right-aligned slot for actions (period selector, buttons) */
.console-tabs__actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-4) var(--space-1) var(--space-2);
  flex-shrink: 0;
}
/* Tab content panel animation */
.console-tab-panel { animation: fade-up 0.2s var(--ease-default); }
@media (prefers-reduced-motion: reduce) {
  .console-tab-panel { animation: none; }
  .console-tabs-wrap::after { display: none !important; }
}
@media (max-width: 600px) {
  .console-tabs { padding: 0 var(--space-4); }
}

/* Empty state wrapper (consistent padding for tab panels) */
.empty-state-wrap { padding: var(--space-8) 0; }

/* --- List row card variant (queue rows on mobile) --- */
.list-row--card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-4);
  border-bottom: 1px solid var(--border);
  transition: background var(--transition-fast);
}
.list-row--card:last-child { border-bottom: none; }
.list-row--card:hover { background: var(--surface-hover); }
.list-row__main {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.list-row__title {
  font-weight: var(--weight-medium);
  color: var(--text);
  font-size: var(--text-sm);
  flex: 1;
  min-width: 0;
}
.list-row__title:hover { color: var(--accent); text-decoration: none; }
.list-row__next { font-size: var(--text-sm); color: var(--text-secondary); margin: 0; }
.list-row__meta {
  display: flex;
  gap: var(--space-4);
  font-size: var(--text-xs);
  color: var(--text-secondary);
}

/* --- Update detail layout: checklist bar + content grid with optional rail --- */
.update-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  padding: var(--space-6);
  min-width: 0;
}
.update-layout:has(.update-layout__rail) {
  grid-template-columns: 1fr var(--inbox-rail-width);
}
.update-layout__rail {
  position: sticky;
  top: calc(3.5rem + var(--space-4));
  align-self: start;
}
.update-layout__main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.update-layout__tabs {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.detail-actions-row {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

/* Horizontal task panel modifier (detail page checklist bar) */
.task-panel--horizontal { position: static; display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap; }
.task-panel--horizontal .task-panel__title { margin: 0; white-space: nowrap; }
.task-panel--horizontal .task-panel__list { flex-direction: row; flex-wrap: wrap; gap: var(--space-2) var(--space-4); margin: 0; }
.task-panel--horizontal .task-panel__action,
.task-panel--horizontal .task-panel__secondary-action { margin-top: 0; padding-top: 0; border-top: none; }

/* --- Review mode: linear collapsible flow --- */
.review-step {
  border-bottom: 1px solid var(--border);
  padding: var(--space-5) var(--space-6);
}
.review-step:last-child { border-bottom: none; }
.review-step__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  cursor: pointer;
}
.review-step__num {
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-tertiary);
}
.review-step__title {
  font-weight: var(--weight-semibold);
  font-size: var(--text-base);
  flex: 1;
}
.review-step__body { margin-top: var(--space-4); }

/* --- Urgency toggle (radio group styled as pill row) --- */
.urgency-toggle {
  display: flex;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.urgency-toggle input[type="radio"] { display: none; }
.urgency-toggle label {
  flex: 1;
  text-align: center;
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  cursor: pointer;
  color: var(--text-secondary);
  border-right: 1px solid var(--border);
  transition: background var(--transition-fast), color var(--transition-fast);
  user-select: none;
}
.urgency-toggle label:last-of-type { border-right: none; }
.urgency-toggle input:checked + label { background: var(--accent); color: var(--color-white); }
.urgency-toggle input#urgency-high:checked + label { background: var(--danger); color: var(--color-white); }
.urgency-toggle input#urgency-med:checked + label { background: var(--warning); color: #0f1419; }
.urgency-toggle input#urgency-low:checked + label { background: var(--success); color: var(--color-white); }

/* --- Advanced toggle (accordion trigger) --- */
.advanced-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: none;
  border: none;
  padding: 0;
  color: var(--accent);
  font-family: var(--font-family);
  font-size: var(--text-sm);
  cursor: pointer;
  margin-top: var(--space-2);
}
.advanced-toggle:hover { text-decoration: underline; }
.advanced-toggle::before { content: '›'; font-size: 1rem; transition: transform 150ms ease; }
.advanced-toggle[aria-expanded="true"]::before { transform: rotate(90deg); }
.advanced-section { margin-top: var(--space-4); padding-top: var(--space-4); border-top: 1px solid var(--border); }

/* --- Empty state diagram (pipeline variant) --- */
.empty-state__diagram {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
  justify-content: center;
}
.empty-state__diagram-step {
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--text-secondary);
}
.empty-state__diagram-arrow {
  color: var(--text-tertiary);
  font-size: var(--text-sm);
}

/* --- Sidebar nav (flat, no section labels) --- */
.sidebar__nav { margin-top: var(--space-2); }

/* --- Sidebar toggle-pages button --- */
.sidebar__toggle-pages {
  display: block;
  width: calc(100% - var(--space-3) * 2);
  margin: var(--space-2) var(--space-3) var(--space-1);
  padding: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  background: none;
  border: 1px dashed var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  text-align: center;
  transition: color var(--transition-fast), border-color var(--transition-fast);
}
.sidebar__toggle-pages:hover { color: var(--text-secondary); border-color: var(--text-tertiary); }
.sidebar__toggle-pages:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* --- Bottom navigation (mobile <= 900px) --- */
/* nav > a.bottom-nav__item structure (direct flex children) */
.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-overlay);
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.bottom-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  flex: 1;
  padding: var(--space-2) var(--space-1);
  color: var(--text-tertiary);
  text-decoration: none;
  font-size: 0.625rem;
  font-weight: var(--weight-medium);
  text-align: center;
  transition: color var(--transition-fast);
  min-height: 52px;
}
.bottom-nav__item--active {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  border-radius: var(--radius-sm);
}
.bottom-nav__item:hover { color: var(--text); text-decoration: none; }
.bottom-nav__item span { font-size: 0.625rem; line-height: 1; }

/* --- Integration guide prose (Phase 5) --- */
.integration-guide .guide-content { max-width: 800px; }
.integration-guide .guide-content h1 { font-size: var(--text-2xl); margin-top: var(--space-6); margin-bottom: var(--space-3); letter-spacing: var(--tracking-tight); }
.integration-guide .guide-content h2 { font-size: var(--text-lg); margin-top: var(--space-5); margin-bottom: var(--space-2); letter-spacing: var(--tracking-tight); }
.integration-guide .guide-content h3 { font-size: var(--text-base); margin-top: var(--space-4); margin-bottom: var(--space-2); font-weight: var(--weight-semibold); }
.integration-guide .guide-content p { margin: var(--space-2) 0 var(--space-4); line-height: var(--leading-normal); }
.integration-guide .guide-content ul,
.integration-guide .guide-content ol { margin: var(--space-2) 0 var(--space-4); padding-left: var(--space-6); }
.integration-guide .guide-content li { margin: var(--space-1) 0; }
.integration-guide .guide-content pre { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-md); padding: var(--space-4); overflow-x: auto; font-size: var(--text-sm); margin: var(--space-3) 0; }
.integration-guide .guide-content code { background: var(--surface); padding: 0.15em 0.4em; border-radius: var(--radius-sm); font-size: 0.9em; font-family: var(--font-mono); }
.integration-guide .guide-content pre code { background: none; padding: 0; }
.integration-guide .guide-content table { border-collapse: collapse; margin: var(--space-3) 0; width: 100%; }
.integration-guide .guide-content th,
.integration-guide .guide-content td { border: 1px solid var(--border); padding: var(--space-2) var(--space-3); text-align: left; }
.integration-guide .guide-content th { background: var(--surface); font-weight: var(--weight-semibold); }
.integration-guide .guide-content hr { border: none; border-top: 1px solid var(--border); margin: var(--space-6) 0; }

/* --- Onboarding wizard (Phase 5) --- */

.onboarding-progress { margin-bottom: var(--space-5); }
.onboarding-progress__label { font-size: var(--text-sm); margin-bottom: var(--space-2); }
/* Wizard-specific styles removed — wizard replaced by inline checklist */

/* --- Inbox: responsive card/table switching --- */
.inbox-cards-mobile { display: none; }
.inbox-table-desktop { display: block; }

/* --- Responsive: 900px breakpoint (sidebar → bottom nav) --- */
@media (max-width: 900px) {
  .sidebar { display: none !important; }
  .sidebar-toggle { display: none !important; }
  .bottom-nav { display: flex; }
  .console-tabs-wrap::after { display: block; }
  .app-main { padding-bottom: 60px; }
  .help-pill { bottom: 72px; }
  /* Widget floating card: clear bottom nav (66px) + pill (72px) with spacing */
  .covren-widget-help-panel { bottom: 140px; right: 8px; max-height: min(480px, calc(100vh - 200px)); }
  .update-layout,
  .update-layout:has(.update-layout__rail) { grid-template-columns: 1fr; }
  .update-layout__rail { display: none; }
  .update-layout__tabs { overflow: visible; border-radius: 0; border: none; }
  .task-panel { position: static; }
  .detail-actions-row { flex-direction: column; align-items: stretch; }
  .page-header { padding: var(--space-4) var(--space-4); }
  .inbox-layout .page-header { padding: var(--space-3) 0; }
  .update-layout { padding: var(--space-4); }
  .inbox-cards-mobile { display: block; }
  .inbox-table-desktop { display: none; }
  .connectors-table-desktop { display: none; }
  .connectors-cards-mobile { display: block; }
  .distribution-keys-table-desktop { display: none; }
  .distribution-keys-cards-mobile { display: block; }
  .distribution-events-table-desktop { display: none; }
  .distribution-events-cards-mobile { display: block; }
  .review-card__action-bar { flex-direction: column; align-items: stretch; }
  .review-card__reject-group { flex-wrap: wrap; }
  .review-card__reject-group .review-card__reason.form-input { width: 100%; }
  .content-panel { border: none; border-radius: 0; background: none; padding: var(--space-3) 0; }
  .ds-table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .settings-panel { border: none; border-radius: 0; background: none; }
  .settings-panel__section { padding: var(--space-3) 0; }
  .settings-panel__inline { padding: var(--space-3) 0; }
  .settings-inline-row { flex-wrap: wrap; row-gap: var(--space-3); }
  .settings-inline-row > .form-label { min-width: auto; width: 100%; }
  .provider-picker { grid-template-columns: repeat(2, 1fr); }
  /* FRD 111 R-3/R-4: allow page header actions to wrap at tablet */
  .page-header__actions { flex-shrink: 1; flex-wrap: wrap; width: 100%; justify-content: flex-start; }
  /* FRD 111 R-5: reduce metric card minimum width for tablet */
  .metric-card-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); }
}

@media (max-width: 480px) {
  .provider-picker { grid-template-columns: 1fr; }
}

/* --- Responsive: auth page mobile (FRD 111 R-7) --- */
@media (max-width: 640px) {
  .auth-page { align-items: flex-start; padding-top: var(--space-6); }
  .auth-page::before { width: 400px; height: 400px; top: -10%; }
}

/* --- Sidebar trial badge (FRD 125) --- */
.sidebar__trial-badge {
  padding: var(--space-4);
  margin: var(--space-2) var(--space-3) var(--space-3);
  background: var(--surface-gradient);
  border: 1px solid rgba(210, 153, 34, 0.25);
  border-radius: var(--radius-lg);
}
.sidebar__trial-link { text-decoration: none; display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--space-2); }
.sidebar__trial-label { font-weight: var(--weight-semibold); color: var(--warning, #d29922); font-size: var(--text-sm); text-transform: uppercase; letter-spacing: 0.05em; }
.sidebar__trial-days { color: var(--text-secondary); font-size: var(--text-xs); }
.sidebar__trial-usage { margin-bottom: var(--space-3); }
.sidebar__trial-meter { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); margin-bottom: var(--space-2); }
.sidebar__trial-dim { width: 4.5rem; color: var(--text-secondary); flex-shrink: 0; }
.sidebar__trial-count { white-space: nowrap; font-size: var(--text-xs); color: var(--text-secondary); }
.progress-wrap--sm { height: 5px; flex: 1; }
.sidebar__trial-upgrade { width: 100%; text-align: center; display: block; font-size: var(--text-sm); padding: var(--space-2) var(--space-4); }
.btn-xs { font-size: var(--text-xs); padding: var(--space-1) var(--space-3); }

/* --- Upgrade comparison table (FRD 125) --- */
.upgrade-comparison { margin: var(--space-6) auto; max-width: 560px; text-align: left; }
.upgrade-comparison th:nth-child(2), .upgrade-comparison td:nth-child(2) { text-align: center; color: var(--text-secondary); }
.upgrade-comparison th:nth-child(3), .upgrade-comparison td:nth-child(3) { text-align: center; color: var(--accent); font-weight: var(--weight-medium); }
.upgrade-yes { color: var(--success, #3fb950); }
.upgrade-no { color: var(--text-secondary); }

/* --- Spacing utilities --- */
.mt-1 { margin-top: var(--space-1); }
.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.mt-6 { margin-top: var(--space-6); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-6 { margin-bottom: var(--space-6); }

/* --- Staggered reveal utility --- */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
.stagger-in > * {
  opacity: 0;
  animation: fade-up 0.3s var(--ease-out) forwards;
}
.stagger-in > *:nth-child(1) { animation-delay: 0ms; }
.stagger-in > *:nth-child(2) { animation-delay: 50ms; }
.stagger-in > *:nth-child(3) { animation-delay: 100ms; }
.stagger-in > *:nth-child(4) { animation-delay: 150ms; }
.stagger-in > *:nth-child(5) { animation-delay: 200ms; }
.stagger-in > *:nth-child(n+6) { animation-delay: 250ms; }

/* --- Quick Start stepper (FRD 150) --- */
.qs-stepper { margin-bottom: var(--space-4); }
.qs-stepper__bar { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; margin-bottom: var(--space-3); }
.qs-stepper__fill { height: 100%; background: var(--accent); border-radius: 2px; transition: width var(--duration-normal) var(--ease-default); }
.qs-stepper__steps { display: flex; justify-content: space-between; gap: var(--space-2); }
.step { display: flex; align-items: center; gap: var(--space-1); font-size: var(--text-sm); color: var(--text-secondary); transition: color var(--transition-fast); }
.step__indicator { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 50%; font-size: var(--text-xs); font-weight: var(--weight-semibold); border: 2px solid var(--border); color: var(--text-secondary); transition: all var(--transition-fast); flex-shrink: 0; }
.step--done .step__indicator { background: var(--accent); border-color: var(--accent); color: var(--accent-text); }
.step--active .step__indicator { border-color: var(--accent); color: var(--accent); box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.15); }
.step--active .step__label { color: var(--text-primary); font-weight: var(--weight-medium); }
.step--done .step__label { color: var(--text-secondary); }
.step--pending .step__indicator { border-color: var(--border); color: var(--text-muted); }
.step--pending .step__label { color: var(--text-muted); }
@keyframes qs-pulse { 0%, 100% { box-shadow: 0 0 0 3px rgba(var(--accent-rgb), 0.15); } 50% { box-shadow: 0 0 0 5px rgba(var(--accent-rgb), 0.08); } }
.step--active .step__indicator { animation: qs-pulse 2s ease-in-out infinite; }

/* --- Auth glow animation --- */
@keyframes auth-glow-drift {
  0%, 100% { transform: translate(-50%, -50%) scale(1); }
  50% { transform: translate(-50%, -50%) scale(1.08); }
}

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
  .auth-page::before { animation: none; }
  .auth-card { animation: none; opacity: 1; transform: none; }
  .empty-state,
  .empty-state svg,
  .empty-state .empty-state__icon,
  .sidebar__badge,
  .content-panel,
  .skeleton,
  .step--active .step__indicator { animation: none !important; }
  .btn-primary:active:not(:disabled),
  .btn-secondary:active:not(:disabled),
  .btn-ghost:active:not(:disabled),
  .btn-danger:active:not(:disabled) { transform: none; }
  .draft-rating__star { transition: none; }
  .confidence-bar__fill { transition: none; }
  .evidence-source { transition: none; }
  .btn--loading::after { animation: none; }
}

/* --- Draft quality rating (FRD 155) --- */
.draft-rating {
  display: inline-flex;
  gap: 0.125rem;
  align-items: center;
}
.draft-rating__star {
  cursor: pointer;
  color: var(--text-tertiary);
  font-size: 1.25rem;
  background: none;
  border: none;
  padding: var(--space-1);
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-fast);
  border-radius: var(--radius-sm);
}
.draft-rating__star:hover,
.draft-rating__star:focus-visible {
  color: #f59e0b;
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.draft-rating__star--active { color: #f59e0b; }
.draft-rating__label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-right: var(--space-2);
}
.draft-rating__display {
  display: inline-flex;
  gap: 0.125rem;
  color: #f59e0b;
  font-size: 1rem;
}

/* --- Regeneration modal (FRD 155) --- */
.regen-modal {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  background: var(--surface);
  color: var(--text);
  padding: var(--space-6);
  max-width: 440px;
  width: calc(100vw - var(--space-8));
  box-shadow: var(--shadow-xl);
}
.regen-modal::backdrop {
  background: rgba(0, 0, 0, 0.5);
}
.regen-modal__form { display: flex; flex-direction: column; gap: var(--space-4); }
.regen-modal__title {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-tight);
  margin: 0;
}
.regen-modal__reasons {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.regen-modal__reason {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-height: 44px;
  font-size: var(--text-sm);
  cursor: pointer;
  padding: var(--space-1) 0;
}
.regen-modal__reason input[type="checkbox"] { accent-color: var(--accent); }
.regen-modal__guidance {
  resize: vertical;
  min-height: 60px;
}
.regen-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
}

/* Expandable section (FRD 152) */
.expandable-section {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: var(--space-2);
}
.expandable-section summary {
  cursor: pointer;
  padding: var(--space-2) var(--space-3);
  font-weight: 500;
  user-select: none;
}
.expandable-section summary:hover {
  background: color-mix(in srgb, var(--surface) 90%, var(--text-primary) 10%);
}
.expandable-section[open] summary {
  border-bottom: 1px solid var(--border);
}
.expandable-section__body {
  padding: var(--space-3);
}

/* ── Claims (FRD 200) ─────────────────────────────────────────── */
.claim-card {
  padding: var(--space-4);
  background: var(--surface-gradient);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin-bottom: var(--space-3);
  transition: var(--transition-fast);
}
.claim-card:hover {
  box-shadow: var(--shadow-sm);
}
.claim-card--breaking {
  border-left: 3px solid var(--color-error);
}
.claim-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
  flex-wrap: wrap;
}
.claim-card__statement {
  font-size: var(--text-base);
  font-weight: 500;
  line-height: var(--leading-normal);
  margin-bottom: var(--space-2);
}
.claim-card__description {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}
.claim-card__diff {
  font-size: var(--text-sm);
  padding: var(--space-2);
  background: var(--bg-secondary);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-2);
}
.claim-card__before { color: var(--color-error); }
.claim-card__after { color: var(--color-success); }
.claim-card__audiences {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
}
.claim-card__migration,
.claim-card__evidence {
  font-size: var(--text-sm);
  margin-top: var(--space-2);
}
.claim-card__evidence ul {
  list-style: none;
  padding: 0;
  margin: var(--space-2) 0 0 0;
}
.claim-card__evidence li {
  padding: var(--space-1) 0;
  border-bottom: 1px solid var(--border);
}
.claims-summary {
  color: var(--text-secondary);
  font-weight: 500;
}

/* FRD 201: Claim status variants */
.claim-card--greenlit { border-left: 3px solid var(--color-success); }
.claim-card--retracted { opacity: var(--opacity-muted); border-left: 3px solid var(--border); }
/* FRD 220: Claim card state icons */
.claim-card__state-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  font-size: var(--text-sm);
  border-radius: var(--radius-full);
  flex-shrink: 0;
}
.claim-card--greenlit .claim-card__state-icon { color: var(--color-success); }
.claim-card--retracted .claim-card__state-icon,
.claim-card--superseded .claim-card__state-icon { color: var(--text-tertiary); }
.claim-card--needs_confirmation .claim-card__state-icon { color: var(--color-warning, #f59e0b); }
.claim-card--draft .claim-card__state-icon { color: var(--text-tertiary); }

/* FRD 220: Claim card meta row */
.claim-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  margin-top: var(--space-2);
  font-size: var(--text-sm);
}
.claim-card__meta-label {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-secondary);
  margin-right: var(--space-1);
}
.claim-card__team,
.claim-card__workflow {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}
.claim-card__change-ref {
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}
.claim-card__change-ref a { text-decoration: none; }
.claim-card__change-ref a:hover { text-decoration: underline; }

/* FRD 220: Compact claim card variant */
.claim-card--compact {
  padding: var(--space-3);
  margin-bottom: var(--space-2);
}
.claim-card--compact .claim-card__statement {
  font-size: var(--text-sm);
  margin-bottom: var(--space-1);
}

/* FRD 220: Claim summary bar */
.claim-summary-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--surface-gradient);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-4);
}
.claim-summary-bar .claims-progress-bar { flex: 1; max-width: 240px; }
.claim-summary-bar__text {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: 500;
  white-space: nowrap;
}

.claim-card__status { margin-left: auto; }

/* FRD 201: Claim action buttons */
.claim-card__actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.claim-card__action-form { display: inline-flex; align-items: center; gap: var(--space-2); }
.claim-card__retract-form,
.claim-card__feedback-form {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

/* FRD 201: Claims approval bar */
.claims-approval-bar {
  background: var(--surface-gradient);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}
.claims-approval-bar__info {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}
.claims-approval-bar__actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

/* FRD 201: Claims progress bar */
.claims-progress-bar {
  height: 8px;
  background: var(--border);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.claims-progress-bar__fill {
  height: 100%;
  background: var(--color-success);
  border-radius: var(--radius-full);
  transition: width var(--duration-normal) var(--ease-spring);
}
.claims-progress-bar--sm {
  height: 4px;
}

@media (prefers-reduced-motion: reduce) {
  .claim-card { transition: none; }
  .claims-progress-bar__fill { transition: none; }
  .claim-card--compact { transition: none; }
}

/* --- Inbox claims summary + expansion (FRD 220) --- */
.inbox-card__claims {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin: var(--space-1) 0 0 0;
  cursor: pointer;
  list-style: none;
}
.inbox-card__claims::-webkit-details-marker { display: none; }
.inbox-card__claims::marker { content: ""; }
.inbox-card__claims::before {
  content: "▸ ";
  font-size: var(--text-xs);
  transition: transform var(--duration-fast) ease;
  display: inline-block;
}
.inbox-card__claims-expand[open] > .inbox-card__claims::before {
  content: "▾ ";
}
.inbox-card__claims--breaking {
  color: var(--color-error, #ef4444);
  font-weight: 600;
}
.inbox-card__claims-expand {
  margin-top: var(--space-1);
}
.inbox-card__claims-list {
  padding: var(--space-2) 0 0 var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.inbox-card__claim-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}
.inbox-card__claim-statement {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* --- Routing rules (FRD 203) --- */
.routing-rule-card {
  padding: var(--space-4);
  background: var(--surface-gradient);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-4);
}
.routing-rule-card--disabled {
  opacity: var(--opacity-muted);
}
.routing-rule-card__conditions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  font-size: var(--text-sm);
}
.routing-rule-card__action {
  font-weight: 500;
  white-space: nowrap;
}
.routing-rule-card__priority {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  min-width: 2rem;
  text-align: center;
}
.routing-rule-card__actions .btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
.claim-card__assignments {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}

/* --- Distribution (FRD 205) --- */
.channel-card {
  padding: var(--space-4);
  background: var(--surface-gradient);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  margin-bottom: var(--space-3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  transition: var(--transition-fast);
}
.channel-card:hover {
  box-shadow: var(--shadow-accent);
}
.channel-card--disabled {
  opacity: var(--opacity-muted);
}
.channel-card__info {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  flex: 1;
  min-width: 0;
}
.channel-card__actions {
  display: flex;
  gap: var(--space-2);
  flex-shrink: 0;
}
.distribution-status {
  margin-top: var(--space-4);
}
.distribution-status__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border);
  font-size: var(--text-sm);
}
.distribution-status__item:last-child {
  border-bottom: none;
}
@media (prefers-reduced-motion: reduce) {
  .channel-card { transition: none; }
}

/* API keys (FRD 206) */
.api-key-reveal {
  padding: var(--space-3) var(--space-4);
  background: var(--bg-secondary);
  border-radius: var(--radius-md);
  font-family: monospace;
  font-size: var(--text-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  border: 2px solid var(--accent);
}

/* Change groups (FRD 209) */
.correlation-banner {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    background: color-mix(in srgb, var(--accent) 8%, transparent);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
    margin-bottom: var(--space-3);
}
.correlation-banner a {
    color: var(--accent);
    text-decoration: none;
}
.correlation-banner a:hover {
    text-decoration: underline;
}
.correlation-banner a:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}
.group-events-list {
    list-style: none;
    padding: 0;
    margin: 0;
}
.group-event {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border);
}
.group-event__source-icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    opacity: var(--opacity-muted);
}
.group-event__summary {
    flex: 1;
    font-size: var(--text-sm);
}
.group-event__actions {
    flex-shrink: 0;
}
.cross-ref-link {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2);
    font-size: var(--text-xs);
    color: var(--text-secondary);
}
.dedup-suggestion {
    padding: var(--space-3) var(--space-4);
    background: color-mix(in srgb, var(--warning) 10%, transparent);
    border-left: 3px solid var(--warning);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-3);
}

@media (prefers-reduced-motion: reduce) {
    .correlation-banner,
    .group-event,
    .cross-ref-link,
    .dedup-suggestion {
        transition: none;
    }
}

/* ══════════════════════════════════════════════════════════════════
   Plan tiers, integrations, feature dependencies (FRD 210)
   ══════════════════════════════════════════════════════════════════ */
.plan-tier-card {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
    transition: var(--transition-fast);
}
.plan-tier-card:hover {
    box-shadow: var(--shadow-md);
}
.plan-tier-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-3);
}
.plan-tier-card__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-base);
}
.entitlement-grid {
    display: grid;
    grid-template-columns: 1fr auto auto;
    gap: var(--space-2) var(--space-3);
    align-items: center;
    font-size: var(--text-sm);
}
.entitlement-grid__header {
    font-weight: var(--weight-medium);
    color: var(--text-secondary);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: var(--tracking-tight);
}
.integration-card {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
    transition: var(--transition-fast);
}
.integration-card:hover {
    box-shadow: var(--shadow-md);
}
.integration-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-2);
}
.integration-card__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-base);
}
.dependency-graph {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}
.dependency-graph__row {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    font-size: var(--text-sm);
}
.dependency-graph__arrow {
    color: var(--text-secondary);
    flex-shrink: 0;
}
.impact-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}
.impact-summary__stat {
    text-align: center;
    padding: var(--space-3);
    background: var(--surface-gradient);
    border-radius: var(--radius-md);
    border: 1px solid var(--border);
}
.impact-summary__number {
    font-size: var(--text-2xl);
    font-weight: var(--weight-semibold);
    color: var(--accent);
}
.impact-summary__label {
    font-size: var(--text-xs);
    color: var(--text-secondary);
}

@media (prefers-reduced-motion: reduce) {
    .plan-tier-card,
    .integration-card,
    .dependency-graph__row,
    .region-card {
        transition: none;
    }
}

/* ── FRD 211: Regions ──────────────────────────────────────────────── */
.region-card {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
    transition: var(--transition-fast);
}
.region-card:hover {
    box-shadow: var(--shadow-accent);
}
.region-card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-2);
}
.region-card__name {
    font-weight: var(--weight-semibold);
    font-size: var(--text-base);
}
.region-card__compliance {
    display: flex;
    gap: var(--space-2);
    flex-wrap: wrap;
}
.compliance-tag {
    display: inline-block;
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: var(--weight-medium);
    background: color-mix(in srgb, var(--accent) 15%, transparent);
    color: var(--text-primary);
}
.availability-timeline {
    display: inline-flex;
    gap: var(--space-1);
    align-items: center;
    font-size: var(--text-xs);
    color: var(--text-secondary);
}
.availability-timeline__date {
    font-weight: var(--weight-medium);
    color: var(--text-primary);
}

/* Workflows (FRD 212) */
.workflow-stepper {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    padding: var(--space-4) 0;
    overflow-x: auto;
}
.workflow-step {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-1);
    min-width: 100px;
    text-align: center;
    position: relative;
}
.workflow-step::after {
    content: "";
    position: absolute;
    top: 14px;
    left: calc(50% + 16px);
    width: calc(100% - 32px);
    height: 2px;
    background: var(--border);
}
.workflow-step:last-child::after {
    display: none;
}
.workflow-step--completed::after {
    background: var(--accent);
}
.workflow-step__indicator {
    width: 28px;
    height: 28px;
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-sm);
    font-weight: 500;
    position: relative;
    z-index: 1;
}
.workflow-step--completed .workflow-step__indicator {
    background: var(--accent);
    color: var(--color-white);
}
.workflow-step--active .workflow-step__indicator {
    border: 2px solid var(--accent);
    color: var(--accent);
    background: var(--bg-primary);
}
.workflow-step--pending .workflow-step__indicator {
    border: 2px solid var(--border);
    color: var(--text-secondary);
    background: var(--bg-primary);
}
.workflow-step__label {
    font-size: var(--text-xs);
    font-weight: 500;
    color: var(--text-primary);
}
.workflow-step__meta {
    font-size: var(--text-xs);
    color: var(--text-secondary);
}
.workflow-progress {
    padding: var(--space-4);
    background: var(--surface-gradient);
    border-radius: var(--radius-md);
    margin-bottom: var(--space-4);
}
.workflow-progress__title {
    font-size: var(--text-sm);
    font-weight: 500;
    margin-bottom: var(--space-2);
}
/* Stage editor */
.stage-editor {
    list-style: none;
    padding: 0;
    margin: 0;
}
.stage-editor__item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-bottom: 1px solid var(--border);
}
.stage-editor__order {
    width: 28px;
    height: 28px;
    border-radius: var(--radius-full);
    border: 2px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-sm);
    font-weight: 500;
    flex-shrink: 0;
}
.stage-editor__name {
    flex: 1;
    font-weight: 500;
}
.stage-editor__role {
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

/* Workflow card layout utilities (FRD 212 review) */
.workflow-card__header { display: flex; align-items: center; gap: var(--space-3); justify-content: space-between; }
.workflow-card__actions { display: flex; gap: var(--space-2); }
.workflow-card__section { margin-top: var(--space-3); border-top: 1px solid var(--border); padding-top: var(--space-3); }
.workflow-form-grid { display: grid; gap: var(--space-3); }
.stage-add-row { display: flex; gap: var(--space-2); align-items: end; flex-wrap: wrap; margin-top: var(--space-3); }

/* Focus-visible for workflow interactive elements (FRD 212 review) */
.workflow-step__indicator:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.stage-editor__item:focus-visible { outline: 2px solid var(--accent); outline-offset: -2px; }

/* FRD 220: Compact workflow progress (single-line for cards) */
.workflow-progress--compact {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-xs);
    color: var(--text-secondary);
    padding: var(--space-1) var(--space-2);
    background: var(--bg-secondary);
    border-radius: var(--radius-sm);
    white-space: nowrap;
}
.workflow-progress__compact-indicator {
    font-size: var(--text-xs);
    line-height: 1;
}
.workflow-progress__compact-text {
    font-weight: 500;
}

@media (prefers-reduced-motion: reduce) {
    .workflow-stepper,
    .workflow-step,
    .workflow-progress,
    .workflow-progress--compact,
    .stage-editor__item {
        transition: none;
        animation: none;
    }
}

/* ============================================================
   Teams (FRD 213)
   ============================================================ */
.team-card {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-4);
    transition: var(--transition-fast);
}
.team-card:hover { box-shadow: var(--shadow-md); }
.team-card__header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: var(--space-3);
    margin-bottom: var(--space-3);
}
.team-card__stats { font-size: var(--text-sm); color: var(--text-secondary); white-space: nowrap; }

.member-list { list-style: none; padding: 0; margin: 0; }
.member-list__item {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--border);
    flex-wrap: wrap;
    min-height: 44px;
}
.member-list__item:last-child { border-bottom: none; }
.member-list__name { flex: 1; font-size: var(--text-sm); font-weight: 500; min-width: 120px; }
.member-list__role {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
}
.member-list__role--lead { color: var(--accent); background: rgba(var(--accent-rgb), 0.1); }

/* FRD 220: Team queue page layout */
.team-queue-layout {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: var(--space-5);
}
.team-queue-layout__sidebar {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    height: fit-content;
    position: sticky;
    top: var(--space-4);
}
.team-workload-stats {
    display: flex;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
}
.team-workload__stat-value { font-size: var(--text-xl); font-weight: 700; display: block; }
.team-workload__stat-label { font-size: var(--text-xs); color: var(--text-secondary); }
.team-workload__members { list-style: none; padding: 0; margin: 0; }
.team-workload__member {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-2) 0;
    border-bottom: 1px solid var(--border);
    font-size: var(--text-sm);
}
.team-workload__member:last-child { border-bottom: none; }
@media (max-width: 900px) {
    .team-queue-layout { grid-template-columns: 1fr; }
    .team-queue-layout__sidebar { position: static; }
}

.team-queue-item {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
    min-height: 44px;
    transition: var(--transition-fast);
}
.team-queue-item:hover { box-shadow: var(--shadow-sm); }
.team-queue-item__header {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-2);
}
.team-queue-item__body { margin-bottom: var(--space-2); }
.team-queue-item__title {
    font-weight: 500;
    font-size: var(--text-sm);
    text-decoration: none;
}
.team-queue-item__title:hover { text-decoration: underline; }
.team-queue-item__actions { display: flex; gap: var(--space-2); }
.team-queue-item__type {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    background: var(--bg-secondary);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    white-space: nowrap;
}
.team-queue-item__summary { flex: 1; font-size: var(--text-sm); min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.team-queue-item__assignee { font-size: var(--text-sm); color: var(--text-secondary); white-space: nowrap; }
.team-queue-item__actions { white-space: nowrap; }
.team-queue-item__actions .btn { min-height: 44px; }

.team-workload {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
    margin-bottom: var(--space-5);
}
.team-workload__stat {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    text-align: center;
    min-width: 100px;
}
.team-workload__count { font-size: var(--text-xl); font-weight: 700; color: var(--text-primary); }
.team-workload__label { font-size: var(--text-xs); color: var(--text-secondary); margin-top: var(--space-1); }

.badge--team {
    font-size: var(--text-xs);
    background: rgba(var(--accent-rgb), 0.1);
    color: var(--accent);
    padding: var(--space-1) var(--space-2);
    border-radius: var(--radius-sm);
    white-space: nowrap;
}

/* Touch targets for team actions (WCAG 2.5.5) */
.team-card .btn { min-height: 44px; }
.member-list__item .btn { min-height: 44px; }

/* Focus-visible for team interactive elements */
.team-card .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.member-list__item .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.team-queue-item .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.team-card a:focus-visible,
.team-queue-item a:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

@media (prefers-reduced-motion: reduce) {
    .team-card,
    .team-workload__stat,
    .team-queue-item {
        transition: none;
    }
}

/* FRD 220: Coverage & Remediation metrics */
.coverage-metrics {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: var(--space-4);
    margin-bottom: var(--space-4);
}
.coverage-metric-card {
    background: var(--surface-gradient);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    text-align: center;
    transition: var(--transition-fast);
}
.coverage-metric-card:hover { box-shadow: var(--shadow-sm); }
.coverage-metric-card--warning {
    border-color: var(--color-warning, #e0a800);
    background: rgba(224, 168, 0, 0.05);
}
.coverage-metric-card__value {
    display: block;
    font-size: var(--text-xl);
    font-weight: 700;
    color: var(--text-primary);
}
.coverage-metric-card__label {
    display: block;
    font-size: var(--text-xs);
    color: var(--text-secondary);
    margin-top: var(--space-1);
}

/* Focus-visible for coverage/remediation interactive elements */
.coverage-metric-card .btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* First-run pulse animation (FRD 222-06) */
.first-run-pulse {
    animation: first-run-ring 2s ease-in-out infinite;
}
@keyframes first-run-ring {
    0%, 100% { box-shadow: 0 0 0 0 rgba(var(--accent-rgb), 0.4); }
    50% { box-shadow: 0 0 0 6px rgba(var(--accent-rgb), 0); }
}
@media (prefers-reduced-motion: reduce) {
    .first-run-pulse { animation: none; }
}

@media (prefers-reduced-motion: reduce) {
    .coverage-metric-card {
        transition: none;
    }
}
