*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* TOKENS */
:root{
  --teal:#0a7c7c;--teal2:#0e9696;--teal3:#e6f7f7;--teal4:#b2e0e0;
  --bg:#f4f8f8;--surface:#fff;--surface2:#f7fafa;--surface3:#eef5f5;
  --border:#ddeaea;--border2:#c2d8d8;
  --blue:#2563eb;--blue-t:rgba(37,99,235,0.1);
  --green:#16a34a;--green-t:rgba(22,163,74,0.1);
  --amber:#d97706;--amber-t:rgba(217,119,6,0.1);
  --red:#dc2626;--red-t:rgba(220,38,38,0.1);
  --purple:#7c3aed;--purple-t:rgba(124,58,237,0.1);
  --gold:#c9a84c;--gold-t:rgba(201,168,76,0.12);
  --text:#0f2020;--text2:#3d5c5c;--text3:#7a9e9e;--text4:#bdd0d0;
  --sidebar-bg:#0a5a5a;--sidebar-text:rgba(255,255,255,0.85);--sidebar-muted:rgba(255,255,255,0.4);
  --shadow:0 1px 3px rgba(0,40,40,0.08);--shadow2:0 6px 20px rgba(0,40,40,0.12);
}
[data-theme="dark"]{
  --bg:#0d1a1a;--surface:#111f1f;--surface2:#172626;--surface3:#1e3030;
  --border:rgba(255,255,255,0.08);--border2:rgba(255,255,255,0.13);
  --teal3:rgba(10,124,124,0.15);--teal4:rgba(10,124,124,0.25);
  --text:#d4eded;--text2:#8ab5b5;--text3:#4a7070;--text4:#2a4040;
  --sidebar-bg:#071515;
  --shadow:0 1px 3px rgba(0,0,0,0.4);--shadow2:0 6px 20px rgba(0,0,0,0.5);
  --blue-t:rgba(37,99,235,0.15);--green-t:rgba(22,163,74,0.15);
  --amber-t:rgba(217,119,6,0.15);--red-t:rgba(220,38,38,0.15);
}
[data-theme="blue-dark"]{
  --bg:#0b1220;--surface:#111a2e;--surface2:#16233d;--surface3:#1e2f4a;
  --border:rgba(255,255,255,0.09);--border2:rgba(255,255,255,0.14);
  --teal:#6fb4ff;--teal2:#4b8fe8;--teal3:rgba(111,180,255,0.12);--teal4:rgba(111,180,255,0.2);
  --text:#e9f1ff;--text2:#a9b9d6;--text3:#4a6080;--text4:#1e2f45;
  --sidebar-bg:#060d1c;
  --shadow:0 1px 3px rgba(0,0,0,0.5);--shadow2:0 6px 20px rgba(0,0,0,0.6);
  --blue:#6fb4ff;--blue-t:rgba(111,180,255,0.14);
  --green:#5be2a7;--green-t:rgba(91,226,167,0.14);
  --amber:#ffd87a;--amber-t:rgba(255,216,122,0.14);
  --red:#ff6b6b;--red-t:rgba(255,107,107,0.14);
}
[data-theme="blue-dark"] body{
  background:
    radial-gradient(circle at top right,rgba(79,141,255,.1),transparent 30%),
    radial-gradient(circle at left 60%,rgba(91,226,167,.07),transparent 25%),
    linear-gradient(180deg,#08101d 0%,#0c1527 50%,#0f1b32 100%);
}
[data-theme="blue-dark"] .sb-logo-icon{background:linear-gradient(135deg,#6fb4ff,#5be2a7)}

body{font-family:'Inter',sans-serif;font-size:15px;line-height:1.5;background:var(--bg);color:var(--text);min-height:100vh;display:flex;transition:background 0.2s,color 0.2s}
.rdb-email-opt{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-weight:600;font-size:12px}
.rdb-email-opt input{width:16px;height:16px}
.release-timestamp{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  padding:6px 16px;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.05em;
  text-align:center;
  border-radius:18px;
  border:1px solid rgba(4,44,63,0.35);
  background:rgba(255,255,255,0.92);
  color:#021c2d;
  box-shadow:0 12px 32px rgba(2,28,45,0.18);
  z-index:200;
  pointer-events:none;
  min-width:200px;
  font-family:'JetBrains Mono', 'Inter', sans-serif;
}

/* SIDEBAR */
.sidebar{width:240px;background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:width 0.2s}
.sb-head{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,0.07)}
.sb-logo{display:flex;align-items:center;gap:10px;margin-bottom:2px}
.sb-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--teal2),#4fc3c3);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sb-brand{display:flex;flex-direction:column;line-height:1.2}
.sb-brand-name{font-size:15px;font-weight:700;color:#fff}
.sb-brand-sub{font-size:11px;color:var(--sidebar-muted);font-weight:400}
.sb-module{margin-top:10px;background:rgba(255,255,255,0.08);border-radius:8px;padding:7px 12px;display:flex;align-items:center;gap:8px}
.sb-module-icon{font-size:16px}
.sb-module-name{font-size:13px;font-weight:700;color:rgba(255,255,255,0.9)}
.sb-module-sub{font-size:11px;color:var(--sidebar-muted)}

.sb-nav{flex:1;padding:12px 10px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.1) transparent}
.sb-section{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.18em;color:var(--sidebar-muted);padding:10px 10px 4px;margin-top:4px}
.sb-item{display:flex;align-items:center;gap:9px;padding:10px 11px;border-radius:8px;font-size:13px;font-weight:500;color:var(--sidebar-text);cursor:pointer;transition:all 0.15s;background:none;border:none;width:100%;text-align:left;font-family:'Inter',sans-serif;margin-bottom:1px}
.sb-item:hover{background:rgba(255,255,255,0.08);color:#fff}
.sb-item.active{background:rgba(255,255,255,0.13);color:#fff;font-weight:600}
.sb-item-icon{font-size:14px;flex-shrink:0;width:18px;text-align:center}
.sb-item-label{display:inline-block;flex:1 1 auto;min-width:0;color:inherit;opacity:1;visibility:visible;white-space:normal}
.sb-badge{margin-left:auto;background:rgba(255,255,255,0.12);color:rgba(255,255,255,0.7);font-size:11px;padding:2px 7px;border-radius:8px;font-weight:600}
.sb-badge.alert{background:rgba(220,38,38,0.3);color:#fca5a5}

.sb-bottom{padding:12px 10px;border-top:1px solid rgba(255,255,255,0.07)}
.sb-live{display:flex;align-items:center;gap:7px;padding:8px 10px;border-radius:8px;background:rgba(255,255,255,0.05)}
.sb-live-dot{width:6px;height:6px;border-radius:50%;background:#4ade80;animation:blink 2s infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.sb-live-text{font-size:12px;color:var(--sidebar-text)}
.sb-live-text strong{color:#4ade80}
.sb-user-wrap{position:relative}
.sb-user{display:flex;align-items:center;gap:8px;padding:8px 10px;margin-top:4px;border-radius:8px;cursor:pointer}
.sb-user:hover{background:rgba(255,255,255,0.06)}
.sb-avatar{width:30px;height:30px;border-radius:50%;background:var(--teal2);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.sb-user-name{font-size:13px;font-weight:600;color:#fff}
.sb-user-role{font-size:11px;color:var(--sidebar-muted)}
.sb-theme{width:28px;height:28px;border-radius:7px;background:rgba(255,255,255,0.08);border:none;cursor:pointer;color:var(--sidebar-text);font-size:13px;display:flex;align-items:center;justify-content:center;margin-left:auto;transition:background 0.15s}
.sb-theme:hover{background:rgba(255,255,255,0.15)}
.sb-user-menu{position:absolute;left:0;right:0;bottom:50px;background:rgba(7,21,21,0.98);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:8px;box-shadow:0 18px 34px rgba(0,0,0,0.28);display:none;z-index:30}
.sb-user-menu.open{display:block}
.sb-user-menu-head{padding:6px 8px 10px;border-bottom:1px solid rgba(255,255,255,0.08);margin-bottom:8px}
.sb-user-menu-title{font-size:12px;font-weight:700;color:#fff}
.sb-user-menu-sub{font-size:11px;color:var(--sidebar-muted);margin-top:2px}
.sb-user-menu-btn{width:100%;background:none;border:none;color:var(--sidebar-text);font:inherit;text-align:left;padding:9px 10px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px}
.sb-user-menu-btn:hover{background:rgba(255,255,255,0.06)}
.sb-user-menu-note{font-size:10px;color:var(--sidebar-muted)}

/* MAIN */
.main{margin-left:240px;flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 28px;height:52px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow);position:sticky;top:0;z-index:50}
.tb-left{display:flex;flex-direction:column;gap:1px}
.tb-title{font-size:16px;font-weight:700;color:var(--text)}
.tb-sub{font-size:12px;color:var(--text3)}
.tb-right{display:flex;align-items:center;gap:8px}
.btn{padding:9px 16px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;border:none;font-family:'Inter',sans-serif;transition:all 0.15s;display:inline-flex;align-items:center;gap:6px}
.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border2);box-shadow:0 1px 2px rgba(0,40,40,0.06)}
.btn-ghost:hover{background:var(--surface3);color:var(--text);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,40,40,0.12)}
.btn-teal{background:var(--teal);color:#fff}
.btn-teal:hover{background:var(--teal2);transform:translateY(-1px)}
.btn-icon{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text2);transition:all 0.15s}
.btn-icon:hover{background:var(--surface3);color:var(--text)}

.content{padding:24px 28px;flex:1}
.page{display:none}
.page.active{display:block}

/* KPI ROW */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:22px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow);transition:transform 0.15s;cursor:default}
.kpi:hover{transform:translateY(-2px)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.kpi-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px}
.kpi-icon.teal{background:var(--teal3)}
.kpi-icon.green{background:var(--green-t)}
.kpi-icon.amber{background:var(--amber-t)}
.kpi-icon.red{background:var(--red-t)}
.kpi-icon.purple{background:var(--purple-t)}
.kpi-val{font-size:29px;font-weight:700;color:var(--text);letter-spacing:-0.5px;font-family:'JetBrains Mono',monospace;line-height:1}
.kpi-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);margin-top:4px}
.kpi-delta{font-size:12px;margin-top:3px}
.kpi-delta.up{color:var(--green)}.kpi-delta.down{color:var(--red)}.kpi-delta.warn{color:var(--amber)}.kpi-delta.neutral{color:var(--text3)}

/* GRID */
.g2{display:grid;grid-template-columns:1fr 380px;gap:16px;margin-bottom:16px}
.g2-eq{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.billing-stack{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:16px}
.g-full{margin-bottom:16px}

/* PANEL */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.ph{padding:13px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.ph-left{display:flex;flex-direction:column;gap:1px}
.ph-title{font-size:15px;font-weight:700;color:var(--text)}
.ph-sub{font-size:12px;color:var(--text3)}
.ph-right{display:flex;gap:6px;align-items:center}
.pb{padding:16px 18px}
.pb-sm{padding:10px 18px}
.tag{font-size:11px;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:0.05em}
.tag-teal{background:var(--teal3);color:var(--teal)}
.tag-green{background:var(--green-t);color:var(--green)}
.tag-amber{background:var(--amber-t);color:var(--amber)}
.tag-red{background:var(--red-t);color:var(--red)}
.tag-blue{background:var(--blue-t);color:var(--blue)}
.tag-purple{background:var(--purple-t);color:var(--purple)}
.tag-gold{background:var(--gold-t);color:var(--gold)}
.tag-gray{background:var(--surface3);color:var(--text3)}
.chart-wrap{position:relative;height:210px}
.chart-wrap-lg{position:relative;height:260px}

/* TABLE */
.tbl{width:100%;border-collapse:collapse;font-size:15px}
.tbl th{padding:12px 16px;text-align:left;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--text2);border-bottom:2px solid var(--border);white-space:nowrap;background:var(--surface2)}
.tbl td{padding:13px 16px;border-bottom:1px solid var(--border);color:var(--text);font-weight:600;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:var(--surface2)}
.cell-bold{font-weight:600;color:var(--text)}
.cell-mono{font-family:'JetBrains Mono',monospace}
.cell-actions,.cell-ai{white-space:nowrap}
.cell-actions{min-width:168px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cell-ai{min-width:88px}
.cell-note{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:var(--text2);font-weight:600}
.lab-actions-cell,.implant-actions-cell{display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.lab-actions-cell .cell-note,.implant-actions-cell .cell-note{max-width:220px}
.lab-actions-row,.implant-actions-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.implant-modal-body{display:flex;flex-direction:column;gap:12px}
.implant-modal-body label{display:block;font-size:13px;font-weight:700;color:var(--text2);margin-bottom:6px}
.billing-actions-inline{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.billing-actions-inline .btn{padding:4px 10px;font-size:11px;font-weight:700}
.cell-actions .btn,.cell-ai .btn{padding:7px 12px;font-size:13px;font-weight:700;line-height:1.2;border-radius:9px}
.cell-actions .btn{min-width:62px;justify-content:center}
.cell-ai .btn{min-width:42px;justify-content:center}
.tbl td .btn.btn-ghost{
  padding:7px 12px !important;
  font-size:13px !important;
  font-weight:700 !important;
  line-height:1.2 !important;
  border-radius:9px !important;
  color:var(--text) !important;
  background:var(--surface) !important;
  border:1px solid var(--border2) !important;
  box-shadow:0 1px 2px rgba(0,40,40,0.06) !important;
}
.tbl td .btn.btn-ghost:hover{
  background:var(--surface3) !important;
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(0,40,40,0.12) !important;
}
.tbl td .btn.btn-ghost[onclick*="Delete"],
.tbl td .btn.btn-ghost[onclick*="delete"],
.tbl td .btn.btn-ghost[onclick*="lcDelete"],
.tbl td .btn.btn-ghost[onclick*="impDelete"]{
  border-color:#fecaca !important;
  background:#fef2f2 !important;
  color:#b91c1c !important;
}
.tbl td .btn.btn-ghost[onclick*="Book"],
.tbl td .btn.btn-ghost[onclick*="newAppt"]{
  border-color:#99f6e4 !important;
  background:#ecfeff !important;
  color:#0f766e !important;
}
.tbl td .btn.btn-ghost[onclick*="edit"],
.tbl td .btn.btn-ghost[onclick*="Edit"],
.tbl td .btn.btn-ghost[onclick*="loadDeviceStudyDetail"]{
  border-color:#93c5fd !important;
  background:#eff6ff !important;
  color:#1d4ed8 !important;
}
.tbl td .btn.btn-ghost[onclick*="quickAI"],
.tbl td .btn.btn-ghost[onclick*="loadAndAnalyze"],
.tbl td .btn.btn-ghost[onclick*="openImagingWorkspace"]{
  border-color:#ddd6fe !important;
  background:#f5f3ff !important;
  color:#6d28d9 !important;
}
.tbl td .rfmo-code{
  font-size:12px !important;
  font-weight:700 !important;
}
.btn-action-edit{border-color:#93c5fd;background:#eff6ff;color:#1d4ed8}
.btn-action-book{border-color:#99f6e4;background:#ecfeff;color:#0f766e}
.btn-action-delete{border-color:#fecaca;background:#fef2f2;color:#b91c1c}
.btn-action-ai{border-color:#ddd6fe;background:#f5f3ff;color:#6d28d9}
.btn-action-report{border-color:#bfdbfe;background:#eff6ff;color:#1e40af}
.tbl-link{color:var(--teal);cursor:pointer;font-weight:600}
.tbl-link:hover{text-decoration:underline}
.table-scroll{overflow-x:auto;overflow-y:hidden}
.table-scroll .tbl{min-width:1220px}
#apptsTable{table-layout:fixed}
#apptsTable th,#apptsTable td{padding:10px 8px;font-size:13px}
#apptsTable th:nth-child(1),#apptsTable td:nth-child(1){width:56px}
#apptsTable th:nth-child(2),#apptsTable td:nth-child(2){width:58px}
#apptsTable th:nth-child(3),#apptsTable td:nth-child(3){width:118px}
#apptsTable th:nth-child(4),#apptsTable td:nth-child(4){width:96px}
#apptsTable th:nth-child(5),#apptsTable td:nth-child(5){width:72px}
#apptsTable th:nth-child(6),#apptsTable td:nth-child(6){width:58px}
#apptsTable th:nth-child(7),#apptsTable td:nth-child(7){width:56px}
#apptsTable th:nth-child(8),#apptsTable td:nth-child(8){width:70px}
#apptsTable th:nth-child(9),#apptsTable td:nth-child(9){width:64px}
#apptsTable th:nth-child(10),#apptsTable td:nth-child(10){width:70px}
#apptsTable th:nth-child(11),#apptsTable td:nth-child(11){width:74px}
#apptsTable th:nth-child(12),#apptsTable td:nth-child(12){width:56px}
#apptsTable th:nth-child(13),#apptsTable td:nth-child(13){width:104px}
#apptsTable th:nth-child(14),#apptsTable td:nth-child(14){width:56px}
#apptsTable th:nth-child(15),#apptsTable td:nth-child(15){width:82px}
#apptsTable td:nth-child(3),
#apptsTable td:nth-child(4),
#apptsTable td:nth-child(5),
#apptsTable td:nth-child(13){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#apptsTable td:nth-child(14) button,
#apptsTable td:nth-child(15) button{padding:7px 12px;font-size:13px;font-weight:700;border-radius:9px}

/* Enhanced grid toolbar */
.grid-toolbar{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  margin:0 0 12px;
  justify-content:space-between;
  font-size:14px;
}
.grid-toolbar .toolbar-actions{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}
.grid-toolbar button{
  padding:8px 12px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--surface);
  color:var(--text);
  font-size:14px;
  cursor:pointer;
  transition:background 0.2s,border 0.2s,transform 0.2s;
}
.grid-toolbar button:hover{background:var(--surface2);transform:translateY(-1px)}
.grid-toolbar .grid-search{
  flex:1;
  min-width:180px;
  max-width:320px;
  padding:8px 12px;
  border-radius:8px;
  border:1px solid var(--border);
}
.grid-filter-panel{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}
.grid-filter-panel select,.grid-filter-panel input{
  padding:8px 10px;
  border-radius:8px;
  border:1px solid var(--border);
  min-width:160px;
}
.grid-filter-panel button{
  padding:8px 10px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--teal3);
  color:var(--text);
}
.grid-toolbar .sort-active{font-weight:600;text-decoration:underline}
.tbl th.sort-asc::after{content:' --';font-size:9px;margin-left:4px;color:var(--text3)}
.tbl th.sort-desc::after{content:' --';font-size:9px;margin-left:4px;color:var(--text3)}

/* APPOINTMENT LIST */
.appt-list{display:flex;flex-direction:column;gap:0}
.appt-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.appt-item:last-child{border-bottom:none;padding-bottom:0}
.appt-time{width:48px;text-align:center;flex-shrink:0}
.appt-time-val{font-size:14px;font-weight:700;color:var(--text);font-family:'JetBrains Mono',monospace}
.appt-time-ampm{font-size:10px;color:var(--text3);text-transform:uppercase}
.appt-line{width:2px;height:36px;border-radius:2px;flex-shrink:0}
.appt-body{flex:1;min-width:0}
.appt-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appt-detail{font-size:12px;color:var(--text3);margin-top:1px}
.appt-right{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0}

/* TOOTH CHART */
.tooth-chart{display:flex;flex-direction:column;gap:8px;align-items:center;padding:12px 0;width:100%;overflow-x:auto;overflow-y:hidden}
.tooth-chart-label{font-size:10px;color:var(--text3);width:max-content;min-width:100%;text-align:center}
.tooth-row{display:flex;gap:4px;min-width:max-content;padding:2px 4px 6px}
.tooth{width:30px;height:40px;border-radius:8px 8px 10px 10px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;cursor:pointer;transition:all 0.15s;border:1.5px solid var(--border2);flex:0 0 auto}
.tooth.healthy{background:var(--teal3);color:var(--teal);border-color:var(--teal4)}
.tooth.filled{background:var(--amber-t);color:var(--amber);border-color:rgba(217,119,6,0.3)}
.tooth.crown{background:var(--gold-t);color:var(--gold);border-color:rgba(201,168,76,0.3)}
.tooth.missing{background:var(--red-t);color:var(--red);border-color:rgba(220,38,38,0.2);opacity:0.6}
.tooth.implant{background:var(--purple-t);color:var(--purple);border-color:rgba(124,58,237,0.3)}
.tooth:hover{transform:scale(1.1);z-index:2}
.tooth.active{box-shadow:0 0 0 2px rgba(10,124,124,0.16),0 10px 18px rgba(10,124,124,0.18);transform:translateY(-2px) scale(1.08)}
.tooth-legend{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}
.tooth-leg-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text3)}
.tooth-leg-dot{width:10px;height:10px;border-radius:3px}
.tooth-details{margin-top:10px;border:1px solid var(--border);background:var(--panel);border-radius:14px;padding:12px}
.tooth-detail-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}
.tooth-detail-copy{font-size:12px;color:var(--text2);line-height:1.5}
.tooth-editor{margin-top:10px;border-top:1px solid var(--border);padding-top:10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.tooth-editor textarea{min-height:72px}
.tooth-micro-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.setup-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.setup-note{font-size:12px;color:var(--text3);margin-top:8px}
.plan-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.plan-card{padding:14px;border:1px solid var(--border);border-radius:14px;background:var(--panel);display:flex;flex-direction:column;gap:10px}
.plan-card-top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.plan-card-title{font-size:14px;font-weight:700;color:var(--text)}
.plan-card-sub{font-size:12px;color:var(--text3);margin-top:3px}
.plan-chip-row{display:flex;flex-wrap:wrap;gap:8px}
.plan-chip{padding:5px 8px;border-radius:999px;background:var(--surface2);font-size:11px;color:var(--text2);border:1px solid var(--border)}
.plan-copy{font-size:12px;color:var(--text2);line-height:1.55}
.plan-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}
.plan-metric{padding:8px;border-radius:10px;background:var(--surface2);border:1px solid var(--border)}
.plan-metric-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em}
.plan-metric-val{font-size:12px;color:var(--text);font-weight:700;margin-top:4px}

/* RFMO CODE ROW */
.rfmo-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border)}
.rfmo-row:last-child{border-bottom:none}
.rfmo-code{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--teal);background:var(--teal3);padding:3px 8px;border-radius:4px}
.rfmo-desc{font-size:13px;color:var(--text2);flex:1;margin:0 10px}
.rfmo-rate{font-size:13px;font-weight:700;color:var(--text);font-family:'JetBrains Mono',monospace}

/* STAT MINI */
.stat-mini{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--border)}
.stat-mini:last-child{border-bottom:none}
.sm-label{font-size:13px;color:var(--text2)}
.sm-val{font-size:14px;font-weight:700;color:var(--text);font-family:'JetBrains Mono',monospace}

/* RISK BAR */
.risk-item{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.risk-item:last-child{margin-bottom:0}
.risk-header{display:flex;justify-content:space-between;align-items:center}
.risk-name{font-size:13px;font-weight:600;color:var(--text)}
.risk-bar-wrap{height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.risk-fill{height:100%;border-radius:3px;transition:width 0.6s}

/* FILTER BAR */
.filter-bar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:10px 18px;background:var(--surface2);border-bottom:1px solid var(--border)}
.search-wrap{position:relative;flex:1;min-width:180px}
.search-wrap::before{content:'';position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:11px;pointer-events:none}
.search-input{width:100%;padding:10px 12px 10px 32px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:600;background:var(--surface);color:var(--text);font-family:'Inter',sans-serif;outline:none}
.search-input:focus{border-color:var(--teal)}
.filter-select{padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:600;background:var(--surface);color:var(--text);font-family:'Inter',sans-serif;outline:none;cursor:pointer}
.appt-week-shell{padding:18px;background:linear-gradient(180deg,var(--surface),var(--surface2))}
.appt-week-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.appt-week-title-group{display:flex;flex-direction:column;gap:3px}
.appt-week-label{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.appt-week-range{font-size:18px;font-weight:700;color:var(--text);line-height:1.2}
.appt-week-sub{font-size:12px;color:var(--text2)}
.appt-week-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.appt-week-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:14px}
.appt-week-stat{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);display:flex;flex-direction:column;gap:3px}
.appt-week-stat-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.appt-week-stat-value{font-size:18px;font-weight:700;color:var(--text);font-family:'JetBrains Mono',monospace}
.appt-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:12px}
.appt-week-day{min-height:260px;border:1px solid var(--border);border-radius:8px;background:var(--surface);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 2px 8px rgba(0,40,40,0.04)}
.appt-week-day.is-today{border-color:var(--teal);box-shadow:inset 0 0 0 1px rgba(10,124,124,0.14),0 10px 24px rgba(10,124,124,0.08)}
.appt-week-head{padding:11px 12px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:10px;background:var(--surface2)}
.appt-week-head-main{display:flex;flex-direction:column;gap:2px}
.appt-week-dow{font-size:10px;font-weight:800;text-transform:uppercase;color:var(--text3);letter-spacing:.08em}
.appt-week-date{font-size:15px;font-weight:700;color:var(--text)}
.appt-week-count{font-size:10px;font-weight:700;padding:4px 7px;border-radius:999px;background:var(--teal3);color:var(--teal);white-space:nowrap}
.appt-week-count.is-empty{background:var(--surface3);color:var(--text3)}
.appt-week-body{padding:10px;display:flex;flex-direction:column;gap:8px;flex:1;background:
linear-gradient(transparent 31px, rgba(148,163,184,0.08) 32px),
linear-gradient(90deg, transparent calc(100% - 1px), rgba(148,163,184,0.04) calc(100% - 1px));
background-size:100% 32px,100% 100%}
.appt-week-empty{font-size:12px;color:var(--text3);padding:12px 8px;border:1px dashed var(--border);border-radius:8px;background:rgba(148,163,184,0.06)}
.appt-week-card{border:1px solid var(--border);border-left:4px solid var(--teal);border-radius:8px;background:var(--surface);padding:9px 10px;display:flex;flex-direction:column;gap:5px;cursor:pointer;text-align:left;box-shadow:0 1px 3px rgba(0,40,40,0.05)}
.appt-week-card:hover{background:var(--surface3);transform:translateY(-1px)}
.appt-week-time{font-size:11px;font-weight:700;color:var(--text2);font-family:'JetBrains Mono',monospace}
.appt-week-patient{font-size:12px;font-weight:700;color:var(--text);line-height:1.25}
.appt-week-proc{font-size:11px;color:var(--text2);line-height:1.35;min-height:28px}
.appt-week-meta{font-size:10px;color:var(--text3);line-height:1.35}
.appt-week-status{display:inline-flex;align-self:flex-start;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:3px 6px;border-radius:999px;background:var(--surface2);color:var(--text2)}
.appt-week-card.status-completed .appt-week-status{background:var(--green-t);color:var(--green)}
.appt-week-card.status-cancelled .appt-week-status,.appt-week-card.status-canceled .appt-week-status{background:var(--surface3);color:var(--text3)}
.appt-week-card.status-no-show .appt-week-status,.appt-week-card.status-noshow .appt-week-status{background:var(--red-t);color:var(--red)}
.appt-week-card.status-rescheduled .appt-week-status,.appt-week-card.status-confirmed .appt-week-status,.appt-week-card.status-scheduled .appt-week-status{background:var(--blue-t);color:var(--blue)}
.appt-week-card.status-completed{border-left-color:var(--green)}
.appt-week-card.status-cancelled,.appt-week-card.status-canceled{border-left-color:var(--text3)}
.appt-week-card.status-no-show,.appt-week-card.status-noshow{border-left-color:var(--red)}
.appt-week-card.status-rescheduled,.appt-week-card.status-confirmed,.appt-week-card.status-scheduled{border-left-color:var(--blue)}

/* AI ANALYSIS */
.ai-banner{background:linear-gradient(135deg,var(--teal3),rgba(201,168,76,0.08));border:1px solid var(--teal4);border-radius:12px;padding:14px 18px;margin-bottom:18px;display:flex;align-items:flex-start;gap:12px}
[data-theme="dark"] .ai-banner{background:linear-gradient(135deg,rgba(10,124,124,0.1),rgba(201,168,76,0.06))}
.ai-banner-icon{font-size:22px;flex-shrink:0}
.ai-banner-title{font-size:13px;font-weight:700;color:var(--teal);margin-bottom:3px}
.ai-banner-text{font-size:13px;color:var(--text2);line-height:1.7}
.trial-strip{margin:16px 28px 0;background:linear-gradient(135deg,var(--surface),var(--surface2));border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.trial-copy{display:flex;flex-direction:column;gap:2px}
.trial-title{font-size:13px;font-weight:700;color:var(--text)}
.trial-text{font-size:12px;color:var(--text2)}
.trial-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.price-cta{margin-top:14px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.price-note{font-size:11px;color:var(--text3)}
.locked-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;background:var(--amber-t);color:var(--amber);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.locked-note{margin-top:10px;font-size:12px;color:var(--text3)}
.is-locked{position:relative}
.is-locked::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0.08));pointer-events:none}
.btn-premium{opacity:.6;cursor:not-allowed}
.ai-result-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:10px;animation:fadein 0.25s}
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.arc-head{padding:10px 14px;background:var(--surface2);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.arc-title{font-size:13px;font-weight:700;color:var(--text)}
.arc-body{padding:14px;font-size:13px;line-height:1.8;color:var(--text2);white-space:pre-wrap}

/* FLOATING AI */
.ai-fab{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.ai-toggle{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--teal2));border:none;cursor:pointer;font-size:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(10,124,124,0.45);transition:transform 0.2s;color:#fff}
.ai-toggle:hover{transform:scale(1.08)}
.ai-panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:340px;box-shadow:var(--shadow2);display:none;flex-direction:column;overflow:hidden;max-height:480px}
.ai-panel.open{display:flex}
.ai-phead{padding:13px 16px;background:linear-gradient(135deg,var(--teal),var(--teal2));display:flex;align-items:center;justify-content:space-between}
.ai-phead-title{font-size:13px;font-weight:700;color:#fff;display:flex;align-items:center;gap:6px}
.ai-phead-close{background:rgba(255,255,255,0.2);border:none;color:#fff;width:22px;height:22px;border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}
.ai-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px;min-height:0}
.ai-msg{padding:10px 12px;border-radius:10px;font-size:13px;line-height:1.6;max-width:88%;animation:fadein 0.2s}
.ai-msg.user{background:var(--teal);color:#fff;align-self:flex-end;border-radius:10px 10px 2px 10px}
.ai-msg.bot{background:var(--surface3);color:var(--text);align-self:flex-start;border-radius:10px 10px 10px 2px}
.ai-msg.bot.loading{color:var(--text3);font-style:italic}
.ai-pinput{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:8px}
.ai-pinput input{flex:1;padding:9px 10px;border:1px solid var(--border);border-radius:8px;font-size:13px;background:var(--surface2);color:var(--text);font-family:'Inter',sans-serif;outline:none}
.ai-pinput input:focus{border-color:var(--teal)}
.ai-psend{width:30px;height:30px;background:var(--teal);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-psend:hover{background:var(--teal2)}
.ai-psugg{padding:0 12px 8px;display:flex;flex-wrap:wrap;gap:4px}
.ai-sugg-btn{padding:5px 10px;border:1px solid var(--border);background:var(--surface3);border-radius:10px;font-size:11px;color:var(--text2);cursor:pointer;font-family:'Inter',sans-serif;transition:all 0.15s}
.ai-sugg-btn:hover{background:var(--teal3);color:var(--teal);border-color:var(--teal4)}

/* SPINNER */
.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin 0.7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-row td{text-align:center;padding:32px;color:var(--text3)}
.empty-state{text-align:center;padding:40px 20px;color:var(--text3)}
.empty-icon{font-size:36px;margin-bottom:10px;opacity:0.4}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:300;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border-radius:14px;width:520px;max-width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow2)}
.modal-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-title{font-size:19px;font-weight:800;color:var(--text)}
.modal-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:18px}
.modal-body{padding:18px 20px}
.modal-label{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:0.08em;color:var(--text2);margin-bottom:6px}
.modal-input{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-weight:600;background:var(--surface2);color:var(--text);font-family:'Inter',sans-serif;outline:none;margin-bottom:14px}
.modal-input:focus{border-color:var(--teal)}
.modal-ta{width:100%;padding:11px 13px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-weight:600;background:var(--surface2);color:var(--text);font-family:'Inter',sans-serif;outline:none;resize:vertical;min-height:110px;margin-bottom:14px}
.modal-foot{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}

/* Invoice line items: make Procedure readable in modal */
.inv-lines-wrap{
  border:1px solid var(--border);
  border-radius:8px;
  padding:8px;
  background:var(--surface2);
}
.inv-lines-table{min-width:980px}
.inv-lines-table th,.inv-lines-table td{padding:8px 8px}
.inv-lines-table .modal-input{margin-bottom:0; padding:9px 10px; font-size:14px}
.inv-col-code{width:120px}
.inv-col-tooth{width:90px}
.inv-col-dentist{width:160px}
.inv-col-qty{width:74px}
.inv-col-unit{width:110px}
.inv-col-tax{width:95px}
.inv-col-disc{width:95px}
.inv-col-actions{width:88px; text-align:right}
.inv-col-proc{min-width:280px}
.inv-lines-table .inv-line-remove{font-size:11px; padding:4px 8px}

/* Invoice modal: larger popup, no inner scroller */
#modal-newInvoice .modal{
  width: 980px;
  max-width: min(980px, calc(100vw - 24px));
  max-height: 92vh;
}
#modal-newInvoice .modal-body{
  max-height: calc(92vh - 64px - 58px);
  overflow-y: auto;
}

.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}
.feature-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--shadow)}
.feature-icon{width:38px;height:38px;border-radius:10px;background:var(--teal3);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
.feature-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:6px}
.feature-copy{font-size:13px;color:var(--text2);line-height:1.7;margin-bottom:10px}
.feature-list{display:flex;flex-direction:column;gap:6px}
.feature-item{font-size:12px;color:var(--text2);padding-left:14px;position:relative}
.feature-item::before{content:'▪';position:absolute;left:0;color:var(--teal)}
.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:16px}
.price-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.price-card.featured{border-color:var(--teal4);box-shadow:0 10px 24px rgba(10,124,124,0.14)}
.price-head{padding:16px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,var(--surface),var(--surface2))}
.price-plan{font-size:13px;font-weight:700;color:var(--text);margin-bottom:4px}
.price-for{font-size:12px;color:var(--text3)}
.price-val{font-size:28px;font-weight:800;color:var(--text);letter-spacing:-0.04em;margin-top:10px}
.price-val small{font-size:12px;font-weight:600;color:var(--text3)}
.price-body{padding:16px 18px;display:flex;flex-direction:column;gap:8px;flex:1}
.price-line{font-size:12px;color:var(--text2);line-height:1.6}
.price-foot{padding:14px 18px;border-top:1px solid var(--border);background:var(--surface2)}
.addon-table{width:100%;border-collapse:collapse;font-size:13px}
.addon-table th{padding:10px 12px;text-align:left;border-bottom:2px solid var(--border);font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3)}
.addon-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text2)}
.signal-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.signal-box{background:linear-gradient(135deg,var(--surface2),var(--surface));border:1px solid var(--border);border-radius:12px;padding:14px 16px}
.signal-label{font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--text3);margin-bottom:6px}
.signal-value{font-size:20px;font-weight:700;color:var(--text)}

/* RESPONSIVE */
@media(max-width:1100px){.kpi-row{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:1fr}.pricing-grid{grid-template-columns:repeat(2,1fr)}.feature-grid{grid-template-columns:1fr 1fr}.signal-strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.sidebar{width:60px}.sidebar .sb-brand,.sidebar .sb-module-name,.sidebar .sb-module-sub,.sidebar .sb-section,.sb-badge,.sb-user-name,.sb-user-role,.sb-brand-sub{display:none}.sb-item{justify-content:center;padding:10px}.main{margin-left:60px}.kpi-row{grid-template-columns:repeat(2,1fr)}.g2-eq{grid-template-columns:1fr}.g3{grid-template-columns:1fr}}

/* ODONTOGRAM */
.odonto-wrap{overflow-x:auto;padding-bottom:8px}
.odonto-arch-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);padding:6px 0 4px}
.odonto-row{display:flex;gap:6px;padding:4px 0}
.odonto-tooth{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer}
.odonto-num{font-size:10px;font-weight:700;color:var(--text3);text-align:center}
.odonto-svg{width:36px;height:36px}
.odonto-divider{border:none;border-top:2px dashed var(--border2);margin:8px 0}
.odonto-legend{display:flex;flex-wrap:wrap;gap:10px;font-size:11px;color:var(--text2);margin-top:12px}
.odonto-legend-item{display:flex;align-items:center;gap:5px}
.odonto-legend-swatch{width:12px;height:12px;border-radius:3px;border:1px solid rgba(0,0,0,.1)}
.odonto-condition-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.odonto-cond-btn{padding:4px 10px;border-radius:6px;border:1.5px solid var(--border2);background:var(--surface);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s}
.odonto-cond-btn.selected{border-color:var(--teal2);background:var(--teal3);color:var(--teal)}
.odonto-summary-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.odonto-stat{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:7px 12px;font-size:12px}
.odonto-stat strong{display:block;font-size:16px;font-weight:700;color:var(--text)}
.odonto-stat span{color:var(--text3)}

/* LAB CASES */
.lab-status-sent{background:var(--blue-t);color:var(--blue)}
.lab-status-inprogress{background:var(--amber-t);color:var(--amber)}
.lab-status-received{background:var(--green-t);color:var(--green)}
.lab-status-tryin{background:var(--purple-t);color:var(--purple)}
.lab-status-rejected{background:var(--red-t);color:var(--red)}
.lab-status-draft{background:var(--surface3);color:var(--text3)}
.lab-overdue{color:var(--red);font-weight:600}

/* IMPLANT TRACKER */
.implant-status-planning{background:var(--blue-t);color:var(--blue)}
.implant-status-placed{background:var(--amber-t);color:var(--amber)}
.implant-status-restored{background:var(--green-t);color:var(--green)}
.implant-status-review{background:var(--red-t);color:var(--red)}

/* PERIO CHART */
.perio-wrap{overflow-x:auto;padding-bottom:8px}
.perio-arch{display:flex;flex-direction:column;gap:0}
.perio-arch-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);padding:6px 0 4px}
.perio-teeth-row{display:flex;gap:3px;align-items:flex-end}
.perio-tooth{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:42px}
.perio-tooth-num{font-size:10px;font-weight:700;color:var(--text3);text-align:center;line-height:1}
.perio-depths{display:flex;gap:2px}
.perio-depth{width:12px;height:28px;border-radius:3px;border:1.5px solid var(--border2);background:var(--surface2);font-size:9px;font-weight:600;text-align:center;color:var(--text2);cursor:pointer;outline:none;padding:0;line-height:28px;transition:background .15s,border-color .15s}
.perio-depth:focus{border-color:var(--teal2);outline:none}
.perio-depth.d-healthy{background:#dcfce7;border-color:#86efac;color:#166534}
.perio-depth.d-watch{background:#fef9c3;border-color:#fde047;color:#854d0e}
.perio-depth.d-moderate{background:#fed7aa;border-color:#fb923c;color:#7c2d12}
.perio-depth.d-severe{background:#fee2e2;border-color:#f87171;color:#7f1d1d}
.perio-indicators{display:flex;gap:3px;margin-top:2px}
.perio-dot{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--border2);cursor:pointer;transition:background .15s}
.perio-dot.active-bleed{background:#ef4444;border-color:#ef4444}
.perio-dot.active-suppuration{background:#f97316;border-color:#f97316}
.perio-dot.active-furcation{background:#8b5cf6;border-color:#8b5cf6}
.perio-tooth-svg{width:30px;height:38px;margin:2px 0}
.perio-divider{width:100%;height:1px;background:var(--border);margin:8px 0}
.perio-legend{display:flex;flex-wrap:wrap;gap:10px;font-size:11px;color:var(--text2)}
.perio-legend-item{display:flex;align-items:center;gap:5px}
.perio-legend-swatch{width:12px;height:12px;border-radius:3px}
.perio-mobility-row{display:flex;gap:3px}
.perio-mobility{width:42px;text-align:center}
.perio-mob-input{width:32px;height:20px;border:1.5px solid var(--border2);border-radius:4px;font-size:10px;text-align:center;background:var(--surface2);color:var(--text);outline:none}
.perio-mob-input:focus{border-color:var(--teal2)}
.perio-ai-summary{background:linear-gradient(135deg,var(--teal3),#f0fdf4);border:1px solid var(--teal4);border-radius:10px;padding:14px 16px;font-size:13px;line-height:1.6;color:var(--text)}
.perio-ai-summary strong{color:var(--teal)}
.perio-selector{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
.perio-selector label{font-size:13px;font-weight:500;color:var(--text2)}
.perio-selector select{padding:5px 10px;border-radius:7px;border:1.5px solid var(--border2);background:var(--surface);font-size:13px;color:var(--text);cursor:pointer}
.perio-status-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.perio-stat{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:12px}
.perio-stat strong{display:block;font-size:18px;font-weight:700;color:var(--text)}
.perio-stat span{color:var(--text3)}

/* TOAST NOTIFICATIONS */
#ovi-toast-container{position:fixed;bottom:24px;right:24px;z-index:99999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.ovi-toast{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:10px;font-size:13px;font-weight:500;color:#fff;max-width:360px;pointer-events:auto;box-shadow:0 4px 20px rgba(0,0,0,0.25);animation:toastIn .25s ease;transition:opacity .3s ease,transform .3s ease}
.ovi-toast.closing{opacity:0;transform:translateY(8px)}
.ovi-toast.success{background:linear-gradient(135deg,#1a9850,#27ae60)}
.ovi-toast.error{background:linear-gradient(135deg,#c0392b,#e74c3c)}
.ovi-toast.info{background:linear-gradient(135deg,#2471a3,#2980b9)}
.ovi-toast.warning{background:linear-gradient(135deg,#b7770d,#d4a017)}
.ovi-toast-icon{font-size:16px;line-height:1;flex-shrink:0;margin-top:1px}
.ovi-toast-body{flex:1;line-height:1.4}
.ovi-toast-close{background:none;border:none;color:rgba(255,255,255,0.7);cursor:pointer;font-size:16px;padding:0;line-height:1;flex-shrink:0;margin-top:-1px}
.ovi-toast-close:hover{color:#fff}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ONBOARDING WIZARD */
.onboarding-wizard{background:var(--surface2);border:1px solid var(--border);border-radius:18px;box-shadow:0 12px 24px rgba(0,25,25,0.12);margin:16px 28px 24px;padding:16px 20px;display:flex;flex-direction:column;gap:12px;transition:all 0.35s ease}
.onboarding-wizard.hidden{opacity:0;height:0;transform:scaleY(0);padding:0 20px;margin:0;height:0;pointer-events:none;overflow:hidden}
.onboarding-wizard.wizard-success{border-color:var(--green);background:linear-gradient(135deg,rgba(10,124,124,0.08),var(--surface));}
.wizard-card{display:flex;flex-direction:column;gap:12px}
.wizard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.wizard-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.25em;color:var(--text3)}
.wizard-status{font-size:12px;font-weight:600;color:var(--text2)}
.wizard-step-title{font-size:18px;font-weight:700;color:var(--text)}
.wizard-progress{display:flex;gap:6px;min-height:8px}
.wizard-progress-dot{width:34px;height:6px;border-radius:999px;background:rgba(15,32,32,0.08);flex:1}
.wizard-progress-dot.active{background:var(--teal);box-shadow:0 0 0 3px rgba(10,124,124,0.1)}
.wizard-progress-dot.completed{background:var(--green)}
.wizard-body{min-height:140px}
.wizard-pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}
.wizard-pill{border:1px solid var(--border);border-radius:999px;padding:8px 16px;font-size:13px;font-weight:600;background:var(--surface);color:var(--text2);cursor:pointer;transition:all 0.25s ease;display:inline-flex;align-items:center;gap:6px}
.wizard-pill.active{border-color:var(--teal);background:var(--teal3);color:#083033;box-shadow:0 6px 18px rgba(10,124,124,0.2)}
.wizard-pill-sub{display:block;font-size:11px;font-weight:400;color:var(--text3)}
.wizard-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:12px}
.wizard-form-grid label{font-size:12px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:0.08em}
.wizard-form-grid input,.wizard-form-grid select{width:100%;padding:6px 10px;border-radius:8px;border:1px solid var(--border);background:var(--surface);font-size:14px;color:var(--text);font-family:'Inter',sans-serif}
.wizard-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-end;margin-top:8px}
.wizard-tip{font-size:12px;color:var(--text3);margin-left:auto}
.wizard-dismiss{background:none;border:none;color:var(--text3);cursor:pointer;font-size:12px;padding:0;text-decoration:underline}
.wizard-complete-summary{padding:12px 14px;background:linear-gradient(135deg,rgba(22,163,74,0.15),rgba(15,32,32,0.02));border-radius:10px;border:1px solid rgba(22,163,74,0.25);font-size:13px;line-height:1.6;color:var(--text)}
.wizard-complete-summary strong{color:var(--teal);display:block;margin-bottom:6px}
.wizard-open-btn{border-radius:8px;font-size:12px;padding:8px 14px}
@media (max-width:860px){.onboarding-wizard{margin:12px 16px;padding:14px}.wizard-actions{flex-direction:column;align-items:flex-start}.wizard-tip{margin-left:0}}

/* OPS ACTIONS INLINE */
.ops-actions-inline{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.ops-actions-inline .btn{
  min-width:0;
  padding:6px 10px;
  font-size:12px;
  line-height:1.2;
}

#insuranceTbody .cell-actions,
#rfmoTbody .cell-actions{
  min-width:154px;
}

#insuranceTbody .btn,
#rfmoTbody .btn{
  min-width:58px;
}

#page-insurance .tbl{
  table-layout:fixed;
}

#page-insurance .tbl th,
#page-insurance .tbl td{
  padding:10px 8px;
  font-size:12px;
  vertical-align:middle;
}

@media (max-width: 1200px){
  .appt-week-summary{grid-template-columns:repeat(3,minmax(0,1fr))}
  .appt-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width: 700px){
  .appt-week-summary{grid-template-columns:1fr}
  .appt-week-grid{grid-template-columns:1fr}
  .appt-week-day{min-height:auto}
  .appt-week-toolbar{align-items:stretch}
}


#insuranceTbody td:nth-child(1){
  width:88px;
}

#insuranceTbody td:nth-child(2){
  width:136px;
}

#insuranceTbody td:nth-child(3),
#insuranceTbody td:nth-child(4),
#insuranceTbody td:nth-child(5),
#insuranceTbody td:nth-child(10){
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

#insuranceTbody td:nth-child(3){
  width:110px;
}

#insuranceTbody td:nth-child(4){
  width:96px;
}

#insuranceTbody td:nth-child(5){
  width:116px;
}

#insuranceTbody td:nth-child(6),
#insuranceTbody td:nth-child(7),
#insuranceTbody td:nth-child(8),
#insuranceTbody td:nth-child(9),
#insuranceTbody td:nth-child(11){
  width:82px;
}

#insuranceTbody td:nth-child(10){
  width:110px;
}

#insuranceTbody .cell-actions{
  min-width:132px;
  gap:5px;
}

#insuranceTbody .cell-actions .btn{
  min-width:54px;
  padding:5px 8px !important;
  font-size:11px !important;
}

#modal-newInsuranceClaim .modal,
#modal-newClaim .modal{
  max-width:620px;
}

#modal-newInsuranceClaim .modal-body,
#modal-newClaim .modal-body{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:0 14px;
}

#modal-newInsuranceClaim .modal-label,
#modal-newClaim .modal-label{
  margin-top:2px;
}

#modal-newInsuranceClaim .modal-ta,
#modal-newInsuranceClaim .modal-input,
#modal-newClaim .modal-input{
  margin-bottom:12px;
}

#modal-newInsuranceClaim .modal-body > .modal-label:nth-child(1),
#modal-newInsuranceClaim .modal-body > #insuranceClaimPatient,
#modal-newInsuranceClaim .modal-body > .modal-label:nth-child(5),
#modal-newInsuranceClaim .modal-body > #insuranceClaimProcedure,
#modal-newInsuranceClaim .modal-body > .modal-label:nth-child(15),
#modal-newInsuranceClaim .modal-body > #insuranceClaimDenial,
#modal-newClaim .modal-body > .modal-label:nth-child(1),
#modal-newClaim .modal-body > #claimPatient,
#modal-newClaim .modal-body > .modal-label:nth-child(3),
#modal-newClaim .modal-body > #claimCodes,
#modal-newClaim .modal-body > .modal-label:nth-child(17),
#modal-newClaim .modal-body > #claimAttachments,
#modal-newClaim .modal-body > .modal-label:nth-child(21),
#modal-newClaim .modal-body > #claimReason{
  grid-column:1 / -1;
}

#impModalOverlay .modal{
  max-width:700px;
}

#impModalOverlay .modal-head{
  padding:18px 22px;
}

#impModalOverlay .modal-body{
  padding:20px 22px 16px;
}

#impModalOverlay .modal-foot{
  padding:14px 22px 18px;
}

#impModalOverlay .form-row2{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}

#impModalOverlay .modal-input,
#impModalOverlay .modal-ta{
  margin-bottom:0;
}

.consent-inline-actions{
  margin-top:12px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.consent-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid var(--border);
}

.consent-row-title{
  font-size:13px;
  font-weight:700;
  color:var(--text);
}

.consent-row-sub{
  font-size:12px;
  color:var(--text3);
}

.consent-row-meta{
  text-align:right;
  font-size:12px;
  color:var(--text3);
}

.consent-launcher-copy{
  margin-top:12px;
  font-size:12px;
  color:var(--text3);
  line-height:1.45;
}

.consent-viewer-modal{
  max-width:980px;
  width:min(96vw,980px);
}

.consent-viewer-body{
  padding:0;
}

.consent-viewer-frame{
  width:100%;
  height:min(78vh,820px);
  border:0;
  background:#fff;
}

.consent-forms-modal{
  max-width:1120px;
  width:min(96vw,1120px);
}

.consent-forms-body{
  display:grid;
  grid-template-columns:280px minmax(0,1fr);
  gap:18px;
  align-items:start;
}

.consent-forms-side{
  border-right:1px solid var(--border);
  padding-right:16px;
}

.consent-forms-list{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-top:12px;
}

.consent-form-item{
  width:100%;
  border:1px solid var(--border);
  background:#fff;
  border-radius:10px;
  padding:10px 12px;
  text-align:left;
  cursor:pointer;
}

.consent-form-item.active{
  border-color:var(--teal);
  box-shadow:0 0 0 2px rgba(10,124,124,0.12);
}

.consent-form-item-title{
  display:block;
  font-size:13px;
  font-weight:700;
  color:var(--text);
}

.consent-form-item-sub{
  display:block;
  margin-top:4px;
  font-size:11px;
  color:var(--text3);
}

.consent-forms-editor{
  min-width:0;
}

.consent-forms-langbar{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.consent-forms-bodyta{
  min-height:280px;
  font-family:'JetBrains Mono',monospace;
  font-size:12px;
}

.consent-forms-help{
  margin-top:10px;
  font-size:12px;
  color:var(--text3);
}

@media (max-width: 860px){
  .consent-forms-body{
    grid-template-columns:1fr;
  }

  .consent-forms-side{
    border-right:0;
    padding-right:0;
    border-bottom:1px solid var(--border);
    padding-bottom:14px;
  }
}
.ops-actions-inline{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.ops-actions-inline .btn{min-width:0;padding:6px 10px;font-size:12px;line-height:1.2}

/* ── Reports page ────────────────────────────────────────────────── */
.rpt-row{
  display:flex;align-items:center;gap:16px;
  background:var(--card-bg,#fff);
  border:1px solid var(--border,#e2e8f0);
  border-radius:10px;padding:16px 18px;
  transition:box-shadow .15s;
}
.rpt-row:hover{box-shadow:0 2px 8px rgba(0,0,0,.07)}
.rpt-icon{
  width:42px;height:42px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;letter-spacing:.5px;
}
.rpt-meta{flex:1;min-width:0}
.rpt-name{font-size:14px;font-weight:600;color:var(--text,#1e293b);margin-bottom:3px}
.rpt-desc{font-size:12px;color:var(--text-muted,#64748b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rpt-status{min-width:120px;text-align:right;font-size:11px;flex-shrink:0}
.rpt-badge-idle{color:#94a3b8}
.rpt-badge-ready{
  display:inline-flex;align-items:center;gap:5px;
  background:#f0fdf4;color:#16a34a;
  border-radius:20px;padding:3px 10px;font-weight:600;font-size:11px;
}
.rpt-badge-loading{
  display:inline-flex;align-items:center;gap:6px;
  color:#0e7c6e;font-size:11px;font-weight:500;
}
.rpt-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.rpt-actions .btn-ghost{font-size:12px;padding:6px 12px;border:1px solid var(--border,#e2e8f0)}
.rpt-actions .btn-primary{font-size:12px;padding:6px 14px}
.rpt-regen{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:11px;padding:4px 6px;border-radius:4px;transition:color .15s}
.rpt-regen:hover{color:#0e7c6e}

/* ── Reports & Dashboard page (dark glassmorphism) ───────────────── */
.rdb-wrap{
  --rdb-bg:#0b1220;
  --rdb-card:rgba(255,255,255,0.055);
  --rdb-border:rgba(255,255,255,0.09);
  --rdb-text:#e9f1ff;
  --rdb-muted:#a9b9d6;
  --rdb-blue:#6fb4ff;
  --rdb-green:#5be2a7;
  --rdb-gold:#ffd87a;
  --rdb-red:#ff6b6b;
  --rdb-teal:#2dd4bf;
  --rdb-radius:20px;
  background:
    radial-gradient(circle at top right,rgba(79,141,255,.14),transparent 30%),
    radial-gradient(circle at left 60%,rgba(91,226,167,.08),transparent 24%),
    linear-gradient(180deg,#08101d 0%,#0c1527 50%,#0f1b32 100%);
  border-radius:16px;
  padding:28px 24px 40px;
  color:var(--rdb-text);
  font-family:inherit;
}

/* Header */
.rdb-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.rdb-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:5px 13px;border-radius:999px;margin-bottom:10px;
  border:1px solid rgba(111,180,255,.24);background:rgba(111,180,255,.08);
  color:#d7e9ff;font-size:11px;letter-spacing:.8px;font-weight:700;text-transform:uppercase;
}
.rdb-eyebrow::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--rdb-green);box-shadow:0 0 0 3px rgba(91,226,167,.18)}
.rdb-h1{font-size:26px;font-weight:900;color:#fff;letter-spacing:-.4px;margin-bottom:4px}
.rdb-sub{font-size:13px;color:var(--rdb-muted)}
.rdb-header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rdb-patient-box{
  display:flex;align-items:center;gap:8px;
  background:var(--rdb-card);border:1px solid var(--rdb-border);
  border-radius:12px;padding:8px 14px;min-width:220px;max-width:300px;
}
.rdb-select{
  flex:1;background:transparent;border:none;outline:none;
  color:var(--rdb-text);font-size:13px;font-weight:500;cursor:pointer;
}
.rdb-select option{background:#1a2540;color:#e9f1ff}
.rdb-btn-ghost{
  padding:8px 16px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  color:#d5e6ff;transition:.15s;
}
.rdb-btn-ghost:hover{background:rgba(255,255,255,.11);color:#fff}

/* KPI Row */
.rdb-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.rdb-kpi{
  background:var(--rdb-card);border:1px solid var(--rdb-border);
  border-radius:var(--rdb-radius);padding:18px 20px;position:relative;overflow:hidden;
}
.rdb-kpi::before{
  content:"";position:absolute;inset:-60px auto auto 60%;
  width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle,rgba(111,180,255,.1),transparent 65%);
  pointer-events:none;
}
.rdb-kpi.rdb-kpi-highlight{border-color:rgba(91,226,167,.22);background:rgba(91,226,167,.05)}
.rdb-kpi.rdb-kpi-warn{border-color:rgba(255,215,122,.2);background:rgba(255,215,122,.04)}
.rdb-k-icon{font-size:20px;margin-bottom:9px}
.rdb-k-label{font-size:11px;color:var(--rdb-muted);text-transform:uppercase;letter-spacing:.7px;font-weight:700;margin-bottom:5px}
.rdb-k-value{font-size:26px;font-weight:900;color:#fff;line-height:1;margin-bottom:5px}
.rdb-k-delta{font-size:12px;font-weight:700;color:var(--rdb-muted)}
.rdb-k-delta.up{color:var(--rdb-green)}
.rdb-k-delta.warn{color:var(--rdb-gold)}
.rdb-k-delta.down{color:var(--rdb-red)}

/* Main Grid */
.rdb-main-grid{display:grid;grid-template-columns:1fr 320px;gap:18px}
.rdb-panel{
  background:var(--rdb-card);border:1px solid var(--rdb-border);
  border-radius:var(--rdb-radius);padding:22px 24px;
}
.rdb-panel-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:18px;gap:12px}
.rdb-panel-title{font-size:15px;font-weight:800;color:#fff}
.rdb-panel-sub{font-size:12px;color:var(--rdb-muted);margin-top:3px}
.rdb-badge{
  flex-shrink:0;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;
  background:rgba(111,180,255,.12);border:1px solid rgba(111,180,255,.2);color:var(--rdb-blue);
}
.rdb-badge.rdb-badge-green{background:rgba(91,226,167,.12);border-color:rgba(91,226,167,.2);color:var(--rdb-green)}

/* Report Rows */
.rdb-rpt-list{display:flex;flex-direction:column;gap:8px}
.rdb-rpt-row{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);
  border-radius:14px;padding:14px 16px;transition:background .15s,border-color .15s;
}
.rdb-rpt-row:hover{background:rgba(255,255,255,.055);border-color:rgba(255,255,255,.1)}
.rdb-rpt-icon{
  width:40px;height:40px;border-radius:12px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;letter-spacing:.5px;
}
.rdb-rpt-meta{flex:1;min-width:0}
.rdb-rpt-name{font-size:13px;font-weight:700;color:#fff;margin-bottom:3px}
.rdb-rpt-desc{font-size:11px;color:var(--rdb-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rdb-rpt-status{min-width:110px;text-align:right;font-size:11px;flex-shrink:0}
.rdb-rpt-actions{display:flex;align-items:center;gap:7px;flex-shrink:0}

/* Status badges */
.rdb-badge-idle{color:#94a3b8;font-size:11px}
.rdb-badge-ready{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(91,226,167,.12);color:var(--rdb-green);
  border-radius:20px;padding:3px 9px;font-weight:700;font-size:11px;
  border:1px solid rgba(91,226,167,.2);
}
.rdb-badge-loading{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--rdb-teal);font-size:11px;font-weight:500;
}
.rdb-badge-fail{
  display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,107,107,.1);color:var(--rdb-red);
  border-radius:20px;padding:3px 9px;font-weight:700;font-size:11px;
}

/* Action buttons */
.rdb-gen-btn{
  padding:6px 14px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;
  background:linear-gradient(135deg,#6fb4ff,#4b8fe8);color:#fff;border:none;
  transition:.15s;white-space:nowrap;
}
.rdb-gen-btn:disabled{opacity:.45;cursor:not-allowed}
.rdb-gen-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(75,143,232,.3)}
.rdb-gen-btn.rdb-gen-regen{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:#d5e6ff}
.rdb-gen-btn.rdb-gen-regen:not(:disabled):hover{background:rgba(255,255,255,.12)}
.rdb-view-btn{
  padding:6px 14px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;
  background:rgba(91,226,167,.12);border:1px solid rgba(91,226,167,.2);color:var(--rdb-green);
  text-decoration:none;white-space:nowrap;transition:.15s;
}
.rdb-view-btn:hover{background:rgba(91,226,167,.18)}

/* Today's schedule */
.rdb-appt-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}
.rdb-appt-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:12px;
  background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.05);
  transition:background .15s;
}
.rdb-appt-item:hover{background:rgba(255,255,255,.055)}
.rdb-appt-time{font-size:12px;font-weight:700;color:var(--rdb-blue);flex-shrink:0;min-width:46px}
.rdb-appt-info{flex:1;min-width:0}
.rdb-appt-name{font-size:13px;font-weight:700;color:#fff}
.rdb-appt-type{font-size:11px;color:var(--rdb-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rdb-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.rdb-dot.rdb-dot-active{background:var(--rdb-green);box-shadow:0 0 0 3px rgba(91,226,167,.2)}
.rdb-dot.rdb-dot-done{background:var(--rdb-muted)}
.rdb-dot.rdb-dot-cancel{background:var(--rdb-red)}

/* Empty / loading states */
.rdb-loading{display:flex;align-items:center;gap:8px;color:var(--rdb-muted);font-size:13px;padding:16px 0}
.rdb-empty{color:var(--rdb-muted);font-size:13px;padding:16px 0;text-align:center}
.rdb-spinner{
  width:14px;height:14px;border-radius:50%;flex-shrink:0;
  border:2px solid rgba(255,255,255,.12);border-top-color:var(--rdb-blue);
  animation:rdb-spin .8s linear infinite;display:inline-block;
}
@keyframes rdb-spin{to{transform:rotate(360deg)}}

/* Responsive */
@media(max-width:900px){
  .rdb-kpi-row{grid-template-columns:repeat(2,1fr)}
  .rdb-main-grid{grid-template-columns:1fr}
}
