/* ═══════════════════════════════════════════════════════════════
   SAR MANAGEMENT — Case Review & Triage
   ═══════════════════════════════════════════════════════════════ */

/* ── KPI Strip ── */
.sar-kpi-strip{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.sar-kpi{background:var(--card);border:1px solid var(--border2);border-radius:10px;padding:16px 20px;flex:1;min-width:120px;text-align:center;box-shadow:0 1px 4px rgba(0,0,0,0.04);}
.sar-kpi-val{font-size:1.6rem;font-weight:800;letter-spacing:-.03em;line-height:1.2;}
.sar-kpi-label{font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--mid);margin-top:4px;}

/* ── Filter Bar ── */
.sar-filter-bar{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap;}
.sar-filter-btn{height:32px;padding:0 14px;border:1.5px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.72rem;font-weight:600;cursor:pointer;background:#fff;color:var(--slate);transition:all .15s;}
.sar-filter-btn:hover{border-color:var(--forest);color:var(--forest);}
.sar-filter-btn.active{background:var(--forest);color:#fff;border-color:var(--forest);}

/* ── Split Layout ── */
.sar-split{display:grid;grid-template-columns:1fr;gap:20px;align-items:start;}
.sar-split:has(.sar-detail-wrap[style*="display: block"]){grid-template-columns:1fr 440px;}

/* Fallback for browsers without :has — JS toggles class */
.sar-split.sar-split-open{grid-template-columns:1fr 440px;}

.sar-table-wrap{background:var(--card);border:1px solid var(--border2);border-radius:10px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,0.06);}

/* ── Detail Wrap ── */
.sar-detail-wrap{background:var(--card);border:1px solid var(--border2);border-radius:10px;overflow-y:auto;max-height:calc(100vh - 200px);box-shadow:0 1px 6px rgba(0,0,0,0.06);}

.sar-detail-header{display:flex;align-items:flex-start;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border2);background:#f8fafc;}
.sar-detail-ref{font-family:monospace;font-size:.78rem;font-weight:700;color:var(--forest);margin-top:4px;}
.sar-close-detail{background:none;border:none;font-size:1.3rem;color:var(--mid);cursor:pointer;padding:0 4px;line-height:1;}
.sar-close-detail:hover{color:var(--charcoal);}

.sar-detail-section{padding:16px 20px;border-bottom:1px solid var(--border2);}
.sar-detail-section:last-child{border-bottom:none;}
.sar-detail-section-title{font-size:.6rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--forest);margin-bottom:10px;}

.sar-narrative-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mid);margin-bottom:4px;}
.sar-narrative-box{font-size:.78rem;color:var(--charcoal);line-height:1.6;white-space:pre-wrap;background:#f8fafc;border:1px solid var(--border2);border-radius:8px;padding:12px;font-weight:400;}

/* ── Status Pills ── */
.sar-status-pill{display:inline-block;font-size:.58rem;font-weight:700;padding:3px 9px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em;}
.sar-st-amber{background:var(--amber-pale);color:var(--amber);}
.sar-st-red{background:var(--red-pale);color:var(--red);}
.sar-st-green{background:var(--green-pale);color:var(--green);}
.sar-st-slate{background:rgba(0,0,0,0.06);color:var(--slate);}

/* ── Reference in table ── */
.sar-ref{font-family:monospace;font-size:.72rem;font-weight:600;color:var(--forest);}

/* ── Active row ── */
.sar-row-active td{background:var(--forest-pale) !important;}

/* ── Action Buttons ── */
.sar-action-section{background:#f8fafc;}
.sar-action-group{display:flex;flex-direction:column;gap:8px;}
.sar-action-btn{height:36px;padding:0 16px;border:2px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.75rem;font-weight:700;cursor:pointer;background:#fff;transition:all .15s;letter-spacing:.02em;}
.sar-action-btn:hover{opacity:.85;}
.sar-action-review{background:var(--forest);color:#fff;border-color:var(--forest);}
.sar-action-escalate{background:var(--red);color:#fff;border-color:var(--red);}
.sar-action-dismiss{background:var(--card);color:var(--slate);border-color:var(--border2);}
.sar-action-dismiss:hover{border-color:var(--slate);}
.sar-action-info{background:var(--amber-pale);color:var(--amber);border-color:var(--amber);}

/* ── Audit Trail ── */
.sar-audit-list{display:flex;flex-direction:column;gap:0;}
.sar-audit-entry{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.74rem;}
.sar-audit-entry:last-child{border-bottom:none;}
.sar-audit-time{color:var(--mid);min-width:110px;font-size:.68rem;flex-shrink:0;}
.sar-audit-body{color:var(--charcoal);flex:1;line-height:1.5;}
.sar-audit-role{color:var(--mid);font-weight:400;}

@media(max-width:1100px){
  .sar-split.sar-split-open{grid-template-columns:1fr;}
  .sar-detail-wrap{max-height:none;}
}

/* ═══════════════════════════════════════════════════════════════
   ADMIN PANEL — User Management
   ═══════════════════════════════════════════════════════════════ */

.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:16px;}
.admin-title{font-size:1.15rem;font-weight:800;color:var(--charcoal);letter-spacing:-.03em;}
.admin-sub{font-size:.76rem;color:var(--mid);margin-top:3px;}

.admin-table-wrap{background:var(--card);border:1px solid var(--border2);border-radius:10px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,0.06);}

/* ── Create Form Card ── */
.admin-create-form{margin-bottom:20px;}
.admin-form-card{background:var(--card);border:1px solid var(--border2);border-radius:10px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,0.06);}
.admin-form-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border2);background:#f8fafc;}
.admin-form-header h3{font-size:.88rem;font-weight:700;color:var(--charcoal);}
.admin-form-body{padding:20px;}

/* ── Ghost btn (ensure available in main tool context) ── */
.ghost-btn{height:38px;padding:0 16px;background:#fff;color:var(--mid);border:1.5px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .15s;}
.ghost-btn:hover{border-color:var(--forest);color:var(--forest);}

/* ── Status pill green (for active status) ── */
.sar-st-green{background:var(--green-pale);color:var(--green);}

/* ── SAR Sub-tabs ── */
.sar-subtab-bar{display:flex;gap:0;margin-bottom:20px;border-bottom:2px solid var(--border2);}
.sar-subtab{padding:10px 20px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;color:var(--mid);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .15s;}
.sar-subtab:hover{color:var(--forest);}
.sar-subtab.active{color:var(--forest);border-bottom-color:var(--forest);}

/* ── Admin Tab Checkboxes ── */
.admin-tabs-grid{display:flex;flex-direction:column;gap:4px;}
.admin-tab-section-label{font-size:.6rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);margin:8px 0 4px;padding-top:4px;}
.admin-tab-section-label:first-child{margin-top:0;}
.admin-tab-check{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:6px;cursor:pointer;transition:background .12s;user-select:none;}
.admin-tab-check:hover{background:var(--forest-pale);}
.admin-tab-check input[type="checkbox"]{accent-color:var(--forest);flex-shrink:0;}
.admin-tab-check span{font-size:.78rem;color:var(--charcoal);font-weight:500;}

/* ══════════════════════════════════════════════════════════
   USER MANAGEMENT (RBAC) — admin-panel.js
   ══════════════════════════════════════════════════════════ */

/* Layout */
.um-wrap{display:flex;flex-direction:column;gap:16px;}
.um-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:4px;}
.um-header-left{flex:1;}
.um-create-btn{width:auto;padding:0 20px;height:38px;font-size:.8rem;}

/* Filter bar */
.um-filter-bar{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid var(--border2);border-radius:9px;flex-wrap:wrap;}
.um-search-wrap{display:flex;align-items:center;gap:8px;color:var(--mid);flex:1;min-width:180px;}
.um-search-input{flex:1;border:none;outline:none;font-family:'Inter',sans-serif;font-size:.82rem;color:var(--charcoal);background:transparent;}
.um-search-input::placeholder{color:var(--mid);}
.um-filter-pills{display:flex;gap:4px;flex-wrap:wrap;}
.um-pill{height:28px;padding:0 12px;border:1.5px solid var(--border2);border-radius:20px;background:#fff;font-family:'Inter',sans-serif;font-size:.72rem;font-weight:600;color:var(--mid);cursor:pointer;transition:all .15s;white-space:nowrap;}
.um-pill:hover{border-color:var(--forest);color:var(--forest);}
.um-pill.active{background:var(--forest);border-color:var(--forest);color:#fff;}
.um-count-label{font-size:.68rem;color:var(--mid);white-space:nowrap;margin-left:auto;}

/* Table layout */
.um-table{width:100%;}
.um-row-inactive{opacity:.6;}
.um-row-inactive .um-user-name{text-decoration:line-through;text-decoration-color:var(--mid);}

/* User cell */
.um-user-cell{display:flex;align-items:center;gap:10px;}
.um-avatar{width:34px;height:34px;border-radius:50%;background:var(--forest);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:700;letter-spacing:.03em;flex-shrink:0;}
.um-avatar-inactive{background:var(--mid);}
.um-user-info{display:flex;flex-direction:column;gap:2px;}
.um-user-name{font-size:.82rem;font-weight:600;color:var(--charcoal);}
.um-user-meta{display:flex;align-items:center;gap:5px;font-size:.68rem;color:var(--mid);}
.um-user-username{font-family:'DM Mono','IBM Plex Mono',monospace;font-size:.66rem;color:var(--forest);}
.um-meta-sep{color:var(--border2);}

/* Role badges */
.um-role-badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:.66rem;font-weight:700;letter-spacing:.04em;white-space:nowrap;}
.role-MLRO   {background:rgba(220,38,38,0.1);  color:#b91c1c;}
.role-senior {background:rgba(217,119,6,0.1);  color:#b45309;}
.role-co     {background:rgba(1,84,65,0.1);    color:var(--forest);}
.role-screen {background:rgba(51,65,85,0.1);   color:var(--slate);}
.role-report {background:rgba(100,116,139,0.1);color:var(--mid);}
.role-staff  {background:rgba(100,116,139,0.1);color:var(--mid);}

/* Tab count */
.um-tab-count{display:flex;align-items:baseline;gap:2px;}
.um-tab-num{font-size:.84rem;font-weight:700;color:var(--charcoal);}
.um-tab-slash{font-size:.7rem;color:var(--mid);}

/* Row actions */
.um-actions{display:flex;gap:4px;flex-wrap:nowrap;}

/* Empty state */
.um-empty{display:flex;flex-direction:column;align-items:center;gap:10px;padding:56px 24px;color:var(--mid);text-align:center;}
.um-empty p{font-size:.9rem;font-weight:600;color:var(--slate);margin:0;}
.um-empty span{font-size:.76rem;}

/* Form section labels */
.um-section-label{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--forest);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.um-section-hint{font-size:.65rem;font-weight:400;text-transform:none;letter-spacing:0;color:var(--mid);}

/* Role hint strip */
.um-role-hint{display:flex;align-items:center;gap:6px;background:var(--forest-pale);border:1px solid var(--forest-pale2);border-radius:7px;padding:8px 12px;font-size:.73rem;color:var(--forest);margin-top:4px;}

/* Tab matrix — 2-column grid */
.um-tabs-matrix{display:grid;grid-template-columns:repeat(2,1fr);gap:0;background:var(--bg);border:1px solid var(--border2);border-radius:8px;padding:10px 12px;}
.um-tabs-matrix .admin-tab-section-label{grid-column:1/-1;margin-top:10px;}
.um-tabs-matrix .admin-tab-section-label:first-child{margin-top:0;}

/* Password strength */
.um-pw-strength{display:flex;align-items:center;gap:8px;margin-top:7px;}
.um-pw-bar{flex:1;height:4px;background:var(--border2);border-radius:4px;overflow:hidden;}
.um-pw-fill{height:100%;border-radius:4px;width:0;transition:width .25s,background .25s;}
.um-pw-label{font-size:.67rem;font-weight:700;min-width:52px;}

/* Password rules */
.um-pw-rules{display:flex;flex-direction:column;gap:3px;margin-top:6px;}
.um-pw-rule{display:flex;align-items:center;gap:6px;font-size:.67rem;color:var(--mid);transition:color .15s;}
.um-pw-rule.passed{color:var(--green);}
.um-rule-dot{width:7px;height:7px;border-radius:50%;background:var(--border2);flex-shrink:0;transition:background .15s;}

/* Password match */
.um-pw-match{margin-top:7px;font-size:.7rem;font-weight:600;display:flex;align-items:center;}
.um-pw-match-ok {color:var(--green);}
.um-pw-match-err{color:var(--red);}

/* Audit trail */
.um-audit-trail{display:flex;align-items:center;gap:6px;background:#f8fafc;border:1px solid var(--border2);border-radius:7px;padding:8px 12px;font-size:.68rem;color:var(--mid);margin-top:-2px;}

/* Deactivate modal */
.um-deactivate-header{background:var(--red-pale);border-bottom:1px solid rgba(220,38,38,0.15);}
.um-deactivate-body{display:flex;gap:14px;align-items:flex-start;}
.um-deactivate-icon{width:44px;height:44px;background:var(--red-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.um-deactivate-title{font-size:.88rem;font-weight:700;color:var(--charcoal);margin-bottom:8px;}
.um-deactivate-sub{font-size:.76rem;color:var(--mid);line-height:1.6;}

/* Form actions */
.um-form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border2);}

/* Password reset notice */
.um-reset-notice{display:flex;align-items:center;gap:6px;font-size:.72rem;color:var(--mid);background:#f8fafc;border:1px solid var(--border2);border-radius:7px;padding:8px 12px;}

/* Toast notification */
.um-toast{position:fixed;bottom:24px;right:24px;z-index:9999;background:var(--forest);color:#fff;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;padding:12px 18px;border-radius:10px;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px rgba(1,84,65,0.35);opacity:0;transform:translateY(8px);transition:opacity .25s,transform .25s;pointer-events:none;}
.um-toast-visible{opacity:1;transform:translateY(0);}

/* ══════════════════════════════════════════════
   ── TRAINING TAB ──
   ══════════════════════════════════════════════ */
.training-wrap{padding:28px 32px;width:100%;box-sizing:border-box;}
.training-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;}
.training-title{font-size:1.15rem;font-weight:700;color:var(--charcoal);letter-spacing:-.025em;}
.training-subtitle{font-size:.72rem;color:var(--mid);margin-top:3px;}
.training-header-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;}

.training-report-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;background:#00c471;color:#fff;border:none;border-radius:8px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s;box-shadow:0 2px 8px rgba(0,196,113,0.3);}
.training-report-btn:hover{background:#00a85f;box-shadow:0 4px 12px rgba(0,196,113,0.4);}
.training-csv-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;background:#fff;color:var(--forest);border:1.5px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;}
.training-csv-btn:hover{border-color:var(--forest);background:var(--forest-pale);}

.training-kpis{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;}
.train-kpi-chip{background:#fff;border:1px solid var(--border2);border-radius:10px;padding:12px 20px;min-width:120px;box-shadow:0 1px 4px rgba(0,0,0,0.05);}
.train-kpi-val{font-size:1.4rem;font-weight:700;color:var(--charcoal);line-height:1;}
.train-kpi-label{font-size:.65rem;color:var(--mid);font-weight:600;margin-top:5px;text-transform:uppercase;letter-spacing:.06em;}
.train-kpi-complete .train-kpi-val{color:#00c471;}
.train-kpi-pending .train-kpi-val{color:var(--amber);}
.train-kpi-overdue .train-kpi-val{color:var(--red);}

.training-filters{display:flex;align-items:flex-end;gap:14px;margin-bottom:18px;flex-wrap:wrap;background:#fff;border:1px solid var(--border2);border-radius:10px;padding:16px 20px;box-shadow:0 1px 4px rgba(0,0,0,0.04);}
.training-filter-group{display:flex;flex-direction:column;gap:5px;}
.training-filter-label{font-size:.65rem;font-weight:700;color:var(--charcoal);text-transform:uppercase;letter-spacing:.07em;}
.training-select{padding:7px 10px;border:1.5px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.8rem;color:var(--charcoal);background:#fff;outline:none;cursor:pointer;min-width:140px;transition:border-color .15s;}
.training-select:focus{border-color:var(--forest);}
.training-filter-reset{justify-content:flex-end;}
.training-reset-btn{padding:7px 14px;background:var(--forest-pale);color:var(--forest);border:1.5px solid transparent;border-radius:7px;font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;cursor:pointer;transition:all .15s;}
.training-reset-btn:hover{background:var(--forest-pale2);border-color:var(--forest);}

.training-table-wrap{background:#fff;border:1px solid var(--border2);border-radius:10px;overflow-x:auto;box-shadow:0 1px 6px rgba(0,0,0,0.05);width:100%;}
.training-table{width:100%;min-width:700px;border-collapse:collapse;font-size:.82rem;}
.training-table thead tr{background:var(--forest);}
.training-table thead th{padding:11px 14px;text-align:left;font-size:.68rem;font-weight:700;color:#fff;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;}
.training-table tbody tr{border-bottom:1px solid var(--border2);transition:background .12s;}
.training-table tbody tr:last-child{border-bottom:none;}
.training-table tbody tr:hover{background:#f8fffe;}
.training-table tbody td{padding:11px 14px;color:var(--charcoal);vertical-align:middle;}
.train-name{font-weight:600;}
.train-module{display:inline-block;background:rgba(1,84,65,0.07);color:var(--forest);padding:2px 8px;border-radius:5px;font-size:.72rem;font-weight:600;}
.train-expired{color:var(--red);font-weight:600;}

/* ── Inline row expansion ──────────────────────────────────────── */
.train-chevron-col{width:28px;text-align:center;padding-right:0;}
.train-chevron{display:inline-block;color:var(--mid);font-size:.85rem;transition:transform .15s ease;}
.train-chevron.open{transform:rotate(90deg);color:var(--forest);}
.training-table tbody tr.train-row{cursor:pointer;}
.training-table tbody tr.train-row:hover{background:rgba(1,84,65,0.04);}
.training-table tbody tr.train-row-open{background:rgba(1,84,65,0.06);}
.training-table tbody tr.train-detail-row{background:#fafbfc;}
.training-table tbody tr.train-detail-row > td{padding:0;border-top:none;}

.train-detail-panel{padding:18px 22px 22px;border-top:1px solid var(--border2);background:#fafbfc;}
.train-detail-loading{color:var(--mid);font-size:.85rem;padding:18px 0;}
.train-detail-empty{color:var(--mid);font-size:.85rem;padding:8px 0;}
.train-detail-section-title{font-size:.7rem;font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;}
.train-detail-summary{margin-bottom:18px;}
.train-detail-summary-table{width:100%;border-collapse:collapse;font-size:.8rem;}
.train-detail-summary-table thead tr{background:#fff;border-bottom:1px solid var(--border2);}
.train-detail-summary-table th{padding:8px 10px;text-align:left;font-weight:600;color:var(--mid);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;}
.train-detail-summary-table td{padding:8px 10px;border-bottom:1px solid var(--border2);color:var(--charcoal);background:#fff;}
.train-detail-summary-table tr:last-child td{border-bottom:none;}
.train-detail-summary-table .train-num{text-align:right;font-variant-numeric:tabular-nums;}

.train-detail-timeline{margin-bottom:18px;}
.train-timeline-list{list-style:none;padding:0;margin:0;border-left:2px solid rgba(1,84,65,0.18);}
.train-timeline-item{position:relative;padding:10px 12px 10px 18px;background:#fff;border:1px solid var(--border2);border-radius:8px;margin-bottom:8px;margin-left:8px;}
.train-timeline-item::before{content:'';position:absolute;left:-14px;top:14px;width:10px;height:10px;border-radius:50%;background:var(--forest);box-shadow:0 0 0 2px #fff;}
.train-timeline-date{font-weight:700;color:var(--charcoal);font-size:.85rem;margin-bottom:2px;}
.train-timeline-body{font-size:.78rem;color:var(--mid);}
.train-timeline-module{color:var(--charcoal);font-weight:600;margin-bottom:2px;}
.train-timeline-meta{font-size:.74rem;color:var(--mid);}

.train-detail-form{background:#fff;border:1px solid var(--border2);border-radius:8px;padding:14px 16px;}
.train-form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-bottom:10px;}
.train-form-row:last-child{margin-bottom:0;}
.train-form-cell{flex:1 1 180px;min-width:0;display:flex;flex-direction:column;}
.train-form-cell-wide{flex:2 1 360px;}
.train-form-submit{flex:0 0 auto;align-self:flex-end;}
.train-form-record-btn{background:var(--forest);color:#fff;border:none;border-radius:6px;padding:9px 18px;font-weight:600;font-size:.82rem;cursor:pointer;}
.train-form-record-btn:hover{background:#016e54;}
.train-form-record-btn:disabled{opacity:.6;cursor:not-allowed;}

.train-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.03em;}
.train-badge::before{content:'';display:inline-block;width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.train-badge.complete{background:rgba(0,196,113,0.12);color:#00a85f;}
.train-badge.complete::before{background:#00c471;}
.train-badge.pending{background:var(--amber-pale);color:var(--amber);}
.train-badge.pending::before{background:var(--amber);}
.train-badge.overdue{background:var(--red-pale);color:var(--red);}
.train-badge.overdue::before{background:var(--red);}

.training-empty{padding:40px;text-align:center;color:var(--mid);font-size:.85rem;}

/* ── Add Employee button ── */
.training-add-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;background:var(--forest);color:#fff;border:none;border-radius:8px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s;box-shadow:0 2px 8px rgba(1,84,65,0.25);}
.training-add-btn:hover{background:#013d2e;box-shadow:0 4px 12px rgba(1,84,65,0.35);}

/* ── Search bar ── */
.training-search-bar{margin-bottom:14px;}
.training-search-wrap{position:relative;display:inline-flex;align-items:center;width:300px;max-width:100%;}
.training-search-icon{position:absolute;left:10px;pointer-events:none;flex-shrink:0;}
.training-search-input{width:100%;padding:8px 36px 8px 32px;border:1.5px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.82rem;color:var(--charcoal);background:#fff;outline:none;transition:border-color .15s;box-sizing:border-box;}
.training-search-input:focus{border-color:var(--forest);}
.training-search-input::placeholder{color:#94a3b8;}
.training-search-clear{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:#94a3b8;font-size:.9rem;line-height:1;padding:2px 4px;display:inline-flex;align-items:center;transition:color .13s;}
.training-search-clear:hover{color:var(--charcoal);}

/* ── Add Employee modal form ── */
.train-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:520px){.train-form-grid{grid-template-columns:1fr;}}
.train-form-group{display:flex;flex-direction:column;gap:5px;}
.train-form-label{font-size:.68rem;font-weight:700;color:var(--charcoal);text-transform:uppercase;letter-spacing:.07em;}
.train-form-req{color:var(--red);margin-left:2px;}
.train-form-input{padding:8px 11px;border:1.5px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.83rem;color:var(--charcoal);background:#fff;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box;}
.train-form-input:focus{border-color:var(--forest);}
.train-form-error{font-size:.72rem;color:var(--red);min-height:16px;margin-top:1px;}
.train-modal-cancel{padding:9px 18px;background:#fff;color:var(--charcoal);border:1.5px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;}
.train-modal-cancel:hover{border-color:var(--charcoal);}
.train-modal-submit{padding:9px 20px;background:var(--forest);color:#fff;border:none;border-radius:8px;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:600;cursor:pointer;transition:background .15s;box-shadow:0 2px 8px rgba(1,84,65,0.25);}
.train-modal-submit:hover{background:#013d2e;}
.train-modal-submit:disabled{opacity:.6;cursor:not-allowed;}

/* ═══════════════════════════════════════════════════════════════
   COMPLICORE INTEL — EXTERNAL REPORTS
   ═══════════════════════════════════════════════════════════════ */

/* Hero */
.ccx-hero{background:#0F3D24;border-radius:10px;padding:22px 28px;margin-bottom:20px;position:relative;transition:padding .18s ease;}
.ccx-hero-inner{display:flex;align-items:flex-start;gap:18px;padding-right:28px;}
.ccx-hero-toggle{position:absolute;top:10px;right:10px;width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:6px;color:rgba(255,255,255,0.55);cursor:pointer;transition:background .15s,color .15s;padding:0;}
.ccx-hero-toggle:hover{background:rgba(255,255,255,0.1);color:#fff;}
.ccx-hero-toggle:focus-visible{outline:2px solid rgba(255,255,255,0.6);outline-offset:2px;}

/* Collapsed hero — drops the marketing copy, shrinks the strip to ~42px,
   and centers the brand line with the toggle button. */
.ccx-hero.collapsed{padding-top:10px;padding-bottom:10px;}
.ccx-hero.collapsed .ccx-hero-inner{align-items:center;}
.ccx-hero.collapsed .ccx-hero-text{display:none;}
.ccx-hero-logo{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.ccx-hero-brand{font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;color:#fff;letter-spacing:-.02em;}
.ccx-hero-text{flex:1;}
.ccx-hero-headline{font-size:.88rem;font-weight:600;color:#fff;line-height:1.55;margin-bottom:5px;}
.ccx-hero-sub{font-size:.74rem;color:rgba(255,255,255,0.55);line-height:1.5;}

/* Layout */
.ccx-layout{display:grid;grid-template-columns:440px 1fr;gap:20px;align-items:start;}
.ccx-form-col{}
.ccx-audit-col{}

/* Card */
.ccx-card{background:#fff;border:1px solid var(--border2);border-radius:10px;overflow:hidden;box-shadow:0 1px 6px rgba(0,0,0,0.06);}
.ccx-card-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--border2);background:#fafbfc;gap:10px;}
.ccx-card-title{font-size:.85rem;font-weight:700;color:var(--charcoal);letter-spacing:-.02em;}

/* Credits widget */
.ccx-credits-widget{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.ccx-credits-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--mid);}
.ccx-credits-val{font-size:.95rem;font-weight:800;color:var(--forest);font-family:'Sora',sans-serif;min-width:42px;text-align:right;}
.ccx-credits-val.warn{color:var(--amber);}
.ccx-credits-val.danger{color:var(--red);}
.ccx-credits-link{font-size:.68rem;font-weight:600;color:var(--forest);background:none;border:1px solid var(--forest);border-radius:5px;padding:3px 9px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap;font-family:'Inter',sans-serif;}
.ccx-credits-link:hover{background:var(--forest);color:#fff;}

/* Form */
.ccx-form{padding:20px;}
.ccx-form-section{margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid var(--border);}
.ccx-form-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.ccx-section-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mid);margin-bottom:12px;}
.ccx-fgroup{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;}
.ccx-fgroup:last-child{margin-bottom:0;}
.ccx-frow{display:grid;gap:10px;}
.ccx-c2{grid-template-columns:1fr 1fr;}
.ccx-label{font-size:.74rem;font-weight:600;color:var(--slate);}
.ccx-opt{font-size:.62rem;font-weight:400;color:var(--mid);margin-left:4px;}
.ccx-req{color:var(--red);margin-left:2px;}
.ccx-input{width:100%;padding:8px 11px;border:1px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.8rem;color:var(--charcoal);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none;}
.ccx-input:focus{border-color:var(--forest);box-shadow:0 0 0 3px rgba(1,84,65,0.08);}
.ccx-input.error{border-color:var(--red);}
.ccx-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer;}
.ccx-textarea{resize:vertical;min-height:64px;}
.ccx-field-error{font-size:.68rem;color:var(--red);margin-top:2px;}
.ccx-add-link{display:inline-flex;align-items:center;gap:6px;font-size:.72rem;font-weight:600;color:var(--forest);background:none;border:none;cursor:pointer;padding:0;font-family:'Inter',sans-serif;margin-top:4px;transition:opacity .15s;}
.ccx-add-link:hover{opacity:.7;}

/* Extra field tags (additional companies/nationalities) */
.ccx-extra-field{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.ccx-extra-field input{flex:1;}
.ccx-remove-btn{width:24px;height:24px;border-radius:50%;border:1px solid var(--border2);background:#fff;color:var(--mid);font-size:.9rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,color .15s,border-color .15s;}
.ccx-remove-btn:hover{background:var(--red-pale);border-color:var(--red);color:var(--red);}

/* File upload */
.ccx-upload-zone{border:1.5px dashed var(--border2);border-radius:8px;padding:18px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--mid);}
.ccx-upload-zone:hover,.ccx-upload-zone.drag{border-color:var(--forest);background:var(--forest-pale);}
.ccx-upload-label{font-size:.74rem;color:var(--slate);}
.ccx-upload-link{color:var(--forest);font-weight:600;text-decoration:underline;cursor:pointer;}
.ccx-file-list{display:flex;flex-direction:column;gap:4px;margin-top:6px;}
.ccx-file-item{display:flex;align-items:center;gap:8px;padding:5px 10px;background:#f8fafc;border-radius:6px;font-size:.72rem;color:var(--charcoal);}
.ccx-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.ccx-file-size{color:var(--mid);font-size:.65rem;flex-shrink:0;}
.ccx-file-rm{background:none;border:none;color:var(--mid);cursor:pointer;font-size:.85rem;padding:0;line-height:1;flex-shrink:0;transition:color .15s;}
.ccx-file-rm:hover{color:var(--red);}

/* Turnaround options */
/* Subject Type toggle — segmented control sitting at the top of the order
   form. Drives the show/hide of Individual vs. Corporate field groups. */
.ccx-subject-type-toggle{display:inline-flex;background:#f1f5f9;border:1px solid var(--border2);border-radius:9px;padding:3px;gap:2px;}
.ccx-subject-type-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;font-family:'Inter',sans-serif;font-size:.78rem;font-weight:600;color:var(--mid);background:transparent;border:none;border-radius:6px;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s;}
.ccx-subject-type-btn:hover{color:var(--charcoal);}
.ccx-subject-type-btn.active{background:#fff;color:var(--forest);box-shadow:0 1px 3px rgba(0,0,0,0.08);}
.ccx-subject-type-btn svg{flex-shrink:0;}

.ccx-turnaround-group{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.ccx-turnaround-option{cursor:pointer;border:1.5px solid var(--border2);border-radius:8px;padding:12px 14px;transition:border-color .15s,background .15s;display:block;}
.ccx-turnaround-option:has(input:checked){border-color:var(--forest);background:var(--forest-pale);}
.ccx-turnaround-option input[type=radio]{position:absolute;opacity:0;pointer-events:none;}
.ccx-turnaround-body{display:flex;flex-direction:column;gap:3px;}
.ccx-turnaround-title{font-size:.82rem;font-weight:700;color:var(--charcoal);}
.ccx-turnaround-meta{font-size:.68rem;color:var(--mid);}
.ccx-turnaround-credit{font-size:1.05rem;font-weight:800;color:var(--forest);font-family:'Sora',sans-serif;margin-top:4px;letter-spacing:-.01em;}
.ccx-turnaround-price{font-size:.68rem;font-weight:500;color:var(--mid);margin-top:1px;}

/* Form footer */
.ccx-form-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid var(--border2);margin-top:16px;}
.ccx-form-note{font-size:.7rem;color:var(--mid);flex:1;}
.ccx-form-note.warn{color:var(--amber);font-weight:600;}
.ccx-submit-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;background:var(--forest);color:#fff;border:none;border-radius:8px;font-family:'Inter',sans-serif;font-size:.82rem;font-weight:700;cursor:pointer;transition:background .15s,opacity .15s;letter-spacing:.01em;}
.ccx-submit-btn:disabled{opacity:.4;cursor:not-allowed;}
.ccx-submit-btn:not(:disabled):hover{background:#013d2f;}

/* Audit trail */
.ccx-audit-filters{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border2);flex-wrap:wrap;}
.ccx-audit-search{flex:1;min-width:160px;padding:7px 11px;border:1px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.77rem;color:var(--charcoal);background:#fff;outline:none;transition:border-color .15s;}
.ccx-audit-search:focus{border-color:var(--forest);}
.ccx-audit-sel{padding:7px 28px 7px 10px;border:1px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.75rem;color:var(--charcoal);background:#fff;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2364748b' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;}
.ccx-audit-date{padding:6px 10px;border:1px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.74rem;color:var(--charcoal);background:#fff;outline:none;cursor:pointer;}
.ccx-audit-count{font-size:.7rem;color:var(--mid);font-weight:500;white-space:nowrap;}

.ccx-audit-table-wrap{overflow-x:auto;}
.ccx-audit-loading{display:flex;align-items:center;gap:8px;padding:32px;color:var(--mid);font-size:.78rem;}
.ccx-audit-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;color:var(--mid);font-size:.78rem;text-align:center;}
.ccx-audit-empty svg{opacity:.3;margin-bottom:4px;}
.ccx-audit-empty p{font-weight:600;color:var(--slate);}

.ccx-audit-table{width:100%;border-collapse:collapse;font-size:.75rem;}
.ccx-audit-table thead tr{background:#fafbfc;border-bottom:1px solid var(--border2);}
.ccx-audit-table th{padding:10px 14px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--mid);text-align:left;white-space:nowrap;}
.ccx-audit-table td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--charcoal);vertical-align:middle;}
.ccx-audit-table tbody tr:last-child td{border-bottom:none;}
.ccx-audit-table tbody tr:hover td{background:#f9fafb;}
.ccx-audit-ref{font-family:monospace;font-size:.72rem;font-weight:700;color:var(--forest);cursor:pointer;white-space:nowrap;}
.ccx-audit-ref:hover{text-decoration:underline;}
.ccx-audit-subject{font-weight:600;color:var(--charcoal);}
.ccx-audit-company{font-size:.68rem;color:var(--mid);margin-top:1px;}
.ccx-audit-date-cell{font-size:.7rem;color:var(--slate);white-space:nowrap;}
.ccx-audit-credit{font-size:.72rem;font-weight:700;color:var(--charcoal);}
.ccx-audit-by{font-size:.68rem;color:var(--mid);}

/* Status badges
   Lifecycle: Pending (amber) -> Delivered (blue) -> Under Review (orange) ->
   Complete (green). Cancelled (grey) is a terminal state from Pending only.
   .ccx-status-progress kept for any legacy data in localStorage that has not
   yet migrated to 'Pending'. */
.ccx-status{display:inline-block;font-size:.6rem;font-weight:700;padding:3px 9px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;}
.ccx-status-progress{background:var(--amber-pale);color:var(--amber);}
.ccx-status-pending{background:var(--amber-pale);color:var(--amber);}
.ccx-status-delivered{background:rgba(59,130,246,0.1);color:#2563eb;}
.ccx-status-review{background:rgba(234,88,12,0.1);color:#c2410c;}
.ccx-status-complete{background:var(--green-pale);color:var(--green);}
.ccx-status-returned{background:rgba(234,88,12,0.1);color:#c2410c;}
.ccx-status-cancelled{background:rgba(0,0,0,0.06);color:var(--mid);}

/* Actions cell layout */
.ccx-actions-cell{display:inline-flex;align-items:center;gap:6px;}

/* Inline action element — at most one per row. Active states (Delivered,
   Complete) render a neutral pill button; passive terminal/in-flight states
   (Pending, Returned, Cancelled) render a muted text label instead. Colour
   vocabulary is reserved entirely for the Status badge column. */
.ccx-inline-action-btn{padding:5px 10px;border:1px solid var(--border2);border-radius:6px;background:#fff;font-family:'Inter',sans-serif;font-size:.7rem;font-weight:600;color:var(--slate);cursor:pointer;transition:background .15s;white-space:nowrap;}
.ccx-inline-action-btn:hover{background:#f1f5f9;}
.ccx-inline-passive{display:inline-block;padding:5px 10px;font-family:'Inter',sans-serif;font-size:.7rem;font-weight:500;color:var(--mid);font-style:italic;white-space:nowrap;}

/* Cancel-reason modal — mandatory rationale before a Pending order can be
   cancelled. Required for MLR 2017 Reg 40 audit completeness. */
.ccx-cancel-reason-input{width:100%;min-height:90px;border:1px solid var(--border2);border-radius:7px;padding:10px 12px;font-family:'Inter',sans-serif;font-size:.8rem;color:var(--charcoal);resize:vertical;}
.ccx-cancel-reason-input:focus{outline:none;border-color:var(--forest);}
.ccx-cancel-reason-err{font-size:.72rem;color:var(--red);margin-top:6px;display:none;}
.ccx-cancel-reason-err.show{display:block;}

/* Timeline transition row — renders from -> to and any captured reason. */
.ccx-timeline-transition{font-size:.7rem;color:var(--mid);margin-top:2px;}
.ccx-timeline-reason{font-size:.7rem;color:var(--slate);margin-top:3px;padding:6px 9px;background:rgba(0,0,0,0.03);border-left:2px solid var(--border2);border-radius:0 4px 4px 0;}

/* Actions dropdown */
.ccx-actions-wrap{position:relative;}
.ccx-actions-btn{padding:5px 10px;border:1px solid var(--border2);border-radius:6px;background:#fff;font-family:'Inter',sans-serif;font-size:.7rem;font-weight:500;color:var(--slate);cursor:pointer;transition:background .15s;white-space:nowrap;}
.ccx-actions-btn:hover{background:#f1f5f9;}
.ccx-actions-menu{position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--border2);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,0.12);z-index:200;min-width:180px;overflow:hidden;}
.ccx-actions-menu button{display:block;width:100%;padding:9px 14px;font-family:'Inter',sans-serif;font-size:.76rem;font-weight:500;color:var(--charcoal);background:none;border:none;text-align:left;cursor:pointer;transition:background .15s;}
.ccx-actions-menu button:hover{background:#f1f5f9;}
.ccx-actions-menu button.danger{color:var(--red);}
.ccx-actions-menu button:disabled{color:var(--mid);cursor:not-allowed;}
.ccx-actions-menu button:disabled:hover{background:none;}
.ccx-actions-menu .ccx-menu-divider{height:1px;background:var(--border2);margin:4px 0;}

/* Modals */
.ccx-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:1000;display:none;align-items:center;justify-content:center;}
.ccx-modal-overlay.open{display:flex;}
.ccx-modal{background:#fff;border-radius:12px;box-shadow:0 8px 40px rgba(0,0,0,0.18);width:480px;max-width:92vw;max-height:88vh;overflow-y:auto;display:flex;flex-direction:column;}
.ccx-modal-wide{width:580px;}
.ccx-modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--border2);}
.ccx-modal-title{font-size:.92rem;font-weight:700;color:var(--charcoal);letter-spacing:-.02em;}
.ccx-modal-close{background:none;border:none;font-size:1.3rem;color:var(--mid);cursor:pointer;padding:0;line-height:1;transition:color .15s;}
.ccx-modal-close:hover{color:var(--charcoal);}
.ccx-modal-body{padding:20px 22px;flex:1;}
.ccx-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 22px;border-top:1px solid var(--border2);}
.ccx-modal-info{font-size:.78rem;color:var(--slate);background:#f8fafc;border:1px solid var(--border2);border-radius:7px;padding:10px 14px;}
.ccx-modal-confirm{display:flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;color:var(--green);background:var(--green-pale);border-radius:7px;padding:10px 14px;margin-top:14px;}

/* Modal buttons */
.ccx-btn-primary{padding:9px 20px;background:var(--forest);color:#fff;border:none;border-radius:7px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:700;cursor:pointer;transition:background .15s;white-space:nowrap;}
.ccx-btn-primary:hover{background:#013d2f;}
.ccx-btn-secondary{padding:9px 18px;background:#fff;color:var(--slate);border:1px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.ccx-btn-secondary:hover{background:#f1f5f9;}
.ccx-btn-primary:disabled{background:var(--border2) !important;color:var(--mid);cursor:not-allowed;}
.ccx-btn-primary:disabled:hover{background:var(--border2) !important;}

/* Context strip inside reason modals — shows the report Reference + Subject so
   the reviewer has at-a-glance confirmation of which row they're acting on. */
.ccx-modal-context-strip{display:flex;flex-direction:column;gap:6px;background:#f8fafc;border:1px solid var(--border2);border-radius:7px;padding:10px 14px;margin-bottom:14px;}
.ccx-modal-context-row{display:flex;align-items:baseline;gap:10px;font-size:.74rem;}
.ccx-modal-context-label{flex:0 0 80px;color:var(--mid);font-weight:600;text-transform:uppercase;letter-spacing:.06em;font-size:.62rem;}
.ccx-modal-context-val{color:var(--charcoal);font-weight:600;}

/* Confirmation modal content */
.ccx-confirm-ref{font-family:monospace;font-size:1.1rem;font-weight:800;color:var(--forest);background:var(--forest-pale);padding:10px 16px;border-radius:8px;display:inline-block;margin-bottom:16px;letter-spacing:.04em;}
.ccx-confirm-grid{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:.78rem;margin-bottom:16px;}
.ccx-confirm-key{color:var(--mid);font-weight:500;}
.ccx-confirm-val{color:var(--charcoal);font-weight:600;}
.ccx-confirm-new-bal{font-size:.8rem;font-weight:700;color:var(--forest);background:var(--forest-pale);border-radius:6px;padding:8px 12px;margin-top:10px;display:inline-flex;align-items:center;gap:6px;}

/* Order details modal */
.ccx-details-section{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border);}
.ccx-details-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0;}
.ccx-details-section-title{font-size:.64rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--mid);margin-bottom:10px;}
.ccx-details-grid{display:grid;grid-template-columns:130px 1fr;gap:5px 12px;font-size:.78rem;}
.ccx-details-key{color:var(--mid);font-weight:500;}
.ccx-details-val{color:var(--charcoal);font-weight:600;word-break:break-word;}
.ccx-details-val a{color:var(--forest);text-decoration:underline;}
.ccx-timeline{display:flex;flex-direction:column;gap:0;}
.ccx-timeline-item{display:flex;gap:12px;padding:8px 0;position:relative;}
.ccx-timeline-item::before{content:'';position:absolute;left:7px;top:24px;width:1px;height:calc(100% - 8px);background:var(--border2);}
.ccx-timeline-item:last-child::before{display:none;}
.ccx-timeline-dot{width:16px;height:16px;border-radius:50%;border:2px solid var(--border2);background:#fff;flex-shrink:0;margin-top:2px;}
.ccx-timeline-dot.done{border-color:var(--forest);background:var(--forest);}
.ccx-timeline-dot.active{border-color:var(--amber);background:var(--amber);}
.ccx-timeline-body{flex:1;}
.ccx-timeline-label{font-size:.76rem;font-weight:600;color:var(--charcoal);}
.ccx-timeline-time{font-size:.68rem;color:var(--mid);margin-top:1px;}

/* ══════════════════════════════════════════════════════════
   BUILD NOTES
   ══════════════════════════════════════════════════════════ */

.bn-wrap{padding:28px 32px;width:100%;box-sizing:border-box;}

/* ── Header ── */
.bn-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px;flex-wrap:wrap;}
.bn-title{font-family:'Sora','DM Sans',sans-serif;font-size:1.35rem;font-weight:800;color:var(--charcoal);letter-spacing:-.03em;}
.bn-subtitle{font-size:.75rem;color:var(--mid);margin-top:3px;font-weight:400;}
.bn-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex-shrink:0;}

/* ── Buttons ── */
.bn-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;border:none;font-family:'Inter',sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s;}
.bn-btn-add{background:var(--forest);color:#fff;}
.bn-btn-add:hover{background:#017a5e;}
.bn-btn-adhoc{background:rgba(1,84,65,0.08);color:var(--forest);border:1px solid rgba(1,84,65,0.2);}
.bn-btn-adhoc:hover{background:rgba(1,84,65,0.14);}
.bn-btn-csv,.bn-btn-pdf{background:#fff;color:var(--slate);border:1px solid var(--border2);}
.bn-btn-csv:hover,.bn-btn-pdf:hover{background:var(--forest-pale);color:var(--forest);border-color:var(--forest);}

/* ── KPIs ── */
.bn-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:18px;}
.bn-kpi-chip{background:#fff;border:1px solid var(--border2);border-radius:10px;padding:12px 18px;min-width:0;box-shadow:0 1px 4px rgba(0,0,0,0.04);border-top:3px solid var(--border2);}
.bn-kpi-chip.bn-kpi-open{border-top-color:#3b82f6;}
.bn-kpi-chip.bn-kpi-inprog{border-top-color:var(--amber);}
.bn-kpi-chip.bn-kpi-done{border-top-color:#00c471;}
.bn-kpi-chip.bn-kpi-high{border-top-color:var(--red);}
.bn-kpi-val{font-family:'Sora',sans-serif;font-size:1.55rem;font-weight:800;color:var(--charcoal);letter-spacing:-.04em;line-height:1;}
.bn-kpi-label{font-size:.67rem;color:var(--mid);font-weight:500;margin-top:4px;white-space:nowrap;}

/* ── Filters ── */
.bn-filters{background:#fff;border:1px solid var(--border2);border-radius:10px;padding:16px 18px;margin-bottom:16px;box-shadow:0 1px 4px rgba(0,0,0,0.04);}
.bn-filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;align-items:end;margin-bottom:10px;}
.bn-filter-row:last-child{margin-bottom:0;}
.bn-filter-group{display:flex;flex-direction:column;gap:4px;min-width:0;}
.bn-filter-reset-wrap{justify-content:flex-end;}
.bn-filter-label{font-size:.65rem;font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:.06em;}
.bn-select,.bn-input{padding:7px 10px;border:1.5px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.8rem;color:var(--charcoal);background:#fff;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box;}
.bn-select:focus,.bn-input:focus{border-color:var(--forest);box-shadow:0 0 0 3px rgba(1,84,65,0.08);}
.bn-reset-btn{padding:7px 14px;border:1.5px solid var(--border2);border-radius:7px;background:#fff;font-family:'Inter',sans-serif;font-size:.75rem;font-weight:600;color:var(--mid);cursor:pointer;transition:all .15s;white-space:nowrap;}
.bn-reset-btn:hover{background:var(--forest-pale);color:var(--forest);border-color:var(--forest);}

/* ── Search bar ── */
.bn-search-bar{margin-top:10px;}
.bn-search-wrap{position:relative;max-width:380px;}
.bn-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);pointer-events:none;}
.bn-search-input{width:100%;padding:8px 34px 8px 34px;border:1.5px solid var(--border2);border-radius:8px;font-family:'Inter',sans-serif;font-size:.82rem;color:var(--charcoal);background:#fff;outline:none;transition:border-color .15s;box-sizing:border-box;}
.bn-search-input:focus{border-color:var(--forest);box-shadow:0 0 0 3px rgba(1,84,65,0.08);}
.bn-search-clear{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--mid);font-size:.85rem;display:none;align-items:center;justify-content:center;padding:2px;}

/* ── Table ── */
.bn-table-wrap{background:#fff;border:1px solid var(--border2);border-radius:10px;overflow-x:auto;box-shadow:0 1px 6px rgba(0,0,0,0.05);width:100%;}
.bn-table{width:100%;min-width:960px;border-collapse:collapse;font-size:.8rem;}
.bn-table thead tr{background:var(--forest);}
.bn-table thead th{padding:11px 12px;text-align:left;font-size:.66rem;font-weight:700;color:#fff;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;}
.bn-table tbody tr{border-bottom:1px solid var(--border2);transition:background .12s;}
.bn-table tbody tr:last-child{border-bottom:none;}
.bn-table tbody tr:hover{background:#f8fffe;}
.bn-table tbody td{padding:10px 12px;color:var(--charcoal);vertical-align:middle;}
.bn-col-note{max-width:280px;cursor:help;}
.bn-col-dim{color:var(--slate);}
.bn-col-page{max-width:140px;}
.bn-col-date{white-space:nowrap;font-size:.75rem;}
.bn-loading{text-align:center;padding:40px;color:var(--mid);font-size:.82rem;}

/* ── Empty state ── */
.bn-empty{padding:52px 24px;text-align:center;color:var(--mid);}
.bn-empty-icon{width:52px;height:52px;background:var(--forest-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--forest);}
.bn-empty-title{font-size:.95rem;font-weight:700;color:var(--slate);margin-bottom:6px;}
.bn-empty-sub{font-size:.8rem;color:var(--mid);}

/* ── Actions ── */
.bn-actions-cell{white-space:nowrap;}
.bn-act-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border2);border-radius:6px;background:#fff;cursor:pointer;color:var(--mid);transition:all .13s;}
.bn-act-btn:hover{background:var(--forest-pale);color:var(--forest);border-color:var(--forest);}
.bn-act-del:hover{background:var(--red-pale);color:var(--red);border-color:var(--red);}

/* ── Type badges ── */
.bn-type-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:5px;font-size:.67rem;font-weight:700;white-space:nowrap;letter-spacing:.02em;}
.bn-type-bug      {background:rgba(220,38,38,0.1);  color:#b91c1c;}
.bn-type-ux       {background:rgba(124,58,237,0.1); color:#6d28d9;}
.bn-type-feature  {background:rgba(59,130,246,0.1); color:#2563eb;}
.bn-type-idea     {background:rgba(217,119,6,0.1);  color:#b45309;}
.bn-type-compliance{background:rgba(1,84,65,0.1);   color:#015441;}
.bn-type-content  {background:rgba(13,148,136,0.1); color:#0f766e;}
.bn-type-tech     {background:rgba(234,88,12,0.1);  color:#c2410c;}
.bn-type-other    {background:rgba(100,116,139,0.1);color:#475569;}

/* ── Priority badges ── */
.bn-pri-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:5px;font-size:.67rem;font-weight:700;white-space:nowrap;}
.bn-pri-low  {background:rgba(0,196,113,0.1); color:#00a85f;}
.bn-pri-med  {background:rgba(59,130,246,0.1);color:#2563eb;}
.bn-pri-high {background:rgba(234,88,12,0.1); color:#c2410c;}
.bn-pri-crit {background:rgba(220,38,38,0.1); color:#b91c1c;}

/* ── Status badges ── */
.bn-status-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:5px;font-size:.67rem;font-weight:700;white-space:nowrap;}
.bn-status-open   {background:rgba(59,130,246,0.1); color:#2563eb;}
.bn-status-inprog {background:rgba(217,119,6,0.1);  color:#b45309;}
.bn-status-done   {background:rgba(0,196,113,0.1);  color:#00a85f;}
.bn-status-wontfix{background:rgba(100,116,139,0.1);color:#475569;}
.bn-status-deferred{background:rgba(71,85,105,0.08);color:#64748b;}

/* ── Add / Edit form ── */
.bn-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:20px 22px 10px;}
.bn-form-span2{grid-column:1/-1;}
.bn-form-group{display:flex;flex-direction:column;gap:5px;}
.bn-form-label{font-size:.68rem;font-weight:700;color:var(--charcoal);letter-spacing:.06em;text-transform:uppercase;}
.bn-form-req{color:var(--red);font-style:normal;}
.bn-form-input,.bn-form-select{padding:9px 11px;border:1.5px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.85rem;color:var(--charcoal);background:#fff;outline:none;transition:border-color .15s;width:100%;box-sizing:border-box;}
.bn-form-input:focus,.bn-form-select:focus{border-color:var(--forest);box-shadow:0 0 0 3px rgba(1,84,65,0.08);}
.bn-form-textarea{padding:9px 11px;border:1.5px solid var(--border2);border-radius:7px;font-family:'Inter',sans-serif;font-size:.85rem;color:var(--charcoal);background:#fff;outline:none;resize:vertical;width:100%;box-sizing:border-box;transition:border-color .15s;line-height:1.5;}
.bn-form-textarea:focus{border-color:var(--forest);box-shadow:0 0 0 3px rgba(1,84,65,0.08);}
.bn-form-err{font-size:.72rem;color:var(--red);min-height:16px;}

/* ── Auto-captured context strip ── */
.bn-form-ctx{background:var(--forest-pale);border-radius:8px;padding:10px 14px;margin:8px 22px 4px;font-size:.72rem;}
.bn-form-ctx-title{font-size:.63rem;font-weight:700;color:var(--forest);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px;}
.bn-form-ctx-row{display:flex;gap:8px;margin-bottom:4px;align-items:baseline;}
.bn-form-ctx-row:last-child{margin-bottom:0;}
.bn-ctx-key{font-weight:700;color:var(--forest);min-width:80px;flex-shrink:0;font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;}
.bn-ctx-val{color:var(--slate);word-break:break-all;}
.bn-ctx-trunc{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px;display:block;}
