:root{
  --bg:#f4f7fb;
  --surface:#ffffff;
  --surface-2:#f8fbff;
  --text:#0f172a;
  --muted:#667085;
  --line:#e6ebf3;
  --line-strong:#d9e2ef;
  --primary:#2563eb;
  --primary-2:#1d4ed8;
  --primary-soft:#eff6ff;
  --success:#16a34a;
  --success-soft:#ecfdf3;
  --warning:#f59e0b;
  --warning-soft:#fff7ed;
  --danger:#ef4444;
  --danger-soft:#fef2f2;
  --purple:#8b5cf6;
  --purple-soft:#f5f3ff;
  --cyan:#0891b2;
  --cyan-soft:#ecfeff;
  --amber:#d97706;
  --amber-soft:#fff7ed;
  --shadow:0 20px 50px rgba(15,23,42,.06);
  --shadow-soft:0 10px 24px rgba(15,23,42,.04);
  --radius:22px;
  --radius-sm:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.45}
a{color:var(--primary);text-decoration:none}
button,input,select,textarea{font:inherit}
kbd{border:1px solid var(--line-strong);background:#fff;border-radius:10px;padding:4px 8px;color:#475467;font-size:12px;box-shadow:var(--shadow-soft)}
code{display:block;background:#0f172a;color:#dbeafe;padding:16px;border-radius:16px;white-space:pre-wrap;word-break:break-word;line-height:1.5}

.app-shell{display:grid;grid-template-columns:220px minmax(0,1fr);min-height:100vh}
.sidebar{background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-right:1px solid var(--line);padding:18px 16px;display:flex;flex-direction:column;gap:20px;position:sticky;top:0;height:100vh}
.brand{display:flex;gap:12px;align-items:center;padding:6px 6px 12px}
.brand-badge{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#7c3aed,#2563eb);color:#fff;font-weight:800;box-shadow:0 12px 26px rgba(37,99,235,.25)}
.brand strong{display:block;font-size:16px}
.brand small{display:block;margin-top:2px;color:var(--muted)}
.nav{display:grid;gap:6px}
.nav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:14px;color:#243248;font-weight:600;transition:.18s ease;background:transparent}
.nav a:hover{background:var(--primary-soft);color:var(--primary)}
.nav a.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 10px 24px rgba(37,99,235,.25)}
.nav-icon{width:20px;text-align:center;font-size:13px;opacity:.85}
.sidebar-footer{margin-top:auto;border-top:1px solid var(--line);padding-top:16px;display:grid;gap:14px}
.user-chip{display:flex;align-items:center;gap:10px}
.user-avatar{width:34px;height:34px;border-radius:999px;background:#dbeafe;color:var(--primary);display:grid;place-items:center;font-weight:800;font-size:12px}
.progress-stack{display:grid;gap:8px}
.progress-meta{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:13px}
.progress-bar{height:10px;border-radius:999px;background:#e8eef8;overflow:hidden}
.progress-bar.slim{height:8px}
.progress-bar span{display:block;height:100%;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--primary-2))}
.logout-link{font-weight:700;color:var(--primary)}

.main{padding:22px 24px 28px;min-width:0}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:18px}
.topbar h1{margin:0;font-size:18px;display:none}
.topbar p{display:none}
.topbar-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;width:100%;justify-content:flex-end}
.search-wrap{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:0 12px;min-width:min(520px,100%);height:48px;box-shadow:var(--shadow-soft)}
.search-wrap span{color:#98a2b3}
.search-wrap input{border:0;outline:none;background:transparent;flex:1;padding:0;color:var(--text)}
.search{border:0;outline:none;background:transparent}
.top-pill,.user-pill{height:38px;padding:0 14px;border-radius:12px;border:1px solid var(--line);background:var(--surface);display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow-soft);font-weight:700;color:#334155}
.user-pill span{color:#94a3b8}
.dot-indicator{width:8px;height:8px;border-radius:999px;background:var(--danger);display:inline-block}

.page-intro{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}
.page-intro h2{margin:0;font-size:24px;line-height:1.15}
.page-intro p{margin:8px 0 0;color:var(--muted)}
.page-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}

.grid{display:grid;gap:18px}
.metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.split-layout{display:grid;grid-template-columns:minmax(0,1.65fr) minmax(320px,.85fr);gap:18px;align-items:start}
.two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.three-col{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.stack{display:grid;gap:12px}

.card{background:var(--surface);border:1px solid #edf1f7;border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card.soft{background:linear-gradient(180deg,#fff,#fbfdff)}
.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:14px}
.card-header h3,.card-header h2{margin:0;font-size:18px}
.card-subtitle{margin:6px 0 0;color:var(--muted);font-size:14px}

.metric-card{display:flex;gap:14px;align-items:center;background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:18px 18px;box-shadow:var(--shadow-soft)}
.metric-icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;font-size:22px;font-weight:800}
.icon-blue{background:#e8f0ff;color:var(--primary)}
.icon-green{background:#eafaf1;color:var(--success)}
.icon-orange{background:#fff4e8;color:var(--warning)}
.icon-purple{background:#f4ecff;color:var(--purple)}
.metric-title{font-size:14px;color:var(--muted);margin-bottom:2px}
.metric-value{font-size:18px;font-weight:800}
.metric-meta{font-size:13px;margin-top:4px}
.metric-meta.positive{color:var(--success)}
.metric-meta.negative{color:var(--danger)}
.metric-meta.neutral{color:var(--muted)}

.segmented{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.segmented a,.segmented button,.chip{display:inline-flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:9px 14px;font-weight:700;color:#334155}
.segmented .active,.chip.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-color:transparent}
.count-badge{min-width:22px;height:22px;padding:0 8px;border-radius:999px;background:#fff;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;font-size:12px;color:#64748b}
.segmented .active .count-badge{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.2);color:#fff}

.toolbar{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.toolbar-group{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.form-inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.input,.select,input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:14px;padding:12px 14px;color:var(--text)}
input:focus,select:focus,textarea:focus{outline:2px solid rgba(37,99,235,.13);outline-offset:0;border-color:#bdd0ff}
label{display:grid;gap:8px;font-weight:700;color:#334155}
textarea{min-height:112px;resize:vertical}

.btn-primary,.btn-secondary,.btn-danger,.btn-ghost,button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:12px 16px;font-weight:800;cursor:pointer;text-decoration:none;transition:.16s ease}
.btn-primary,button{border:0;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;box-shadow:0 10px 22px rgba(37,99,235,.22)}
.btn-secondary{border:1px solid var(--line);background:#fff;color:#334155}
.btn-secondary:hover{border-color:#cbd5e1;background:#f8fafc}
.btn-danger{border:1px solid #fecaca;background:#fff;color:#dc2626}
.btn-ghost{border:1px dashed var(--line-strong);background:#f8fafc;color:#475467}
.icon-only{width:42px;height:42px;padding:0}

.list-table{width:100%;border-collapse:separate;border-spacing:0}
.list-table thead th{font-size:13px;color:#64748b;font-weight:800;text-align:left;padding:13px 12px;border-bottom:1px solid var(--line)}
.list-table tbody td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px}
.list-table tbody tr:hover{background:#fbfdff}
.list-table tbody tr.selected{background:#eef4ff}
.list-table tbody tr:last-child td{border-bottom:0}
.table-footer{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap;padding-top:14px;color:var(--muted);font-size:13px}
.pagination{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.page-btn{width:30px;height:30px;border-radius:10px;border:1px solid var(--line);display:grid;place-items:center;background:#fff;color:#334155;font-weight:700}
.page-btn.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));border-color:transparent;color:#fff}

.person{display:flex;align-items:flex-start;gap:12px}
.avatar{width:36px;height:36px;border-radius:999px;display:grid;place-items:center;font-weight:800;font-size:12px;background:#e8f0ff;color:var(--primary);flex:0 0 36px}
.avatar.green{background:#eafaf1;color:var(--success)}
.avatar.orange{background:#fff4e8;color:var(--warning)}
.avatar.purple{background:#f5f3ff;color:var(--purple)}
.avatar.pink{background:#fdf2f8;color:#ec4899}
.avatar.cyan{background:#ecfeff;color:var(--cyan)}
.person strong{display:block}
.person small{display:block;color:var(--muted)}
.subject-cell strong{display:block}
.subject-cell small{display:block;color:var(--muted);margin-top:3px;max-width:340px}
.table-actions{display:flex;gap:10px;align-items:center;color:#64748b}
.table-actions a,.table-actions button{width:32px;height:32px;padding:0;border-radius:10px;border:1px solid var(--line);background:#fff;color:#64748b;box-shadow:none}
.checkbox{width:16px;height:16px;border-radius:6px;border:1px solid #cbd5e1;background:#fff}
.checkbox.is-selected{background:linear-gradient(135deg,var(--primary),var(--primary-2));border-color:transparent;position:relative}
.checkbox.is-selected::after{content:'✓';position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:11px;font-weight:800}

.badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-weight:800;font-size:12px;border:1px solid transparent;white-space:nowrap}
.badge.is-success{background:var(--success-soft);color:var(--success)}
.badge.is-warning{background:var(--warning-soft);color:var(--amber)}
.badge.is-danger{background:var(--danger-soft);color:var(--danger)}
.badge.is-neutral{background:#f3f4f6;color:#6b7280}
.badge.is-blue{background:#e8f0ff;color:var(--primary)}
.badge.is-green{background:#eafaf1;color:var(--success)}
.badge.is-purple{background:#f5f3ff;color:var(--purple)}
.badge.is-cyan{background:#ecfeff;color:var(--cyan)}
.badge.is-amber{background:#fff7ed;color:var(--amber)}

.detail-card{position:sticky;top:20px}
.detail-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:14px}
.detail-head .person{align-items:center}
.detail-section{display:grid;gap:12px;margin-bottom:16px}
.kv-grid{display:grid;grid-template-columns:1fr auto;gap:10px 16px;align-items:center}
.kv-grid .label{color:var(--muted);font-size:13px;font-weight:700}
.edit-link{font-size:13px;color:var(--primary);font-weight:700}
.response-box,.note-box{background:#f8fbff;border:1px solid var(--line);border-radius:16px;padding:16px}
.action-row{display:flex;gap:10px;flex-wrap:wrap}
.activity-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.activity-list li{display:grid;grid-template-columns:14px 1fr;gap:10px;align-items:start;color:#475467;font-size:14px}
.activity-list li::before{content:'';width:8px;height:8px;border-radius:999px;background:var(--primary);margin-top:6px}

.section-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.9fr);gap:18px}
.stats-band{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.empty-state{padding:28px;border:1px dashed var(--line-strong);border-radius:18px;background:#fbfdff;text-align:center;color:var(--muted)}
.empty-state strong{display:block;color:var(--text);font-size:16px;margin-bottom:6px}

.transcript-wrap{display:grid;gap:12px}
.transcript-bubble{max-width:86%;padding:14px 16px;border-radius:18px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-soft)}
.transcript-bubble.is-user{margin-left:auto;background:#edf4ff;border-color:#cfe0ff}
.transcript-bubble.is-bot{margin-right:auto}
.transcript-bubble strong{display:block;font-size:13px;color:#475467;margin-bottom:5px}
.transcript-bubble p{margin:0 0 6px}

.info-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:8px}
.info-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px}
.info-card .label{display:block;color:var(--muted);font-size:12px;margin-bottom:4px}

.code-card{display:grid;gap:10px}
.doc-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.doc-stat{padding:14px;border:1px solid var(--line);border-radius:16px;background:#fbfdff}
.doc-stat strong{display:block;font-size:28px;margin-bottom:4px}
.upload-list{display:grid;gap:10px}
.upload-item{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid var(--line)}
.upload-item:last-child{border-bottom:0}

.login-card{width:min(540px,92vw);margin:6vh auto;background:#fff;padding:34px;border-radius:28px;border:1px solid var(--line);box-shadow:var(--shadow)}
.login-card.wide{width:min(780px,96vw)}
.auth-shell,.install-shell{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-header{text-align:center;margin-bottom:20px}
.login-header h1{margin:0 0 8px}
.center{text-align:center}
.muted{color:var(--muted)}
.alert{padding:14px 16px;border-radius:14px;margin-bottom:16px;border:1px solid transparent}
.alert-success{background:#ecfdf3;border-color:#bbf7d0;color:#166534}
.alert-error{background:#fef2f2;border-color:#fecaca;color:#991b1b}

.mt-12{margin-top:12px}
.mt-16{margin-top:16px}
.mt-20{margin-top:20px}
.mt-24{margin-top:24px}

@media (max-width:1280px){
  .metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .split-layout,.section-grid{grid-template-columns:1fr}
  .detail-card{position:static}
}
@media (max-width:960px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;border-right:0;border-bottom:1px solid var(--line)}
  .topbar{flex-direction:column}
  .topbar-actions{justify-content:stretch}
  .search-wrap{min-width:100%}
  .info-cards,.doc-stats,.stats-band,.two-col,.three-col{grid-template-columns:1fr}
}
@media (max-width:640px){
  .main{padding:16px}
  .metrics-grid{grid-template-columns:1fr}
  .toolbar,.form-inline,.topbar-actions,.page-actions,.action-row{flex-direction:column;align-items:stretch}
  .table-footer{flex-direction:column;align-items:flex-start}
}


/* v3.1 utilities */
.pill{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);font-weight:800;font-size:12px;color:#475467}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table thead th{font-size:13px;color:#64748b;font-weight:800;text-align:left;padding:13px 12px;border-bottom:1px solid var(--line)}
.table tbody td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px}
.table tbody tr:last-child td{border-bottom:0}
.table tbody tr:hover{background:#fbfdff}
.form-two-col{grid-template-columns:repeat(2,minmax(0,1fr))}
.checkbox-row{display:flex;gap:10px;align-items:center;font-weight:600;color:#475467;background:#f8fafc;border:1px solid var(--line);padding:12px 14px;border-radius:14px}
.mini-card{background:#fbfdff;border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:var(--shadow-soft)}
.mini-card strong{display:block;margin-bottom:4px;font-size:15px}
.tab-strip{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.tab-btn{display:inline-flex;align-items:center;gap:8px;background:#f8fafc;border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-weight:700;color:#334155;cursor:pointer}
.tab-btn.active{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;border-color:transparent;box-shadow:0 10px 22px rgba(37,99,235,.18)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.settings-test-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.kv-list{display:grid;gap:12px}
.kv-item{display:flex;justify-content:space-between;gap:14px;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#fbfdff}
.kv-item .label{color:var(--muted);font-size:13px;font-weight:700}
.hero-callout{padding:18px;border:1px dashed var(--line-strong);border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f8fbff)}
.hero-callout h3{margin:0 0 8px}
.list-clean{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.list-clean li{display:flex;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid var(--line)}
.list-clean li:last-child{border-bottom:0}
.grid-2-1{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.9fr);gap:18px;align-items:start}
.card-footer-note{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);color:var(--muted);font-size:13px}
.metric-trend{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);font-size:12px;font-weight:800;color:#475467}
.overview-banner{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}
.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.summary-card{padding:16px;border-radius:18px;border:1px solid var(--line);background:#fbfdff}
.summary-card strong{display:block;font-size:28px;margin-bottom:4px}
@media (max-width:960px){.form-two-col,.summary-grid,.overview-banner,.grid-2-1{grid-template-columns:1fr}}


/* ===== v3.1 rebuild fallbacks and production-core components ===== */
.table{width:100%;border-collapse:separate;border-spacing:0}
.table thead th{font-size:13px;color:#64748b;font-weight:800;text-align:left;padding:13px 12px;border-bottom:1px solid var(--line)}
.table tbody td{padding:14px 12px;border-bottom:1px solid var(--line);vertical-align:top;font-size:14px}
.table tbody tr:last-child td{border-bottom:0}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:18px;box-shadow:var(--shadow-soft)}
.stat-label{display:block;color:var(--muted);font-weight:700;font-size:14px;margin-bottom:6px}
.stat-value{display:block;font-size:28px;font-weight:800;line-height:1.1}
.progress-wrap{display:grid;gap:10px;margin-bottom:14px}
.progress-head{display:flex;justify-content:space-between;gap:12px;align-items:center}
.chart-placeholder{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:12px;height:140px;padding:18px 10px;border:1px dashed var(--line-strong);border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f8fbff)}
.chart-placeholder .bar{border-radius:12px 12px 4px 4px;background:linear-gradient(180deg,#93c5fd,#2563eb);height:40px;opacity:.95}.chart-placeholder .bar.h45{height:45px}.chart-placeholder .bar.h60{height:60px}.chart-placeholder .bar.h70{height:70px}.chart-placeholder .bar.h85{height:85px}.chart-placeholder .bar.h90{height:90px}.chart-placeholder .bar.h95{height:95px}.chart-placeholder .bar.h110{height:110px}
.kpi-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.kpi-mini{padding:14px;border:1px solid var(--line);border-radius:16px;background:#fbfdff}.kpi-mini strong{display:block;font-size:24px}.kpi-mini span{color:var(--muted);font-size:13px}
.side-panel{display:grid;gap:14px}.status-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}.status-list li{display:flex;align-items:center;gap:10px}.status{width:10px;height:10px;border-radius:999px;display:inline-block}.status.ok{background:var(--success)}.status.warn{background:var(--warning)}
.metric-trend{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:#eef4ff;color:var(--primary);font-weight:800;font-size:12px}
.compact-card{padding:16px}.compact .card-header{margin-bottom:10px}.compact-card .metric-value{font-size:22px}
.icon-btn{width:40px;height:40px;padding:0;border-radius:12px;border:1px solid var(--line);background:#fff;color:#475467;display:grid;place-items:center;box-shadow:var(--shadow-soft)}
.cards-list{display:grid;gap:14px}.plan-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.plan-card{padding:18px;border:1px solid var(--line);border-radius:18px;background:#fff;box-shadow:var(--shadow-soft)}
.modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.42);display:none;align-items:center;justify-content:center;padding:20px;z-index:80}.modal-backdrop.is-open{display:flex}.modal-dialog,.modal-card{width:min(680px,96vw);background:#fff;border-radius:24px;padding:22px;border:1px solid var(--line);box-shadow:var(--shadow)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:18px}
.onboarding-item{padding:16px;border:1px solid var(--line);border-radius:18px;background:#fff}.header-actions{display:flex;gap:10px;flex-wrap:wrap}.mini-card-header{display:flex;justify-content:space-between;gap:10px;align-items:center}.top-align{align-items:flex-start}
.page-intro h2{font-size:22px}.card h2{font-size:18px}.card h3{font-size:16px;margin:0}
@media (max-width:1280px){.stats-grid,.plan-list{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-row{grid-template-columns:1fr}}
@media (max-width:960px){.stats-grid,.plan-list{grid-template-columns:1fr}.chart-placeholder{grid-template-columns:repeat(4,minmax(0,1fr));height:auto}.chart-placeholder .bar{min-height:42px}.modal-dialog,.modal-card{padding:18px}}


/* v3.1 additions */
.badge.is-job{background:#ecfeff;color:#0f766e}.badge.is-queued{background:#eef2ff;color:#4338ca}.badge.is-running{background:#fff7ed;color:#c2410c}.badge.is-done{background:#ecfdf5;color:#15803d}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}

.detail-banner{margin:0 0 14px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#f8fbff;color:#475467;font-size:13px}

.link-btn{border:0;background:transparent;color:var(--primary);font-weight:800;padding:0 4px;cursor:pointer}
.link-btn:hover{color:var(--primary-2)}



/* v3.1 rules ui */
.rules-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:18px}.rule-card{border:1px solid #e6ebf3;border-radius:18px;padding:16px;background:#fff}.rule-list{display:grid;gap:12px}.rule-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:14px 16px;border:1px solid #e8edf5;border-radius:16px;background:#fbfdff}.rule-row .meta{display:grid;gap:6px}.rule-row .actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.code-block{display:block;padding:12px 14px;border:1px solid #e6ebf3;border-radius:14px;background:#0f172a;color:#e2e8f0;font-size:12px;overflow:auto}.kv-stack{display:grid;gap:10px}.audit-timeline{display:grid;gap:12px}.audit-item{padding:12px 14px;border:1px solid #e6ebf3;border-radius:14px;background:#fff}.mt-12{margin-top:12px}@media (max-width:1180px){.rules-grid{grid-template-columns:1fr}}


/* ===== v3.5 UI cohesion suite ===== */
:root{--section-gap:18px;--inner-gap:14px;--panel-radius:24px;--panel-padding:20px;}
.main{padding:24px 24px 32px;}
.page-intro{margin-bottom:20px;}
.page-intro p{max-width:760px;}
.card.section-card{padding:var(--panel-padding);border-radius:var(--panel-radius);box-shadow:0 12px 30px rgba(15,23,42,.05);}
.card.section-card > .card-header{margin-bottom:16px;}
.card.section-card > .card-header h2{font-size:17px;}
.card.section-card > .card-header h3{font-size:16px;}
.metrics-grid{gap:18px;margin-bottom:2px;}
.metric-card{min-height:88px;border-radius:20px;padding:16px 18px;box-shadow:0 8px 20px rgba(15,23,42,.04);}
.metric-card > div:last-child{display:grid;gap:2px;}
.metric-value{font-size:30px;line-height:1.05;}
.metric-title{font-weight:700;color:#5b6b82;}
.metric-meta{font-size:12px;}
.summary-grid,.stats-grid,.doc-stats,.three-col,.two-col,.grid-2-1,.overview-banner,.rules-grid,.security-grid,.section-grid,.plan-grid{gap:18px;}
.summary-grid{margin-top:2px;margin-bottom:2px;}
.summary-card,.mini-card,.doc-stat,.kpi-mini,.rule-card,.plan-card-clean,.info-card{background:#fbfdff;border:1px solid var(--line);border-radius:18px;box-shadow:none;}
.summary-card{padding:18px;min-height:96px;display:flex;flex-direction:column;justify-content:center;}
.summary-card strong{font-size:30px;line-height:1;margin-bottom:8px;}
.hero-callout{padding:18px 18px 16px;border-style:solid;background:#fcfdff;min-height:180px;display:flex;flex-direction:column;gap:10px;}
.hero-callout .progress-bar{margin-top:4px;}
.kv-list{gap:10px;}
.kv-item{padding:12px 14px;border-radius:14px;background:#fcfdff;min-height:48px;}
.kv-item strong,.kv-item .badge{margin-left:auto;}
.stack-list{gap:12px;}
.alert-row{border-radius:16px;background:#fcfdff;}
.health-score{font-size:46px;}
.grid-2-1{align-items:start;}
.grid-2-1 > *{min-width:0;}
.table,.list-table{width:100%;}
.table thead th,.list-table thead th{padding:12px 12px;font-size:12px;text-transform:none;}
.table tbody td,.list-table tbody td{padding:14px 12px;}
.table tbody tr,.list-table tbody tr{background:#fff;}
.table tbody tr:hover,.list-table tbody tr:hover{background:#fbfdff;}
.empty-state{min-height:112px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:22px;}
.detail-card{padding:20px;}
.detail-head{padding-bottom:12px;margin-bottom:12px;}
.segmented{gap:8px;margin-bottom:16px;}
.segmented a,.segmented button,.chip,.tab-btn{border-radius:14px;padding:10px 14px;}
.toolbar{gap:12px;margin-bottom:16px;}
.toolbar-group{gap:10px;}
.btn-primary,.btn-secondary,.btn-danger,.btn-ghost,button{border-radius:14px;padding:12px 16px;}
button.btn-secondary{background:#fff;color:#1f2937;}
.page-actions .btn-primary,.page-actions .btn-secondary{min-width:140px;}
.topbar-actions{gap:12px;}
.top-pill,.user-pill{height:40px;border-radius:14px;}
.search-wrap{height:42px;border-radius:14px;}
.search-wrap input{font-size:14px;}
.plan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));}
.plan-card-clean{padding:20px;display:grid;gap:16px;}
.plan-card-clean p{margin:0;color:var(--muted);}
.plan-feature-list{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 16px;}
.plan-feature-list li{position:relative;padding-left:18px;color:#334155;}
.plan-feature-list li::before{content:'•';position:absolute;left:0;top:0;color:var(--primary);font-weight:800;}
.modal-backdrop{background:rgba(15,23,42,.36);backdrop-filter:blur(4px);}
.modal-dialog-tight{width:min(760px,96vw);}
.modal-surface{border-radius:24px;padding:22px;box-shadow:0 24px 60px rgba(15,23,42,.18);}
.card .table + .table-footer,.card .list-table + .table-footer{margin-top:10px;}
#clientModal .modal-dialog{display:flex;align-items:flex-start;justify-content:center;padding-top:18px;}
.form-two-col{gap:14px;}
.settings-test-row,.header-actions,.page-actions{gap:12px;}
.tab-strip{gap:10px;margin-bottom:20px;}
.tab-panel .grid{gap:16px;}
.checkbox-row{min-height:48px;}
.section-card .muted{line-height:1.45;}
#clientModal .modal-card .stack{gap:16px;}
.sidebar-footer{gap:16px;}
.sidebar-footer .progress-stack{padding:14px;border:1px solid var(--line);border-radius:16px;background:#fbfdff;}
.rule-row,.upload-item,.audit-item{background:#fcfdff;}
@media (max-width:1280px){.plan-grid{grid-template-columns:1fr;}.page-actions .btn-primary,.page-actions .btn-secondary{min-width:auto;}}
@media (max-width:960px){.main{padding:18px;}.metric-card{min-height:auto;}.hero-callout{min-height:auto;}.plan-feature-list{grid-template-columns:1fr;}.modal-dialog-tight{width:min(96vw,760px);} }


/* ===== v3.6 design system polish ===== */
:root{--section-gap:20px;--inner-gap:16px;--card-inset:#fbfdff;--card-inset-2:#f8fbff;}
.main{padding:24px 26px 34px;}
.card.section-card{display:grid;gap:16px;padding:22px;border-radius:24px;}
.card.section-card.soft{background:linear-gradient(180deg,#ffffff,#fbfdff);}
.card.section-card > *{min-width:0;}
.card.section-card > .card-header{margin-bottom:0;align-items:center;}
.card.section-card > .card-header + .summary-grid,
.card.section-card > .card-header + .stats-grid,
.card.section-card > .card-header + .doc-stats,
.card.section-card > .card-header + .plan-grid,
.card.section-card > .card-header + .plan-list,
.card.section-card > .card-header + .rule-list,
.card.section-card > .card-header + .stack-list,
.card.section-card > .card-header + .grid-2-1,
.card.section-card > .card-header + .overview-banner,
.card.section-card > .card-header + .rules-grid,
.card.section-card > .card-header + .table,
.card.section-card > .card-header + .list-table{margin-top:2px;}
.metrics-grid,.summary-grid,.stats-grid,.doc-stats,.three-col,.two-col,.grid-2-1,.overview-banner,.rules-grid,.security-grid,.section-grid,.plan-grid,.plan-list{gap:18px;}
.summary-grid,.stats-grid,.doc-stats,.plan-grid,.plan-list{align-items:stretch;}
.summary-grid > *, .stats-grid > *, .doc-stats > *, .plan-grid > *, .plan-list > *, .overview-banner > *, .rules-grid > *{height:100%;min-width:0;}
.summary-card,.mini-card,.doc-stat,.kpi-mini,.rule-card,.plan-card-clean,.plan-card,.info-card,.stat-card{min-height:104px;display:flex;flex-direction:column;justify-content:center;padding:18px;border-radius:18px;background:var(--card-inset);border-color:#e7edf6;}
.summary-card strong,.stat-value{font-size:32px;line-height:1;}
.metric-card{min-height:86px;padding:18px;align-items:center;}
.metric-card .metric-value{font-size:28px;}
.metric-card .metric-title{margin-bottom:4px;}
.metric-card .metric-meta{line-height:1.35;}
.hero-callout{min-height:0;padding:20px;border-radius:20px;background:linear-gradient(180deg,#fbfdff,#f7fbff);border:1px solid #e7edf6;}
.hero-callout h3{margin:0 0 4px;}
.hero-callout .card-footer-note{margin-top:10px;padding-top:10px;}
.kv-list{gap:12px;}
.kv-item{min-height:50px;padding:13px 14px;border-radius:15px;background:var(--card-inset-2);}
.stack-list{gap:12px;}
.alert-row{padding:16px 18px;border-radius:18px;}
.health-score{font-size:44px;line-height:1;}
.table,.list-table{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;}
.table thead th,.list-table thead th{background:#fbfcfe;color:#607089;padding:13px 14px;font-size:12px;border-bottom:1px solid var(--line);}
.table tbody td,.list-table tbody td{padding:14px;border-bottom:1px solid #edf2f8;}
.table tbody tr:last-child td,.list-table tbody tr:last-child td{border-bottom:0;}
.table tbody tr:hover,.list-table tbody tr:hover{background:#fbfdff;}
.table-footer{padding-top:12px;}
.empty-state{min-height:120px;border-radius:18px;background:linear-gradient(180deg,#fcfdff,#f9fbff);}
.detail-card{display:grid;gap:14px;padding:20px;border-radius:24px;}
.detail-head{margin-bottom:0;padding-bottom:14px;}
.detail-section{gap:12px;margin-bottom:0;}
.response-box,.note-box,.detail-banner{border-radius:16px;background:#fbfdff;border-color:#e7edf6;}
.segmented,.tab-strip{gap:10px;margin-bottom:0;}
.segmented a,.segmented button,.chip,.tab-btn{min-height:42px;padding:10px 15px;border-radius:14px;}
.toolbar{gap:12px;margin-bottom:0;align-items:center;}
.toolbar-group{gap:10px;}
.header-actions,.settings-test-row,.page-actions,.action-row{gap:12px;}
.btn-primary,.btn-secondary,.btn-danger,.btn-ghost,button{min-height:44px;padding:12px 16px;border-radius:14px;}
.btn-primary{box-shadow:0 12px 24px rgba(37,99,235,.2);}
.page-actions .btn-primary,.page-actions .btn-secondary{min-width:138px;}
.search-wrap{height:44px;border-radius:14px;}
.top-pill,.user-pill{height:40px;border-radius:13px;}
.form-two-col{gap:16px;}
label{gap:9px;}
input,select,textarea,.input,.select{min-height:48px;border-radius:14px;}
textarea{min-height:120px;}
.checkbox-row{min-height:50px;border-radius:15px;}
.modal{position:fixed;inset:0;display:none;align-items:flex-start;justify-content:center;padding:28px 20px;z-index:90;}
.modal.is-open{display:flex;}
.modal .modal-backdrop{position:absolute;inset:0;display:block;}
.modal .modal-dialog{position:relative;z-index:1;max-height:calc(100vh - 56px);overflow:auto;display:flex;justify-content:center;align-items:flex-start;}
.modal-dialog-tight{width:min(760px,96vw);}
.modal-card,.modal-surface{padding:22px;border-radius:24px;box-shadow:0 24px 60px rgba(15,23,42,.18);}
.modal-card .stack{gap:16px;}
.plan-grid,.plan-list{align-items:stretch;}
.plan-card-clean,.plan-card{padding:20px;gap:16px;}
.plan-feature-list{gap:10px 18px;}
.rule-row{padding:16px;border-radius:16px;align-items:center;}
.audit-item,.upload-item{padding:14px 0;}
.cards-list,.upload-list,.audit-timeline{gap:12px;}
.info-cards{gap:12px;}
.icon-btn{width:38px;height:38px;border-radius:12px;}
#clientModal .modal-card{width:min(760px,96vw);} 
@media (max-width:1280px){.page-actions .btn-primary,.page-actions .btn-secondary{min-width:auto;}.summary-card,.stat-card,.doc-stat{min-height:96px;}}
@media (max-width:960px){.main{padding:18px;}.card.section-card{padding:18px;}.modal{padding:18px 12px;}.modal .modal-dialog{max-height:calc(100vh - 24px);} .metrics-grid,.summary-grid,.stats-grid,.doc-stats,.plan-grid,.plan-list,.overview-banner,.grid-2-1,.rules-grid,.section-grid,.info-cards,.two-col,.three-col{grid-template-columns:1fr;} .page-actions,.header-actions{width:100%;} .page-actions .btn-primary,.page-actions .btn-secondary{width:100%;}}


/* v4.0 right column stabilization */
.icon-danger{background:#fef2f2;color:var(--danger)}
.card{display:block}
.card.section-card{position:relative;overflow:hidden}
.card.section-card + .card.section-card{margin-top:0}
.card.section-card .card-header{padding-bottom:0;border-bottom:0}
.card.section-card .card-header + .muted{margin-top:-6px}
.card.section-card .card,
.card.section-card .mini-card,
.card.section-card .plan-card,
.card.section-card .doc-stat,
.card.section-card .kv-item,
.card.section-card .alert-row,
.card.section-card .danger-box,
.card.section-card .success-box,
.card.section-card .empty-state{box-shadow:none}
.card.section-card .mini-card,
.plan-card,
.doc-stat,
.kv-item,
.alert-row{border-radius:18px}
.cards-list,.stack-list,.list-clean,.activity-list,.kv-list,.plan-feature-list{margin:0;padding:0}
.cards-list{display:grid;gap:14px}
.mini-card,.plan-card,.doc-stat,.kv-item,.alert-row,.danger-box,.success-box{padding:16px 18px}
.mini-card,.plan-card,.doc-stat{border:1px solid var(--line);background:linear-gradient(180deg,#fff,#fbfdff)}
.kv-item{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;border:1px solid var(--line);background:#fbfdff}
.kv-item .label{display:block;color:var(--muted);font-size:13px;margin-bottom:4px}
.list-clean{display:grid;gap:12px;list-style:none}
.list-clean li{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fbfdff}
.activity-list{display:grid;gap:12px;list-style:none}
.activity-list li{display:block;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:#fbfdff}
.stack-list > * + *{margin-top:0}
.security-grid > .card.section-card,.grid-2-1 > .card.section-card,.split-layout > .card.section-card,.split-layout > .detail-card{height:100%}
.detail-card{align-self:start}
.hero-callout,.overview-banner > *, .summary-grid > *, .stats-grid > *{min-width:0}
.hero-callout{padding:18px 20px;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,#f8fbff,#ffffff)}
.form-two-col,.rules-grid,.security-grid,.doc-stats,.summary-grid,.stats-grid{align-items:stretch}
.table-scroll{overflow:auto;border:1px solid var(--line);border-radius:20px;background:#fff}
.table-scroll .list-table{min-width:720px}
.list-table{margin:0}
.list-table thead th:first-child,.list-table tbody td:first-child{padding-left:16px}
.list-table thead th:last-child,.list-table tbody td:last-child{padding-right:16px}
.list-table tbody td{background:#fff}
.list-table tbody tr:last-child td:first-child{border-bottom-left-radius:18px}
.list-table tbody tr:last-child td:last-child{border-bottom-right-radius:18px}
.section-card > .list-table, .section-card > form, .section-card > .toolbar, .section-card > .segmented, .section-card > .empty-state, .section-card > .cards-list, .section-card > .stack-list, .section-card > .list-clean, .section-card > .activity-list, .section-card > .kv-list{margin-top:0}
.page-intro{margin-bottom:20px}
.page-intro + .metrics-grid, .page-intro + .split-layout, .page-intro + .grid-2-1{margin-top:0}
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:#f8fafc;border:1px solid var(--line);font-size:12px;font-weight:800;color:#475467}
.badge{white-space:nowrap}
.inline-form{flex-wrap:wrap}
.inline-form button{min-height:42px}
.modal .card.section-card,.modal .card{box-shadow:none}
@media (max-width:960px){
  .kv-item,.list-clean li{flex-direction:column;align-items:flex-start}
  .search-wrap{min-width:0;width:100%}
}


/* v4.0 right column stabilization */
.split-layout{align-items:stretch}
.split-layout > .card.section-card,
.split-layout > .detail-card{min-width:0}
.split-layout > .detail-card{
  display:flex;
  flex-direction:column;
  height:100%;
  min-height:100%;
  align-self:stretch;
}
.split-layout > .detail-card .detail-head{flex:0 0 auto}
.split-layout > .detail-card .detail-section{flex:0 0 auto}
.split-layout > .detail-card > .empty-state,
.split-layout > .detail-card .detail-empty,
.split-layout > .detail-card .detail-empty-state{
  flex:1 1 auto;
  min-height:240px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.split-layout > .detail-card .transcript-wrap{flex:1 1 auto}
.split-layout > .detail-card .note-box:last-child,
.split-layout > .detail-card .response-box:last-child{margin-bottom:0}
.split-layout > .detail-card .action-row:last-child{margin-top:auto}
.split-layout > .detail-card .detail-section:last-child{margin-bottom:0}
@media (min-width:1281px){
  .split-layout > .detail-card{position:sticky;top:20px}
}
@media (max-width:1280px){
  .split-layout > .detail-card{
    position:static;
    height:auto;
    min-height:0;
    align-self:auto;
  }
  .split-layout > .detail-card > .empty-state,
  .split-layout > .detail-card .detail-empty,
  .split-layout > .detail-card .detail-empty-state{min-height:180px}
}


/* v4.1 table density fix */
:root{
  --table-head-py: 11px;
  --table-cell-py: 12px;
  --table-card-gap: 12px;
}
.card.section-card{gap:var(--table-card-gap)}
.card.section-card > .card-header + .list-table,
.card.section-card > .card-header + .table,
.card.section-card > .card-header + .list-clean,
.card.section-card > .card-header + .activity-list{margin-top:0}
.table,
.list-table{border-radius:18px;border:1px solid var(--line);overflow:hidden;background:#fff}
.table thead th,
.list-table thead th{height:44px;padding:var(--table-head-py) 14px;font-size:12px;line-height:1.2;vertical-align:middle;background:#fbfcfe}
.table tbody td,
.list-table tbody td{padding:var(--table-cell-py) 14px;line-height:1.35;vertical-align:middle}
.list-table tbody td:first-child,
.table tbody td:first-child,
.list-table thead th:first-child,
.table thead th:first-child{padding-left:14px}
.list-table tbody td:last-child,
.table tbody td:last-child,
.list-table thead th:last-child,
.table thead th:last-child{padding-right:14px}
.table tbody td > .empty-state,
.list-table tbody td > .empty-state{min-height:88px;padding:18px 20px;margin:0;border-radius:16px}
.table tbody td[colspan],
.list-table tbody td[colspan]{padding:10px 12px 12px;background:#fff}
.table tbody tr:has(td[colspan]),
.list-table tbody tr:has(td[colspan]){background:#fff}
.empty-state strong{margin-bottom:4px;font-size:15px}
.empty-state p,
.empty-state span{margin:0;line-height:1.45}
.section-card > .list-clean,
.section-card > .activity-list{gap:10px}
.list-clean li,
.activity-list li{min-height:64px;padding:14px 16px}
.audit-timeline{gap:10px}
.audit-item{padding:12px 14px;border-radius:14px}
.table-footer{padding-top:10px}
.section-card .card-subtitle{margin-top:4px}
@media (max-width:960px){
  .table thead th,
  .list-table thead th,
  .table tbody td,
  .list-table tbody td{padding-left:12px;padding-right:12px}
  .table tbody td > .empty-state,
  .list-table tbody td > .empty-state{min-height:76px;padding:16px}
}


/* v4.2 table-space-and-right-column polish */
:root{
  --table-head-height-v42: 42px;
  --table-cell-py-v42: 11px;
  --table-empty-min-v42: 64px;
}
.card.section-card{
  padding:18px 18px 16px;
  gap:14px;
}
.card.section-card > .card-header{
  margin-bottom:0;
  padding-bottom:0;
}
.card.section-card > .card-header + .list-table,
.card.section-card > .card-header + .table,
.card.section-card > .card-header + .table-scroll,
.card.section-card > .card-header + .empty-state,
.card.section-card > .card-header + .stats-band,
.card.section-card > .card-header + .doc-stats{
  margin-top:8px;
}
.list-table,
.table{
  border-radius:16px;
}
.list-table thead th,
.table thead th{
  height:var(--table-head-height-v42);
  padding:10px 14px;
  font-size:12px;
  line-height:1.15;
}
.list-table tbody td,
.table tbody td{
  padding:var(--table-cell-py-v42) 14px;
  line-height:1.35;
}
.list-table thead th:first-child,
.list-table tbody td:first-child,
.table thead th:first-child,
.table tbody td:first-child{padding-left:14px}
.list-table thead th:last-child,
.list-table tbody td:last-child,
.table thead th:last-child,
.table tbody td:last-child{padding-right:14px}
.list-table tbody td[colspan],
.table tbody td[colspan]{
  padding:8px 10px 10px;
}
.list-table tbody td > .empty-state,
.table tbody td > .empty-state,
.section-card .empty-state{
  min-height:var(--table-empty-min-v42);
  padding:16px 18px;
  border-radius:16px;
}
.list-table tbody td > .empty-state strong,
.table tbody td > .empty-state strong,
.section-card .empty-state strong{
  font-size:14px;
  margin-bottom:4px;
}
.list-table tbody td > .empty-state p,
.list-table tbody td > .empty-state span,
.table tbody td > .empty-state p,
.table tbody td > .empty-state span,
.section-card .empty-state p,
.section-card .empty-state span{
  font-size:13px;
  line-height:1.45;
}
.table-footer{
  padding-top:10px;
}
.card.section-card .table-footer{
  margin-top:2px;
}
.detail-card{
  height:100%;
  display:flex;
  flex-direction:column;
}
.detail-card > .empty-state,
.detail-card .detail-empty-state,
.split-layout > .detail-card > .empty-state,
.split-layout > .detail-card .detail-empty-state{
  min-height:160px;
  flex:1 1 auto;
  display:flex;
  align-items:center;
  justify-content:center;
}
.kv-list .kv-item,
# health and right column rows share density
.stack-list .kv-item,
.info-card{
  min-height:48px;
}
@media (max-width:1280px){
  .card.section-card{padding:16px;}
  .list-table thead th,
  .table thead th{padding:10px 12px;}
  .list-table tbody td,
  .table tbody td{padding:10px 12px;}
}

/* v4.4 functional ux fix */
.split-layout-wide{grid-template-columns:minmax(0,1.45fr) minmax(360px,0.95fr);}
.metrics-grid-compact{grid-template-columns:1fr;gap:12px;}
.metric-row{display:flex;align-items:center;justify-content:space-between;gap:12px;}
.compact-list li{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.compact-list li .badge{white-space:nowrap;}
#client-form{scroll-margin-top:24px;}
#client-form .stack{gap:16px;}
#client-form .btn-secondary,#client-form .btn-primary{min-width:140px;}
@media (max-width:1180px){.split-layout-wide{grid-template-columns:1fr;}}


/* v4.5 table scroll system */
.table-scroll{
  position:relative;
  overflow:auto;
  border:1px solid var(--line);
  border-radius:18px;
  background:#fff;
  max-width:100%;
  scrollbar-gutter: stable both-edges;
}
.table-scroll--auto{max-height:380px;}
.table-scroll--md{max-height:320px;}
.table-scroll--lg{max-height:460px;}
.page-dashboard .table-scroll--md{max-height:300px;}
.page-clients .table-scroll--md{max-height:360px;}
.page-errors .table-scroll--md,.page-health .table-scroll--md{max-height:300px;}
.page-knowledge .table-scroll--md{max-height:320px;}
.table-scroll > .table,
.table-scroll > .list-table{
  min-width:760px;
  width:100%;
  margin:0;
  border:0;
  border-radius:0;
}
.table-scroll > .table thead th,
.table-scroll > .list-table thead th{
  position:sticky;
  top:0;
  z-index:2;
  background:#fbfcfe;
  box-shadow: inset 0 -1px 0 var(--line);
}
.table-scroll > .table tbody td,
.table-scroll > .list-table tbody td{background:#fff;}
.table-scroll::-webkit-scrollbar{width:10px;height:10px}
.table-scroll::-webkit-scrollbar-track{background:#f3f6fb;border-radius:999px}
.table-scroll::-webkit-scrollbar-thumb{background:#cfd8e6;border-radius:999px;border:2px solid #f3f6fb}
.table-scroll::-webkit-scrollbar-thumb:hover{background:#b9c6da}
.table-scroll + .table-footer{margin-top:10px}
.section-card > .table-scroll + .empty-state,
.section-card > .table-scroll + .table-footer{margin-top:10px}
.table-scroll .empty-state{min-height:72px}
@media (max-width: 1280px){
  .table-scroll--lg,.table-scroll--md,.table-scroll--auto{max-height:unset;}
}


/* v4.6 actions menus + uploads */
.table-scroll--sm{max-height:280px}
.table-scroll--md{max-height:360px}
.table-scroll--lg{max-height:520px}
.table-scroll thead th{position:sticky;top:0;z-index:2;background:#fbfcfe}
.row-menu{position:relative;display:inline-block}
.row-menu summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid var(--line);border-radius:12px;background:#fff;font-weight:800;color:#475467}
.row-menu summary::-webkit-details-marker{display:none}
.row-menu[open] summary{background:#f8fbff}
.row-menu__items{position:absolute;right:0;top:40px;min-width:180px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 18px 40px rgba(15,23,42,.12);padding:8px;display:grid;gap:4px;z-index:20}
.row-menu__items a,.row-menu__items button{display:block;width:100%;text-align:left;padding:10px 12px;border-radius:10px;background:transparent;border:0;color:#1f2937;text-decoration:none;font:inherit;cursor:pointer}
.row-menu__items a:hover,.row-menu__items button:hover{background:#f8fbff}
.row-menu__items form{margin:0}
.danger-link{color:#b42318!important}


/* v4.7 ui controls fix */
.page-emails .segmented{align-items:center;gap:12px;margin-bottom:16px}
.page-emails .segmented a,
.page-emails .segmented button,
.page-emails .chip{height:50px;min-width:0;padding:0 18px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;line-height:1}
.page-emails .segmented .count-badge{margin-left:2px}
.page-emails .segmented .active{box-shadow:0 10px 22px rgba(37,99,235,.18)}
.table-actions{justify-content:flex-end}
.list-table td:last-child,.list-table th:last-child{width:86px;white-space:nowrap}
.row-menu{position:relative;display:inline-block;vertical-align:middle}
.row-menu summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border:1px solid var(--line);border-radius:12px;background:#fff;color:#475467;font-weight:800;box-shadow:none;transition:.16s ease}
.row-menu summary:hover,.row-menu[open] summary{background:#f8fbff;border-color:#cfd8e6}
.row-menu summary::marker,.row-menu summary::-webkit-details-marker{display:none}
.row-menu__items{position:absolute;right:0;top:42px;min-width:190px;max-width:220px;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 42px rgba(15,23,42,.14);padding:8px;display:grid;gap:4px;z-index:200;overflow:hidden}
.row-menu__items a,
.row-menu__items button,
.row-menu__items form button{
  all:unset;
  display:flex !important;
  align-items:center;
  gap:10px;
  width:100%;
  min-height:40px;
  padding:10px 12px;
  border-radius:10px;
  color:#1f2937 !important;
  background:transparent !important;
  box-shadow:none !important;
  cursor:pointer;
  font:600 14px/1.2 Inter,Segoe UI,Arial,sans-serif;
}
.row-menu__items a:hover,
.row-menu__items button:hover,
.row-menu__items form button:hover{background:#f8fbff !important}
.row-menu__items a::before,
.row-menu__items button::before,
.row-menu__items form button::before{content:'•';font-size:14px;color:#94a3b8;line-height:1}
.row-menu__items .danger-link{color:#b42318 !important}
.row-menu__items .danger-link::before{color:#ef4444}
@media (max-width: 820px){
  .row-menu__items{right:auto;left:0;min-width:170px;max-width:calc(100vw - 48px)}
  .page-emails .segmented{gap:8px}
  .page-emails .segmented a,
  .page-emails .segmented button,
  .page-emails .chip{height:44px;padding:0 14px;border-radius:14px;font-size:14px}
}


/* v4.7.2 dropdown overflow fix */
.page-emails .section-card,
.page-clients .section-card,
.page-knowledge .section-card{overflow:visible;}
.table-scroll{position:relative;overflow-x:auto;overflow-y:visible;}
.table-scroll > .table,
.table-scroll > .list-table{overflow:visible;}
.table-scroll .list-table,
.table-scroll .table{position:relative;z-index:1;}
.row-menu{position:relative;display:inline-block;vertical-align:middle;z-index:50;}
.row-menu summary{position:relative;z-index:51;}
.row-menu__items{position:absolute;top:calc(100% + 8px);right:0;left:auto;min-width:190px;max-width:220px;z-index:9999;}
.row-menu__items.is-up{top:auto;bottom:calc(100% + 8px);}
.row-menu__items.is-left{right:auto;left:0;}
@media (max-width: 960px){
  .row-menu__items{min-width:170px;max-width:min(220px,calc(100vw - 32px));}
}


/* v4.7.3 portal dropdown + card scroll */
#row-menu-portal{position:fixed;inset:0;pointer-events:none;z-index:10040;}
.row-menu__items--portal{pointer-events:auto;}
.row-menu__placeholder{display:none!important;}
.row-menu__items{overflow:visible;}
.dashboard-scroll-list{max-height:340px;overflow:auto;padding-right:4px;}
.dashboard-scroll-list::-webkit-scrollbar{width:10px;height:10px}
.dashboard-scroll-list::-webkit-scrollbar-track{background:#f3f6fb;border-radius:999px}
.dashboard-scroll-list::-webkit-scrollbar-thumb{background:#cfd8e6;border-radius:999px;border:2px solid #f3f6fb}
.page-dashboard .dashboard-scroll-list{max-height:340px;}
.page-dashboard .dashboard-scroll-list li{margin-right:2px;}
.page-dashboard .grid-2-1 > .section-card{min-height:0;}
@media (max-width: 960px){
  .dashboard-scroll-list{max-height:unset;}
}


/* v4.7.4 portal body + top5 scroll */
#row-menu-portal{position:fixed !important;inset:0 !important;pointer-events:none !important;z-index:2147483000 !important;overflow:visible !important;isolation:isolate;}
.row-menu__items--portal{pointer-events:auto !important;position:fixed !important;z-index:2147483001 !important;min-width:190px;max-width:220px;max-height:min(320px,calc(100vh - 24px));overflow:auto;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 20px 42px rgba(15,23,42,.18);padding:8px;}
.row-menu__items--portal::-webkit-scrollbar{width:10px}.row-menu__items--portal::-webkit-scrollbar-thumb{background:#cfd8e6;border-radius:999px;border:2px solid #fff;}
.row-menu summary{position:relative;z-index:1;}
.table-scroll,.section-card,.card{overflow:visible;}
.page-emails .section-card .table-scroll,.page-clients .section-card .table-scroll,.page-knowledge .section-card .table-scroll{overflow:auto;}
.dashboard-scroll-list{max-height:420px;overflow:auto;padding-right:4px;}
.page-dashboard .dashboard-scroll-list{max-height:420px;}
.page-dashboard .activity-list.dashboard-scroll-list li,.page-dashboard .list-clean.dashboard-scroll-list li{min-height:72px;}
@media (max-width:960px){.row-menu__items--portal{min-width:170px;max-width:calc(100vw - 24px);} .dashboard-scroll-list{max-height:unset;}}
