/* CFC Legislative Monitor — Web App Styles */
/* Brand colors from email_sender.py */

/*
 * Z-INDEX LAYER MAP
 * =================
 * Canonical reference for all z-index values across CSS files.
 * Before adding a new z-index, check this map to avoid conflicts.
 *
 *   1-10      Progress nodes, inline overlays (bill-detail.css)
 *   50        Relative-position loading overlays (within containers)
 *   100       Sticky navigation (.public-nav in public.css, .sticky-action-bar in style.css)
 *   200       Dropdown menus, share panels (.leg-share-panel in public.css)
 *   500       Address suggestion dropdowns, help tooltips
 *   900       Bottom action bars (.bottom-action-bar in bill-detail.css)
 *   1000      Bottom sheets (.bottom-sheet in bill-detail.css), modal backdrops (.modal)
 *   1040      Modal containers (.modal)
 *   1050      Modal content (.modal-content)
 *   1055      FAB button (.fab)
 *   1058      Ask Watchdog FAB (.ask-fab)
 *   1060      Ask Watchdog panel (.ask-panel)
 *   1070      Toast notifications (.toast-container)
 *   2100      Search autocomplete (.search-ac-dropdown) — above everything
 *   9000      Public Ask Watchdog FAB (.pa-fab in public-ask.css)
 *   9001      Public Ask Watchdog panel (.pa-panel in public-ask.css)
 *   9999      Full-page loading overlays (#scorecardLoadingOverlay), toasts (public.css)
 *   10000     Guided tour spotlight (.wt-spotlight in walkthrough.js)
 *   10001     Guided tour tooltip (.wt-tooltip in walkthrough.js)
 */

/* ==========================================================================
   ICON CONVENTIONS (VIS-06)
   v10.90: Card headers moved from emoji to inline Lucide SVG via the
   `icon()` Jinja macro in templates/_icons.html. Emoji are reserved for
   specific semantic spots (status cues, celebrations) where personality
   is appropriate. Headings use SVG for a consistent, professional look.

   CARD HEADERS (dashboard, bill detail, mailings, admin):
     - Inline SVG via `{% from "_icons.html" import icon %}` + `{{ icon('name', 18) }}`
     - Wrapped in `.heading-icon` span for vertical alignment + color
     - Fallback (no icon): plain text heading, no prefix
     - Drag handle: ☰ (&#9776;)
     - Collapse toggle: ▼ (&#9660;) when open

   ACTION BUTTONS:
     - Inline SVG icons via the same `icon()` macro (message-circle, clipboard, etc.)

   STATUS INDICATORS (CSS ::before in this file, lines ~639-646):
     - ✓ completed/approved, ▶ running, ○ pending, ✗ failed
     - ✎ draft, ⏳ pending-approval, ★ published
     - Unicode symbols here are intentional — they carry semantic weight
       and are defined in a small enumerated set.

   NAVIGATION / COLLAPSE ARROWS:
     - Dropdown menus: ▾ (&#9662;) — smaller triangle
     - Card collapse toggle: ▼ (&#9660;) — standard triangle
     - Collapsed/expand indicator: ▶ (&#9654;) — rightward triangle
     - Sort arrows in tables: ▲ (&#9650;) asc / ▼ (&#9660;) desc

   CLOSE / DISMISS:
     - Modal close: &times; (×)
     - Tag remove: &times; (×)

   MISC:
     - Keeper star: ★ (CSS gold)
     - Settings gear: ⚙ (&#9881;)
     - Empty state checkmark: ✓
     - View all arrows: → (&rarr;)
   ========================================================================== */

/* Inline icon inside a heading. Small, navy, vertically centered.
   Used across dashboard / mailings / admin card headers (v10.90). */
.heading-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    vertical-align: -3px;
    margin-right: 8px;
    color: var(--cfc-navy);
    flex-shrink: 0;
}
.heading-icon svg { display: block; }
h1 .heading-icon, h2 .heading-icon { vertical-align: -4px; }
h4 .heading-icon, h5 .heading-icon, h6 .heading-icon { vertical-align: -2px; }
/* Variant for danger-zone / warning headings */
.heading-icon.heading-icon-danger { color: var(--cfc-red); }

/* ══════════════════════════════════════════════════════════════════════
   DESIGN TOKENS moved to variables.css (v10.90 Sprint 1.1).
   Z-INDEX SCALE moved to z-index.css (v10.90 Sprint 2.1).
   Both files load BEFORE this one via base.html / base_public.html /
   base_mobile.html, so every var(--token) in this file resolves.
   ══════════════════════════════════════════════════════════════════════ */

/* Screen-reader only utility (accessibility) */
.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;
}

/* Skip Link (accessibility) */
.skip-link {
    position: absolute;
    top: -100px;
    left: 16px;
    z-index: var(--z-tour-spotlight);
    background: var(--cfc-gold);
    color: var(--dark-navy);
    padding: 10px 20px;
    border-radius: 0 0 6px 6px;
    font-weight: 700;
    font-size: 14px;
    text-decoration: none;
    transition: top 0.2s;
}
.skip-link:focus {
    top: 0;
    outline: 3px solid var(--dark-navy);
    outline-offset: 2px;
}

/* ── Global Focus Indicators (R2 — WCAG 2.1 Level A) ──────────────── */
/* Visible focus ring for keyboard users; hidden for mouse clicks.     */
:focus-visible {
    outline: 2px solid var(--cfc-blue);
    outline-offset: 2px;
    border-radius: var(--radius-sm);
}
/* Suppress default focus ring for mouse users */
:focus:not(:focus-visible) {
    outline: none;
}
/* High-contrast focus on dark backgrounds (navbar, footer, buttons) */
.navbar :focus-visible,
.footer :focus-visible,
.btn:focus-visible,
.btn-primary:focus-visible {
    outline-color: var(--cfc-gold);
}
/* v10.90 Sprint 1.4 — gold button needs navy outline (gold-on-gold is invisible) */
.btn-gold:focus-visible {
    outline-color: var(--cfc-navy);
    outline-width: 3px;
}
/* Dark mode focus ring */
[data-theme="dark"] :focus-visible {
    outline-color: var(--cfc-blue);
}

/* Reset & Base */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: var(--font-sans);
    background: var(--bg-warm);
    color: var(--dark-navy);
    line-height: 1.6;
    min-height: 100vh;
}

a {
    color: var(--cfc-blue);
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
}

/* Layout */
.app-container {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.main-content {
    flex: 1;
    max-width: 1000px;
    margin: 0 auto;
    padding: var(--spacing-lg) var(--spacing-md);
    width: 100%;
}

/* Navigation */
.navbar {
    background: linear-gradient(135deg, var(--dark-navy) 0%, var(--cfc-blue) 100%);
    padding: 0 var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    min-height: 60px;
    position: relative;
}

.navbar-brand {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 8px 0;
}

.navbar-brand img {
    height: 54px;
    width: auto;
}

.brand-text {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.brand-name {
    color: white;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: 2.5px;
    line-height: 1;
}

.brand-subtitle {
    color: rgba(255, 255, 255, 0.7);
    font-size: 12px;
    font-style: italic;
    font-weight: 400;
    letter-spacing: 0.3px;
    line-height: 1;
}

.navbar-links {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
    padding: 4px 0;
}

.navbar-links a {
    color: rgba(255,255,255,0.85);
    padding: 8px 14px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    transition: background 0.15s;
}
.navbar-links a:hover {
    background: rgba(255,255,255,0.12);
    text-decoration: none;
    color: white;
}
.navbar-links a.active {
    background: rgba(255,255,255,0.18);
    color: white;
}

/* Capitol nav dropdown */
.nav-dropdown {
    position: relative;
}
.nav-dropdown-toggle {
    background: none;
    border: none;
    cursor: pointer;
    color: rgba(255,255,255,0.85);
    padding: 8px 14px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    font-family: inherit;
    transition: background 0.15s;
    display: flex;
    align-items: center;
    gap: 4px;
    min-height: 44px;
    white-space: nowrap;
}
.nav-dropdown-toggle:hover,
.nav-dropdown.open .nav-dropdown-toggle {
    background: rgba(255,255,255,0.12);
    color: white;
}
.nav-dropdown-toggle.active {
    background: rgba(255,255,255,0.18);
    color: white;
}
.nav-dropdown-menu {
    display: none;
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    background: white;
    border-radius: 8px;
    box-shadow: var(--shadow-md);
    min-width: 190px;
    z-index: var(--z-autocomplete);
    padding: 4px 0;
    border: 1px solid var(--light-border);
}
.nav-dropdown.open .nav-dropdown-menu {
    display: block;
}
.nav-dropdown-menu a {
    display: flex;
    align-items: center;
    padding: 10px 16px;
    min-height: 44px;
    color: var(--text-primary) !important;
    font-size: 13px;
    font-weight: 500;
    transition: background 0.12s;
    background: none !important;
    white-space: nowrap;
}
.nav-dropdown-menu a:hover {
    background: var(--bg-hover) !important;
    color: var(--dark-navy) !important;
    text-decoration: none;
}
.nav-dropdown-menu a.active {
    background: var(--tint-info-bg) !important;
    color: var(--cfc-blue) !important;
    font-weight: 600;
}
.nav-dropdown-menu hr {
    border: none;
    border-top: 1px solid var(--light-border);
    margin: 4px 0;
}

/* Nav badge — red pill for pending approval counts */
.nav-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--alert-red);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    border-radius: 9px;
    line-height: 1;
    vertical-align: middle;
    margin-left: 3px;
}

.gold-bar {
    height: 4px;
    background: linear-gradient(90deg, var(--cfc-gold), var(--cfc-blue), var(--cfc-gold));
}

/* Cards
   v10.90 Sprint 4.2 — unified card system.
   .card-surface is the minimal visual primitive (background + border +
   radius + shadow). Use it on any panel that should look like a card but
   needs its own padding/margin/grid behavior. .card extends it with the
   default padding and margin-bottom for document-flow usage. */
.card-surface {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-border);
    box-shadow: var(--shadow-sm);
}
.card {
    background: var(--bg-card);
    border-radius: var(--radius-lg);
    border: 1px solid var(--light-border);
    padding: var(--spacing-lg);
    margin-bottom: var(--spacing-md);
    box-shadow: var(--shadow-sm);
}

.card-header {
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--dark-navy);
    margin-bottom: var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 3px solid var(--cfc-gold);
}

.card-table { padding: 0; overflow: hidden; }

/* Modal panels — shared dark-mode-safe modal content wrapper */
.lib-modal-panel {
    background: white; border-radius: 12px; box-shadow: 0 20px 60px rgba(0,0,0,0.3);
    display: flex; flex-direction: column;
}
[data-theme="dark"] .lib-modal-panel { background: #1a1a2e; color: #e2e8f0; }
[data-theme="dark"] .lib-modal-panel div[style*="border-top"],
[data-theme="dark"] .lib-modal-panel div[style*="border-bottom"] { border-color: #2d2d45 !important; }

/* ═══════════════════════════════════════════════════════
   Library page — migrated from inline <style> + new classes
   ═══════════════════════════════════════════════════════ */

/* Page-level overflow containment */
.main-content.wide { overflow-x: hidden; }

/* Resource type badges */
.resource-type-badge {
    display: inline-block; padding: 2px 8px; border-radius: 4px;
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px;
}
.resource-type-stats { background: #dbeafe; color: #1e40af; }
.resource-type-quotes { background: #fef3c7; color: #92400e; }
.resource-type-case-law { background: #e0e7ff; color: #3730a3; }
.resource-type-org-stance { background: #d1fae5; color: var(--success-green); }
.resource-type-news { background: #f3f4f6; color: #374151; }
.resource-type-testimony { background: #fde8e8; color: var(--alert-red); }
.resource-type-research { background: #ede9fe; color: #5b21b6; }
.resource-type-fact-sheet { background: #ccfbf1; color: #0f766e; }
.resource-type-opposition { background: #fce7f3; color: #9d174d; }
.resource-type-amendment { background: #fee2e2; color: #991b1b; }
.resource-type-fiscal { background: #ecfccb; color: #3f6212; }
.resource-type-other { background: #f3f4f6; color: var(--muted-gray); }
th a { color: inherit; }
th a:hover { text-decoration: none; color: var(--cfc-blue); }

/* Library resource actions (hover-reveal + keyboard) */
tr:hover .lib-row-actions,
tr:focus-within .lib-row-actions { opacity: 1 !important; }
.lib-resource-edit-form { padding: 12px 16px; background: var(--bg-warm); border: 1px solid var(--light-border); border-top: none; }
[data-theme="dark"] .lib-resource-edit-form { background: #1a1a2e; border-color: #2d2d45; }

/* Library table — prevent horizontal overflow */
.lib-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.lib-table { width: 100%; table-layout: fixed; border-collapse: collapse; }
.lib-table th, .lib-table td { overflow: hidden; text-overflow: ellipsis; }
.lib-col-star    { width: 32px; }
.lib-col-status  { width: 85px; }
.lib-col-item    { /* flexible — takes remaining space */ }
.lib-col-cat     { width: 105px; }
.lib-col-bill    { width: 95px; }
.lib-col-type    { width: 165px; }
.lib-col-date    { width: 115px; }
.lib-col-actions { width: 90px; }

/* Letter tab — dedicated column widths */
.lib-col-lstatus  { width: 120px; }
.lib-col-lactions { width: 155px; }

/* Letter status badges */
.lib-letter-status {
    display: inline-block; padding: 3px 8px; border-radius: 10px;
    font-size: 11px; font-weight: 600; white-space: nowrap; letter-spacing: 0.02em;
}
.lib-letter-status-published     { background: #d1fae5; color: #065f46; }
.lib-letter-status-approved      { background: #dbeafe; color: #1e40af; }
.lib-letter-status-pending_approval { background: #fef3c7; color: #92400e; }
.lib-letter-status-under_review  { background: #ede9fe; color: #5b21b6; }
.lib-letter-status-reviewed      { background: #d1fae5; color: #166534; }
.lib-letter-status-draft         { background: #f3f4f6; color: #6b7280; }
[data-theme="dark"] .lib-letter-status-published     { background: #064e3b; color: #6ee7b7; }
[data-theme="dark"] .lib-letter-status-approved      { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .lib-letter-status-pending_approval { background: #451a03; color: #fcd34d; }
[data-theme="dark"] .lib-letter-status-under_review  { background: #2e1065; color: #c4b5fd; }
[data-theme="dark"] .lib-letter-status-reviewed      { background: #064e3b; color: #86efac; }
[data-theme="dark"] .lib-letter-status-draft         { background: #374151; color: #9ca3af; }

/* Truncate item cell content */
.lib-item-title {
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
    max-width: 100%; display: block;
}
.lib-item-sub {
    font-size: 12px; color: var(--muted-gray); margin-top: 1px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.lib-letter-meta { margin-top: 2px; font-size: 12px; color: var(--muted-gray); line-height: 1.5; }
.lib-letter-meta span { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Library tab bar */
.lib-tab-bar {
    display: flex; align-items: flex-end; justify-content: space-between;
    margin-bottom: 16px; border-bottom: 2px solid var(--light-border); gap: 8px;
}
.lib-tabs { display: flex; gap: 0; overflow-x: auto; flex-shrink: 1; min-width: 0; }
.lib-tab {
    padding: 10px 20px; font-size: 14px; font-weight: 500; text-decoration: none;
    color: var(--muted-gray); border-bottom: 3px solid transparent;
    margin-bottom: -2px; white-space: nowrap; transition: all 0.15s;
}
.lib-tab-active { font-weight: 700; color: var(--cfc-blue); border-bottom-color: var(--cfc-blue); }

/* Library action buttons */
.lib-actions { display: flex; gap: 6px; padding-bottom: 8px; flex-shrink: 0; }
.lib-action-btn {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 600;
    color: var(--cfc-blue); background: white; border: 1.5px solid var(--light-border);
    cursor: pointer; text-decoration: none; white-space: nowrap; transition: all 0.15s;
    line-height: 1.2;
}
.lib-action-btn:hover { border-color: var(--cfc-blue); background: #f0f6ff; color: var(--cfc-blue); }
.lib-action-btn svg { flex-shrink: 0; }
[data-theme="dark"] .lib-action-btn { background: #1a1a2e; color: #93c5fd; border-color: #2d2d45; }
[data-theme="dark"] .lib-action-btn:hover { background: #1e3a5f; border-color: #93c5fd; }

/* ── Content/category/article badge classes (replaces inline styles) ── */
.lib-badge-status {
    display: inline-block; font-size: 10px; padding: 2px 6px; border-radius: 3px;
    font-weight: 600; white-space: nowrap;
}
.lib-badge-status-published     { background: #d1fae5; color: var(--success-green); }
.lib-badge-status-approved      { background: #dbeafe; color: #1e40af; }
.lib-badge-status-reviewed      { background: #fef3c7; color: #92400e; }
.lib-badge-status-under_review  { background: #ede9fe; color: #5b21b6; }
.lib-badge-status-pending_approval { background: #fef3c7; color: #92400e; }
.lib-badge-status-draft         { background: #f3f4f6; color: var(--muted-gray); }
[data-theme="dark"] .lib-badge-status-published     { background: #064e3b; color: #6ee7b7; }
[data-theme="dark"] .lib-badge-status-approved      { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .lib-badge-status-reviewed      { background: #451a03; color: #fcd34d; }
[data-theme="dark"] .lib-badge-status-under_review  { background: #2e1065; color: #c4b5fd; }
[data-theme="dark"] .lib-badge-status-pending_approval { background: #451a03; color: #fcd34d; }
[data-theme="dark"] .lib-badge-status-draft         { background: #374151; color: #9ca3af; }

.lib-badge-cat {
    display: inline-block; font-size: 11px; font-weight: 600; padding: 2px 8px;
    border-radius: 4px; white-space: nowrap;
}
.lib-badge-cat-research { background: #ede9fe; color: #5b21b6; }
.lib-badge-cat-letter   { background: #dbeafe; color: #1e40af; }
.lib-badge-cat-content  { background: #fef3c7; color: #92400e; }
[data-theme="dark"] .lib-badge-cat-research { background: #2e1065; color: #c4b5fd; }
[data-theme="dark"] .lib-badge-cat-letter   { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .lib-badge-cat-content  { background: #451a03; color: #fcd34d; }

.lib-badge-chip {
    display: inline-block; font-size: 11px; padding: 1px 6px;
    border-radius: 8px; margin: 1px 2px;
}
.lib-badge-article-cat { background: #EFF6FF; color: #1a5276; }
.lib-badge-bill-ref    { background: #FEF3C7; color: #92400E; }
[data-theme="dark"] .lib-badge-article-cat { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .lib-badge-bill-ref    { background: #451a03; color: #fcd34d; }

/* ── Stats header pills ── */
.lib-stat-pills { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.lib-stat-pill {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 4px 12px; border-radius: 20px; font-size: 13px; font-weight: 500;
    text-decoration: none; transition: all 0.15s;
}
.lib-stat-pill:hover { filter: brightness(0.92); text-decoration: none; }
.lib-stat-pill-val { font-weight: 700; }
.lib-stat-pill-research { background: #ede9fe; color: #5b21b6; }
.lib-stat-pill-letter   { background: #dbeafe; color: #1e40af; }
.lib-stat-pill-content  { background: #fef3c7; color: #92400e; }
.lib-stat-pill-article  { background: #f3f4f6; color: #374151; }
[data-theme="dark"] .lib-stat-pill-research { background: #2e1065; color: #c4b5fd; }
[data-theme="dark"] .lib-stat-pill-letter   { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .lib-stat-pill-content  { background: #451a03; color: #fcd34d; }
[data-theme="dark"] .lib-stat-pill-article  { background: #374151; color: #9ca3af; }

/* ── Compact view toggle ── */
.lib-compact .lib-research-detail { display: none !important; }

/* ── Library mobile responsive ── */
@media (max-width:640px) {
    .lib-tab-bar { flex-wrap: wrap; gap: 0; }
    .lib-tabs { width: 100%; border-bottom: none; }
    .lib-tab { padding: 8px 14px; font-size: 13px; }
    .lib-actions { width: 100%; padding: 8px 0 8px; gap: 6px; border-top: none; }
    .lib-action-btn { flex: 1; justify-content: center; padding: 7px 8px; font-size: 11px; }
    .lib-action-btn svg { width: 12px; height: 12px; }
    .lib-col-cat, .lib-hide-mobile { display: none !important; }
    .lib-col-star   { width: 24px; }
    .lib-col-status { width: 72px; }
    .lib-col-bill { width: 70px; }
    .lib-col-type { width: 90px; }
    .lib-col-date { width: 90px; }
    .lib-col-actions { width: 50px; }
    .lib-table th, .lib-table td { padding: 8px 4px; font-size: 12px; }
    .lib-stat-pills { gap: 4px; }
    .lib-stat-pill { font-size: 11px; padding: 3px 8px; }
}
@media (max-width:480px) {
    .lib-table thead { display: none; }
    .lib-table, .lib-table tbody, .lib-table tr, .lib-table td { display: block; width: 100% !important; }
    .lib-table tr {
        border: 1px solid var(--border-color, #e5e7eb); border-radius: 6px;
        margin-bottom: 8px; padding: 10px 12px;
        background: var(--bg-card, #fff); position: relative;
    }
    .lib-table tr td:first-child { position: absolute; top: 10px; right: 10px; width: auto !important; padding: 0; }
    .lib-table tr td:nth-child(2) { padding: 0 0 6px; }
    .lib-col-cat, .lib-col-type, .lib-col-date, .lib-col-bill, .lib-hide-mobile { display: none !important; }
    .lib-table tr td:last-child { padding: 6px 0 0; text-align: left; }
    .lib-table-wrap { overflow-x: unset; }
    [data-theme="dark"] .lib-table tr { background: #1a1a2e; border-color: #2d2d45; }
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xs);
    padding: 10px 20px;
    min-height: var(--touch-min);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-weight: 600;
    border: none;
    cursor: pointer;
    transition: all var(--ease-fast);
    text-decoration: none;
}
.btn:hover {
    text-decoration: none;
    filter: brightness(0.92);
}

/* v10.90 Sprint 4.1 — button variants now read from --btn-* tokens in
   variables.css. To add a new variant: define tokens in variables.css,
   then copy this 4-line pattern. Never hardcode colors in button rules. */
.btn-primary {
    background: var(--btn-primary-bg);
    color: var(--btn-primary-text);
    border: 1px solid var(--btn-primary-border);
}
.btn-primary:hover {
    background: var(--btn-primary-bg-hover);
    color: var(--btn-primary-text);
}

.btn-gold {
    background: var(--btn-gold-bg);
    color: var(--btn-gold-text);
    border: 1px solid var(--btn-gold-border);
}
.btn-gold:hover {
    background: var(--btn-gold-bg-hover);
    color: var(--btn-gold-text);
}

.btn-outline {
    background: var(--btn-outline-bg);
    color: var(--btn-outline-text);
    border: 2px solid var(--btn-outline-border);
}
.btn-outline:hover {
    background: var(--btn-outline-bg-hover);
    color: var(--btn-outline-text-hover);
}

.btn-danger {
    background: var(--btn-danger-bg);
    color: var(--btn-danger-text);
    border: 1px solid var(--btn-danger-border);
}
.btn-danger:hover {
    background: var(--btn-danger-bg-hover);
    color: var(--btn-danger-text);
}

.btn-warning {
    background: var(--btn-warning-bg);
    color: var(--btn-warning-text);
    border: 1px solid var(--btn-warning-border);
}
.btn-warning:hover {
    background: var(--btn-warning-bg-hover);
    color: var(--btn-warning-text);
}

/* Secondary + success variants added v10.90 Sprint 4.1 for completeness */
.btn-secondary {
    background: var(--btn-secondary-bg);
    color: var(--btn-secondary-text);
    border: 1px solid var(--btn-secondary-border);
}
.btn-secondary:hover {
    background: var(--btn-secondary-bg-hover);
    color: var(--btn-secondary-text);
}

.btn-success {
    background: var(--btn-success-bg);
    color: var(--btn-success-text);
    border: 1px solid var(--btn-success-border);
}
.btn-success:hover {
    background: var(--btn-success-bg-hover);
    color: var(--btn-success-text);
}

/* MOB-02: Minimum touch targets */
.btn-warning, .filter-pill {
    min-height: 44px;
    min-width: 44px;
}

/* .btn-sm defined once below in the VIS-03 section (search for "VIS-03") —
   the old definition here was removed in v10.90 audit item #10 because it
   conflicted with the tokenized VIS-03 rule (34px vs. 44px min-height). */

/* Forms */
.form-group {
    margin-bottom: var(--spacing-md);
}

.form-group label {
    display: block;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--dark-navy);
    margin-bottom: var(--spacing-xs);
}

.form-control {
    width: 100%;
    padding: 10px 14px;
    min-height: var(--touch-min);
    border: 1px solid var(--light-border);
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    font-family: inherit;
    color: var(--dark-navy);
    background: white;
    transition: border var(--ease-fast);
}
/* Form focus states — v10.90 audit item #6.
   Every focus state lives in one place and reads from --input-focus-*
   tokens. Two distinct visual treatments by input device:

     :focus            → subtle border-color change (mouse users +
                         keyboard users — quiet, non-disruptive)
     :focus-visible    → full outline ring (keyboard users only — strong
                         WCAG 2.4.7 signal)

   Previously .form-control:focus used outline:none + box-shadow glow,
   which conflicted with the global :focus-visible outline rule and made
   keyboard-tab affordances inconsistent with the rest of the app.       */
.form-control:focus {
    outline: none;
    border-color: var(--input-focus-border);
}
.form-control:focus-visible {
    outline: var(--input-focus-ring-width) solid var(--input-focus-ring-color);
    outline-offset: var(--input-focus-ring-offset);
    border-color: var(--input-focus-border);
}

textarea.form-control {
    min-height: 80px;
    resize: vertical;
}

/* Required field indicator — asterisk after label text */
label.required::after,
label[for] ~ .form-control[required] ~ .field-required-indicator::after,
.form-group.required > label::after {
    content: " *";
    color: var(--alert-red, #CF0A2C);
    font-weight: 700;
}
/* Also catch labels that wrap required inputs */
label:has(+ [required])::after,
label:has(+ .form-control[required])::after {
    content: " *";
    color: var(--alert-red, #CF0A2C);
    font-weight: 700;
}

/* Form Validation States
   v10.90 Sprint 3.2: [aria-invalid="true"] gets the same treatment as the
   legacy .field-error class. Prefer the ARIA attribute in new code — it's
   picked up by screen readers automatically. */
.form-control.field-error,
.tag-input-container.field-error,
.form-control[aria-invalid="true"],
input[aria-invalid="true"],
textarea[aria-invalid="true"],
select[aria-invalid="true"] {
    border-color: var(--error-red);
    background: var(--tint-error-bg);
    box-shadow: 0 0 0 2px rgba(207, 10, 44, 0.1);
}
.form-control[aria-invalid="true"]:focus,
input[aria-invalid="true"]:focus,
textarea[aria-invalid="true"]:focus,
select[aria-invalid="true"]:focus {
    outline: 2px solid var(--error-red);
    outline-offset: 2px;
}
.form-control.field-success {
    border-color: var(--success-green);
}
.field-error-message {
    display: none;
    font-size: 12px;
    color: var(--alert-red);
    margin-top: 4px;
    line-height: 1.4;
}
.btn-disabled {
    opacity: 0.6;
    cursor: not-allowed;
    pointer-events: none;
}

.form-check {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
    min-height: var(--touch-min);
    cursor: pointer;
}

.form-check input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: var(--cfc-blue);
    cursor: pointer;
    /* Ensure checkbox has adequate touch area via padding */
    margin: 0;
    padding: 0;
}

.form-check label,
.form-check span {
    cursor: pointer;
    min-height: var(--touch-min);
    display: inline-flex;
    align-items: center;
    padding-top: 4px;
    padding-bottom: 4px;
}

/* Form action button groups — right-aligned */
.form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    margin-top: 20px;
}

/* Flash Messages */
.flash-messages {
    margin-bottom: 16px;
}

.alert {
    padding: var(--spacing-sm) var(--spacing-md);
    padding-right: 40px;
    border-radius: var(--radius-md);
    font-size: var(--text-base);
    margin-bottom: var(--spacing-sm);
    position: relative;
    transition: opacity var(--ease-smooth), transform var(--ease-smooth);
}
.alert-fade-out {
    opacity: 0;
    transform: translateY(-8px);
}
.alert-dismiss {
    position: absolute;
    top: 50%;
    right: 12px;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    color: inherit;
    opacity: 0.5;
    padding: 4px 6px;
    min-width: 44px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.alert-dismiss:hover {
    opacity: 1;
}

.alert-error {
    background: var(--tint-error-bg);
    color: var(--alert-red);
    border: 1px solid var(--tint-error-bg);
}

.alert-success {
    background: var(--tint-success-bg);
    color: var(--success-green);
    border: 1px solid var(--tint-success-bg);
}

.alert-info {
    background: var(--tint-info-bg);
    color: var(--cfc-blue);
    border: 1px solid var(--tint-info-bg);
}

.alert-warning {
    background: var(--tint-warning-bg);
    color: var(--tint-warning-text);
    border: 1px solid var(--tint-warning-bg);
}

/* Tables */
.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth;
    position: relative;
}

/* Right-edge gradient fade to indicate scrollable content */
.table-responsive.has-scroll-right::after {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 32px;
    background: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,0.9));
    pointer-events: none;
    z-index: 1;
    transition: opacity 0.2s;
}
.table-responsive.scrolled-end::after {
    opacity: 0;
}

table {
    width: 100%;
    border-collapse: collapse;
}

th {
    text-align: left;
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--muted-gray);
    padding: 10px 12px;
    border-bottom: 2px solid var(--light-border);
}

td {
    padding: 12px;
    border-bottom: 1px solid var(--light-border);
    font-size: 14px;
    vertical-align: top;
}

tr:hover {
    background: rgba(39, 88, 141, 0.03);
}

.clickable-row { cursor: pointer; transition: background 0.15s ease; }
.clickable-row:hover { background: rgba(39, 88, 141, 0.04); }

/* Status Badges */
.badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: var(--radius-xl);
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.badge-completed { background: var(--tint-success-bg); color: var(--success-green); }
.badge-running { background: var(--tint-info-bg); color: var(--cfc-blue); }
.badge-pending { background: var(--tint-neutral-bg); color: var(--muted-gray); }
.badge-failed { background: var(--tint-error-bg); color: var(--alert-red); }

/* v10.95: Deceased contact memorial badge */
.badge-deceased {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
    font-size: 11px;
    padding: 2px 6px;
    border-radius: 4px;
    margin-left: 4px;
    font-weight: 600;
    display: inline-block;
}
[data-theme="dark"] .badge-deceased {
    background: #450a0a;
    color: #fecaca;
    border-color: #7f1d1d;
}

/* v10.95: Household & Family card section helpers */
.hf-section { margin-bottom: 12px; }
.hf-rel-label { font-weight: 600; color: var(--muted-gray); }
.hf-rel-date { font-size: 11px; color: var(--muted-gray); margin-left: 4px; }
.hf-former summary { color: var(--muted-gray); font-style: italic; }
.hf-former details[open] summary { margin-bottom: 6px; }

/* v10.96: Inline relationship label chip in household member row */
.hf-member-rel {
    display: inline-block;
    font-size: 10px;
    font-weight: 600;
    color: var(--cfc-blue, #1B3A6B);
    background: var(--tint-blue-bg, #eef2f7);
    border: 1px solid var(--tint-blue-border, #d6e0ec);
    padding: 1px 6px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    white-space: nowrap;
    line-height: 1.4;
}
[data-theme="dark"] .hf-member-rel {
    color: #9ec5ff;
    background: rgba(94, 141, 184, 0.18);
    border-color: rgba(94, 141, 184, 0.35);
}
/* v10.96: End-relationship icon button in household row */
.hf-end-btn {
    color: var(--alert-red, #991b1b) !important;
    border-color: #fecaca !important;
}
.hf-end-btn:hover {
    background: #fef2f2;
    color: #991b1b !important;
}
[data-theme="dark"] .hf-end-btn {
    color: #fecaca !important;
    border-color: #7f1d1d !important;
}
[data-theme="dark"] .hf-end-btn:hover {
    background: rgba(127, 29, 29, 0.25);
}
/* v10.96: Mobile - keep label visible but smaller; hide on very narrow */
@media (max-width: 480px) {
    .hf-member-rel {
        font-size: 9px;
        padding: 0 4px;
        letter-spacing: 0.02em;
    }
}

/* Letter approval workflow status badges */
.badge-draft { background: var(--gray-200); color: var(--gray-600); }
.badge-pending-approval { background: var(--tint-warning-bg); color: var(--tint-warning-text); }
.badge-under-review { background: var(--tint-purple-bg); color: var(--tint-purple-text); }
.badge-reviewed { background: var(--tint-success-bg); color: var(--tint-success-text); }
.badge-approved { background: var(--tint-success-bg); color: var(--tint-success-text); }
.badge-published { background: var(--tint-info-bg); color: var(--tint-info-text); }

.badge-critical { background: var(--alert-red); color: white; }
.badge-high { background: var(--cfc-gold); color: var(--dark-navy); }
.badge-moderate { background: var(--tint-info-bg); color: var(--cfc-blue); }
.badge-supportive { background: var(--tint-success-bg); color: var(--success-green); }
.badge-watch { background: var(--tint-neutral-bg); color: var(--muted-gray); }

/* Accessible status indicators — icons for colorblind differentiation */
.badge-completed::before { content: "\2713 "; /* checkmark */ }
.badge-running::before { content: "\25B6 "; /* play arrow */ }
.badge-pending::before { content: "\25CB "; /* circle */ }
.badge-failed::before { content: "\2717 "; /* cross */ }
.badge-draft::before { content: "\270E "; /* pencil */ }
.badge-pending-approval::before { content: "\23F3 "; /* hourglass */ }
.badge-under-review::before { content: "\1F50D "; /* magnifying glass */ }
.badge-reviewed::before { content: "\2713 "; /* checkmark */ }
.badge-approved::before { content: "\2713 "; /* checkmark */ }
.badge-published::before { content: "\2605 "; /* star */ }
.badge-unknown { background: var(--tint-neutral-bg); color: var(--muted-gray); }

/* Priority Badges */
.badge-priority-low { background: var(--tint-neutral-bg); color: var(--muted-gray); }
.badge-priority-normal { background: var(--tint-info-bg); color: var(--cfc-blue); }
.badge-priority-high { background: var(--tint-warning-bg); color: var(--tint-warning-text); }
.badge-priority-urgent { background: var(--alert-red); color: white; }

/* Task Status Badges */
.task-badge-not_started { background: var(--tint-neutral-bg); color: var(--muted-gray); }
.task-badge-in_progress { background: var(--tint-info-bg); color: var(--tint-info-text); }
.task-badge-waiting_approval { background: var(--tint-warning-bg); color: var(--tint-warning-text); }
.task-badge-done_editing { background: var(--tint-purple-bg); color: var(--tint-purple-text); }
.task-badge-completed { background: var(--tint-success-bg); color: var(--tint-success-text); }
.task-badge-approved { background: var(--tint-success-bg); color: var(--success-green); }
.task-badge-approved_published { background: var(--tint-success-bg); color: var(--tint-success-text); }
.task-badge-sent_published { background: var(--tint-success-bg); color: var(--tint-success-text); }
.task-badge-uploaded_submitted { background: var(--tint-success-bg); color: var(--tint-success-text); }

/* Inline status dropdown on Tasks index */
.task-inline-status {
    border-radius: 6px;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid transparent;
    appearance: auto;
}
select.task-badge-not_started { background: var(--tint-neutral-bg); color: var(--muted-gray); }
select.task-badge-in_progress { background: var(--tint-info-bg); color: var(--tint-info-text); }
select.task-badge-waiting_approval { background: var(--tint-warning-bg); color: var(--tint-warning-text); }
select.task-badge-done_editing { background: var(--tint-purple-bg); color: var(--tint-purple-text); }
select.task-badge-completed { background: var(--tint-success-bg); color: var(--tint-success-text); }
select.task-badge-approved_published { background: var(--tint-success-bg); color: var(--tint-success-text); }
select.task-badge-sent_published { background: var(--tint-success-bg); color: var(--tint-success-text); }
select.task-badge-uploaded_submitted { background: var(--tint-success-bg); color: var(--tint-success-text); }
.inline-status-form { display: inline; }
[data-theme="dark"] select.task-badge-not_started { background: #1f2937; color: #9ca3af; }
[data-theme="dark"] select.task-badge-in_progress { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] select.task-badge-waiting_approval { background: #2E2208; color: #FBBF24; }
[data-theme="dark"] select.task-badge-done_editing { background: #1e1036; color: #c4b5fd; }
[data-theme="dark"] select.task-badge-completed { background: #052e16; color: #4ade80; }
[data-theme="dark"] select.task-badge-approved_published { background: #052e16; color: #4ade80; }
[data-theme="dark"] select.task-badge-sent_published { background: #052e16; color: #4ade80; }
[data-theme="dark"] select.task-badge-uploaded_submitted { background: #052e16; color: #4ade80; }

/* Role Badges */
.badge-role-admin { background: var(--cfc-gold); color: var(--dark-navy); }
.badge-role-staff { background: var(--tint-info-bg); color: var(--cfc-blue); }
.badge-role-contributor { background: var(--tint-success-bg); color: var(--success-green); }
.badge-role-viewer { background: var(--tint-neutral-bg); color: var(--muted-gray); }

/* Scan Progress */
.progress-container {
    max-width: 600px;
    margin: 40px auto;
    text-align: center;
}

.progress-bar-track {
    width: 100%;
    height: 8px;
    background: var(--light-border);
    border-radius: 4px;
    overflow: hidden;
    margin: 20px 0;
}

.progress-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--cfc-blue), var(--cfc-gold));
    border-radius: 4px;
    transition: width 0.5s ease;
}

.progress-phase {
    font-size: 16px;
    font-weight: 600;
    color: var(--dark-navy);
    margin-bottom: 8px;
}

.progress-detail {
    font-size: 14px;
    color: var(--muted-gray);
}

.progress-spinner {
    display: inline-block;
    width: 24px;
    height: 24px;
    border: 3px solid var(--light-border);
    border-top-color: var(--cfc-blue);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    margin-bottom: 16px;
}

@keyframes spin {
    to { transform: rotate(360deg); }
}

/* Inline spinner for buttons */
.spinner-sm {
    display: inline-block;
    width: 14px;
    height: 14px;
    border: 2px solid rgba(255,255,255,0.4);
    border-top-color: #fff;
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
    vertical-align: middle;
    margin-right: 4px;
}
.btn-outline .spinner-sm,
.btn-sm:not(.btn-primary):not(.btn-gold):not(.btn-success) .spinner-sm {
    border-color: rgba(0,0,0,0.15);
    border-top-color: var(--cfc-blue);
}

/* Quick Stats */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}

.stat-card {
    background: white;
    border: 1px solid var(--light-border);
    border-radius: 8px;
    padding: 16px;
    text-align: center;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
    transition: box-shadow 0.2s ease, transform 0.2s ease;
}
.stat-card:hover { box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); transform: translateY(-1px); }

.stat-value {
    font-size: 28px;
    font-weight: 700;
    color: var(--cfc-blue);
}

.stat-label {
    font-size: 12px;
    color: var(--muted-gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 4px;
}

/* Brief Display */
.brief-content {
    background: white;
    padding: 32px;
    border-radius: 8px;
    border: 1px solid var(--light-border);
    line-height: 1.8;
}

.brief-content h1, .brief-content h2, .brief-content h3 {
    color: var(--dark-navy);
    margin-top: 24px;
    margin-bottom: 12px;
}

.brief-content h2 {
    border-bottom: 3px solid var(--cfc-gold);
    padding-bottom: 8px;
}

/* Action Bar */
.action-bar {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 16px;
}

/* Empty State */
.empty-state {
    text-align: center;
    padding: 48px 24px;
    color: var(--muted-gray);
}
.empty-state .empty-icon { font-size: 48px; opacity: 0.25; margin-bottom: 12px; line-height: 1; }
.empty-state h3 { color: var(--dark-navy); margin-bottom: 8px; font-size: 16px; }
.empty-state p { font-size: 14px; line-height: 1.6; max-width: 400px; margin: 0 auto; }
.empty-state .btn { margin-top: 16px; }

/* Footer */
.app-footer {
    text-align: center;
    padding: 16px;
    font-size: 12px;
    color: var(--muted-gray);
    border-top: 1px solid var(--light-border);
    margin-top: auto;
}

.app-footer .scripture {
    color: var(--cfc-blue);
    font-style: italic;
    margin-bottom: 4px;
}

/* Tag Input Component */
.tag-input-container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    min-height: 38px;
    padding: 4px 8px;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    background: white;
    cursor: text;
}
.tag-input-container:focus-within {
    border-color: var(--cfc-blue);
    box-shadow: 0 0 0 2px rgba(39, 88, 141, 0.1);
}
.tag-pill {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: rgba(39, 88, 141, 0.1);
    color: var(--cfc-blue);
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}
.tag-pill-x {
    cursor: pointer;
    font-size: 14px;
    line-height: 1;
    color: var(--muted-gray);
    margin-left: 2px;
    /* Expand touch target without changing visual size */
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    min-height: 28px;
}
.tag-pill-x::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: var(--touch-min);
    height: var(--touch-min);
}
.tag-pill-x:hover {
    color: var(--alert-red);
}
.tag-text-input {
    border: none;
    outline: none;
    flex: 1;
    min-width: 80px;
    font-size: 13px;
    padding: 4px 0;
    background: transparent;
}
.tag-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: var(--z-sticky);
    background: white;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    max-height: 200px;
    overflow-y: auto;
    margin-top: 2px;
}
.tag-dropdown-item {
    padding: 8px 12px;
    font-size: 13px;
    cursor: pointer;
    color: var(--dark-navy);
}
.tag-dropdown-item:hover,
.tag-dropdown-item.active {
    background: rgba(39, 88, 141, 0.08);
}
.tag-dropdown-item.active {
    outline: 2px solid var(--cfc-blue);
    outline-offset: -2px;
}

/* Tag Browse Button */
.tag-browse-btn {
    background: none;
    border: 1px dashed var(--light-border);
    border-radius: 4px;
    padding: 2px 8px;
    font-size: 12px;
    color: var(--cfc-blue);
    cursor: pointer;
    white-space: nowrap;
    min-height: 28px;
    transition: background 0.15s, border-color 0.15s;
}
.tag-browse-btn:hover {
    background: rgba(39, 88, 141, 0.06);
    border-color: var(--cfc-blue);
}

/* Tag Picker Popup Overlay */
.tag-picker-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--z-overlay-top);
    background: rgba(0, 0, 0, 0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: tp-fade-in 0.15s ease;
}
@keyframes tp-fade-in { from { opacity: 0; } to { opacity: 1; } }

.tag-picker-panel {
    background: white;
    border-radius: 12px;
    box-shadow: 0 16px 48px rgba(0, 0, 0, 0.2);
    width: 100%;
    max-width: 680px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    animation: tp-slide-up 0.2s ease;
}
@keyframes tp-slide-up { from { transform: translateY(12px); opacity: 0; } to { transform: none; opacity: 1; } }

.tag-picker-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px 12px;
    border-bottom: 1px solid var(--light-border);
}
.tag-picker-header h3 {
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    color: var(--dark-navy);
}
.tag-picker-close {
    background: none;
    border: none;
    font-size: 24px;
    color: var(--muted-gray);
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
}
.tag-picker-close:hover { color: var(--alert-red); }

.tag-picker-search-wrap {
    display: flex;
    gap: 8px;
    padding: 12px 20px;
    border-bottom: 1px solid var(--light-border);
}
.tag-picker-search {
    flex: 1;
    padding: 8px 12px;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    font-size: 13px;
    outline: none;
}
.tag-picker-search:focus {
    border-color: var(--cfc-blue);
    box-shadow: 0 0 0 2px rgba(39, 88, 141, 0.12);
}
.tag-picker-sort-btn {
    background: none;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    padding: 6px 12px;
    font-size: 12px;
    color: var(--cfc-blue);
    cursor: pointer;
    white-space: nowrap;
}
.tag-picker-sort-btn:hover { background: rgba(39, 88, 141, 0.06); }

.tag-picker-body {
    flex: 1;
    overflow-y: auto;
    padding: 16px 20px;
}
.tag-picker-section { margin-bottom: 16px; }
.tag-picker-section:last-child { margin-bottom: 0; }
.tag-picker-cat-header {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted-gray);
    margin-bottom: 8px;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--light-border);
}
.tag-picker-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.tag-picker-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 5px 10px;
    border: 1px solid var(--light-border);
    border-radius: 16px;
    background: white;
    font-size: 12px;
    font-weight: 500;
    color: var(--dark-navy);
    cursor: pointer;
    transition: all 0.15s;
    line-height: 1.3;
}
.tag-picker-chip:hover {
    border-color: var(--cfc-blue);
    background: rgba(39, 88, 141, 0.04);
}
.tag-picker-chip-selected {
    background: var(--cfc-blue) !important;
    border-color: var(--cfc-blue) !important;
    color: white !important;
}
.tag-picker-chip-selected .tag-picker-chip-count {
    background: rgba(255, 255, 255, 0.25);
    color: white;
}
.tag-picker-chip-name { white-space: nowrap; }
.tag-picker-chip-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 4px;
    border-radius: 9px;
    background: rgba(39, 88, 141, 0.08);
    font-size: 12px;
    font-weight: 700;
    color: var(--cfc-blue);
}
.tag-picker-footer {
    display: flex;
    align-items: center;
    padding: 12px 20px;
    border-top: 1px solid var(--light-border);
    gap: 12px;
}

/* Selected tags bar inside picker */
.tag-picker-sel-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    padding: 10px 20px;
    min-height: 38px;
    border-bottom: 1px solid var(--light-border);
    background: rgba(39, 88, 141, 0.02);
    align-items: center;
}

/* Edit tags button */
.btn-edit-tags {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    background: rgba(39, 88, 141, 0.06);
    border: 1px solid rgba(39, 88, 141, 0.2);
    border-radius: 4px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: var(--cfc-blue);
    padding: 2px 8px;
    white-space: nowrap;
    transition: background 0.15s, border-color 0.15s;
}
.btn-edit-tags:hover {
    background: rgba(39, 88, 141, 0.12);
    border-color: var(--cfc-blue);
}
[data-theme="dark"] .btn-edit-tags {
    background: rgba(39, 88, 141, 0.15);
    border-color: rgba(39, 88, 141, 0.3);
    color: #8AA8C8;
}

/* Custom tag pill — dashed border, muted, visually distinct from standard */
.tag-pill-custom {
    background: rgba(138, 138, 138, 0.08);
    color: var(--muted-gray);
    border: 1px dashed var(--muted-gray);
    font-style: italic;
}

/* Custom tag input row at bottom of picker */
.tag-picker-custom {
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px dashed var(--light-border);
}
.tag-picker-custom-label {
    display: block;
    font-size: 12px;
    color: var(--muted-gray);
    margin-bottom: 8px;
}
.tag-picker-custom-row {
    display: flex;
    gap: 8px;
}
.tag-picker-custom-input {
    flex: 1;
    padding: 7px 12px;
    border: 1px dashed var(--light-border);
    border-radius: 6px;
    font-size: 13px;
    outline: none;
    background: transparent;
    color: var(--dark-navy);
}
.tag-picker-custom-input:focus {
    border-color: var(--muted-gray);
    border-style: solid;
}
.tag-picker-custom-input::placeholder { color: var(--muted-gray); font-style: italic; }
.tag-picker-custom-add {
    padding: 6px 14px;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    background: white;
    font-size: 12px;
    font-weight: 600;
    color: var(--muted-gray);
    cursor: pointer;
    white-space: nowrap;
}
.tag-picker-custom-add:hover { color: var(--cfc-blue); border-color: var(--cfc-blue); }

/* Tag Picker — Dark Mode */
[data-theme="dark"] .tag-picker-panel { background: var(--bg-card, #1A1A2E); }
[data-theme="dark"] .tag-picker-header h3 { color: var(--text-primary, #E2E8F0); }
[data-theme="dark"] .tag-picker-search { background: #2A2A3E; border-color: #3A3A4E; color: var(--text-primary, #E2E8F0); }
[data-theme="dark"] .tag-picker-chip { background: #2A2A3E; border-color: #3A3A4E; color: var(--text-primary, #E2E8F0); }
[data-theme="dark"] .tag-picker-chip:hover { border-color: var(--cfc-blue); background: rgba(39, 88, 141, 0.15); }
[data-theme="dark"] .tag-picker-chip-count { background: rgba(39, 88, 141, 0.2); }
[data-theme="dark"] .tag-picker-cat-header { color: #8A8A9E; border-color: #3A3A4E; }
[data-theme="dark"] .tag-picker-sort-btn { border-color: #3A3A4E; color: #8AA8C8; }
[data-theme="dark"] .tag-browse-btn { border-color: #3A3A4E; color: #8AA8C8; }
[data-theme="dark"] .tag-picker-sel-bar { background: rgba(39, 88, 141, 0.08); border-color: #3A3A4E; }
[data-theme="dark"] .tag-picker-footer { border-color: #3A3A4E; }
[data-theme="dark"] .tag-picker-custom { border-color: #3A3A4E; }
[data-theme="dark"] .tag-picker-custom-input { border-color: #3A3A4E; color: var(--text-primary, #E2E8F0); }
[data-theme="dark"] .tag-picker-custom-add { background: #2A2A3E; border-color: #3A3A4E; color: #8A8A9E; }
[data-theme="dark"] .tag-pill-custom { background: rgba(138, 138, 138, 0.12); border-color: #5A5A6E; color: #9A9AB0; }

/* Tag Picker — Mobile */
@media (max-width: 640px) {
    .tag-picker-panel { max-width: none; max-height: 90vh; border-radius: 12px 12px 0 0; }
    .tag-picker-overlay { align-items: flex-end; padding: 0; }
    .tag-picker-body { padding: 12px 16px; }
    .tag-picker-chip { font-size: 12px; padding: 4px 8px; }
}

/* Navbar Search Form */
.nav-search-form {
    display: flex;
    align-items: center;
    gap: 0;
    margin-left: auto;
}
.nav-search-input {
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.25);
    border-right: none;
    border-radius: 6px 0 0 6px;
    color: #fff;
    font-size: 13px;
    padding: 5px 10px;
    width: 160px;
    min-height: 32px;
    outline: none;
    transition: background 0.15s, width 0.2s;
}
.nav-search-input::placeholder { color: rgba(255,255,255,0.5); }
.nav-search-input:focus {
    background: rgba(255,255,255,0.2);
    width: 220px;
    border-color: rgba(255,255,255,0.5);
}
.nav-search-btn {
    background: rgba(255,255,255,0.15);
    border: 1px solid rgba(255,255,255,0.25);
    border-radius: 0 6px 6px 0;
    color: #fff;
    cursor: pointer;
    font-size: 14px;
    padding: 5px 9px;
    min-height: 32px;
    transition: background 0.15s;
}
.nav-search-btn:hover { background: rgba(255,255,255,0.25); }
[data-theme="dark"] .nav-search-input {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.2);
}
[data-theme="dark"] .nav-search-input:focus {
    background: rgba(255,255,255,0.14);
}
@media (max-width: 900px) {
    .nav-search-form { display: none; }
}

/* User Menu Dropdown */
.user-menu {
    position: relative;
    margin-left: auto;
}
.user-menu-toggle {
    background: none;
    border: 1px solid rgba(255,255,255,0.25);
    color: rgba(255,255,255,0.9);
    padding: 8px 14px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    font-family: inherit;
    transition: background 0.15s;
}
.user-menu-toggle:hover {
    background: rgba(255,255,255,0.12);
    color: white;
}
.user-menu-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 6px);
    right: 0;
    min-width: 160px;
    background: white;
    border-radius: 8px;
    border: 1px solid var(--light-border);
    box-shadow: 0 8px 24px rgba(0,0,0,0.12);
    z-index: var(--z-dropdown);
    padding: 4px 0;
    flex-direction: column;
}
.user-menu.open .user-menu-dropdown {
    display: flex;
}
.user-menu-dropdown a {
    color: var(--dark-text) !important;
    padding: 10px 16px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    transition: background 0.1s;
    text-decoration: none;
}
.user-menu-dropdown a:hover {
    background: #f0f4f8 !important;
    color: var(--dark-navy) !important;
}
.dropdown-logout-btn {
    display: block;
    width: 100%;
    text-align: left;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--dark-text) !important;
    padding: 10px 16px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    border-radius: 0 !important;
    transition: background 0.1s;
    font-family: inherit;
}
.dropdown-logout-btn:hover {
    background: #f0f4f8 !important;
    color: var(--dark-navy) !important;
}

/* Hamburger Menu Toggle */
.navbar-toggle {
    display: none;
    background: none;
    border: none;
    color: white;
    font-size: 24px;
    cursor: pointer;
    padding: 10px 12px;
    min-width: 44px;
    min-height: 44px;
    line-height: 1;
}

/* Loading Spinner Overlay */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.85);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    z-index: var(--z-overlay-top);
}
.loading-overlay .progress-spinner { margin-bottom: 16px; }
.loading-overlay p { font-size: 16px; font-weight: 600; color: var(--dark-navy); }
.loading-overlay .loading-sub { font-size: 13px; color: var(--muted-gray); margin-top: 4px; }

/* MOB-09: Prevent text overflow */
.card-body, td, .public-card { overflow-wrap: break-word; word-break: break-word; }

/* MOB-17: Prevent dashboard card overflow */
.card-body { overflow: hidden; }
.card-body .badge-row, .card-body .chip-row { flex-wrap: wrap; }

/* FORM-13: Search input clear button */
input[type="search"]::-webkit-search-cancel-button { -webkit-appearance: searchfield-cancel-button; cursor: pointer; }

/* Admin-only content visibility */
.admin-only {
    /* Shown by default; hidden via Jinja2 {% if %} for non-admin users */
}

/* ==========================================================================
   RESPONSIVE BREAKPOINTS
   480px  — phone (portrait)
   768px  — tablet / phone (landscape)
   900px  — nav search hidden
   1024px — desktop (small)
   1920px — widescreen (sidebar visible)
   ========================================================================== */

/* Responsive — Nav collapse */
@media (max-width: 900px) {
    .navbar {
        padding: 8px 12px;
        flex-wrap: nowrap;
    }

    .navbar-brand {
        flex: 1;
        min-width: 0;
        overflow: hidden;
    }

    .brand-subtitle {
        display: none;
    }

    .navbar-toggle {
        display: block;
        flex-shrink: 0;
    }

    .navbar-links {
        display: none;
        width: 100%;
        flex-direction: column;
        gap: 2px;
        padding: 8px 0;
        border-top: 1px solid rgba(255,255,255,0.15);
        margin-top: 4px;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: linear-gradient(135deg, var(--dark-navy) 0%, var(--cfc-blue) 100%);
        z-index: var(--z-sticky);
        padding: 8px 12px;
    }
    .navbar-links.open {
        display: flex;
    }

    .navbar-links a {
        padding: 10px 12px;
        font-size: 14px;
        border-radius: 6px;
        text-align: center;
    }

    /* Capitol nav dropdown — inline on mobile (same as user-menu) */
    .nav-dropdown {
        width: 100%;
    }
    .nav-dropdown-toggle {
        width: 100%;
        justify-content: center;
        padding: 10px 12px;
        font-size: 14px;
        border-radius: 6px;
    }
    .nav-dropdown-menu {
        position: static;
        background: rgba(255,255,255,0.08);
        border: none;
        box-shadow: none;
        border-radius: 6px;
        margin-top: 4px;
        padding: 2px 0;
        min-width: 0;
    }
    .nav-dropdown-menu a {
        color: rgba(255,255,255,0.85) !important;
        text-align: center;
        font-size: 14px !important;
        padding: 10px 12px !important;
    }
    .nav-dropdown-menu a:hover {
        background: rgba(255,255,255,0.12) !important;
        color: white !important;
    }
    .nav-dropdown-menu a.active {
        background: rgba(255,255,255,0.18) !important;
        color: white !important;
    }
    .nav-dropdown-menu hr {
        border-color: rgba(255,255,255,0.15);
    }

    /* User menu: inline on mobile */
    .user-menu {
        margin-left: 0;
        width: 100%;
        border-top: 1px solid rgba(255,255,255,0.15);
        margin-top: 4px;
        padding-top: 6px;
    }
    .user-menu-toggle {
        width: 100%;
        text-align: center;
        padding: 10px 12px;
        font-size: 14px;
        border: none;
    }
    .user-menu-dropdown {
        position: static;
        background: rgba(255,255,255,0.08);
        border: none;
        box-shadow: none;
        border-radius: 6px;
        margin-top: 4px;
        padding: 2px 0;
    }
    .user-menu-dropdown a {
        color: rgba(255,255,255,0.85) !important;
        text-align: center;
        padding: 10px 12px !important;
        font-size: 14px !important;
    }
    .user-menu-dropdown a:hover {
        background: rgba(255,255,255,0.12) !important;
        color: white !important;
    }

    .navbar-brand img {
        height: 44px;
    }

    .brand-name {
        font-size: 14px;
        letter-spacing: 1.5px;
    }

    .main-content {
        padding: 16px 12px;
    }

    .card {
        padding: 16px;
    }

    .card-header {
        font-size: 16px;
        flex-direction: column;
        gap: 8px;
    }

    .card-header.collapsible-header {
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        gap: 8px;
    }

    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .action-bar {
        flex-direction: column;
    }

    .action-bar .btn {
        width: 100%;
        justify-content: center;
    }

    table {
        font-size: 13px;
    }

    th, td {
        padding: 8px 6px;
    }

    /* Hide Stance and Priority columns on mobile (3rd and 4th columns) - bills table only */
    #bills-table th:nth-child(3), #bills-table th:nth-child(4),
    #bills-table td:nth-child(3), #bills-table td:nth-child(4) {
        display: none;
    }

    /* Reduce left padding on bill ID to align with separator */
    #bills-table td:first-child {
        padding-left: 0 !important;
    }

    /* Task detail grid stacks on mobile */
    .task-detail-grid {
        grid-template-columns: 1fr !important;
    }

    /* Resource items stack */
    .resource-item {
        flex-direction: column;
        gap: 8px;
    }
    .resource-actions {
        opacity: 1 !important;
    }

    /* Filter forms stack */
    .filter-row {
        flex-direction: column;
        gap: 8px;
    }
    .filter-row select,
    .filter-row input {
        width: 100%;
    }

    .page-header {
        flex-direction: column;
        gap: 8px;
    }
}

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

    .stat-value {
        font-size: 22px;
    }

    .btn-sm {
        padding: 8px 12px;
        font-size: 13px;
    }
}

/* ===================================================================
   Wide Layout — shared by all landing pages (Bills, Tasks, Research)
   Blows out the 1000px cap, fills the viewport with responsive padding.
   Usage: {% block main_class %}wide{% endblock %} in any template.
   =================================================================== */

.main-content.wide {
    max-width: none;
    padding: 24px 24px;
}

/* ═══ Task Filter Bar ═══ */
.tf-bar {
    display: flex;
    align-items: flex-end;
    gap: 12px;
    padding: 14px 18px;
    margin-bottom: 12px;
    background: var(--bg-card);
    border: 1px solid var(--light-border);
    border-radius: 10px;
    flex-wrap: wrap;
}
.tf-filters {
    display: flex;
    align-items: flex-end;
    gap: 10px;
    flex: 1;
    flex-wrap: wrap;
    min-width: 0;
}
.tf-group {
    display: flex;
    flex-direction: column;
    gap: 3px;
    min-width: 0;
}
.tf-group-bill { flex: 1 1 160px; max-width: 220px; }
.tf-label {
    font-size: 12px;
    font-weight: 600;
    color: var(--muted-gray);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.tf-input-wrap { position: relative; }
.tf-input, .tf-select {
    font-size: 13px !important;
    padding: 6px 10px !important;
    min-height: 34px !important;
    border-radius: 6px !important;
}
.tf-clear {
    position: absolute;
    right: 6px;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: 16px;
    color: var(--muted-gray);
    cursor: pointer;
    line-height: 1;
    padding: 2px 4px;
}
.tf-clear:hover { color: var(--alert-red); }
.tf-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.tf-btn { min-height: 34px; font-size: 13px; }

/* Toggle switch for "Show completed" */
.tf-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
    margin: 0;
    white-space: nowrap;
}
.tf-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.tf-toggle-track {
    position: relative;
    width: 36px;
    height: 20px;
    background: var(--light-border);
    border-radius: 10px;
    transition: background 0.2s;
    flex-shrink: 0;
}
.tf-toggle-thumb {
    position: absolute;
    top: 2px;
    left: 2px;
    width: 16px;
    height: 16px;
    background: white;
    border-radius: 50%;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}
.tf-toggle input:checked + .tf-toggle-track {
    background: var(--cfc-blue);
}
.tf-toggle input:checked + .tf-toggle-track .tf-toggle-thumb {
    transform: translateX(16px);
}
.tf-toggle-label {
    font-size: 13px;
    font-weight: 500;
    color: var(--text-secondary);
}
.tf-toggle input:checked ~ .tf-toggle-label {
    color: var(--text-primary);
}

/* Results count */
.tf-results {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--muted-gray);
    margin-bottom: 12px;
    padding-left: 2px;
}
.tf-results-note {
    font-size: 12px;
    background: var(--bg-hover);
    color: var(--muted-gray);
    padding: 2px 8px;
    border-radius: 4px;
}

/* Dark mode */
[data-theme="dark"] .tf-bar {
    background: var(--bg-card);
    border-color: var(--light-border);
}
[data-theme="dark"] .tf-toggle-track {
    background: var(--gray-700);
}
[data-theme="dark"] .tf-toggle-thumb {
    background: var(--gray-300);
}
[data-theme="dark"] .tf-toggle input:checked + .tf-toggle-track {
    background: #5B8DB8;
}
[data-theme="dark"] .tf-results-note {
    background: rgba(255,255,255,0.06);
}

/* Mobile: stack filters */
@media (max-width: 768px) {
    .tf-bar { flex-direction: column; align-items: stretch; gap: 10px; padding: 12px 14px; }
    .tf-filters { flex-direction: column; gap: 8px; }
    .tf-group-bill { max-width: 100%; }
    .tf-actions { justify-content: space-between; }
}

/* Page-level headings inside wide layout */
.wide-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.wide-header h1 {
    font-size: 22px;
    font-weight: 700;
}
.wide-header .subtitle {
    font-size: 13px;
    color: var(--muted-gray);
    margin-top: 2px;
}

/* Generic page header (non-wide pages like Instagram, Legislators) */
.page-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 20px;
}
.page-header h1 { font-size: 22px; font-weight: 700; }
.page-header .subtitle { font-size: 13px; color: var(--muted-gray); margin-top: 2px; }

/* --- Mobile ≤768 --- */
@media (max-width: 768px) {
    .main-content.wide { padding: 16px 12px; }
    .main-content.wide table { font-size: 12px; }
    .main-content.wide th,
    .main-content.wide td { padding: 8px 6px; }
    /* MOB-03: Minimum readable font size on mobile */
    .dash-stat-lbl, .filter-pill, td, .card-body small { font-size: max(12px, 0.75rem); }
}

/* --- Tablet 769–1024 --- */
@media (min-width: 769px) and (max-width: 1024px) {
    .main-content.wide { padding: 24px 20px; }
}

/* --- Desktop 1025–1440 --- */
@media (min-width: 1025px) and (max-width: 1440px) {
    .main-content.wide { padding: 28px 40px; }
    .wide-header h1 { font-size: 24px; }
    .main-content.wide .card { padding: 20px; }
    .main-content.wide .card-header { font-size: 17px; }
    .main-content.wide th { font-size: 13px; padding: 12px 14px; }
    .main-content.wide td { font-size: 15px; padding: 14px; }
    .main-content.wide .form-control { font-size: 14px; padding: 10px 14px; }
    .main-content.wide .stat-value { font-size: 30px; }
    .main-content.wide .stat-label { font-size: 12px; }
    .main-content.wide .btn { font-size: 14px; }
    .main-content.wide .btn-sm { font-size: 12px; }
}

/* --- Large desktop 1441–1920 --- */
@media (min-width: 1441px) and (max-width: 1920px) {
    .main-content.wide { padding: 32px 60px; }
    .wide-header h1 { font-size: 26px; }
    .wide-header .subtitle { font-size: 14px; }
    .main-content.wide .card { padding: 24px; }
    .main-content.wide .card-header { font-size: 18px; margin-bottom: 18px; }
    .main-content.wide th { font-size: 13px; padding: 12px 16px; }
    .main-content.wide td { font-size: 15px; padding: 14px 16px; }
    .main-content.wide .form-group label { font-size: 14px; }
    .main-content.wide .form-control { font-size: 15px; padding: 12px 16px; }
    .main-content.wide .stat-value { font-size: 34px; }
    .main-content.wide .stat-label { font-size: 13px; }
    .main-content.wide .stats-grid { gap: 16px; }
    .main-content.wide .btn { font-size: 15px; padding: 12px 24px; }
    .main-content.wide .btn-sm { font-size: 13px; padding: 8px 16px; }
    .main-content.wide .alert { font-size: 15px; padding: 14px 20px; }
    .main-content.wide .empty-state { padding: 56px 16px; }
    .main-content.wide .empty-state p { font-size: 15px; }
}

/* --- Ultrawide 1921–2560 --- */
@media (min-width: 1921px) and (max-width: 2560px) {
    .main-content.wide { padding: 36px 80px; }
    .wide-header h1 { font-size: 30px; }
    .wide-header .subtitle { font-size: 15px; }
    .main-content.wide .card { padding: 28px; }
    .main-content.wide .card-header { font-size: 20px; margin-bottom: 20px; }
    .main-content.wide th { font-size: 14px; padding: 14px 18px; }
    .main-content.wide td { font-size: 16px; padding: 16px 18px; }
    .main-content.wide .form-group label { font-size: 15px; }
    .main-content.wide .form-control { font-size: 16px; padding: 14px 18px; }
    .main-content.wide .stat-value { font-size: 38px; }
    .main-content.wide .stat-label { font-size: 14px; }
    .main-content.wide .stats-grid { gap: 20px; }
    .main-content.wide .btn { font-size: 16px; padding: 14px 28px; }
    .main-content.wide .btn-sm { font-size: 14px; padding: 8px 18px; }
    .main-content.wide .alert { font-size: 16px; padding: 16px 24px; }
    .main-content.wide .empty-state { padding: 64px 16px; }
    .main-content.wide .empty-state p { font-size: 16px; }
}

/* --- Beyond 2560 --- */
@media (min-width: 2561px) {
    .main-content.wide { padding: 40px 80px; }
    .wide-header h1 { font-size: 32px; }
    .main-content.wide th { font-size: 15px; padding: 16px 20px; }
    .main-content.wide td { font-size: 17px; padding: 18px 20px; }
    .main-content.wide .stat-value { font-size: 42px; }
    .main-content.wide .form-control { font-size: 17px; }
}

/* ═══════════════════════════════════════════════════════
   Dashboard shared styles (used by dashboard + research)
   ═══════════════════════════════════════════════════════ */

/* --- Core layout --- */
.dash-card { margin: 0; transition: box-shadow 0.15s; }

/* Fix #15: Drag handles hidden by default, show on card hover */
.dash-card .card-drag-handle { opacity: 0; transition: opacity 0.15s; }
.dash-card:hover .card-drag-handle { opacity: 0.5; }

/* Fix #12: Urgency tinting for cards with hearing-urgent data */
.dash-card[data-hearing-urgent] { background: #fef8f0; border-left: 3px solid #d97706; }
[data-theme="dark"] .dash-card[data-hearing-urgent] { background: rgba(217,119,6,0.08); border-left-color: #d97706; }

/* ── Focus Today card items ── */
.focus-item:hover { background: var(--bg-hover, #f5f5f5); }
.focus-item:last-child { border-bottom: none; }
[data-theme="dark"] .focus-item:hover { background: rgba(255,255,255,0.05); }
[data-theme="dark"] .focus-item { border-bottom-color: rgba(255,255,255,0.08); }
[data-card-id="focus-today"] { border-left: 3px solid var(--alert-red, #dc2626); }
[data-theme="dark"] [data-card-id="focus-today"] { border-left-color: #ef4444; }

/* ── Shared Card Components (Dashboard + Bill Detail) ── */
.card-drag-handle {
    cursor: grab; opacity: 0.5; font-size: 14px; user-select: none;
    padding: 2px 6px; transition: opacity 0.15s; flex-shrink: 0;
}
@media (max-width: 768px) {
    .card-drag-handle {
        font-size: 18px; padding: 6px 8px;
        min-width: 32px; min-height: 32px;
        display: flex; align-items: center; justify-content: center;
    }
}
.card-drag-handle:hover { opacity: 0.7; }
.card-drag-handle:active { cursor: grabbing; }
.collapsible-header {
    display: flex; justify-content: space-between; align-items: center;
    cursor: pointer; user-select: none; gap: 8px; flex-wrap: wrap;
}
.card-toggle {
    font-size: 18px; user-select: none; flex-shrink: 0; margin-left: 8px;
}
.card-header-actions {
    display: flex; gap: 6px; align-items: center; flex-shrink: 0;
}
.sortable-ghost { opacity: 0.3; }
.sortable-chosen { box-shadow: 0 4px 16px rgba(0,0,0,0.15); }

.dash-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 16px;
}
.dash-welcome { font-size: 22px; font-weight: 700; }
.dash-subtitle { font-size: 13px; color: var(--muted-gray); margin-top: 2px; }

/* Dashboard Mobile Search — only visible when nav search is hidden */
.dash-mobile-search { display: none; margin-bottom: 12px; }
.dash-mobile-search-form {
    display: flex;
    align-items: center;
    background: var(--bg-card, #fff);
    border: 1px solid #d0d5dd;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: var(--shadow-sm, 0 1px 2px rgba(0,0,0,0.06));
}
.dash-mobile-search-input {
    flex: 1;
    border: none;
    outline: none;
    padding: 10px 14px;
    font-size: 15px;
    background: transparent;
    color: var(--text-primary, #1a1a1a);
    min-height: 44px;
}
.dash-mobile-search-input::placeholder { color: var(--text-secondary, #6b7280); }
.dash-mobile-search-btn {
    border: none;
    background: var(--cfc-blue, #002D5C);
    color: #fff;
    padding: 0 16px;
    min-height: 44px;
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}
.dash-mobile-search-btn:hover { opacity: 0.85; }
[data-theme="dark"] .dash-mobile-search-form { border-color: #3a3a5c; background: var(--bg-card, #1A1A2E); }
[data-theme="dark"] .dash-mobile-search-btn { background: #1a5276; }
@media (max-width: 900px) {
    .dash-mobile-search { display: block; }
}
.dash-stats { display: flex; gap: 20px; }
.dash-stat { text-align: center; }
.dash-stat-val { font-size: 22px; font-weight: 700; color: var(--dark-navy); line-height: 1; }
.dash-stat-lbl { font-size: 12px; color: var(--muted-gray); text-transform: uppercase; letter-spacing: 0.5px; }
.dash-stat-link { text-decoration: none; border-radius: 8px; padding: 8px 12px; margin: -8px -12px; transition: background 0.15s; }
.dash-stat-link:hover { background: rgba(39, 88, 141, 0.08); text-decoration: none; }
.dash-stat-link:hover .dash-stat-val { color: var(--cfc-blue); }

/* Vote Breaking News Banner */
.vote-breaking-news {
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    color: #fff; border-radius: 8px; padding: 0; margin-bottom: 16px;
    border-left: 4px solid #e74c3c; overflow: hidden;
}
.vote-breaking-header {
    display: flex; align-items: center; gap: 8px; padding: 10px 16px;
    background: rgba(231, 76, 60, 0.15); font-size: 13px;
}
.vote-breaking-pulse {
    width: 8px; height: 8px; border-radius: 50%; background: #e74c3c;
    animation: pulse-red 1.5s ease-in-out infinite;
}
.vote-breaking-items { padding: 8px 16px 12px; display: flex; flex-direction: column; gap: 6px; }
.vote-breaking-item {
    display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
    font-size: 13px; padding: 4px 8px; border-radius: 4px;
}
.vote-breaking-defection { background: rgba(231, 76, 60, 0.1); }
.vote-breaking-dem_alignment { background: rgba(46, 204, 113, 0.1); }
.vote-breaking-item a { color: #fff; text-decoration: none; }
.vote-breaking-item a:hover { text-decoration: underline; }
[data-theme="dark"] .vote-breaking-news { border-left-color: #c0392b; }

.dash-alerts { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 16px; }
.dash-alert { flex: 1; min-width: 240px; padding: 10px 16px; margin: 0; }
.dash-alert-list { margin-top: 4px; font-size: 13px; }
.dash-alert-list > div { margin-bottom: 2px; }

.dash-top-row { display: flex; gap: 16px; align-items: start; margin-bottom: 16px; }
.dash-top-card { flex: 1; min-width: 0; }
.dash-bottom-row { display: flex; gap: 16px; align-items: start; }
.dash-bottom-card { flex: 1; min-width: 0; }

/* Dashboard card headers (static, non-collapsible — used in approvals, batch, research_needs, engagement) */
.dash-card-hdr {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 16px;
    font-size: 15px;
    font-weight: 600;
    border-bottom: 1px solid var(--light-border);
}
.dash-card-btn { font-size: 12px; padding: 2px 10px; }

.dash-list { display: flex; flex-direction: column; }
.dash-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    border-bottom: 1px solid var(--light-border);
    text-decoration: none;
}
.dash-row-overdue { background: var(--tint-error-bg); }
.dash-row-id { font-weight: 700; font-size: 14px; color: var(--dark-navy); white-space: nowrap; }
.dash-row-title { font-size: 13px; color: var(--muted-gray); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.dash-row-badge { font-size: 12px; padding: 2px 8px; white-space: nowrap; flex-shrink: 0; }
.dash-row-date { font-size: 12px; color: var(--muted-gray); white-space: nowrap; }
.dash-row-date-overdue { color: var(--alert-red); font-weight: 600; }

.dash-res-title { font-size: 14px; font-weight: 600; display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dash-res-meta { font-size: 12px; color: var(--muted-gray); margin-top: 2px; }
.dash-res-thumb { width: 44px; height: 30px; object-fit: cover; border-radius: 3px; border: 1px solid var(--light-border); flex-shrink: 0; }

.dash-empty { padding: 24px; text-align: center; }
.dash-empty p { font-size: 14px; font-style: italic; color: var(--muted-gray); margin: 0; }

/* --- Dashboard breakpoints --- */

/* Mobile ≤768: stack, tight gutters */
@media (max-width: 768px) {
    .dash-header { align-items: flex-start; }
    .dash-top-row, .dash-bottom-row { flex-direction: column; }
    .dash-top-card, .dash-bottom-card { width: 100%; }
    .dash-welcome { font-size: 20px; }
    .dash-stats { gap: 16px; }
    .dash-stat-val { font-size: 20px; }
}

/* Tablet 769–1024: two-col top, wrap bottom */
@media (min-width: 769px) and (max-width: 1024px) {
    .dash-bottom-row { flex-wrap: wrap; }
    .dash-bottom-card { min-width: 45%; }
}

/* Desktop 1025–1440 */
@media (min-width: 1025px) and (max-width: 1440px) {
    .dash-top-row, .dash-bottom-row { gap: 20px; }
    .dash-card .card-header { padding: 14px 20px; font-size: 15px; }
    .dash-row { padding: 9px 20px; gap: 12px; }
    .dash-row-id { font-size: 15px; }
    .dash-row-title { font-size: 14px; }
    .dash-row-badge { font-size: 12px; }
    .dash-row-date { font-size: 13px; }
    .dash-res-title { font-size: 15px; }
    .dash-res-meta { font-size: 13px; }
    .dash-stat-val { font-size: 26px; }
    .dash-welcome { font-size: 24px; }
    .dash-subtitle { font-size: 14px; }
}

/* Large desktop 1441–1920 */
@media (min-width: 1441px) and (max-width: 1920px) {
    .dash-top-row, .dash-bottom-row { gap: 24px; }
    .dash-card .card-header { padding: 14px 24px; font-size: 16px; }
    .dash-card-btn { font-size: 12px; padding: 3px 12px; }
    .dash-row { padding: 10px 24px; gap: 14px; }
    .dash-row-id { font-size: 16px; }
    .dash-row-title { font-size: 15px; }
    .dash-row-badge { font-size: 12px; padding: 3px 10px; }
    .dash-row-date { font-size: 14px; }
    .dash-res-title { font-size: 16px; }
    .dash-res-meta { font-size: 14px; }
    .dash-res-thumb { width: 56px; height: 38px; }
    .dash-stat-val { font-size: 30px; }
    .dash-stat-lbl { font-size: 12px; }
    .dash-stats { gap: 28px; }
    .dash-welcome { font-size: 26px; }
    .dash-subtitle { font-size: 15px; }
    .dash-alert { padding: 14px 20px; font-size: 14px; }
    .dash-alert-list { font-size: 14px; }
    .dash-empty p { font-size: 15px; }
}

/* Ultrawide 1921–2560 */
@media (min-width: 1921px) and (max-width: 2560px) {
    .dash-top-row, .dash-bottom-row { gap: 28px; }
    .dash-card .card-header { padding: 16px 28px; font-size: 17px; }
    .dash-card-btn { font-size: 13px; padding: 4px 14px; }
    .dash-row { padding: 12px 28px; gap: 16px; }
    .dash-row-id { font-size: 17px; }
    .dash-row-title { font-size: 16px; }
    .dash-row-badge { font-size: 13px; padding: 3px 12px; }
    .dash-row-date { font-size: 15px; }
    .dash-res-title { font-size: 17px; }
    .dash-res-meta { font-size: 15px; }
    .dash-res-thumb { width: 64px; height: 44px; }
    .dash-stat-val { font-size: 34px; }
    .dash-stat-lbl { font-size: 13px; }
    .dash-stats { gap: 36px; }
    .dash-welcome { font-size: 30px; }
    .dash-subtitle { font-size: 16px; }
    .dash-alert { padding: 16px 24px; font-size: 15px; }
    .dash-alert-list { font-size: 15px; }
    .dash-empty p { font-size: 16px; }
}

/* Beyond 2560 */
@media (min-width: 2561px) {
    .dash-row-id { font-size: 18px; }
    .dash-row-title { font-size: 17px; }
    .dash-stat-val { font-size: 36px; }
    .dash-welcome { font-size: 32px; }
}

/* --- Shared Sticky Action Bar (Dashboard + Bill Detail) --- */

.sticky-sentinel { height: 1px; margin: 0; }
.sticky-action-bar {
    position: sticky;
    top: 0;
    z-index: var(--z-sticky);
    background: transparent;
    padding: 10px 0;
    margin-bottom: 12px;
    transition: box-shadow 0.2s ease;
}
.sticky-action-bar.is-stuck {
    background: var(--bg-main, #f5f3ef);
    box-shadow: var(--shadow-sm, 0 1px 3px rgba(0,0,0,0.1));
    border-bottom: 1px solid var(--light-border);
}
.action-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.action-bar-group {
    display: flex;
    align-items: center;
    gap: 8px;
}
.action-bar-form { display: inline; }
.action-bar-left { flex-shrink: 0; }
.action-bar-center { flex: 1; justify-content: center; }
.action-bar-right { flex-shrink: 0; margin-left: auto; }

.view-toggle {
    display: flex;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    overflow: hidden;
    flex-shrink: 0;
}
.view-btn {
    background: white;
    border: none;
    padding: 6px 8px;
    cursor: pointer;
    color: var(--muted-gray);
    display: flex;
    align-items: center;
    transition: all 0.15s;
}
.view-btn:hover { background: #f0f4f8; color: var(--cfc-blue); }
.view-btn.active { background: var(--cfc-blue); color: white; }
.view-btn + .view-btn { border-left: 1px solid var(--light-border); }

.btn-reset-layout { font-size: 12px; padding: 4px 8px; }
.btn-expand-collapse { font-size: 12px; padding: 4px 8px; }
.tour-trigger { font-size: 12px; padding: 4px 10px; }

/* Mobile: hide view toggle, compact centered layout */
@media (max-width: 640px) {
    .action-bar-left { display: none; }
    .action-bar { justify-content: center; gap: 6px; }
    .action-bar-center { flex: 0 1 auto; justify-content: center; gap: 6px; }
    .action-bar-right { margin-left: 0; }
    .action-bar .btn { font-size: 12px; padding: 6px 10px; }
}

/* Dark mode: sticky action bar + view toggle */
[data-theme="dark"] .sticky-action-bar.is-stuck { background: var(--bg-main, #0F0F1A); }
[data-theme="dark"] .view-btn { background: var(--bg-card, #1E1E30); color: var(--text-secondary); border-color: var(--light-border); }
[data-theme="dark"] .view-btn:hover { background: var(--bg-hover); color: var(--cfc-blue); }
[data-theme="dark"] .view-btn.active { background: var(--cfc-blue); color: white; }

/* --- Shared Dashboard-style Control Bar (Dashboard + Bill Detail) --- */

.dash-control-bar {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin: 0 0 10px;
    padding: 4px 0;
}
.dash-inline-controls {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}
.dash-inline-controls .view-toggle {
    background: var(--bg-hover, #f3f4f6);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 20px;
    padding: 2px 3px;
    display: flex;
    gap: 1px;
}
.dash-inline-controls .view-btn {
    border-radius: 16px;
    padding: 3px 7px;
    min-height: unset;
    height: 22px;
    opacity: 0.45;
    border: none;
    background: none;
    box-shadow: none;
}
.dash-inline-controls .view-btn.active { opacity: 1; background: #fff; box-shadow: 0 1px 2px rgba(0,0,0,.1); }
.dash-inline-controls .dash-settings-btn {
    height: 26px;
    min-height: unset;
    padding: 0 9px;
    font-size: 13px;
    border-radius: 20px;
    background: var(--bg-hover, #f3f4f6);
    border: 1px solid var(--border-color, #e5e7eb);
    color: var(--text-secondary, #6b7280);
    line-height: 1;
}
.dash-ctrl-pill {
    background: var(--bg-hover, #f3f4f6);
    border: 1px solid var(--border-color, #e5e7eb);
    border-radius: 20px;
    padding: 0 10px;
    font-size: 12px;
    cursor: pointer;
    color: var(--text-secondary, #6b7280);
    white-space: nowrap;
    min-height: unset;
    height: 26px;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    transition: background .15s, border-color .15s, color .15s;
}
.dash-ctrl-pill:hover {
    background: #fff;
    border-color: var(--cfc-blue, #002D5C);
    color: var(--cfc-blue, #002D5C);
}
.dash-control-bar .jump-nav {
    flex: 1;
    margin: 0;
    padding: 0;
    background: none;
    border: none;
    min-height: 0;
}
/* Right-side bill controls group (Watch, Tour, Advocacy, Back) */
.bill-ctrl-right {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    margin-left: auto;
}
.bill-ctrl-right .action-bar-form { display: inline; }
/* Dark mode: control bar */
[data-theme="dark"] .dash-inline-controls .view-toggle,
[data-theme="dark"] .dash-inline-controls .dash-settings-btn,
[data-theme="dark"] .dash-ctrl-pill {
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.12);
    color: #a0aec0;
}
[data-theme="dark"] .dash-inline-controls .view-btn.active { background: rgba(255,255,255,.12); }
[data-theme="dark"] .dash-ctrl-pill:hover {
    background: rgba(255,255,255,.1);
    border-color: #5B8DB8;
    color: #5B8DB8;
}
[data-theme="dark"] .dash-inline-controls .dash-settings-btn:hover {
    background: rgba(255,255,255,.1);
    border-color: #5B8DB8;
    color: #5B8DB8;
}
@media (max-width: 768px) {
    /* Hide dashboard nav helpers + quick actions on mobile — redundant with FAB + nav */
    .dash-quick-actions { display: none !important; }
    .dash-control-bar .view-toggle { display: none !important; }
    .dash-control-bar .jump-nav { display: none !important; }
    .dash-control-bar #dash-reset-card-order { display: none !important; }
    .dash-control-bar { gap: 4px; }
    /* Hide bill detail sections toggle + status strip on mobile — too crowded */
    .bill-section-toggle { display: none !important; }
    .bill-summary-strip { display: none !important; }
}
@media (max-width: 640px) {
    .bill-ctrl-right { gap: 4px; }
    .bill-ctrl-right .btn { font-size: 12px; padding: 4px 8px; }
    .dash-ctrl-pill { font-size: 12px; padding: 0 8px; }
}

/* --- Dashboard Quick Actions --- */

.dash-quick-actions {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.dash-qa-badge {
    display: inline-block;
    background: white;
    color: var(--cfc-blue);
    font-size: 12px;
    font-weight: 700;
    border-radius: 10px;
    padding: 0 5px;
    min-width: 16px;
    text-align: center;
    margin-left: 4px;
}

/* --- Dashboard Grid Layout (v7.8) --- */

#dash-cards-grid {
    display: grid;
    gap: 16px;
    align-items: start;
}
#dash-cards-grid.dash-grid-1 { grid-template-columns: 1fr; }
#dash-cards-grid.dash-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
#dash-cards-grid.dash-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }

/* Grid cards fill their cell — min-width:0 prevents content from blowing out grid tracks */
#dash-cards-grid > .card,
#dash-cards-grid > .dash-card { margin: 0; min-width: 0; overflow: hidden; align-self: start; }

/* Half-width paired card rows — always two equal columns regardless of parent grid mode */
.dash-half-row {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
    align-items: start;
}
.dash-half-row > .card,
.dash-half-row > .dash-card { margin: 0; min-width: 0; overflow: hidden; align-self: start; }

/* Mobile: always 1 column */
@media (max-width: 768px) {
    #dash-cards-grid.dash-grid-2,
    #dash-cards-grid.dash-grid-3 { grid-template-columns: 1fr; }
    .dash-half-row { grid-template-columns: 1fr; }
}
/* Tablet: max 2 columns */
@media (max-width: 1023px) {
    #dash-cards-grid.dash-grid-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* --- Dashboard Settings Button + Panel --- */

.dash-settings-wrap { position: relative; display: inline-block; }

.dash-settings-btn {
    background: none;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    width: 30px; height: 30px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    color: var(--muted-gray);
    font-size: 16px;
    transition: color 0.15s, border-color 0.15s;
}
.dash-settings-btn:hover {
    color: var(--dark-navy);
    border-color: var(--dark-navy);
}

.dash-settings-panel {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    z-index: var(--z-dropdown);
    width: 280px;
    max-height: 420px;
    overflow-y: auto;
    background: var(--bg-card);
    border: 1px solid var(--light-border);
    border-radius: 8px;
    box-shadow: var(--shadow-md);
    margin-top: 6px;
    padding: 12px;
}
.dash-settings-panel.open { display: block; }

.dash-settings-panel h2 {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--muted-gray);
    margin: 0 0 8px;
}

.dash-settings-divider {
    height: 1px;
    background: var(--light-border);
    margin: 8px 0;
}

.dash-settings-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0;
    font-size: 13px;
    color: var(--text-primary);
}
.dash-settings-item label {
    flex: 1;
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.dash-settings-item input[type="checkbox"] {
    width: 15px; height: 15px;
    cursor: pointer;
    accent-color: var(--cfc-blue);
}
.dash-settings-arrow {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--muted-gray);
    font-size: 12px;
    padding: 2px 4px;
    border-radius: 3px;
    line-height: 1;
}
.dash-settings-arrow:hover { color: var(--dark-navy); background: var(--bg-hover); }
.dash-settings-arrow:disabled { opacity: 0.25; cursor: default; }

.dash-settings-reset {
    display: block;
    width: 100%;
    margin-top: 8px;
    padding: 6px;
    font-size: 12px;
    border: 1px solid var(--light-border);
    border-radius: 4px;
    background: none;
    cursor: pointer;
    color: var(--muted-gray);
    text-align: center;
}
.dash-settings-reset:hover { color: var(--alert-red); border-color: var(--alert-red); }

/* Dark mode: settings panel */
[data-theme="dark"] .dash-settings-btn { color: var(--text-secondary); border-color: var(--light-border); }
[data-theme="dark"] .dash-settings-btn:hover { color: var(--text-primary); }
[data-theme="dark"] .dash-settings-panel { background: var(--bg-card); border-color: var(--light-border); }
[data-theme="dark"] .dash-settings-item { color: var(--text-primary); }
[data-theme="dark"] .dash-settings-arrow:hover { background: var(--bg-hover); color: var(--text-primary); }

/* --- Share to Coalition Panel --- */
.share-coalition-panel {
    display: none; position: absolute; top: 100%; right: 0; z-index: var(--z-dropdown);
    width: 300px; max-width: calc(100vw - 24px); max-height: 440px; overflow-y: auto;
    background: var(--bg-card, #fff); border: 1px solid var(--light-border);
    border-radius: 8px; box-shadow: var(--shadow-md); margin-top: 6px; padding: 12px;
}
.share-coalition-panel.open { display: block; }
.share-coalition-panel h2 {
    font-size: 12px; font-weight: 700; text-transform: uppercase;
    letter-spacing: 0.5px; color: var(--muted-gray); margin: 0 0 8px;
}
.share-coalition-group {
    border: 1px solid var(--light-border); border-radius: 6px;
    margin-bottom: 8px; overflow: hidden;
}
.share-coalition-header {
    display: flex; align-items: center; gap: 6px;
    padding: 8px 10px; background: var(--bg-hover, #f8f9fa);
    cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text-primary);
}
.share-coalition-header:hover { background: var(--light-border); }
.share-coalition-dot {
    width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
}
.share-coalition-count {
    font-size: 12px; padding: 1px 6px; border-radius: 10px;
    background: var(--cfc-blue); color: #fff; font-weight: 600;
    margin-left: auto;
}
.share-coalition-arrow {
    font-size: 12px; color: var(--text-secondary); margin-left: 4px;
}
.share-coalition-cards { padding: 6px 10px; }
.share-card-check {
    display: flex; align-items: center; gap: 6px;
    padding: 3px 0; font-size: 13px; color: var(--text-primary);
}
.share-card-check input[type="checkbox"] {
    width: 15px; height: 15px; cursor: pointer; accent-color: var(--cfc-blue);
}
.share-card-check span { cursor: pointer; flex: 1; }
.share-select-btn {
    background: none; border: none; cursor: pointer;
    color: var(--cfc-blue); font-size: 12px; padding: 0;
}
.share-select-btn:hover { text-decoration: underline; }

/* Dark mode: share panel */
[data-theme="dark"] .share-coalition-panel { background: var(--bg-card); border-color: var(--light-border); }
[data-theme="dark"] .share-coalition-group { border-color: var(--light-border); }
[data-theme="dark"] .share-coalition-header { background: var(--bg-hover); }
[data-theme="dark"] .share-coalition-header:hover { background: var(--light-border); }

/* ========== Coalitions module — dark mode (tier-2.8) ==========
   Most coalition pages render via CSS variables and inherit dark mode
   automatically from base.html. The overrides below target specific
   hardcoded hexcolors and custom classes that don't respond to the
   variable system. The email-preview iframe intentionally stays light
   because its content is an email rendered the way recipients see it.
================================================================= */

/* Coalition stat chips on the index cards */
[data-theme="dark"] .coalition-stat-chip {
    background: var(--bg-hover) !important;
    color: var(--text-secondary) !important;
}

/* AI generation-notes callout on email preview */
.coalition-gen-notes {
    margin-top: 12px;
    padding: 8px 12px;
    background: #fffbeb;
    border: 1px solid #fef3c7;
    border-radius: 6px;
    font-size: 12px;
    color: #92400e;
}
[data-theme="dark"] .coalition-gen-notes {
    background: rgba(146, 64, 14, 0.12);
    border-color: rgba(146, 64, 14, 0.35);
    color: #fcd34d;
}

/* Pre-call-brief letter status badges */
.lbadge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 999px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.lbadge-published          { background: #dbeafe; color: #1e40af; }
.lbadge-approved           { background: #dcfce7; color: #166534; }
.lbadge-pending_approval   { background: #fef3c7; color: #92400e; }
.lbadge-none, .lbadge-draft { background: #f3f4f6; color: #6b7280; }
[data-theme="dark"] .lbadge-published        { background: rgba(30, 64, 175, 0.22); color: #93c5fd; }
[data-theme="dark"] .lbadge-approved         { background: rgba(22, 101, 52, 0.22); color: #86efac; }
[data-theme="dark"] .lbadge-pending_approval { background: rgba(146, 64, 14, 0.22); color: #fcd34d; }
[data-theme="dark"] .lbadge-none,
[data-theme="dark"] .lbadge-draft            { background: var(--bg-hover); color: var(--muted-gray); }

/* Autocomplete dropdown used on the coalition Bills tab (reuses
   .search-ac-dropdown / .search-ac-item defined inline on bills.html).
   Override those in dark mode so the popup isn't a blinding white box. */
[data-theme="dark"] .search-ac-dropdown {
    background: var(--bg-card) !important;
    border-color: var(--light-border) !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5) !important;
    color: var(--text-primary) !important;
}
[data-theme="dark"] .search-ac-item {
    border-bottom-color: var(--light-border) !important;
    color: var(--text-primary) !important;
}
[data-theme="dark"] .search-ac-item:hover,
[data-theme="dark"] .search-ac-item.active {
    background: var(--bg-hover) !important;
}
[data-theme="dark"] .search-ac-bill { color: var(--text-primary) !important; }
[data-theme="dark"] .search-ac-title { color: var(--text-secondary) !important; }

/* Readiness grade pill (tier-2.10) — grade backgrounds already have
   per-grade inline colors, but in dark mode we need higher-contrast
   variants. Applied via [title^="Digest readiness"] selector so we
   don't have to touch the template. */
[data-theme="dark"] [title^="Digest readiness"] {
    filter: saturate(1.1) brightness(1.08);
}

/* Bulk action bar on the coalition Bills tab (tier-2.12) — force
   a consistent navy background regardless of theme; inline styling
   already handles the rest. */
[data-theme="dark"] #bulk-action-bar {
    background: #0B1B33 !important;
}

/* --- Section Toggle Bar --- */

.section-toggle-bar {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 12px;
    padding: 6px 0;
}
.section-toggle-bar-label {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--muted-gray);
    margin-right: 4px;
    white-space: nowrap;
}
.section-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    border: 1.5px solid var(--cfc-blue);
    background: var(--cfc-blue);
    color: #fff;
    cursor: pointer;
    transition: background 0.2s, color 0.2s, border-color 0.2s, opacity 0.2s;
    user-select: none;
    min-height: 30px;
}
.section-pill:hover { opacity: 0.85; }
.section-pill.inactive {
    background: transparent;
    color: var(--cfc-blue);
    opacity: 0.65;
}
.section-pill.inactive:hover { opacity: 1; }
.section-pill-count {
    font-size: 12px;
    font-weight: 700;
    background: rgba(255,255,255,0.3);
    border-radius: 8px;
    padding: 0 5px;
    line-height: 16px;
}
.section-pill.inactive .section-pill-count {
    background: rgba(39,88,141,0.12);
}

/* Dark mode: section toggle bar */
[data-theme="dark"] .section-pill {
    border-color: #5B8DB8;
    background: #5B8DB8;
}
[data-theme="dark"] .section-pill.inactive {
    background: transparent;
    color: #5B8DB8;
    border-color: #5B8DB8;
}
[data-theme="dark"] .section-pill.inactive .section-pill-count {
    background: rgba(91,141,184,0.2);
}

/* Bill detail section toggle: mobile only */
.bill-section-toggle {
    display: none;
}
@media (max-width: 768px) {
    .bill-section-toggle {
        display: flex;
    }
}

/* Mobile: smaller pills */
@media (max-width: 768px) {
    .section-pill { font-size: 12px; padding: 3px 10px; min-height: 28px; }
    .section-toggle-bar-label { font-size: 12px; }
}


/* ═══════════════════════════════════════════════════════
   Legislator Module — v3.0
   ═══════════════════════════════════════════════════════ */

/* Party badges */
.badge-party-democratic { background: var(--tint-info-bg); color: var(--tint-info-text); }
.badge-party-republican { background: var(--tint-error-bg); color: var(--tint-error-text); }
.badge-party-independent { background: var(--party-ind-bg); color: var(--party-ind-text); }
.badge-party-other { background: var(--tint-neutral-bg); color: var(--muted-gray); }

/* Legislator list — hide Party column on mobile */
@media (max-width: 768px) {
  .leg-party-col { display: none; }
}

/* Sponsor chips (bill detail) */
.sponsor-group { margin-bottom: 12px; }
.sponsor-group:last-child { margin-bottom: 0; }
.sponsor-group-label {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--muted-gray);
    margin-bottom: 6px;
}
.sponsor-group-primary { color: var(--cfc-navy); }
.sponsor-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.sponsor-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 16px;
    font-size: 13px;
    line-height: 1.3;
}
.sponsor-chip a { color: var(--cfc-navy); text-decoration: none; font-weight: 500; }
.sponsor-chip a:hover { text-decoration: underline; }

/* ── Witness card ── */
.witness-list { display: flex; flex-direction: column; gap: 8px; }
.witness-row { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; padding: 8px 10px; background: var(--bg-hover, #f8f9fa); border-radius: 6px; border-left: 3px solid var(--cfc-blue, #1a5276); }
.witness-info { flex: 1; min-width: 0; }
.witness-name-line { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.witness-org { font-size: 12px; color: var(--text-secondary); }
.witness-contact-info { font-size: 12px; margin-top: 2px; }
.witness-contact-info a { color: var(--cfc-blue); text-decoration: none; }
.witness-contact-info a:hover { text-decoration: underline; }
.witness-actions { display: flex; gap: 4px; flex-shrink: 0; align-items: center; }
.witness-edit-form { padding: 10px; margin-bottom: 8px; background: var(--bg-hover, #f5f5f5); border-radius: 6px; border: 1px solid var(--border-color, #e0e0e0); }
.witness-autocomplete-dropdown { position: absolute; top: 100%; left: 0; right: 0; max-height: 200px; overflow-y: auto; background: #fff; border: 1px solid var(--border-color, #ddd); border-radius: 6px; box-shadow: 0 4px 12px rgba(0,0,0,0.1); z-index: var(--z-sticky); }
.witness-dd-item { padding: 8px 12px; cursor: pointer; font-size: 13px; }
.witness-dd-item:hover { background: var(--bg-hover, #f0f4f8); }
.witness-dd-empty { color: var(--text-secondary); cursor: default; font-style: italic; }

.party-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}
.party-dot.democratic { background: var(--party-dem-dot); }
.party-dot.republican { background: var(--party-rep-dot); }
.party-dot.independent { background: var(--party-ind-dot); }
.sponsor-chamber-badge {
    font-size: 12px;
    font-weight: 600;
    color: var(--muted-gray);
    background: #f1f5f9;
    padding: 1px 5px;
    border-radius: 4px;
    margin-left: 2px;
}

/* Vote badges */
.vote-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.vote-aye { background: var(--tint-success-bg); color: #0D7C3E; }
.vote-nay { background: var(--tint-error-bg); color: #CF0A2C; }
.vote-absent { background: var(--tint-warning-bg); color: var(--tint-warning-text); }
.vote-nvr { background: var(--tint-neutral-bg); color: var(--muted-gray); }
.vote-missed { background: var(--tint-neutral-bg); color: var(--muted-gray); }

/* Bill stance row backgrounds (voting record table) */
.bill-row-support { background: rgba(13, 124, 62, 0.06); }
.bill-row-oppose  { background: rgba(207, 10, 44, 0.06); }
.bill-row-support:hover { background: rgba(13, 124, 62, 0.10); }
.bill-row-oppose:hover  { background: rgba(207, 10, 44, 0.10); }

/* Score display */
.score-large {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.1;
}
.score-grade {
    font-size: 1.5rem;
    font-weight: 700;
}

/* Filter labels */
.filter-label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: var(--muted-gray);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

/* Form inputs & selects (legislators) */
.form-input, .form-select {
    width: 100%;
    padding: 10px 14px;
    border: 1px solid var(--light-border);
    border-radius: 6px;
    font-size: 14px;
    font-family: inherit;
    color: var(--dark-navy);
    background: white;
    transition: border 0.15s;
}
.form-input:focus, .form-select:focus {
    outline: none;
    border-color: var(--cfc-blue);
    box-shadow: 0 0 0 3px rgba(39, 88, 141, 0.1);
}

/* Icon button (delete, etc.) */
.btn-icon {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 16px;
    padding: 4px;
    opacity: 0.5;
    transition: opacity 0.15s;
    min-width: var(--touch-min);
    min-height: var(--touch-min);
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.btn-icon:hover { opacity: 1; }

/* Muted text helper */
.muted { color: var(--muted-gray); font-size: 13px; }

/* Legislator card on index - hover row */
.legislator-row {
    cursor: pointer;
    transition: background 0.15s;
}
.legislator-row:hover {
    background: rgba(39, 88, 141, 0.05);
}

/* Sortable column headers */
th.sortable {
    cursor: pointer;
    user-select: none;
    white-space: nowrap;
}
th.sortable:hover {
    background: rgba(39, 88, 141, 0.08);
}
th.sortable.active-sort {
    color: var(--cfc-blue);
}
.sort-arrow {
    font-size: 12px;
    margin-left: 2px;
    opacity: 0.7;
}

/* Scorecard party filter active state */
.party-filter.active {
    background: var(--cfc-blue) !important;
    color: white !important;
    border-color: var(--cfc-blue) !important;
}

/* Social media links on legislator detail */
.social-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    color: var(--cfc-blue);
    font-size: 13px;
    font-weight: 500;
    transition: opacity 0.15s;
}
.social-link:hover {
    opacity: 0.7;
}
.social-link svg {
    flex-shrink: 0;
}

/* ── Search Autocomplete (shared across all pages) ── */
.search-ac-dropdown {
    position: absolute; top: 100%; left: 0; right: 0; z-index: var(--z-autocomplete-top);
    background: white; border: 1px solid var(--light-border);
    border-top: none; border-radius: 0 0 8px 8px;
    box-shadow: 0 6px 20px rgba(0,0,0,0.12);
    max-height: 280px; overflow-y: auto;
}
.search-ac-item {
    padding: 8px 12px; cursor: pointer; font-size: 14px;
    border-bottom: 1px solid #f0f0f0; display: flex; align-items: center; gap: 8px;
    transition: background .1s;
}
.search-ac-item:hover, .search-ac-item.active { background: #f0f7ff; }
.search-ac-item:last-child { border-bottom: none; }
.search-ac-bill { font-weight: 700; color: var(--dark-navy); white-space: nowrap; min-width: 60px; }
.search-ac-title { color: #666; font-size: 13px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 1; }
.search-ac-stance {
    font-size: 12px; font-weight: 700; text-transform: uppercase;
    padding: 1px 6px; border-radius: 3px; white-space: nowrap; margin-left: auto; flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════
   v7.0 — Loading overlay, Modal, Toast notifications
   ══════════════════════════════════════════════════════════════ */

/* Loading overlay */
.loading-overlay {
    position: absolute;
    inset: 0;
    background: rgba(255,255,255,0.75);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-sticky-sub);
    border-radius: inherit;
}
.loading-spinner {
    width: 28px; height: 28px;
    border: 3px solid #ddd;
    border-top-color: var(--cfc-blue);
    border-radius: 50%;
    animation: spin .6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* Inline button spinner — use inside buttons for long-running actions */
.btn-spinner {
    display: inline-block;
    width: 14px; height: 14px;
    border: 2px solid rgba(255,255,255,0.3);
    border-top-color: currentColor;
    border-radius: 50%;
    animation: spin .6s linear infinite;
    vertical-align: middle;
    margin-right: 4px;
}

/* Standard modal */
.modal-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    z-index: var(--z-modal-backdrop);
    align-items: center;
    justify-content: center;
    padding: 20px;
}
.modal-content {
    background: white;
    border-radius: var(--radius-xl);
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: var(--shadow-xl);
    position: relative;
    z-index: var(--z-modal);
}
.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--spacing-md) 20px;
    border-bottom: 1px solid var(--light-border);
}
.modal-header h3 {
    font-size: var(--text-md);
    font-weight: 700;
    color: var(--dark-navy);
    margin: 0;
}
.modal-body { padding: 20px; }
.modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: var(--spacing-sm);
    padding: var(--spacing-sm) 20px;
    border-top: 1px solid var(--light-border);
}
.modal-close {
    background: none;
    border: none;
    font-size: 22px;
    line-height: 1;
    cursor: pointer;
    color: var(--muted-gray);
    min-width: var(--touch-min);
    min-height: var(--touch-min);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    transition: background 0.15s, color 0.15s;
    flex-shrink: 0;
}
.modal-close:hover {
    background: var(--bg-hover);
    color: var(--dark-navy);
}
/* MOB-06: Mobile modal fixes */
@media (max-width: 768px) {
    .modal-content { max-width: 95vw; max-height: 80vh; overflow-y: auto; }
}
body.modal-open { overflow: hidden; }

/* ── R3: Custom Confirm Modal ──────────────────────────────────── */
/* Replaces browser confirm() dialogs with a styled, branded modal. */
/* Created dynamically by showConfirm() in app.js.                  */
#confirm-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: var(--z-ask-panel);
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: confirm-fade-in 0.15s ease;
}
@keyframes confirm-fade-in {
    from { opacity: 0; }
    to { opacity: 1; }
}
.confirm-modal-box {
    background: var(--bg-card);
    border-radius: var(--radius-xl);
    max-width: 420px;
    width: 100%;
    padding: 24px;
    box-shadow: var(--shadow-xl);
    animation: confirm-slide-in 0.2s ease;
}
@keyframes confirm-slide-in {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}
.confirm-modal-title {
    font-size: var(--text-lg);
    font-weight: 700;
    color: var(--text-primary);
    margin: 0 0 12px 0;
}
.confirm-modal-msg {
    font-size: var(--text-base);
    color: var(--text-secondary);
    line-height: 1.5;
    margin: 0 0 20px 0;
}
.confirm-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}
.confirm-modal-actions .confirm-cancel {
    min-width: 80px;
}
.confirm-modal-actions .confirm-ok {
    min-width: 80px;
}
/* Dark mode */
[data-theme="dark"] .confirm-modal-box {
    background: var(--bg-card);
    border: 1px solid var(--light-border);
}
@media (max-width: 480px) {
    .confirm-modal-box { max-width: 95vw; padding: 20px; }
}

/* Toast notifications */
#toast-container {
    position: fixed;
    top: 16px;
    right: 16px;
    z-index: var(--z-toast);
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-width: 400px;
    pointer-events: none;
}
.toast {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-radius: 8px;
    background: var(--dark-navy);
    color: white;
    font-size: 14px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    pointer-events: auto;
    animation: toast-in 0.3s ease;
}
.toast-success { background: var(--cfc-gold); color: var(--dark-navy); }
.toast-error { background: #dc3545; }
.toast-warning { background: #e0a800; color: #1a1a1a; }
.toast-info { background: var(--cfc-blue); }
.toast-text { flex: 1; }
.toast-dismiss {
    background: none;
    border: none;
    color: inherit;
    font-size: 18px;
    cursor: pointer;
    opacity: 0.7;
    line-height: 1;
    padding: 0 2px;
    min-width: var(--touch-min);
    min-height: var(--touch-min);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.toast-dismiss:hover { opacity: 1; }
.toast-exit { animation: toast-out 0.3s ease forwards; }
@keyframes toast-in { from { opacity: 0; transform: translateX(40px); } to { opacity: 1; transform: translateX(0); } }
@keyframes toast-out { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(40px); } }

/* ══════════════════════════════════════════════════════════════
   v7.0 Phase 3 — Contextual Help Tooltips
   ══════════════════════════════════════════════════════════════ */

/* Help icon (? circle) */
.help-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: var(--bg-hover);
    color: var(--cfc-blue);
    font-size: 12px;
    font-weight: 700;
    cursor: help;
    position: relative;
    border: 1px solid var(--light-border);
    flex-shrink: 0;
    vertical-align: middle;
    margin-left: 4px;
}
/* Expand help icon touch target to 44px */
.help-icon::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: var(--touch-min);
    height: var(--touch-min);
}
.help-icon:hover {
    background: var(--cfc-blue);
    color: white;
    border-color: var(--cfc-blue);
}

/* Tooltip bubble */
.help-icon .help-tooltip {
    display: none;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 50%;
    transform: translateX(-50%);
    background: var(--dark-navy);
    color: white;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.5;
    white-space: normal;
    width: max-content;
    max-width: 280px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.2);
    z-index: var(--z-autocomplete);
    text-align: left;
    pointer-events: none;
}
.help-icon .help-tooltip::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 6px solid transparent;
    border-top-color: var(--dark-navy);
}
.help-icon:hover .help-tooltip {
    display: block;
}

/* Tooltip position variants */
.help-icon.tooltip-right .help-tooltip {
    left: auto;
    right: 0;
    transform: none;
}
.help-icon.tooltip-right .help-tooltip::after {
    left: auto;
    right: 12px;
    transform: none;
}
.help-icon.tooltip-left .help-tooltip {
    left: 0;
    right: auto;
    transform: none;
}
.help-icon.tooltip-left .help-tooltip::after {
    left: 12px;
    right: auto;
    transform: none;
}
.help-icon.tooltip-below .help-tooltip {
    bottom: auto;
    top: calc(100% + 8px);
}
.help-icon.tooltip-below .help-tooltip::after {
    top: auto;
    bottom: 100%;
    border-top-color: transparent;
    border-bottom-color: var(--dark-navy);
}

/* ── "Did you know?" Tip Card (Dashboard) ── */
.tip-card {
    background: linear-gradient(135deg, #f0f7ff 0%, #e8f0fe 100%);
    border: 1px solid rgba(39, 88, 141, 0.15);
    border-left: 4px solid var(--cfc-blue);
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 16px;
    display: flex;
    align-items: flex-start;
    gap: 10px;
    font-size: 13px;
    color: var(--dark-navy);
    animation: tip-slide-in 0.3s ease;
}
.tip-card-icon {
    font-size: 18px;
    flex-shrink: 0;
    line-height: 1;
}
.tip-card-text {
    flex: 1;
    line-height: 1.5;
}
.tip-card-text strong {
    color: var(--cfc-blue);
}
.tip-card-dismiss {
    background: none;
    border: none;
    color: var(--muted-gray);
    font-size: 16px;
    cursor: pointer;
    padding: 0 2px;
    line-height: 1;
    flex-shrink: 0;
    opacity: 0.6;
}
.tip-card-dismiss:hover {
    opacity: 1;
    color: var(--dark-navy);
}
@keyframes tip-slide-in {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

/* ── Advocacy Readiness Progress Bar ── */
.readiness-bar {
    display: flex;
    align-items: center;
    gap: 10px;
}
.readiness-track {
    flex: 1;
    height: 8px;
    background: var(--gray-200);
    border-radius: 4px;
    overflow: hidden;
}
.readiness-fill {
    height: 100%;
    border-radius: 4px;
    transition: width 0.5s ease;
}
.readiness-fill.score-low { background: var(--alert-red); }
.readiness-fill.score-mid { background: var(--warning-amber); }
.readiness-fill.score-high { background: var(--success-green); }
.readiness-label {
    font-size: 13px;
    font-weight: 700;
    min-width: 28px;
    text-align: right;
}

/* ── Keyboard Shortcuts Modal ── */
.shortcuts-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 8px 16px;
    align-items: center;
}
.shortcuts-grid kbd {
    background: #f0f0f0;
    border: 1px solid #ddd;
    border-bottom: 2px solid #ccc;
    padding: 2px 8px;
    border-radius: 4px;
    font-family: 'SF Mono', Menlo, monospace;
    font-size: 12px;
    color: var(--dark-navy);
    white-space: nowrap;
}
.shortcuts-section {
    grid-column: 1 / -1;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--muted-gray);
    letter-spacing: 0.5px;
    padding-top: 12px;
    border-top: 1px solid var(--light-border);
    margin-top: 4px;
}
.shortcuts-section:first-child {
    padding-top: 0;
    border-top: none;
    margin-top: 0;
}

/* ── Voting Timeline ── */
.vote-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
    padding-left: 24px;
}
.vote-timeline::before {
    content: '';
    position: absolute;
    left: 8px;
    top: 4px;
    bottom: 4px;
    width: 2px;
    background: var(--light-border);
}
.vote-timeline-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 10px 0;
    position: relative;
}
.vote-timeline-dot {
    position: absolute;
    left: -20px;
    top: 14px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 2px solid white;
    box-shadow: 0 0 0 2px var(--light-border);
    flex-shrink: 0;
}
.vote-timeline-dot.passed { background: var(--success-green); box-shadow: 0 0 0 2px var(--success-green); }
.vote-timeline-dot.failed { background: var(--alert-red); box-shadow: 0 0 0 2px var(--alert-red); }
.vote-timeline-dot.pending { background: var(--muted-gray); box-shadow: 0 0 0 2px var(--muted-gray); }
.vote-timeline-content {
    flex: 1;
}
.vote-timeline-header {
    font-size: 14px;
    font-weight: 600;
    color: var(--dark-navy);
}
.vote-timeline-date {
    font-size: 12px;
    color: var(--muted-gray);
    margin-top: 2px;
}
.vote-timeline-result {
    font-size: 13px;
    margin-top: 4px;
}
.vote-timeline-result .vote-pass { color: var(--success-green); font-weight: 600; }
.vote-timeline-result .vote-fail { color: var(--alert-red); font-weight: 600; }

/* ── Roll Call Vote Cards ── */
.roll-call-card {
    border: 1px solid var(--border-gray);
    border-radius: 8px;
    padding: 16px;
    margin-bottom: 12px;
    background: var(--bg-card, #fff);
}
.roll-call-card:last-child { margin-bottom: 0; }
.roll-call-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.roll-call-info {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    flex: 1;
    min-width: 0;
}
.roll-call-date {
    font-size: 13px;
    color: var(--text-secondary, #666);
    font-weight: 500;
}
.roll-call-motion {
    font-size: 12px;
    color: var(--text-secondary, #666);
    font-style: italic;
}
.roll-call-result {
    flex-shrink: 0;
}
.tally-bar {
    display: flex;
    height: 28px;
    border-radius: 6px;
    overflow: hidden;
    background: var(--border-gray);
}
.tally-bar-segment {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    min-width: 28px;
    transition: width 0.3s ease;
}
.tally-bar-yea { background: var(--success-green); }
.tally-bar-nay { background: var(--alert-red); }
.tally-bar-other { background: var(--muted-gray); }
.tally-counts {
    display: flex;
    gap: 16px;
    font-size: 13px;
    margin-top: 8px;
    flex-wrap: wrap;
}
.tally-count-yea { color: var(--success-green); font-weight: 600; }
.tally-count-nay { color: var(--alert-red); font-weight: 600; }
.tally-count-abs { color: var(--warning-amber, #E8A317); font-weight: 600; }
.tally-count-nvr { color: var(--muted-gray); font-weight: 600; }
.roll-call-breakdown {
    margin-top: 12px;
}
.roll-call-breakdown summary {
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: var(--cfc-blue);
    padding: 6px 0;
    user-select: none;
}
.roll-call-breakdown summary:hover {
    text-decoration: underline;
}
.vote-breakdown-table {
    width: 100%;
    margin-top: 8px;
}
.vote-breakdown-table th {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.vote-breakdown-table td {
    padding: 6px 8px;
    font-size: 13px;
}
.roll-call-leg-name {
    font-weight: 600;
    text-decoration: none;
    color: inherit;
}
.roll-call-leg-name:hover {
    color: var(--cfc-blue);
    text-decoration: underline;
}
.roll-call-district {
    font-size: 12px;
    color: var(--text-secondary, #666);
}

/* ── Tour "Take a Tour" button ── */
.tour-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    border: 1px dashed var(--cfc-blue);
    color: var(--cfc-blue);
    padding: 6px 12px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s;
}
.tour-trigger:hover {
    background: var(--bg-hover);
    border-style: solid;
}
.tour-trigger svg, .tour-trigger span.tour-icon {
    font-size: 14px;
}

/* ── Collapsible filter bars on mobile ─────────────────── */

.filter-toggle {
    display: none; /* Hidden on desktop — filters always visible */
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 10px 0;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    color: var(--dark-navy);
}
.filter-toggle-icon {
    font-size: 12px;
    transition: transform 0.2s;
    color: var(--muted-gray);
}
.filter-toggle[aria-expanded="true"] .filter-toggle-icon {
    transform: rotate(180deg);
}
.filter-toggle-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 10px;
    background: var(--cfc-blue);
    color: white;
    font-size: 12px;
    font-weight: 700;
    margin-left: 8px;
}
.filter-toggle-badge:empty {
    display: none;
}

@media (max-width: 768px) {
    .filter-toggle {
        display: flex;
    }
    .filter-body {
        display: none;
    }
    .filter-body.open {
        display: flex;
        flex-wrap: wrap;
        gap: 12px;
        align-items: end;
        padding-bottom: 4px;
    }
}

@media (max-width: 640px) {
    .shortcuts-grid { grid-template-columns: 1fr; }
    .tip-card { flex-direction: column; }
    .vote-timeline { padding-left: 20px; }
}


/* ── Pull to Refresh ──────────────────────────────────── */

.ptr-indicator {
    position: fixed;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50px);
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    background: var(--bg-card, #fff);
    border-radius: 24px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.15);
    z-index: var(--z-overlay-top);
    opacity: 0;
    transition: opacity 0.2s, transform 0.2s;
    font-size: 13px;
    color: var(--text-secondary, #666);
    pointer-events: none;
}
.ptr-indicator.ptr-visible {
    pointer-events: auto;
}
.ptr-spinner {
    width: 18px;
    height: 18px;
    border: 2px solid var(--border-color, #ddd);
    border-top-color: var(--cfc-blue, #002D5C);
    border-radius: 50%;
}
.ptr-indicator.ptr-ready .ptr-spinner {
    border-top-color: #16a34a;
}
.ptr-indicator.ptr-refreshing .ptr-spinner {
    animation: ptr-spin 0.6s linear infinite;
}
@keyframes ptr-spin {
    to { transform: rotate(360deg); }
}
[data-theme="dark"] .ptr-indicator {
    background: var(--bg-card, #1A1A2E);
    box-shadow: 0 2px 12px rgba(0,0,0,0.4);
}


/* ── Network Status Banner ────────────────────────────── */

.network-status-banner {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: var(--z-tour-spotlight);
    text-align: center;
    padding: 8px 16px;
    font-size: 13px;
    font-weight: 600;
    transform: translateY(-100%);
    transition: transform 0.3s ease;
}
.network-status-banner.network-offline {
    transform: translateY(0);
    background: var(--party-rep-dot);
    color: #fff;
}
.network-status-banner.network-online {
    transform: translateY(0);
    background: #16a34a;
    color: #fff;
}
.network-status-banner.network-online span::after {
    content: ' — reconnected';
}


/* ── PWA Install Banner ───────────────────────────────── */

.pwa-install-banner {
    position: fixed;
    bottom: 80px;
    left: 16px;
    right: 16px;
    max-width: 400px;
    margin: 0 auto;
    background: var(--cfc-blue, #002D5C);
    color: #fff;
    border-radius: 12px;
    padding: 14px 16px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    z-index: var(--z-ask-panel);
    box-shadow: 0 4px 20px rgba(0,0,0,0.25);
    transform: translateY(120%);
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
}
.pwa-install-banner.pwa-banner-visible {
    transform: translateY(0);
    opacity: 1;
}
.pwa-install-content {
    display: flex;
    flex-direction: column;
    gap: 2px;
    min-width: 0;
}
.pwa-install-content strong {
    font-size: 15px;
}
.pwa-install-content span {
    font-size: 12px;
    opacity: 0.8;
}
.pwa-install-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.pwa-install-btn {
    background: #C8A951;
    color: #002D5C;
    border: none;
    border-radius: 8px;
    padding: 8px 16px;
    font-weight: 700;
    font-size: 13px;
    cursor: pointer;
    white-space: nowrap;
}
.pwa-install-btn:hover { opacity: 0.9; }
.pwa-dismiss-btn {
    background: transparent;
    border: none;
    color: rgba(255,255,255,0.6);
    font-size: 22px;
    cursor: pointer;
    padding: 4px;
    line-height: 1;
    min-width: 44px;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pwa-dismiss-btn:hover { color: #fff; }

@media (min-width: 769px) {
    .pwa-install-banner { bottom: 24px; }
    .ptr-indicator { display: none; }
}


/* ── Floating Action Button (mobile only) ─────────────── */

.fab-container {
    display: none;
}

@media (max-width: 768px) {
    /* MOB-15: FAB content clearance */
    .main-content { padding-bottom: 80px; }
    .fab-container.fab-active {
        display: block;
        position: fixed;
        bottom: 24px;
        right: 24px;
        z-index: var(--z-fab);
    }
    .fab-toggle {
        width: 56px;
        height: 56px;
        border-radius: 50%;
        background: var(--cfc-blue);
        color: #fff;
        font-size: 28px;
        line-height: 1;
        border: none;
        cursor: pointer;
        box-shadow: 0 4px 16px rgba(0,0,0,0.25);
        transition: transform 0.2s ease, background 0.2s ease;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .fab-toggle:hover,
    .fab-toggle:focus-visible {
        background: var(--dark-navy);
    }
    .fab-toggle.open {
        transform: rotate(45deg);
        background: var(--alert-red);
    }
    .fab-backdrop {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.3);
        z-index: var(--z-modal-top);
    }
    .fab-backdrop.visible {
        display: block;
    }
    .fab-menu {
        position: absolute;
        bottom: 68px;
        right: 0;
        display: flex;
        flex-direction: column;
        gap: 10px;
        align-items: flex-end;
        opacity: 0;
        transform: translateY(10px);
        pointer-events: none;
        transition: opacity 0.2s ease, transform 0.2s ease;
    }
    .fab-menu.open {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }
    .fab-action {
        display: flex;
        align-items: center;
        gap: 10px;
        padding: 10px 16px;
        background: #fff;
        border: none;
        border-radius: 24px;
        box-shadow: 0 2px 8px rgba(0,0,0,0.15);
        font-size: 14px;
        font-weight: 500;
        color: var(--text-primary);
        white-space: nowrap;
        min-height: 44px;
        cursor: pointer;
        transition: background 0.15s;
    }
    .fab-action:hover,
    .fab-action:focus-visible {
        background: var(--bg-hover);
    }
    .fab-action-icon {
        font-size: 18px;
        flex-shrink: 0;
        width: 24px;
        text-align: center;
    }
}

/* ── Dark Mode ────────────────────────────────────────────────────────── */

/* Dark mode toggle button */
.dark-mode-toggle {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 8px 16px;
    background: none;
    border: none;
    cursor: pointer;
    font-size: 14px;
    color: inherit;
    text-align: left;
    min-height: 44px;
}
.dark-mode-toggle:hover {
    background: var(--bg-hover);
}
.dark-mode-toggle .toggle-icon { font-size: 16px; }

/* ── Dashboard hearings grid ──────────────────────────────────────── */
.dash-hearings-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
@media (max-width: 768px) {
    .dash-hearings-grid { grid-template-columns: 1fr; }
    #dash-cards-grid > * { grid-column: span 1 !important; }
    .dash-card .card-drag-handle { display: none; }
    .dash-card .card-header { padding: 10px 14px; font-size: 14px; gap: 6px; }
    .dash-card .badge { font-size: 10px !important; padding: 1px 6px !important; }
}

/* ── Hearing components ────────────────────────────────────────────── */
.hearing-card {
    padding: 12px;
    margin-bottom: 8px;
    border-radius: 8px;
    border: 1px solid var(--light-border);
}
.hearing-card:last-child { margin-bottom: 0; }
.hearing-normal { background: var(--gray-50); }
.hearing-soon   { background: var(--tint-warning-bg); border-color: #fcd34d; }
.hearing-urgent  { background: var(--tint-error-bg); border-color: #fca5a5; }
.hearing-card-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 8px;
}
.hearing-card-info { flex: 1; min-width: 0; }
.hearing-card-committee {
    font-weight: 700;
    font-size: 14px;
    color: var(--dark-navy);
    line-height: 1.3;
}
.hearing-card-datetime {
    font-size: 13px;
    color: var(--text-secondary, #4b5563);
    margin-top: 2px;
}
.hearing-card-meta {
    font-size: 12px;
    color: var(--muted-gray);
    margin-top: 2px;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 12px;
}
.hearing-card-countdown { flex-shrink: 0; }
.hearing-countdown {
    display: inline-block;
    min-width: 44px;
    padding: 2px 8px;
    border-radius: 10px;
    font-size: 12px;
    font-weight: bold;
    text-align: center;
    color: white;
}
.hc-urgent  { background: var(--party-rep-dot); }
.hc-soon    { background: var(--hearing-soon); }
.hc-week    { background: var(--party-dem-dot); }
.hc-later   { background: var(--tint-neutral-text); }
.hc-removed { background: var(--hearing-removed); }
.hearing-removed { border-left: 3px solid var(--hearing-removed) !important; background: #faf5ff; }
[data-theme="dark"] .hearing-removed { background: #2d1b4e; }
.hearing-hidden { border-left: 3px solid #dc2626 !important; background: #fef2f2; }
[data-theme="dark"] .hearing-hidden { background: #3b1111; }
.hearing-card-actions {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: 8px;
}
.hearing-card-actions .btn-sm { font-size: 12px; }

/* ── Dark theme variable overrides ──────────────────────────────────── */
[data-theme="dark"] {
    /* Core palette — NOTE: --cfc-navy and --dark-navy intentionally invert
       from dark (#002D5C) to light (#E2E8F0) in dark mode. These vars are used
       for heading/primary text, which must be light-on-dark. The names are
       historical; treat them as "primary heading color", not literal navy. */
    --cfc-blue: #4A90D9;
    --cfc-gold: #F4B824;
    --cfc-navy: #E2E8F0;
    --cfc-red: #F87171;
    --dark-navy: #E2E8F0;
    --alert-red: #F87171;
    --success-green: #34D399;
    --warning-amber: #FBBF24;
    --error-red: #F87171;
    --info-blue: #6BA8E8;

    /* Tinted backgrounds (dark mode) */
    --tint-success-bg: #0D2818;
    --tint-success-text: #34D399;
    --tint-error-bg: #2D1111;
    --tint-error-text: #F87171;
    --tint-warning-bg: #2E2208;
    --tint-warning-text: #FBBF24;
    --tint-info-bg: #0D1B2E;
    --tint-info-text: #6BA8E8;
    --tint-purple-bg: #1E0D2E;
    --tint-purple-text: #A78BFA;
    --tint-neutral-bg: #1E1E30;
    --tint-neutral-text: #9CA3AF;

    /* Party (dark mode) */
    --party-dem-bg: #0D1B2E;
    --party-dem-text: #6BA8E8;
    --party-rep-bg: #2D1111;
    --party-rep-text: #F87171;
    --party-ind-bg: #1D0D2E;
    --party-ind-text: #C084FC;

    /* Grays (dark mode) */
    --gray-100: #1E1E30;
    --gray-200: #2A2A40;
    --gray-300: #3A3A4E;
    --gray-400: #6b7280;
    --gray-500: #9CA3AF;

    /* Backgrounds */
    --bg-white: #1A1A2E;
    --bg-warm: #0F0F1A;
    --bg-card: #1E1E30;
    --bg-hover: #2A2A40;
    --bg-subtle: #1E1E30;

    /* Text */
    --text-primary: #E2E8F0;
    --text-secondary: #A0AEC0;
    --muted-gray: #718096;
    --text-on-dark: #E2E8F0;
    --text-link-hover: #6BA8E8;

    /* Borders & shadows */
    --light-border: #2D2D44;
    --card-border: #2D2D44;
    --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.3);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
    --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.4);

    /* Hearing urgency (dark mode) */
    --hearing-urgent: #ef4444;
    --hearing-soon: #f59e0b;
    --hearing-week: #3b82f6;
    --hearing-removed: #a78bfa;

    /* Absence (dark mode) */
    --absence-legislative-bg: #1A2A40;
    --absence-legislative-text: #64B5F6;
    --absence-personal-bg: #2A1A0A;
    --absence-personal-text: #FFB74D;
    --absence-illness-bg: #2A0A0A;
    --absence-illness-text: #EF9A9A;
    --absence-leave-bg: #1A0A2A;
    --absence-leave-text: #CE93D8;
    --absence-bereavement-bg: #1A1A2A;
    --absence-bereavement-text: #90A4AE;

    color-scheme: dark;
}

/* Body & base */
[data-theme="dark"] body {
    background: var(--bg-warm);
    color: var(--text-primary);
}

/* Links */
[data-theme="dark"] a { color: var(--cfc-blue); }
[data-theme="dark"] a:hover { color: #6BA8E8; }

/* Cards */
[data-theme="dark"] .card {
    background: var(--bg-card);
    border-color: var(--light-border);
    box-shadow: var(--shadow-sm);
}
[data-theme="dark"] .card-header {
    color: var(--text-primary);
}

/* Tables */
[data-theme="dark"] th { color: var(--muted-gray); }
[data-theme="dark"] td { color: var(--text-primary); }
[data-theme="dark"] tr:hover { background: rgba(74, 144, 217, 0.06); }
[data-theme="dark"] .clickable-row:hover { background: rgba(74, 144, 217, 0.08); }
[data-theme="dark"] .table-responsive.has-scroll-right::after {
    background: linear-gradient(to right, rgba(30,30,48,0), rgba(30,30,48,0.9));
}

/* Navbar — keep dark gradient but adjust */
[data-theme="dark"] .navbar {
    background: linear-gradient(135deg, #0A0A18 0%, #1A1A2E 100%);
    border-bottom: 1px solid #2D2D44;
}

/* Footer */
[data-theme="dark"] .app-footer {
    background: #0A0A18;
    color: #A0AEC0;
}

/* Form inputs */
[data-theme="dark"] input,
[data-theme="dark"] select,
[data-theme="dark"] textarea {
    background: #16162B;
    color: var(--text-primary);
    border-color: var(--light-border);
}
[data-theme="dark"] input:focus,
[data-theme="dark"] select:focus,
[data-theme="dark"] textarea:focus {
    border-color: var(--cfc-blue);
    outline-color: var(--cfc-blue);
}
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
    color: var(--muted-gray);
}

/* Buttons */
[data-theme="dark"] .btn-primary {
    background: var(--cfc-blue);
    color: #fff;
}
[data-theme="dark"] .btn-primary:hover {
    background: #3A7BC8;
}
[data-theme="dark"] .btn-outline {
    color: var(--cfc-blue);
    border-color: var(--cfc-blue);
}
[data-theme="dark"] .btn-outline:hover {
    background: var(--cfc-blue);
    color: #fff;
}
[data-theme="dark"] .btn-secondary {
    background: var(--cfc-gold);
    color: #0F0F1A;
}

/* Alert variants */
[data-theme="dark"] .alert-error {
    background: #2D1111;
    color: #F87171;
    border-color: #5C1A1A;
}
[data-theme="dark"] .alert-success {
    background: #0D2818;
    color: #34D399;
    border-color: #1A5C35;
}
[data-theme="dark"] .alert-info {
    background: #0D1B2E;
    color: #6BA8E8;
    border-color: #1A3A5C;
}
[data-theme="dark"] .alert-warning {
    background: #2E2208;
    color: #FBBF24;
    border-color: #5C4A0A;
}

/* Badge variants — muted dark backgrounds */
[data-theme="dark"] .badge-completed { background: #0D2818; color: #34D399; }
[data-theme="dark"] .badge-running { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] .badge-pending { background: #1E1E30; color: var(--muted-gray); }
[data-theme="dark"] .badge-failed { background: #2D1111; color: #F87171; }
[data-theme="dark"] .badge-draft { background: #1E1E30; color: #A0AEC0; }
[data-theme="dark"] .badge-pending-approval { background: #2E2208; color: #FBBF24; }
[data-theme="dark"] .badge-under-review { background: #1E0D2E; color: #A78BFA; }
[data-theme="dark"] .badge-reviewed { background: #0D2818; color: #34D399; }
[data-theme="dark"] .badge-approved { background: #0D2818; color: #34D399; }
[data-theme="dark"] .badge-published { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] .badge-unknown { background: #1E1E30; color: var(--muted-gray); }

/* Priority badges */
[data-theme="dark"] .badge-priority-low { background: #1E1E30; color: var(--muted-gray); }
[data-theme="dark"] .badge-priority-normal { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] .badge-priority-high { background: #2E2208; color: #FBBF24; }
[data-theme="dark"] .badge-priority-urgent { background: #5C1A1A; color: #F87171; }

/* Task badges */
[data-theme="dark"] .task-badge-in_progress { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] .task-badge-waiting_approval { background: #2E2208; color: #FBBF24; }
[data-theme="dark"] .task-badge-done_editing { background: #1e1036; color: #c4b5fd; }

/* Stance badges (already on CSS vars, but the hardcoded ones) */
[data-theme="dark"] .badge-critical { background: #5C1A1A; color: #F87171; }
[data-theme="dark"] .badge-high { background: #3D3006; color: #F4B824; }

/* Party badges */
[data-theme="dark"] .badge-party-democratic { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] .badge-party-republican { background: #2D1111; color: #F87171; }
[data-theme="dark"] .badge-party-independent { background: #1D0D2E; color: #C084FC; }

/* Sponsor chips */
[data-theme="dark"] .sponsor-chip { background: #1E1E30; border-color: #2A2A40; }
[data-theme="dark"] .sponsor-chip a { color: #93C5FD; }
[data-theme="dark"] .witness-row { background: #1E1E30; border-left-color: #5B8DB8; }
[data-theme="dark"] .witness-edit-form { background: #1E1E30; border-color: #2A2A40; }
[data-theme="dark"] .witness-autocomplete-dropdown { background: #1A1A2E; border-color: #2A2A40; }
[data-theme="dark"] .witness-dd-item:hover { background: #252540; }
[data-theme="dark"] .sponsor-group-label { color: #94A3B8; }
[data-theme="dark"] .sponsor-group-primary { color: #93C5FD; }
[data-theme="dark"] .sponsor-chamber-badge { background: #2A2A40; color: #94A3B8; }

/* Roll call cards */
[data-theme="dark"] .roll-call-card { background: #1A1A2E; border-color: #2A2A40; }
[data-theme="dark"] .roll-call-date { color: #94A3B8; }
[data-theme="dark"] .roll-call-motion { color: #94A3B8; }
[data-theme="dark"] .roll-call-leg-name { color: #E2E8F0; }
[data-theme="dark"] .roll-call-leg-name:hover { color: #93C5FD; }
[data-theme="dark"] .roll-call-district { color: #94A3B8; }
[data-theme="dark"] .roll-call-breakdown summary { color: #93C5FD; }
[data-theme="dark"] .tally-bar { background: #2A2A40; }

/* Vote cells */
[data-theme="dark"] .vote-aye { background: #0D2818; color: #34D399; }
[data-theme="dark"] .vote-nay { background: #2D1111; color: #F87171; }
[data-theme="dark"] .vote-absent { background: #2E2208; color: #FBBF24; }

/* Dashboard overdue row */
[data-theme="dark"] .dash-row-overdue { background: #2D1111; }

/* Search autocomplete */
[data-theme="dark"] .search-ac-dropdown {
    background: var(--bg-card);
    border-color: var(--light-border);
}
[data-theme="dark"] .search-ac-item { border-bottom-color: var(--light-border); }
[data-theme="dark"] .search-ac-item:hover,
[data-theme="dark"] .search-ac-item.active { background: var(--bg-hover); }
[data-theme="dark"] .search-ac-title { color: var(--muted-gray); }

/* Toast notifications */
[data-theme="dark"] .toast { background: var(--bg-card); color: var(--text-primary); }
[data-theme="dark"] .toast-success { background: #065f46; }
[data-theme="dark"] .toast-error { background: #991b1b; }
[data-theme="dark"] .toast-warning { background: #92400e; color: #fff; }
[data-theme="dark"] .toast-info { background: #1e40af; }

/* Filter row / alternating section backgrounds */
[data-theme="dark"] .filter-bar,
[data-theme="dark"] .filter-row {
    background: var(--bg-card);
    border-color: var(--light-border);
}

/* Walkthrough & readiness cards */
[data-theme="dark"] .readiness-card {
    background: var(--bg-card);
}

/* Progress bars */
[data-theme="dark"] .progress-bar-bg,
[data-theme="dark"] .progress-bg {
    background: #2D2D44;
}

/* Keyboard shortcut badges */
[data-theme="dark"] kbd {
    background: #2D2D44;
    border-color: #3D3D5C;
    color: var(--text-primary);
}

/* Modal overlay */
[data-theme="dark"] .modal-backdrop { background: rgba(0, 0, 0, 0.7); }
[data-theme="dark"] .modal-content,
[data-theme="dark"] .modal {
    background: var(--bg-card);
    border-color: var(--light-border);
    color: var(--text-primary);
}

/* Capitol nav dropdown */
[data-theme="dark"] .nav-dropdown-menu {
    background: var(--bg-card);
    border-color: var(--light-border);
}
[data-theme="dark"] .nav-dropdown-menu a {
    color: var(--text-primary) !important;
}
[data-theme="dark"] .nav-dropdown-menu a:hover {
    background: var(--bg-hover) !important;
    color: var(--text-primary) !important;
}
[data-theme="dark"] .nav-dropdown-menu a.active {
    background: rgba(99, 102, 241, 0.15) !important;
    color: #818cf8 !important;
}
[data-theme="dark"] .nav-dropdown-menu hr {
    border-color: var(--light-border);
}
[data-theme="dark"] .nav-badge {
    background: var(--party-rep-dot);
}

/* User menu dropdown */
[data-theme="dark"] .user-menu-dropdown {
    background: var(--bg-card);
    border-color: var(--light-border);
}
[data-theme="dark"] .user-menu-dropdown a {
    color: var(--text-primary);
}
[data-theme="dark"] .user-menu-dropdown a:hover {
    background: var(--bg-hover);
}
[data-theme="dark"] .dropdown-logout-btn {
    color: var(--text-primary) !important;
}
[data-theme="dark"] .dropdown-logout-btn:hover {
    background: var(--bg-hover) !important;
}

/* ── Slide-out Ask Panel ─────────────────────────────── */
.ask-fab {
    position: fixed;
    bottom: 80px;
    right: 20px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--brand-blue, #27588D);
    color: white;
    border: none;
    cursor: pointer;
    box-shadow: 0 2px 12px rgba(0,0,0,0.2);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: var(--z-ask-fab);
    transition: transform 0.2s, background 0.2s;
}
.ask-fab:hover { transform: scale(1.08); background: #1d4a73; }
.ask-fab.active { background: var(--tint-error-text); transform: rotate(90deg); }

.ask-panel-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.3);
    z-index: var(--z-ask-panel);
}
.ask-panel-backdrop.open { display: block; }

.ask-panel {
    position: fixed;
    top: 0;
    right: -420px;
    width: 400px;
    max-width: 90vw;
    height: 100vh;
    background: var(--bg-card, white);
    border-left: 1px solid var(--border-color, #e2e8f0);
    box-shadow: -4px 0 20px rgba(0,0,0,0.1);
    z-index: var(--z-ask-panel);
    display: flex;
    flex-direction: column;
    transition: right 0.25s ease;
}
.ask-panel.open { right: 0; }

.ask-panel-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    border-bottom: 1px solid var(--border-color, #e2e8f0);
    background: var(--brand-blue, #27588D);
    color: white;
}
.ask-panel-title { font-weight: 600; font-size: 0.95rem; }
.ask-panel-close {
    background: none;
    border: none;
    color: white;
    font-size: 1.4rem;
    cursor: pointer;
    padding: 0 4px;
    line-height: 1;
    opacity: 0.8;
}
.ask-panel-close:hover { opacity: 1; }

.ask-panel-messages {
    flex: 1;
    overflow-y: auto;
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.ask-panel-empty {
    text-align: center;
    color: var(--text-secondary, #888);
    font-size: 0.85rem;
    margin-top: 40px;
}

.ask-panel-msg {
    padding: 8px 12px;
    border-radius: 10px;
    font-size: 0.84rem;
    line-height: 1.5;
    word-wrap: break-word;
    max-width: 90%;
}
.ask-panel-msg.user {
    align-self: flex-end;
    background: var(--brand-blue, #27588D);
    color: white;
    border-bottom-right-radius: 3px;
}
.ask-panel-msg.assistant {
    align-self: flex-start;
    background: var(--bg-hover, #f0f4f8);
    border: 1px solid var(--border-color, #e2e8f0);
    border-bottom-left-radius: 3px;
    color: var(--text-primary, #333);
}
.ask-panel-msg.error {
    align-self: center;
    background: var(--tint-error-bg);
    border: 1px solid #fca5a5;
    color: var(--tint-error-text);
    font-size: 0.8rem;
}

.ask-panel-input-row {
    display: flex;
    gap: 6px;
    padding: 10px 12px;
    border-top: 1px solid var(--border-color, #e2e8f0);
}
.ask-panel-input-row textarea {
    flex: 1;
    padding: 8px 12px;
    border: 1px solid var(--border-color, #ccc);
    border-radius: 6px;
    font-size: 0.85rem;
    background: var(--bg-card, white);
    color: var(--text-primary, #333);
    resize: none;
    min-height: 36px;
    max-height: 100px;
    overflow-y: hidden;
    font-family: inherit;
    line-height: 1.4;
}
.ask-panel-input-row textarea:focus {
    outline: none;
    border-color: var(--brand-blue, #27588D);
}
.ask-panel-input-row button {
    padding: 8px 14px;
    background: var(--brand-blue, #27588D);
    color: white;
    border: none;
    border-radius: 6px;
    font-size: 1rem;
    cursor: pointer;
    min-height: 36px;
}
.ask-panel-input-row button:hover { background: #1d4a73; }
.ask-panel-input-row button:disabled { opacity: 0.5; cursor: not-allowed; }

/* Dark mode for Ask panel */
[data-theme="dark"] .ask-fab { box-shadow: 0 2px 12px rgba(0,0,0,0.5); }
[data-theme="dark"] .ask-panel {
    background: var(--bg-card, #1E1E30);
    border-left-color: #2a2a3e;
    box-shadow: -4px 0 20px rgba(0,0,0,0.4);
}
[data-theme="dark"] .ask-panel-msg.assistant {
    background: #2a2a3e;
    border-color: #3a3a5e;
}
[data-theme="dark"] .ask-panel-msg.error {
    background: #2d1b1b;
    border-color: #7f1d1d;
    color: #fca5a5;
}

/* Hide Ask FAB + panel on mobile — too crowded */
@media (max-width: 768px) {
    .ask-fab { display: none !important; }
    .ask-panel, .ask-panel-backdrop { display: none !important; }
}

/* FAB (mobile) */
[data-theme="dark"] .fab-action {
    background: var(--bg-card);
    color: var(--text-primary);
    box-shadow: 0 2px 8px rgba(0,0,0,0.4);
}
[data-theme="dark"] .fab-action:hover { background: var(--bg-hover); }

/* Misc hardcoded bg overrides */
[data-theme="dark"] .stat-card,
[data-theme="dark"] .stats-grid .stat-item,
[data-theme="dark"] .collapsible-header,
[data-theme="dark"] .accordion-header {
    background: var(--bg-card);
    color: var(--text-primary);
}

/* Select option text in dark mode */
[data-theme="dark"] option {
    background: var(--bg-card);
    color: var(--text-primary);
}

/* pre and code blocks */
[data-theme="dark"] pre,
[data-theme="dark"] code {
    background: #16162B;
    color: #E2E8F0;
}

/* HR */
[data-theme="dark"] hr { border-color: var(--light-border); }

/* Hearing components */
[data-theme="dark"] .hearing-normal { background: var(--bg-hover); border-color: var(--light-border); }
[data-theme="dark"] .hearing-soon   { background: #422006; border-color: #92400e; }
[data-theme="dark"] .hearing-urgent  { background: #450a0a; border-color: #991b1b; }
[data-theme="dark"] .hearing-card-committee { color: var(--text-primary); }
[data-theme="dark"] .hearing-card-datetime { color: var(--text-secondary); }
[data-theme="dark"] .hearing-card         { border-color: var(--light-border); }
[data-theme="dark"] .hearing-normal       { background: var(--bg-card); }
[data-theme="dark"] .hearing-soon         { background: rgba(217, 119, 6, 0.12); border-color: #92400e; }
[data-theme="dark"] .hearing-urgent       { background: rgba(220, 38, 38, 0.12); border-color: #991b1b; }

/* Images in dark mode — subtle brightness reduction for comfort */
[data-theme="dark"] img:not(.navbar-brand img):not([src*="logo"]) {
    opacity: 0.92;
}

/* ===== Opposing Org Position Tracker (v8.1) ===== */
.org-chip {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 4px 10px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 500;
    background: #f5f5f5;
    border: 1px solid #e0e0e0;
    white-space: nowrap;
}
.org-chip-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #999;
    flex-shrink: 0;
}
.org-dot-support .org-chip-dot { background: var(--success-green); }
.org-dot-oppose .org-chip-dot { background: var(--alert-red); }
.org-dot-neutral .org-chip-dot { background: var(--warning-amber); }
.org-dot-unknown .org-chip-dot { background: #999; }
.org-dot-support { border-color: #b7e1cd; background: #edf7f2; }
.org-dot-oppose { border-color: #f5c6cb; background: #fdf0f1; }
.org-dot-neutral { border-color: #fde68a; background: #fefce8; }
.org-dot-unknown { border-color: #e0e0e0; background: #f5f5f5; }
.org-chip-name { font-weight: 600; color: var(--text-primary); }
.org-chip-pos { color: var(--text-secondary); font-size: 12px; }
.org-chip-link {
    color: var(--cfc-blue);
    text-decoration: none;
    font-size: 13px;
    margin-left: 2px;
}
.org-chip-link:hover { text-decoration: underline; }
.org-chip-edit {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 12px;
    color: var(--text-secondary);
    padding: 0 2px;
    line-height: 1;
}
.org-chip-edit:hover { color: var(--cfc-blue); }

/* Dark mode — org positions */
[data-theme="dark"] .org-chip { background: #2a2a3e; border-color: #3a3a50; }
[data-theme="dark"] .org-dot-support { border-color: #065f46; background: #1a2e2a; }
[data-theme="dark"] .org-dot-oppose { border-color: #7f1d1d; background: #2d1a1a; }
[data-theme="dark"] .org-dot-neutral { border-color: #78350f; background: #2d2a1a; }
[data-theme="dark"] .org-dot-unknown { border-color: #3a3a50; background: #2a2a3e; }
[data-theme="dark"] .org-chip-name { color: var(--text-primary); }
[data-theme="dark"] .org-chip-pos { color: var(--text-secondary); }
[data-theme="dark"] .org-chip-link { color: #60a5fa; }
[data-theme="dark"] .org-chip-edit { color: var(--text-secondary); }
[data-theme="dark"] .org-chip-edit:hover { color: #60a5fa; }
[data-theme="dark"] .org-edit-form { background: #1e1e30 !important; border-color: #3a3a50 !important; }

/* ===== Vote Alert Badges & Row Tinting (v8.1) ===== */
.badge-alert-defection {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    color: white;
    background: var(--alert-red);
}
.badge-alert-alignment {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    color: white;
    background: var(--success-green);
}
.badge-alert-absence {
    display: inline-block;
    padding: 2px 8px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 600;
    color: white;
    background: var(--warning-amber);
}
.alert-row-defection { background: var(--tint-error-bg); }
.alert-row-dem_alignment { background: var(--tint-success-bg); }
.alert-row-notable_absence { background: var(--tint-warning-bg); }
.alert-row-committee { border-left: 3px solid var(--party-ind-dot); }
.vote-badge { display: inline-block; }
.vote-aye { color: white; background: var(--success-green); }
.vote-nay { color: white; background: var(--alert-red); }
.vote-abs { color: white; background: var(--warning-amber); }
.vote-nvr { color: white; background: var(--tint-neutral-text); }
.badge-scope-floor {
    display: inline-block; padding: 2px 8px; border-radius: 4px;
    font-size: 12px; font-weight: 600; color: white; background: #3b82f6;
}
.badge-scope-committee {
    display: inline-block; padding: 2px 8px; border-radius: 4px;
    font-size: 12px; font-weight: 600; color: white; background: var(--party-ind-dot);
}

/* Dark mode — vote alerts */
[data-theme="dark"] .alert-row-defection { background: #2d1a1a; }
[data-theme="dark"] .alert-row-dem_alignment { background: #1a2d1a; }
[data-theme="dark"] .alert-row-notable_absence { background: #2d2a1a; }
[data-theme="dark"] .alert-row-committee { border-left-color: #a78bfa; }
[data-theme="dark"] .alert-stat-card { border-color: var(--light-border); }

/* ===== Hearing Prep Brief (v8.1) ===== */
.prep-member-table th { font-size: 12px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--muted-gray); }
.prep-role-badge { display: inline-block; font-size: 12px; font-weight: 600; padding: 2px 8px; border-radius: 4px; }
.prep-role-chair { background: #002D5C; color: #fff; }
.prep-role-vice { background: #e0e7ff; color: #3730a3; }
.prep-score { font-size: 13px; font-weight: 700; }
.prep-score-high { color: var(--success-green); }
.prep-score-mid { color: var(--warning-amber); }
.prep-score-low { color: var(--alert-red); }
.prep-swing { display: inline-block; font-size: 12px; font-weight: 600; padding: 2px 8px; border-radius: 10px; }
.prep-swing-high { background: var(--tint-error-bg); color: var(--tint-error-text); border: 1px solid #fecaca; }
.prep-swing-medium { background: var(--tint-warning-bg); color: var(--tint-warning-text); border: 1px solid #fde68a; }
.prep-swing-low { background: #f0f9ff; color: #075985; border: 1px solid #bae6fd; }
.prep-swing-none { background: #f5f5f5; color: var(--gray-400); border: 1px solid var(--gray-200); }
.prep-callout { border-left: 4px solid var(--warning-amber); background: var(--tint-warning-bg); }
.prep-talking-points { margin: 0; padding-left: 20px; }
.prep-talking-points li { font-size: 13px; line-height: 1.7; margin-bottom: 8px; color: var(--text-primary); }

/* Dark mode — prep briefs */
[data-theme="dark"] .prep-role-chair { background: #1e3a5f; }
[data-theme="dark"] .prep-role-vice { background: #2e2b5f; color: #a5b4fc; }
[data-theme="dark"] .prep-swing-high { background: #2d1a1a; color: #fca5a5; border-color: #7f1d1d; }
[data-theme="dark"] .prep-swing-medium { background: #2d2a1a; color: #fcd34d; border-color: #78350f; }
[data-theme="dark"] .prep-swing-low { background: #1a2636; color: #7dd3fc; border-color: #0c4a6e; }
[data-theme="dark"] .prep-swing-none { background: #2a2a3e; color: #6b7280; border-color: #3a3a50; }
[data-theme="dark"] .prep-callout { background: #2d2a1a; border-left-color: #d97706; }
[data-theme="dark"] .prep-callout h3 { color: #fcd34d; }
[data-theme="dark"] .prep-callout p { color: #fde68a; }

/* ── Social Content Pipeline ─────────────────────────────────────────── */
.social-platform-badge { font-size: 13px; font-weight: 600; padding: 3px 12px; border-radius: 12px; }
.platform-twitter { background: #000; color: #fff; }
.platform-facebook { background: var(--platform-facebook); color: #fff; }
.platform-instagram { background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); color: #fff; }

.social-stat-pill { display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px; border-radius: 20px; font-size: 13px; font-weight: 600; text-decoration: none; border: 1px solid var(--border-color, #e5e7eb); background: var(--bg-card, #fff); color: var(--text-secondary, #6b7280); transition: all 0.15s; }
.social-stat-pill:hover { border-color: var(--cfc-blue, #002D5C); color: var(--cfc-blue, #002D5C); }
.social-stat-pill.active { background: var(--cfc-blue, #002D5C); color: #fff; border-color: var(--cfc-blue, #002D5C); }

.social-draft-card { padding: 16px 20px; margin-bottom: 12px; border-left: 3px solid var(--border-color, #e5e7eb); transition: border-color 0.15s; }
.social-draft-card:hover { border-left-color: var(--cfc-blue, #002D5C); }
.social-draft-card .draft-preview { font-size: 14px; line-height: 1.6; color: var(--text-primary, #111827); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }

.social-char-bar { width: 100%; height: 5px; background: var(--bg-hover, #f3f4f6); border-radius: 3px; overflow: hidden; }
.social-char-bar-fill { height: 100%; border-radius: 3px; transition: width 0.3s; }

/* Dark mode */
[data-theme="dark"] .social-stat-pill { background: var(--bg-card, #1E1E30); border-color: var(--border-color, #2d2d44); color: var(--text-secondary, #9ca3af); }
[data-theme="dark"] .social-stat-pill:hover { border-color: #3b82f6; color: #93c5fd; }
[data-theme="dark"] .social-stat-pill.active { background: #1e3a5f; color: #93c5fd; border-color: #3b82f6; }
[data-theme="dark"] .social-draft-card { border-left-color: var(--border-color, #2d2d44); }
[data-theme="dark"] .social-draft-card:hover { border-left-color: #3b82f6; }
[data-theme="dark"] .social-draft-card .draft-preview { color: var(--text-primary, #E2E8F0); }
[data-theme="dark"] .social-char-bar { background: var(--bg-hover, #2a2a3e); }
[data-theme="dark"] .platform-twitter { background: #1a1a2e; color: #e2e8f0; border: 1px solid #3a3a50; }
[data-theme="dark"] .platform-facebook { border: 1px solid #4A4A5A; }
[data-theme="dark"] .platform-instagram { border: 1px solid #4A4A5A; }

/* ── Trend-to-Content Pipeline ─────────────────────────── */
.trend-banner-container { border: 2px solid var(--party-rep-dot); border-radius: 10px; background: linear-gradient(135deg, #FEF2F2, #FFF7ED); padding: 0; margin-bottom: 20px; overflow: hidden; }
.trend-banner-container.collapsed .trend-banner-body { display: none; }
.trend-banner-header { display: flex; align-items: center; gap: 10px; padding: 10px 16px; background: linear-gradient(90deg, var(--party-rep-dot)10, #F59E0B10); border-bottom: 1px solid #FCA5A520; }
.trend-banner-icon { font-size: 20px; }
.trend-banner-count { font-size: 12px; color: var(--text-secondary, #6b7280); margin-left: auto; }
.trend-banner-toggle { background: none; border: none; cursor: pointer; font-size: 14px; color: var(--text-secondary); padding: 4px 8px; }
.trend-banner-container.collapsed .trend-banner-toggle { transform: rotate(180deg); }
.trend-banner-body { padding: 4px 0; }
.trend-card { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 10px 16px; border-bottom: 1px solid #FCA5A515; }
.trend-card:last-child { border-bottom: none; }
.trend-card-left { display: flex; gap: 12px; align-items: flex-start; min-width: 0; flex: 1; }
.trend-card-info { min-width: 0; }
.trend-topic { font-weight: 600; font-size: 14px; display: block; }
.trend-meta { font-size: 12px; color: var(--text-secondary, #6b7280); display: block; margin-top: 2px; }
.trend-meta a { color: var(--cfc-blue, #1a5276); }
.trend-headlines { margin-top: 4px; }
.trend-headline { display: block; font-size: 12px; color: var(--text-secondary, #888); font-style: italic; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 400px; }
.trend-card-actions { display: flex; gap: 6px; flex-shrink: 0; align-items: center; }
.trend-heat-badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px; border-radius: 12px; font-size: 12px; font-weight: 700; white-space: nowrap; }
.trend-heat-critical { background: #FEE2E2; color: var(--tint-error-text); }
.trend-heat-high { background: var(--tint-warning-bg); color: var(--tint-warning-text); }
.trend-heat-moderate { background: var(--tint-info-bg); color: var(--tint-info-text); }

/* Mobile */
@media (max-width: 768px) {
  .trend-card { flex-direction: column; gap: 8px; }
  .trend-card-actions { align-self: flex-end; }
  .trend-headline { max-width: 250px; }
}

/* Dark mode: trends */
[data-theme="dark"] .trend-banner-container { border-color: #7F1D1D; background: linear-gradient(135deg, #1A1A2E, #1E1E30); }
[data-theme="dark"] .trend-banner-header { background: linear-gradient(90deg, #7F1D1D20, #92400E20); border-bottom-color: #7F1D1D30; }
[data-theme="dark"] .trend-card { border-bottom-color: #2d2d44; }
[data-theme="dark"] .trend-heat-critical { background: #7F1D1D; color: #FCA5A5; }
[data-theme="dark"] .trend-heat-high { background: #78350F; color: #FDE68A; }
[data-theme="dark"] .trend-heat-moderate { background: #1E3A5F; color: #93C5FD; }
[data-theme="dark"] .trend-topic { color: var(--text-primary, #E2E8F0); }

/* Dark mode: email preview iframes */
[data-theme="dark"] iframe { border: 2px solid var(--card-border, #2d2d44); border-radius: 8px; box-shadow: 0 0 20px rgba(0,0,0,0.3); }

/* Dark mode: navbar logo brightness */
[data-theme="dark"] .navbar-brand img { filter: brightness(1.1); }
/* Dark mode: show email preview light-mode note */
.preview-light-note { display: none !important; }
[data-theme="dark"] .preview-light-note { display: block !important; }

/* Navbar theme toggle button */
.nav-theme-toggle { background:none; border:none; color:white; cursor:pointer; font-size:18px; padding:4px 8px; opacity:0.7; transition:opacity 0.15s; }
.nav-theme-toggle:hover { opacity:1; }

/* ══════════════════════════════════════════════════════════════
   Shared Interactive Components (used by Dashboard + Bill Detail)
   ══════════════════════════════════════════════════════════════ */

/* ── Jump-to Quick Nav ── */
.jump-nav {
    display: flex;
    gap: 6px;
    padding: 8px 0;
    margin-bottom: 12px;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}
.jump-nav::-webkit-scrollbar { display: none; }
.jump-chip {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 500;
    background: var(--bg-warm);
    border: 1px solid var(--light-border);
    color: var(--dark-navy);
    cursor: pointer;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all 0.15s;
}
.jump-chip:hover {
    background: var(--cfc-blue);
    color: white;
    border-color: var(--cfc-blue);
}
.jump-dot {
    display: inline-block;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    margin-right: 6px;
    flex-shrink: 0;
}
.jump-dot-overview { background: var(--success-green); }
.jump-dot-legislative { background: var(--cfc-blue); }
.jump-dot-research { background: var(--cfc-gold); }
.jump-dot-outreach { background: var(--gray-400); }
.jump-dot-action { background: var(--cfc-blue); }
.jump-dot-data { background: var(--gray-400); }
@media (max-width: 768px) {
    .jump-nav {
        overflow-x: unset;
        flex-wrap: wrap;
        gap: 6px;
    }
    .jump-chip {
        font-size: 12px;
        padding: 3px 10px;
    }
}
@keyframes card-highlight {
    0% { box-shadow: 0 0 0 3px rgba(39, 88, 141, 0.4); }
    100% { box-shadow: none; }
}
.card-highlight { animation: card-highlight 1.5s ease-out; }
[data-theme="dark"] .jump-chip {
    background: rgba(255,255,255,0.05);
    border-color: rgba(255,255,255,0.1);
    color: var(--text-primary, #E2E8F0);
}
[data-theme="dark"] .jump-chip:hover {
    background: var(--cfc-blue);
    color: white;
}
[data-theme="dark"] .jump-dot-action { background: #5b9bd5; }
[data-theme="dark"] .jump-dot-legislative { background: #5b9bd5; }
[data-theme="dark"] .jump-dot-data { background: #6b7280; }
[data-theme="dark"] .jump-dot-outreach { background: #6b7280; }

/* ── Scroll-triggered card fade-in ── */
.card-fade-in {
    opacity: 0;
    transform: translateY(12px);
}
.card-fade-in.card-visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.3s ease, transform 0.3s ease;
}

/* ── Card hover elevation (desktop only) ── */
@media (min-width: 769px) {
    #dash-cards-grid .card {
        transition: box-shadow 0.15s ease;
    }
    #dash-cards-grid .card:hover {
        box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    }
}
[data-theme="dark"] #dash-cards-grid .card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

/* ── Widescreen sticky sidebar (>=1920px) ── */
@media (min-width: 1920px) {
    .page-sidebar-summary {
        position: sticky;
        top: 80px;
        width: 260px;
        flex-shrink: 0;
        background: white;
        border: 1px solid var(--light-border, #e5e7eb);
        border-radius: 10px;
        padding: 16px;
        font-size: 13px;
        max-height: calc(100vh - 100px);
        overflow-y: auto;
        box-shadow: 0 1px 3px rgba(0,0,0,0.04);
    }
    .page-sidebar-summary h4 {
        font-size: 14px;
        font-weight: 700;
        margin: 0 0 12px;
        color: var(--dark-navy);
    }
    .sidebar-row {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 6px 0;
        border-bottom: 1px solid var(--light-border, #f0f0f0);
    }
    .sidebar-row:last-child { border-bottom: none; }
    .sidebar-label {
        font-size: 12px;
        font-weight: 600;
        text-transform: uppercase;
        letter-spacing: 0.03em;
        color: var(--muted-gray);
    }
    .sidebar-value {
        font-weight: 600;
        color: var(--dark-navy);
    }
    .sidebar-links {
        margin-top: 12px;
        padding-top: 10px;
        border-top: 1px solid var(--light-border);
        display: flex;
        flex-direction: column;
        gap: 4px;
    }
    .sidebar-links a {
        font-size: 12px;
        color: var(--cfc-blue);
        text-decoration: none;
        padding: 3px 0;
    }
    .sidebar-links a:hover { text-decoration: underline; }
    .page-with-sidebar {
        display: flex;
        gap: 20px;
        align-items: flex-start;
    }
    .page-with-sidebar > #dash-cards-grid,
    .page-with-sidebar > .bill-grid { flex: 1; min-width: 0; }
    [data-theme="dark"] .page-sidebar-summary {
        background: var(--bg-card, #1E1E30);
        border-color: rgba(255,255,255,0.08);
    }
    [data-theme="dark"] .sidebar-row { border-bottom-color: rgba(255,255,255,0.05); }
    [data-theme="dark"] .sidebar-label { color: #9ca3af; }
    [data-theme="dark"] .sidebar-value { color: var(--text-primary); }
    [data-theme="dark"] .sidebar-links { border-top-color: rgba(255,255,255,0.08); }
}
@media (max-width: 1919px) {
    .page-sidebar-summary { display: none !important; }
}

/* ── Bottom bar + bottom sheet — hidden everywhere (redundant with FAB + nav) ── */
.bottom-action-bar, .bottom-sheet-overlay, .bottom-sheet { display: none !important; }
.has-bottom-bar { padding-bottom: 0; }

/* Amendment warning banner (v10.19) */
[data-theme="dark"] .amendment-warning {
    background: #422006 !important;
    border-left-color: var(--hearing-soon) !important;
    color: #fbbf24 !important;
}

/* ===== UX Audit v10.23 Fixes ===== */

/* C-03: Touch targets — ensure 44px minimum on interactive elements */
input[type="checkbox"], input[type="radio"] {
    min-width: 20px;
    min-height: 20px;
    cursor: pointer;
}
label:has(input[type="checkbox"]), label:has(input[type="radio"]) {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}

/* M-01: Focus-visible states for keyboard navigation (WCAG 2.4.7) */
:focus-visible {
    outline: 3px solid var(--cfc-blue, #27588D);
    outline-offset: 2px;
}
input:focus-visible, textarea:focus-visible, select:focus-visible {
    outline: 3px solid var(--cfc-blue, #27588D);
    outline-offset: 0;
    border-color: var(--cfc-blue, #27588D);
}
.tag-pill-x:focus-visible {
    outline: 2px solid var(--cfc-blue);
    outline-offset: 1px;
    border-radius: 3px;
}
.sponsor-chip a:focus-visible {
    outline: 2px solid var(--cfc-blue);
    outline-offset: 2px;
}
.social-link:focus-visible {
    outline: 2px solid var(--cfc-blue);
    outline-offset: 2px;
    border-radius: 4px;
}
.hearing-card:hover {
    background: var(--bg-hover, rgba(0,0,0,0.02));
}

/* H-01: Dark mode gaps — missing overrides */
[data-theme="dark"] .hearing-soon {
    background: #422006 !important;
    color: #fbbf24 !important;
}
[data-theme="dark"] .hearing-urgent {
    background: #450a0a !important;
    color: #fca5a5 !important;
}
[data-theme="dark"] .badge-supporting,
[data-theme="dark"] .badge-stance-support {
    background: #14532d !important;
    color: #86efac !important;
}
[data-theme="dark"] .badge-opposing,
[data-theme="dark"] .badge-stance-oppose {
    background: #450a0a !important;
    color: #fca5a5 !important;
}
[data-theme="dark"] .bill-row-support {
    background: rgba(34, 197, 94, 0.08) !important;
}
[data-theme="dark"] .bill-row-oppose {
    background: rgba(239, 68, 68, 0.08) !important;
}
[data-theme="dark"] .fab-menu .fab-action {
    background: var(--bg-card, #1A1A2E) !important;
    color: var(--text-primary, #E2E8F0) !important;
    border-color: rgba(255,255,255,0.1) !important;
}
[data-theme="dark"] .search-ac-item:hover {
    background: rgba(255,255,255,0.08) !important;
}
[data-theme="dark"] .shortcuts-grid kbd {
    background: #2d2d3d !important;
    color: #E2E8F0 !important;
    border-color: rgba(255,255,255,0.1) !important;
}
[data-theme="dark"] .vote-timeline-dot.aye { background: #22c55e !important; }
[data-theme="dark"] .vote-timeline-dot.nay { background: #ef4444 !important; }
[data-theme="dark"] .vote-timeline-dot.abs { background: #6b7280 !important; }
[data-theme="dark"] .vote-breakdown-table tr:hover {
    background: rgba(255,255,255,0.04);
}
[data-theme="dark"] .hearing-card:hover {
    background: rgba(255,255,255,0.04);
}

/* M-07: Skeleton loading animation */
.skeleton-line {
    height: 16px;
    background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
    background-size: 200% 100%;
    animation: shimmer 1.5s infinite;
    border-radius: 4px;
    margin-bottom: 8px;
}
[data-theme="dark"] .skeleton-line {
    background: linear-gradient(90deg, #2d2d3d 25%, #3d3d4d 50%, #2d2d3d 75%);
    background-size: 200% 100%;
}
@keyframes shimmer {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ═══════════════════════════════════════════════════════════════
   Assembly Absence / Attendance Styles
   ═══════════════════════════════════════════════════════════════ */
.attendance-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 10px 16px;
    background: var(--bg-warm, #FAF7F2);
    border: 1px solid var(--light-border, #E5E5E5);
    border-radius: 8px;
    min-width: 80px;
}
.attendance-stat-value {
    font-size: 22px;
    font-weight: 700;
    color: var(--cfc-blue, #002D5C);
    line-height: 1.2;
}
.attendance-stat-label {
    font-size: 12px;
    color: var(--text-secondary, #777);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 2px;
}
.text-danger { color: #DC3545; }
.text-warning { color: #D4880F; }

/* Absence type badges */
.absence-badge {
    display: inline-block;
    font-size: 12px;
    padding: 2px 8px;
    border-radius: 10px;
    font-weight: 500;
    white-space: nowrap;
}
.absence-legislative { background: var(--absence-legislative-bg); color: var(--absence-legislative-text); }
.absence-personal { background: var(--absence-personal-bg); color: var(--absence-personal-text); }
.absence-illness { background: var(--absence-illness-bg); color: var(--absence-illness-text); }
.absence-leave { background: var(--absence-leave-bg); color: var(--absence-leave-text); }
.absence-bereavement { background: var(--absence-bereavement-bg); color: var(--absence-bereavement-text); }
.absence-other { background: #F5F5F5; color: #616161; }

/* NVR annotation on roll call vote rows */
.nvr-annotation {
    display: inline-block;
    font-size: 12px;
    padding: 1px 6px;
    border-radius: 8px;
    margin-left: 6px;
    font-weight: 500;
    vertical-align: middle;
}
.nvr-on-leave {
    background: var(--absence-personal-bg);
    color: var(--absence-personal-text);
    border: 1px solid #FFCC02;
}
.nvr-was-present {
    background: var(--absence-illness-bg);
    color: #B71C1C;
    border: 1px solid #EF9A9A;
    font-weight: 600;
}
.nvr-absent-no-leave {
    background: #FFF8E1;
    color: var(--absence-personal-text);
    border: 1px solid #FFE082;
}
.nvr-present {
    background: var(--absence-bereavement-bg);
    color: #546E7A;
    border: 1px solid #CFD8DC;
}

/* Dark mode */
[data-theme="dark"] .attendance-stat {
    background: #1E1E30;
    border-color: #333;
}
[data-theme="dark"] .attendance-stat-value { color: #7FB3E0; }
[data-theme="dark"] .attendance-stat-label { color: #999; }
[data-theme="dark"] .absence-legislative { background: #1A2A40; color: #64B5F6; }
[data-theme="dark"] .absence-personal { background: #2A1A0A; color: #FFB74D; }
[data-theme="dark"] .absence-illness { background: #2A0A0A; color: #EF9A9A; }
[data-theme="dark"] .absence-leave { background: #1A0A2A; color: #CE93D8; }
[data-theme="dark"] .absence-bereavement { background: #1A1A2A; color: #90A4AE; }
[data-theme="dark"] .absence-other { background: #1E1E30; color: #999; }
[data-theme="dark"] .nvr-on-leave { background: #2A1A0A; color: #FFB74D; border-color: #5A4A1A; }
[data-theme="dark"] .nvr-was-present { background: #2A0A0A; color: #EF9A9A; border-color: #5A1A1A; }
[data-theme="dark"] .nvr-absent-no-leave { background: #2A1A0A; color: #FFB74D; border-color: #4A3A0A; }
[data-theme="dark"] .nvr-present { background: #1A1A2A; color: #90A4AE; border-color: #333; }

/* Party dot — compact party badge for attendance tables */
.party-dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 700;
    margin-right: 6px;
    vertical-align: middle;
    padding: 0;
    line-height: 1;
}

/* Attendance tab — stats row + reason grid */
.att-stats-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}
.att-stat-card {
    background: var(--bg-card, #fff);
    border: 1px solid var(--light-border, #E5E5E5);
    border-radius: 12px;
    padding: 18px 14px;
    text-align: center;
    box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}
.att-stat-num {
    font-size: 2rem;
    font-weight: 800;
    line-height: 1;
    color: var(--cfc-blue, #002D5C);
}
.att-stat-label {
    font-size: 0.78rem;
    color: var(--text-secondary, #64748b);
    margin-top: 6px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}
.att-reason-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}
.att-reason-card {
    background: var(--bg-warm, #f1f5f9);
    border: 1px solid var(--light-border, #e2e8f0);
    border-radius: 10px;
    padding: 14px;
    display: flex;
    align-items: center;
    gap: 12px;
}
.att-reason-count {
    font-size: 1.6rem;
    font-weight: 800;
    color: #b45309;
    min-width: 40px;
    text-align: center;
}
.att-reason-label {
    font-size: 0.85rem;
    color: var(--text-primary, #1e293b);
    font-weight: 500;
}
.rank { color: var(--text-secondary, #64748b); font-weight: 600; width: 40px; }
.num { text-align: right; font-variant-numeric: tabular-nums; }
@media (max-width: 768px) {
    .hide-mobile { display: none !important; }
    .att-stats-row { grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 8px; }
    .att-stat-num { font-size: 1.5rem; }
    .att-stat-card { padding: 12px 10px; }
}
/* Attendance tab dark mode */
[data-theme="dark"] .att-stat-card {
    background: #1E1E30;
    border-color: #333;
    box-shadow: none;
}
[data-theme="dark"] .att-stat-num { color: #7FB3E0; }
[data-theme="dark"] .att-stat-label { color: #999; }
[data-theme="dark"] .att-reason-card {
    background: #1E1E30;
    border-color: #333;
}
[data-theme="dark"] .att-reason-count { color: #FFB74D; }
[data-theme="dark"] .att-reason-label { color: #ccc; }

/* MOB-13: Global print styles */
@media print {
    .navbar, .gold-bar, .footer, .btn, .fab-container, .bottom-bar, .bottom-sheet-backdrop,
    .bottom-action-bar, .bottom-sheet-overlay, .bottom-sheet,
    .nav-search-form, .user-menu, .sticky-action-bar, .section-toggle-bar,
    .jump-nav, .toast-container, .ask-panel-backdrop, .ask-panel,
    .card-drag-handle, .card-toggle, .dash-settings-wrap { display: none !important; }
    .main-content { padding: 0; margin: 0; }
    .card { break-inside: avoid; box-shadow: none !important; border: 1px solid #ddd !important; }
    .card-body, [id$="-content"] { display: block !important; }
    .card[data-card-id="narrative"],
    .card[data-card-id="relationship"],
    .card[data-card-id="timeline"],
    .card[data-card-id="sponsor-contacts"],
    .card[data-card-id="similar-bills"] { break-inside: avoid; }
}

/* ── Accessibility: focus styles for collapsible headers ── */
.collapsible-header:focus-visible {
    outline: 2px solid var(--cfc-blue, #002D5C);
    outline-offset: 2px;
    border-radius: 4px;
}

/* ── Accessibility: respect reduced motion preference ── */
@media (prefers-reduced-motion: reduce) {
    *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ── MOB-04: Admin pages mobile responsiveness ─────────────── */
@media (max-width: 768px) {
    /* Admin hub grid — force single column (supplements template 640px rule) */
    .admin-hub-grid { grid-template-columns: 1fr !important; }

    /* Scheduled jobs — hide Schedule + Recipients columns (2nd & 3rd) */
    .sj-table th:nth-child(2), .sj-table td:nth-child(2),
    .sj-table th:nth-child(3), .sj-table td:nth-child(3) { display: none; }
    .sj-filter-bar { flex-wrap: wrap; gap: 6px; }
    .sj-filter-pill { font-size: 12px; padding: 5px 10px; }

    /* Article library — stack filter form elements vertically */
    form[method="get"][style*="display:flex"][style*="flex-wrap:wrap"] select,
    form[method="get"][style*="display:flex"][style*="flex-wrap:wrap"] input[type="text"] {
        flex: 1 1 100% !important;
        min-width: 0 !important;
    }

    /* Exec dashboard — tighten gap on inline auto-fit grids */
    .card [style*="grid-template-columns: repeat(auto-fit"] { gap: 8px !important; }
}

/* ── MOB-08: Force side-by-side layouts to stack on mobile ── */
@media (max-width: 768px) {
    /* Catch inline style grids with fixed column widths (e.g. "1fr 340px", "1fr 300px") */
    [style*="grid-template-columns:1fr 3"],
    [style*="grid-template-columns: 1fr 3"],
    [style*="grid-template-columns:1fr 2"],
    [style*="grid-template-columns: 1fr 2"] {
        grid-template-columns: 1fr !important;
    }

    /* Named two-column layouts (for any templates that adopt these classes) */
    .two-col-layout, .side-by-side {
        grid-template-columns: 1fr !important;
    }
}

/* ── MOB-14: Ensure images don't overflow on mobile ── */
img {
    max-width: 100%;
    height: auto;
}

/* ── MOB-19: Ensure loading indicators visible on mobile ── */
.loading-overlay, .loading-state {
    position: fixed;
    z-index: var(--z-sticky-sub);
}

/* ═══════════════════════════════════════════════════════════════
   VIS & DARK — Visual consistency & dark mode fixes (18 rules)
   Added: Mar 18, 2026
   ═══════════════════════════════════════════════════════════════ */

/* VIS-01: Unified stat card */
.stat-card { display:flex; flex-direction:column; align-items:center; padding:16px; border:1px solid var(--card-border); border-radius:8px; text-align:center; background:var(--bg-card); }
.stat-card-value { font-size:28px; font-weight:700; color:var(--cfc-navy); }
.stat-card-label { font-size:12px; color:var(--text-secondary); margin-top:4px; text-transform:uppercase; letter-spacing:0.5px; }
.stat-card--blue .stat-card-value { color:var(--cfc-blue); }
.stat-card--green .stat-card-value { color:#0D7C3E; }
.stat-card--amber .stat-card-value { color:var(--hearing-soon); }
.stat-card--red .stat-card-value { color:var(--party-rep-dot); }

/* VIS-03: Standard button sizes
   v10.90 audit item #10 — every value now reads from --btn-*-h / --btn-*-py
   / --btn-*-px tokens in variables.css. Font sizes use existing --text-*
   typography scale. To adjust a size, edit variables.css, not this file.

   IMPORTANT ordering rule (fixed in v10.90c): the modifier rules
   (.btn-xs / .btn-sm / .btn-lg) MUST come AFTER the base .btn rule so
   that a `class="btn btn-sm"` element resolves to the smaller size.
   The previous ordering (modifiers first, then `.btn-md, .btn`)
   caused `.btn` to override `.btn-sm` via same-specificity cascade —
   meaning `.btn-sm` was silently never taking effect.                    */
.btn-md, .btn {
    min-height: var(--btn-md-h);
    padding: var(--btn-md-py) var(--btn-md-px);
    font-size: var(--text-base);
}
.btn-xs {
    min-height: var(--btn-xs-h);
    padding: var(--btn-xs-py) var(--btn-xs-px);
    font-size: var(--text-xs);
}
.btn-sm {
    min-height: var(--btn-sm-h);
    padding: var(--btn-sm-py) var(--btn-sm-px);
    font-size: var(--text-sm);
}
.btn-lg {
    min-height: var(--btn-lg-h);
    padding: var(--btn-lg-py) var(--btn-lg-px);
    font-size: var(--text-md);
}

/* VIS-04: Standardized card styles */
.card--outlined { border:1px solid var(--card-border); border-radius:8px; padding:16px; background:var(--bg-card); }
.card--elevated { border-radius:8px; padding:16px; background:var(--bg-card); box-shadow:0 2px 8px rgba(0,0,0,0.08); }
.card--accent-left { border-left:4px solid var(--cfc-blue); }

/* VIS-05: Typography scale */
.text-xs { font-size:12px; } .text-sm { font-size:13px; } .text-base { font-size:15px; }
.text-lg { font-size:18px; } .text-xl { font-size:22px; } .text-2xl { font-size:28px; }

/* VIS-07: Unified stance badge colors */
.badge-stance-support, [data-stance="support"] { --stance-color:#0D7C3E; }
.badge-stance-oppose, [data-stance="oppose"] { --stance-color:var(--party-rep-dot); }
.badge-stance-watching, [data-stance="watching"] { --stance-color:#d97706; }

/* VIS-08: Consistent section spacing */
.section-gap { margin-bottom:24px; }
.section-gap-sm { margin-bottom:16px; }
.section-gap-lg { margin-bottom:32px; }

/* VIS-09: Table variants */
.table-default thead th { background:var(--bg-hover); font-weight:600; font-size:12px; text-transform:uppercase; letter-spacing:0.5px; }
.table-default tbody tr:nth-child(even) { background:var(--bg-hover); }
.table-default tbody tr:hover { background:rgba(26,82,118,0.05); }
.table-compact td, .table-compact th { padding:6px 10px; font-size:13px; }

/* VIS-10: Unified alert/callout styles */
.alert-info { background:var(--tint-info-bg); border:1px solid #93C5FD; color:var(--tint-info-text); padding:12px 16px; border-radius:8px; }
.alert-success { background:var(--tint-success-bg); border:1px solid #6EE7B7; color:var(--tint-success-text); padding:12px 16px; border-radius:8px; }
.alert-warning { background:var(--tint-warning-bg); border:1px solid #FCD34D; color:var(--tint-warning-text); padding:12px 16px; border-radius:8px; }
.alert-danger { background:#FEE2E2; border:1px solid #FCA5A5; color:var(--tint-error-text); padding:12px 16px; border-radius:8px; }
.callout { border-left:4px solid var(--cfc-blue); padding:12px 16px; background:var(--bg-hover); border-radius:0 8px 8px 0; }
.callout--warning { border-left-color:#F59E0B; background:var(--tint-warning-bg); }
.callout--danger { border-left-color:var(--party-rep-dot); background:var(--tint-error-bg); }

/* VIS-11: Consistent hover transitions */
.btn, a.btn, .nav-dropdown-menu a, .filter-pill, .tag-pill { transition:background-color 0.15s ease, border-color 0.15s ease, opacity 0.15s ease; }

/* VIS-12: Unified loading spinner */
.spinner { display:inline-block; border:3px solid var(--card-border); border-top-color:var(--cfc-blue); border-radius:50%; animation:spin 0.8s linear infinite; }
.spinner-sm { width:16px; height:16px; border-width:2px; }
.spinner-md { width:24px; height:24px; }
.spinner-lg { width:36px; height:36px; border-width:4px; }

/* VIS-13: Footer separation */
.footer { border-top:1px solid var(--card-border); margin-top:32px; }

/* VIS-14: Consistent sidebar width */
@media (min-width:1920px) {
    .dash-sidebar-summary, .bill-sidebar { width:320px; min-width:320px; }
}

/* VIS-15: Z-index scale — variables defined in :root above; inline updates applied to
   .sticky-action-bar, .modal-backdrop, .modal-content, #toast-container, .fab-container */

/* ── Dark Mode Fixes ── */

/* DARK-10: Visible focus rings in dark mode */
[data-theme="dark"] *:focus-visible { outline-color:var(--cfc-gold, #F4B824); }

/* DARK-11: Placeholder visibility in dark mode */
[data-theme="dark"] ::placeholder { color:#8E8EA0; }
[data-theme="dark"] input::placeholder, [data-theme="dark"] textarea::placeholder { color:#8E8EA0; }

/* DARK-12: Dark mode scrollbars */
[data-theme="dark"] ::-webkit-scrollbar { width:8px; height:8px; }
[data-theme="dark"] ::-webkit-scrollbar-track { background:#1A1A2E; }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background:#4A4A5A; border-radius:4px; }
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover { background:#5A5A6A; }

/* DARK-13: Dark mode text selection */
[data-theme="dark"] ::selection { background:var(--cfc-blue); color:white; }

/* DARK-15: Admin hub cards dark mode */
[data-theme="dark"] .admin-hub-grid .card, [data-theme="dark"] .hub-card { background:var(--bg-card); border-color:var(--card-border); }
[data-theme="dark"] .hub-card-icon { opacity:0.8; }

/* ═══════════════════════════════════════════════════════════════
   POLISH — Readiness chips, relationship health, print rules
   Added: Mar 20, 2026
   ═══════════════════════════════════════════════════════════════ */

/* Readiness detail chips */
.readiness-chip { font-size:12px; padding:2px 8px; border-radius:12px; display:inline-block; }
.readiness-chip-yes { background:#dcfce7; color:#166534; }
.readiness-chip-no { background:#fee2e2; color:var(--tint-error-text); }
[data-theme="dark"] .readiness-chip-yes { background:#14532d; color:#86efac; }
[data-theme="dark"] .readiness-chip-no { background:#7f1d1d; color:#fca5a5; }

/* Relationship health indicator */
.relationship-health-strong { background:#E8F8EE; border:1px solid #B7E4C7; color:#0D7C3E; }
.relationship-health-attention { background:#FFF8E1; border:1px solid #F5E6A3; color:#B7791F; }
.relationship-health-none { background:var(--tint-error-bg); border:1px solid #FECACA; color:#DC3545; }
[data-theme="dark"] .relationship-health-strong { background:#14532d; border-color:#22543d; color:#86efac; }
[data-theme="dark"] .relationship-health-attention { background:#78350f; border-color:#92400e; color:#fde68a; }
[data-theme="dark"] .relationship-health-none { background:#7f1d1d; border-color:#991b1b; color:#fca5a5; }

/* Coalition purple CSS variable */
:root { --coalition-purple: #7B2D8B; }

/* Print styles for newer cards */
@media print {
    .pulse-card, #pulse-card { display:none !important; }
    .narrative-card { border-left-width:3px !important; }
    .card-fade-in { opacity:1 !important; animation:none !important; transform:none !important; }
    .relationship-health { page-break-inside:avoid; }
    #bill-timeline-card, .bill-timeline-card { page-break-inside:avoid; }
    #bill-timeline-card .card-body { max-height:none !important; overflow:visible !important; }
}

/* ── Interest Group Rating chips (Vote Smart) ─────────────────────── */
.ig-chip {
    display:inline-flex; align-items:center; gap:5px;
    padding:3px 10px; border-radius:12px; font-size:12px;
    border:1px solid var(--light-border); background:var(--bg-warm);
    white-space:nowrap; cursor:default;
}
.ig-chip-name { color:var(--text-secondary); }
.ig-chip-score { font-weight:600; }
.ig-rating-high { border-color:#b7e1cd; background:#edf7f2; }
.ig-rating-high .ig-chip-score { color:var(--tint-success-text); }
.ig-rating-low { border-color:#f5c6cb; background:#fdf0f1; }
.ig-rating-low .ig-chip-score { color:var(--tint-error-text); }
.ig-rating-mid { border-color:#fde68a; background:#fefce8; }
.ig-rating-mid .ig-chip-score { color:#78350f; }
.ig-rating-neutral .ig-chip-score { color:var(--text-secondary); }

.ig-table-score {
    display:inline-block; padding:1px 7px; border-radius:8px;
    font-size:12px; font-weight:600;
}
.ig-table-score.ig-rating-high { background:var(--tint-success-bg); color:var(--tint-success-text); }
.ig-table-score.ig-rating-low { background:#fee2e2; color:var(--tint-error-text); }
.ig-table-score.ig-rating-mid { background:var(--tint-warning-bg); color:#78350f; }

.ig-all-details summary { padding:6px 0; }
.ig-all-details[open] summary .toggle-arrow { display:inline-block; transform:rotate(90deg); }
.ig-all-details summary .toggle-arrow { display:inline-block; transition:transform 0.2s; }

/* Dark mode — IG ratings */
[data-theme="dark"] .ig-chip { background:#2a2a3e; border-color:#3a3a50; }
[data-theme="dark"] .ig-rating-high { border-color:#065f46; background:#1a2e2a; }
[data-theme="dark"] .ig-rating-high .ig-chip-score { color:#6ee7b7; }
[data-theme="dark"] .ig-rating-low { border-color:#7f1d1d; background:#2d1a1a; }
[data-theme="dark"] .ig-rating-low .ig-chip-score { color:#fca5a5; }
[data-theme="dark"] .ig-rating-mid { border-color:#78350f; background:#2d2a1a; }
[data-theme="dark"] .ig-rating-mid .ig-chip-score { color:#fcd34d; }
[data-theme="dark"] .ig-table-score.ig-rating-high { background:#064e3b; color:#6ee7b7; }
[data-theme="dark"] .ig-table-score.ig-rating-low { background:#7f1d1d; color:#fca5a5; }
[data-theme="dark"] .ig-table-score.ig-rating-mid { background:#78350f; color:#fcd34d; }

/* ============================================================
   TIER 4 — POLISH & ACCESSIBILITY (v10.65 UI Audit)
   ============================================================ */

/* ── 4.1 Utility Classes ──────────────────────────────────── */
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-start { display: flex; align-items: center; justify-content: flex-start; }
.flex-wrap { flex-wrap: wrap; }
.flex-col { flex-direction: column; }
.gap-1 { gap: 4px; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.gap-5 { gap: 24px; }
.mt-1 { margin-top: 4px; }
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 12px; }
.mt-4 { margin-top: 16px; }
.mt-5 { margin-top: 24px; }
.mb-1 { margin-bottom: 4px; }
.mb-2 { margin-bottom: 8px; }
.mb-3 { margin-bottom: 12px; }
.mb-4 { margin-bottom: 16px; }
.mb-5 { margin-bottom: 24px; }
.p-1 { padding: 4px; }
.p-2 { padding: 8px; }
.p-3 { padding: 12px; }
.p-4 { padding: 16px; }
.text-muted { color: var(--muted-gray); }
.text-sm { font-size: 12px; }
.text-center { text-align: center; }
.w-full { width: 100%; }
.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; }

/* ── 4.2 Standardized Stance Badges ──────────────────────── */
/* These complement existing badge-stance-* classes with generic .badge-{type} names */
.badge-support {
    background: var(--tint-success-bg);
    color: var(--tint-success-text);
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.badge-oppose {
    background: #fee2e2;
    color: var(--tint-error-text);
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.badge-watching {
    background: var(--tint-warning-bg);
    color: var(--tint-warning-text);
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.badge-neutral {
    background: var(--tint-neutral-bg);
    color: var(--gray-600);
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
/* Generic status badge variants */
.badge-info { background: var(--tint-info-bg); color: var(--tint-info-text); padding: 2px 8px; border-radius: 12px; font-size: 12px; font-weight: 700; }
.badge-warning { background: var(--tint-warning-bg); color: var(--tint-warning-text); padding: 2px 8px; border-radius: 12px; font-size: 12px; font-weight: 700; }
.badge-success { background: var(--tint-success-bg); color: var(--tint-success-text); padding: 2px 8px; border-radius: 12px; font-size: 12px; font-weight: 700; }
.badge-danger { background: #fee2e2; color: var(--tint-error-text); padding: 2px 8px; border-radius: 12px; font-size: 12px; font-weight: 700; }
/* Dark mode stance badges */
[data-theme="dark"] .badge-support { background: #052e16; color: #6ee7b7; }
[data-theme="dark"] .badge-oppose { background: #450a0a; color: #fca5a5; }
[data-theme="dark"] .badge-watching { background: #2d2208; color: #fcd34d; }
[data-theme="dark"] .badge-neutral { background: #1f2937; color: #9ca3af; }
[data-theme="dark"] .badge-info { background: #0D1B2E; color: #6BA8E8; }
[data-theme="dark"] .badge-warning { background: #2d2208; color: #fcd34d; }
[data-theme="dark"] .badge-success { background: #052e16; color: #6ee7b7; }
[data-theme="dark"] .badge-danger { background: #450a0a; color: #fca5a5; }

/* ── 4.3 Keyboard Focus States (:focus-visible) ───────────── */
/* Global focus ring — applies to all interactive elements when navigated by keyboard */
*:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: 2px;
}
/* Buttons */
.btn:focus-visible,
button:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(39, 88, 141, 0.2);
}
/* Links */
a:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: 2px;
    border-radius: 2px;
}
/* Form inputs */
input:focus-visible,
textarea:focus-visible,
select:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: 0;
    box-shadow: 0 0 0 3px rgba(39, 88, 141, 0.15);
}
/* Checkboxes & radios */
input[type="checkbox"]:focus-visible,
input[type="radio"]:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: 2px;
}
/* Table rows used as links */
tr[role="link"]:focus-visible,
tr[onclick]:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: -2px;
}
/* Nav links */
.navbar-links a:focus-visible,
.nav-link:focus-visible {
    outline: 2px solid var(--cfc-gold, #C9A84C);
    outline-offset: 2px;
    border-radius: 3px;
}
/* Card toggle/collapsible headers */
.collapsible-header:focus-visible {
    outline: 2px solid var(--cfc-blue, #27588D);
    outline-offset: -2px;
    border-radius: 4px;
}
/* Dark mode focus ring — brighter for visibility on dark backgrounds */
[data-theme="dark"] *:focus-visible {
    outline-color: #6BA8E8;
}
[data-theme="dark"] .btn:focus-visible,
[data-theme="dark"] button:focus-visible {
    outline-color: #6BA8E8;
    box-shadow: 0 0 0 4px rgba(107, 168, 232, 0.25);
}
[data-theme="dark"] a:focus-visible {
    outline-color: #6BA8E8;
}
[data-theme="dark"] input:focus-visible,
[data-theme="dark"] textarea:focus-visible,
[data-theme="dark"] select:focus-visible {
    outline-color: #6BA8E8;
    box-shadow: 0 0 0 3px rgba(107, 168, 232, 0.2);
}
[data-theme="dark"] .navbar-links a:focus-visible {
    outline-color: #F4B824;
}

/* ── 4.5 Dark Mode Contrast — Gold Badge Fix ─────────────── */
/* Ensure #C9A84C gold on dark navy meets WCAG AA 4.5:1 */
/* Gold (#C9A84C) on dark navy (#0F0F1A) = ~6.2:1 — passes AA */
/* Gold (#C9A84C) on card (#1A1A2E) = ~5.8:1 — passes AA */
/* The existing dark mode gold uses lighter #F4B824 on dark-navy which = ~8.1:1 — passes AAA */
/* badge-role-admin uses gold background with dark-navy text — same ratio passes */
[data-theme="dark"] .badge-role-admin {
    background: #b8930f;
    color: #fff;
}
[data-theme="dark"] .badge-high {
    background: #b8930f;
    color: #fff;
}
/* Stance badge — base definition (also in bill-detail.css for bill pages) */
.badge-stance {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 4px 12px; border-radius: 6px;
    font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px;
}
.badge-stance-oppose  { background: var(--tint-error-bg, #fee2e2); color: var(--alert-red, #dc2626); }
.badge-stance-support { background: var(--tint-success-bg, #dcfce7); color: var(--success-green, #16a34a); }
.badge-stance-watching { background: var(--tint-warning-bg, #fef3c7); color: #b45309; }

/* Priority pill — matches bill detail page style */
.bill-priority-pill {
    display: inline-block; padding: 4px 12px; border-radius: 6px;
    font-size: 12px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.5px;
    background: #fef3c7; color: #92400e; border: 1px solid #fcd34d;
}
[data-theme="dark"] .bill-priority-pill {
    background: #C9A84C; color: #0F0F1A; border-color: #C9A84C;
}

/* ── Y10: Quill rich-text editor dark mode ─────────────────────────── */
[data-theme="dark"] .ql-toolbar.ql-snow {
    background: var(--bg-card);
    border-color: var(--light-border);
}
[data-theme="dark"] .ql-container.ql-snow {
    background: var(--bg-card);
    border-color: var(--light-border);
    color: var(--text-primary);
}
[data-theme="dark"] .ql-editor.ql-blank::before {
    color: var(--text-secondary);
}
[data-theme="dark"] .ql-snow .ql-stroke {
    stroke: var(--text-secondary);
}
[data-theme="dark"] .ql-snow .ql-fill {
    fill: var(--text-secondary);
}
[data-theme="dark"] .ql-snow .ql-picker {
    color: var(--text-secondary);
}
[data-theme="dark"] .ql-snow .ql-picker-options {
    background: var(--bg-card);
    border-color: var(--light-border);
}

/* ── Y4+Y18: Typography & spacing utility classes ──────────────────── */
/* Font sizes (matching --text-* token scale) */
.text-xs  { font-size: var(--text-xs, 12px) !important; }
.text-sm  { font-size: var(--text-sm, 13px) !important; }
.text-base { font-size: var(--text-base, 14px) !important; }
.text-md  { font-size: var(--text-md, 16px) !important; }
.text-lg  { font-size: var(--text-lg, 18px) !important; }
.text-xl  { font-size: var(--text-xl, 22px) !important; }
.text-2xl { font-size: var(--text-2xl, 28px) !important; }

/* Font weights */
.fw-400 { font-weight: 400 !important; }
.fw-500 { font-weight: 500 !important; }
.fw-600 { font-weight: 600 !important; }
.fw-700 { font-weight: 700 !important; }

/* Text colors */
.text-primary   { color: var(--text-primary) !important; }
.text-secondary { color: var(--text-secondary) !important; }
.text-muted     { color: var(--muted-gray) !important; }
.text-link      { color: var(--cfc-blue) !important; }
.text-success   { color: var(--success-green) !important; }
.text-danger    { color: var(--alert-red) !important; }
.text-warning   { color: var(--warning-amber) !important; }

/* Spacing (matching --spacing-* token scale) */
.gap-xs  { gap: var(--spacing-xs, 4px) !important; }
.gap-sm  { gap: var(--spacing-sm, 8px) !important; }
.gap-md  { gap: var(--spacing-md, 16px) !important; }
.gap-lg  { gap: var(--spacing-lg, 24px) !important; }

.p-xs  { padding: var(--spacing-xs) !important; }
.p-sm  { padding: var(--spacing-sm) !important; }
.p-md  { padding: var(--spacing-md) !important; }
.p-lg  { padding: var(--spacing-lg) !important; }

.mb-xs { margin-bottom: var(--spacing-xs) !important; }
.mb-sm { margin-bottom: var(--spacing-sm) !important; }
.mb-md { margin-bottom: var(--spacing-md) !important; }
.mb-lg { margin-bottom: var(--spacing-lg) !important; }
.mb-0  { margin-bottom: 0 !important; }

/* Display helpers */
/* ── G4: SVG icon base ── */
.icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }

/* Display helpers */
.flex        { display: flex !important; }
.flex-wrap   { flex-wrap: wrap !important; }
.flex-col    { flex-direction: column !important; }
.items-center { align-items: center !important; }
.justify-between { justify-content: space-between !important; }

/* ═══════════════════════════════════════════════════════════════════
   Committee Pages — Index Cards + Detail Intelligence
   ═══════════════════════════════════════════════════════════════════ */

/* ── Chamber badges ─────────────────────────────────────────────── */
.cmte-chamber-badge {
    display: inline-block; padding: 2px 7px; border-radius: 3px;
    font-size: 10px; font-weight: 700; letter-spacing: 0.5px; color: #fff;
}
.cmte-chamber-assembly { background: var(--cfc-blue, #1a5276); }
.cmte-chamber-senate   { background: #991b1b; }

/* ── Card grid (index page) ─────────────────────────────────────── */
.cmte-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}
.cmte-card {
    display: block; padding: 20px 22px; border-radius: 8px;
    background: var(--bg-card, #fff); border: 1px solid var(--card-border, #e5e7eb);
    transition: box-shadow 0.15s, border-color 0.15s;
}
.cmte-card:hover {
    border-color: var(--cfc-blue, #1a5276);
    box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.cmte-card-top {
    display: flex; align-items: flex-start; justify-content: space-between;
    gap: 10px; margin-bottom: 10px;
}
.cmte-card-name {
    font-weight: 700; font-size: 15px; color: var(--dark-navy);
    white-space: normal !important; overflow: visible !important;
    text-overflow: clip !important; overflow-wrap: break-word;
}
.cmte-card-stats {
    display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
    font-size: 12px; color: var(--muted-gray); margin-top: 6px;
}

/* ── Score indicators ───────────────────────────────────────────── */
.cmte-score {
    font-weight: 700; font-size: 15px; padding: 4px 10px;
    border-radius: 6px; flex-shrink: 0;
}
.cmte-score-green { background: #dcfce7; color: #166534; }
.cmte-score-amber { background: #fef3c7; color: #92400e; }
.cmte-score-red   { background: #fee2e2; color: #991b1b; }

.cmte-score-large {
    font-size: 36px; font-weight: 800; line-height: 1;
}
.cmte-score-large.cmte-score-green { color: #16a34a; }
.cmte-score-large.cmte-score-amber { color: #d97706; }
.cmte-score-large.cmte-score-red   { color: #dc2626; }

/* ── Stat pills ─────────────────────────────────────────────────── */
.cmte-stat-pill {
    display: inline-block; padding: 3px 10px; border-radius: 10px;
    font-size: 11px; font-weight: 600;
}
.cmte-stat-bills   { background: #dbeafe; color: #1e40af; }
.cmte-stat-hearing  { background: #fef3c7; color: #92400e; }
.cmte-stat-urgent   { background: #fee2e2; color: #991b1b; animation: pulse-red 2s infinite; }

/* ── Party breakdown bar ────────────────────────────────────────── */
.cmte-party-bar {
    display: flex; height: 6px; border-radius: 3px; overflow: hidden;
    background: var(--bg-hover, #f1f5f9);
}
.cmte-party-seg { height: 100%; min-width: 2px; }
.cmte-party-r { background: #dc2626; }
.cmte-party-d { background: #2563eb; }
.cmte-party-i { background: #9ca3af; }

/* ── Lean badges ────────────────────────────────────────────────── */
.cmte-lean {
    display: inline-block; padding: 3px 10px; border-radius: 4px;
    font-size: 11px; font-weight: 700; letter-spacing: 0.3px;
}
.cmte-lean-favorable { background: #dcfce7; color: #166534; }
.cmte-lean-swing     { background: #fef3c7; color: #92400e; }
.cmte-lean-hostile   { background: #fee2e2; color: #991b1b; }

/* ── Quick stat boxes (detail sidebar) ──────────────────────────── */
.cmte-stat-box {
    text-align: center; padding: 10px 8px; border-radius: 6px;
    background: var(--bg-hover, #f8fafc);
}
.cmte-stat-num {
    font-size: 18px; font-weight: 700; color: var(--dark-navy);
}
.cmte-stat-label {
    font-size: 10px; color: var(--muted-gray); text-transform: uppercase;
    letter-spacing: 0.5px; margin-top: 2px;
}

/* ── Committee header card ──────────────────────────────────────── */
.cmte-header-card { padding: 20px 24px; }
@media (max-width: 480px) {
    .cmte-header-card { padding: 16px; }
}

/* ── Member card grid ───────────────────────────────────────────── */
.cmte-member-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 16px;
}
.cmte-member-card {
    position: relative; display: flex; flex-direction: column;
    align-items: center; text-align: center;
    padding: 20px 16px 16px; border-radius: 10px;
    background: var(--bg-card, #fff); border: 1px solid var(--card-border, #e5e7eb);
    transition: box-shadow 0.15s, border-color 0.15s, transform 0.15s;
}
.cmte-member-card:hover {
    border-color: var(--cfc-blue, #1a5276);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    transform: translateY(-2px);
}
.cmte-member-role {
    position: absolute; top: 0; left: 50%; transform: translateX(-50%) translateY(-50%);
    padding: 2px 12px; border-radius: 10px;
    font-size: 10px; font-weight: 700; letter-spacing: 0.5px; text-transform: uppercase;
    white-space: nowrap;
}
.cmte-member-role-chair { background: var(--cfc-gold, #C9A84C); color: #fff; }
.cmte-member-role-vc    { background: var(--cfc-blue, #1a5276); color: #fff; }

.cmte-member-photo { margin-bottom: 10px; }
.cmte-member-photo img {
    width: 75%; aspect-ratio: 4/5; border-radius: 8px;
    object-fit: cover; object-position: top;
    box-shadow: 0 2px 6px rgba(0,0,0,0.1);
}
.cmte-member-photo-placeholder {
    width: 75%; aspect-ratio: 4/5; border-radius: 8px;
    background: var(--bg-hover, #f1f5f9);
}
.cmte-member-info { width: 100%; }
.cmte-member-name {
    font-size: 14px; font-weight: 700; color: var(--dark-navy);
    margin-bottom: 4px; line-height: 1.3;
}
.cmte-member-meta {
    display: flex; align-items: center; justify-content: center;
    gap: 6px; font-size: 12px; color: var(--muted-gray);
    margin-bottom: 8px;
}
.cmte-member-score-row {
    display: flex; align-items: center; gap: 8px; width: 100%;
}
.cmte-member-score-bar {
    flex: 1; height: 6px; border-radius: 3px;
    background: var(--bg-hover, #f1f5f9); overflow: hidden;
}
.cmte-member-score-fill {
    height: 100%; border-radius: 3px;
    transition: width 0.3s ease;
}
.cmte-member-score-val {
    font-size: 14px; font-weight: 800; min-width: 36px; text-align: right;
}

/* ── Responsive ─────────────────────────────────────────────────── */
@media (max-width: 900px) {
    .cmte-card-grid {
        grid-template-columns: 1fr;
    }
    .cmte-card-name { font-size: 14px; }
    .cmte-member-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 480px) {
    .cmte-member-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
    }
    .cmte-member-card { padding: 10px 6px 10px; }
    .cmte-member-photo { margin-bottom: 8px; }
    .cmte-member-photo img { width: 88%; }
    .cmte-member-photo-placeholder { width: 88%; }
    .cmte-member-name { font-size: 13px; }
    .cmte-member-meta { gap: 4px; font-size: 11px; margin-bottom: 6px; }
}
/* Hide columns on mobile */
@media (max-width: 640px) {
    .hide-mobile { display: none !important; }
}

/* ── Dark mode ──────────────────────────────────────────────────── */
[data-theme="dark"] .cmte-card {
    background: var(--bg-card); border-color: var(--card-border);
}
[data-theme="dark"] .cmte-card:hover {
    border-color: #5B8DB8; box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
[data-theme="dark"] .cmte-card-name { color: var(--text-primary); }
[data-theme="dark"] .cmte-chamber-assembly { background: #2563eb; }
[data-theme="dark"] .cmte-chamber-senate   { background: #dc2626; }
[data-theme="dark"] .cmte-score-green { background: #14532d; color: #86efac; }
[data-theme="dark"] .cmte-score-amber { background: #78350f; color: #fcd34d; }
[data-theme="dark"] .cmte-score-red   { background: #7f1d1d; color: #fca5a5; }
[data-theme="dark"] .cmte-lean-favorable { background: #14532d; color: #86efac; }
[data-theme="dark"] .cmte-lean-swing     { background: #78350f; color: #fcd34d; }
[data-theme="dark"] .cmte-lean-hostile   { background: #7f1d1d; color: #fca5a5; }
[data-theme="dark"] .cmte-stat-bills   { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .cmte-stat-hearing  { background: #78350f; color: #fcd34d; }
[data-theme="dark"] .cmte-stat-urgent   { background: #7f1d1d; color: #fca5a5; }
[data-theme="dark"] .cmte-stat-box     { background: var(--bg-hover); }
[data-theme="dark"] .cmte-stat-num     { color: var(--text-primary); }
[data-theme="dark"] .cmte-party-bar    { background: #374151; }
[data-theme="dark"] .cmte-score-large.cmte-score-green { color: #86efac; }
[data-theme="dark"] .cmte-score-large.cmte-score-amber { color: #fcd34d; }
[data-theme="dark"] .cmte-score-large.cmte-score-red   { color: #fca5a5; }
[data-theme="dark"] .cmte-member-card {
    background: var(--bg-card); border-color: var(--card-border);
}
[data-theme="dark"] .cmte-member-card:hover {
    border-color: #5B8DB8; box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
[data-theme="dark"] .cmte-member-name { color: var(--text-primary); }
[data-theme="dark"] .cmte-member-photo img { box-shadow: 0 2px 6px rgba(0,0,0,0.3); }
[data-theme="dark"] .cmte-member-score-bar { background: #374151; }

/* ============================================================
   Watchdog Studio (v10.84)
   ============================================================ */
.studio-page { max-width: 1280px; margin: 0 auto; padding: 24px; }
.studio-page-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 32px; gap: 16px;
}
.studio-page-title { font-size: 28px; margin: 0 0 4px 0; color: var(--text-primary); }
.studio-page-sub { color: var(--text-secondary); margin: 0; }

.studio-empty {
  text-align: center; padding: 80px 20px; background: var(--bg-card);
  border: 2px dashed var(--border-color); border-radius: 12px;
}
.studio-empty h3 { color: var(--text-primary); margin: 0 0 8px 0; }
.studio-empty p { color: var(--text-secondary); margin: 0 0 20px 0; }

.studio-session-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
}
.studio-session-card {
  display: block; padding: 18px; background: var(--bg-card);
  border: 1px solid var(--border-color); border-radius: 10px;
  text-decoration: none; color: inherit; transition: all 0.15s;
}
.studio-session-card:hover {
  border-color: #1B3A6B; transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(27,58,107,0.08);
}
.studio-session-card-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 10px;
}
.studio-session-card-title {
  font-size: 16px; font-weight: 600; color: var(--text-primary);
  margin: 0 0 8px 0; line-height: 1.3;
}
.studio-session-card-meta { font-size: 12px; color: var(--text-secondary); margin-bottom: 8px; }
.studio-session-card-ctx { font-size: 12px; color: #1B3A6B; font-weight: 500; margin-bottom: 6px; }
.studio-session-card-time { font-size: 11px; color: var(--text-secondary); }

.studio-mode-pill {
  display: inline-block; padding: 3px 10px; background: #1B3A6B; color: white;
  border-radius: 12px; font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.5px;
}
.studio-ctx-pill {
  display: inline-block; padding: 3px 10px; background: #FFF7E6; color: #92400E;
  border: 1px solid #FCD34D; border-radius: 12px; font-size: 11px; font-weight: 500;
}
.studio-session-status {
  font-size: 10px; padding: 2px 8px; border-radius: 8px; text-transform: uppercase;
  font-weight: 600;
}
.studio-status-active { background: #DCFCE7; color: #166534; }
.studio-status-archived { background: #F1F5F9; color: #475569; }
.studio-status-exported { background: #E0E7FF; color: #3730A3; }

/* ── New session form ── */
.studio-new-form {
  max-width: 640px; background: var(--bg-card); padding: 28px;
  border: 1px solid var(--border-color); border-radius: 12px;
}
.studio-form-group { margin-bottom: 22px; }
.studio-form-group label {
  display: block; font-weight: 600; margin-bottom: 6px; color: var(--text-primary);
}
.studio-form-group input, .studio-form-group select, .studio-form-group textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--border-color);
  border-radius: 6px; font-size: 14px; background: white;
}
.studio-form-group small { display: block; margin-top: 4px; color: var(--text-secondary); font-size: 12px; }
.studio-form-actions { display: flex; gap: 12px; margin-top: 28px; }

/* ── Session view (two-pane) ── */
.studio-session-page { padding: 0; max-width: none; margin: 0; }
.studio-session-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 16px 24px; background: var(--bg-card);
  border-bottom: 1px solid var(--border-color);
}
.studio-session-header-left { flex: 1; min-width: 0; }
.studio-back {
  display: inline-block; font-size: 12px; color: var(--text-secondary);
  text-decoration: none; margin-bottom: 4px;
}
.studio-back:hover { color: #1B3A6B; }
.studio-session-title {
  font-size: 20px; font-weight: 600; margin: 0 0 6px 0; color: var(--text-primary);
  outline: none; padding: 2px 4px; border-radius: 4px;
}
.studio-session-title:focus { background: #FFF7E6; }
.studio-session-chips { display: flex; gap: 8px; flex-wrap: wrap; }
.studio-session-header-right { display: flex; gap: 8px; }
.btn-danger-outline {
  background: white; border: 1px solid #DC2626; color: #DC2626;
  padding: 6px 10px; border-radius: 6px; cursor: pointer;
}
.btn-danger-outline:hover { background: #DC2626; color: white; }

.studio-context-bar {
  padding: 10px 24px; background: #FFF7E6; border-bottom: 1px solid #FCD34D;
  font-size: 13px; color: #78350F;
  display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
}
.studio-context-detail { color: #92400E; }
.studio-context-tag {
  display: inline-block; padding: 2px 8px; background: white;
  border: 1px solid #16A34A; color: #166534; border-radius: 10px;
  font-size: 11px; font-weight: 500;
}

.studio-pane {
  display: grid; grid-template-columns: 1fr 1fr;
  height: calc(100vh - 180px); min-height: 500px;
}

/* Chat pane */
.studio-chat-pane {
  display: flex; flex-direction: column; border-right: 1px solid var(--border-color);
  background: #FAFBFC;
}
.studio-chat-messages {
  flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 14px;
}
.studio-chat-welcome {
  background: white; border: 1px dashed var(--border-color); border-radius: 10px;
  padding: 20px; color: var(--text-secondary);
}
.studio-chat-welcome h3 { color: var(--text-primary); margin: 0 0 8px 0; }
.studio-chat-welcome ul { margin: 8px 0; padding-left: 20px; font-size: 13px; }
.studio-suggest { font-size: 13px; color: #1B3A6B; }

.studio-msg { background: white; border: 1px solid var(--border-color); border-radius: 10px; padding: 12px 14px; }
.studio-msg-user { background: #EFF6FF; border-color: #BFDBFE; }
.studio-msg-assistant { background: white; }
.studio-msg-role { font-size: 11px; font-weight: 600; color: var(--text-secondary); text-transform: uppercase; margin-bottom: 4px; letter-spacing: 0.5px; }
.studio-msg-body { font-size: 14px; line-height: 1.55; color: var(--text-primary); white-space: pre-wrap; word-wrap: break-word; }

.studio-chat-form {
  border-top: 1px solid var(--border-color); padding: 12px 16px; background: white;
}
.studio-chat-form textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--border-color);
  border-radius: 8px; font-size: 14px; resize: vertical; font-family: inherit;
}
.studio-chat-form-row {
  display: flex; justify-content: space-between; align-items: center; margin-top: 8px;
}
.studio-chat-form small { color: var(--text-secondary); font-size: 11px; }

/* Document pane */
.studio-doc-pane { display: flex; flex-direction: column; background: white; }
.studio-doc-header {
  padding: 10px 16px; border-bottom: 1px solid var(--border-color);
  display: flex; align-items: center; gap: 12px; background: #F8FAFC;
}
.studio-doc-header strong { color: var(--text-primary); }
.studio-doc-header span { flex: 1; font-size: 12px; color: var(--text-secondary); }
.studio-doc-editor {
  flex: 1; padding: 24px 32px; border: none; outline: none; resize: none;
  font-family: Georgia, "Times New Roman", serif; font-size: 15px; line-height: 1.7;
  color: var(--text-primary); background: white;
}

/* Mobile fallback */
@media (max-width: 900px) {
  .studio-pane { grid-template-columns: 1fr; height: auto; }
  .studio-chat-pane { border-right: none; border-bottom: 1px solid var(--border-color); }
  .studio-chat-messages { max-height: 60vh; }
  .studio-doc-editor { min-height: 400px; }
}

/* Dark mode */
[data-theme="dark"] .studio-session-card { background: #1E1E30; border-color: #374151; }
[data-theme="dark"] .studio-session-card:hover { border-color: #5B8DB8; }
[data-theme="dark"] .studio-chat-pane { background: #0F0F1A; }
[data-theme="dark"] .studio-msg { background: #1E1E30; border-color: #374151; }
[data-theme="dark"] .studio-msg-user { background: #1e3a5f; border-color: #2d4f7d; }
[data-theme="dark"] .studio-chat-welcome { background: #1E1E30; }
[data-theme="dark"] .studio-doc-pane { background: #1A1A2E; }
[data-theme="dark"] .studio-doc-header { background: #0F0F1A; }
[data-theme="dark"] .studio-doc-editor { background: #1A1A2E; color: var(--text-primary); }
[data-theme="dark"] .studio-context-bar { background: #2d2410; border-color: #92400E; color: #FCD34D; }
[data-theme="dark"] .studio-empty { background: #1E1E30; border-color: #374151; }
[data-theme="dark"] .studio-new-form { background: #1E1E30; border-color: #374151; }
[data-theme="dark"] .studio-form-group input, [data-theme="dark"] .studio-form-group select, [data-theme="dark"] .studio-form-group textarea { background: #0F0F1A; color: var(--text-primary); border-color: #374151; }

/* Studio Phase 2 — section headers in the new-session form */
.studio-form-section {
  margin: 28px 0 12px 0; padding-top: 18px;
  border-top: 1px solid var(--border-color);
}
.studio-form-section-title {
  font-size: 13px; font-weight: 700; margin: 0 0 4px 0;
  text-transform: uppercase; letter-spacing: 0.08em; color: #1B3A6B;
}
.studio-form-section-sub { margin: 0; font-size: 12px; color: var(--text-secondary); }
.studio-mode-description {
  font-style: italic; color: #475569 !important;
  padding: 6px 10px; background: #F8FAFC; border-left: 3px solid #1B3A6B;
  margin-top: 6px !important; display: block;
}
[data-theme="dark"] .studio-form-section { border-top-color: #374151; }
[data-theme="dark"] .studio-form-section-title { color: #5B8DB8; }
[data-theme="dark"] .studio-mode-description { background: #0F0F1A; color: #94A3B8 !important; border-left-color: #5B8DB8; }

/* Studio Phase 3 — modal + history + templates */
.studio-modal {
  position: fixed; inset: 0; z-index: var(--z-bottom-sheet);
  display: flex; align-items: center; justify-content: center;
}
.studio-modal-backdrop {
  position: absolute; inset: 0; background: rgba(15,15,26,0.55);
  backdrop-filter: blur(3px);
}
.studio-modal-box {
  position: relative; background: white; width: min(720px, 94vw);
  max-height: 82vh; border-radius: 12px; overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 50px rgba(0,0,0,0.25);
}
.studio-modal-header {
  padding: 14px 20px; border-bottom: 1px solid var(--border-color);
  display: flex; justify-content: space-between; align-items: center;
  background: #F8FAFC;
}
.studio-modal-close {
  background: none; border: none; font-size: 22px; cursor: pointer;
  color: var(--text-secondary); width: 32px; height: 32px;
  border-radius: 6px;
}
.studio-modal-close:hover { background: #E2E8F0; color: var(--text-primary); }
.studio-modal-body { padding: 16px 20px; overflow-y: auto; }

.studio-history-row {
  padding: 12px 14px; border: 1px solid var(--border-color);
  border-radius: 8px; margin-bottom: 10px; background: white;
}
.studio-history-row.is-current {
  border-color: #1B3A6B; background: #EFF6FF;
}
.studio-history-row-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 6px;
}
.studio-history-row-head strong { font-size: 14px; color: #1B3A6B; }
.studio-history-row-head span { font-size: 12px; color: var(--text-secondary); }
.studio-history-ts { flex: 1; }
.studio-history-pill {
  padding: 3px 10px; background: #1B3A6B; color: white;
  border-radius: 10px; font-size: 10px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
}
.studio-history-preview {
  font-size: 12px; color: var(--text-secondary); font-family: Georgia, serif;
  font-style: italic; line-height: 1.5; max-height: 48px; overflow: hidden;
}

[data-theme="dark"] .studio-modal-box { background: #1E1E30; }
[data-theme="dark"] .studio-modal-header { background: #0F0F1A; border-bottom-color: #374151; }
[data-theme="dark"] .studio-modal-close:hover { background: #374151; }
[data-theme="dark"] .studio-history-row { background: #1E1E30; border-color: #374151; }
[data-theme="dark"] .studio-history-row.is-current { background: #1e3a5f; border-color: #5B8DB8; }
[data-theme="dark"] .studio-history-row-head strong { color: #5B8DB8; }

/* Studio Phase 4 — mobile tabs + download group */
.studio-download-group { display: inline-flex; gap: 4px; margin-right: 4px; }
.studio-download-group .btn { padding: 6px 10px; font-size: 12px; }

.studio-tab-bar {
  display: none;  /* hidden on desktop */
  border-bottom: 1px solid var(--border-color);
  background: #F8FAFC;
}
.studio-tab {
  flex: 1; padding: 12px 16px; border: none; background: transparent;
  font-size: 14px; font-weight: 600; color: var(--text-secondary);
  cursor: pointer; border-bottom: 3px solid transparent;
}
.studio-tab-active {
  color: #1B3A6B; border-bottom-color: #1B3A6B; background: white;
}

@media (max-width: 900px) {
  .studio-tab-bar { display: flex; }
  .studio-pane { display: block; }  /* override grid */
  .studio-pane-hidden-mobile { display: none !important; }
  .studio-chat-pane { border-right: none; }
  .studio-chat-messages { max-height: calc(100vh - 340px); }
  .studio-doc-pane { min-height: calc(100vh - 240px); }
  .studio-doc-editor { min-height: calc(100vh - 320px); padding: 18px 20px; font-size: 14px; }
  .studio-session-header { flex-direction: column; gap: 10px; align-items: stretch; }
  .studio-session-header-right { flex-wrap: wrap; gap: 6px; }
  .studio-session-header-right .btn { padding: 6px 10px; font-size: 12px; }
  .studio-download-group { width: 100%; }
  .studio-download-group .btn { flex: 1; }
}

[data-theme="dark"] .studio-tab-bar { background: #0F0F1A; border-bottom-color: #374151; }
[data-theme="dark"] .studio-tab-active { background: #1A1A2E; color: #5B8DB8; border-bottom-color: #5B8DB8; }

/* ============================================================
   Studio v10.85 — Design audit redesign (RED + YELLOW items)
   ============================================================ */
:root {
  --st-navy-900: #0F1F3A;
  --st-navy-800: #1B3A6B;
  --st-navy-700: #2B4F85;
  --st-navy-500: #5B8DB8;
  --st-navy-100: #DDE7F3;
  --st-gold-600: #C9A84C;
  --st-gold-100: #FFF7E6;
  --st-ink-900: #0F172A;
  --st-ink-700: #334155;
  --st-ink-500: #64748B;
  --st-ink-300: #CBD5E1;
  --st-ink-200: #E2E8F0;
  --st-ink-100: #F1F5F9;
  --st-ink-50:  #F8FAFC;
  --st-paper:   #FFFFFF;
  --st-cream:   #FFFBF5;
  --st-radius-sm: 6px;
  --st-radius-md: 10px;
  --st-radius-lg: 16px;
  --st-shadow-sm: 0 2px 6px rgba(15,23,42,0.06);
  --st-shadow-md: 0 6px 18px rgba(15,23,42,0.08);
  --st-shadow-doc: 0 1px 3px rgba(15,23,42,0.04), 0 24px 48px rgba(15,23,42,0.08);
  --st-ease: cubic-bezier(0.16, 1, 0.3, 1);
}
[data-theme="dark"] {
  --st-paper: #1A1A2E;
  --st-cream: #1A1A2E;
  --st-ink-50: #0F0F1A;
  --st-ink-100: #1E1E30;
  --st-ink-200: #2A2A3E;
  --st-ink-300: #374151;
  --st-ink-500: #94A3B8;
  --st-ink-700: #CBD5E1;
  --st-ink-900: #E2E8F0;
}

.st-icon { width: 16px; height: 16px; stroke: currentColor; fill: none;
  stroke-width: 1.75; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0; vertical-align: -3px; }
.st-icon-lg { width: 22px; height: 22px; }

/* Rebalanced two-pane: 42/58 favoring document */
.studio-pane { grid-template-columns: 42% 58%; }

/* Document pane elevation — the work product is the hero */
.studio-doc-pane {
  background: var(--st-cream);
  position: relative;
}
.studio-doc-pane::before {
  content: '';
  position: absolute; inset: 0;
  pointer-events: none;
  box-shadow: inset 1px 0 0 var(--st-ink-200);
}
.studio-doc-header {
  padding: 14px 32px;
  background: var(--st-paper);
  border-bottom: 1px solid var(--st-ink-200);
}
.studio-doc-editor {
  padding: 32px 56px !important;
  background: var(--st-cream) !important;
  font-family: var(--font-serif) !important;
  font-size: 17px !important;
  line-height: 1.7 !important;
}
[data-theme="dark"] .studio-doc-editor { color: var(--st-ink-900) !important; }

.studio-chat-pane { background: var(--st-ink-50); }

/* Edit/Preview tabs in document pane */
.studio-doc-mode-tabs {
  display: inline-flex;
  background: var(--st-ink-100);
  border-radius: var(--st-radius-sm);
  padding: 2px;
  margin-right: auto;
}
.studio-doc-mode-tab {
  padding: 6px 14px;
  border: none;
  background: transparent;
  color: var(--st-ink-500);
  font-size: 12px;
  font-weight: 600;
  border-radius: 4px;
  cursor: pointer;
  transition: all 120ms var(--st-ease);
  min-height: 28px;
}
.studio-doc-mode-tab.is-active {
  background: var(--st-paper);
  color: var(--st-navy-800);
  box-shadow: var(--st-shadow-sm);
}
[data-theme="dark"] .studio-doc-mode-tab.is-active { background: var(--st-ink-200); color: var(--st-navy-500); }

.studio-doc-preview {
  display: none;
  flex: 1;
  padding: 32px 56px;
  overflow-y: auto;
  background: var(--st-cream);
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.7;
  color: var(--st-ink-900);
}
.studio-doc-preview.is-active { display: block; }
.studio-doc-editor.is-hidden { display: none !important; }
.studio-doc-preview h1, .studio-doc-preview h2, .studio-doc-preview h3 {
  font-family: var(--font-sans);
  color: var(--st-navy-800);
  margin: 1.4em 0 0.5em;
  line-height: 1.25;
}
.studio-doc-preview h1 { font-size: 28px; font-weight: 700; }
.studio-doc-preview h2 { font-size: 22px; font-weight: 700; }
.studio-doc-preview h3 { font-size: 18px; font-weight: 600; }
.studio-doc-preview h1:first-child, .studio-doc-preview h2:first-child { margin-top: 0; }
.studio-doc-preview p { margin: 0 0 1em; }
.studio-doc-preview strong { font-weight: 700; color: var(--st-ink-900); }
.studio-doc-preview em { font-style: italic; }
.studio-doc-preview ul, .studio-doc-preview ol { margin: 0 0 1em; padding-left: 1.4em; }
.studio-doc-preview li { margin-bottom: 0.3em; }
.studio-doc-preview blockquote {
  margin: 1em 0; padding: 0.5em 1em;
  border-left: 3px solid var(--st-navy-800);
  background: var(--st-ink-50);
  color: var(--st-ink-700);
}
.studio-doc-preview code {
  font-family: ui-monospace, "JetBrains Mono", monospace;
  font-size: 13px;
  background: var(--st-ink-100); padding: 1px 5px;
  border-radius: 3px;
}
.studio-doc-preview hr { border: none; border-top: 1px solid var(--st-ink-200); margin: 2em 0; }
[data-theme="dark"] .studio-doc-preview { background: var(--st-cream); color: var(--st-ink-900); }

/* AI is drafting — shimmer overlay */
.studio-doc-pane.is-thinking .studio-doc-editor,
.studio-doc-pane.is-thinking .studio-doc-preview {
  opacity: 0.5;
  pointer-events: none;
}
.studio-doc-pane.is-thinking::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--st-navy-800), transparent);
  animation: stShimmer 1.4s ease-in-out infinite;
  z-index: 5;
}
@keyframes stShimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

@keyframes stFlash {
  0% { background: var(--st-gold-100) !important; }
  100% { background: var(--st-cream) !important; }
}
.studio-doc-editor.just-refreshed,
.studio-doc-preview.just-refreshed { animation: stFlash 1.2s ease-out; }

/* Avatar circles for chat */
.studio-msg { display: flex; gap: 12px; align-items: flex-start; padding: 4px 0;
  background: transparent !important; border: none !important; border-radius: 0 !important; }
.studio-msg-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
  flex-shrink: 0;
}
.studio-msg-user .studio-msg-avatar {
  background: var(--st-navy-800); color: white;
}
.studio-msg-assistant .studio-msg-avatar {
  background: var(--st-gold-100); color: var(--st-navy-800);
  border: 1px solid var(--st-gold-600);
}
.studio-msg-content { flex: 1; min-width: 0; }
.studio-msg-content-head {
  display: flex; align-items: baseline; gap: 8px; margin-bottom: 4px;
}
.studio-msg-content-name {
  font-size: 13px; font-weight: 600; color: var(--st-ink-900);
}
.studio-msg-content-time {
  font-size: 11px; color: var(--st-ink-500);
}
.studio-msg .studio-msg-body {
  font-size: 14px; line-height: 1.55;
  color: var(--st-ink-700);
  white-space: normal;
}
.studio-msg-body p { margin: 0 0 0.6em; }
.studio-msg-body p:last-child { margin-bottom: 0; }
.studio-msg-body strong { font-weight: 700; color: var(--st-ink-900); }
.studio-msg-body em { font-style: italic; }
.studio-msg-body ul, .studio-msg-body ol { margin: 0.4em 0; padding-left: 1.4em; }
.studio-msg-body code {
  font-family: ui-monospace, monospace; font-size: 12px;
  background: var(--st-ink-100); padding: 1px 5px; border-radius: 3px;
}

/* Typing indicator */
.studio-typing { display: inline-flex; gap: 4px; padding: 6px 0; }
.studio-typing span {
  width: 7px; height: 7px;
  background: var(--st-navy-500);
  border-radius: 50%;
  animation: stBounce 1.2s ease-in-out infinite;
}
.studio-typing span:nth-child(2) { animation-delay: 0.15s; }
.studio-typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes stBounce {
  0%, 60%, 100% { transform: translateY(0); opacity: 0.5; }
  30% { transform: translateY(-5px); opacity: 1; }
}

/* Header More menu + Export dropdown */
.studio-more-wrap, .studio-export-wrap { position: relative; display: inline-block; }
.studio-more-btn {
  background: var(--st-paper); border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-sm);
  width: 38px; height: 38px;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--st-ink-700);
  transition: all 120ms var(--st-ease);
}
.studio-more-btn:hover { background: var(--st-ink-100); border-color: var(--st-navy-500); }
.studio-more-menu, .studio-export-menu {
  display: none;
  position: absolute; top: calc(100% + 6px); right: 0;
  background: var(--st-paper);
  border: 1px solid var(--st-ink-200);
  border-radius: var(--st-radius-md);
  box-shadow: var(--st-shadow-md);
  min-width: 200px;
  padding: 6px;
  z-index: var(--z-sticky-sub);
}
.studio-more-menu.is-open, .studio-export-menu.is-open { display: block; }
.studio-more-item {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 9px 12px;
  background: none; border: none;
  font-size: 13px; color: var(--st-ink-700);
  text-align: left; cursor: pointer;
  border-radius: 6px;
  text-decoration: none;
}
.studio-more-item:hover { background: var(--st-ink-100); color: var(--st-navy-800); }
.studio-more-item.is-danger { color: #B91C1C; }
.studio-more-item.is-danger:hover { background: #FEE2E2; }
.studio-more-divider { height: 1px; background: var(--st-ink-200); margin: 4px 0; }

/* Mode card grid (new session form) */
.studio-mode-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 8px;
}
.studio-mode-card {
  border: 2px solid var(--st-ink-200);
  border-radius: var(--st-radius-md);
  padding: 16px;
  background: var(--st-paper);
  cursor: pointer;
  transition: all 160ms var(--st-ease);
  text-align: left;
  display: flex; flex-direction: column; gap: 6px;
  min-height: 110px;
  font-family: inherit;
}
.studio-mode-card:hover {
  border-color: var(--st-navy-500);
  transform: translateY(-1px);
  box-shadow: var(--st-shadow-sm);
}
.studio-mode-card.is-selected {
  border-color: var(--st-navy-800);
  background: var(--st-navy-100);
  box-shadow: var(--st-shadow-sm);
}
[data-theme="dark"] .studio-mode-card { background: var(--st-ink-100); border-color: var(--st-ink-300); }
[data-theme="dark"] .studio-mode-card.is-selected { background: rgba(91,141,184,0.15); border-color: var(--st-navy-500); }
.studio-mode-card-icon { color: var(--st-navy-800); width: 24px; height: 24px; }
[data-theme="dark"] .studio-mode-card-icon { color: var(--st-navy-500); }
.studio-mode-card-name { font-size: 14px; font-weight: 700; color: var(--st-ink-900); }
.studio-mode-card-desc { font-size: 12px; color: var(--st-ink-500); line-height: 1.4; }
@media (max-width: 768px) {
  .studio-mode-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .studio-mode-grid { grid-template-columns: 1fr; }
}

/* Diff view in version history */
.studio-diff-controls {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: var(--st-ink-50);
  border-bottom: 1px solid var(--st-ink-200);
  font-size: 12px;
}
.studio-diff-controls strong { color: var(--st-navy-800); }
.studio-diff-view {
  padding: 16px 20px;
  font-family: ui-monospace, "JetBrains Mono", monospace;
  font-size: 12px;
  line-height: 1.55;
  white-space: pre-wrap;
  word-wrap: break-word;
  max-height: 50vh;
  overflow-y: auto;
}
.studio-diff-add { background: #DCFCE7; color: #14532D; }
.studio-diff-del { background: #FEE2E2; color: #7F1D1D; text-decoration: line-through; }
[data-theme="dark"] .studio-diff-add { background: rgba(34,197,94,0.18); color: #86EFAC; }
[data-theme="dark"] .studio-diff-del { background: rgba(239,68,68,0.18); color: #FCA5A5; }
.studio-history-compare {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; color: var(--st-ink-500);
}
.studio-history-compare input { margin: 0; }

/* Focus styles */
.studio-page :focus-visible,
.studio-session-page :focus-visible {
  outline: 2px solid var(--st-navy-500);
  outline-offset: 2px;
  border-radius: 3px;
}

/* Editable title affordance */
.studio-session-title {
  cursor: text;
  position: relative;
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid transparent;
  transition: all 120ms var(--st-ease);
}
.studio-session-title:hover {
  border-color: var(--st-ink-200);
  background: var(--st-ink-50);
}
.studio-session-title:focus {
  border-color: var(--st-navy-500);
  background: var(--st-paper);
  outline: none;
}
[data-theme="dark"] .studio-session-title:hover { background: var(--st-ink-100); }

/* Suggestion chips in chat empty state */
.studio-suggest-chips {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 14px;
}
.studio-suggest-chip {
  padding: 8px 14px;
  background: var(--st-paper);
  border: 1px solid var(--st-ink-300);
  border-radius: 999px;
  font-size: 12px;
  color: var(--st-navy-800);
  cursor: pointer;
  transition: all 120ms var(--st-ease);
  font-family: inherit;
}
.studio-suggest-chip:hover {
  background: var(--st-navy-100);
  border-color: var(--st-navy-500);
}
[data-theme="dark"] .studio-suggest-chip { background: var(--st-ink-100); }

.studio-session-page .btn { min-height: 38px; }
.studio-session-page .btn-sm { min-height: 32px; padding: 6px 12px; }

@media (max-width: 900px) {
  .studio-pane { grid-template-columns: 1fr !important; }
  .studio-doc-editor { padding: 18px 22px !important; font-size: 15px !important; }
  .studio-doc-preview { padding: 18px 22px; font-size: 15px; }
  .studio-doc-header { padding: 10px 16px; }
}

/* ============================================================
   Studio v10.86 — Remaining audit items (Y + G tier)
   ============================================================ */

/* G1 — Branded typography (v11.11 — Avenir Next + Garamond). Self-hosted via variables.css @font-face. */
.studio-page, .studio-session-page {
  font-family: var(--font-sans);
}
.studio-page-title, .studio-session-title,
.studio-session-card-title, .studio-form-section-title {
  font-family: var(--font-sans);
  letter-spacing: -0.01em;
}
.studio-doc-editor, .studio-doc-preview {
  font-family: var(--font-serif) !important;
}
.studio-doc-preview h1, .studio-doc-preview h2, .studio-doc-preview h3 {
  font-family: var(--font-sans);
}

/* G2 — Ambient motion / micro-interactions */
@keyframes stFadeIn {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes stSlideUp {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.studio-msg { animation: stFadeIn 240ms var(--st-ease) both; }
.studio-modal-box { animation: stSlideUp 200ms var(--st-ease) both; }
.studio-session-card { animation: stFadeIn 200ms var(--st-ease) both; }
.studio-session-card:hover {
  border-color: var(--st-navy-500);
  transform: translateY(-2px);
  box-shadow: var(--st-shadow-md);
}
@keyframes stPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(27,58,107,0.4); }
  50%      { box-shadow: 0 0 0 6px rgba(27,58,107,0); }
}
.studio-msg-assistant.is-fresh .studio-msg-avatar { animation: stPulse 1.4s var(--st-ease); }
@media (prefers-reduced-motion: reduce) {
  .studio-msg, .studio-modal-box, .studio-session-card { animation: none !important; }
}

/* Y2 — Searchable bill combobox */
.studio-combobox { position: relative; }
.studio-combobox-input {
  width: 100%; padding: 10px 12px;
  border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-sm);
  font-size: 14px;
  background: var(--st-paper);
  color: var(--st-ink-900);
}
.studio-combobox-list {
  display: none;
  position: absolute; left: 0; right: 0; top: calc(100% + 4px);
  background: var(--st-paper);
  border: 1px solid var(--st-ink-200);
  border-radius: var(--st-radius-md);
  box-shadow: var(--st-shadow-md);
  max-height: 320px; overflow-y: auto;
  z-index: 60;
}
.studio-combobox-list.is-open { display: block; }
.studio-combobox-item {
  padding: 10px 14px;
  display: flex; flex-direction: column; gap: 2px;
  cursor: pointer;
  border-bottom: 1px solid var(--st-ink-100);
}
.studio-combobox-item:hover, .studio-combobox-item.is-active {
  background: var(--st-navy-100);
}
.studio-combobox-item-row1 {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--st-ink-900);
}
.studio-combobox-item-row2 {
  font-size: 12px; color: var(--st-ink-500);
}
.studio-combobox-stance {
  font-size: 10px; padding: 1px 6px; border-radius: 999px;
  text-transform: uppercase; font-weight: 700; letter-spacing: 0.05em;
}
.studio-combobox-stance.is-support { background: #DCFCE7; color: #166534; }
.studio-combobox-stance.is-oppose { background: #FEE2E2; color: #991B1B; }
.studio-combobox-stance.is-watching { background: var(--st-ink-100); color: var(--st-ink-700); }

/* Y4 — Document previews on session cards */
.studio-session-card-preview {
  font-family: var(--font-serif);
  font-size: 12px;
  color: var(--st-ink-500);
  line-height: 1.5;
  background: var(--st-cream);
  border-left: 2px solid var(--st-ink-200);
  padding: 8px 10px;
  border-radius: 0 6px 6px 0;
  margin: 8px 0;
  max-height: 56px;
  overflow: hidden;
  position: relative;
}
.studio-session-card-preview::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 16px;
  background: linear-gradient(transparent, var(--st-cream));
}
[data-theme="dark"] .studio-session-card-preview { background: var(--st-ink-50); }

/* Y5 — Dashboard filters + groups */
.studio-filters {
  display: flex; flex-wrap: wrap; gap: 10px;
  align-items: center;
  padding: 14px 16px;
  background: var(--st-paper);
  border: 1px solid var(--st-ink-200);
  border-radius: var(--st-radius-md);
  margin-bottom: 16px;
}
.studio-filters input[type="search"] {
  flex: 1; min-width: 200px;
  padding: 8px 12px;
  border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-sm);
  font-size: 13px;
  font-family: inherit;
}
.studio-filters select {
  padding: 8px 10px;
  border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-sm);
  font-size: 13px;
  background: var(--st-paper);
  color: var(--st-ink-700);
  font-family: inherit;
}
.studio-group-heading {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--st-ink-500);
  margin: 24px 0 10px 4px;
}
.studio-group-heading:first-of-type { margin-top: 8px; }
.studio-archive-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  font-size: 12px;
  color: var(--st-ink-500);
  background: var(--st-ink-50);
  border: 1px dashed var(--st-ink-300);
  border-radius: var(--st-radius-sm);
  text-decoration: none;
  margin-top: 12px;
}
.studio-archive-toggle:hover { color: var(--st-navy-800); border-color: var(--st-navy-500); }

/* Y10 — Inline AI selection toolbar */
.studio-selection-toolbar {
  position: absolute;
  display: none;
  background: var(--st-navy-900);
  color: white;
  border-radius: var(--st-radius-sm);
  padding: 4px;
  box-shadow: var(--st-shadow-md);
  z-index: var(--z-sticky);
  gap: 2px;
  align-items: center;
}
.studio-selection-toolbar.is-open { display: inline-flex; }
.studio-selection-toolbar button {
  background: transparent;
  border: none;
  color: white;
  font-size: 12px;
  font-weight: 500;
  padding: 6px 10px;
  cursor: pointer;
  border-radius: 4px;
  font-family: inherit;
}
.studio-selection-toolbar button:hover { background: var(--st-navy-700); }

/* Y11 — Template thumbnail rows in select */
.studio-template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
  margin-top: 8px;
}
.studio-template-card {
  border: 2px solid var(--st-ink-200);
  border-radius: var(--st-radius-sm);
  padding: 12px;
  background: var(--st-paper);
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  transition: all 160ms var(--st-ease);
}
.studio-template-card:hover { border-color: var(--st-navy-500); }
.studio-template-card.is-selected { border-color: var(--st-navy-800); background: var(--st-navy-100); }
.studio-template-card-name { font-size: 13px; font-weight: 700; color: var(--st-ink-900); margin-bottom: 4px; }
.studio-template-card-desc { font-size: 11px; color: var(--st-ink-500); line-height: 1.4; }
.studio-template-card-thumb {
  height: 32px; margin-bottom: 8px;
  background: linear-gradient(180deg, var(--st-cream) 0%, var(--st-ink-50) 100%);
  border-radius: 3px;
  display: flex; align-items: center; padding: 4px 8px;
  gap: 3px; flex-direction: column;
}
.studio-template-card-thumb-line {
  height: 2px; background: var(--st-ink-300); border-radius: 1px; width: 100%;
}
.studio-template-card-thumb-line.short { width: 60%; }
.studio-template-card-thumb-line.medium { width: 80%; }

/* Y12 — Wizard steps */
.studio-wizard {
  margin-top: 8px;
}
.studio-wizard-progress {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 24px;
  padding: 0 4px;
}
.studio-wizard-step-dot {
  display: flex; align-items: center; gap: 8px;
  flex: 1;
}
.studio-wizard-step-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--st-ink-200);
  color: var(--st-ink-500);
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 700;
  flex-shrink: 0;
  transition: all 200ms var(--st-ease);
}
.studio-wizard-step.is-active .studio-wizard-step-num {
  background: var(--st-navy-800); color: white;
  box-shadow: 0 0 0 4px var(--st-navy-100);
}
.studio-wizard-step.is-done .studio-wizard-step-num {
  background: #15803D; color: white;
}
.studio-wizard-step-label {
  font-size: 12px; font-weight: 600;
  color: var(--st-ink-500);
}
.studio-wizard-step.is-active .studio-wizard-step-label { color: var(--st-navy-800); }
.studio-wizard-step-line {
  flex: 1; height: 2px;
  background: var(--st-ink-200);
}
.studio-wizard-step.is-done + .studio-wizard-step-line { background: #15803D; }
.studio-wizard-panel { display: none; animation: stFadeIn 200ms var(--st-ease) both; }
.studio-wizard-panel.is-active { display: block; }
.studio-wizard-nav {
  display: flex; gap: 12px; justify-content: space-between;
  margin-top: 24px; padding-top: 20px;
  border-top: 1px solid var(--st-ink-200);
}

/* G3 — Presence avatars */
.studio-presence {
  display: inline-flex; align-items: center; gap: -6px;
  margin-left: 8px;
}
.studio-presence-avatar {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--st-navy-800);
  color: white;
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--st-paper);
  margin-left: -8px;
  position: relative;
}
.studio-presence-avatar:first-child { margin-left: 0; }
.studio-presence-avatar.is-self { background: var(--st-gold-600); color: var(--st-navy-900); }

/* G4 — Quick Look hover preview */
.studio-history-row {
  position: relative;
  cursor: default;
  transition: all 120ms var(--st-ease);
}
.studio-history-row:hover {
  border-color: var(--st-navy-500);
  background: var(--st-ink-50);
}
.studio-quicklook {
  display: none;
  position: fixed;
  width: 360px;
  max-height: 50vh;
  background: var(--st-cream);
  border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-md);
  box-shadow: var(--st-shadow-doc);
  padding: 16px 20px;
  font-family: var(--font-serif);
  font-size: 12px;
  line-height: 1.5;
  overflow: hidden;
  z-index: var(--z-dropdown);
  pointer-events: none;
}
.studio-quicklook.is-open { display: block; }
.studio-quicklook::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 32px;
  background: linear-gradient(transparent, var(--st-cream));
}

/* G6 — Suggested next action chips */
.studio-suggest-row {
  display: none;
  flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
  padding: 10px;
  background: var(--st-gold-100);
  border: 1px solid var(--st-gold-600);
  border-radius: var(--st-radius-sm);
}
.studio-suggest-row.is-visible { display: flex; }
.studio-suggest-row-label {
  width: 100%; font-size: 11px; font-weight: 700;
  color: var(--st-navy-800);
  text-transform: uppercase; letter-spacing: 0.05em;
  margin-bottom: 4px;
}

/* G7 — Word-count budget badge */
.studio-budget {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 600;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--st-ink-100);
  color: var(--st-ink-500);
  margin-left: 8px;
}
.studio-budget.is-good { background: #DCFCE7; color: #166534; }
.studio-budget.is-low { background: #FEF3C7; color: #92400E; }
.studio-budget.is-over { background: #FEE2E2; color: #991B1B; }

/* G8 — Citation suggest markers */
.studio-cite-marker {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 6px;
  background: var(--st-gold-100);
  border: 1px solid var(--st-gold-600);
  color: var(--st-navy-800);
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  vertical-align: super;
}
.studio-cite-popover {
  display: none;
  position: absolute;
  background: var(--st-paper);
  border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-md);
  box-shadow: var(--st-shadow-md);
  padding: 12px;
  width: 320px;
  z-index: 150;
  font-family: var(--font-sans);
}
.studio-cite-popover.is-open { display: block; }

/* G11 — Theme variants: focus mode + print preview */
.studio-session-page.is-focus-mode .studio-session-header,
.studio-session-page.is-focus-mode .studio-context-bar,
.studio-session-page.is-focus-mode .studio-chat-pane {
  display: none !important;
}
.studio-session-page.is-focus-mode .studio-pane {
  grid-template-columns: 1fr !important;
}
.studio-session-page.is-focus-mode {
  background: #0a0a14;
}
.studio-session-page.is-focus-mode .studio-doc-pane,
.studio-session-page.is-focus-mode .studio-doc-editor,
.studio-session-page.is-focus-mode .studio-doc-preview {
  background: #0f1018 !important;
  color: #e6e1cf !important;
}
.studio-session-page.is-focus-mode .studio-doc-header {
  background: #15161f !important;
  border-bottom-color: #2a2b38;
}
.studio-focus-exit {
  position: fixed;
  top: 12px; right: 12px;
  z-index: var(--z-dropdown);
  background: var(--st-paper);
  border: 1px solid var(--st-ink-300);
  border-radius: var(--st-radius-sm);
  padding: 8px 12px;
  font-size: 12px;
  cursor: pointer;
  display: none;
}
.studio-session-page.is-focus-mode .studio-focus-exit { display: block; }

.studio-session-page.is-print-mode .studio-session-header,
.studio-session-page.is-print-mode .studio-context-bar,
.studio-session-page.is-print-mode .studio-chat-pane,
.studio-session-page.is-print-mode .studio-tab-bar {
  display: none !important;
}
.studio-session-page.is-print-mode .studio-pane {
  grid-template-columns: 1fr !important;
}
.studio-session-page.is-print-mode .studio-doc-editor { display: none !important; }
.studio-session-page.is-print-mode .studio-doc-preview {
  display: block !important;
  max-width: 720px;
  margin: 0 auto;
  padding: 64px 80px !important;
  background: white !important;
  color: black !important;
  box-shadow: var(--st-shadow-doc);
  min-height: 100vh;
}

/* Visually hidden helper for screen readers */
.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

/* Onboarding tour highlight already handled by walkthrough.js */

/* ---------- Watch Live button (committee livestream URL scraped daily) ---------- */
.btn-livestream {
    display: inline-flex; align-items: center; gap: 6px;
    background: #fef2f2;
    color: #b91c1c;
    border: 1px solid #fecaca;
    font-weight: 700;
}
.btn-livestream:hover {
    background: #fee2e2;
    border-color: #fca5a5;
    color: #991b1b;
}
.btn-livestream .ls-dot {
    width: 8px; height: 8px; border-radius: 50%;
    background: #dc2626;
    display: inline-block;
    animation: ls-pulse 1.6s ease-in-out infinite;
}
@keyframes ls-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.55; transform: scale(0.85); }
}
@media (prefers-reduced-motion: reduce) {
    .btn-livestream .ls-dot { animation: none; }
}
[data-theme="dark"] .btn-livestream {
    background: rgba(185,28,28,0.18);
    color: #fca5a5;
    border-color: rgba(252,165,165,0.35);
}
[data-theme="dark"] .btn-livestream:hover {
    background: rgba(185,28,28,0.28);
}

/* ── Dashboard hierarchical hearings (v10.89) ───────────────────────── */
/* Matches /m/today and /m/hearings: date → committee → bill rows.     */
.dash-hg { display: flex; flex-direction: column; gap: 18px; }
.dash-hg-date { display: flex; flex-direction: column; gap: 10px; }
.dash-hg-date-header {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--text-secondary);
    padding: 4px 0;
    border-bottom: 1px solid var(--border-color, #e2e8f0);
}
.dash-hg-date-header.is-today {
    color: #b91c1c;
    border-bottom-color: #fca5a5;
}
.dash-hg-date-header.is-tomorrow {
    color: #b45309;
    border-bottom-color: #fcd34d;
}
[data-theme="dark"] .dash-hg-date-header { border-bottom-color: rgba(255,255,255,0.12); }
[data-theme="dark"] .dash-hg-date-header.is-today { color: #fca5a5; border-bottom-color: rgba(252,165,165,0.4); }
[data-theme="dark"] .dash-hg-date-header.is-tomorrow { color: #fcd34d; border-bottom-color: rgba(252,211,77,0.4); }

.dash-hg-committee {
    background: var(--bg-card, #fff);
    border: 1px solid var(--border-color, #e2e8f0);
    border-radius: 8px;
    overflow: hidden;
}
[data-theme="dark"] .dash-hg-committee { background: var(--bg-card, #1E1E30); border-color: rgba(255,255,255,0.1); }

.dash-hg-committee-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 14px;
    background: rgba(15,23,42,0.02);
    border-bottom: 1px solid var(--border-color, #e2e8f0);
    flex-wrap: wrap;
}
[data-theme="dark"] .dash-hg-committee-header {
    background: rgba(255,255,255,0.02);
    border-bottom-color: rgba(255,255,255,0.08);
}
.dash-hg-committee-left {
    display: flex;
    flex-direction: column;
    min-width: 0;
    flex: 1;
}
.dash-hg-committee-name {
    font-size: 14px;
    font-weight: 700;
    color: var(--dark-navy, #002D5C);
    text-decoration: none;
}
.dash-hg-committee-name:hover { text-decoration: underline; }
[data-theme="dark"] .dash-hg-committee-name { color: #93c5fd; }
.dash-hg-arrow { font-size: 14px; color: var(--muted-gray, #64748b); }
.dash-hg-committee-room {
    font-size: 11px;
    color: var(--text-secondary);
    font-weight: 500;
    margin-top: 2px;
}
.dash-hg-committee-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--text-secondary);
    flex-wrap: wrap;
    /* Cap meta width so very long time strings ("3 p.m. or Upon Adjournment")
       can't push the committee name off the line. overflow-wrap:anywhere
       lets the text wrap mid-word as a last resort instead of forcing the
       parent flex container to expand. */
    max-width: 50%;
    min-width: 0;
    overflow-wrap: anywhere;
    text-align: right;
    justify-content: flex-end;
}
.dash-hg-sep { opacity: 0.4; }
.dash-hg-live {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 8px;
    border-radius: 12px;
    background: rgba(30,64,175,0.08);
    color: var(--cfc-blue, #1a5276);
    font-size: 11px;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid rgba(30,64,175,0.2);
}
.dash-hg-live:hover { background: rgba(30,64,175,0.15); }
.dash-hg-live.is-live {
    background: rgba(220,38,38,0.08);
    color: #b91c1c;
    border-color: rgba(220,38,38,0.25);
}
.dash-hg-live-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #dc2626;
    animation: dash-hg-pulse 1.6s ease-in-out infinite;
}
@keyframes dash-hg-pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%      { opacity: 0.55; transform: scale(1.25); }
}
[data-theme="dark"] .dash-hg-live {
    background: rgba(147,197,253,0.1);
    color: #93c5fd;
    border-color: rgba(147,197,253,0.25);
}
[data-theme="dark"] .dash-hg-live.is-live {
    background: rgba(252,165,165,0.1);
    color: #fca5a5;
    border-color: rgba(252,165,165,0.3);
}

.dash-hg-bills { display: flex; flex-direction: column; }
.dash-hg-bill {
    display: flex;
    align-items: stretch;
    gap: 10px;
    padding: 8px 14px;
    border-bottom: 1px solid rgba(15,23,42,0.05);
    text-decoration: none;
    color: inherit;
    transition: background 0.12s;
}
.dash-hg-bill:last-child { border-bottom: none; }
.dash-hg-bill:hover { background: rgba(30,64,175,0.04); }
[data-theme="dark"] .dash-hg-bill { border-bottom-color: rgba(255,255,255,0.05); }
[data-theme="dark"] .dash-hg-bill:hover { background: rgba(147,197,253,0.05); }
.dash-hg-bill.is-removed { opacity: 0.65; }

.dash-hg-bill-stance {
    width: 3px;
    border-radius: 2px;
    flex-shrink: 0;
    background: #cbd5e1;
}
.dash-hg-bill-stance.dash-hg-stance-support   { background: #16a34a; }
.dash-hg-bill-stance.dash-hg-stance-oppose    { background: #dc2626; }
.dash-hg-bill-stance.dash-hg-stance-watching  { background: #d97706; }
.dash-hg-bill-stance.dash-hg-stance-none      { background: #cbd5e1; }

.dash-hg-bill-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.dash-hg-bill-line {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
}
.dash-hg-bill-number {
    font-weight: 700;
    font-size: 14px;
    color: var(--dark-navy, #002D5C);
}
[data-theme="dark"] .dash-hg-bill-number { color: #e2e8f0; }
.dash-hg-bill-notes {
    font-size: 12px;
    font-style: italic;
    color: var(--text-secondary);
    line-height: 1.35;
}

.dash-hg-author {
    display: inline-block;
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 600;
}
.dash-hg-author-d { background: #dbeafe; color: #1e40af; }
.dash-hg-author-r { background: #fee2e2; color: #991b1b; }
.dash-hg-author-i { background: #e2e8f0; color: #475569; }
[data-theme="dark"] .dash-hg-author-d { background: rgba(59,130,246,0.2); color: #93c5fd; }
[data-theme="dark"] .dash-hg-author-r { background: rgba(239,68,68,0.2); color: #fca5a5; }
[data-theme="dark"] .dash-hg-author-i { background: rgba(148,163,184,0.2); color: #cbd5e1; }

.dash-hg-tag {
    display: inline-block;
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 10px;
    background: #e2e8f0;
    color: #475569;
}
[data-theme="dark"] .dash-hg-tag { background: rgba(148,163,184,0.18); color: #cbd5e1; }

/* Shrink the global stance badge when it lives inside a dashboard bill row
   so it matches the compact author + tag chips (10px / 1px 6px / 3px radius). */
.dash-hg-bill-line .badge-stance {
    padding: 1px 6px;
    border-radius: 3px;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    height: auto;
    display: inline-block;
    vertical-align: middle;
}

@media (max-width: 768px) {
    .dash-hg-committee-header { padding: 8px 12px; }
    .dash-hg-bill { padding: 7px 12px; }
    .dash-hg-committee-name { font-size: 13px; }
    .dash-hg-bill-number { font-size: 13px; }
}
