*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body,#root{height:100%;width:100%}
body{font-family:'IBM Plex Sans',system-ui,sans-serif;background:#f4f6f9;color:#1e293b;font-size:13px;line-height:1.5}
:root{
  --navy:#0d1f33;--navy2:#1e3a5f;--teal:#38bdf8;
  --blue:#2563eb;--blue-light:#dbeafe;
  --white:#fff;--grey-50:#f8fafc;--grey-100:#f1f5f9;
  --grey-200:#e2e8f0;--grey-300:#cbd5e1;--grey-400:#94a3b8;
  --grey-500:#64748b;--grey-600:#475569;--grey-700:#334155;--grey-800:#1e293b;
  --green:#16a34a;--green-light:#f0fdf4;--green-border:#bbf7d0;
  --red:#ef4444;--amber:#d97706;
  --args-bg:#eef2f7;--args-border:#c8d8e8;
}
#root{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.app-body{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}

/* Header */
.app-header{background:var(--navy);height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid rgba(255,255,255,0.1);flex-shrink:0}
.app-title{font-size:14px;font-weight:600;color:#fff}
.app-title b{font-weight:700}
.app-sub{font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,0.45);margin-top:2px}
.header-right{display:flex;align-items:center;gap:10px}
.header-pills{display:flex;gap:6px}
.header-pill{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:4px;padding:3px 10px;font-size:10px;font-weight:500;color:#fff}
.header-pill.offline{color:#fca5a5}
.header-pill.online{color:#86efac}
.hdr-sep{width:1px;height:20px;background:rgba(255,255,255,0.2)}
.hdr-icon{background:rgba(255,255,255,0.1);border:none;border-radius:6px;color:rgba(255,255,255,0.8);width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;transition:all 0.15s}
.hdr-icon:hover{background:rgba(255,255,255,0.2);color:#fff}

/* Ribbon */
.ribbon{background:#fff;height:40px;border-bottom:2px solid var(--navy);display:flex;align-items:stretch;flex-shrink:0;padding:0 4px;overflow:hidden}
.ribbon-tab{display:flex;align-items:center;padding:0 20px;font-size:13px;font-weight:500;color:#334155;cursor:pointer;border:none;background:transparent;border-bottom:3px solid transparent;margin-bottom:-2px;white-space:nowrap;font-family:inherit;transition:background 0.1s}
.ribbon-tab:hover{background:#f0f4f8;color:var(--navy)}
.ribbon-tab.active{color:var(--navy);font-weight:700;background:#e8eef5}

/* Context bar */
.ctx-bar{background:var(--navy2);height:26px;display:flex;align-items:center;padding:0 16px;gap:4px;border-bottom:1px solid rgba(255,255,255,0.08);flex-shrink:0}
.ctx-label{font-size:8px;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,0.5);font-weight:600}
.ctx-value{font-size:10px;font-weight:600;color:rgba(255,255,255,0.85);margin-left:2px}
.ctx-sep{color:rgba(255,255,255,0.2);margin:0 6px}

/* Stepper */
.stepper{background:transparent;border-bottom:none;display:flex;align-items:center;padding:0;gap:4px;overflow-x:auto;flex-shrink:0}
.stepper::-webkit-scrollbar{height:3px}
.stepper::-webkit-scrollbar-thumb{background:var(--grey-300)}
.step-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:500;border:2px solid var(--grey-400);color:var(--grey-600);cursor:pointer;white-space:nowrap;background:transparent;font-family:inherit;transition:all 0.15s;flex-shrink:0}
.step-pill:hover{border-color:var(--navy);color:var(--navy)}
.step-pill.active{background:var(--navy);color:#fff;border-color:var(--navy);font-weight:600}
.step-pill.done{background:var(--green-light);color:var(--green);border-color:var(--green);border-width:2px}
.step-arrow{color:var(--grey-400);font-size:14px;flex-shrink:0;user-select:none}
.step-arrow.done{color:var(--green)}

/* Two-col */
.two-col{display:flex;flex:1;overflow:hidden;min-height:0}
.col-args{width:290px;flex-shrink:0;background:var(--args-bg);border-right:2px solid var(--args-border);display:flex;flex-direction:column;overflow-y:auto}
.col-results{flex:1;background:#fff;display:flex;flex-direction:column;overflow:hidden}
.col-header{font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--grey-400);padding:10px 16px 8px;border-bottom:1px solid var(--args-border);background:inherit;position:sticky;top:0;z-index:1;flex-shrink:0}
.col-results .col-header{border-bottom-color:var(--grey-200)}
.col-args-collapsed{width:24px;flex-shrink:0;background:var(--args-bg);border-right:2px solid var(--args-border);display:flex;align-items:flex-start;justify-content:center;padding-top:12px;cursor:pointer;transition:background 0.15s}
.col-args-collapsed:hover{background:var(--grey-200)}
.col-args-expand-icon{font-size:12px;color:var(--grey-500);font-weight:700}
.col-args-collapse-btn{background:none;border:none;cursor:pointer;font-size:11px;color:var(--grey-400);padding:2px 4px;border-radius:3px;line-height:1}
.col-args-collapse-btn:hover{background:var(--grey-200);color:var(--grey-700)}
.col-body{padding:12px 16px;flex:1;display:flex;flex-direction:column;gap:10px;overflow-y:auto}

/* Form widgets */
.field-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-600);margin-bottom:4px;display:block}
.field-hint{font-size:10px;color:var(--grey-400);margin-top:3px;line-height:1.4;font-style:italic}
.sel-select{width:100%;padding:7px 10px;border:1px solid var(--args-border);border-radius:5px;background:#fff;font-size:12px;font-family:inherit;color:var(--grey-800);cursor:pointer;outline:none;box-sizing:border-box}
.sel-select:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}
.sel-input{width:100%;padding:7px 10px;border:1px solid var(--args-border);border-radius:5px;background:#fff;font-size:12px;font-family:inherit;color:var(--grey-800);outline:none;box-sizing:border-box}
.sel-input:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}
.checkbox-row{display:flex;align-items:center;gap:8px;padding:3px 0;cursor:pointer;user-select:none}
.checkbox-row input[type=checkbox]{width:13px;height:13px;accent-color:var(--navy);cursor:pointer;flex-shrink:0}
.checkbox-row span{font-size:12px;color:var(--grey-700)}
.args-section{padding-top:10px;border-top:1px solid var(--args-border);margin-top:4px}
.args-section-title{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-400);margin-bottom:8px}
.two-field{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* File zone */
.file-zone{border:2px dashed var(--args-border);border-radius:6px;padding:14px 10px;text-align:center;cursor:pointer;background:#fff;transition:all 0.15s;position:relative}
.file-zone:hover{border-color:var(--blue);background:var(--blue-light)}
.file-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.file-zone-icon{font-size:20px;margin-bottom:5px;opacity:0.45}
.file-zone-text{font-size:11px;color:var(--grey-400);line-height:1.5}
.file-zone-text b{color:var(--blue)}
.file-chosen{background:var(--green-light);border:1px solid var(--green-border);border-radius:5px;padding:5px 10px;font-size:11px;color:var(--green);margin-top:5px;display:flex;align-items:center;gap:5px}

/* Action buttons */
.action-btns{display:flex;flex-direction:column;gap:5px}
.action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--grey-200);background:#fff;color:var(--grey-700);font-family:inherit;transition:all 0.15s;text-align:center;width:250px;max-width:250px;box-sizing:border-box}
.action-btn:hover{background:var(--grey-100);border-color:var(--grey-300)}
.action-btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.action-btn.primary:hover{background:#1a3050}
.action-btn.danger{color:var(--red);border-color:#fecaca}
.action-btn.danger:hover{background:#fff5f5}
.args-footer{margin-top:auto;padding-top:10px;border-top:1px solid var(--args-border);display:flex;align-items:center;justify-content:space-between}
.help-btn{display:flex;align-items:center;gap:5px;color:var(--grey-400);font-size:11px;cursor:pointer;background:none;border:1px solid var(--grey-200);border-radius:4px;padding:4px 8px;font-family:inherit;transition:all 0.15s}
.help-btn:hover{color:var(--blue);border-color:var(--blue)}

/* Results tabs */
.results-tabs{display:flex;border-bottom:2px solid var(--grey-200);padding:0 16px;background:#fff;flex-shrink:0}
.result-tab{padding:8px 16px;font-size:12px;font-weight:500;color:var(--grey-400);cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:inherit;white-space:nowrap;transition:all 0.15s}
.result-tab:hover{color:var(--grey-700)}
.result-tab.active{color:var(--navy);font-weight:700;border-bottom-color:var(--navy)}
.results-toolbar{display:flex;align-items:center;gap:6px;padding:6px 16px;border-bottom:1px solid var(--grey-100);background:#fafbfc;flex-shrink:0;min-height:36px;flex-wrap:wrap}
.tool-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;border-radius:4px;font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--grey-200);background:#fff;color:var(--grey-600);font-family:inherit;transition:all 0.15s}
.tool-btn:hover{background:var(--grey-100)}
.tool-btn.active-filter{background:var(--blue-light);border-color:var(--blue);color:var(--blue)}
.tool-sep{width:1px;height:16px;background:var(--grey-200)}
.results-body{flex:1;overflow:auto;min-height:0}

/* Data Table */
.data-table-wrap{overflow:auto;height:100%;position:relative}
.data-table{width:100%;border-collapse:collapse;font-size:11px}
.data-table th{position:sticky;top:0;background:#f1f5f9;font-weight:600;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--grey-600);padding:0;border-bottom:2px solid var(--grey-200);text-align:left;white-space:nowrap;z-index:10}
.th-inner{display:flex;flex-direction:column}
.th-sort{padding:6px 12px 3px;cursor:pointer;display:flex;align-items:center;gap:3px;user-select:none}
.th-sort:hover{background:#e2e8f0}
.th-filter{padding:2px 6px 4px}
.th-filter input{width:100%;padding:2px 5px;border:1px solid var(--grey-300);border-radius:3px;font-size:10px;font-family:inherit;background:#fff;outline:none;min-width:50px}
.th-filter input:focus{border-color:var(--blue)}
.data-table td{padding:6px 12px;border-bottom:1px solid var(--grey-100);color:var(--grey-700);white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}
.data-table tr.selected td{background:#dbeafe!important}
.data-table tr:hover td{background:#f8fafc}
.data-table tr.selected:hover td{background:#bfdbfe!important}
.ds-original td:first-child{border-left:3px solid var(--grey-300)}
.ds-sample td:first-child{border-left:3px solid var(--teal)}
.table-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-top:1px solid var(--grey-200);background:#fafbfc;font-size:11px;color:var(--grey-400);flex-shrink:0;flex-wrap:wrap;gap:4px}
.pagination{display:flex;gap:4px}
.page-btn{padding:3px 8px;border-radius:4px;border:1px solid var(--grey-200);background:#fff;cursor:pointer;font-size:11px;font-family:inherit;color:var(--grey-600)}
.page-btn:hover{background:var(--grey-100)}
.page-btn.active{background:var(--navy);color:#fff;border-color:var(--navy)}
.page-btn:disabled{opacity:0.4;cursor:not-allowed}
.sel-count-badge{background:var(--blue-light);color:var(--blue);border-radius:4px;padding:2px 7px;font-size:10px;font-weight:600}

/* Profile panel */
.profile-wrap{display:flex;height:100%;overflow:hidden}
.profile-tabs-side{width:130px;flex-shrink:0;background:var(--grey-50);border-right:1px solid var(--grey-200);display:flex;flex-direction:column;padding:8px 0}
.profile-tab-side{padding:8px 14px;font-size:12px;font-weight:500;color:var(--grey-500);cursor:pointer;border:none;background:transparent;text-align:left;font-family:inherit;border-left:3px solid transparent;transition:all 0.1s}
.profile-tab-side:hover{background:var(--grey-100);color:var(--grey-700)}
.profile-tab-side.active{color:var(--navy);font-weight:700;border-left-color:var(--navy);background:#fff}
.profile-content{flex:1;overflow-y:auto;padding:16px}

/* Profile stat grid */
.profile-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin-bottom:16px}
.stat-card{background:var(--grey-50);border:1px solid var(--grey-200);border-radius:6px;padding:10px 12px}
.stat-card-label{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);margin-bottom:3px}
.stat-card-val{font-size:22px;font-weight:600;color:var(--grey-800);line-height:1}
.stat-card-sub{font-size:11px;color:var(--grey-400);margin-top:3px}
.stat-card.warn .stat-card-val{color:var(--amber)}
.stat-card.ok .stat-card-val{color:var(--green)}

/* Profile overview table */
.profile-table{width:100%;border-collapse:collapse;font-size:11px}
.profile-table th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);padding:6px 10px;border-bottom:2px solid var(--grey-200);white-space:nowrap}
.profile-table td{padding:5px 10px;border-bottom:1px solid var(--grey-100);color:var(--grey-700);vertical-align:middle}
.profile-table tr:hover td{background:var(--grey-50)}
.null-bar-wrap{width:60px;display:inline-block;vertical-align:middle}
.null-bar-bg{height:5px;background:var(--grey-200);border-radius:3px}
.null-bar-fill{height:5px;border-radius:3px;background:var(--amber)}
.null-bar-fill.high{background:var(--red)}
.type-badge{display:inline-block;padding:1px 6px;border-radius:3px;font-size:9px;font-weight:600;background:var(--grey-100);color:var(--grey-600)}
.type-badge.numeric{background:#ede9fe;color:#5b21b6}
.type-badge.text{background:#fef9c3;color:#854d0e}
.type-badge.bool{background:#dcfce7;color:#166534}

/* Before/after compare */
.compare-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;height:100%;overflow:hidden}
.compare-pane{display:flex;flex-direction:column;overflow:hidden}
.compare-header{padding:8px 14px;background:var(--grey-50);border-bottom:1px solid var(--grey-200);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-500);flex-shrink:0}
.compare-header.resolved{background:#f0fdf4;color:var(--green)}
.compare-pane:first-child{border-right:2px solid var(--grey-200)}
.compare-body{flex:1;overflow-y:auto;padding:10px}

/* Quality summary cards */
.quality-cards{display:flex;flex-direction:column;gap:8px;padding:16px}
.quality-card{background:var(--grey-50);border:1px solid var(--grey-200);border-radius:6px;padding:12px 14px}
.quality-card-title{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);margin-bottom:6px}
.quality-card-body{font-size:12px;color:var(--grey-700);line-height:1.6}
.quality-score{font-size:28px;font-weight:700;line-height:1}
.quality-score.good{color:var(--green)}
.quality-score.warn{color:var(--amber)}
.quality-score.poor{color:var(--red)}
.q-row{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid var(--grey-100);font-size:11px}
.q-row:last-child{border:none}
.q-label{color:var(--grey-500)}
.q-val{font-weight:600;color:var(--grey-700)}
.q-val.pass{color:var(--green)}
.q-val.warn{color:var(--amber)}
.q-val.fail{color:var(--red)}

/* Plot panel */
.plot-wrap{display:flex;height:100%;overflow:hidden}
.plot-controls{width:200px;flex-shrink:0;background:var(--grey-50);border-right:1px solid var(--grey-200);padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.plot-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}
.plot-scope-bar{padding:3px 14px;background:var(--blue-light);font-size:10px;color:#1e40af;border-bottom:1px solid var(--grey-200);flex-shrink:0}
.plot-render{flex:1;min-height:300px;height:100%}

/* Map panel */
.map-wrap{display:flex;height:100%;overflow:hidden}
.map-controls{width:200px;flex-shrink:0;background:var(--grey-50);border-right:1px solid var(--grey-200);padding:12px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.map-area{flex:1;background:#dde4ed;display:flex;align-items:center;justify-content:center}
.map-placeholder{text-align:center;color:var(--grey-400)}
.map-placeholder-icon{font-size:40px;margin-bottom:10px;opacity:0.3}
.map-placeholder-title{font-size:13px;font-weight:500;color:var(--grey-500);margin-bottom:4px}
.map-placeholder-sub{font-size:11px;max-width:240px;line-height:1.6}

/* Empty */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:8px;color:var(--grey-400);padding:40px;text-align:center}
.empty-icon{font-size:32px;opacity:0.35}
.empty-title{font-size:13px;font-weight:500;color:var(--grey-500)}
.empty-sub{font-size:11px;max-width:260px;line-height:1.6}

/* Log */
.log-section{border-top:1px solid var(--grey-100);flex-shrink:0}
.log-toolbar{display:flex;align-items:center;justify-content:space-between;padding:5px 16px;background:#fafbfc;border-bottom:1px solid var(--grey-100)}
.log-title-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-400)}
.log-actions{display:flex;gap:4px}
.log-rows{max-height:110px;overflow-y:auto}
.log-row{display:flex;gap:8px;padding:3px 16px;border-bottom:1px solid var(--grey-50);font-family:'IBM Plex Mono',monospace;font-size:10px}
.log-ts{color:var(--grey-400);min-width:130px}
.log-level{min-width:40px;font-weight:700}
.log-level.info{color:#3b82f6}.log-level.ok{color:var(--green)}.log-level.warn{color:var(--amber)}.log-level.error{color:var(--red)}
.log-msg{color:var(--grey-600)}
.log-empty-msg{padding:8px 16px;font-size:11px;color:var(--grey-400)}

/* Step nav */
.step-nav{display:flex;justify-content:space-between;align-items:center;padding:8px 20px;background:#fff;border-top:1px solid var(--grey-200);flex-shrink:0}
.btn{padding:6px 20px;border-radius:5px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all 0.15s}
.btn-primary{background:var(--navy);color:#fff;border:none}
.btn-primary:hover{background:#1a3050}
.btn-ghost{background:transparent;color:var(--grey-600);border:1px solid var(--grey-200)}
.btn-ghost:hover{background:var(--grey-100)}
.btn:disabled{opacity:0.4;cursor:not-allowed}
.step-nav-info{font-size:11px;color:var(--grey-400)}

/* Modal / settings */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);display:flex;align-items:center;justify-content:center;z-index:1000}
.modal{background:#fff;border-radius:10px;width:420px;max-height:80vh;overflow-y:auto;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,0.25)}
.modal-title{font-size:15px;font-weight:700;color:var(--grey-800);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--grey-200)}
.modal-close{background:var(--navy);color:#fff;border:none;border-radius:5px;padding:8px 20px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;margin-top:12px}
.settings-modal{background:#fff;border-radius:10px;width:680px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,0.25)}
.settings-header{padding:18px 24px;border-bottom:1px solid var(--grey-200);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.settings-title{font-size:15px;font-weight:700;color:var(--grey-800)}
.settings-close{background:none;border:none;font-size:20px;color:var(--grey-400);cursor:pointer;padding:0;line-height:1}
.settings-close:hover{color:var(--grey-800)}
.settings-tabs{display:flex;border-bottom:2px solid var(--grey-200);padding:0 24px;flex-shrink:0}
.settings-tab{padding:10px 16px;font-size:12px;font-weight:500;color:var(--grey-400);cursor:pointer;border:none;background:transparent;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:inherit}
.settings-tab.active{color:var(--navy);font-weight:700;border-bottom-color:var(--navy)}
.settings-body{flex:1;overflow-y:auto;padding:20px 24px}
.user-table{width:100%;border-collapse:collapse;font-size:12px}
.user-table th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);padding:8px 12px;border-bottom:2px solid var(--grey-200)}
.user-table td{padding:8px 12px;border-bottom:1px solid var(--grey-100);color:var(--grey-700)}
.user-table tr:hover td{background:var(--grey-50)}
.role-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}
.role-badge.admin{background:#dbeafe;color:#1e40af}
.role-badge.analyst{background:#f0fdf4;color:#166534}
.role-badge.viewer{background:#fef9c3;color:#854d0e}
.status-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}
.status-badge.active{background:#f0fdf4;color:#166534}
.status-badge.inactive{background:#fff1f2;color:#9f1239}
.add-user-form{background:var(--grey-50);border:1px solid var(--grey-200);border-radius:8px;padding:16px;margin-bottom:16px}
.add-user-form-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-600);margin-bottom:12px}
.form-row{display:flex;gap:10px;margin-bottom:10px}
.form-field{flex:1}
.form-field label{display:block;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-600);margin-bottom:4px}
.form-field input,.form-field select{width:100%;padding:7px 10px;border:1px solid var(--grey-200);border-radius:5px;font-size:12px;font-family:inherit;color:var(--grey-800);outline:none}
.form-field input:focus,.form-field select:focus{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue-light)}
.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:4px}
.btn-sm{padding:5px 14px;border-radius:4px;font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;border:none;transition:all 0.15s}
.btn-sm-primary{background:var(--navy);color:#fff}
.btn-sm-primary:hover{background:#1a3050}
.btn-sm-ghost{background:transparent;color:var(--grey-600);border:1px solid var(--grey-200)!important}
.btn-sm-ghost:hover{background:var(--grey-100)}
.btn-sm-danger{background:#fff;color:var(--red);border:1px solid #fecaca!important}
.btn-sm-danger:hover{background:#fff5f5}
.form-success{background:#f0fdf4;border:1px solid var(--green-border);border-radius:5px;padding:8px 12px;font-size:12px;color:var(--green);margin-bottom:12px}
.form-error{background:#fff5f5;border:1px solid #fecaca;border-radius:5px;padding:8px 12px;font-size:12px;color:var(--red);margin-bottom:12px}

/* Login */
.login-wrap{position:fixed;inset:0;background:var(--navy);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:9999}
.login-brand{text-align:center;margin-bottom:32px}
.login-brand-title{font-size:32px;font-weight:700;color:#fff;letter-spacing:-0.5px}
.login-brand-title span{color:#38bdf8}
.login-brand-sub{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:6px}
.login-card{background:#fff;border-radius:12px;padding:32px 36px;width:340px;box-shadow:0 24px 64px rgba(0,0,0,0.4)}
.login-card-title{font-size:15px;font-weight:700;color:#1e293b;margin-bottom:4px}
.login-card-sub{font-size:12px;color:#94a3b8;margin-bottom:24px}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#475569;margin-bottom:5px}
.login-field input{width:100%;padding:9px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;font-family:inherit;color:#1e293b;outline:none;transition:border 0.15s;box-sizing:border-box}
.login-field input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #dbeafe}
.login-btn{width:100%;padding:10px;border-radius:6px;background:#0d1f33;color:#fff;border:none;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;margin-top:4px;transition:background 0.15s}
.login-btn:hover{background:#1a3050}
.login-btn:disabled{opacity:0.6;cursor:not-allowed}
.login-error{background:#fff5f5;border:1px solid #fecaca;border-radius:6px;padding:10px 12px;font-size:12px;color:#ef4444;margin-bottom:16px}
.login-footer{text-align:center;margin-top:16px;font-size:11px;color:#94a3b8}
.setup-badge{background:rgba(56,189,248,0.15);border:1px solid rgba(56,189,248,0.3);border-radius:4px;padding:3px 10px;font-size:10px;color:#38bdf8;margin-bottom:20px;display:inline-block}

::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--grey-300);border-radius:3px}

/* Hierarchy selector */
.hier-panel{display:flex;flex-direction:column;gap:6px}
.hier-tier{display:flex;flex-direction:column;gap:3px}
.hier-tier-label{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--grey-500)}
.hier-list{border:1px solid var(--args-border);border-radius:5px;background:#fff;max-height:150px;overflow-y:auto}
.hier-list-large{max-height:320px}
.hier-item{display:flex;align-items:center;gap:6px;padding:3px 8px;font-size:11px;color:var(--grey-700);cursor:pointer;border-bottom:1px solid var(--grey-100)}
.hier-item:last-child{border:none}
.hier-item:hover{background:var(--grey-50)}
.hier-item input[type=checkbox]{width:12px;height:12px;accent-color:var(--navy);flex-shrink:0}
.hier-search{width:100%;padding:4px 8px;border:1px solid var(--args-border);border-radius:4px 4px 0 0;border-bottom:none;font-size:11px;font-family:inherit;outline:none;background:#fafcff}
.hier-search:focus{border-color:var(--blue)}
.hier-sel-count{font-size:10px;color:var(--grey-400);margin-left:auto}
.hier-actions{display:flex;gap:4px;margin-top:2px}
.hier-action-btn{font-size:10px;color:var(--blue);background:none;border:none;cursor:pointer;padding:0;font-family:inherit}
.hier-action-btn:hover{text-decoration:underline}

/* Variable dual-panel */
.var-panel{display:flex;flex-direction:column;gap:6px;padding-right:12px}
.var-dual{display:grid;grid-template-columns:1fr 28px 1fr;gap:4px;align-items:start}
.var-col{display:flex;flex-direction:column;gap:3px;height:200px}
.var-col-label{font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-500);flex-shrink:0}
.var-list{border:1px solid var(--args-border);border-radius:4px;background:#fff;flex:1;overflow-y:auto;min-height:0}
.var-item{display:flex;align-items:center;padding:3px 6px;font-size:11px;color:var(--grey-700);cursor:pointer;border-bottom:1px solid var(--grey-50)}
.var-item:last-child{border:none}
.var-item:hover{background:var(--blue-light)}
.var-item.selected{background:var(--blue-light);color:var(--blue);font-weight:600}
.var-item .type-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-right:4px}
.var-item .type-dot.num{background:#5b21b6}
.var-item .type-dot.cat{background:#854d0e}
.var-btns{display:flex;flex-direction:column;gap:4px;padding-top:20px}
.var-move-btn{width:24px;height:24px;border:1px solid var(--grey-200);border-radius:4px;background:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;color:var(--grey-600)}
.var-move-btn:hover{background:var(--grey-100)}
.var-search{width:100%;padding:3px 6px;border:1px solid var(--args-border);border-radius:4px 4px 0 0;border-bottom:none;font-size:10px;font-family:inherit;outline:none}

/* Config presets */
.preset-row{display:flex;gap:4px;align-items:center;margin-top:4px}
.preset-row .sel-select{flex:1;font-size:11px;padding:4px 6px}
.preset-btn{padding:4px 8px;border-radius:4px;font-size:10px;font-weight:600;cursor:pointer;border:1px solid var(--grey-200);background:#fff;color:var(--grey-600);font-family:inherit;white-space:nowrap}
.preset-btn:hover{background:var(--grey-100)}
.preset-btn.save{background:var(--navy);color:#fff;border-color:var(--navy)}

/* Per-column override table */
.override-table{width:100%;border-collapse:collapse;font-size:11px}
.override-table th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);padding:5px 8px;border-bottom:2px solid var(--grey-200);background:var(--grey-50)}
.override-table td{padding:3px 5px;border-bottom:1px solid var(--grey-100);vertical-align:middle}
.override-table select,.override-table input[type=text]{width:100%;padding:2px 5px;border:1px solid var(--grey-200);border-radius:3px;font-size:10px;font-family:inherit;background:#fff}
.override-table tr:hover td{background:var(--grey-50)}
.null-badge{display:inline-block;padding:1px 5px;border-radius:3px;font-size:9px;font-weight:700;background:#fef9c3;color:var(--amber)}
.null-badge.high{background:#fff1f2;color:var(--red)}

/* Profile NZV tab */
.nzv-table{width:100%;border-collapse:collapse;font-size:11px}
.nzv-table th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);padding:6px 10px;border-bottom:2px solid var(--grey-200);white-space:nowrap}
.nzv-table td{padding:5px 10px;border-bottom:1px solid var(--grey-100);color:var(--grey-700)}
.nzv-table tr:hover td{background:var(--grey-50)}

/* KS results table */
.ks-table{width:100%;border-collapse:collapse;font-size:11px}
.ks-table th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);padding:5px 10px;border-bottom:2px solid var(--grey-200)}
.ks-table td{padding:4px 10px;border-bottom:1px solid var(--grey-100)}
.ks-pass{color:var(--green);font-weight:700}
.ks-fail{color:var(--red);font-weight:700}

/* Coverage panel */
.coverage-table{width:100%;border-collapse:collapse;font-size:11px}
.coverage-table th{text-align:left;font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);padding:5px 10px;border-bottom:2px solid var(--grey-200)}
.coverage-table td{padding:4px 10px;border-bottom:1px solid var(--grey-100);vertical-align:top}
.missing-tag{display:inline-block;background:#fff1f2;color:var(--red);border-radius:3px;padding:1px 5px;font-size:9px;font-weight:600;margin:1px}
.phantom-tag{display:inline-block;background:#fef9c3;color:var(--amber);border-radius:3px;padding:1px 5px;font-size:9px;font-weight:600;margin:1px}

/* Run state indicator */
.run-state{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:5px;font-size:11px;margin-top:8px}
.run-state.running{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}
.run-state.done{background:var(--green-light);color:var(--green);border:1px solid var(--green-border)}
.run-state.error{background:#fff1f2;color:var(--red);border:1px solid #fecaca}
.run-spinner{width:12px;height:12px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}

/* Compare file zone */
.compare-zone{border:1px dashed var(--grey-300);border-radius:5px;padding:8px 10px;background:#fafbfc;position:relative;cursor:pointer}
.compare-zone:hover{border-color:var(--blue);background:var(--blue-light)}
.compare-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.compare-zone-text{font-size:10px;color:var(--grey-400);text-align:center}

/* Tabs in profile panel — add NZV */
/* nzv tab uses same color as other tabs */

/* ── Dashboard ─────────────────────────────────────────────────────────── */
.dashboard{max-width:none;margin:0;padding:24px 48px;height:calc(100vh - 48px);overflow-y:auto}
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.dash-select{font-size:11px;padding:4px 8px;border:1px solid var(--grey-200);border-radius:4px;background:#fff;color:var(--grey-600);cursor:pointer;font-family:inherit}
.dash-pills{display:flex;gap:6px;justify-content:flex-start}
.dash-pill{flex:0 0 auto;padding:5px 12px;border-radius:6px;text-align:center;min-width:70px}
.dash-wf-section{margin-bottom:24px}
.dash-wf-title{font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:10px}
.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.dash-card{background:#fff;border:1px solid var(--grey-200);border-radius:8px;padding:14px 16px;transition:box-shadow .15s,transform .15s}
.dash-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.08);transform:translateY(-1px)}
.dash-section{margin-top:28px}
.dash-section-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--grey-400);margin-bottom:10px}
.dash-activity-table{width:100%;border-collapse:collapse;font-size:11px}
.dash-activity-table th{padding:5px 10px;text-align:left;font-size:9px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--grey-400);border-bottom:2px solid var(--grey-200)}
.dash-activity-table td{padding:5px 10px;border-bottom:1px solid var(--grey-100)}
.dash-activity-table tr:hover td{background:var(--grey-50)}