/* ══════════════════════════════════════════════════════════════════════
   CCM Compliance Manager — Main Dashboard Styles
   Design tokens are in shared.css; this file has component styles.
   ══════════════════════════════════════════════════════════════════════ */

/* ── RESET & BODY ── */
* { margin:0; padding:0; box-sizing:border-box; }
body { font-family: var(--font-body); background:var(--bg); color:var(--text-primary); font-size:var(--text-base); line-height:var(--leading-normal); }

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

/* ── TOPBAR ── */
.topbar { background:var(--header); color:var(--header-text); padding:12px 24px; display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.topbar-left { display:flex; align-items:center; gap:12px; }
.topbar h1 { font-size:var(--text-lg); font-weight:var(--font-bold); letter-spacing:.2px; font-family:var(--font-heading); display:flex; align-items:center; gap:8px; }
.topbar h1 svg { flex-shrink:0; }
.topbar .subtitle { font-size:var(--text-xs); opacity:.6; margin-top:1px; }
.month-nav { display:flex; align-items:center; gap:8px; color:#fff; font-size:var(--text-sm); }
.month-nav button { background:rgba(255,255,255,.12); border:none; color:#fff; padding:8px 14px; border-radius:var(--radius-sm); cursor:pointer; font-size:var(--text-base); min-height:36px; min-width:36px; transition:background var(--duration-fast) ease; }
.month-nav button:hover { background:rgba(255,255,255,.22); }

/* ── SIDEBAR ── */
.main { display:flex; flex:1; }
.sidebar { width:var(--sidebar-width); min-width:var(--sidebar-width); background:var(--card); border-right:1px solid var(--border); padding:var(--space-4) 0; display:flex; flex-direction:column; gap:1px; transition:width var(--duration-normal) var(--ease-out), min-width var(--duration-normal) var(--ease-out); overflow:hidden; }
.nav-group-label { font-size:10px; font-weight:var(--font-bold); text-transform:uppercase; letter-spacing:.8px; color:var(--text-tertiary); padding:var(--space-4) var(--space-5) var(--space-2); }
.nav-divider { height:1px; background:var(--border); margin:var(--space-2) var(--space-4); }
.nav-item { display:flex; align-items:center; gap:10px; padding:9px 18px; cursor:pointer; border-radius:0; color:var(--text-secondary); font-size:var(--text-sm); font-weight:var(--font-medium); border-left:3px solid transparent; transition:all var(--duration-fast) ease; position:relative; }
.nav-item:hover { background:var(--bg-secondary); color:var(--text-primary); }
.nav-item.active { background:var(--accent-subtle); color:var(--accent); border-left-color:var(--accent); font-weight:var(--font-semibold); }
.nav-icon { width:20px; height:20px; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.nav-icon svg { width:18px; height:18px; }
.nav-badge { margin-left:auto; background:var(--red); color:#fff; font-size:10px; padding:1px 7px; border-radius:var(--radius-full); font-weight:var(--font-bold); }
.sidebar-collapse-btn { display:flex; align-items:center; justify-content:center; gap:6px; padding:10px 18px; margin-top:auto; cursor:pointer; color:var(--text-tertiary); font-size:var(--text-xs); font-weight:var(--font-medium); border-top:1px solid var(--border); transition:color var(--duration-fast) ease; }
.sidebar-collapse-btn:hover { color:var(--text-primary); }
.sidebar-collapse-btn svg { transition:transform var(--duration-normal) var(--ease-out); }

/* Collapsed sidebar */
.sidebar.collapsed { width:var(--sidebar-collapsed-width); min-width:var(--sidebar-collapsed-width); }
.sidebar.collapsed .nav-item { justify-content:center; padding:12px 0; border-left-width:0; font-size:0; line-height:0; color:transparent; overflow:hidden; white-space:nowrap; }
.sidebar.collapsed .nav-item .nav-icon { font-size:initial; line-height:initial; }
.sidebar.collapsed .nav-item .nav-icon svg { color:var(--text-secondary); }
.sidebar.collapsed .nav-item.active .nav-icon svg { color:var(--accent); }
.sidebar.collapsed .nav-badge { display:none; }
.sidebar.collapsed .nav-group-label { display:none; }
.sidebar.collapsed .nav-divider { margin:var(--space-2) var(--space-3); }
.sidebar.collapsed .sidebar-collapse-btn { font-size:0; color:transparent; }
.sidebar.collapsed .sidebar-collapse-btn svg { transform:rotate(180deg); color:var(--text-tertiary); }
/* Tooltip for collapsed sidebar */
.sidebar.collapsed .nav-item[data-tooltip]::after { content:attr(data-tooltip); position:absolute; left:calc(100% + 8px); top:50%; transform:translateY(-50%); background:var(--header); color:#fff; font-size:var(--text-xs); padding:4px 10px; border-radius:var(--radius-sm); white-space:nowrap; opacity:0; pointer-events:none; transition:opacity var(--duration-fast) ease; z-index:100; }
.sidebar.collapsed .nav-item[data-tooltip]:hover::after { opacity:1; }

.content { flex:1; padding:var(--space-5); overflow:auto; }

/* ── VIEWS ── */
.view { display:none; }
.view.active { display:block; }

/* ── KPI ROW ── */
.kpi-row { display:grid; grid-template-columns:repeat(auto-fit, minmax(180px,1fr)); gap:var(--space-4); margin-bottom:var(--space-5); }
.kpi-card { background:var(--card); border-radius:var(--radius-md); padding:var(--space-5) var(--space-6); box-shadow:var(--shadow-sm); border:1px solid var(--border); border-top:3px solid var(--accent); transition:box-shadow var(--duration-fast) ease, transform var(--duration-fast) ease; }
.kpi-card:hover { box-shadow:var(--shadow-md); transform:translateY(-1px); }
.kpi-card.green { border-top-color:var(--green); }
.kpi-card.yellow { border-top-color:var(--yellow); }
.kpi-card.red { border-top-color:var(--red); }
.kpi-label { font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.7px; color:var(--text-secondary); margin-bottom:var(--space-1); font-weight:var(--font-semibold); }
.kpi-value { font-size:var(--text-2xl); font-weight:var(--font-extrabold); line-height:1; font-variant-numeric:tabular-nums; }
.kpi-sub { font-size:var(--text-xs); color:var(--text-secondary); margin-top:var(--space-1); }

/* ── SECTION HEADER ── */
.section-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:var(--space-3); flex-wrap:wrap; gap:var(--space-2); }
.section-header h2 { font-size:var(--text-md); font-weight:var(--font-semibold); font-family:var(--font-heading); color:var(--text-primary); }
.section-header .actions { display:flex; gap:var(--space-2); flex-wrap:wrap; }

/* ── BUTTONS ── */
.btn { padding:8px 16px; border-radius:var(--radius-sm); font-size:var(--text-sm); font-weight:var(--font-semibold); cursor:pointer; border:none; transition:all var(--duration-fast) ease; min-height:38px; display:inline-flex; align-items:center; justify-content:center; gap:6px; }
.btn:active:not(:disabled) { transform:scale(0.97); }
.btn svg { flex-shrink:0; }
.btn-primary { background:var(--accent); color:#fff; min-width:120px; }
.btn-primary:hover { background:var(--accent-hover); }
.btn-secondary { background:var(--bg-secondary); color:var(--text-primary); border:1px solid var(--border); }
.btn-secondary:hover { background:var(--border); }
.btn-sm { padding:4px 10px; font-size:var(--text-xs); min-height:30px; }
.btn-green { background:var(--green-light); color:var(--green-dark); }
.btn-yellow { background:var(--yellow-light); color:var(--yellow-dark); }
.btn-red { background:var(--red-light); color:var(--red-dark); }

/* ── TABLE ── */
.table-wrap { background:var(--card); border-radius:var(--radius-md); box-shadow:var(--shadow-sm); overflow:auto; margin-bottom:var(--space-5); border:1px solid var(--border); }
table { width:100%; border-collapse:collapse; }
thead th { background:var(--bg-secondary); padding:12px 16px; text-align:left; font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.5px; color:var(--text-secondary); font-weight:var(--font-bold); border-bottom:1px solid var(--border); white-space:nowrap; cursor:pointer; user-select:none; }
thead th:hover { color:var(--text-primary); }
tbody td { padding:12px 16px; border-bottom:1px solid var(--divider); font-size:var(--text-sm); }
tbody tr:last-child td { border-bottom:none; }
tbody tr { transition:background var(--duration-fast) ease; }
tbody tr:hover { background:var(--accent-subtle); }

/* ── BADGES ── */
.badge { display:inline-flex; align-items:center; gap:4px; padding:2px 10px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-semibold); }
.badge-green { background:var(--green-light); color:var(--green-dark); }
.badge-yellow { background:var(--yellow-light); color:var(--yellow-dark); }
.badge-red { background:var(--red-light); color:var(--red-dark); }
.badge-blue { background:var(--accent-subtle); color:var(--accent); }
.badge-gray { background:var(--bg-secondary); color:var(--text-secondary); }

/* ── PATIENT AVATAR ── */
.patient-avatar { display:inline-flex; align-items:center; justify-content:center; width:30px; height:30px; border-radius:50%; font-size:var(--text-xs); font-weight:var(--font-bold); color:#fff; margin-right:8px; flex-shrink:0; vertical-align:middle; }

/* ── PROGRESS BAR ── */
.progress-bar { background:var(--bg-secondary); border-radius:var(--radius-full); height:6px; overflow:hidden; min-width:80px; }
.progress-fill { height:100%; border-radius:var(--radius-full); transition:width .6s var(--ease-out); }
.progress-fill.green { background:var(--green); }
.progress-fill.yellow { background:var(--yellow); }
.progress-fill.red { background:var(--red); }

/* ── CHART GRID ── */
.chart-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(340px,1fr)); gap:var(--space-4); margin-bottom:var(--space-5); }
.chart-card { background:var(--card); border-radius:var(--radius-md); padding:var(--space-5) var(--space-6); box-shadow:var(--shadow-sm); border:1px solid var(--border); }
.chart-card h3 { font-size:var(--text-base); font-weight:var(--font-semibold); margin-bottom:var(--space-4); color:var(--text-primary); font-family:var(--font-heading); }
.chart-card canvas { max-height:220px; }

/* ── FILTER BAR ── */
.filter-bar { display:flex; gap:var(--space-3); flex-wrap:wrap; margin-bottom:var(--space-4); align-items:center; }
.filter-bar select, .filter-bar input[type="text"] { padding:7px 12px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-sm); background:var(--card); color:var(--text-primary); transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.filter-bar select:focus, .filter-bar input[type="text"]:focus { border-color:var(--accent); outline:none; box-shadow:0 0 0 3px var(--accent-subtle); }
.search-input { min-width:200px; }

/* ── MODAL ── */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); backdrop-filter:blur(4px); z-index:1000; align-items:center; justify-content:center; opacity:0; transition:opacity .2s ease; }
.modal-overlay.open { display:flex; opacity:1; }
.modal { background:var(--card); border-radius:var(--radius-lg); padding:var(--space-8); width:540px; max-width:95vw; max-height:90vh; overflow-y:auto; box-shadow:var(--shadow-xl); transform:scale(.96) translateY(8px); transition:transform .25s var(--ease-out); display:flex; flex-direction:column; }
.modal > *:not(.modal-footer) { flex-shrink:0; }
.modal-overlay.open .modal { transform:scale(1) translateY(0); }
.modal h2 { font-size:var(--text-lg); font-weight:var(--font-semibold); margin-bottom:var(--space-5); font-family:var(--font-heading); color:var(--text-primary); }
.modal-header-colored { margin:calc(-1 * var(--space-8)) calc(-1 * var(--space-8)) var(--space-5); padding:var(--space-5) var(--space-8); border-radius:var(--radius-lg) var(--radius-lg) 0 0; }
.modal-header-colored h2 { color:#fff; margin-bottom:0; }
.modal-header-colored .modal-close { color:rgba(255,255,255,.7); }
.modal-header-colored .modal-close:hover { color:#fff; }
.modal-header-navy { background:var(--header); }
.modal-header-teal { background:#0d9488; }
.modal-header-blue { background:var(--accent); }
.modal-close { float:right; background:none; border:none; font-size:20px; cursor:pointer; color:var(--text-secondary); margin-top:-4px; transition:color var(--duration-fast) ease; }
.modal-close:hover { color:var(--text-primary); }
.modal-footer { display:flex; gap:var(--space-2); justify-content:flex-end; margin-top:var(--space-5); position:sticky; bottom:calc(-1 * var(--space-8)); background:var(--card); padding:var(--space-4) 0 0; border-top:1px solid var(--border); z-index:10; }

/* ── BILLED TOOLTIP ── */
.billed-chip { position:relative; cursor:default; }
.billed-chip[data-tip]::after { content:attr(data-tip); position:absolute; bottom:calc(100% + 4px); left:50%; transform:translateX(-50%); background:var(--header); color:#fff; font-size:var(--text-xs); padding:4px 10px; border-radius:var(--radius-sm); white-space:nowrap; opacity:0; pointer-events:none; transition:opacity var(--duration-fast); z-index:10; }
.billed-chip[data-tip]:hover::after { opacity:1; }

/* ── EMPTY STATE ── */
.empty-state { text-align:center; padding:60px 24px; color:var(--text-secondary); }
.empty-state .empty-icon { font-size:48px; margin-bottom:var(--space-3); display:block; }
.empty-state h3 { font-size:var(--text-md); font-weight:var(--font-semibold); color:var(--text-primary); margin-bottom:6px; }

/* ── FORMS ── */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-3); margin-bottom:var(--space-3); }
.form-row.full { grid-template-columns:1fr; }
.form-group { display:flex; flex-direction:column; gap:var(--space-1); }
.form-group label { font-size:var(--text-sm); font-weight:var(--font-semibold); color:var(--text-secondary); }
.form-group input, .form-group select, .form-group textarea { padding:9px 12px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-sm); font-family:inherit; background:var(--card); color:var(--text-primary); transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--accent); outline:none; box-shadow:0 0 0 3px var(--accent-subtle); }
.form-group textarea { resize:vertical; min-height:70px; }

/* ── TASK BOARD ── */
.task-cols { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4); }
.task-col { background:var(--bg-secondary); border-radius:var(--radius-md); padding:var(--space-4); }
.task-col-header { font-size:var(--text-sm); font-weight:var(--font-bold); text-transform:uppercase; letter-spacing:.5px; margin-bottom:var(--space-3); display:flex; justify-content:space-between; align-items:center; }
.task-card { background:var(--card); border-radius:var(--radius-sm); padding:var(--space-3) var(--space-4); margin-bottom:var(--space-2); box-shadow:var(--shadow-sm); border-left:3px solid var(--accent); cursor:pointer; transition:box-shadow var(--duration-fast) ease; }
.task-card:hover { box-shadow:var(--shadow-md); }
.task-card.urgent { border-left-color:var(--red); }
.task-card.normal { border-left-color:var(--accent); }
.task-card.done { border-left-color:var(--green); opacity:.75; }
.task-card-title { font-size:var(--text-sm); font-weight:var(--font-semibold); margin-bottom:var(--space-1); }
.task-card-meta { font-size:var(--text-xs); color:var(--text-secondary); display:flex; gap:var(--space-2); flex-wrap:wrap; }
.task-card-meta span { display:flex; align-items:center; gap:3px; }

/* ── ENROLLMENT CONSENT ── */
.consent-strip { display:flex; align-items:center; gap:6px; font-size:var(--text-sm); }
.dot { width:8px; height:8px; border-radius:50%; display:inline-block; }
.dot-green { background:var(--green); }
.dot-yellow { background:var(--yellow); }
.dot-red { background:var(--red); }

/* ── TOAST ── */
.toast { position:fixed; right:24px; background:var(--header); color:#fff; padding:var(--space-3) var(--space-5); border-radius:var(--radius-md); font-size:var(--text-sm); font-weight:var(--font-medium); box-shadow:var(--shadow-lg); z-index:2000; transform:translateX(60px); opacity:0; transition:all .3s var(--ease-out); cursor:pointer; max-width:360px; display:flex; align-items:center; gap:var(--space-2); }
.toast.show { transform:translateX(0); opacity:1; }
.toast.toast-success { background:var(--green-dark); }
.toast.toast-error { background:var(--red-dark); }
.toast.toast-info { background:var(--accent); }

/* ── AUDIT LOG ── */
#view-audit .table-wrap table td { vertical-align:top; }
#view-audit .table-wrap table tr:hover { background:var(--accent-subtle); }

/* ── BILLED CHECKLIST ── */
@keyframes badge-pulse { 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.12); } }
.nav-badge.badge-pulse { animation: badge-pulse 2s ease-in-out infinite; }
.bill-row-billed td { opacity:.6; }
.bill-row-billed td:first-child strong { text-decoration:line-through; }
.bill-row-billed td:first-child, .bill-row-billed td:nth-child(6) { opacity:1; }
tr.bill-row-billed { background:linear-gradient(90deg, var(--green-light) 0%, var(--card) 100%) !important; }
#bill-billed-progress-wrap .progress-bar { height:8px; }

/* ── AI TOOLS ── */
.ai-tabs { display:flex; gap:4px; flex-wrap:wrap; margin-bottom:var(--space-5); }
.ai-tab { padding:8px 18px; border-radius:var(--radius-full); font-size:var(--text-sm); font-weight:var(--font-semibold); cursor:pointer; border:1.5px solid var(--border); background:var(--card); color:var(--text-secondary); transition:all var(--duration-fast); }
.ai-tab:hover { border-color:var(--accent); color:var(--accent); }
.ai-tab.active { background:var(--accent); color:#fff; border-color:var(--accent); }
.ai-panel { display:none; }
.ai-panel.active { display:block; }
.ai-card { background:var(--card); border-radius:var(--radius-md); padding:var(--space-6) var(--space-6); box-shadow:var(--shadow-sm); margin-bottom:var(--space-4); border:1px solid var(--border); }
.ai-card h3 { font-size:var(--text-md); font-weight:var(--font-semibold); margin-bottom:6px; display:flex; align-items:center; gap:var(--space-2); font-family:var(--font-heading); color:var(--text-primary); }
.ai-card p { font-size:var(--text-sm); color:var(--text-secondary); margin-bottom:var(--space-4); line-height:var(--leading-relaxed); }
.ai-output { background:var(--bg-secondary); border:1px solid var(--border); border-radius:var(--radius-sm); padding:var(--space-5); margin-top:var(--space-4); font-size:var(--text-sm); line-height:var(--leading-relaxed); min-height:80px; }
.ai-output h4 { font-size:var(--text-sm); font-weight:var(--font-bold); color:var(--text-primary); margin:12px 0 4px; font-family:var(--font-heading); }
.ai-output h4:first-child { margin-top:0; }
.ai-output ul { margin:4px 0 10px 16px; }
.ai-output li { margin-bottom:3px; }
.ai-output .risk-high { color:var(--red-dark); font-weight:var(--font-bold); }
.ai-output .risk-med { color:var(--yellow-dark); font-weight:var(--font-bold); }
.ai-output .risk-low { color:var(--green-dark); font-weight:var(--font-bold); }
.ai-output table { width:100%; border-collapse:collapse; margin-top:var(--space-2); font-size:var(--text-sm); }
.ai-output table th { background:var(--accent-subtle); padding:8px 12px; text-align:left; font-weight:var(--font-bold); border-bottom:1px solid var(--border); }
.ai-output table td { padding:8px 12px; border-bottom:1px solid var(--divider); }
.ai-output table tr:last-child td { border-bottom:none; }
.ai-streaming { opacity:.8; }
.ai-streaming::after { content:''; display:inline-block; width:2px; height:1em; background:var(--accent); margin-left:2px; animation:blink .7s infinite; vertical-align:text-bottom; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.ai-loading { display:flex; align-items:center; gap:10px; color:var(--text-secondary); font-size:var(--text-sm); padding:12px 0; }
.spinner { width:18px; height:18px; border:2px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to{transform:rotate(360deg)} }

/* ── PROMPT CUSTOMIZER ── */
.pc-section { border:1px solid var(--border); border-radius:var(--radius-sm); margin-bottom:var(--space-2); overflow:hidden; }
.pc-section-header { display:flex; align-items:center; justify-content:space-between; padding:10px 14px; background:var(--bg); cursor:pointer; font-size:var(--text-sm); font-weight:var(--font-semibold); transition:background var(--duration-fast) ease; }
.pc-section-header:hover { background:var(--bg-secondary); }
.pc-section-body { display:none; padding:var(--space-3) var(--space-4); border-top:1px solid var(--border); }
.pc-section-body.open { display:block; }
.pc-textarea { width:100%; padding:10px 12px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-sm); line-height:1.6; font-family:var(--font-mono); resize:vertical; background:var(--bg); color:var(--text-primary); }
.pc-textarea:focus { border-color:var(--accent); outline:none; box-shadow:0 0 0 3px var(--accent-subtle); }
.pc-hint { font-size:var(--text-xs); color:var(--text-secondary); margin:0 0 var(--space-2); line-height:1.4; }
.pc-inline { display:flex; align-items:center; gap:var(--space-2); margin-bottom:var(--space-2); }
.pc-inline label { font-size:var(--text-sm); font-weight:var(--font-semibold); white-space:nowrap; }
.pc-title-input { padding:4px 8px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-sm); font-weight:var(--font-semibold); width:260px; }
.pc-chevron { font-size:12px; color:var(--text-secondary); transition:transform .2s; }
.pc-toggle { display:flex; align-items:center; gap:4px; font-size:var(--text-xs); cursor:pointer; margin-right:var(--space-2); }
.pc-toggle input { cursor:pointer; }
.pc-toggle-label { color:var(--text-secondary); font-weight:var(--font-medium); }
.pc-section.pc-disabled { opacity:0.45; }
.pc-section.pc-disabled .pc-section-body { pointer-events:none; }

/* ── CARE PLAN ARCHIVE ── */
#cp-archive-section { margin-top:var(--space-6); padding-top:var(--space-5); border-top:1px solid var(--border); }
.cp-preview-snippet { max-width:320px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:var(--text-secondary); font-size:var(--text-sm); }
#careplan-view-text { white-space:pre-wrap; font-family:var(--font-mono); font-size:var(--text-sm); line-height:1.6; padding:var(--space-4); background:var(--bg); border:1px solid var(--border); border-radius:var(--radius-sm); max-height:60vh; overflow-y:auto; margin:var(--space-3) 0; }
.cp-archive-empty { text-align:center; padding:40px 20px; color:var(--text-secondary); }
.cp-archive-empty-icon { font-size:36px; margin-bottom:var(--space-2); }
.api-key-notice { background:var(--yellow-light); border:1px solid var(--yellow); border-radius:var(--radius-sm); padding:var(--space-3) var(--space-4); font-size:var(--text-sm); color:var(--yellow-dark); margin-bottom:var(--space-4); display:flex; align-items:center; gap:var(--space-2); }

/* ── RISK TABLE ── */
.risk-table { width:100%; border-collapse:collapse; }
.risk-table th { background:var(--bg-secondary); padding:10px 12px; text-align:left; font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.5px; color:var(--text-secondary); font-weight:var(--font-bold); border-bottom:1px solid var(--border); }
.risk-table td { padding:10px 12px; border-bottom:1px solid var(--divider); font-size:var(--text-sm); }
.risk-table tr:last-child td { border-bottom:none; }
.risk-badge-high { background:var(--red-light); color:var(--red-dark); padding:2px 10px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-bold); }
.risk-badge-med { background:var(--yellow-light); color:var(--yellow-dark); padding:2px 10px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-bold); }
.risk-badge-low { background:var(--green-light); color:var(--green-dark); padding:2px 10px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-bold); }
.settings-gear { background:rgba(255,255,255,.12); border:none; color:#fff; font-size:16px; padding:6px 8px; border-radius:var(--radius-sm); cursor:pointer; transition:background var(--duration-fast) ease; display:flex; align-items:center; }
.settings-gear:hover { background:rgba(255,255,255,.22); }

/* ── WIZARD ── */
.wizard-steps { display:flex; gap:0; margin-bottom:22px; border-bottom:2px solid var(--border); }
.wizard-step { padding:10px 20px; font-size:var(--text-sm); font-weight:var(--font-semibold); color:var(--text-secondary); border-bottom:2px solid transparent; margin-bottom:-2px; cursor:default; transition:color var(--duration-fast) ease; }
.wizard-step.active { color:var(--accent); border-bottom-color:var(--accent); }
.wizard-step.done { color:var(--green-dark); }
.wizard-body { min-height:220px; max-height:58vh; overflow-y:auto; padding-right:4px; }
.condition-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:var(--space-2); margin-bottom:var(--space-4); }
.condition-chip { border:2px solid var(--border); border-radius:var(--radius-sm); padding:10px 12px; cursor:pointer; font-size:var(--text-sm); font-weight:var(--font-semibold); background:var(--card); display:flex; align-items:center; gap:6px; transition:all var(--duration-fast); }
.condition-chip:hover { border-color:var(--accent); }
.condition-chip.selected { border-color:var(--accent); background:var(--accent-subtle); color:var(--accent); }
.condition-chip input[type=checkbox] { display:none; }
.template-preview { background:var(--bg-secondary); border:1px solid var(--border); border-radius:var(--radius-sm); padding:14px 16px; font-size:var(--text-sm); line-height:var(--leading-relaxed); margin-bottom:10px; }
.template-preview h5 { font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.5px; color:var(--text-secondary); margin:var(--space-2) 0 var(--space-1); }
.template-preview h5:first-child { margin-top:0; }
.template-preview ul { margin-left:14px; }
.template-preview li { margin-bottom:2px; }

/* ── HAMBURGER / MOBILE ── */
.hamburger-btn { display:none; background:rgba(255,255,255,.12); border:none; color:#fff; font-size:20px; padding:6px 10px; border-radius:var(--radius-sm); cursor:pointer; line-height:1; transition:background var(--duration-fast) ease; }
.hamburger-btn:hover { background:rgba(255,255,255,.22); }
.sidebar-backdrop { display:none; position:fixed; inset:0; background:rgba(0,0,0,.4); z-index:899; backdrop-filter:blur(2px); }
.sidebar-backdrop.active { display:block; }

/* ── BUTTON STATES ── */
button:disabled, button[disabled] { opacity:0.5; cursor:not-allowed; }
.btn-danger { background:var(--red); color:#fff; }
.btn-danger:hover { background:var(--red-dark); }

/* ── RESPONSIVE ── */
@media(max-width:480px) {
  .modal { padding:var(--space-4) var(--space-3); width:95vw; }
  .modal-footer { bottom:calc(-1 * var(--space-4)); }
  table { font-size:var(--text-xs); }
  thead th, tbody td { padding:8px; }
  .btn { padding:6px 10px; font-size:var(--text-xs); min-height:34px; }
  .topbar { flex-wrap:wrap; gap:6px; }
  .kpi-row { grid-template-columns:1fr; }
}
@media(max-width:768px) {
  .hamburger-btn { display:inline-flex; align-items:center; }
  .sidebar { display:none; position:fixed; left:0; top:0; bottom:0; z-index:900; box-shadow:var(--shadow-xl); }
  .sidebar.mobile-open { display:flex; }
  .sidebar.collapsed { width:var(--sidebar-width); min-width:var(--sidebar-width); }
  .kpi-row { grid-template-columns:repeat(2,1fr); }
  .task-cols { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
}

/* ── BILLING PROGRAM BADGES ── */
.badge-ccm  { background:var(--accent-subtle); color:var(--accent); }
.badge-apcm { background:var(--green-light); color:var(--green-dark); }
.badge-psych{ background:var(--purple-light); color:var(--purple); }
.badge-pain { background:var(--red-light); color:var(--red-dark); }
.badge-pcm  { background:#d1fae5; color:#065f46; }
.badge-rpm  { background:#e0e7ff; color:#3730a3; }
.badge-nav  { background:var(--yellow-light); color:var(--yellow-dark); }
.badge-hr   { background:var(--orange-light); color:var(--orange); }

/* ── ADD-ON ELIGIBILITY ── */
.addon-eligibility-card { background:var(--yellow-light); border:1px solid var(--yellow); border-radius:var(--radius-sm); padding:var(--space-3) var(--space-4); margin-top:var(--space-3); }

/* ── CONDITION FLAGS ── */
.cond-flag { display:inline-block; font-size:9px; font-weight:var(--font-bold); padding:1px 5px; border-radius:4px; margin-left:3px; }
.flag-hr   { background:var(--orange-light); color:var(--orange); }
.flag-psy  { background:var(--purple-light); color:var(--purple); }
.flag-pain { background:var(--yellow-light); color:var(--yellow-dark); }

/* ── CONDITION CATEGORY PICKER ── */
.cond-category    { margin-bottom:10px; }
.cond-cat-header  { font-size:10px; font-weight:var(--font-bold); text-transform:uppercase; letter-spacing:.6px; color:var(--text-secondary); padding:4px 0 6px; border-bottom:1px solid var(--border); margin-bottom:6px; }
.cond-grid        { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:5px; }
.cond-item        { display:flex; align-items:center; gap:6px; padding:5px 7px; border-radius:var(--radius-sm); background:var(--bg); border:1px solid transparent; transition:border-color var(--duration-fast); }
.cond-item:hover  { border-color:var(--border); }
.cond-label       { font-size:var(--text-sm); cursor:pointer; flex:1; }
.cond-flags       { display:flex; gap:2px; flex-shrink:0; }

/* ── MODAL TABS ── */
.modal-tabs       { display:flex; gap:0; border-bottom:2px solid var(--border); margin-bottom:var(--space-5); overflow-x:auto; }
.modal-tab        { padding:9px 14px; font-size:var(--text-sm); font-weight:var(--font-semibold); color:var(--text-secondary); border-bottom:2px solid transparent; margin-bottom:-2px; cursor:pointer; white-space:nowrap; transition:color var(--duration-fast) ease; }
.modal-tab:hover  { color:var(--text-primary); }
.modal-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
.tab-panel        { display:none; padding:4px 2px; }
.tab-panel.active { display:block; }

/* ── REVENUE PREVIEW ── */
.rev-preview { background:var(--green-light); border:1px solid var(--green); border-radius:var(--radius-sm); padding:var(--space-3) var(--space-4); margin-top:10px; }
.rev-preview h4 { font-size:var(--text-sm); font-weight:var(--font-bold); color:var(--green-dark); margin-bottom:var(--space-2); font-family:var(--font-heading); }
.rev-line    { display:flex; justify-content:space-between; font-size:var(--text-sm); padding:3px 0; border-bottom:1px dashed var(--green); }
.rev-line:last-child { border-bottom:none; font-weight:var(--font-bold); font-size:var(--text-sm); color:var(--green-dark); }
.rev-code    { font-weight:var(--font-bold); color:var(--accent); margin-right:6px; font-size:var(--text-xs); background:var(--accent-subtle); padding:1px 5px; border-radius:4px; }

/* ── BILLING SECTION ── */
.billing-section   { background:var(--card); border-radius:var(--radius-md); padding:var(--space-4) var(--space-5); box-shadow:var(--shadow-sm); margin-bottom:var(--space-3); border:1px solid var(--border); }
.billing-section h4 { font-size:var(--text-xs); font-weight:var(--font-bold); text-transform:uppercase; letter-spacing:.6px; color:var(--text-secondary); margin-bottom:10px; padding-bottom:6px; border-bottom:1px solid var(--border); }
.billing-radio-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:6px; }
.billing-radio-opt  { display:flex; align-items:flex-start; gap:7px; padding:8px 10px; border-radius:var(--radius-sm); border:1px solid var(--border); cursor:pointer; transition:border-color var(--duration-fast); font-size:var(--text-sm); }
.billing-radio-opt:hover { border-color:var(--accent); }
.billing-radio-opt input[type=radio] { margin-top:1px; accent-color:var(--accent); flex-shrink:0; }
.billing-radio-opt .opt-code { font-weight:var(--font-bold); display:block; font-size:var(--text-xs); }
.billing-radio-opt .opt-desc { color:var(--text-secondary); font-size:10px; display:block; line-height:1.3; margin-top:1px; }
.billing-addon  { margin-top:var(--space-2); display:flex; align-items:center; gap:var(--space-2); font-size:var(--text-sm); padding:8px 10px; background:var(--bg); border-radius:var(--radius-sm); }
.billing-addon input[type=number] { width:60px; padding:4px 6px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-sm); }

/* ── RATES TABLE ── */
.rates-table input[type=number] { width:80px; padding:5px 7px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-sm); text-align:right; }
.prog-group-hdr td { background:var(--bg-secondary); font-weight:var(--font-bold); font-size:var(--text-xs); text-transform:uppercase; letter-spacing:.5px; color:var(--text-secondary); padding:8px 14px; }

/* ── IMPORT DROP ZONE ── */
.import-drop { border:2px dashed var(--border); border-radius:var(--radius-md); padding:var(--space-8) var(--space-5); text-align:center; cursor:pointer; transition:border-color .2s, background .2s; background:var(--bg); }
.import-drop:hover { border-color:var(--accent); }
.import-drop.drag-over { border-color:var(--accent); background:var(--accent-subtle); }
.import-drop p { font-size:var(--text-sm); color:var(--text-secondary); margin:6px 0; }
.import-drop strong { font-size:var(--text-md); color:var(--text-primary); }
.mapping-grid { display:flex; flex-direction:column; gap:6px; margin-bottom:var(--space-4); }
.mapping-row  { display:flex; align-items:center; gap:10px; }
.csv-col      { font-size:var(--text-sm); font-weight:var(--font-semibold); color:var(--accent); background:var(--accent-subtle); padding:2px 8px; border-radius:4px; min-width:130px; }
.import-preview { max-height:180px; overflow-y:auto; border:1px solid var(--border); border-radius:var(--radius-sm); }

/* ── HIPAA BANNER ── */
.hipaa-banner { background:var(--bg-secondary); border-bottom:1px solid var(--border); padding:6px 20px; font-size:var(--text-xs); color:var(--text-secondary); display:flex; align-items:center; gap:var(--space-2); }
.hipaa-banner svg { color:var(--accent); flex-shrink:0; }
.hipaa-banner strong { color:var(--text-primary); }
.hipaa-banner-text { display:flex; align-items:center; gap:var(--space-2); }

/* ── STAT CARDS ── */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(140px,1fr)); gap:var(--space-3); margin-bottom:var(--space-5); }
.stat-card { padding:var(--space-4); border-radius:var(--radius-md); color:#fff; }
.stat-card .stat-label { font-size:10px; text-transform:uppercase; letter-spacing:.5px; opacity:.85; margin-bottom:var(--space-1); }
.stat-card .stat-value { font-size:var(--text-xl); font-weight:var(--font-extrabold); line-height:1; font-variant-numeric:tabular-nums; }
.stat-card .stat-sub   { font-size:var(--text-xs); opacity:.75; margin-top:var(--space-1); }
.stat-card.sc-navy  { background:var(--header); }
.stat-card.sc-teal  { background:var(--accent); }
.stat-card.sc-green { background:var(--green-dark); }
.stat-card.sc-blue  { background:var(--accent-hover); }
.stat-card.sc-purple{ background:var(--purple); }
.stat-card.sc-orange{ background:var(--orange); }
.stat-card.sc-red   { background:var(--red); }

/* ── CUSTOM CONDITIONS TAG ── */
.custom-tag { display:inline-flex; align-items:center; gap:4px; background:var(--accent-subtle); border:1px solid var(--border); border-radius:var(--radius-full); padding:2px 8px; font-size:var(--text-sm); margin:2px 3px; }
.custom-tag button { background:none; border:none; cursor:pointer; color:var(--text-secondary); font-size:14px; line-height:1; padding:0 2px; }

/* ── REPORT TABLE ── */
.report-section { background:var(--card); border-radius:var(--radius-md); padding:var(--space-5); box-shadow:var(--shadow-sm); margin-bottom:var(--space-4); border:1px solid var(--border); }
.report-section h3 { font-size:var(--text-md); font-weight:var(--font-semibold); margin-bottom:var(--space-4); padding-bottom:var(--space-2); border-bottom:1px solid var(--border); font-family:var(--font-heading); color:var(--text-primary); }
.prog-bar-row { margin-bottom:10px; }
.prog-bar-row .label { display:flex; justify-content:space-between; font-size:var(--text-sm); margin-bottom:3px; }

/* ── SETTINGS TABS ── */
.settings-tabs { display:flex; gap:6px; margin-bottom:var(--space-5); flex-wrap:wrap; }
.settings-tab { padding:7px 16px; font-size:var(--text-sm); font-weight:var(--font-medium); color:var(--text-secondary); background:transparent; border:1px solid transparent; border-radius:var(--radius-full); cursor:pointer; display:flex; align-items:center; gap:7px; transition:all var(--duration-fast); }
.settings-tab:hover:not(.active) { background:var(--bg-secondary); border-color:var(--border); }
.settings-tab.active { background:var(--accent); color:#fff; border-color:var(--accent); }
.settings-tab svg { flex-shrink:0; }
.settings-panel { display:none; }
.settings-panel.active { display:block; }

/* ── AI NAV ── */
.nav-item-ai { color:var(--purple); font-weight:var(--font-semibold); }
.nav-item-ai.active { color:var(--purple); }
.nav-badge-new { margin-left:auto; background:var(--purple); color:#fff; font-size:9px; padding:1px 6px; border-radius:var(--radius-full); font-weight:var(--font-bold); }

/* ── SECONDARY KPI STRIP ── */
.kpi-secondary { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:10px; margin-bottom:var(--space-5); padding:var(--space-4); background:var(--bg-secondary); border:1px solid var(--border); border-radius:var(--radius-md); }
.kpi-secondary-label { font-size:10px; text-transform:uppercase; letter-spacing:.6px; color:var(--text-secondary); margin-bottom:2px; font-weight:var(--font-semibold); }
.kpi-secondary-value { font-size:var(--text-xl); font-weight:var(--font-extrabold); line-height:1; font-variant-numeric:tabular-nums; }
.kpi-secondary-sub { font-size:var(--text-xs); color:var(--text-secondary); margin-top:3px; }

/* ── STATUS INDICATOR ── */
.kpi-status { font-size:var(--text-xs); font-weight:var(--font-bold); margin-top:5px; display:flex; align-items:center; gap:3px; }
.kpi-status.status-good { color:var(--green-dark); }
.kpi-status.status-warn { color:var(--yellow-dark); }
.kpi-status.status-alert { color:var(--red-dark); }

/* ── ATTENTION HERO ── */
.attention-hero { background:var(--card); border-radius:var(--radius-md); box-shadow:var(--shadow-sm); border:1px solid var(--border); margin-bottom:var(--space-5); overflow:hidden; }
.attention-hero-header { display:flex; align-items:center; justify-content:space-between; padding:var(--space-4) var(--space-5); background:var(--bg-secondary); border-bottom:1px solid var(--border); }
.attention-hero-header h2 { font-size:var(--text-md); font-weight:var(--font-semibold); color:var(--text-primary); display:flex; align-items:center; gap:7px; font-family:var(--font-heading); }
.attention-hero-header .attention-count { background:var(--accent); color:#fff; font-size:var(--text-xs); font-weight:var(--font-bold); padding:2px 8px; border-radius:var(--radius-full); }

/* ── PRINT ── */
@media print {
  body > *:not(#ai-cp-output) { display: none !important; }
  #ai-cp-output { display: block !important; }
}

/* ── LAB RESULTS ── */
.lab-report-card { background:var(--card); border-radius:var(--radius-md); box-shadow:var(--shadow-sm); margin-bottom:var(--space-4); border:1px solid var(--border); border-left:3px solid var(--accent); overflow:hidden; }
.lab-report-header { display:flex; align-items:center; justify-content:space-between; padding:var(--space-3) var(--space-4); cursor:pointer; gap:var(--space-3); background:var(--bg); transition:background var(--duration-fast) ease; }
.lab-report-header:hover { background:var(--bg-secondary); }
.lab-report-title { font-size:var(--text-sm); font-weight:var(--font-bold); color:var(--text-primary); display:flex; align-items:center; gap:var(--space-2); flex-wrap:wrap; }
.lab-report-meta { font-size:var(--text-xs); color:var(--text-secondary); display:flex; gap:var(--space-3); flex-wrap:wrap; }
.lab-report-body { display:none; padding:0 0 4px; }
.lab-report-body.open { display:block; }
.lab-result-table { width:100%; border-collapse:collapse; font-size:var(--text-sm); }
.lab-result-table th { background:var(--bg-secondary); padding:8px 14px; text-align:left; font-size:10px; text-transform:uppercase; letter-spacing:.5px; color:var(--text-secondary); font-weight:var(--font-bold); border-bottom:1px solid var(--border); white-space:nowrap; }
.lab-result-table td { padding:8px 14px; border-bottom:1px solid var(--divider); }
.lab-result-table tr:last-child td { border-bottom:none; }
.lab-result-table tr:hover td { background:var(--accent-subtle); }
.lab-flag-H  { display:inline-block; padding:1px 7px; border-radius:var(--radius-full); font-size:10px; font-weight:var(--font-bold); background:var(--red-light); color:var(--red-dark); }
.lab-flag-L  { display:inline-block; padding:1px 7px; border-radius:var(--radius-full); font-size:10px; font-weight:var(--font-bold); background:var(--green-light); color:var(--green-dark); }
.lab-flag-HH { display:inline-block; padding:1px 7px; border-radius:var(--radius-full); font-size:10px; font-weight:var(--font-bold); background:var(--red-dark); color:#fff; }
.lab-flag-LL { display:inline-block; padding:1px 7px; border-radius:var(--radius-full); font-size:10px; font-weight:var(--font-bold); background:var(--header); color:#fff; }
.lab-flag-none { display:inline-block; padding:1px 7px; border-radius:var(--radius-full); font-size:10px; color:var(--text-tertiary); }
.lab-abnormal-count { background:var(--red-light); color:var(--red-dark); font-size:10px; font-weight:var(--font-bold); padding:2px 8px; border-radius:var(--radius-full); }
.labs-empty { padding:var(--space-8) var(--space-5); text-align:center; color:var(--text-secondary); font-size:var(--text-sm); }
.labs-empty .labs-empty-icon { font-size:36px; margin-bottom:10px; }
.lab-patient-chip { font-size:var(--text-xs); background:var(--accent-subtle); color:var(--accent); padding:2px 8px; border-radius:var(--radius-full); font-weight:var(--font-semibold); cursor:pointer; transition:background var(--duration-fast) ease; }
.lab-patient-chip:hover { background:var(--accent); color:#fff; }

/* ── PANEL REVIEW ── */
.pr-conf-high { display:inline-block; padding:2px 8px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-bold); background:var(--green-light); color:var(--green-dark); }
.pr-conf-medium { display:inline-block; padding:2px 8px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-bold); background:var(--yellow-light); color:var(--yellow-dark); }
.pr-conf-low { display:inline-block; padding:2px 8px; border-radius:var(--radius-full); font-size:var(--text-xs); font-weight:var(--font-bold); background:var(--bg-secondary); color:var(--text-secondary); }
.pr-basis-tag { display:inline-block; padding:1px 6px; border-radius:4px; font-size:10px; background:var(--purple-light); color:var(--purple); margin-right:3px; }
#pr-results-body td { vertical-align:top; padding:8px 6px; font-size:var(--text-sm); }
#pr-results-body ul { margin:0; padding-left:14px; }
#pr-results-body ul li { margin-bottom:2px; }

/* ── LOGIN OVERLAY ── */
.login-overlay { position:fixed; inset:0; background:linear-gradient(135deg, #0F1D35 0%, #1a2d4a 50%, #0F1D35 100%); z-index:10000; display:flex; align-items:center; justify-content:center; flex-direction:column; }
.login-card { background:var(--card); border-radius:var(--radius-lg); padding:var(--space-12) var(--space-12); text-align:center; box-shadow:var(--shadow-xl); max-width:400px; width:90%; animation:loginEnter .4s var(--ease-out) both; }
@keyframes loginEnter { from { opacity:0; transform:translateY(12px) scale(.97); } to { opacity:1; transform:translateY(0) scale(1); } }
.login-logo { margin-bottom:var(--space-3); }
.login-title { font-size:var(--text-xl); font-weight:var(--font-bold); color:var(--text-primary); margin-bottom:var(--space-1); }
.login-subtitle { font-size:var(--text-sm); color:var(--text-secondary); margin-bottom:var(--space-6); }
.login-input { width:100%; padding:11px 14px; margin-bottom:10px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-base); box-sizing:border-box; background:var(--bg); color:var(--text-primary); transition:border-color var(--duration-fast) ease, box-shadow var(--duration-fast) ease; }
.login-input:focus { border-color:var(--accent); outline:none; box-shadow:0 0 0 3px var(--accent-subtle); }
.login-remember { display:flex; align-items:center; gap:6px; font-size:var(--text-sm); color:var(--text-secondary); margin-bottom:var(--space-4); cursor:pointer; }
.login-btn { width:100%; padding:11px; background:var(--accent); color:#fff; border:none; border-radius:var(--radius-sm); font-size:var(--text-md); font-weight:var(--font-semibold); cursor:pointer; transition:background var(--duration-fast) ease; }
.login-btn:hover { background:var(--accent-hover); }
.login-btn:active { transform:scale(.98); }
.login-passkey-btn { width:100%; padding:12px; background:var(--green); color:#fff; border:none; border-radius:var(--radius-sm); font-size:var(--text-md); font-weight:var(--font-semibold); cursor:pointer; display:flex; align-items:center; justify-content:center; gap:var(--space-2); }
.login-totp-input { width:100%; padding:12px; margin-bottom:10px; border:1px solid var(--border); border-radius:var(--radius-sm); font-size:var(--text-xl); text-align:center; letter-spacing:8px; box-sizing:border-box; background:var(--bg); color:var(--text-primary); }
.login-status { margin-top:var(--space-3); font-size:var(--text-sm); color:var(--red); min-height:18px; }

/* ── DARK MODE TOGGLE ── */
.theme-toggle { background:rgba(255,255,255,.12); border:none; color:#fff; padding:6px 8px; border-radius:var(--radius-sm); cursor:pointer; display:flex; align-items:center; transition:background var(--duration-fast) ease; }
.theme-toggle:hover { background:rgba(255,255,255,.22); }

/* ══════════════════════════════════════════════════════════════════════
   DARK MODE OVERRIDES
   Aggressive overrides for inline styles with hardcoded colors.
   Uses !important sparingly but necessarily to override style="..."
   ══════════════════════════════════════════════════════════════════════ */
[data-theme="dark"] .modal-footer { background:var(--card); }
[data-theme="dark"] .hipaa-banner { background:var(--card); border-color:var(--border); }
[data-theme="dark"] .ai-tab.active { background:var(--accent); }
[data-theme="dark"] .condition-chip { background:var(--bg-secondary); }
/* Flatten stat cards to uniform dark */
[data-theme="dark"] .stat-card { background:var(--card) !important; color:var(--text-primary) !important; border:1px solid var(--border); }
[data-theme="dark"] .stat-card .stat-label { color:var(--text-secondary) !important; opacity:1 !important; }
[data-theme="dark"] .stat-card .stat-sub { color:var(--text-tertiary) !important; opacity:1 !important; }
/* Flatten KPI card top borders to subtle */
[data-theme="dark"] .kpi-card { border-top-color:var(--border) !important; }
[data-theme="dark"] .kpi-card.green { border-top-color:var(--border) !important; }
[data-theme="dark"] .kpi-card.red { border-top-color:var(--border) !important; }
[data-theme="dark"] .kpi-card.yellow { border-top-color:var(--border) !important; }
/* Remove decorative colored backgrounds on error banners */
[data-theme="dark"] [style*="background:#fde8e8"],
[data-theme="dark"] [style*="background:#fee2e2"] { background:var(--bg-secondary) !important; border-color:var(--border) !important; }
[data-theme="dark"] .import-drop { background:var(--bg-secondary); }
[data-theme="dark"] .pc-section-header { background:var(--bg-secondary); }
[data-theme="dark"] .billing-radio-opt { background:var(--bg-secondary); }
[data-theme="dark"] .billing-addon { background:var(--bg-secondary); }
[data-theme="dark"] .cond-item { background:var(--bg-secondary); }
[data-theme="dark"] .task-col { background:var(--bg-secondary); }
[data-theme="dark"] .prog-group-hdr td { background:var(--bg-secondary); }

/* Override inline style="background:..." on dashboard elements */
[data-theme="dark"] .kpi-card[style] { background:var(--card) !important; }
[data-theme="dark"] .kpi-secondary { background:var(--bg-secondary) !important; border-color:var(--border) !important; }
[data-theme="dark"] details summary[style] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }
[data-theme="dark"] details summary[style] + div[style] { background:var(--card) !important; border-color:var(--border) !important; }
[data-theme="dark"] details div[style] .kpi-card[style] { background:var(--bg-secondary) !important; }

/* Override inline text colors */
[data-theme="dark"] [style*="color:#4a8a35"],
[data-theme="dark"] [style*="color:#2d6a4a"],
[data-theme="dark"] [style*="color:#2d5a1e"] { color:var(--green) !important; }
[data-theme="dark"] [style*="color:#92400e"],
[data-theme="dark"] [style*="color:#7F6000"] { color:var(--yellow) !important; }
[data-theme="dark"] [style*="color:#0d617e"] { color:var(--accent) !important; }
[data-theme="dark"] [style*="color:var(--red-dark)"] { color:var(--red) !important; }

/* Override inline backgrounds on notification/info banners */
[data-theme="dark"] [style*="background:#e3f5da"],
[data-theme="dark"] [style*="background:#edf9f2"],
[data-theme="dark"] [style*="background:#f8fef9"],
[data-theme="dark"] [style*="background:#f0fdf4"],
[data-theme="dark"] div[style*="background:#e3f5da"] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }

[data-theme="dark"] [style*="background:#fff8d6"],
[data-theme="dark"] [style*="background:#FFF9F2"],
[data-theme="dark"] [style*="background:#fffbeb"] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }

[data-theme="dark"] [style*="background:#fde8e8"],
[data-theme="dark"] [style*="background:#fee2e2"] { background:rgba(220,38,38,0.15) !important; border-color:rgba(220,38,38,0.3) !important; }

[data-theme="dark"] [style*="background:#e6f5fb"],
[data-theme="dark"] [style*="background:#f0f8fc"],
[data-theme="dark"] [style*="background:#f0f9ff"],
[data-theme="dark"] [style*="background:#eff6ff"],
[data-theme="dark"] [style*="background:#d6eef6"] { background:var(--bg-secondary) !important; border-color:var(--border) !important; }

[data-theme="dark"] [style*="background:#f9fafb"],
[data-theme="dark"] [style*="background:#f3f4f6"],
[data-theme="dark"] [style*="background:#fafbfc"],
[data-theme="dark"] [style*="background:#fafafa"],
[data-theme="dark"] [style*="background:#f0f4f8"],
[data-theme="dark"] [style*="background:#f1f5f9"] { background:var(--bg-secondary) !important; }

/* Override inline borders */
[data-theme="dark"] [style*="border:1px solid #b5dfca"],
[data-theme="dark"] [style*="border:1px solid #92C57D"],
[data-theme="dark"] [style*="border:1px solid #FFD966"],
[data-theme="dark"] [style*="border:1px solid #b8dcea"],
[data-theme="dark"] [style*="border:1px solid #bfdbfe"],
[data-theme="dark"] [style*="border:1px solid #bbf7d0"],
[data-theme="dark"] [style*="border:1px solid #f5a3a3"] { border-color:var(--border) !important; }

/* Billing time summary bar */
[data-theme="dark"] #bill-time-summary[style] { background:var(--bg-secondary) !important; border-color:var(--border) !important; }

/* Chart card backgrounds in AI output */
[data-theme="dark"] .ai-output { background:var(--bg-secondary) !important; border-color:var(--border) !important; }
[data-theme="dark"] .ai-output table th { background:var(--bg-secondary) !important; }
[data-theme="dark"] .template-preview { background:var(--bg-secondary) !important; border-color:var(--border) !important; }

/* PHI protection banner */
[data-theme="dark"] div[style*="background:#e3f5da"][style*="border:1px solid #92C57D"] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }
[data-theme="dark"] div[style*="background:#fde8e8"][style*="border:1px solid #f5a3a3"] { background:rgba(220,38,38,0.12) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }

/* Elation import guide cards */
[data-theme="dark"] .chart-card[style*="border-left"] { border-left-color:var(--accent) !important; }
[data-theme="dark"] div[style*="background:var(--bg)"] { background:var(--bg) !important; }
[data-theme="dark"] div[style*="background:#e6f5fb"] { background:var(--bg-secondary) !important; }

/* Care plan prior preview */
[data-theme="dark"] #ai-cp-prior-preview[style] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }
[data-theme="dark"] #ai-cp-forms-preview[style] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }
[data-theme="dark"] #ai-cp-preview[style] { background:var(--bg-secondary) !important; border-color:var(--border) !important; }

/* Billing note info cards */
[data-theme="dark"] div[style*="background:var(--bg2)"] { background:var(--bg-secondary) !important; border-color:var(--border) !important; }

/* Attention hero */
[data-theme="dark"] .attention-hero-header { background:var(--bg-secondary) !important; }

/* User management and settings inline styles */
[data-theme="dark"] input[style*="border:1px solid var(--border)"] { background:var(--card) !important; color:var(--text-primary) !important; }
[data-theme="dark"] select[style*="border:1px solid var(--border)"] { background:var(--card) !important; color:var(--text-primary) !important; }
[data-theme="dark"] textarea[style*="border:1px solid var(--border)"] { background:var(--card) !important; color:var(--text-primary) !important; }

/* Manual care plan output */
[data-theme="dark"] #manual-cp-output[style] { background:var(--card) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }
[data-theme="dark"] #bn-preview-text[style] { background:var(--card) !important; color:var(--text-primary) !important; }
[data-theme="dark"] #careplan-view-text { background:var(--bg-secondary) !important; }
[data-theme="dark"] #pc-live-preview[style] { background:var(--bg-secondary) !important; border-color:var(--border) !important; color:var(--text-primary) !important; }

/* Revenue line overrides */
[data-theme="dark"] .rev-preview { background:var(--bg-secondary) !important; border-color:var(--border) !important; }
[data-theme="dark"] .rev-line { border-bottom-color:var(--border) !important; }

/* Ensure form inputs in inline-styled containers are visible */
[data-theme="dark"] input[type="text"][style],
[data-theme="dark"] input[type="email"][style],
[data-theme="dark"] input[type="password"][style],
[data-theme="dark"] input[type="number"][style],
[data-theme="dark"] input[type="month"][style],
[data-theme="dark"] select[style],
[data-theme="dark"] textarea[style] { background:var(--card) !important; color:var(--text-primary) !important; border-color:var(--border) !important; }
