:root {
  --primary:#6b6b6b; --primary-dk:#555555; --primary-lt:#f3f3f3;
  --success:#2e7d5e; --success-lt:#e6f5ed;
  --warning:#b8862e; --warning-lt:#fdf5e0;
  --danger:#c4403a; --danger-lt:#fde8e6;
  --sidebar:#f0ece8; --sidebar-txt:#8b7e74;
  --border:#e8e4df; --bg:#f5f3f0; --white:#fff;
  --text:#2d2b28; --muted:#7a756e;
  --sb-w:210px; --topbar-h:52px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);display:flex;flex-direction:column;height:100vh;overflow:hidden;font-size:14px;}
a{text-decoration:none;}

/* ─── APP SHELL & TOPBAR ─── */
#app-shell{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden;}
#app-body{flex:1;display:flex;min-height:0;overflow:hidden;}
#topbar{height:var(--topbar-h);display:flex;align-items:stretch;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;box-shadow:0 1px 2px rgba(0,0,0,.04);position:relative;z-index:10;}
.tb-left{width:var(--sb-w);display:flex;align-items:center;gap:6px;padding:0 10px;background:var(--sidebar);border-right:1px solid var(--border);transition:width .2s ease;flex-shrink:0;overflow:hidden;}
.tb-collapse{background:none;border:none;cursor:pointer;padding:6px 8px;border-radius:6px;color:var(--sidebar-txt);font-size:18px;line-height:1;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;}
.tb-collapse:hover{background:rgba(0,0,0,.06);color:var(--text);}
.tb-logo{flex:1;display:flex;align-items:center;justify-content:center;min-width:0;overflow:hidden;}
.tb-logo-full{display:none;}
.tb-logo-square{display:block;max-height:36px;max-width:36px;object-fit:contain;}
#topbar-page-header{flex:1;display:flex;align-items:stretch;min-width:0;overflow:hidden;}
#topbar-page-header .ph{flex:1;background:transparent;box-shadow:none;border-bottom:none;padding:0 18px;display:flex;align-items:center;min-width:0;}
#topbar-page-header .ph h2{font-size:16px;font-weight:700;line-height:1.2;}
#topbar-page-header .ph p{font-size:11px;color:var(--muted);margin-top:1px;line-height:1.2;}
body.resizing-sb .tb-left,body.resizing-sb #sidebar{transition:none;}

/* ─── SIDEBAR ─── */
#sidebar{width:var(--sb-w);background:var(--sidebar);display:flex;flex-direction:column;flex-shrink:0;transition:width .2s ease;position:relative;min-width:52px;max-width:400px;}
.sidebar-resize-handle{position:absolute;top:0;right:-3px;width:6px;height:100%;cursor:col-resize;z-index:50;background:transparent;transition:background .15s;}
.sidebar-resize-handle:hover,.sidebar-resize-handle.active{background:var(--primary);opacity:.5;}
#sidebar nav{flex:1;padding:10px 0;}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:#5c5650;cursor:pointer;border-left:3px solid transparent;transition:all .15s;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;}
.nav-item:hover{background:rgba(0,0,0,.06);color:#2d2b28;}
.nav-item.active{background:rgba(107,107,107,.12);color:var(--primary);border-left-color:var(--primary);}
.nav-item .ni{font-size:15px;width:18px;text-align:center;}
.nav-item .nav-abbr{display:none;font-size:13px;font-weight:700;width:24px;text-align:center;flex-shrink:0;}
.nav-item .nav-label{white-space:nowrap;}
.nav-item[draggable="true"]{cursor:grab;}
.nav-item[draggable="true"]:active{cursor:grabbing;}
.nav-item.drag-over{border-top:2px solid var(--primary);margin-top:-2px;}
.nav-item.dragging{opacity:.4;}
/* Collapsed sidebar */
#sidebar.collapsed .nav-item{justify-content:center;padding:10px 0;border-left-width:2px;gap:0;}
#sidebar.collapsed .nav-item .nav-label{display:none;}
#sidebar.collapsed .nav-item .nav-abbr{display:block;}

/* ─── LAYOUT ─── */
#main{flex:1;overflow:hidden;display:flex;flex-direction:column;}
.page{display:none;flex:1;flex-direction:column;overflow:hidden;}
.page.active{display:flex;}
.ph{background:#fff;border-bottom:none;box-shadow:0 1px 2px rgba(0,0,0,.05);padding:14px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.ph h2{font-size:18px;font-weight:700;}
.ph p{color:var(--muted);font-size:12px;margin-top:2px;}
.pc{padding:20px 22px;flex:1;overflow-y:auto;}

/* ─── CARDS ─── */
.card{background:#fff;border:1px solid transparent;border-radius:8px;overflow:hidden;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);}
.card-hd{padding:12px 18px;border-bottom:1px solid var(--border);background:#faf8f6;display:flex;align-items:center;justify-content:space-between;}
.card-hd h3{font-size:14px;font-weight:600;}
.card-bd{padding:18px;}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-primary:hover{background:var(--primary-dk);}
.btn-sec{background:#fff;color:var(--text);border-color:var(--border);}
.btn-sec:hover{background:var(--bg);}
.btn-success{background:var(--success);color:#fff;}
.btn-success:hover{background:#256b4f;}
.btn-danger{background:var(--danger);color:#fff;}
.btn-danger:hover{background:#a33632;}
.btn-orange{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-orange:hover{background:var(--primary-dk);}
.btn-sm{padding:4px 10px;font-size:12px;}
.btn-xs{padding:3px 8px;font-size:11px;}
.btn-ico{background:none;border:none;cursor:pointer;padding:4px 6px;border-radius:4px;color:var(--muted);font-size:14px;line-height:1;}
.btn-ico:hover{background:var(--bg);color:var(--text);}
.btn-ico svg{pointer-events:none;}
.flex-row{display:flex;align-items:center;gap:8px;}

/* ─── TABLES ─── */
.tbl-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
th{text-align:left;padding:9px 12px;background:#faf8f6;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;}
td{padding:8px 12px;border-bottom:1px solid #f5f3f0;vertical-align:middle;}
tr.row-ok{background:#f0fdf4;}
tr.row-ok:hover{background:#dcfce7;}
tr.row-est{background:#fffbeb;}
tr.row-est:hover{background:#fef3c7;}
tr:not(.row-ok):not(.row-est):not(.sum-row):hover{background:#faf8f6;}
tr.sum-row td{background:#faf8f6;font-weight:700;border-top:2px solid var(--border);}

/* ─── FORMS ─── */
input,select,textarea{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:5px;font-size:13px;color:var(--text);background:#fff;transition:border-color .15s;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(107,107,107,.12);}
input[type=number]{text-align:right;}
label.lbl{display:block;font-size:11px;font-weight:600;color:var(--muted);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em;}
.fg{margin-bottom:14px;}
.form-grid{display:grid;gap:14px;}
.fc2{grid-template-columns:1fr 1fr;}
.fc3{grid-template-columns:1fr 1fr 1fr;}
.fc4{grid-template-columns:1fr 1fr 1fr 1fr;}
.input-sfx{display:flex;align-items:center;border:1px solid var(--border);border-radius:5px;overflow:hidden;}
.input-sfx input{border:none;flex:1;border-radius:0;}
.input-sfx input:focus{box-shadow:none;}
.input-sfx .sfx{padding:7px 10px;background:#faf8f6;border-left:1px solid var(--border);font-size:12px;color:var(--muted);white-space:nowrap;}

/* ─── BADGES ─── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;}
.badge-ok{background:var(--success-lt);color:var(--success);}
.badge-est{background:var(--warning-lt);color:var(--warning);}
.badge-info{background:var(--primary-lt);color:var(--primary);}

/* ─── MODAL ─── */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:900;align-items:center;justify-content:center;}
.modal-ov.open{display:flex;}
.modal{background:#fff;border-radius:12px;width:90%;max-width:560px;max-height:88vh;overflow-y:auto;box-shadow:0 20px 50px rgba(0,0,0,.15);}
.modal-lg{max-width:760px;}
.modal-hd{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-hd h3{font-size:16px;font-weight:600;}
.modal-bd{padding:22px;}
.modal-ft{padding:14px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;}
.modal-box{background:#fff;border-radius:12px;width:90%;max-height:88vh;overflow-y:auto;box-shadow:0 20px 50px rgba(0,0,0,.15);}
/* New Customer modal: segmented tab toggle */
.nc-tabs{display:flex;gap:0;background:var(--bg);border-radius:8px;padding:3px;margin-bottom:16px;}
.nc-tabs button{flex:1;padding:7px 14px;border:none;background:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--muted);border-radius:6px;transition:all .15s;}
.nc-tabs button.active{background:#fff;color:var(--text);box-shadow:0 1px 3px rgba(0,0,0,.1);}
/* New Customer modal: dynamic contact rows */
.nc-contact{border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:10px;position:relative;background:#faf9f7;}
.nc-contact .btn-remove{position:absolute;top:8px;right:8px;}

/* ─── QUOTE BUILDER SLIDE-IN PANEL ─── */
#modal-quote-builder{padding:0;background:rgba(0,0,0,0);z-index:800;justify-content:flex-end;transition:background .3s ease;}
#modal-quote-builder.open{background:rgba(0,0,0,.45);}
.qb-inner{width:92%;max-width:1400px;height:100%;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.12);}
#modal-quote-builder.open .qb-inner{transform:translateX(0);}
/* View-only lockdown — applied when the current user has canView but not
   canEdit. Disables every interactive control inside the builder so the
   record can be read without being modified. The Close (✕) button is
   exempted so the user can always dismiss the slider. */
#modal-quote-builder.view-only .qb-inner input,
#modal-quote-builder.view-only .qb-inner textarea,
#modal-quote-builder.view-only .qb-inner select{pointer-events:none;background:#f7f8fa !important;color:var(--muted) !important;cursor:default;}
#modal-quote-builder.view-only .qb-inner button:not(.qb-close-btn):not([data-allow-view]){pointer-events:none;opacity:.55;cursor:default;}
#modal-quote-builder.view-only .qb-inner .doc-btn{pointer-events:auto;opacity:1;}
#modal-quote-builder.view-only .qb-inner::before{content:"Read-only — you can view this deal but not edit it.";display:block;background:#fef3c7;color:#92400e;font-size:12px;font-weight:600;padding:6px 22px;border-bottom:1px solid #fde68a;}
.qb-header{background:#fff;border-bottom:1px solid var(--border);padding:14px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:16px;}
.qb-header h2{font-size:18px;font-weight:700;}
.qb-header p{color:var(--muted);font-size:12px;margin-top:2px;}
.qb-title-wrap{display:flex;flex-direction:column;min-width:0;}
.qb-title-wrap h2{font-size:18px;font-weight:700;color:var(--fg);line-height:1.2;}
.qb-title-sub{font-size:12px;color:var(--muted);font-weight:500;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.qb-header-total{display:none;align-items:center;gap:8px;margin-left:auto;margin-right:10px;height:30px;padding:0 12px;box-sizing:border-box;background:var(--primary-lt);border:1px solid var(--primary);border-radius:6px;}
.qb-header-total.visible{display:inline-flex;}
.qb-header-total .qb-ht-lbl{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}
.qb-header-total strong{font-size:12px;font-weight:700;color:var(--primary);line-height:1;}
.qb-chk-label{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--fg);cursor:pointer;white-space:nowrap;}
.qb-chk-label input[type=checkbox]{width:15px;height:15px;accent-color:var(--primary);cursor:pointer;}
.qb-body{flex:1;overflow-y:auto;padding:20px 22px;}
.qb-footer{background:#fff;border-top:1px solid var(--border);padding:10px 22px;flex-shrink:0;}
/* ─── QUOTE BUILDER TABS ─── */
.qb-tabs{display:flex;border-bottom:2px solid var(--border);padding:0 22px;background:#fff;flex-shrink:0;}
.qb-tabs button{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;}
.qb-tabs button:hover{color:var(--text);}
.qb-tabs button.active{color:var(--primary);border-bottom-color:var(--primary);}
.qb-tab-panel{display:none;}
.qb-tab-panel.active{display:block;}
/* ─── QUOTE BUILDER HEADER KPI BAR ─── */
.qb-kpis{display:flex;gap:14px;padding:4px 22px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;justify-content:flex-end;}
.qb-tabs-inline{margin-right:auto;border:none!important;padding:0!important;background:transparent!important;}
.qb-tabs-inline button{padding:6px 14px!important;margin-bottom:0!important;border-bottom:2px solid transparent!important;}
.qb-tabs-inline button.active{border-bottom-color:var(--primary)!important;}
.qb-kpi{display:inline-flex;align-items:center;gap:6px;padding:2px 8px;background:#f9fafb;border:1px solid var(--border);border-radius:6px;}
.qb-kpi-ico{width:14px;height:14px;color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.8;}
.qb-kpi-ico svg{width:14px;height:14px;}
.qb-kpi-val{font-size:12px;font-weight:700;color:var(--fg);line-height:1;white-space:nowrap;}
.qb-kpi-due .qb-kpi-val.alert{color:var(--danger);}
/* ─── RAG (Red/Amber/Green) traffic-light highlights ─── */
/* Quote Builder KPI pills: colour the border only, keep body neutral */
.qb-kpi.rag-red    {border-color:#dc2626;border-width:1.5px;}
.qb-kpi.rag-amber  {border-color:#facc15;border-width:1.5px;}
.qb-kpi.rag-green  {border-color:#16a34a;border-width:1.5px;}
/* Company page: only tint the top accent stripe, keep card body neutral */
.customer-detail-stats .stat-box.rag-red::before  {background:#dc2626;opacity:1;}
.customer-detail-stats .stat-box.rag-amber::before{background:#facc15;opacity:1;}
.customer-detail-stats .stat-box.rag-green::before{background:#16a34a;opacity:1;}
/* ─── SALES WIDGET ─── */
.sw-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px;}
.sw-stat{background:#fff;border:1px solid transparent;border-radius:8px;padding:18px 20px;box-shadow:0 1px 3px rgba(0,0,0,.06);}
.sw-stat h4{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px;}
.sw-stat .sw-val{font-size:24px;font-weight:700;color:var(--text);}
.sw-stat .sw-sub{font-size:12px;color:var(--muted);margin-top:4px;}
.sw-chart-wrap{background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:20px;}
.sw-chart-wrap h3{font-size:14px;font-weight:600;margin-bottom:14px;}
.sw-endole{background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;}
.sw-endole h3{font-size:14px;font-weight:600;margin-bottom:10px;}
.sw-endole .sw-endole-info{font-size:13px;color:var(--muted);margin-bottom:14px;line-height:1.6;}
.sw-endole .btn-endole{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;}
.sw-endole .btn-endole:hover{background:var(--primary-dk);}
.sw-ch-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;margin-bottom:16px;}
.role-card{background:#faf8f5;border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:14px;}
.role-card:last-child{margin-bottom:0;}
.role-card-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;}
.role-card-title{font-size:13px;font-weight:700;color:var(--text);letter-spacing:.01em;}
.role-card-desc{font-size:12px;color:var(--muted);margin-top:2px;line-height:1.45;}
.role-card-actions{display:flex;gap:4px;flex-shrink:0;}
.role-quick-btn{padding:3px 10px;font-size:11px;font-weight:600;border:1px solid var(--border);background:#fff;color:var(--muted);border-radius:5px;cursor:pointer;transition:all .12s;}
.role-quick-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-lt);}
.role-checks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px 12px;}
.role-check{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 10px;border-radius:6px;cursor:pointer;user-select:none;transition:background .12s;border:1px solid transparent;}
.role-check:hover{background:#fff;border-color:var(--border);}
.role-check input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--primary);margin:0;flex-shrink:0;}
.role-check input[type=checkbox]:disabled{cursor:not-allowed;}
.role-check.disabled{opacity:.55;cursor:not-allowed;}
.role-check.disabled:hover{background:transparent;border-color:transparent;}
.role-status-pill{display:inline-block;padding:1px 8px;border-radius:10px;font-size:11px;font-weight:600;margin-left:auto;}
.sw-ch-field label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;display:block;margin-bottom:3px;}
.sw-ch-field span{font-size:14px;font-weight:500;color:var(--text);display:block;}
.sw-ch-status{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize;}
.sw-ch-status.active{background:var(--success-lt);color:var(--success);}
.sw-ch-status.dissolved,.sw-ch-status.liquidation,.sw-ch-status.administration{background:var(--danger-lt);color:var(--danger);}
.sw-psc-list{margin-top:14px;}
.sw-psc-item{padding:10px 14px;border:1px solid var(--border);border-radius:6px;margin-bottom:8px;background:#faf8f6;}
.sw-psc-item .sw-psc-name{font-weight:600;font-size:13px;margin-bottom:4px;}
.sw-psc-item .sw-psc-detail{font-size:12px;color:var(--muted);line-height:1.5;}
.sw-empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:14px;}
.sw-loading{text-align:center;padding:60px 20px;color:var(--muted);font-size:14px;}
.sw-layout{display:flex;gap:20px;margin-bottom:20px;}
.sw-layout-left,.sw-layout-right{flex:1;min-width:0;}
.sw-layout-left .sw-chart-wrap{margin-bottom:20px;}
.sw-layout-left .sw-grid{margin-bottom:0;}
.sw-prospects{background:#fff;border:1px solid var(--border);border-radius:8px;padding:20px;height:100%;box-sizing:border-box;display:flex;flex-direction:column;}
.sw-prospects h3{font-size:14px;font-weight:600;margin-bottom:14px;}
.sw-prospects-url{font-size:12px;color:var(--muted);margin-bottom:14px;word-break:break-all;}
.sw-prospects-url a{color:var(--primary);}
.sw-prospects-summary{font-size:13px;color:var(--text);line-height:1.6;margin-bottom:14px;}
.sw-prospects-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;margin-top:14px;}
.sw-prospects-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px;}
.sw-prospects-tag{display:inline-block;font-size:11px;background:#f3f3f3;color:var(--primary);padding:3px 10px;border-radius:10px;font-weight:500;}
.sw-prospect-list{flex:1;overflow-y:auto;}
.sw-prospect-item{padding:10px 14px;border:1px solid var(--border);border-radius:6px;margin-bottom:8px;background:#faf8f6;}
.sw-prospect-item:last-child{margin-bottom:0;}
.sw-prospect-name{font-weight:600;font-size:13px;margin-bottom:2px;}
.sw-prospect-name a{color:var(--primary);text-decoration:none;}
.sw-prospect-name a:hover{text-decoration:underline;}
.sw-prospect-cat{display:inline-block;font-size:11px;background:var(--primary-lt,#e0e7ff);color:var(--primary);padding:1px 8px;border-radius:10px;margin-bottom:4px;font-weight:500;}
.sw-prospect-reason{font-size:12px;color:var(--muted);line-height:1.5;}
.sw-prospects-loading{text-align:center;padding:40px 20px;color:var(--muted);font-size:13px;}
.sw-prospects-empty{text-align:center;padding:40px 20px;color:var(--muted);font-size:13px;}
.sw-prospects-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;}
.sw-prospects-btn:hover{background:var(--primary-dk);}
.sw-prospects-btn:disabled{opacity:.5;cursor:not-allowed;}
@media(max-width:900px){.sw-layout{flex-direction:column;}}

/* ─── QUOTE PAGE ─── */
.q-info-bar{background:#fff;border:1px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;flex-direction:column;gap:10px;margin-bottom:16px;}
.q-info-row{display:flex;flex-wrap:wrap;gap:14px 18px;}
.q-info-section{display:contents;}
.q-field{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1 1 130px;}
.q-field-status .status-pill-btn{font-size:12px;}
.q-field .ord-date-input{border:none;border-bottom:1px solid var(--border);border-radius:0;padding:4px 0;font-size:14px;font-weight:500;background:transparent;width:100%;}
.q-field .ord-date-input:focus{border-color:var(--primary);outline:none;box-shadow:none;}
.q-field label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}
.q-field input{border:none;border-bottom:1px solid var(--border);border-radius:0;padding:4px 0;font-size:14px;font-weight:500;background:transparent;width:100%;}
.q-field input:focus{border-color:var(--primary);box-shadow:none;outline:none;}
.ac-wrap{position:relative;}
.ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:260px;max-width:380px;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.12);z-index:999;overflow:hidden;max-height:280px;overflow-y:auto;}
.ac-item{padding:9px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid #f5f3f0;display:flex;flex-direction:column;gap:2px;}
.ac-item:last-child{border-bottom:none;}
.ac-item:hover,.ac-item.ac-active{background:var(--primary-lt);}
.ac-item .ac-name{font-weight:600;color:var(--text);}
.ac-item .ac-sub{font-size:11px;color:var(--muted);}
.ac-loading{padding:10px 14px;font-size:12px;color:var(--muted);text-align:center;}
.ac-none{padding:10px 14px;font-size:12px;color:var(--muted);text-align:center;font-style:italic;}

.q-table td input,
.q-table td select{border:1px solid var(--border);background:#faf8f6;padding:5px 7px;font-size:13px;border-radius:4px;}
.q-table td input:hover,
.q-table td select:hover{border-color:#a39d96;background:#fff;}
.q-table td input:focus,
.q-table td select:focus{border-color:var(--primary);background:#fff;outline:none;}
.q-table th.r,
.q-table td.r{text-align:right;}
.q-table input.no-spin::-webkit-outer-spin-button,
.q-table input.no-spin::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.q-table input.no-spin{-moz-appearance:textfield;}
.q-table th.c,
.q-table td.c{text-align:center;}

.q-total-bar{background:#fff;border:1px solid var(--border);border-radius:8px;padding:14px 20px;display:flex;justify-content:flex-end;align-items:center;gap:16px;margin-top:12px;}
.q-total-item{text-align:left;}
.q-total-item .t-lbl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;}
.q-total-item .t-val{font-size:20px;font-weight:700;color:var(--text);}
.q-total-item .t-val.sub{font-size:16px;color:var(--text);}
.price-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#faf8f6;border:1px solid var(--border);border-radius:8px;padding:10px 18px;min-width:130px;cursor:pointer;transition:background .15s,border-color .15s;text-align:center;gap:2px;}
.price-tile:hover{background:#e8e4df;border-color:#a39d96;}
.price-tile:active{background:#d1ccc7;}
.price-tile .pt-lbl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;}
.price-tile .pt-val{font-size:21px;font-weight:700;color:var(--text);}
.price-tile .pt-hint{font-size:10px;color:#a39d96;margin-top:1px;}

/* ─── SALES STAT BANNERS ─── */
.sales-stats{display:flex;gap:12px;padding:14px 22px 12px;flex-wrap:wrap;}
.sales-stat{flex:1;min-width:140px;background:#fff;border:1px solid transparent;border-radius:10px;padding:12px 16px 14px;display:flex;flex-direction:column;gap:4px;box-shadow:0 1px 3px rgba(0,0,0,.06);}
.sales-stat .ss-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.sales-stat .ss-value{font-size:20px;font-weight:700;color:var(--primary);}
.sales-stat.ss-accent .ss-value{color:var(--orange);}
.sales-stat.ss-clickable{cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease;}
.sales-stat.ss-clickable:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.08);border-color:var(--primary);}
.sales-stat.ss-clickable.ss-accent:hover{border-color:var(--orange);}

/* ─── SALES DRILL-DOWN DRAWER ─── */
#sales-drill{display:none;position:fixed;inset:0;background:rgba(0,0,0,0);z-index:850;justify-content:flex-end;transition:background .3s ease;}
#sales-drill.open{display:flex;background:rgba(0,0,0,.45);}
.sd-inner{width:92%;max-width:720px;height:100%;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.12);}
#sales-drill.open .sd-inner{transform:translateX(0);}
.sd-header{background:#fff;border-bottom:1px solid var(--border);padding:14px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.sd-header h2{font-size:17px;font-weight:700;}
.sd-header p{color:var(--muted);font-size:12px;margin-top:2px;}
.sd-body{flex:1;overflow-y:auto;padding:16px 22px 22px;}
.sd-empty{text-align:center;padding:60px 20px;color:var(--muted);font-size:14px;}
.sd-list{width:100%;border-collapse:collapse;font-size:13px;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.sd-list th{background:#faf8f6;padding:8px 10px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;}
.sd-list td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle;}
.sd-list tr:last-child td{border-bottom:none;}
.sd-list tr.sd-row{cursor:pointer;transition:background .1s;}
.sd-list tr.sd-row:hover{background:var(--primary-lt);}
.sd-list td.r{text-align:right;white-space:nowrap;}
.sd-total{margin-top:12px;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#fff;border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:600;}
.sd-total .sd-total-val{color:var(--primary);font-size:15px;}

/* ─── ORDERS PAGE ─── */
.orders-toolbar{display:flex;align-items:center;gap:10px;padding:10px 22px;background:#fff;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.orders-toolbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-left:auto;}
.orders-search-wrap{flex:1;min-width:200px;}
.orders-search-wrap input{margin:0;}
.orders-wrap{flex:1;overflow:auto;padding:16px 22px 120px;}
/* Purchase Orders sub-tab — mirrors the Deals page bands inside the Parts sub-tab. */
.po-shell{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;}
.po-subhead{background:#fff;border-bottom:1px solid var(--border);padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.po-subhead-title h3{font-size:16px;font-weight:700;margin:0;}
.po-subhead-title p{color:var(--muted);font-size:12px;margin:2px 0 0;}
.po-search-wrap{position:relative;min-width:280px;max-width:380px;}
.po-search-wrap #po-search-clear{position:absolute;top:50%;right:8px;transform:translateY(-50%);background:transparent;border:none;color:var(--muted);font-size:18px;line-height:1;cursor:pointer;padding:0 6px;border-radius:50%;}
.po-search-wrap #po-search-clear:hover{background:var(--bg);color:var(--text);}
.po-toolbar{display:flex;align-items:center;gap:10px;padding:8px 20px;background:#fff;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.po-toolbar .view-tabs-bar{flex:1;min-width:0;overflow-x:auto;scrollbar-width:none;}
.po-toolbar .view-tabs-bar::-webkit-scrollbar{display:none;}
.po-toolbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-left:auto;}
.po-wrap{overflow:auto;}
.po-wrap .orders-table{border:none;border-radius:0;}
.po-wrap .orders-empty{padding:60px 20px;text-align:center;color:var(--muted);}
.vt-count{display:inline-block;background:var(--bg,#f5f4f1);color:var(--muted);padding:1px 7px;border-radius:9px;font-size:10px;font-weight:600;margin-left:4px;line-height:1.5;}
.view-tab.active .vt-count{background:var(--primary-lt,#fef3eb);color:var(--primary);}
/* Dashboard has stacked stat banners + a chart above the table, which can
   push the inner .orders-wrap off-screen on shorter windows. Let the whole
   Dashboard page scroll instead of the table alone. */
#page-sales{overflow-y:auto;}
#page-sales .orders-wrap{flex:0 0 auto;overflow:visible;}
.orders-table{width:100%;border-collapse:collapse;font-size:13px;background:#fff;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
.orders-table th{background:#faf8f6;padding:8px 8px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);white-space:nowrap;}
.orders-table td{padding:7px 8px;border-bottom:1px solid var(--border);vertical-align:middle;line-height:1.3;}
.orders-table td select,.orders-table td .cust-status-badge{padding:1px 6px;height:auto;line-height:1.3;font-size:11px;margin:0;vertical-align:middle;}
.orders-table tr:last-child td{border-bottom:none;}
.orders-table tr.order-row:hover,.orders-table tr.cust-row:hover,.orders-table tr.supp-row:hover{background:#faf8f6;}
.orders-table tr.order-row.dragging,.orders-table tr.cust-row.dragging,.orders-table tr.supp-row.dragging{opacity:.4;}
.orders-table tr.order-row.drag-over,.orders-table tr.cust-row.drag-over,.orders-table tr.supp-row.drag-over{box-shadow:inset 0 2px 0 var(--primary);}
.q-table tr.q-line-main.dragging,.q-table tr.q-line-main.dragging+tr{opacity:.35;}
.q-table tr.q-line-main.drag-over{box-shadow:inset 0 2px 0 var(--primary);}
.q-table tr.q-line-break.dragging{opacity:.35;}
.q-table tr.q-line-break.drag-over{box-shadow:inset 0 2px 0 var(--primary);}
/* Product autocomplete */
.prod-ac-wrap{position:relative;min-width:160px;}
.prod-ac-input{width:100%;box-sizing:border-box;padding-right:26px !important;}
.prod-ac-input{padding-right:40px !important;}
.prod-ac-btns{position:absolute;right:4px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:2px;}
.prod-ac-clear{cursor:pointer;font-size:13px;color:#a39d96;line-height:1;padding:2px;border-radius:3px;display:none;}
.prod-ac-clear:hover{color:var(--danger);background:#fee2e2;}
.prod-ac-clear.visible{display:inline;}
.prod-ac-arrow{cursor:pointer;font-size:10px;color:var(--muted);pointer-events:all;user-select:none;line-height:1;padding:2px;}
.prod-ac-dropdown{display:none;position:fixed;width:320px;max-height:280px;overflow-y:auto;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.15);z-index:9999;font-size:12px;}
.prod-ac-dropdown.open{display:block;}
.prod-ac-group{padding:5px 10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);background:#faf8f6;border-bottom:1px solid var(--border);position:sticky;top:0;}
.prod-ac-item{padding:6px 12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f5f3f0;}
.prod-ac-item:hover,.prod-ac-item.active{background:#eff6ff;color:var(--primary);}
.prod-ac-item .ac-name{font-weight:600;}
.prod-ac-item .ac-code{font-size:11px;color:var(--muted);margin-left:8px;white-space:nowrap;}
.prod-ac-item .ac-price{font-size:11px;color:#7a756e;white-space:nowrap;}
.prod-ac-item .ac-std{font-size:9px;background:#e0f2fe;color:#0369a1;padding:1px 5px;border-radius:3px;margin-left:6px;}
.prod-ac-empty{padding:12px;text-align:center;color:var(--muted);font-style:italic;}
.orders-table tr.group-header td{background:#f5f3f0;font-weight:700;font-size:12px;color:var(--text);letter-spacing:.03em;padding:7px 11px;border-bottom:1px solid var(--border);}
.orders-table tr.group-header.grp-hdr td{cursor:pointer;user-select:none;}
.orders-table tr.group-header.grp-hdr:hover td{background:#ede9e5;}
.orders-table tr.group-header.grp-hdr.grp-dragging{opacity:.4;}
.orders-table tr.group-header.grp-hdr.grp-drag-over td{box-shadow:inset 0 2px 0 var(--primary);}
.orders-table tr.group-header.grp-hdr .grp-chev{display:inline-block;width:10px;margin-right:6px;color:var(--muted);font-size:9px;transition:transform .15s;}
.orders-table tr.group-header.grp-hdr.collapsed .grp-chev{transform:rotate(-90deg);}
.orders-table tr.group-header.grp-hdr .grp-drag{cursor:grab;color:#a39d96;font-size:14px;margin-right:8px;vertical-align:middle;}
.orders-table tr.group-header.grp-hdr .grp-drag:active{cursor:grabbing;}
.orders-table tr.grp-row.grp-hidden{display:none;}
.orders-table tr.group-subheader td{background:#dcfce7;font-weight:600;font-size:11px;color:#166534;letter-spacing:.04em;padding:5px 11px 5px 22px;border-bottom:1px solid #bbf7d0;}
.orders-table tr.urgent-header td{background:#f5f3f0;font-weight:700;font-size:12px;color:var(--text);letter-spacing:.03em;padding:7px 11px;border-bottom:1px solid var(--border);}
.urgent-chk{width:15px;height:15px;cursor:pointer;accent-color:#a39d96;}
.orders-table th.sortable{cursor:pointer;user-select:none;}
.orders-table th.sortable:hover{background:#ede9e5;color:#3d3a36;}
.orders-table th.sortable.sort-active{color:var(--primary);}
.sort-ico{display:inline-block;margin-left:3px;font-size:9px;opacity:.35;vertical-align:middle;line-height:1;}
.sort-ico.asc::after{content:'▲';}
.sort-ico.desc::after{content:'▼';}
.sort-ico.active{opacity:1;}
/* ── Activity Log ── */
.log-table{width:100%;border-collapse:collapse;font-size:13px;}
.log-table th{background:#faf8f6;padding:9px 12px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;}
.log-table td{padding:8px 12px;border-bottom:1px solid var(--border);vertical-align:top;font-size:13px;}
.log-table tr:last-child td{border-bottom:none;}
.log-table tr:hover td{background:#faf8f6;}
.log-action{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;white-space:nowrap;}
.la-login{background:#dcfce7;color:#166534;}
.la-logout{background:#f5f3f0;color:#7a756e;}
.la-quote-created{background:#e4dfd8;color:#5c5650;}
.la-quote-updated{background:#e0ebe6;color:#2e7d5e;}
.la-quote-deleted{background:#fee2e2;color:#991b1b;}
.la-status{background:#fef3c7;color:#92400e;}
.la-bitrix{background:#ede9fe;color:#5b21b6;}
.la-user{background:#fce7f3;color:#9d174d;}
.la-parts{background:#ecfdf5;color:#065f46;}
.la-products{background:#fff7ed;color:#c2410c;}
.la-settings{background:#f5f3f0;color:#5c5650;}
.la-pageview{background:#f0ede8;color:#8b7e74;}
.la-default{background:#f5f3f0;color:#5c5650;}
/* ── Automation Rules ── */
.rule-toggle{position:relative;display:inline-block;width:36px;height:20px;}
.rule-toggle input{opacity:0;width:0;height:0;}
.rule-toggle-slider{position:absolute;cursor:pointer;inset:0;background:#d1ccc7;border-radius:20px;transition:.2s;}
.rule-toggle-slider:before{content:'';position:absolute;width:14px;height:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;}
.rule-toggle input:checked+.rule-toggle-slider{background:var(--primary);}
.rule-toggle input:checked+.rule-toggle-slider:before{transform:translateX(16px);}
.rule-trigger-pill{display:inline-block;padding:2px 9px;border-radius:10px;font-size:11px;font-weight:700;white-space:nowrap;background:#dbeafe;color:#1e40af;}
.rule-action-pill{display:inline-block;padding:2px 9px;border-radius:10px;font-size:11px;font-weight:700;white-space:nowrap;background:#ede9fe;color:#5b21b6;}
.rule-disabled td{opacity:.45;}
/* ── Login Screen ── */
#login-screen{position:fixed;inset:0;background:#f5f3f0;display:flex;align-items:center;justify-content:center;z-index:10000;}
.login-box{background:#fff;border:1px solid transparent;border-radius:12px;padding:36px 40px;width:100%;max-width:380px;box-shadow:0 12px 40px rgba(0,0,0,.08);}
.login-logo{text-align:center;margin-bottom:24px;}
.login-logo img{max-height:52px;max-width:200px;}
.login-box h2{font-size:20px;font-weight:700;margin-bottom:4px;color:var(--text);}
.login-box .login-sub{font-size:13px;color:var(--muted);margin-bottom:22px;}
.login-error{color:#dc2626;font-size:13px;margin-top:10px;min-height:18px;}
/* ── Sidebar user footer ── */
.sidebar-user{padding:10px 12px;border-top:1px solid #d6d1cc;display:flex;align-items:center;gap:8px;}
.sidebar-user-wrap{display:flex;flex-direction:column;flex:1;min-width:0;}
.su-name{font-size:12px;font-weight:600;color:#5c5650;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.su-email{font-size:11px;color:#a39d96;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.su-logout{background:none;border:none;cursor:pointer;color:#a39d96;font-size:11px;padding:3px 6px;border-radius:4px;white-space:nowrap;}
.su-logout:hover{color:#dc2626;background:#fee2e2;}
#sidebar.collapsed .sidebar-user-wrap{display:none;}
#sidebar.collapsed .sidebar-user{justify-content:center;padding:6px;}
#sidebar.collapsed .su-logout{font-size:0;padding:6px;width:100%;justify-content:center;display:flex;}
#sidebar.collapsed .su-logout::before{content:"⏻";font-size:14px;}
/* ── Users table ── */
.users-table{width:100%;border-collapse:collapse;font-size:13px;}
.users-table th{background:#faf8f6;padding:8px 10px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);text-align:left;}
.users-table td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle;}
.users-table tr:last-child td{border-bottom:none;}
.role-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:700;}
.role-admin{background:#fef3c7;color:#92400e;}
.role-manager{background:#ede9fe;color:#5b21b6;}
.role-user{background:#e0f2fe;color:#0369a1;}
.drag-handle{cursor:grab;color:#d1ccc7;font-size:16px;user-select:none;padding:0 4px;}
.drag-handle:active{cursor:grabbing;}
.ord-status{border:none;padding:4px 8px;border-radius:12px;font-size:11px;font-weight:700;cursor:pointer;appearance:none;-webkit-appearance:none;text-align:center;}
.ord-status.s-draft,.status-pill-btn.s-draft{background:#f3f4f6;color:#6b7280;}
.ord-status.s-quote,.status-pill-btn.s-quote{background:#eff6ff;color:#2563eb;}
.ord-status.s-lookinggood,.status-pill-btn.s-lookinggood{background:#f0fdf4;color:#15803d;}
.ord-status.s-approved,.status-pill-btn.s-approved{background:#dcfce7;color:#166534;}
.ord-status.s-proforma,.status-pill-btn.s-proforma{background:#e0f2fe;color:#0369a1;}
.ord-status.s-toorder,.status-pill-btn.s-toorder{background:#ffedd5;color:#c2410c;}
.ord-status.s-onorder{background:#fff7ed;color:#9a3412;}
.ord-status.s-new,.status-pill-btn.s-new{background:#dbeafe;color:#1d4ed8;}
.ord-status.s-production,.status-pill-btn.s-production{background:#fef3c7;color:#92400e;}
.ord-status.s-cancelled,.status-pill-btn.s-cancelled{background:#fee2e2;color:#991b1b;}
.ord-status.s-onhold,.status-pill-btn.s-onhold{background:#fde8e8;color:#991b1b;}
.ord-status.s-dispatched,.status-pill-btn.s-dispatched{background:#dbeafe;color:#1e40af;}
.ord-status.s-shipped,.status-pill-btn.s-shipped{background:#d1fae5;color:#065f46;}
.ord-status.s-paid,.status-pill-btn.s-paid{background:#f3e8ff;color:#7e22ce;}
/* Status multi-filter pills */
.status-multi-filter{display:flex;align-items:center;gap:5px;flex-wrap:wrap;}
.sf-pill{border:2px solid transparent;border-radius:12px;font-size:11px;font-weight:700;padding:3px 10px;cursor:pointer;opacity:.35;transition:opacity .15s,border-color .15s;white-space:nowrap;line-height:1.4;}
.sf-pill.active{opacity:1;border-color:currentColor;}
.sf-pill.sf-quote{background:#eff6ff;color:#2563eb;}
.sf-pill.sf-lookinggood{background:#f0fdf4;color:#15803d;}
.sf-pill.sf-approved{background:#dcfce7;color:#166534;}
.sf-pill.sf-proforma{background:#e0f2fe;color:#0369a1;}
.sf-pill.sf-toorder{background:#ffedd5;color:#c2410c;}
.sf-pill.sf-onorder{background:#fff7ed;color:#9a3412;}
.sf-pill.sf-production{background:#fef3c7;color:#92400e;}
.sf-pill.sf-onhold{background:#fde8e8;color:#991b1b;}
.sf-pill.sf-dispatched{background:#dbeafe;color:#1e40af;}
.sf-pill.sf-shipped{background:#d1fae5;color:#065f46;}
.sf-pill.sf-paid{background:#f3e8ff;color:#7e22ce;}
.sf-pill.sf-cancelled{background:#fee2e2;color:#991b1b;}
/* Customer status pill colours */
.sf-pill.sf-cust-lead{background:#eff6ff;color:#2563eb;}
.sf-pill.sf-cust-prospect{background:#e0f2fe;color:#0369a1;}
.sf-pill.sf-cust-active{background:#f0fdf4;color:#15803d;}
.sf-pill.sf-cust-vip{background:#f3e8ff;color:#7e22ce;}
.sf-pill.sf-cust-dormant{background:#f3f4f6;color:#374151;}
.sf-pill.sf-cust-lost{background:#fee2e2;color:#991b1b;}
/* View Tabs Bar */
.view-tabs-bar{display:flex;align-items:center;gap:0;flex:1;min-width:0;overflow-x:auto;scrollbar-width:none;}
.view-tabs-bar::-webkit-scrollbar{display:none;}
.view-tab{padding:7px 16px;border:none;background:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s;}
.view-tab:hover{color:var(--text);}
.view-tab.active{color:var(--primary);border-bottom-color:var(--primary);}
.view-tab .vt-close{display:none;margin-left:4px;font-size:11px;color:var(--muted);cursor:pointer;padding:0 2px;line-height:1;border-radius:3px;vertical-align:middle;}
.view-tab .vt-close:hover{color:var(--danger);background:var(--danger-lt);}
.view-tab.active .vt-close{display:inline;}
.view-tab.vt-dragging{opacity:.4;}
.view-tab.vt-drag-over{background:var(--primary-lt);border-radius:4px 4px 0 0;}
.view-tab-add{padding:5px 10px;border:1px dashed var(--border);background:none;cursor:pointer;font-size:14px;font-weight:600;color:var(--muted);border-radius:6px;margin-left:6px;transition:all .15s;flex-shrink:0;line-height:1;}
.view-tab-add:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-lt);}
.tab-ctx-menu{position:fixed;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);z-index:1000;min-width:120px;padding:4px 0;display:none;}
.tab-ctx-item{padding:7px 14px;font-size:12px;cursor:pointer;color:var(--text);transition:background .1s;}
.tab-ctx-item:hover{background:var(--bg);}
.tab-ctx-item.danger{color:var(--danger);}
.tab-ctx-item.danger:hover{background:var(--danger-lt);}
.tab-editor-checks{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px;}
.tab-editor-checks label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;padding:5px 8px;border:1px solid var(--border);border-radius:6px;transition:background .1s;}
.tab-editor-checks label:hover{background:var(--bg);}
.tab-editor-checks input[type=checkbox]{accent-color:var(--primary);width:15px;height:15px;cursor:pointer;}
.cust-status-badge{display:inline-block;padding:3px 9px;border-radius:12px;font-size:11px;font-weight:700;white-space:nowrap;}
.cust-status-badge.cs-lead{background:#eff6ff;color:#2563eb;}
.cust-status-badge.cs-prospect{background:#e0f2fe;color:#0369a1;}
.cust-status-badge.cs-active{background:#f0fdf4;color:#15803d;}
.cust-status-badge.cs-vip{background:#f3e8ff;color:#7e22ce;}
.cust-status-badge.cs-dormant{background:#f3f4f6;color:#374151;}
.cust-status-badge.cs-lost{background:#fee2e2;color:#991b1b;}
.cust-status-badge.cs-none{background:#f3f4f6;color:#9ca3af;font-weight:500;}
/* Customer status colours on .ord-status (detail slider dropdown) */
.ord-status.cs-lead{background:#eff6ff;color:#2563eb;}
.ord-status.cs-prospect{background:#e0f2fe;color:#0369a1;}
.ord-status.cs-active{background:#f0fdf4;color:#15803d;}
.ord-status.cs-vip{background:#f3e8ff;color:#7e22ce;}
.ord-status.cs-dormant{background:#f3f4f6;color:#374151;}
.ord-status.cs-lost{background:#fee2e2;color:#991b1b;}
.ord-status.cs-none{background:#f3f4f6;color:#9ca3af;}
.target-chk{cursor:pointer;width:16px;height:16px;accent-color:#f59e0b;}
/* Custom status pill picker */
.status-picker-wrap{position:relative;display:inline-block;}
.status-pill-btn{border:none;padding:4px 20px 4px 10px;border-radius:12px;font-size:11px;font-weight:700;cursor:pointer;position:relative;white-space:nowrap;line-height:1.4;}
.status-pill-btn::after{content:'▾';position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:10px;opacity:.7;}
.status-picker-dropdown{display:none;position:fixed;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 18px rgba(0,0,0,.14);padding:5px;z-index:700;min-width:160px;}
#q-header-status-wrap .status-pill-btn{width:200px;justify-content:center;}
#q-header-status-wrap .status-picker-dropdown{width:200px!important;min-width:200px!important;}
.status-picker-dropdown.open{display:block;}
.status-picker-option{display:block;width:100%;border:none;background:none;padding:4px 6px;border-radius:8px;cursor:pointer;text-align:left;margin:2px 0;}
.status-picker-option span{display:inline-block;padding:3px 12px;border-radius:12px;font-size:11px;font-weight:700;width:100%;text-align:center;}
.status-picker-option:hover span{filter:brightness(.93);}
/* Parts-tracking status pills (deal record → Parts tab). Same palette as
   the deal-status pills above so the two feel like one component. */
.status-pill-btn.s-pt-in_stock,.ord-status.s-pt-in_stock{background:#d1fae5;color:#065f46;}
.status-pill-btn.s-pt-required,.ord-status.s-pt-required{background:#fee2e2;color:#991b1b;}
.status-pill-btn.s-pt-requested,.ord-status.s-pt-requested{background:#fef3c7;color:#92400e;}
.status-pill-btn.s-pt-on_order,.ord-status.s-pt-on_order{background:#dbeafe;color:#1d4ed8;}
.status-picker-option.sp-pt-in_stock span{background:#d1fae5;color:#065f46;}
.status-picker-option.sp-pt-required span{background:#fee2e2;color:#991b1b;}
.status-picker-option.sp-pt-requested span{background:#fef3c7;color:#92400e;}
.status-picker-option.sp-pt-on_order span{background:#dbeafe;color:#1d4ed8;}
/* Dedicated dropdown for the Parts tab status picker. Uses
   position:absolute relative to the wrap so it isn't affected by the
   modal's transform: translateX containing-block trickery. */
.pt-picker-wrap{position:relative;display:inline-block;}
.pt-picker-dropdown{display:none;position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 18px rgba(0,0,0,.14);padding:5px;z-index:1200;min-width:140px;}
.pt-picker-wrap.open .pt-picker-dropdown{display:block;}

/* Requested-parts status pills (Materials → Requested). Shares the
   .pt-picker-wrap geometry so the dropdown behaves the same. */
.status-pill-btn.s-rq-requested{background:#fef3c7;color:#92400e;}
.status-pill-btn.s-rq-ordered{background:#dbeafe;color:#1d4ed8;}
.status-pill-btn.s-rq-rejected{background:#fee2e2;color:#991b1b;}
.status-picker-option.sp-rq-requested span{background:#fef3c7;color:#92400e;}
.status-picker-option.sp-rq-ordered span{background:#dbeafe;color:#1d4ed8;}
.status-picker-option.sp-rq-rejected span{background:#fee2e2;color:#991b1b;}
/* The position:absolute dropdown is otherwise clipped by .card's
   overflow:hidden and .tbl-wrap's overflow:auto. Unset those on the
   Requested page so the popup can extend below its row. */
#st-requested .card{overflow:visible;}
#st-requested .tbl-wrap{overflow:visible;}
.sub-stage-group{margin:2px 4px 6px;padding:2px 0 2px 10px;border-left:2px solid #d1d5db;}
.sub-stage-option{display:block;width:100%;border:none;background:none;padding:6px 10px;border-radius:6px;cursor:pointer;text-align:left;font-size:12px;font-weight:500;color:var(--text);margin:1px 0;}
.sub-stage-option:hover{background:#f4f7fb;color:var(--primary);}
.sp-quote span{background:#eff6ff;color:#2563eb;}
.sp-lookinggood span{background:#f0fdf4;color:#15803d;}
.sp-approved span{background:#dcfce7;color:#166534;}
.sp-proforma span{background:#e0f2fe;color:#0369a1;}
.sp-toorder span{background:#ffedd5;color:#c2410c;}
.sp-production span{background:#fef3c7;color:#92400e;}
.sp-onhold span{background:#fde8e8;color:#991b1b;}
.sp-dispatched span{background:#dbeafe;color:#1e40af;}
.sp-shipped span{background:#d1fae5;color:#065f46;}
.sp-paid span{background:#f3e8ff;color:#7e22ce;}
.sp-cancelled span{background:#fee2e2;color:#991b1b;}
/* PO status pill colours */
.status-pill-btn.s-draft{background:#f3f4f6;color:#6b7280;}
.status-pill-btn.s-topay{background:#fef3c7;color:#92400e;}
.status-pill-btn.s-onorder{background:#eff6ff;color:#2563eb;}
.status-pill-btn.s-partreceived{background:#fffbeb;color:#d97706;}
.status-pill-btn.s-received{background:#f0fdf4;color:#16a34a;}
.sp-draft span{background:#f3f4f6;color:#6b7280;}
.sp-topay span{background:#fef3c7;color:#92400e;}
.sp-onorder span{background:#eff6ff;color:#2563eb;}
.sp-partreceived span{background:#fffbeb;color:#d97706;}
.sp-received span{background:#f0fdf4;color:#16a34a;}
.orders-empty{text-align:center;padding:60px 20px;color:var(--muted);}
.pagination-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;font-size:13px;color:var(--muted);border-top:1px solid var(--border);background:#faf8f6;border-radius:0 0 8px 8px;}
.pagination-bar .pg-info{font-size:12px;}
.pagination-bar .pg-controls{display:flex;align-items:center;gap:6px;}
.pagination-bar .pg-btn{padding:4px 10px;border:1px solid var(--border);border-radius:5px;background:#fff;cursor:pointer;font-size:12px;color:var(--text);transition:background .15s;}
.pagination-bar .pg-btn:hover:not(:disabled){background:#e8e4df;}
.pagination-bar .pg-btn:disabled{opacity:.4;cursor:default;}
.pagination-bar .pg-pages{display:flex;align-items:center;gap:2px;}
.pagination-bar .pg-page{padding:4px 9px;border:1px solid transparent;border-radius:5px;background:none;cursor:pointer;font-size:12px;color:var(--muted);}
.pagination-bar .pg-page:hover{background:#e8e4df;}
.pagination-bar .pg-page.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600;}
.pagination-bar .pg-size{display:flex;align-items:center;gap:6px;}
.pagination-bar .pg-size select{padding:3px 6px;border:1px solid var(--border);border-radius:4px;font-size:12px;background:#fff;}
.order-sub-row td{background:#faf8f6;border-bottom:2px solid var(--border);}
.ord-lines-table{width:100%;border-collapse:collapse;font-size:12px;margin-top:6px;border:1px solid var(--border);border-radius:6px;overflow:hidden;}
.ord-lines-table th{background:#f5f3f0;padding:6px 10px;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);}
.ord-lines-table td{padding:6px 10px;border-bottom:1px solid #ede9e5;}
.ord-lines-table tr:last-child td{border-bottom:none;}
.ord-expand-btn{font-size:11px;color:var(--primary);font-weight:700;}

.q-actions{background:#fff;border-top:1px solid var(--border);padding:12px 22px;display:flex;gap:10px;align-items:center;flex-shrink:0;}
.q-actions .sp{flex:1;}

/* ─── PRODUCTS PAGE (compact table board) ─── */
.products-toolbar{display:flex;align-items:center;gap:10px;padding:10px 22px;background:#fff;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.products-toolbar-right{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-left:auto;}
.products-search-wrap{flex:1;min-width:200px;}
.products-wrap{flex:1;overflow:auto;padding:16px 22px 120px;}
.products-table{width:100%;border-collapse:collapse;font-size:13px;}
.products-table thead th{text-align:left;padding:9px 12px;background:#faf8f6;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;}
.products-table td{padding:8px 12px;border-bottom:1px solid #f5f3f0;vertical-align:middle;}
.products-table tr.product-row{cursor:pointer;}
.products-table tr.product-row:hover{background:#faf8f6;}
.products-table tr.product-row.dragging{opacity:.4;}
.products-table tr.product-row.drag-over{box-shadow:inset 0 2px 0 var(--primary);}
.products-table th.sortable{cursor:pointer;user-select:none;}
.products-table th.sortable:hover{background:#ede9e5;color:#3d3a36;}
.products-table th.sortable.sort-active{color:var(--primary);}
.products-table tr.prod-group-header td{background:#ede9e5;font-weight:700;font-size:12px;color:#3d3a36;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;}
.products-table tr.prod-group-header:hover td{background:#e4dfda;}
.products-table tr.prod-group-header .grp-chev{display:inline-block;transition:transform .2s;margin-right:6px;font-size:10px;}
.products-table tr.prod-group-header.collapsed .grp-chev{transform:rotate(-90deg);}
.products-table tr.prod-group-row.grp-hidden{display:none;}
.products-table tr.prod-group-header.dragging{opacity:.4;}
.products-table tr.prod-group-header.drag-over td{box-shadow:inset 0 2px 0 var(--primary);}
.products-table tr.prod-group-header .grp-drag{cursor:grab;color:#a39d96;font-size:14px;margin-right:8px;vertical-align:middle;}
.products-table tr.prod-group-header .grp-drag:active{cursor:grabbing;}
.prod-cat-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;background:var(--primary-lt);color:var(--primary);}

/* Standard Products columns dropdown */
#std-cols-menu label{margin:0;}
#std-cols-menu label:hover{background:var(--bg, #f9fafb);}
#std-cols-menu input[type="checkbox"]{width:auto;padding:0;margin:0;flex-shrink:0;appearance:auto;}

/* Standard Product modal — sectioned layout & kind cards */
#modal-std-product .sp-section-hd{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted,#6b7280);padding-bottom:6px;margin-bottom:10px;border-bottom:1px solid var(--border,#e5e7eb);}
#modal-std-product .sp-kind-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
#modal-std-product .sp-kind-card{position:relative;display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border:1px solid var(--border,#e5e7eb);border-radius:8px;cursor:pointer;background:#fff;transition:border-color .12s,box-shadow .12s,background .12s;}
#modal-std-product .sp-kind-card:hover{border-color:var(--primary,#2563eb);}
#modal-std-product .sp-kind-card input[type="radio"]{margin:2px 0 0 0;flex-shrink:0;width:auto;padding:0;appearance:auto;}
#modal-std-product .sp-kind-card-body{display:flex;flex-direction:column;gap:2px;}
#modal-std-product .sp-kind-card-title{font-size:13px;font-weight:700;color:var(--text,#111827);}
#modal-std-product .sp-kind-card-sub{font-size:11px;color:var(--muted,#6b7280);line-height:1.35;}
#modal-std-product .sp-kind-card:has(input[type="radio"]:checked){border-color:var(--primary,#2563eb);background:var(--primary-lt,#eff6ff);box-shadow:0 0 0 2px var(--primary-lt,#dbeafe) inset;}
@media (max-width:520px){
  #modal-std-product .sp-kind-cards{grid-template-columns:1fr;}
}
.prod-col-picker-wrap{position:relative;display:inline-block;}
.prod-col-picker-dropdown{display:none;position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);padding:8px 0;min-width:170px;z-index:200;}
.prod-col-picker-dropdown.open{display:block;}

/* Record-edit sliders — Product, Part/Material, and Purchase Order all share
   this drawer treatment. New record-edit modals get the same look-and-feel
   simply by using the pd-inner / pd-header / pd-body structure. */
#modal-product-detail, #modal-part, #modal-po{padding:0;background:rgba(0,0,0,0);z-index:800;justify-content:flex-end;transition:background .3s ease;}
#modal-product-detail.open, #modal-part.open, #modal-po.open{background:rgba(0,0,0,.45);}

/* Order-request detail slider — exact copy of the deal builder geometry
   (#modal-quote-builder + .qb-inner) so it slides in from the right,
   takes 92% width up to 1400px, and animates over .32s. Uses its own
   .rd-inner class to avoid any interaction with .pd-inner / .qb-inner
   so the rule set is self-contained. */
#modal-request-detail{padding:0;background:rgba(0,0,0,0);z-index:800;justify-content:flex-end;transition:background .3s ease;}
#modal-request-detail.open{background:rgba(0,0,0,.45);}
.rd-inner{width:92%;max-width:1400px;height:100%;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.12);}
#modal-request-detail.open .rd-inner{transform:translateX(0);}
.pd-inner{width:82%;max-width:960px;height:100%;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.12);}
.modal-ov.open > .pd-inner{transform:translateX(0);}
.pd-header{background:#fff;border-bottom:1px solid var(--border);padding:14px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.pd-header h2{font-size:18px;font-weight:700;}
.pd-header p{color:var(--muted);font-size:12px;margin-top:2px;}
.pd-body{flex:1;overflow-y:auto;padding:20px 22px;}
.pd-body .card{margin-bottom:16px;}
.pd-body .card-hd{padding:12px 18px;border-bottom:1px solid var(--border);background:#faf8f6;display:flex;align-items:center;justify-content:space-between;}
.pd-body .card-hd h3{font-size:14px;font-weight:600;}
.pd-body .card-bd{padding:14px 18px;}
/* Tighter form spacing inside record-edit sliders — matches Products. */
.pd-body .form-grid{gap:10px;}
.pd-body .fg{margin-bottom:10px;}
.pd-body .form-grid > .fg{margin-bottom:0;}
.sec-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px;}

/* ─── PARTS PAGE ─── */
/* ─── PARTS GROUP HEADERS ─── */
#po-table tr.po-group-header td{background:#ede9e5;font-weight:700;font-size:12px;color:#3d3a36;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;}
#po-table tr.po-group-header:hover td{background:#e4dfda;}
#po-table tr.po-group-header .grp-chev{display:inline-block;transition:transform .2s;margin-right:6px;font-size:10px;}
#po-table tr.po-group-header.collapsed .grp-chev{transform:rotate(-90deg);}
#po-table tr.po-grp-row.grp-hidden{display:none;}
#parts-table tr.parts-group-header td{background:#ede9e5;font-weight:700;font-size:12px;color:#3d3a36;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;}
#parts-table tr.parts-group-header:hover td{background:#e4dfda;}
#parts-table tr.parts-group-header .grp-chev{display:inline-block;transition:transform .2s;margin-right:6px;font-size:10px;}
#parts-table tr.parts-group-header.collapsed .grp-chev{transform:rotate(-90deg);}
#parts-table tr.parts-grp-row.grp-hidden{display:none;}
.part-cat-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;background:#eff6ff;color:#2563eb;}

.subtabs{display:flex;flex-wrap:wrap;border-bottom:2px solid var(--border);margin-bottom:18px;gap:2px;}
.subtabs button{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;border-radius:6px 6px 0 0;}
.subtabs button:hover{color:var(--text);background:rgba(0,0,0,.03);}
.subtabs button.active{color:var(--primary);border-bottom-color:var(--primary);background:transparent;}
.stc{display:none;}
.stc.active{display:block;}
/* Consistent widths and spacing for settings cards */
#page-settings .stc .card{max-width:820px;}
#page-settings .stc .card + .card{margin-top:16px;}
#page-settings .stc > .info-box{max-width:820px;}

/* ─── SETTINGS ─── */
.mkup-row{display:grid;grid-template-columns:1fr 160px 160px 120px;gap:0;align-items:center;}
.mkup-row>div{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;}
.mkup-row.hd>div{background:#faf8f6;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);}
.mkup-row>div:not(.hd) input{text-align:right;}

/* Human-readable record code chip — shown alongside record names in lists */
.rec-code{font-family:'SF Mono','Menlo',Consolas,monospace;font-size:10.5px;color:var(--muted);background:#faf8f6;border:1px solid var(--border);padding:1px 5px;border-radius:4px;margin-right:6px;letter-spacing:.02em;}


/* ─── PRINT STYLES ─── */
@media print {
  #sidebar,#topbar,.q-actions,.ph .flex-row,.no-print,.modal-ov,#toast-container{display:none!important;}
  body{display:block;overflow:auto;font-size:12px;}
  #app-shell,#app-body{display:block;overflow:visible;}
  #main{overflow:visible;}
  .page{display:block!important;}
  #page-quote{display:block!important;}
  #page-products,#page-parts,#page-settings,#page-orders,#page-log,#page-sales,#page-automation,#page-customers,#page-activities,#page-suppliers{display:none!important;}
  .pc{padding:0;}
  .card{border:none;box-shadow:none;}
  .print-quote{display:block!important;}
  .quote-view{display:none!important;}
  /* Preserve accent background colour when printing */
  .pq2-abg{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;}
}
.print-quote{display:none;}

/* ─── CUSTOMERS ─── */
#modal-customer-detail{padding:0;background:rgba(0,0,0,0);z-index:900;justify-content:flex-end;transition:background .3s ease;}
#modal-customer-detail.open{background:rgba(0,0,0,.45);}
.cd-inner{width:82%;max-width:960px;height:100%;background:var(--bg);display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .32s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 40px rgba(0,0,0,.12);}
#modal-customer-detail.open .cd-inner{transform:translateX(0);}
/* ─── SUPPLIERS DETAIL ─── */
#modal-supplier-detail{padding:0;background:rgba(0,0,0,0);z-index:900;justify-content:flex-end;transition:background .3s ease;}
#modal-supplier-detail.open{background:rgba(0,0,0,.45);}
#modal-supplier-detail.open .cd-inner{transform:translateX(0);}
.sf-pill.sf-supp-primary{background:#f0fdf4;color:#15803d;}.sf-pill.sf-supp-primary.active{background:#15803d;color:#fff;}
.sf-pill.sf-supp-caution{background:#fef2f2;color:#991b1b;}.sf-pill.sf-supp-caution.active{background:#991b1b;color:#fff;}
.sf-pill.sf-supp-account{background:#eff6ff;color:#1d4ed8;}.sf-pill.sf-supp-account.active{background:#1d4ed8;color:#fff;}
.cd-header{background:#fff;border-bottom:1px solid var(--border);padding:14px 22px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.cd-header h2{font-size:18px;font-weight:700;}
.cd-header p{color:var(--muted);font-size:12px;margin-top:2px;}
.cd-body{flex:1;overflow-y:auto;padding:20px 22px;}
/* ─── MODERN KPI STAT CARDS ─── */
.customer-detail-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;}
.customer-detail-stats .stat-box{position:relative;padding:14px 16px;background:#fff;border:1px solid var(--border);border-radius:10px;transition:box-shadow .15s, transform .15s;overflow:hidden;}
.customer-detail-stats .stat-box:hover{box-shadow:0 4px 12px rgba(0,0,0,.06);transform:translateY(-1px);}
.customer-detail-stats .stat-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary);opacity:.8;}
.customer-detail-stats .stat-box .stat-icon{position:absolute;top:12px;right:12px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--primary);opacity:.5;}
.customer-detail-stats .stat-box .stat-icon svg{width:18px;height:18px;}
.customer-detail-stats .stat-val{font-size:22px;font-weight:700;color:var(--fg);line-height:1.1;margin-top:6px;}
.customer-detail-stats .stat-lbl{font-size:11px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.03em;font-weight:600;}

/* ─── OVERVIEW GRID LAYOUT ─── */
.cd-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;}
@media (max-width:780px){.cd-overview-grid{grid-template-columns:1fr;}}
.cd-card{background:#fff;border:1px solid var(--border);border-radius:10px;overflow:hidden;}
.cd-card-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);background:#fafafa;}
.cd-card-header h4{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--fg);margin:0;display:flex;align-items:center;gap:8px;}
.cd-card-header h4 svg{width:15px;height:15px;color:var(--primary);}
.cd-card-header .cd-card-badge{font-size:11px;color:var(--muted);font-weight:500;}
.cd-card-body{padding:14px 16px;}

/* Info list rows (address/phone/website/linkedin) */
.cd-info-list{display:flex;flex-direction:column;gap:10px;}
.cd-info-list .cd-info-row{display:flex;align-items:flex-start;gap:10px;font-size:13px;}
.cd-info-list .cd-info-row .cd-info-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#f0f0f3;border-radius:6px;color:var(--muted);}
.cd-info-list .cd-info-row .cd-info-icon svg{width:15px;height:15px;}
.cd-info-list .cd-info-row .cd-info-data{flex:1;min-width:0;}
.cd-info-list .cd-info-row .cd-info-lbl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;}
.cd-info-list .cd-info-row .cd-info-val{color:var(--fg);word-break:break-word;}
.cd-info-list .cd-info-row .cd-info-val a{color:var(--primary);text-decoration:none;}
.cd-info-list .cd-info-row .cd-info-val a:hover{text-decoration:underline;}
.cd-info-list .cd-info-row .cd-info-empty{color:#bbb;font-style:italic;}

/* Contacts list (within a card) */
.cd-contact-list{display:flex;flex-direction:column;gap:0;}
.cd-contact-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f2f2f5;}
.cd-contact-row:last-child{border-bottom:none;}
.cd-contact-notify{display:flex;align-items:center;gap:6px;flex-shrink:0;font-size:11px;color:var(--muted);}
.cd-contact-notify input[type="checkbox"]{width:14px;height:14px;cursor:pointer;accent-color:var(--primary);}
.cd-contact-notify input[type="email"]{font-size:11px;padding:3px 6px;border:1px solid var(--border);border-radius:4px;width:170px;background:#fff;}
.cd-contact-notify input[type="email"]:disabled{background:#f5f4f1;color:var(--muted);}
.cd-contact-notify .cd-notify-status{font-size:10px;width:14px;text-align:center;}
.cd-contact-avatar{flex-shrink:0;width:34px;height:34px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;text-transform:uppercase;}
.cd-contact-info{flex:1;min-width:0;}
.cd-contact-name{font-size:13px;font-weight:600;color:var(--fg);}
.cd-contact-post{font-size:11px;color:var(--muted);margin-top:1px;}
.cd-contact-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:3px;font-size:11px;}
.cd-contact-meta a{color:var(--primary);text-decoration:none;display:inline-flex;align-items:center;gap:3px;}
.cd-contact-meta a:hover{text-decoration:underline;}
.cd-contact-bx{flex-shrink:0;color:var(--muted);text-decoration:none;font-size:14px;opacity:.6;}
.cd-contact-bx:hover{opacity:1;}

/* Order history card (full width below grid) */
.cd-orders-table{width:100%;border-collapse:collapse;font-size:13px;}
.cd-orders-table th{text-align:left;padding:10px 16px;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;background:#fafafa;border-bottom:1px solid var(--border);}
.cd-orders-table td{padding:10px 16px;border-bottom:1px solid #f2f2f5;}
.cd-orders-table tr:last-child td{border-bottom:none;}
.cd-orders-table tr.cd-order-row{cursor:pointer;transition:background .1s;}
.cd-orders-table tr.cd-order-row:hover{background:#fafafa;}
.cd-orders-table th.r, .cd-orders-table td.r{text-align:right;}

/* ─── OVERVIEW COLUMN STACKING ─── */
.cd-overview-col{display:flex;flex-direction:column;gap:16px;}

/* ─── COMMENTS STREAM ─── */
.cd-comments-card{display:flex;flex-direction:column;overflow:hidden;}
.cd-comments-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px;min-height:120px;max-height:360px;}
.cd-comment-bubble{background:#f5f3f0;border-radius:10px;padding:10px 14px;max-width:95%;}
.cd-comment-bubble.mine{background:var(--primary-lt, #e8f0fe);margin-left:auto;}
.cd-comment-meta{display:flex;align-items:center;gap:6px;margin-bottom:3px;}
.cd-comment-user{font-size:11px;font-weight:700;color:var(--primary);}
.cd-comment-time{font-size:10px;color:var(--muted);}
.cd-comment-text{font-size:13px;color:var(--fg);line-height:1.4;word-break:break-word;}
.cd-comments-input{display:flex;gap:8px;padding:10px 16px;border-top:1px solid var(--border);background:#fafafa;}
.cd-comments-input input{flex:1;border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-size:13px;font-family:inherit;}
.cd-comments-input input:focus{outline:none;border-color:var(--primary);}

/* ─── ACTIVITY ITEMS ─── */
.cd-activity-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f2f2f5;font-size:13px;}
.cd-activity-item:last-child{border-bottom:none;}
.cd-activity-type-icon{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;font-size:14px;}
.cd-activity-type-icon.call{background:#e0f2fe;color:#0284c7;}
.cd-activity-type-icon.meeting{background:#fef3c7;color:#d97706;}
.cd-activity-type-icon.follow-up{background:#ede9fe;color:#7c3aed;}
.cd-activity-type-icon.email{background:#e6f5ed;color:var(--success);}
.cd-activity-info{flex:1;min-width:0;}
.cd-activity-subject{font-weight:600;color:var(--fg);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.cd-activity-due{font-size:11px;color:var(--muted);margin-top:2px;}
.cd-activity-due.overdue{color:var(--danger);font-weight:600;}
.cd-activity-actions{display:flex;gap:4px;flex-shrink:0;}

/* Activity booking form (inline) */
.cd-activity-form{padding:4px 0;}
.cd-activity-form .fg{display:flex;flex-direction:column;gap:4px;margin-bottom:10px;}
.cd-activity-form .lbl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;}
.cd-activity-form input,.cd-activity-form select,.cd-activity-form textarea{border:1px solid var(--border);border-radius:6px;padding:7px 10px;font-size:13px;font-family:inherit;width:100%;box-sizing:border-box;}
.cd-activity-form textarea{resize:vertical;min-height:50px;}
.cd-activity-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.cd-activity-form-btns{display:flex;gap:8px;margin-top:4px;}

/* Activity type badges */
.badge-call{background:#e0f2fe;color:#0284c7;}
.badge-meeting{background:#fef3c7;color:#d97706;}
.badge-follow-up,.badge-followup{background:#ede9fe;color:#7c3aed;}
.badge-email{background:#e6f5ed;color:var(--success);}
.badge-pending{background:#fef9c3;color:#a16207;}
.badge-completed{background:#dcfce7;color:#15803d;}
.badge-cancelled{background:#f2f2f5;color:var(--muted);}

.ai-card{border:1px solid #c4b5fd;border-left:4px solid #7c3aed;border-radius:8px;padding:16px;margin:16px 0;background:#faf5ff;}
.ai-card-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;}
.ai-card-badge{display:inline-flex;align-items:center;gap:4px;background:#7c3aed;color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:12px;letter-spacing:.03em;}
.ai-card-confidence{font-size:11px;color:var(--muted);margin-left:auto;}
.ai-card-sources{font-size:11px;color:var(--muted);margin-top:8px;font-style:italic;}
.ai-field-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #ede9fe;}
.ai-field-row:last-of-type{border-bottom:none;}
.ai-field-row input[type=checkbox]{width:16px;height:16px;accent-color:#7c3aed;flex-shrink:0;}
.ai-field-row .ai-field-lbl{font-size:11px;font-weight:600;color:#6d28d9;min-width:80px;}
.ai-field-row .ai-field-val{font-size:13px;color:var(--fg);flex:1;}
.ai-actions{display:flex;gap:8px;margin-top:12px;}
.btn-ai-approve{background:#7c3aed;color:#fff;border:none;padding:6px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;}
.btn-ai-approve:hover{background:#6d28d9;}
.btn-ai-reject{background:transparent;color:#7c3aed;border:1px solid #c4b5fd;padding:6px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;}
.btn-ai-reject:hover{background:#ede9fe;}

/* ─── MISC ─── */
.chevron{display:inline-block;transition:transform .2s;font-size:11px;color:var(--muted);}
.chevron.open{transform:rotate(180deg);}
.empty{text-align:center;padding:30px;color:var(--muted);font-size:13px;}
.txt-r{text-align:right;}
.txt-c{text-align:center;}
.fw7{font-weight:700;}
.fsize12{font-size:12px;}
.text-muted{color:var(--muted);}
.text-success{color:var(--success);}
.text-danger{color:var(--danger);}
.mt8{margin-top:8px;}
.mt12{margin-top:12px;}
.mb8{margin-bottom:8px;}
.divider{border:none;border-top:1px solid var(--border);margin:16px 0;}
.info-box{background:var(--primary-lt);border:1px solid #dcdcdc;border-radius:6px;padding:12px 16px;font-size:13px;color:var(--primary);margin-bottom:16px;}
.csv-tab{background:#fff;border:1px solid var(--border);color:var(--fg);}.csv-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);}

/* ─── TOAST NOTIFICATIONS ─── */
#toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;}
.toast{padding:10px 16px;border-radius:8px;font-size:13px;font-weight:500;box-shadow:0 4px 16px rgba(0,0,0,.18);opacity:0;transform:translateY(8px);transition:opacity .22s,transform .22s;pointer-events:auto;max-width:340px;}
.toast.show{opacity:1;transform:translateY(0);}
.toast.t-success{background:#2e6b52;color:#e6f5ed;}
.toast.t-error{background:#a33232;color:#fde8e6;}
.toast.t-info{background:#3d4a52;color:#e8e4df;}

/* ─── DOCUMENT PRINT BUTTONS ─── */
.doc-btns{display:flex;gap:4px;align-items:center;}
.doc-btn{display:flex;align-items:center;justify-content:center;padding:5px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;color:var(--muted);transition:all .15s;line-height:1;}
.doc-btn:hover{background:#faf8f6;}
.doc-btn svg{pointer-events:none;}
.doc-btn.db-quote:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff;}
.doc-btn.db-confirm:hover{border-color:#059669;color:#059669;background:#d1fae5;}
.doc-btn.db-job:hover{border-color:#0891b2;color:#0891b2;background:#cffafe;}
.doc-btn.db-delivery:hover{border-color:#7c3aed;color:#7c3aed;background:#f3e8ff;}
.doc-btn.db-proforma:hover{border-color:#d97706;color:#d97706;background:#fef3c7;}
.doc-btn.db-invoice:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-lt);}
/* "used" state: button has been clicked for this quote — outline in the icon's highlight colour */
.doc-btn.used{border-width:1px;}
.doc-btn.db-quote.used{border-color:#2563eb;color:#2563eb;}
.doc-btn.db-confirm.used{border-color:#059669;color:#059669;}
.doc-btn.db-job.used{border-color:#0891b2;color:#0891b2;}
.doc-btn.db-delivery.used{border-color:#7c3aed;color:#7c3aed;}
.doc-btn.db-proforma.used{border-color:#d97706;color:#d97706;}
.doc-btn.db-invoice.used{border-color:var(--primary);color:var(--primary);}
/* ─── PRINT TEMPLATE ─── */
.pq-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #333;}
.pq-co{font-size:13px;}
.pq-co h2{font-size:20px;font-weight:700;}
.pq-title{text-align:right;}
.pq-title h1{font-size:28px;font-weight:700;color:var(--primary);}
.pq-title.dt-quote h1{color:#2563eb;}
.pq-title.dt-confirm h1{color:#059669;}
.pq-title.dt-delivery h1{color:#7c3aed;}
.pq-title.dt-proforma h1{color:#d97706;}
.pq-title.dt-invoice h1{color:var(--primary);}
.pq-meta{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
.pq-meta-box{background:#faf8f6;padding:12px;border-radius:6px;}
.pq-meta-box h4{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--muted);margin-bottom:6px;}
.pq-table th,.pq-table td{border:1px solid #e8e4df;padding:8px 12px;}
.pq-table th{background:#faf8f6;}
.pq-table{border-collapse:collapse;width:100%;margin-bottom:20px;}
.pq-totals{float:right;min-width:280px;break-inside:avoid;page-break-inside:avoid;}
.pq-totals table td{border:none;padding:5px 10px;}
.pq-totals .total-line td{font-weight:700;font-size:16px;border-top:2px solid #333;}
.pq-notes{margin-top:24px;padding-top:16px;border-top:1px solid var(--border);}
.pq-footer{font-size:11px;color:#888;text-align:center;margin-top:32px;padding-top:12px;border-top:1px solid #e8e4df;line-height:1.6;}
/* ─── DATE FIELD COLOURS ─── */
.date-overdue{color:#dc2626!important;font-weight:700;}
.date-today{color:#16a34a!important;font-weight:700;}
/* Inline date inputs in the orders table */
.ord-date-input{border:none;background:transparent;font-size:12px;font-family:inherit;color:inherit;padding:0;cursor:pointer;width:92px;}
.ord-date-input:hover{background:#f5f3f0;border-radius:4px;padding:0 2px;}
.ord-date-input:focus{outline:2px solid var(--primary);border-radius:4px;background:#fff;padding:0 2px;}
/* Column picker */
.col-picker-wrap{position:relative;display:inline-block;}
.orders-table thead th[data-col]{cursor:grab;}
.orders-table thead th.col-dragging{opacity:.4;}
.orders-table thead th.col-drop-over{box-shadow:inset 3px 0 0 var(--primary);}
.col-picker-btn{white-space:nowrap;}
.col-picker-dropdown{display:none;position:absolute;right:0;top:calc(100% + 4px);background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);padding:8px 0;min-width:170px;z-index:200;}
.col-picker-dropdown.open{display:block;}
.col-picker-item{display:flex;align-items:center;gap:10px;padding:7px 16px;cursor:pointer;font-size:13px;user-select:none;}
.col-picker-item:hover{background:#f5f3f0;}
.col-picker-item input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--primary);}
