@import url('./mobile.css');
@import url('./scanner.css');

:root {
  --bg:#0a0d14; --surface:#111520; --surface2:#161c2d; --surface3:#1d2540;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.12);
  --accent:#00e5a0; --accent2:#0066ff; --accent3:#ff6b35;
  --text:#f0f2f8; --text2:#8892a4; --text3:#5a6478;
  --danger:#ff4757; --warn:#ffa502; --success:#00e5a0;
  --radius:12px; --radius2:8px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}

/* LOGIN */
#login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow:hidden;}
.login-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 60% 30%,rgba(0,230,160,0.08) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 20% 80%,rgba(0,102,255,0.07) 0%,transparent 50%);}
.login-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.02) 1px,transparent 1px);background-size:60px 60px;}
.login-card{position:relative;z-index:2;width:420px;background:var(--surface);border:1px solid var(--border2);border-radius:20px;padding:44px 40px;box-shadow:0 40px 80px rgba(0,0,0,0.6);}
.logo-lockup{display:flex;align-items:center;gap:10px;margin-bottom:32px;}
.logo-icon{width:42px;height:42px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;}
.logo-text{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;}
.logo-text span{color:var(--accent);}
.login-card h2{font-family:'Syne',sans-serif;font-size:26px;font-weight:700;margin-bottom:6px;}
.login-card p{color:var(--text2);font-size:14px;margin-bottom:28px;}
.role-row{display:flex;gap:10px;margin-bottom:20px;}
.role-btn{flex:1;padding:10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius2);text-align:center;cursor:pointer;transition:all 0.2s;font-size:12px;color:var(--text2);touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.role-btn span{display:block;font-size:20px;margin-bottom:4px;}
.role-btn:hover,.role-btn.active{border-color:var(--accent);color:var(--accent);background:rgba(0,230,160,0.06);}

/* FORM */
.fg{margin-bottom:16px;}
.fg label{display:block;font-size:11px;font-weight:500;color:var(--text2);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:6px;}
.fg input,.fg select,.fg textarea{width:100%;background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:var(--radius2);padding:10px 12px;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color 0.2s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,230,160,0.1);}
.fg select option{background:var(--surface2);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius2);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all 0.2s;text-decoration:none;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.btn-primary{background:var(--accent);color:#000;}
.btn-primary:hover{background:#00c988;transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,230,160,0.3);}
.btn-primary:disabled{opacity:0.4;cursor:not-allowed;transform:none;box-shadow:none;}
.btn-secondary{background:var(--surface3);color:var(--text);border:1px solid var(--border2);}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);}
.btn-danger{background:rgba(255,71,87,0.12);color:var(--danger);border:1px solid rgba(255,71,87,0.25);}
.btn-danger:hover{background:rgba(255,71,87,0.22);}
.btn-warn{background:rgba(255,165,2,0.12);color:var(--warn);border:1px solid rgba(255,165,2,0.25);}
.btn-full{width:100%;justify-content:center;padding:13px;font-size:15px;font-weight:600;}

/* APP LAYOUT */
#app{display:none;min-height:100vh;}
.sidebar{width:240px;min-height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform 0.3s ease;}
.sidebar-logo{padding:18px 18px 14px;display:flex;align-items:center;gap:9px;border-bottom:1px solid var(--border);}
.sidebar-logo-icon{width:32px;height:32px;background:var(--accent);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;}
.sidebar-logo-text{font-family:'Syne',sans-serif;font-size:16px;font-weight:800;}
.sidebar-logo-text span{color:var(--accent);}
.sidebar-user{padding:12px 14px;margin:10px 10px 0;background:var(--surface2);border-radius:var(--radius2);border:1px solid var(--border);}
.sidebar-user-name{font-size:12px;font-weight:600;}
.sidebar-user-role{font-size:10px;color:var(--accent);margin-top:2px;}
.sidebar-nav{flex:1;padding:14px 8px;overflow-y:auto;}
.nav-section-label{font-size:9px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text3);padding:0 10px 6px;margin-top:14px;}
.nav-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--radius2);color:var(--text2);font-size:13px;cursor:pointer;transition:all 0.15s;margin-bottom:1px;-webkit-tap-highlight-color:transparent;}
.nav-item:hover{background:var(--surface2);color:var(--text);}
.nav-item.active{background:rgba(0,230,160,0.1);color:var(--accent);}
.nav-item .ni{width:16px;text-align:center;font-size:14px;}
.nav-badge{margin-left:auto;background:var(--accent3);color:#fff;font-size:9px;font-weight:700;padding:2px 5px;border-radius:8px;}
.nav-badge.accent{background:var(--accent);color:#000;}
.nav-stub{opacity:0.4;cursor:default;}
.nav-stub:hover{background:none;color:var(--text2);}
.sidebar-footer{padding:12px 8px;border-top:1px solid var(--border);}
.main-content{margin-left:240px;flex:1;min-height:100vh;}
.topbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 26px;position:sticky;top:0;z-index:50;}
.topbar-title{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;}
.page{display:none;padding:26px;}
.page.active{display:block;}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:18px;}
.card-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;position:relative;overflow:hidden;}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;}
.stat-card.green::before{background:var(--accent);}
.stat-card.blue::before{background:var(--accent2);}
.stat-card.orange::before{background:var(--accent3);}
.stat-card.red::before{background:var(--danger);}
.stat-card.purple::before{background:#a78bfa;}
.stat-val{font-family:'Syne',sans-serif;font-size:26px;font-weight:800;}
.stat-label{font-size:11px;color:var(--text2);margin-top:3px;}
.stat-icon{font-size:22px;margin-bottom:10px;}

/* TABLES */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
th{text-align:left;padding:9px 12px;color:var(--text3);font-size:10px;text-transform:uppercase;letter-spacing:0.8px;border-bottom:1px solid var(--border);font-weight:500;white-space:nowrap;}
td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:rgba(255,255,255,0.015);}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;font-size:10px;font-weight:700;white-space:nowrap;}
.b-green{background:rgba(0,230,160,0.12);color:var(--accent);}
.b-blue{background:rgba(0,102,255,0.12);color:var(--accent2);}
.b-orange{background:rgba(255,107,53,0.12);color:var(--accent3);}
.b-red{background:rgba(255,71,87,0.12);color:var(--danger);}
.b-warn{background:rgba(255,165,2,0.12);color:var(--warn);}
.b-purple{background:rgba(167,139,250,0.12);color:#a78bfa;}
.b-gray{background:rgba(255,255,255,0.06);color:var(--text2);}

/* STATUS PILLS — dual model */
.cond-full{background:rgba(0,230,160,0.12);color:var(--accent);}
.cond-empty{background:rgba(255,165,2,0.12);color:var(--warn);}
.cond-broken{background:rgba(255,71,87,0.12);color:var(--danger);}
.cond-quarantined{background:rgba(167,139,250,0.12);color:#a78bfa;}
.cond-lost{background:rgba(255,71,87,0.06);color:#ff6b6b;}
.cust-warehouse{background:rgba(0,102,255,0.12);color:var(--accent2);}
.cust-vehicle{background:rgba(255,107,53,0.12);color:var(--accent3);}
.cust-customer{background:rgba(0,230,160,0.12);color:var(--accent);}
.cust-returning{background:rgba(167,139,250,0.12);color:#a78bfa;}
.cust-service{background:rgba(255,71,87,0.12);color:var(--danger);}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:500;display:none;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.show{display:flex;}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:16px;padding:28px;width:100%;max-width:540px;animation:popIn 0.3s ease;position:relative;max-height:92vh;overflow-y:auto;}
.modal h3{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin-bottom:6px;}
.modal .modal-sub{color:var(--text2);font-size:12px;margin-bottom:20px;}
.modal-close{position:absolute;top:14px;right:14px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;color:var(--text2);cursor:pointer;padding:3px 8px;font-size:15px;}
.modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}

/* FILTER ROW */
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px;align-items:center;}
.search-input{background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:var(--radius2);padding:9px 12px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;flex:1;min-width:200px;}
.search-input:focus{border-color:var(--accent);}
.filter-select{background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:var(--radius2);padding:9px 12px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;cursor:pointer;}

/* NOTIFICATION */
.notif{position:fixed;bottom:22px;right:22px;z-index:9999;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius);padding:16px 20px;max-width:320px;box-shadow:0 20px 50px rgba(0,0,0,0.5);animation:popIn 0.3s ease;display:none;}
.notif.show{display:block;}
.notif-header{display:flex;align-items:center;gap:8px;margin-bottom:5px;}
.notif-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;}
.notif-body{font-size:12px;color:var(--text2);line-height:1.5;}
.notif-close{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--text3);cursor:pointer;}

/* PRODUCT TAG */
.product-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;background:var(--surface3);border:1px solid var(--border2);color:var(--text2);margin:2px;}
.product-tag.allowed{background:rgba(0,230,160,0.08);border-color:rgba(0,230,160,0.3);color:var(--accent);}

/* INLINE SECTION HEADER */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px;}
.page-header-title h2{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;margin-bottom:3px;}
.page-header-title p{font-size:12px;color:var(--text2);}

/* TABS */
.tab-row{display:flex;gap:3px;background:var(--surface2);padding:3px;border-radius:var(--radius2);width:fit-content;margin-bottom:16px;}
.tab-btn{padding:7px 14px;border-radius:6px;border:none;background:none;color:var(--text2);font-family:'DM Sans',sans-serif;font-size:12px;cursor:pointer;transition:all 0.2s;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px rgba(0,0,0,0.3);}

/* STAGE STUB */
.stage-stub{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;}
.stage-stub-icon{font-size:48px;margin-bottom:16px;}
.stage-stub h3{font-family:'Syne',sans-serif;font-size:18px;font-weight:700;margin-bottom:8px;}
.stage-stub p{font-size:13px;color:var(--text2);max-width:420px;line-height:1.6;}
.stage-stub .stage-badge{display:inline-block;padding:4px 12px;background:rgba(255,165,2,0.12);color:var(--warn);border:1px solid rgba(255,165,2,0.3);border-radius:20px;font-size:11px;font-weight:700;margin-bottom:12px;}

/* ORDER LINE */
.order-line-row{display:grid;grid-template-columns:1fr 90px auto;gap:8px;align-items:center;padding:10px;background:var(--surface2);border:1px solid var(--border);border-radius:8px;margin-bottom:8px;}
.inline-section{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px;}
.inline-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--accent);margin-bottom:10px;}

/* RUN CARD */
.run-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px;transition:border-color 0.2s;}
.run-card:hover{border-color:var(--border2);}
.run-card.active-run{border-color:rgba(0,230,160,0.3);background:rgba(0,230,160,0.02);}
.run-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;}
.run-product-strip{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}

/* PROGRESS BAR */
.progress-bar{height:5px;background:var(--surface3);border-radius:3px;overflow:hidden;}
.progress-fill{height:100%;border-radius:3px;transition:width 0.5s ease;}

/* ============================================================================
   DISPATCH SCAN — Stage 3
   ============================================================================ */

/* Layout */
.ds-work-area{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;}
.ds-left-col,.ds-right-col{display:flex;flex-direction:column;gap:0;}
.ds-no-run-msg{text-align:center;padding:60px 20px;}
.ds-no-run-msg h3{font-family:'Syne',sans-serif;font-weight:700;}

/* Run info panel */
.ds-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:14px;}
.ds-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3);margin-bottom:2px;}
.ds-value{font-size:13px;font-weight:500;}
.ds-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--accent);margin-bottom:10px;}
.ds-order-row{padding:8px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius2);margin-bottom:6px;}

/* Scan input row */
.ds-scan-input-row{display:flex;gap:8px;margin-bottom:12px;}
.ds-scan-input{flex:1;background:var(--surface2);border:1px solid var(--border2);color:var(--text);border-radius:var(--radius2);padding:10px 12px;font-family:'DM Sans',sans-serif;font-size:14px;outline:none;transition:border-color 0.2s;}
.ds-scan-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,230,160,0.1);}
.ds-scan-input:disabled{opacity:0.4;cursor:not-allowed;}
.btn-sm{padding:6px 12px;font-size:12px;}

/* Order tag list */
.ds-tag-list{display:flex;flex-direction:column;gap:4px;}
.ds-tag-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius2);font-size:13px;transition:all 0.2s;}
.ds-tag-pass{background:rgba(0,230,160,0.08);border:1px solid rgba(0,230,160,0.2);}
.ds-tag-pending{background:var(--surface2);border:1px solid var(--border);}
.ds-tag-icon{font-size:14px;width:18px;text-align:center;}
.ds-tag-pass .ds-tag-icon{color:var(--accent);}
.ds-tag-pending .ds-tag-icon{color:var(--text3);}
.ds-tag-label{flex:1;}
.ds-all-pass{color:var(--accent);font-size:12px;font-weight:600;padding:8px 0;text-align:center;}
.ds-remove-tag-btn{margin-left:auto;padding:2px 6px !important;font-size:14px;background:transparent;border:none;color:var(--text3);cursor:pointer;}
.ds-remove-tag-btn:hover{color:var(--danger);}

/* Product pool progress */
.ds-pool-row{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:12px;}
.ds-pool-row:last-child{border-bottom:none;}
.ds-pool-product{font-weight:500;}
.ds-pool-count{font-weight:700;white-space:nowrap;min-width:60px;text-align:right;}
.ds-pool-met .ds-pool-count{color:var(--accent);}
.ds-pool-over .ds-pool-count{color:var(--warn);}
.ds-pool-pending .ds-pool-count{color:var(--text2);}

/* Cylinder loaded list */
.ds-loaded-list{display:flex;flex-direction:column;gap:4px;}
.ds-loaded-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius2);font-size:12px;animation:slideIn 0.2s ease;}
.ds-loaded-pass{background:rgba(0,230,160,0.06);border:1px solid rgba(0,230,160,0.15);}
.ds-loaded-warn{background:rgba(255,165,2,0.06);border:1px solid rgba(255,165,2,0.2);}
.ds-loaded-icon{font-size:14px;width:16px;text-align:center;}
.ds-loaded-pass .ds-loaded-icon{color:var(--accent);}
.ds-loaded-warn .ds-loaded-icon{color:var(--warn);}
.ds-loaded-id{font-weight:600;min-width:80px;}
.ds-loaded-product{color:var(--text2);min-width:80px;}
.ds-override-tag{background:rgba(255,165,2,0.15);color:var(--warn);font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;margin-left:4px;}
.ds-remove-cyl-btn{margin-left:auto;}

/* Warning box */
.ds-warning-box{background:rgba(255,165,2,0.08);border:1px solid rgba(255,165,2,0.3);border-radius:var(--radius2);padding:14px;margin-bottom:12px;animation:slideIn 0.25s ease;}
.ds-warning-header{color:var(--warn);font-family:'Syne',sans-serif;font-size:13px;font-weight:700;margin-bottom:6px;}
.ds-warning-reason{font-size:12px;color:var(--text2);margin-bottom:6px;line-height:1.5;}
.ds-warning-cyl{font-size:12px;margin-bottom:10px;}
.ds-override-row{display:flex;flex-direction:column;gap:8px;}
.ds-override-input{width:100%;background:var(--surface);border:1px solid rgba(255,165,2,0.3);color:var(--text);border-radius:var(--radius2);padding:8px 10px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;resize:none;}
.ds-override-input:focus{border-color:var(--warn);box-shadow:0 0 0 3px rgba(255,165,2,0.1);}
.ds-override-actions{display:flex;gap:8px;}

/* Scan log */
.ds-log-entry{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:4px;font-size:11px;margin-bottom:2px;line-height:1.4;}
.ds-log-pass{background:rgba(0,230,160,0.04);}
.ds-log-error{background:rgba(255,71,87,0.06);}
.ds-log-warn{background:rgba(255,165,2,0.06);}
.ds-log-time{color:var(--text3);min-width:64px;white-space:nowrap;}
.ds-log-cyl{font-weight:600;min-width:80px;}
.ds-log-result{font-weight:700;min-width:44px;}
.ds-log-pass .ds-log-result{color:var(--accent);}
.ds-log-error .ds-log-result{color:var(--danger);}
.ds-log-warn .ds-log-result{color:var(--warn);}
.ds-log-reason{flex:1;color:var(--text2);}
.ds-log-override{display:block;color:var(--warn);font-style:italic;margin-top:2px;}

/* Finalise gate */
.ds-gate-ready{display:flex;align-items:center;gap:14px;padding:4px 0;}
.ds-gate-ready-icon{font-size:28px;color:var(--accent);}
.ds-gate-blocked{display:flex;align-items:flex-start;gap:14px;padding:4px 0;}
.ds-gate-blocked-icon{font-size:28px;color:var(--danger);}
.ds-gate-errors{margin-top:6px;}
.ds-gate-error{font-size:12px;color:var(--danger);margin-bottom:3px;}
.ds-finalised-banner{display:flex;align-items:center;gap:14px;padding:12px;background:rgba(0,230,160,0.06);border:1px solid rgba(0,230,160,0.2);border-radius:var(--radius2);}
.ds-finalised-icon{font-size:28px;color:var(--accent);}

/* ============================================================================
   DELIVERY SCAN + PROOF — Stage 4
   ============================================================================ */

/* Selectors row */
.dlv-selectors{display:flex;gap:10px;align-items:center;flex-wrap:wrap;}

/* Delivery scan layout */
.dlv-work-area{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;}
.dlv-left-col,.dlv-right-col{display:flex;flex-direction:column;gap:0;}

/* Delivery context */
.dlv-context-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.dlv-ctx-block{padding:8px 0;}
.dlv-ctx-detail{font-size:13px;margin-bottom:4px;}
.dlv-req-row{font-size:13px;padding:3px 0;}

/* Delivery checklist */
.dlv-checklist{display:flex;flex-direction:column;gap:6px;}
.dlv-check-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius2);font-size:13px;}
.dlv-check-pass{background:rgba(0,230,160,0.06);border:1px solid rgba(0,230,160,0.15);color:var(--accent);}
.dlv-check-fail{background:rgba(255,71,87,0.06);border:1px solid rgba(255,71,87,0.15);color:var(--danger);}
.dlv-warning-inline{background:rgba(255,165,2,0.08);border:1px solid rgba(255,165,2,0.25);border-radius:var(--radius2);padding:10px;margin-top:10px;font-size:12px;color:var(--warn);}

/* Count tags for progress */
.count-tag{display:inline-flex;align-items:center;padding:3px 8px;border-radius:6px;font-size:11px;font-weight:600;margin:2px;background:var(--surface3);border:1px solid var(--border2);color:var(--text2);}
.count-met{background:rgba(0,230,160,0.08);border-color:rgba(0,230,160,0.3);color:var(--accent);}
.count-short{background:rgba(255,165,2,0.08);border-color:rgba(255,165,2,0.3);color:var(--warn);}

/* Proof page layout */
.prf-work-area{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start;}
.prf-left-col,.prf-right-col{display:flex;flex-direction:column;gap:0;}

/* Signature canvas */
.prf-sig-container{border:1px solid var(--border2);border-radius:var(--radius2);overflow:hidden;background:var(--surface2);margin-bottom:8px;}
.prf-sig-container canvas{display:block;width:100%;height:180px;cursor:crosshair;}
.prf-sig-actions{display:flex;gap:8px;justify-content:flex-end;}

/* Photo upload */
.prf-photo-area{min-height:180px;}
.prf-photo-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border:2px dashed var(--border2);border-radius:var(--radius2);cursor:pointer;transition:all 0.2s;color:var(--text2);font-size:13px;text-align:center;}
.prf-photo-drop:hover,.prf-photo-drag-over{border-color:var(--accent);color:var(--accent);background:rgba(0,230,160,0.03);}
.prf-preview{margin-top:10px;}
.prf-captured-badge{display:flex;align-items:center;gap:4px;margin-bottom:8px;}

/* Proof tab panels */
.prf-tab-panel{margin-top:12px;}

/* ============================================================================
   EXCEPTION PANEL — exception-panel.js component styles
   ============================================================================ */

/* Shared panel */
.exc-panel{border-left:4px solid var(--border2);padding:16px;border-radius:8px;margin-bottom:12px;}
.exc-error{border-color:var(--danger);background:rgba(255,71,87,0.05);}
.exc-warning{border-color:var(--warn);background:rgba(255,165,2,0.05);}
.exc-info{border-color:var(--accent);background:rgba(0,102,255,0.05);}

.exc-header{display:flex;align-items:center;gap:8px;font-weight:700;margin-bottom:8px;font-size:14px;}
.exc-icon{font-size:16px;}
.exc-reason{font-size:14px;color:var(--text);margin-bottom:12px;line-height:1.5;}

.exc-actions-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.6px;color:var(--text2);margin-bottom:6px;}
.exc-actions-list{list-style:disc;padding-left:20px;font-size:13px;color:var(--text2);line-height:1.7;}
.exc-override-prompt{font-size:12px;color:var(--warn);font-weight:600;margin-top:10px;padding:8px 10px;background:rgba(255,165,2,0.08);border-radius:6px;}

/* Exception log */
.exc-log{max-height:280px;overflow-y:auto;display:flex;flex-direction:column;gap:2px;}
.exc-log-empty{font-size:12px;color:var(--text3);text-align:center;padding:20px 0;}
.exc-log-row{display:flex;align-items:flex-start;gap:8px;padding:6px 8px;border-radius:4px;font-size:11px;line-height:1.4;}
.exc-log-time{color:var(--text3);min-width:64px;white-space:nowrap;}
.exc-log-cyl{font-weight:600;min-width:80px;}
.exc-log-action{color:var(--text2);min-width:60px;}
.exc-log-badge{font-weight:700;min-width:56px;padding:1px 6px;border-radius:10px;font-size:9px;text-align:center;text-transform:uppercase;}
.exc-badge-pass{background:rgba(0,230,160,0.12);color:var(--accent);}
.exc-badge-warning{background:rgba(255,165,2,0.12);color:var(--warn);}
.exc-badge-error{background:rgba(255,71,87,0.12);color:var(--danger);}
.exc-badge-blocked{background:rgba(255,71,87,0.18);color:var(--danger);}
.exc-log-reason{flex:1;color:var(--text2);}
.exc-log-override{display:block;color:var(--warn);font-style:italic;margin-top:2px;}

/* Blocked gate */
.exc-gate{border:1px solid var(--danger);border-radius:8px;padding:16px;background:rgba(255,71,87,0.05);margin-bottom:12px;}
.exc-gate-title{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--danger);margin-bottom:10px;}
.exc-gate-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px;}
.exc-gate-item{font-size:13px;color:var(--text);line-height:1.5;}

@keyframes popIn{from{opacity:0;transform:translateY(10px) scale(0.97);}to{opacity:1;transform:translateY(0) scale(1);}}
@keyframes slideIn{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.scrollbar::-webkit-scrollbar{width:4px;}
.scrollbar::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px;}
/* Responsive overrides moved to mobile.css — legacy query kept as fallback */
@media(max-width:900px){.stat-grid{grid-template-columns:repeat(2,1fr);}.sidebar{transform:translateX(-100%);}.main-content{margin-left:0;}}