:root{
  --logo-green:#8BCAC0;--primary:#163F36;--secondary:#245B4F;--accent:#8BCAC0;
  --danger:#163F36;--warning:#245B4F;--success:#163F36;
  --bg:#8BCAC0;--card:#FFFFFF;--text:#123B33;--muted:#315C54;
  --border:#8BCAC0;--shadow:none;
  --radius:8px;--radius-sm:8px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}

/* HEADER */
.header{
  background:#FFFFFF;
  padding:24px 40px;color:var(--text);
  display:flex;align-items:center;justify-content:space-between;
  border-bottom:4px solid var(--accent);
  box-shadow:none;
}
.header-left{display:flex;align-items:center;gap:16px;}
.header-icon{width:58px;height:58px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.header-icon svg{display:block;width:58px;height:58px;}
.header-title{font-size:26px;font-weight:800;letter-spacing:0;}
.header-sub{font-size:13px;opacity:.75;margin-top:2px;}
.header-actions{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:8px;}
.header-actions-row{display:flex;align-items:center;gap:10px;}
.header-badge{background:var(--accent);border:1px solid var(--primary);
  color:var(--primary);padding:6px 16px;border-radius:8px;font-size:12px;font-weight:700;}
.header-time{font-size:12px;opacity:.75;margin-top:4px;text-align:right;color:var(--primary);}
.download-report{
  display:inline-flex;align-items:center;gap:7px;padding:7px 16px;
  background:#163F36;border:1.5px solid #163F36;color:#FFFFFF;
  border-radius:8px;font-size:12px;font-weight:600;text-decoration:none;
  transition:background .2s,transform .1s;white-space:nowrap;
}
.download-report:hover{background:#245B4F;transform:translateY(-1px);}

/* STICKY TOP WRAPPER */
.sticky-top{position:sticky;top:0;z-index:100;}

/* FILTER BAR */
.filter-bar{
  background:#FFFFFF;padding:16px 40px;border-bottom:2px solid var(--border);
  display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;
  box-shadow:none;
}
.filter-controls{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(138px,158px));
  gap:10px;align-items:center;min-width:0;
}
.filter-label{font-size:13px;font-weight:600;color:var(--muted);white-space:nowrap;}
.filter-select{
  padding:8px 14px;border:1.5px solid var(--border);border-radius:8px;
  font-size:13px;color:var(--text);background:#FFFFFF;cursor:pointer;
  transition:border-color .2s;width:100%;min-width:0;height:36px;
  appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237F8C8D' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:30px;
}
.filter-select:focus{outline:none;border-color:var(--primary);}
.filter-reset{padding:8px 20px;background:var(--primary);color:#FFFFFF;border:none;
  border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;
  transition:background .2s,transform .1s;height:36px;white-space:nowrap;}
.filter-reset:hover{background:var(--secondary);transform:translateY(-1px);}
.filter-divider{width:1px;height:28px;background:var(--border);}

/* MAIN CONTENT */
.main{padding:14px 40px 28px;max-width:1600px;margin:0 auto;}

/* RAG LEGEND — sits in the gap above the KPI grid */
.rag-legend{
  display:flex;align-items:center;gap:16px;
  margin-bottom:4px;padding:2px 4px;
}
.rag-legend-label{
  font-size:10px;font-weight:700;color:var(--muted);
  text-transform:uppercase;letter-spacing:.6px;margin-right:4px;
}
.rag-legend-item{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10.5px;font-weight:700;letter-spacing:.2px;
  padding:3px 10px;border-radius:20px;color:#fff;
}
.rag-legend-item.rag-green{background:#059669;}
.rag-legend-item.rag-amber{background:#D97706;}
.rag-legend-item.rag-red  {background:#DC2626;}
.rag-legend-range{font-size:9.5px;font-weight:600;opacity:.85;}

/* KPI CARDS */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:18px;}
.kpi-card{
  background:var(--card);border-radius:var(--radius);padding:10px 14px;
  box-shadow:var(--shadow);border:2px solid var(--border);border-left:6px solid var(--primary);
  transition:transform .2s;cursor:default;
  display:flex;align-items:center;gap:10px;min-width:0;overflow:hidden;
}
.kpi-card:hover{transform:translateY(-3px);box-shadow:none;}
.kpi-card.blue{border-left-color:var(--accent);}
.kpi-card.red{border-left-color:var(--danger);}
.kpi-card.orange{border-left-color:var(--warning);}
.kpi-card.green{border-left-color:var(--success);}
.kpi-card.purple{border-left-color:var(--primary);}
.kpi-card.teal{border-left-color:var(--primary);}
.kpi-icon{
  width:34px;height:34px;border-radius:8px;display:flex;align-items:center;
  justify-content:center;font-size:14px;flex-shrink:0;
}
.kpi-icon.blue,.kpi-icon.red,.kpi-icon.orange,.kpi-icon.green,.kpi-icon.purple,.kpi-icon.teal{background:var(--accent);color:var(--primary);}
.kpi-metric-row{display:flex;align-items:baseline;gap:6px;min-width:0;flex-wrap:wrap;}
.kpi-value{font-size:20px;font-weight:800;line-height:1;letter-spacing:0;white-space:nowrap;}
.kpi-percent{
  display:inline-flex;align-items:center;justify-content:center;
  padding:2px 6px;border-radius:6px;background:#163F36;color:#FFFFFF;
  border:1px solid #163F36;font-size:11px;font-weight:900;line-height:1;
  box-shadow:0 0 0 2px rgba(139,202,192,.35);
  transition:background .35s ease,border-color .35s ease,box-shadow .35s ease;
}
.kpi-percent.rag-green{background:#059669;border-color:#059669;box-shadow:0 0 0 2px rgba(5,150,105,.25);}
.kpi-percent.rag-amber{background:#D97706;border-color:#D97706;box-shadow:0 0 0 2px rgba(217,119,6,.25);}
.kpi-percent.rag-red  {background:#DC2626;border-color:#DC2626;box-shadow:0 0 0 2px rgba(220,38,38,.25);}
.kpi-value.red{color:var(--danger);}
.kpi-value.orange{color:var(--warning);}
.kpi-value.green{color:var(--success);}
.kpi-value.blue{color:var(--accent);}
.kpi-value.purple{color:var(--primary);}
.kpi-value.teal{color:var(--primary);}
.kpi-label{font-size:10.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;white-space:normal;overflow:hidden;}
.kpi-thresh-badge{display:inline-block;padding:1px 4px;border-radius:4px;font-size:9px;font-weight:700;background:var(--border);color:var(--primary);vertical-align:middle;letter-spacing:.3px;white-space:nowrap;margin-left:3px;}
.kpi-sub{font-size:10px;color:var(--muted);margin-top:1px;white-space:normal;overflow:hidden;}
.kpi-card > div:not(.kpi-icon){min-width:0;}

/* SECTION TITLE */
.section-title{font-size:18px;font-weight:700;color:var(--primary);margin-bottom:16px;
  display:flex;align-items:center;gap:8px;}
.section-title::before{content:'';width:4px;height:20px;background:var(--accent);border-radius:2px;display:inline-block;}

/* CHART GRID */
.chart-grid{display:grid;gap:20px;margin-bottom:28px;}
.chart-grid.cols-2{grid-template-columns:1fr 1fr;}
.chart-grid.cols-3{grid-template-columns:1fr 1fr 1fr;}
.chart-grid.cols-1{grid-template-columns:1fr;}
.chart-plot{width:100%;}
.chart-plot-300{height:300px;}
.chart-plot-320{height:320px;}
.chart-plot-340{height:340px;}
.chart-plot-360{height:360px;}
.chart-plot-400{height:400px;}
.chart-plot-420{height:420px;}
.chart-card{
  background:var(--card);border-radius:var(--radius);padding:20px 20px 16px;
  box-shadow:var(--shadow);border:2px solid var(--border);transition:none;
}
.chart-card:hover{box-shadow:none;}
.chart-title{font-size:14px;font-weight:700;color:var(--primary);margin-bottom:4px;}
.chart-sub{font-size:12px;color:var(--muted);margin-bottom:12px;}

/* RISK TABLE */
.risk-section{background:var(--card);border-radius:var(--radius);padding:24px;
  box-shadow:var(--shadow);border:2px solid var(--border);margin-bottom:28px;}
.risk-controls{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap;}
.risk-search{
  padding:8px 14px;border:1.5px solid var(--border);border-radius:8px;
  font-size:13px;width:min(460px,100%);transition:border-color .2s;
}
.risk-search:focus{outline:none;border-color:var(--accent);}
.risk-filter-btn{
  padding:7px 16px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;
  border:1.5px solid var(--border);background:#FFFFFF;color:var(--text);transition:all .2s;
}
.risk-filter-btn.active{background:var(--primary);color:#FFFFFF;border-color:var(--primary);}
.risk-filter-btn:hover:not(.active){border-color:var(--primary);color:var(--primary);}
.risk-count{margin-left:auto;font-size:13px;color:var(--muted);}
table{width:100%;border-collapse:collapse;}
thead th{
  padding:10px 16px;text-align:left;font-size:11px;font-weight:700;
  color:var(--muted);text-transform:uppercase;letter-spacing:.5px;
  border-bottom:2px solid var(--border);background:#FFFFFF;
}
thead th:first-child{border-radius:8px 0 0 0;}
thead th:last-child{border-radius:0 8px 0 0;}
tbody tr{transition:background .15s;}
tbody tr:hover{background:var(--accent);}
tbody td{padding:11px 16px;font-size:13px;border-bottom:1px solid var(--border);}
.summary-table-wrap{max-height:520px;overflow:auto;border:2px solid var(--border);border-radius:8px;}
.summary-table th,.summary-table td{font-size:12px;vertical-align:top;}
.summary-table thead th{position:sticky;top:0;z-index:2;background:#f2faf8;box-shadow:0 2px 0 var(--border);}
.summary-table td:nth-child(1){font-weight:700;color:var(--primary);white-space:nowrap;}
.summary-table td:nth-child(5),.summary-table td:nth-child(7){max-width:280px;line-height:1.35;}
.summary-note{font-size:12px;color:var(--muted);margin-bottom:12px;}
.thresh-green{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:700;color:#1a7a4a;background:#e6f9f0;border:1px solid #a8e6c8;}
.thresh-amber{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:700;color:#7a4f00;background:#fff6e0;border:1px solid #ffd580;}
.thresh-red{display:inline-block;padding:2px 8px;border-radius:4px;font-weight:700;color:#b02020;background:#fde8e6;border:1px solid #f5a9a4;}
.thresh-legend{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  padding:10px 14px;margin-bottom:12px;
  background:#f8fdfc;border:1px solid var(--border);border-radius:7px;
  font-size:11px;
}
.thresh-legend-label{font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-right:4px;white-space:nowrap;}
.thresh-legend-group{display:flex;align-items:center;gap:5px;flex-wrap:nowrap;}
.thresh-legend-title{font-weight:700;color:var(--primary);white-space:nowrap;margin-right:2px;}
.thresh-legend-sep{width:1px;height:18px;background:var(--border);margin:0 4px;flex-shrink:0;}
.chart-plot-380{height:380px;}

.badge-new{
  padding:2px 8px;border-radius:12px;font-size:10px;font-weight:700;
  display:inline-block;background:#163F36;color:#FFFFFF;vertical-align:middle;
  margin-left:6px;letter-spacing:.3px;
}

/* CROSS-INSIGHT CALLOUT GRID */
.insight-callout-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-bottom:28px;}
.insight-callout{
  background:#FFFFFF;border:2px solid var(--border);border-radius:var(--radius-sm);
  padding:18px 20px;position:relative;overflow:hidden;
}
.insight-callout::before{
  content:'';position:absolute;top:0;left:0;width:4px;height:100%;
  background:var(--primary);border-radius:2px 0 0 2px;
}
.insight-callout.alert::before{background:#c0392b;}
.insight-callout.warn::before{background:#e67e22;}
.insight-callout.good::before{background:#27ae60;}
.callout-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:6px;}
.callout-value{font-size:24px;font-weight:900;color:var(--primary);line-height:1;}
.callout-value.alert{color:#c0392b;}
.callout-value.warn{color:#e67e22;}
.callout-value.good{color:#27ae60;}
.callout-body{font-size:12px;color:var(--text);margin-top:6px;line-height:1.5;}
.callout-sub{font-size:11px;color:var(--muted);margin-top:4px;}

/* DISEASE DETAIL TABLE */
.pct-above{color:#c0392b;font-weight:700;}
.pct-below{color:#27ae60;font-weight:700;}
.pct-neutral{color:var(--muted);}

.badge{
  padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;
  display:inline-block;
}
.badge.low,.badge.medium,.badge.high,.badge.critical,.badge.extreme{background:var(--accent);color:var(--primary);border:1px solid var(--primary);}
.progress-bar{height:6px;background:#FFFFFF;border:1px solid var(--border);border-radius:3px;overflow:hidden;min-width:80px;}
.progress-fill{height:100%;border-radius:3px;background:var(--primary);}
.table-scroll{overflow-x:auto;max-height:520px;overflow-y:auto;border:2px solid var(--border);border-radius:8px;}
#riskTable thead th{position:sticky;top:0;z-index:2;background:#f2faf8;box-shadow:0 2px 0 var(--border);}
.sortable{cursor:pointer;}
.risk-ns-cell{font-weight:700;}
.risk-facility-cell{font-size:12px;}

/* INSIGHT CARDS */
.insight-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:28px;}
.insight-card{
  background:#FFFFFF;border:2px solid var(--border);border-left:6px solid var(--primary);
  border-radius:var(--radius-sm);padding:14px 16px;color:var(--text);min-width:0;overflow:hidden;
}
.insight-label{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;white-space:normal;overflow:hidden;}
.insight-value{font-size:18px;font-weight:800;margin:4px 0;color:var(--primary);white-space:normal;overflow:hidden;}
.insight-desc{font-size:11px;color:var(--muted);white-space:normal;overflow:hidden;}

/* FOOTER */
.footer{text-align:center;padding:20px;font-size:12px;color:var(--muted);
  border-top:1px solid var(--border);margin-top:20px;}

/* RESPONSIVE */
@media(max-width:900px){
  .chart-grid.cols-2,.chart-grid.cols-3{grid-template-columns:1fr;}
  .kpi-grid{grid-template-columns:repeat(3,1fr);}
  .insight-grid{grid-template-columns:repeat(3,1fr);}
  .header{flex-direction:column;align-items:flex-start;gap:8px;padding:16px 20px;}
  .main{padding:16px 20px;}
  .filter-bar{grid-template-columns:1fr;padding:12px 20px;align-items:stretch;}
  .filter-controls{grid-template-columns:repeat(auto-fit,minmax(138px,1fr));}
  .filter-reset{justify-self:start;}
}
@media(max-width:600px){
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
  .insight-grid{grid-template-columns:repeat(2,1fr);}
}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px;height:6px;}
::-webkit-scrollbar-track{background:#FFFFFF;}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--primary);}

[data-tooltip]{position:relative;}
[data-tooltip]::after{
  content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;
  transform:translateX(-50%);background:var(--primary);color:#FFFFFF;padding:6px 10px;
  border-radius:6px;font-size:11px;white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity .2s;z-index:999;
}
[data-tooltip]:hover::after{opacity:1;}

/* ── ML No-Show Predictor Button ─────────────────────────── */
.ml-predictor-btn{
  display:inline-flex;align-items:center;gap:7px;padding:7px 16px;
  background:#4B3B8C;border:1.5px solid #4B3B8C;color:#FFFFFF;
  border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;
  transition:background .2s,transform .1s;white-space:nowrap;
  font-family:inherit;
}
.ml-predictor-btn:hover{background:#3A2D6E;transform:translateY(-1px);}
.ml-predictor-btn .ml-btn-dot{
  width:7px;height:7px;border-radius:50%;background:#A78BFA;
  animation:ml-pulse 1.8s ease-in-out infinite;
  flex-shrink:0;
}
@keyframes ml-pulse{
  0%,100%{opacity:1;transform:scale(1);}
  50%     {opacity:.5;transform:scale(1.4);}
}
@keyframes ml-spin{
  from{transform:rotate(0deg);}
  to  {transform:rotate(360deg);}
}

/* ── ML Modal Overlay ────────────────────────────────────── */
.ml-modal-overlay{
  position:fixed;inset:0;
  background:rgba(18,59,51,.55);
  backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
  display:flex;align-items:flex-start;justify-content:center;
  z-index:9000;overflow-y:auto;padding:32px 16px 48px;
}
.ml-modal-box{
  background:#FFFFFF;border-radius:16px;width:100%;max-width:920px;
  box-shadow:0 24px 64px rgba(22,63,54,.28),0 4px 16px rgba(22,63,54,.12);
  animation:ml-modal-in .28s cubic-bezier(.22,.68,0,1.2);
  overflow:hidden;
}
@keyframes ml-modal-in{
  from{transform:translateY(16px) scale(.98);opacity:0;}
  to  {transform:translateY(0)    scale(1);  opacity:1;}
}

/* Modal header band */
.ml-modal-header{
  background:linear-gradient(135deg,#4B3B8C 0%,#2D1F6E 100%);
  padding:20px 28px;
  display:flex;align-items:center;justify-content:space-between;
}
.ml-modal-title{
  display:flex;align-items:center;gap:12px;
  font-size:18px;font-weight:700;color:#FFFFFF;
}
.ml-modal-title-icon{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:17px;flex-shrink:0;
}
.ml-modal-subtitle{font-size:12px;color:rgba(255,255,255,.65);margin-top:2px;}
.ml-modal-close{
  background:rgba(255,255,255,.15);border:none;color:#FFFFFF;
  width:32px;height:32px;border-radius:50%;font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .18s;line-height:1;flex-shrink:0;
}
.ml-modal-close:hover{background:rgba(255,255,255,.28);}

/* Modal body */
.ml-modal-body{padding:28px;}

/* Loading / error states */
.ml-state-box{
  text-align:center;padding:48px 24px;
  font-size:14px;color:var(--muted);
}
.ml-state-box .ml-state-icon{font-size:40px;margin-bottom:12px;}
.ml-state-box h3{font-size:16px;font-weight:700;color:var(--primary);margin-bottom:8px;}
.ml-state-box code{
  background:#f3f4f6;padding:10px 16px;border-radius:8px;
  font-size:13px;display:inline-block;margin-top:8px;
  border:1px solid #e5e7eb;color:#374151;
}

/* Model KPI cards */
.ml-kpi-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px;}
.ml-kpi{
  background:var(--bg);border-radius:10px;padding:16px 18px;
  border:1.5px solid var(--border);
}
.ml-kpi-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.ml-kpi-value{font-size:26px;font-weight:800;color:var(--primary);}
.ml-kpi-sub{font-size:11px;color:var(--muted);margin-top:3px;}
.ml-kpi.purple .ml-kpi-value{color:#4B3B8C;}
.ml-kpi.amber  .ml-kpi-value{color:#92400E;}
.ml-kpi.red    .ml-kpi-value{color:#991B1B;}
.ml-kpi.red{border-left:3px solid #DC2626;}

/* Future-appointments banner */
.ml-banner{
  background:#EDE9FE;border:1.5px solid #C4B5FD;
  border-radius:10px;padding:12px 16px;margin-bottom:20px;
  display:flex;align-items:flex-start;gap:10px;font-size:12.5px;color:#3730A3;
}
.ml-banner-icon{font-size:16px;flex-shrink:0;margin-top:1px;}
.ml-banner strong{color:#2E1065;}

/* Accuracy metrics grid — 3-column card layout */
.ml-metrics-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:4px;
}
.ml-metric-card{
  background:var(--bg);border:1.5px solid var(--border);border-radius:10px;
  padding:14px 16px;
}
.ml-metric-value{font-size:22px;font-weight:800;color:var(--primary);margin-bottom:2px;}
.ml-metric-name{font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:.5px;color:var(--muted);margin-bottom:5px;}
.ml-metric-desc{font-size:11px;color:var(--muted);line-height:1.5;}
.ml-metric-card.purple .ml-metric-value{color:#4B3B8C;}
.ml-metric-card.teal   .ml-metric-value{color:#0F766E;}
.ml-metric-card.amber  .ml-metric-value{color:#92400E;}
.ml-metric-card.green  .ml-metric-value{color:#166534;}
.ml-metric-card.blue   .ml-metric-value{color:#1D4ED8;}

/* Section headings inside modal */
.ml-section-title{
  font-size:13px;font-weight:700;color:var(--primary);
  text-transform:uppercase;letter-spacing:.6px;
  margin-bottom:14px;margin-top:22px;
  display:flex;align-items:center;gap:8px;
}
.ml-section-title::after{
  content:'';flex:1;height:1px;background:var(--border);
}

/* Metric definitions grid */
.ml-definitions-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:14px;
  margin-bottom:6px;
}
.ml-def-card{
  background:#fafefe;border:1.5px solid #d1ece9;
  border-radius:10px;padding:16px 18px;
}
.ml-def-title{
  font-size:13px;font-weight:700;color:var(--primary);
  margin-bottom:8px;display:flex;align-items:center;gap:6px;
}
.ml-def-body{
  font-size:12.5px;line-height:1.65;color:#374151;
}
.ml-def-body em{color:var(--muted);}

/* Feature importance bars */
.ml-feat-list{display:flex;flex-direction:column;gap:8px;}
.ml-feat-row{display:grid;grid-template-columns:180px 1fr 48px;align-items:center;gap:10px;}
.ml-feat-name{font-size:12px;color:var(--text);font-weight:500;text-align:right;}
.ml-feat-bar-track{background:#e4f2f0;border-radius:6px;height:12px;overflow:hidden;}
.ml-feat-bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,#8BCAC0,#4B3B8C);}
.ml-feat-score{font-size:11px;color:var(--muted);font-weight:600;}

/* Predictions table */
.ml-table-wrap{overflow-x:auto;border-radius:10px;border:1.5px solid var(--border);}
.ml-table{width:100%;border-collapse:collapse;font-size:12.5px;}
.ml-table th{
  background:#f0faf8;padding:10px 12px;text-align:left;
  font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;
  border-bottom:1.5px solid var(--border);white-space:nowrap;
}
.ml-table td{
  padding:9px 12px;border-bottom:1px solid #f3f4f6;vertical-align:middle;
}
.ml-table tr:last-child td{border-bottom:none;}
.ml-table tr:hover td{background:#f8fcfb;}
.ml-prob-badge{
  display:inline-block;padding:3px 9px;border-radius:20px;
  font-size:12px;font-weight:700;
}
.ml-prob-badge.very-high{background:#EDE9FE;color:#4B3B8C;}
.ml-prob-badge.high     {background:#FEF3C7;color:#92400E;}
.ml-prob-badge.medium   {background:#DCFCE7;color:#166534;}
.ml-prob-badge.low      {background:#F3F4F6;color:#6B7280;}
.ml-actual-hit{color:#163F36;font-weight:700;}

/* Info footer inside modal */
.ml-info-box{
  background:#f0faf8;border:1.5px solid var(--border);border-radius:10px;
  padding:14px 18px;margin-top:20px;font-size:12px;color:var(--muted);line-height:1.7;
}
.ml-info-box strong{color:var(--primary);}

@media(max-width:680px){
  .ml-kpi-row{grid-template-columns:repeat(2,1fr);}
  .ml-metrics-grid{grid-template-columns:repeat(2,1fr);}
  .ml-feat-row{grid-template-columns:120px 1fr 40px;}
  .ml-modal-body{padding:18px;}
}
