/* Font loaded via <link> in HTML head for non-blocking render (v3.7.34) */
:root{--bg:#1A1D23;--bg2:#22262E;--bg3:#2A2F38;--bg4:#181B20;--teal:#0099A8;--tl:#00BCD4;--td:rgba(0,153,168,.15);--grn:#27AE60;--gd:rgba(39,174,96,.12);--red:#E74C3C;--rd:rgba(231,76,60,.12);--amb:#F2994A;--ad:rgba(242,153,74,.12);--blu:#009ADE;--bd:rgba(0,154,222,.12);--pur:#7C3AED;--pd:rgba(124,58,237,.12);--wh:#FFF;--tx:#E0E0E0;--t2:#9CA3AF;--t3:#848B98;--bdr:rgba(255,255,255,.06);--bt:rgba(0,153,168,.2);--phi:1.618;--sp1:8px;--sp2:13px;--sp3:21px;--sp4:34px;--fs-xs:8px;--fs-sm:10px;--fs-base:13px;--fs-md:21px;--fs-lg:34px;--sidebar-w:230px}
*{margin:0;padding:0;box-sizing:border-box}
html{height:100%}
body{font-family:Verdana,Geneva,sans-serif;background:var(--bg);color:var(--tx);line-height:1.618;-webkit-font-smoothing:antialiased;font-size:var(--fs-base);-webkit-user-select:none;-moz-user-select:none;user-select:none;min-height:100%}
input,textarea,select,[contenteditable="true"]{-webkit-user-select:text;-moz-user-select:text;user-select:text}

/* ── Global Scrollbar Theme ── */
*{scrollbar-width:thin;scrollbar-color:rgba(0,188,212,.18) transparent}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(0,188,212,.18);border-radius:4px;transition:background .2s}
::-webkit-scrollbar-thumb:hover{background:rgba(0,188,212,.35)}
::-webkit-scrollbar-corner{background:transparent}

.top{display:flex;align-items:center;justify-content:space-between;padding:var(--sp2) var(--sp3);background:var(--bg2);border-bottom:1px solid var(--bdr);flex-shrink:0;z-index:100}
.top-left{display:flex;align-items:center;gap:var(--sp2);flex:1}
.hud-brand{display:flex;flex-direction:column;gap:1px;margin:-5px 0 0 7px}
.hud-version-row{display:flex;align-items:center;gap:8px}
.hud-version{font-size:16px;font-weight:600;color:rgba(0,188,212,.4);letter-spacing:2px;text-transform:uppercase;line-height:normal}
.hud-build{font-size:9px;font-weight:400;color:rgba(255,255,255,.3);letter-spacing:1.5px;text-transform:uppercase;line-height:normal}
.top-center{flex:1;display:flex;align-items:center;justify-content:center;gap:4px}
.hud-greeting{font-size:10px;font-family:Verdana,Geneva,sans-serif;font-weight:600;letter-spacing:.4px;color:rgba(52,211,153,.85);padding:0;background:rgba(52,211,153,.08);border:1px solid transparent;border-radius:8px;opacity:0;max-width:0;overflow:hidden;transition:opacity .5s ease,max-width .5s ease,padding .5s ease,border-color .5s ease,margin .5s ease;pointer-events:none;white-space:nowrap;box-shadow:0 0 8px rgba(52,211,153,.1);margin-right:0}
.hud-greeting.visible{opacity:1;max-width:280px;padding:4px 14px;border-color:rgba(52,211,153,.25);margin-right:6px}
.hud-greeting.fade-out{opacity:0;max-width:0;padding:0;border-color:transparent;margin-right:0}
.top-actions{display:flex;align-items:center;gap:var(--sp1)}
.top-right{display:flex;align-items:center;gap:var(--sp2);flex:1;justify-content:flex-end}
.utc-clock{display:flex;flex-direction:column;align-items:flex-end;gap:2px;line-height:1.2;margin:5px -4px 0 0}
.utc-clock .utc-line1{display:flex;align-items:baseline;gap:10px;white-space:nowrap}
.utc-clock .utc-time{font-size:var(--fs-base);font-weight:600;color:rgba(255,255,255,.45);letter-spacing:2px;text-transform:uppercase;font-family:inherit}
.utc-clock .utc-greg{font-size:var(--fs-base);font-weight:600;color:rgba(0,188,212,.4);letter-spacing:2px;text-transform:uppercase}
.utc-clock .utc-line2{display:flex;align-items:center;gap:10px;margin-top:2px;white-space:nowrap}
.utc-clock .utc-hijri{font-size:11px;font-weight:700;color:rgba(0,155,72,.4);letter-spacing:1.5px}
/* ── DASHBOARD PANEL ── */
.dash{padding:var(--sp2) 8px 0 var(--sp3);background:var(--bg);display:flex;flex-direction:column;gap:var(--sp1)}
.dash-greeting{display:flex;align-items:center;justify-content:space-between;padding:5px 13px;background:var(--bg2);border:1px solid var(--bdr);border-radius:8px 8px 0 0;border-bottom:none;margin-bottom:-1px}
.dash-sun{display:flex;align-items:center;gap:5px;flex:0 0 auto}
.dash-sun-label{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--t3)}
.dash-greet-text{font-family:Verdana,Geneva,sans-serif;font-size:10px;font-weight:600;color:var(--t2);flex:1;text-align:center}
.dash-moon{display:flex;align-items:center;gap:5px}
.dash-moon-label{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--t3)}
.dash-moon-phase{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--t3);opacity:.65}
.top-nav-icons{display:inline-flex;align-items:center;gap:6px;align-self:center}
/* ── Clock Cards ── */
.dash-header-row{display:flex;gap:10px;align-items:stretch;flex-wrap:nowrap;overflow-x:auto;margin-bottom:6px}
.dash-card.dash-card-status{width:260px;flex:none}
.dash-card.dash-card-cal{width:260px;flex:none;min-height:350px}
.dash-center-col{display:flex;flex-direction:column;flex:1;min-width:0;gap:2px;justify-content:space-between}
.dash-clocks-row{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;align-content:flex-start;padding-top:8px}
.clock-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:8px;padding:6px 4px 5px;min-width:80px;flex:1;max-width:110px;display:flex;flex-direction:column;align-items:center;gap:1px;transition:transform .15s,box-shadow .15s}
.clock-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.clock-flag{font-size:14px;line-height:1;margin-bottom:0}
.clock-svg{line-height:0}
.clock-time{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:var(--wh);letter-spacing:.5px}
.clock-city{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--t3);text-align:center;width:100%}
.clock-date{font-size:7px;color:var(--t3);font-family:'JetBrains Mono',monospace}
.clock-weather{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--t2);margin-top:1px}
.clock-weather svg{flex-shrink:0}
/* .clock-holiday styles removed — holidays disabled */
.dash-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:12px 16px;flex:1;min-width:200px}
.dash-card-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--tl);margin-bottom:6px;padding:6px 10px;background:rgba(0,0,0,.2);border-radius:4px;border-bottom:1px solid rgba(255,255,255,.04);position:relative;text-align:center}
.dash-card-title::after{content:'';position:absolute;bottom:-1px;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,rgba(0,188,212,.2),transparent)}
/* ── Status Card Panes ── */
.dash-card-status{padding:8px 10px;overflow:hidden !important;scrollbar-width:none;-ms-overflow-style:none}
.dash-card-status::-webkit-scrollbar{display:none}
.dash-card-status .fl-label-plate{margin:0 0 4px;padding:3px 4px;overflow:hidden}
.dash-card-status .fl-tabs{overflow:hidden}
.dash-card-status .fl-tab{font-size:7px;padding:4px 5px;letter-spacing:.5px}
.dash-card-status .ds-pane{overflow:hidden}
.dash-card-status .donut-wrap svg{width:80px;height:80px}
.dash-card-status .donut-wrap{gap:10px}
.dash-card-status .donut-leg-item{font-size:9px;gap:4px}
.dash-card-status .donut-leg-dot{width:6px;height:6px}
.dash-card-status .donut-leg-count{font-size:10px;min-width:12px}
.dash-card-status .delayed-list{margin-top:4px;gap:2px}
.dash-card-status .delayed-item{font-size:9px;padding:2px 6px}
.ds-pane{min-height:0}
.ds-separator{border:none;border-top:1px solid rgba(255,255,255,.06);margin:5px 0 4px;position:relative}
.ds-separator::after{content:'';position:absolute;top:-1px;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,rgba(0,188,212,.12),transparent)}
/* ── Status KPI Summary ── */
.ds-kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.ds-kpi-tile{padding:3px 6px;border-radius:3px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.03)}
.ds-kpi-tile-val{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;line-height:1.2}
.ds-kpi-tile-lbl{font-size:6px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--t3);margin-top:1px}
.ds-kpi-tile-sub{font-family:'JetBrains Mono',monospace;font-size:6px;color:var(--t3);margin-top:1px}
.ds-kpi-tile.ds-wide{grid-column:1/-1}
#prodExcellencePane .ds-kpi-grid{gap:3px}
#prodExcellencePane .ds-kpi-tile{padding:3px 6px;background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.04)}
#prodExcellencePane .ds-kpi-tile-val{font-size:10px;font-weight:700}
#prodExcellencePane .ds-kpi-tile-lbl{font-size:7px;letter-spacing:.4px}
#prodExcellencePane .ds-kpi-tile-sub{font-size:7px}
/* ── Turnaround Tab ── */
.ds-tat-row{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.ds-tat-row:last-child{border-bottom:none}
.ds-tat-icon{font-size:12px;flex-shrink:0;width:18px;text-align:center}
.ds-tat-info{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}
.ds-tat-label{font-size:9px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.3px}
.ds-tat-range{font-family:'JetBrains Mono',monospace;font-size:8px;color:var(--t3)}
.ds-tat-val{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end}
.ds-tat-n{font-size:7px;font-weight:400;color:var(--t3);letter-spacing:.3px}
.ds-pmt-bar{display:flex;align-items:center;gap:6px;padding:6px 0 2px;border-top:1px solid rgba(255,255,255,.06);margin-top:4px}
.ds-pmt-bar .ds-tat-label{flex-shrink:0}
.ds-pmt-track{flex:1;height:4px;border-radius:2px;background:rgba(255,255,255,.06);overflow:hidden}
.ds-pmt-fill{height:100%;border-radius:2px;transition:width .4s}
.ds-pmt-pct{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:700;flex-shrink:0}
/* ── Corrections Tab ── */
.ds-corr-wrap{display:flex;align-items:center;gap:12px;padding:4px 0}
.ds-corr-wrap svg{flex-shrink:0}
.ds-corr-detail{display:flex;flex-direction:column;gap:3px}
.ds-corr-leg{display:flex;align-items:center;gap:6px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;color:var(--t2)}
.ds-corr-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.ds-corr-count{font-weight:400;color:var(--t3);font-size:9px}
.ds-corr-avgs{display:flex;gap:6px;margin-top:4px;justify-content:center}
.ds-corr-avg-box{text-align:center;padding:3px 8px;border-radius:3px;background:rgba(255,255,255,.04);flex:1}
.ds-corr-avg-num{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700}
.ds-corr-avg-lbl{font-size:7px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--t3);margin-top:1px}
/* ── Forecast Tab ── */
.ds-fc-title{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--tl);margin:6px 0 3px;padding-bottom:3px;border-bottom:1px solid rgba(0,188,212,.12)}
.ds-fc-list{display:flex;flex-direction:column;gap:2px}
.ds-fc-row{display:flex;align-items:center;gap:4px;padding:2px 4px;border-radius:3px;background:rgba(255,255,255,.02);font-size:9px}
.ds-fc-row:hover{background:rgba(255,255,255,.05)}
.ds-fc-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--t2);font-weight:600}
.ds-fc-rev{font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;color:var(--wh);flex-shrink:0}
.ds-fc-jobs{font-family:'JetBrains Mono',monospace;font-size:7px;color:var(--t3);flex-shrink:0;min-width:18px;text-align:right}
.ds-fc-delta{font-family:'JetBrains Mono',monospace;font-size:7px;font-weight:700;padding:1px 4px;border-radius:2px;flex-shrink:0;min-width:32px;text-align:center}
/* ── Delayed List ── */
@keyframes delayBlink{0%,100%{opacity:1}50%{opacity:.4}}
.delayed-list{margin-top:8px;display:flex;flex-direction:column;gap:3px}
.delayed-item{display:flex;align-items:center;justify-content:space-between;font-size:10px;padding:3px 8px;border-radius:4px;background:rgba(231,76,60,.08);border:1px solid rgba(231,76,60,.15);animation:delayBlink 2s ease-in-out infinite;color:#E74C3C}
.delayed-item .di-skc{font-family:'JetBrains Mono',monospace;font-weight:700}
.delayed-item .di-days{font-family:'JetBrains Mono',monospace;font-weight:600;font-size:9px;opacity:.85}
/* ── Donut Chart ── */
/* ── 3-Column Board ── */
.fx-ticker{overflow:hidden;background:var(--bg4);border:1px solid var(--bdr);border-radius:6px;position:relative;height:28px;display:flex;align-items:center;width:100%}
.fx-ticker-label{background:rgba(39,174,96,.12);color:var(--grn);font-size:8px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:0 8px;height:100%;display:flex;align-items:center;white-space:nowrap;z-index:2;flex-shrink:0;border-right:1px solid rgba(39,174,96,.3);box-shadow:3px 0 8px rgba(0,0,0,.3);font-family:'JetBrains Mono',monospace}
.fx-ticker-label-r{background:rgba(39,174,96,.12);color:var(--grn);font-size:8px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:0 8px;height:100%;display:flex;align-items:center;white-space:nowrap;z-index:2;flex-shrink:0;border-left:1px solid rgba(39,174,96,.3);box-shadow:-3px 0 8px rgba(0,0,0,.3);font-family:'JetBrains Mono',monospace}
.fx-ticker-scroll{overflow:hidden;flex:1;contain:content}
.fx-ticker-inner{display:flex;gap:6px;align-items:center;white-space:nowrap;will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);padding:0 8px}
.fx-pair{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;background:var(--bg3);font-size:10px;font-family:'JetBrains Mono',monospace;white-space:nowrap;border:1px solid transparent}
.fx-pair:hover{border-color:var(--bdr);transform:translateY(-1px)}
.fx-flag{font-size:11px}
.fx-code{font-weight:700;color:var(--tl);font-size:9px}
.fx-rate{font-weight:600;color:var(--wh)}
.fx-delta{font-size:8px;font-weight:600}
.fx-delta.up{color:var(--grn)}
.fx-delta.down{color:var(--red)}
.fx-delta.flat{color:var(--t3)}
.fx-updated{font-size:7px;color:var(--t3);white-space:nowrap;flex-shrink:0}
.fx-sep{width:1px;height:16px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.12),transparent);margin:0 8px;flex-shrink:0}
.fx-sep.metal-sep,.fx-sep.crypto-sep{width:1px;height:18px;background:linear-gradient(180deg,transparent,rgba(0,188,212,.3),transparent);margin:0 10px}
.fx-ticker-sep{color:#00C853;font-weight:700;margin:0 4px;font-size:10px;flex-shrink:0}
.fx-pair.metal .fx-code{color:var(--amb)}
.fx-pair.crypto .fx-code{color:var(--pur)}
/* ── Risk Indicator Ticker ── */
.fx-pair.risk-cu .fx-code{color:#FFA726}
.fx-pair.risk-oil .fx-code{color:#FFA726}
.fx-pair.risk-bdi .fx-code{color:#FFA726}
.fx-pair.risk-cpi .fx-code{color:rgba(255,255,255,.5);font-size:8px}
.risk-cpi-label{color:#FFA726;font-size:8px;font-weight:700;letter-spacing:.8px;margin-right:6px;flex-shrink:0}
.risk-cpi-val.up{color:#00C853}
.risk-cpi-val.flat{color:#FFA726}
.risk-cpi-val.down{color:#EF4444}
/* ── Regional Risk Ticker ── */
.risk-ticker{overflow:hidden;background:var(--bg4);border:1px solid var(--bdr);border-radius:6px;position:relative;height:28px;display:flex;align-items:center;width:100%}
.risk-ticker-label{background:rgba(220,38,38,.12);color:#EF4444;font-size:8px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:0 8px;height:100%;display:flex;align-items:center;white-space:nowrap;z-index:2;flex-shrink:0;border-right:1px solid rgba(220,38,38,.3);box-shadow:3px 0 8px rgba(0,0,0,.3);font-family:'JetBrains Mono',monospace}
.risk-ticker-label-r{background:rgba(220,38,38,.12);color:#EF4444;font-size:8px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:0 8px;height:100%;display:flex;align-items:center;white-space:nowrap;z-index:2;flex-shrink:0;border-left:1px solid rgba(220,38,38,.3);box-shadow:-3px 0 8px rgba(0,0,0,.3);font-family:'JetBrains Mono',monospace}
.risk-ticker-scroll{overflow:hidden;flex:1;contain:content}
.risk-ticker-inner{display:flex;gap:6px;align-items:center;white-space:nowrap;will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0);padding:0 8px}
/* Hover pause handled by rAF ticker engine in JS */
.risk-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:5px;background:var(--bg3);font-size:10px;font-family:'JetBrains Mono',monospace;white-space:nowrap;border:1px solid transparent;cursor:default}
.risk-chip:hover{border-color:var(--bdr);transform:translateY(-1px)}
.risk-chip .risk-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.risk-chip .risk-name{font-weight:700;color:var(--tl);font-size:9px}
.risk-chip .risk-level{font-weight:600;font-size:9px}
.risk-chip .risk-evts{font-size:8px;color:var(--t3)}
.risk-sep{width:1px;height:16px;background:linear-gradient(180deg,transparent,rgba(220,38,38,.25),transparent);margin:0 8px;flex-shrink:0}
.risk-loading{color:var(--t3);font-size:10px;font-family:'JetBrains Mono',monospace;padding:0 8px}
.fx-loading{font-size:9px;color:var(--t3)}
.fx-base-code{font-weight:400;color:var(--t3);font-size:8px}
/* ── Board Card (universal base for all 4 board row cards) ── */
.board-card{background:linear-gradient(180deg,#2A2F38 0%,#242830 100%);border:1px solid rgba(255,255,255,.08);border-radius:6px;display:flex;flex-direction:column;padding:0;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 2px 8px rgba(0,0,0,.3);min-height:0;height:100%}
.board-card-map{flex:1;min-width:0}
.board-card-workspace{overflow:hidden;flex:1.6;min-width:0}
.board-card-prodstatus{flex:1;min-width:0}
.board-card.card-min{height:58px;max-height:58px;overflow:hidden}
.board-card.card-min .fl-top-handle{border-bottom-color:rgba(0,188,212,.15)}
.board-card .fl-top-handle{cursor:pointer}
.prodstatus-panes{position:relative;flex:1;min-height:0;overflow:hidden}
/* ── KPI Command Center ── */
.kpi-divider{height:1px;margin:12px 0 6px;background:linear-gradient(90deg,transparent,rgba(0,188,212,.25),transparent)}
body:not(.role-admin) .kpi-row,body:not(.role-admin) .kpi-divider{display:none!important}
.board-card-kpi{flex:1;min-width:0}
.kpi-panes{padding:10px 14px 12px}
.kpi-pane{font-family:'JetBrains Mono',monospace}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:10px}
.kpi-tile{background:var(--bg3);border:1px solid var(--bdr);border-radius:6px;padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.kpi-tile-val{font-size:18px;font-weight:800;line-height:1.1;color:var(--wh)}
.kpi-tile-val.kpi-green{color:var(--grn)}
.kpi-tile-val.kpi-red{color:var(--red)}
.kpi-tile-val.kpi-amber{color:var(--amb)}
.kpi-tile-val.kpi-teal{color:var(--tl)}
.kpi-tile-lbl{font-size:8px;letter-spacing:.6px;text-transform:uppercase;color:var(--t3)}
.kpi-tile-sub{font-size:8px;color:var(--t3);margin-top:2px}
.kpi-bar-wrap{background:var(--bg3);border:1px solid var(--bdr);border-radius:6px;padding:8px 12px;margin-bottom:8px}
.kpi-bar-label{font-size:8px;letter-spacing:.5px;text-transform:uppercase;color:var(--t3);margin-bottom:4px}
.kpi-bar-track{height:6px;background:rgba(255,255,255,.06);border-radius:3px;overflow:hidden}
.kpi-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}
.kpi-bar-val{font-size:10px;font-weight:700;color:var(--wh);margin:5px -4px 0 0}
.kpi-overdue-list{max-height:120px;overflow-y:auto;margin-top:6px}
.kpi-overdue-row{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;border-radius:4px;font-size:9px;border-bottom:1px solid rgba(255,255,255,.04)}
.kpi-overdue-row:last-child{border-bottom:none}
.kpi-overdue-skc{font-weight:700;color:var(--tl)}
.kpi-overdue-amt{color:var(--wh)}
.kpi-overdue-days{color:var(--red);font-weight:700}
.kpi-section-title{font-size:8px;letter-spacing:.8px;text-transform:uppercase;color:var(--t3);margin:10px 0 6px;padding-bottom:4px;border-bottom:1px solid rgba(255,255,255,.05)}
.kpi-flow-row{display:flex;align-items:center;gap:4px;margin-bottom:6px;flex-wrap:wrap}
.kpi-flow-step{display:flex;flex-direction:column;align-items:center;padding:6px 10px;border-radius:5px;background:var(--bg3);border:1px solid var(--bdr);min-width:60px}
.kpi-flow-step-num{font-size:16px;font-weight:800;line-height:1}
.kpi-flow-step-lbl{font-size:7px;letter-spacing:.5px;text-transform:uppercase;color:var(--t3);margin-top:2px}
.kpi-flow-arrow{color:var(--t3);font-size:10px;flex-shrink:0}
.kpi-tat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:6px;margin-bottom:8px}
.kpi-tat-item{display:flex;justify-content:space-between;align-items:center;padding:5px 10px;border-radius:5px;background:var(--bg3);border:1px solid var(--bdr);font-size:9px}
.kpi-tat-label{color:var(--t2)}
.kpi-tat-val{font-weight:700;color:var(--tl)}
.kpi-yoy-row{display:flex;gap:10px;margin-bottom:8px}
.kpi-yoy-card{flex:1;background:var(--bg3);border:1px solid var(--bdr);border-radius:6px;padding:10px 12px}
.kpi-yoy-title{font-size:8px;letter-spacing:.5px;text-transform:uppercase;color:var(--t3);margin-bottom:6px}
.kpi-yoy-bars{display:flex;flex-direction:column;gap:4px}
.kpi-yoy-bar{display:flex;align-items:center;gap:8px;font-size:9px}
.kpi-yoy-year{min-width:32px;color:var(--t3);font-size:8px}
.kpi-yoy-track{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.kpi-yoy-fill{height:100%;border-radius:4px;transition:width .6s ease}
.kpi-yoy-num{min-width:48px;text-align:right;font-weight:700;color:var(--wh);font-size:10px}
.kpi-proj{background:rgba(0,188,212,.06);border:1px solid rgba(0,188,212,.15);border-radius:6px;padding:10px 12px;margin-top:8px}
.kpi-proj-title{font-size:8px;letter-spacing:.8px;text-transform:uppercase;color:var(--tl);margin-bottom:6px}
.kpi-proj-row{display:flex;justify-content:space-between;font-size:10px;padding:2px 0}
.kpi-proj-lbl{color:var(--t2)}
.kpi-proj-val{font-weight:700;color:var(--wh)}
.kpi-corr-wrap{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:5px;background:var(--bg3);border:1px solid var(--bdr);font-size:9px}
.kpi-corr-bar{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden;display:flex}
.kpi-corr-ac{background:var(--amb);height:100%}
.kpi-corr-hc{background:var(--pur);height:100%}
.prodstatus-panes>.prodstatus-body,.prodstatus-panes>.prod-pipeline-body{position:absolute;top:0;left:0;right:0;bottom:0;overflow-y:auto}
.board-card .fl-label-plate{letter-spacing:1px;white-space:nowrap}
.board-card>.fl-label-plate{justify-content:center;text-align:center}
.board-card-workspace{flex:1.6;min-width:0}
.aktenschrank-card{width:var(--sidebar-w);flex:none}
.aktenschrank-card .files-list{flex:1;overflow-y:auto;min-height:0}
.aktenschrank-card .file-item{margin-bottom:3px;border-radius:3px;background:rgba(255,255,255,.02);border:1px solid rgba(0,153,168,.1)}
.aktenschrank-card .file-item:hover{background:rgba(0,153,168,.04);border-color:rgba(0,153,168,.25)}
/* ── Production Status widget ── */
.prodstatus-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px 22px 6px;box-sizing:border-box}
.prodstatus-row{display:flex;align-items:center;gap:6px;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.03)}
.prodstatus-row:last-child{border-bottom:none}
.prodstatus-label{font-size:8px;color:var(--t2);letter-spacing:.6px;white-space:nowrap;width:84px;text-transform:uppercase;flex-shrink:0}
.prodstatus-bar{flex:1;height:10px;background:rgba(255,255,255,.04);border-radius:3px;overflow:hidden;position:relative}
.prodstatus-fill{height:100%;border-radius:3px;transition:width .4s ease}
.prodstatus-count{font-size:9px;font-weight:700;color:var(--t1);width:18px;text-align:right;font-family:'JetBrains Mono',monospace;flex-shrink:0}
.prodstatus-empty{font-size:9px;color:var(--t3);text-align:center;padding:20px 0}
.prod-pipeline-body{flex:1;padding:4px 10px 8px}
.prod-overview-row{display:flex;align-items:stretch;width:100%;box-sizing:border-box}
.prod-overview-row .delayed-list{margin-top:2px;gap:1px}
.prod-overview-row .delayed-item{font-size:8px;padding:1px 5px}
.prod-ov-col{flex:1;min-width:0;overflow:hidden;box-sizing:border-box}
.prod-ov-col-r{text-align:right;padding-right:2px}
.prod-ov-col-r .tat-list{align-items:flex-end}
.prod-ov-col-r .tat-list-row{justify-content:flex-end}
.prod-overview-divider{width:1px;background:rgba(255,255,255,.08);margin:0 4px;flex-shrink:0}
.prod-overview-sep{height:1px;background:rgba(255,255,255,.08);margin:4px 0}
.prod-ov-title{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);margin-bottom:4px}
.exc-tile{flex:1;min-width:0;overflow:hidden;box-sizing:border-box}
.exc-tile-r{text-align:right}
.exc-tile-r .tat-list{align-items:flex-end}
.exc-tile-r .tat-list-row{justify-content:flex-end}
.exc-pane{display:flex;flex-direction:column;padding-top:0!important}
.exc-sub-tabs{display:flex;gap:0;background:rgba(0,0,0,.25);border-radius:3px;padding:1px;margin-bottom:6px;flex-shrink:0}
.exc-sub-tab{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);background:transparent;border:none;padding:3px 8px;cursor:pointer;transition:.15s;border-radius:2px;white-space:nowrap;flex:1;text-align:center}
.exc-sub-tab:hover{color:var(--tl)}
.exc-sub-tab.active{color:var(--tl);background:rgba(0,153,168,.15)}
.exc-sub-pane{flex:1;overflow-y:auto;overflow-x:hidden}
.exc-section-title{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;opacity:.7}
.tat-cols{display:flex;gap:8px;margin-top:2px;overflow:hidden}
.tat-subcol{flex:1;min-width:0;overflow:hidden}
.tat-subcol-title{font-size:6px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:3px;opacity:.7}
.tat-list{display:flex;flex-direction:column;gap:2px}
.tat-list-row{display:flex;align-items:center;gap:4px;font-size:9px;font-family:'JetBrains Mono',monospace}
.tat-list-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.tat-list-lbl{flex:1;font-size:8px;color:var(--t2);letter-spacing:.3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-transform:uppercase}
.tat-list-val{font-weight:700;font-size:8px;text-align:right;min-width:22px;white-space:nowrap}
.donut-wrap-ov{gap:8px;overflow:hidden;margin-top:4px}
.donut-wrap-ov svg{width:90px;height:90px;flex-shrink:0}
.donut-wrap-ov .donut-legend{gap:2px}
.donut-wrap-ov .donut-leg-item{font-size:10px}
.donut-wrap-sm{gap:6px;overflow:hidden;margin-top:2px}
.donut-wrap-sm svg{width:64px;height:64px;flex-shrink:0}
#prodExcellencePane .donut-wrap-sm svg{width:90px;height:90px}
#prodExcellencePane .donut-wrap-sm .donut-leg-item{font-size:10px}
#prodExcellencePane .tat-list-lbl{font-size:9px}
#prodExcellencePane .tat-list-val{font-size:9px}
#prodExcellencePane .tat-subcol-title{font-size:7px}
#prodExcellencePane .cash-stat-num{font-size:12px}
#prodExcellencePane .cash-stat-lbl{font-size:7px}
.exc-trend{margin-top:6px;border-top:1px solid rgba(255,255,255,.06);padding-top:4px}
.exc-trend-title{font-size:6px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin-bottom:3px;opacity:.7}
.exc-trend-tbl{width:100%;border-collapse:collapse;font-size:7px;font-family:'JetBrains Mono',monospace}
.exc-trend-tbl th{font-size:6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);padding:1px 3px;text-align:center}
.exc-trend-tbl td{padding:1px 3px;text-align:center;color:var(--t2);font-size:7px}
.exc-trend-lbl{text-align:left!important;font-weight:700;font-size:6px!important;text-transform:uppercase;letter-spacing:.3px}
.trend-good{color:#27AE60;font-weight:700}
.trend-bad{color:#EF4444;font-weight:700}
.trend-neutral{color:var(--t3)}
.cash-summary{display:flex;gap:6px;justify-content:space-around}
.cash-stat{text-align:center;flex:1}
.cash-stat-num{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:800;line-height:1.3}
.cash-stat-lbl{font-size:6px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);margin-top:1px}
.donut-wrap-sm .donut-legend{gap:1px;min-width:0;overflow:hidden}
.donut-wrap-sm .donut-leg-item{font-size:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:uppercase}
.corr-hc-arc{animation:hcFlash 2.4s ease-in-out infinite}
.corr-hc-alert{color:#F59E0B;font-weight:700;animation:hcFlash 2.4s ease-in-out infinite}
@keyframes hcFlash{0%,100%{opacity:1}50%{opacity:.35}}
.corr-hx-arc{animation:hxFlash .8s ease-in-out infinite}
.corr-hx-alert{color:#EF4444;font-weight:700;animation:hxFlash .8s ease-in-out infinite}
@keyframes hxFlash{0%,100%{opacity:1}50%{opacity:.2}}
.prod-snap{display:flex;flex-direction:column;gap:1px;align-items:flex-end;overflow:hidden;margin-top:2px}
.prod-snap-item{display:flex;align-items:center;gap:4px;padding:1px 4px;border-radius:4px;border:1px solid transparent;white-space:nowrap;max-width:100%;box-sizing:border-box}
.prod-snap-num{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:800;line-height:1;min-width:14px;text-align:right}
.prod-snap-lbl{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--t3)}
.prod-snap-active{border-radius:4px}
@keyframes snapPulse{0%,100%{background:var(--snap-bg1)}50%{background:var(--snap-bg2)}}
.pipe-sub-tabs{display:flex;justify-content:flex-end;gap:2px;padding:0 0 4px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:4px}
.pipe-sub-tab{background:none;border:none;color:var(--t3);font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 6px;border-radius:4px;cursor:pointer;transition:all .15s;white-space:nowrap}
.pipe-sub-tab:hover{color:var(--t1);background:rgba(255,255,255,.04)}
.pipe-sub-tab.active{color:var(--tab-accent,var(--t1));background:rgba(255,255,255,.06)}
.pipe-sub-cnt{font-family:'JetBrains Mono',monospace;font-size:7px;opacity:.7;margin-left:1px}
.pipe-sub-pane{padding:2px 0}
.pipe-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.pipe-bucket{margin-bottom:8px}
.pipe-bucket-hdr{font-size:8px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;padding:3px 0 2px;border-bottom:1px solid rgba(255,255,255,.06)}
.pipe-bucket-count{font-family:'JetBrains Mono',monospace;font-size:8px;opacity:.6;margin-left:2px}
.pipe-card{background:var(--bg3);border-left:2px solid #9CA3AF;border-radius:3px;padding:3px 6px;margin:0}
.pipe-card-top{display:flex;justify-content:space-between;align-items:center}
.pipe-card-skc{font-family:'JetBrains Mono',monospace;font-size:8.5px;font-weight:700;color:var(--t1)}
.pipe-card-who{font-size:8px;color:var(--t3);font-weight:600}
.pipe-card-assign{background:var(--bg4);color:var(--t2);border:1px solid var(--bdr);border-radius:2px;font-size:8px;font-weight:600;padding:0 3px;cursor:pointer;outline:none;font-family:Verdana,Geneva,sans-serif;line-height:1.4}
.pipe-card-assign:hover{border-color:var(--amb);color:var(--t1)}
.pipe-card-assign:focus{border-color:var(--amb);box-shadow:0 0 0 1px rgba(242,156,56,.3)}
.pipe-card-action{font-size:8px;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-board-row{display:flex;gap:10px;margin-top:4px;overflow:hidden;height:var(--board-row-h,260px);transition:height .35s ease}
.dash-board-row.row-collapsed{height:58px}
.eotm-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:12px;text-align:center;min-width:140px;max-width:180px}
.eotm-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--amb);margin-bottom:6px}
.eotm-month{font-size:8px;color:var(--t3);margin-bottom:8px}
.eotm-img-area{width:100%;min-height:100px;border:1.5px dashed var(--bdr);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;overflow:hidden;position:relative}
.eotm-img-area:hover,.eotm-img-area.drag-over{border-color:var(--amb);background:rgba(242,156,56,.04)}
.eotm-img-area img{max-width:100%;max-height:160px;border-radius:6px;display:block}
.eotm-img-area .eotm-placeholder{font-size:9px;color:var(--t3);padding:10px}
.eotm-img-del{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;font-size:11px;line-height:18px;text-align:center;cursor:pointer;display:none}
.eotm-img-area:hover .eotm-img-del{display:block}
.file-locker-card{background:linear-gradient(180deg,#2A2F38 0%,#242830 100%);border:1px solid rgba(255,255,255,.08);border-radius:6px;flex:1;min-width:0;display:flex;flex-direction:column;padding:0;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 2px 8px rgba(0,0,0,.3)}
.fl-top-handle{height:10px;flex-shrink:0;background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.04) 25%,rgba(255,255,255,.07) 50%,rgba(255,255,255,.04) 75%,transparent 90%);border-bottom:1px solid rgba(255,255,255,.04);transition:background .15s}
.fl-top-handle:hover{background:linear-gradient(90deg,transparent 5%,rgba(0,188,212,.08) 25%,rgba(0,188,212,.15) 50%,rgba(0,188,212,.08) 75%,transparent 95%)}
.fl-label-plate{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--tl);text-align:left;padding:6px 10px;background:rgba(0,0,0,.2);border-bottom:1px solid rgba(255,255,255,.04);position:relative;display:flex;align-items:center;justify-content:flex-start;gap:8px;margin:4px 12px;border-radius:4px}
.fl-label-plate::after{content:'';position:absolute;top:-1px;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(0,188,212,.35),transparent)}
.fl-add-btn{width:16px;height:16px;border-radius:3px;border:1px solid rgba(0,188,212,.3);background:rgba(0,153,168,.1);color:var(--tl);font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1;transition:.15s;margin-left:auto}
.fl-add-btn:hover{background:rgba(0,153,168,.25);color:var(--wh);border-color:var(--tl)}
.fl-drawer{border-bottom:1px solid rgba(255,255,255,.05);padding:6px 10px;position:relative;background:linear-gradient(180deg,rgba(255,255,255,.01) 0%,transparent 100%);flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.fl-drawer:last-child{border-bottom:none}
.board-card-workspace .fl-drawer{max-height:none}
.fl-drawer-handle{width:28px;height:3px;background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.04));border-radius:2px;margin:0 auto 5px;box-shadow:0 1px 0 rgba(0,0,0,.3)}
.file-locker-card .files-list{flex:1;overflow-y:auto;min-height:0}
.file-locker-card .file-item{margin-bottom:3px;border-radius:3px;background:rgba(255,255,255,.02);border:1px solid rgba(0,153,168,.1)}
.file-locker-card .file-item:hover{background:rgba(0,153,168,.04);border-color:rgba(0,153,168,.25)}
.fl-tabs{display:flex;gap:0;background:rgba(0,0,0,.2);border-radius:4px;padding:1px;overflow-x:auto;overflow-y:hidden;flex:1}
.fl-tab{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);background:transparent;border:none;padding:5px 10px;cursor:pointer;transition:.15s;border-radius:3px;white-space:nowrap;flex:1;text-align:center}
.fl-tab:hover{color:var(--tl)}
.fl-tab.active{color:var(--tl);background:rgba(0,153,168,.15)}
/* Tab separators removed — tabs now split between Aktenschrank (files) and workspace cards */
/* ── Babe of the Month image area ── */
.botm-img-area{flex:1 1 0;height:0;margin:4px 10px;border:1.5px dashed rgba(255,255,255,.08);border-radius:6px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative;background:var(--bg4);-webkit-user-select:none;user-select:none}
.botm-img-area img{max-width:100%;max-height:100%;border-radius:4px;display:block;pointer-events:none;-webkit-user-drag:none;user-drag:none;-webkit-touch-callout:none;object-fit:contain}
.botm-img-area .botm-placeholder{font-size:9px;color:var(--t3);padding:10px}
.botm-img-area:hover{border-color:rgba(242,153,74,.25)}
.botm-img-del{position:absolute;top:4px;right:4px;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;font-size:11px;line-height:18px;text-align:center;cursor:pointer;display:none;z-index:2}
.botm-img-area:hover .botm-img-del{display:block}
.botm-zoom-btn{position:absolute;bottom:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.65);color:var(--tl);font-size:12px;line-height:22px;text-align:center;cursor:pointer;display:none;z-index:4;border:1px solid rgba(0,188,212,.3)}
.botm-zoom-btn:hover{background:rgba(0,0,0,.85);border-color:var(--tl)}
.botm-img-area:hover .botm-zoom-btn{display:block}
/* BOTM nav overlay buttons (inside image area) */
.botm-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.65);border:1px solid rgba(255,255,255,.2);border-radius:50%;color:#ccc;width:22px;height:22px;font-size:11px;line-height:20px;text-align:center;cursor:pointer;z-index:3;opacity:0;transition:opacity .2s}
.botm-img-area:hover .botm-nav-btn{opacity:1}
.botm-nav-prev{left:4px}
.botm-nav-next{right:4px}
.botm-nav-btn:hover{border-color:var(--tl);color:var(--tl);background:rgba(0,0,0,.85)}
/* BOTM month label (below image) */
.botm-month-label{text-align:center;padding:3px 10px 6px;font-size:8px;color:var(--t3);font-family:'JetBrains Mono',monospace;letter-spacing:1px;text-transform:uppercase}
/* BOTM zoom overlay */
.botm-zoom-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:10000;display:flex;align-items:center;justify-content:center;cursor:zoom-out;backdrop-filter:blur(4px);animation:fadeIn .15s ease-out}
.botm-zoom-overlay img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.6);pointer-events:none;-webkit-user-drag:none;user-drag:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}
/* Copy/download protection for BOTM */
.botm-img-area{-webkit-touch-callout:none}
.botm-img-area::after{content:'';position:absolute;inset:0;z-index:1;background:transparent;pointer-events:none}
body.locked .botm-img-area img{filter:blur(10px);-webkit-filter:blur(10px);pointer-events:none}
body.locked .botm-img-area{pointer-events:none}
body.locked .botm-img-del{display:none!important}
body.role-guest .botm-img-del{display:none!important}
.dash-board-col{flex:1;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;padding:10px 12px;min-height:auto;display:flex;flex-direction:column;transition:min-height .2s,padding .2s}
.dash-board-col.collapsed{min-height:0;padding-bottom:6px}
.dash-board-col.collapsed #boardNewsWrap,.dash-board-col.collapsed #boardTasksWrap,.dash-board-col.collapsed #boardNotesWrap{display:none}
.dash-board-col-news{border-color:rgba(0,188,212,.15)}
.dash-board-header{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--tl);margin-bottom:6px;padding:6px 10px;background:rgba(0,0,0,.2);border-radius:4px;border-bottom:1px solid rgba(255,255,255,.04);position:relative;text-align:center}
.dash-board-header::after{content:'';position:absolute;bottom:-1px;left:20%;right:20%;height:1px;background:linear-gradient(90deg,transparent,rgba(0,188,212,.2),transparent)}
.dash-board-list{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:4px;min-height:0;overflow-y:auto;align-content:start}
.dash-board-item{display:flex;align-items:center;gap:5px;font-size:9px;color:var(--t2);padding:4px 7px;border-radius:4px;background:var(--bg3);transition:background .15s;font-family:Verdana,Geneva,sans-serif}
.dash-board-item:hover{background:rgba(0,153,168,.1);border-color:rgba(0,153,168,.2)}
.dash-board-item .bi-check{cursor:pointer;opacity:.5;font-size:10px;flex-shrink:0}
.dash-board-item .bi-check:hover{opacity:1}
.dash-board-item .bi-text{flex:1;word-break:break-word}
.dash-board-item .bi-del{cursor:pointer;opacity:0;font-size:10px;color:var(--t3);transition:opacity .15s}
.dash-board-item:hover .bi-del{opacity:.6}
.dash-board-item.done .bi-text{text-decoration:line-through;opacity:.45}
.dash-board-input{background:transparent;border:1px dashed var(--bdr);border-radius:4px;padding:4px 8px;font-size:9px;color:var(--t2);margin-top:6px;font-family:Verdana,Geneva,sans-serif;outline:none;transition:border-color .15s}
.dash-board-input:focus{border-color:var(--tl)}
.dash-board-notes:focus{border-color:var(--tl)!important}
.task-due{font-size:8px;font-weight:600;font-family:'JetBrains Mono',monospace;padding:2px 6px;border:1px solid;border-radius:3px;flex-shrink:0;letter-spacing:.3px}
.task-due-edit{cursor:pointer;transition:.15s}
.task-due-edit:hover{filter:brightness(1.3);transform:scale(1.05)}
.task-due-add{color:var(--t3);border-color:var(--t3);border-style:dashed;font-weight:400;font-style:italic;opacity:.7}
.task-due-add:hover{opacity:1;color:var(--grn);border-color:var(--grn)}
.task-inserted{font-size:7px;color:var(--t3);font-family:'JetBrains Mono',monospace;margin-left:auto;flex-shrink:0;opacity:.5;letter-spacing:.2px}
/* ── Inline Task Add Row ── φ spacing ── */
.task-add-row{display:flex;align-items:center;gap:5px;margin-bottom:var(--sp1);position:relative}
.task-add-row .dash-board-input{margin-top:0}
.task-add-btn{width:21px;height:21px;border-radius:3px;border:1px solid var(--teal);background:var(--td);color:var(--tl);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.15s;flex-shrink:0;padding:0;line-height:1}
.task-add-btn:hover{background:rgba(0,153,168,.25);color:var(--wh)}
/* ── Task Calendar Popup — Sacred Geometry ── */
/* φ=1.618  Fib: 3 5 8 13 21 34  Cell: 21×21  Grid: 7×21+6×3=165  Pad: 8  Total: 181 ≈ φ×112 */
.task-cal{position:absolute;top:100%;right:0;z-index:200;background:var(--bg2);border:1px solid rgba(0,188,212,.2);border-radius:8px;padding:8px;box-shadow:0 5px 21px rgba(0,0,0,.55);margin-top:5px;width:181px;backdrop-filter:blur(5px);animation:tcFadeIn .15s ease}
@keyframes tcFadeIn{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}
.tc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.tc-month{font-size:9px;font-weight:700;color:var(--wh);letter-spacing:.5px;font-family:Verdana,Geneva,sans-serif}
.tc-nav{background:none;border:1px solid var(--bdr);color:var(--t3);cursor:pointer;font-size:8px;width:18px;height:18px;border-radius:3px;display:flex;align-items:center;justify-content:center;transition:.15s;padding:0}
.tc-nav:hover{color:var(--tl);border-color:var(--tl);background:var(--td)}
.tc-grid{display:grid;grid-template-columns:repeat(7,21px);gap:3px;justify-content:center}
.tc-dow{font-size:7px;font-weight:700;color:var(--t3);text-align:center;text-transform:uppercase;letter-spacing:.3px;line-height:13px}
.tc-day{width:21px;height:21px;font-size:9px;color:var(--t2);border-radius:3px;cursor:pointer;transition:.12s;font-family:'JetBrains Mono',monospace;display:flex;align-items:center;justify-content:center;border:1px solid transparent}
.tc-day:hover{background:var(--tl);color:#fff;border-color:var(--tl)}
.tc-day.tc-today{color:#F2C94C;font-weight:700;background:rgba(242,201,76,.08);border-color:rgba(242,201,76,.25)}
.tc-day.tc-future{color:var(--grn)}
.tc-day.tc-past{color:var(--t3);opacity:.55}
.tc-day.tc-empty{pointer-events:none;cursor:default}
.tc-skip{display:block;width:100%;margin-top:5px;padding:4px;background:transparent;border:1px dashed var(--bdr);border-radius:3px;color:var(--t3);font-size:8px;cursor:pointer;font-family:Verdana,Geneva,sans-serif;transition:.15s;text-align:center;letter-spacing:.3px}
.tc-skip:hover{border-color:var(--tl);color:var(--tl)}
.donut-wrap{display:flex;align-items:center;gap:14px}
.donut-legend{display:flex;flex-direction:column;gap:3px}
.donut-leg-item{display:flex;align-items:center;gap:6px;font-size:10px;color:var(--t2)}
.donut-leg-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.donut-leg-count{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--wh);min-width:14px}
/* ── Calendar ── */
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.cal-nav{background:none;border:none;color:var(--t3);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:4px;transition:.15s}
.cal-nav:hover{color:var(--wh);background:var(--bg3)}
.cal-month{font-family:Verdana,Geneva,sans-serif;font-size:12px;font-weight:600;color:var(--wh)}
.cal-today-btn{background:rgba(242,201,76,.1);border:1px solid rgba(242,201,76,.3);color:#F2C94C;cursor:pointer;font-size:7px;font-weight:700;letter-spacing:1px;padding:1px 5px;border-radius:3px;transition:.15s;vertical-align:middle;font-family:'JetBrains Mono',monospace;text-transform:uppercase}
.cal-today-btn:hover{background:rgba(242,201,76,.2);border-color:#F2C94C;color:#fff}
.cal-grid{display:grid;grid-template-columns:20px repeat(7,1fr);gap:1px;text-align:center}
.cal-kw-hdr{font-size:6px;font-weight:700;text-transform:uppercase;color:var(--t3);padding:2px 0 4px;letter-spacing:.3px;opacity:.6}
.cal-kw{font-size:7px;font-weight:600;color:var(--t3);display:flex;align-items:center;justify-content:center;opacity:.5;font-family:'JetBrains Mono',monospace;border-radius:3px 0 0 3px}
.cal-kw.cal-current-week{color:var(--grn);opacity:1}
.cal-dow{font-size:7px;font-weight:700;text-transform:uppercase;color:var(--t3);padding:2px 0 4px;letter-spacing:.5px}
.cal-day{font-size:10px;padding:3px 2px;border-radius:4px;position:relative;color:var(--t2);cursor:default;min-height:22px;display:flex;align-items:center;justify-content:center}
.cal-day.in-current-week{color:var(--wh)}
.cal-day.has-job::after{content:'';position:absolute;bottom:1px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--tl)}
/* .cal-day.has-holiday removed — holidays disabled */
.cal-day.has-files::before{content:'';position:absolute;top:1px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--pur)}
/* Single task dot — centered, color-coded by urgency */
.cal-day.has-task .cal-task-dot{position:absolute;bottom:1px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--amb)}
.cal-day.task-future .cal-task-dot{background:#27ae60}
.cal-day.task-today .cal-task-dot{background:#F2C94C}
.cal-day.task-overdue .cal-task-dot{background:#e74c3c}
/* Google Calendar event dot — blue, top-right */
.cal-day.has-gcal .cal-gcal-dot{position:absolute;top:1px;right:2px;width:4px;height:4px;border-radius:50%;background:#4285F4}
/* Hide job dot when task dot is present — single dot per day */
.cal-day.has-job.has-task::after{display:none}
.cal-day.cal-today{background:rgba(242,201,76,.08);color:#F2C94C;font-weight:700;border-radius:3px;border:1px solid rgba(242,201,76,.25)}
/* .cal-day.cal-today.has-holiday removed — holidays disabled */
.cal-day.other-month{opacity:.25}
/* ── Calendar Sync Panel ── */
.dash-card-cal{position:relative}
.cal-sync-btn{padding:4px;font-size:0;border:1px solid rgba(39,174,96,.3);border-radius:6px;cursor:pointer;transition:.15s;user-select:none;display:inline-flex;align-items:center;justify-content:center;background:rgba(39,174,96,.12);color:#6EE7B7;position:absolute;right:10px;top:50%;transform:translateY(-50%);line-height:0}
.cal-sync-btn:hover{background:rgba(39,174,96,.2)}
.cal-sync-btn svg{display:inline-block;vertical-align:middle;flex-shrink:0;width:11px;height:11px;stroke:currentColor;fill:none;overflow:visible}
.cal-sync-panel{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg2);border:1px solid var(--bdr);border-radius:0 0 10px 10px;padding:10px 12px;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.cal-sync-info{font-size:10px;color:var(--t2);margin-bottom:8px;line-height:1.4}
.cal-sync-url-row{display:flex;gap:4px;margin-bottom:8px}
.cal-sync-url{flex:1;background:rgba(0,0,0,.3);border:1px solid var(--bdr);border-radius:4px;color:var(--t1);font-size:9px;font-family:'JetBrains Mono',monospace;padding:5px 8px;outline:none;min-width:0}
.cal-sync-url:focus{border-color:var(--tl)}
.cal-sync-copy{background:rgba(0,188,212,.15);border:1px solid rgba(0,188,212,.3);border-radius:4px;color:var(--tl);cursor:pointer;padding:4px 8px;display:flex;align-items:center;transition:background .2s}
.cal-sync-copy:hover{background:rgba(0,188,212,.25)}
.cal-sync-buttons{display:flex;gap:6px;flex-wrap:wrap}
.cal-sync-add{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.05);border:1px solid var(--bdr);border-radius:4px;color:var(--t2);font-size:10px;font-weight:500;padding:5px 10px;cursor:pointer;transition:background .2s,border-color .2s}
.cal-sync-add:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.15);color:var(--t1)}
.cal-sync-add svg{flex-shrink:0}
/* ── Upcoming 3-Month Miniature ── */
.cal-upcoming-row{display:flex;gap:10px;margin-top:10px;padding:0 2px}
.cal-mini-month{flex:1;min-width:0}
.cal-mini-title{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--t3);text-align:center;margin-bottom:3px}
.cal-mini-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px}
.cal-mini-hdr{font-size:6px;font-weight:700;color:var(--t3);text-align:center;opacity:.5;padding:2px 0}
.cal-mini-cell{font-size:8px;color:var(--t3);text-align:center;padding:2px 0;line-height:1.5;font-family:'JetBrains Mono',monospace}
.cal-mini-cell.cal-mini-today{color:#F2C94C;font-weight:700;background:rgba(242,201,76,.12);border-radius:50%}
.cal-mini-cell.cal-mini-hol{color:rgba(231,76,60,.6);font-weight:600}
.cal-hol-list{margin-top:4px;padding-top:3px;border-top:1px solid rgba(255,255,255,.05)}
.cal-hol-item{display:flex;align-items:center;gap:5px;font-size:7px;padding:1px 0;color:var(--t3)}
.cal-hol-day{font-family:'JetBrains Mono',monospace;font-size:7px;font-weight:700;color:rgba(231,76,60,.6);min-width:30px;flex-shrink:0}
.cal-hol-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* ── Mini Map (Leaflet/OSM) ── */
.dash-map{position:relative;width:100%;min-height:200px;margin:0 auto;background:#1a1d23;border-radius:6px;z-index:0;isolation:isolate}
.dash-map .leaflet-container{background:#1a1d23!important;border-radius:6px}
.dash-map .leaflet-tile-pane{background:#1a1d23!important}
.dash-map .leaflet-tile{background:#1a1d23!important;image-rendering:auto}
.dash-map .leaflet-fade-anim .leaflet-tile,.dash-map .leaflet-zoom-anim .leaflet-zoom-animated{background:#1a1d23!important}
.dash-map .leaflet-map-pane,.dash-map .leaflet-proxy,.dash-map .leaflet-overlay-pane,.dash-map .leaflet-marker-pane,.dash-map .leaflet-tooltip-pane,.dash-map .leaflet-popup-pane,.dash-map .leaflet-shadow-pane{background:transparent!important}
.dash-map .leaflet-pane{background:#1a1d23!important}
.dash-map .leaflet-map-pane{background:transparent!important}
.dash-map .leaflet-zoom-anim .leaflet-zoom-animated{will-change:transform;backface-visibility:hidden}
.dash-map .leaflet-tile-container{background:#1a1d23!important}
/* ── Crisis Intel List ── */
.crisis-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-bottom:1px solid rgba(255,255,255,.04);font-size:9px;font-family:'JetBrains Mono',monospace}
.crisis-row:last-child{border-bottom:none}
.crisis-row:hover{background:rgba(255,255,255,.03)}
.crisis-sev{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.crisis-name{font-weight:700;color:var(--tx);min-width:90px}
.crisis-type{font-size:8px;padding:1px 6px;border-radius:3px;font-weight:600;letter-spacing:.3px;text-transform:uppercase}
.crisis-detail{color:var(--t3);font-size:8px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.crisis-header{font-size:8px;letter-spacing:.8px;text-transform:uppercase;color:var(--t3);padding:4px 8px;border-bottom:1px solid rgba(255,255,255,.06)}
/* ── Ops Intel Panel ── */
.ops-intel-body{max-height:200px;overflow-y:auto}
.ops-header{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;border-bottom:1px solid rgba(255,255,255,.06);gap:6px}
.ops-header-title{font-size:8px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--tl);white-space:nowrap}
.ops-header-counts{display:flex;gap:4px;flex-wrap:wrap}
.ops-count-badge{font-family:'JetBrains Mono',monospace;font-size:7px;font-weight:700;padding:1px 5px;border-radius:3px;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}
.ops-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-bottom:1px solid rgba(255,255,255,.03);font-family:'JetBrains Mono',monospace;transition:background .15s;border-radius:2px;margin:1px 0}
.ops-row:hover{filter:brightness(1.2)}
.ops-icon{font-size:11px;flex-shrink:0;width:18px;text-align:center}
.ops-content{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}
.ops-msg{font-size:9px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ops-detail{font-size:8px;color:var(--t3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ops-sev-badge{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;padding:1px 5px;border-radius:3px;border:1px solid;flex-shrink:0;white-space:nowrap}
.ops-empty{padding:20px 8px;text-align:center;font-size:10px;color:var(--t3)}
.ops-footer{font-size:7px;color:var(--t3);padding:4px 8px;border-top:1px solid rgba(255,255,255,.04);text-align:right;letter-spacing:.3px}
.osm-office-pin,.osm-market-pin{background:none!important;border:none!important}
.osm-tooltip{background:var(--bg2)!important;color:var(--tx)!important;border:1px solid var(--bdr)!important;border-radius:4px!important;font-size:9px!important;font-family:'JetBrains Mono',monospace!important;padding:3px 6px!important;box-shadow:0 2px 8px rgba(0,0,0,.4)!important}
.osm-tooltip::before{border-top-color:var(--bg2)!important}
.ship-map-pin{background:none!important;border:none!important}
.ship-map-pulse{background:none!important;border:none!important}
@keyframes shipPulse{0%{transform:scale(1);opacity:1}50%{transform:scale(2.2);opacity:.3}100%{transform:scale(1);opacity:1}}
.ship-pulse-dot{width:10px;height:10px;border-radius:50%;margin:2px;animation:shipPulse 1.8s ease-in-out infinite}
.dash-map .leaflet-top.leaflet-left{top:50%!important;transform:translateY(-50%)}
.dash-map .leaflet-control-zoom a{background:var(--bg2)!important;color:var(--t2)!important;border-color:var(--bdr)!important;width:22px!important;height:22px!important;line-height:22px!important;font-size:11px!important}
.dash-map .leaflet-control-zoom a:hover{background:var(--bg3)!important;color:var(--tx)!important}
.map-tooltip{position:absolute;background:var(--bg4);border:1px solid var(--bdr);border-radius:6px;padding:6px 10px;font-size:10px;color:var(--tx);pointer-events:none;white-space:nowrap;z-index:10;display:none;box-shadow:0 4px 12px rgba(0,0,0,.4)}

/* ── Top Nav Icons — uniform size, centered, flashy glow ── */
.top-nav-icons{display:inline-flex;align-items:center;gap:6px;align-self:center}
.nav-icon{width:32px;height:32px;border-radius:6px;border:1px solid var(--bdr);background:var(--bg3);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.25s;padding:0;flex-shrink:0;position:relative}
.nav-icon svg{width:16px;height:16px;stroke:currentColor;fill:none;overflow:visible;display:block}
.nc-teal{color:#00BCD4;border-color:rgba(0,188,212,.4);background:rgba(0,188,212,.12);box-shadow:0 0 6px rgba(0,188,212,.15)}
.nc-teal:hover,.nc-teal.active{color:#4de8fc;border-color:rgba(0,188,212,.7);background:rgba(0,188,212,.22);box-shadow:0 0 16px rgba(0,188,212,.45),0 0 4px rgba(0,188,212,.2) inset}
.nc-pur{color:#A78BFA;border-color:rgba(124,58,237,.4);background:rgba(124,58,237,.12);box-shadow:0 0 6px rgba(124,58,237,.15)}
.nc-pur:hover,.nc-pur.active{color:#d4c0ff;border-color:rgba(124,58,237,.7);background:rgba(124,58,237,.22);box-shadow:0 0 16px rgba(124,58,237,.45),0 0 4px rgba(124,58,237,.2) inset}
.nc-amb{color:#F2994A;border-color:rgba(242,153,74,.4);background:rgba(242,153,74,.12);box-shadow:0 0 6px rgba(242,153,74,.15)}
.nc-amb:hover,.nc-amb.active{color:#ffba75;border-color:rgba(242,153,74,.7);background:rgba(242,153,74,.22);box-shadow:0 0 16px rgba(242,153,74,.45),0 0 4px rgba(242,153,74,.2) inset}
.nc-grn{color:#34D399;border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.12);box-shadow:0 0 6px rgba(52,211,153,.15)}
.nc-grn:hover,.nc-grn.active{color:#6ee7b7;border-color:rgba(52,211,153,.7);background:rgba(52,211,153,.22);box-shadow:0 0 16px rgba(52,211,153,.45),0 0 4px rgba(52,211,153,.2) inset}
.nc-ind{color:#818CF8;border-color:rgba(99,102,241,.4);background:rgba(99,102,241,.12);box-shadow:0 0 6px rgba(99,102,241,.15)}
.nc-ind:hover,.nc-ind.active{color:#a5b4fc;border-color:rgba(99,102,241,.7);background:rgba(99,102,241,.22);box-shadow:0 0 16px rgba(99,102,241,.45),0 0 4px rgba(99,102,241,.2) inset}
.top-sep{width:1px;height:21px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.08),transparent);margin:0 6px;flex-shrink:0}
.btn{padding:7px 16px;font-size:12px;font-weight:600;font-family:Verdana,Geneva,sans-serif;border:1px solid var(--bdr);border-radius:6px;cursor:pointer;transition:.15s;user-select:none;display:inline-flex;align-items:center;gap:5px}
.btn-add{background:var(--td);color:var(--tl);border-color:var(--teal)}
.btn-add:hover{background:rgba(0,153,168,.25)}
.btn-add:disabled{opacity:.3;cursor:default}
.btn-del{background:var(--rd);color:var(--red);border-color:rgba(231,76,60,.3)}
.btn-del:hover{background:rgba(231,76,60,.2)}
.btn-del:disabled{opacity:.3;cursor:default}
.btn-save{background:rgba(124,58,237,.12);color:#A78BFA;border-color:rgba(124,58,237,.3)}
.btn-save:hover{background:rgba(124,58,237,.22)}
.btn svg{display:inline-block;vertical-align:middle;flex-shrink:0;width:13px;height:13px;stroke:currentColor;fill:none;overflow:visible}
.btn-lock{background:rgba(239,68,68,.12);color:#F87171;border-color:rgba(239,68,68,.3);min-width:85px;justify-content:center;text-align:center;font-size:10px;padding:5px 10px;margin-top:3px}
.btn-lock:hover{background:rgba(239,68,68,.2)}
.btn-lock.unlocked{background:rgba(39,174,96,.12);color:#6EE7B7;border-color:rgba(39,174,96,.3)}
.btn-lock.unlocked:hover{background:rgba(39,174,96,.2)}
.btn-lock.unlocked.sync-off{background:rgba(239,68,68,.10);color:#F87171;border-color:rgba(239,68,68,.25)}
.btn-lock.unlocked.sync-off:hover{background:rgba(239,68,68,.18)}
.btn-lock.unlocked.sync-ing{background:rgba(242,153,74,.10);color:#F2994A;border-color:rgba(242,153,74,.25)}
.btn-lock.unlocked.sync-ing:hover{background:rgba(242,153,74,.18)}

/* ── Search-area action buttons — match magnifying glass size, glow style ── */
.search-actions{gap:8px !important}
.sa-btn{padding:6px 10px;border-radius:6px;border:1px solid var(--bdr);background:var(--bg3);color:var(--t2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0;font-size:13px;line-height:1}
.sa-btn:disabled{opacity:.35;cursor:default;pointer-events:none}
.sa-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;overflow:visible;display:block}
.sa-del{color:#E74C3C;border-color:rgba(231,76,60,.45);background:rgba(231,76,60,.15);box-shadow:0 0 6px rgba(231,76,60,.18)}
.sa-del:hover,.sa-del.active{color:#ff8a7a;border-color:rgba(231,76,60,.7);background:rgba(231,76,60,.25);box-shadow:0 0 14px rgba(231,76,60,.45),0 0 4px rgba(231,76,60,.2) inset}
.sa-archive{color:#9CA3AF;border-color:rgba(156,163,175,.45);background:rgba(156,163,175,.15);box-shadow:0 0 6px rgba(156,163,175,.12)}
.sa-archive:hover,.sa-archive.active{color:#e5e7eb;border-color:rgba(156,163,175,.7);background:rgba(156,163,175,.25);box-shadow:0 0 14px rgba(156,163,175,.35),0 0 4px rgba(156,163,175,.15) inset}
.sa-add{color:#00BCD4;border-color:rgba(0,188,212,.45);background:rgba(0,188,212,.15);box-shadow:0 0 6px rgba(0,188,212,.18)}
.sa-add:hover,.sa-add.active{color:#4de8fc;border-color:rgba(0,188,212,.7);background:rgba(0,188,212,.25);box-shadow:0 0 14px rgba(0,188,212,.45),0 0 4px rgba(0,188,212,.2) inset}
.sa-save{color:#A78BFA;border-color:rgba(124,58,237,.45);background:rgba(124,58,237,.15);box-shadow:0 0 6px rgba(124,58,237,.18)}
.sa-save:hover,.sa-save.active{color:#d4c0ff;border-color:rgba(124,58,237,.7);background:rgba(124,58,237,.25);box-shadow:0 0 14px rgba(124,58,237,.45),0 0 4px rgba(124,58,237,.15) inset}

.main{max-width:100%;padding:24px 28px;overflow-x:auto}

.tbl-wrap{border-radius:10px;border:1px solid var(--bdr);overflow-x:auto;background:var(--bg2)}
table{width:100%;border-collapse:collapse;min-width:1400px}
thead th{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--teal);padding:12px 10px;text-align:center;border-bottom:2px solid var(--bt);background:rgba(0,153,168,.04);white-space:nowrap;position:sticky;top:0;z-index:2}
thead th:nth-child(2){text-align:left}
thead th .th-icon{display:block;font-size:14px;margin-bottom:2px}
thead th.phase{min-width:100px}

tbody td{padding:0;border-bottom:1px solid var(--bdr);vertical-align:middle;text-align:center;position:relative}
tbody tr.job-row{transition:.1s}
tbody tr.job-row:hover{background:rgba(0,153,168,.03)}
tbody tr.job-row.selected{background:rgba(0,153,168,.06)}
tbody tr.job-row.open{background:rgba(0,153,168,.04);border-bottom:none}

.cell-input{width:100%;padding:10px;font-size:11px;font-family:Verdana,Geneva,sans-serif;color:var(--tx);background:transparent;border:none;outline:none;text-align:center}
.cell-input:focus{background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35);border-radius:3px;color:#fff}
.cell-input[readonly]{pointer-events:none;user-select:none;cursor:default}
.cell-input::placeholder{color:var(--t3);font-style:italic}
.cell-skc{text-align:left!important;font-family:'JetBrains Mono',monospace!important;font-weight:600!important;color:var(--tl)!important;font-size:11px!important}
.cell-proj{text-align:left!important;font-weight:500!important;font-size:11px!important}

/* Info button (main table + detail sections) */
.info-btn{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--t3);background:transparent;color:var(--t3);font-size:11px;font-weight:700;font-family:Verdana,Geneva,sans-serif;font-style:italic;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s;line-height:1}
.info-btn:hover{border-color:var(--tl);color:#fff;background:var(--teal)}
#jobSearch:focus{border-color:var(--tl);box-shadow:0 0 0 2px var(--td)}
.time-tracker{display:flex;align-items:center;gap:4px;padding:6px 8px;background:var(--bg2);border:1px solid var(--bdr);border-radius:6px;flex-wrap:wrap;max-width:320px}
.time-tracker+.time-tracker{margin-top:4px}
.tt-select{max-width:120px;font-size:9px;background:var(--bg3);border:1px solid var(--bdr);color:var(--t2);border-radius:4px;padding:1px 4px;text-overflow:ellipsis;overflow:hidden}
.tt-select-pick{border-color:var(--teal);color:var(--tl);font-weight:600;padding:2px 6px}
.tt-btn{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--bdr);background:transparent;color:var(--t2);font-size:10px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.15s}
.tt-btn:hover{border-color:var(--tl);color:var(--tl)}
.tt-btn.running{border-color:var(--grn);color:var(--grn);animation:tPulse 1.5s ease-in-out infinite}
@keyframes tPulse{0%,100%{box-shadow:0 0 2px rgba(39,174,96,.2)}50%{box-shadow:0 0 6px rgba(39,174,96,.5)}}
.tt-display{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;color:var(--t2);min-width:50px}
.tt-entries{margin-top:4px;font-size:9px;color:var(--t3)}
.tt-entry{display:flex;gap:6px;padding:2px 0;border-bottom:1px solid rgba(255,255,255,.03)}
.tt-user{font-weight:600;color:var(--tl);min-width:20px}
.tt-task{flex:1;color:var(--t2)}
.tt-dur{font-family:'JetBrains Mono',monospace;color:var(--amb)}
.tt-del{width:14px;height:14px;border-radius:3px;border:1px solid rgba(231,76,60,.25);background:transparent;color:var(--red);font-size:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;opacity:.4;transition:.15s;flex-shrink:0;margin-left:auto}
.tt-del:hover{opacity:1;background:rgba(231,76,60,.1);border-color:var(--red)}
.tt-manual-btn{font-size:8px;color:var(--tl);background:transparent;border:1px dashed rgba(0,153,168,.3);border-radius:4px;padding:2px 8px;cursor:pointer;transition:.15s;letter-spacing:.3px}
.tt-manual-btn:hover{border-color:var(--tl);background:rgba(0,153,168,.06)}
.tt-manual-form{display:flex;align-items:center;gap:4px;margin-top:6px;padding:6px 8px;background:rgba(0,153,168,.04);border:1px solid rgba(0,153,168,.2);border-radius:6px}
.tt-manual-input{width:36px;padding:2px 4px;font-size:10px;font-family:'JetBrains Mono',monospace;background:var(--bg3);border:1px solid var(--bdr);border-radius:4px;color:var(--tx);text-align:center}
.audit-log{font-size:10px}
.al-entry{display:flex;gap:8px;padding:6px 8px;border-bottom:1px solid rgba(255,255,255,.04);color:var(--t3)}
.al-entry:hover{background:rgba(255,255,255,.03)}
.al-ts{font-family:'JetBrains Mono',monospace;min-width:120px;flex-shrink:0;font-size:10px}
.al-user{font-weight:600;color:var(--tl);min-width:28px;flex-shrink:0}
.al-field{color:var(--amb);min-width:80px;flex-shrink:0}
.al-val{color:var(--t2);word-break:break-word;flex:1}
.so-panel-narrow{width:720px;max-width:88vw}
.so-icon.audit{background:linear-gradient(135deg,#6366F1,#818CF8);color:#fff}
.so-tag.audit{background:rgba(99,102,241,.15);color:#818CF8;border:1px solid rgba(99,102,241,.25);border-radius:4px;font-size:9px;padding:2px 6px;letter-spacing:.5px}
.audit-open-btn{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;font-size:9px;background:rgba(99,102,241,.12);color:#818CF8;border:1px solid rgba(99,102,241,.25);border-radius:4px;cursor:pointer;transition:.15s;font-weight:600;letter-spacing:.3px}
.audit-open-btn:hover{background:rgba(99,102,241,.22);border-color:rgba(99,102,241,.4)}
.audit-open-btn .al-count{font-weight:400;opacity:.7}
.tt-row-icon{font-size:9px;cursor:help;opacity:.6;margin-left:4px}
.tt-notime{color:var(--amb);font-size:7px;margin-left:2px;cursor:help}
.tt-row-icon.has{opacity:1;color:var(--grn)}
tr.job-row:not(.open) .info-cell .info-btn{border-color:var(--tl);color:var(--tl);background:var(--td)}
tr.job-row.open .info-cell .info-btn{border-color:var(--t3);color:var(--t3);background:transparent}
.info-cell{width:52px;text-align:center!important;white-space:nowrap}
.copy-job-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:1px solid rgba(255,255,255,.08);background:transparent;color:var(--t3);cursor:pointer;padding:0;margin-left:2px;transition:.15s;vertical-align:middle}
.copy-job-btn:hover{color:var(--tl);border-color:var(--tl);background:rgba(0,153,168,.08)}
.prio-cell{width:28px;text-align:center!important}
.prio-btn{width:20px;height:20px;border-radius:4px;border:1.5px solid var(--bdr);background:transparent;font-size:9px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.15s;line-height:1;padding:0}
.prio-btn:hover{border-color:var(--amb)}
.prio-btn.p1{background:rgba(239,68,68,.2);border-color:#EF4444;color:#EF4444}
.prio-btn.p2{background:rgba(249,115,22,.15);border-color:#F97316;color:#F97316}
.prio-btn.p3{background:rgba(234,179,8,.12);border-color:#EAB308;color:#EAB308}
.prio-btn.p4{background:rgba(45,212,191,.1);border-color:var(--tl);color:var(--tl)}
.prio-btn.p0{color:var(--t3);border-color:var(--bdr)}
@keyframes officeGlow{0%,100%{box-shadow:0 0 3px rgba(45,212,191,.3)}50%{box-shadow:0 0 8px rgba(45,212,191,.6)}}
.clock-card.office-hours{animation:officeGlow 2s ease-in-out infinite;transform:translateY(-2px);border-color:rgba(0,188,212,.25)}
.clock-card.office-hours:hover{transform:translateY(-4px);box-shadow:0 4px 20px rgba(0,188,212,.35)}
.clock-office-badge{font-size:7px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#00e5a0;background:rgba(0,229,160,.1);border:1px solid rgba(0,229,160,.25);border-radius:3px;padding:1px 6px;margin-top:1px;display:none}
.clock-card.office-hours .clock-office-badge{display:block}
.clock-closed-badge{color:rgba(231,76,60,.45);background:rgba(231,76,60,.06);border-color:rgba(231,76,60,.15)}
.clock-card.office-closed .clock-closed-badge{display:block}
.cal-eotm-strip{display:flex;gap:2px;justify-content:center;margin-top:4px;padding-top:4px;border-top:1px solid var(--bdr)}
.cal-eotm-thumb{width:16px;height:16px;border-radius:3px;object-fit:cover;cursor:pointer;opacity:.7;transition:.15s;border:1px solid var(--bdr)}
.cal-eotm-thumb:hover{opacity:1;border-color:var(--amb)}
.cal-eotm-thumb.active{opacity:1;border-color:var(--amb);box-shadow:0 0 4px rgba(242,156,56,.4)}
.cal-eotm-empty{width:16px;height:16px;border-radius:3px;background:var(--bg3);border:1px dashed var(--bdr);opacity:.3}
.dash-board-toggle{display:inline-flex;align-items:center;gap:6px}
.dash-board-toggle .info-btn{width:16px;height:16px;font-size:8px}
/* When section is COLLAPSED — button highlighted (indicates hidden content) */
.dash-board-col.collapsed .dash-board-toggle .info-btn{border-color:var(--tl);color:var(--tl);background:var(--td)}
/* When section is OPEN — button dimmed */
.dash-board-col:not(.collapsed) .dash-board-toggle .info-btn{border-color:var(--t3);color:var(--t3);background:transparent}
/* Hover always fills regardless of state — needs higher specificity to override collapsed/open rules */
.dash-board-col .dash-board-toggle .info-btn:hover{border-color:var(--tl);color:#fff;background:var(--teal)}
.info-btn-teal{border-color:var(--tl);color:var(--tl)}
.notes-tabs{display:flex;gap:4px;margin-bottom:8px}
.notes-tab{padding:4px 10px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--bdr);border-radius:4px;background:transparent;color:var(--t3);cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif}
.notes-tab:hover{color:var(--tx);border-color:var(--t3)}
.notes-tab.active{color:var(--tl);border-color:var(--tl);background:var(--td)}
/* ── Chat Channel Bar ── */
.chat-channel-bar{display:flex;gap:3px;margin-bottom:6px}
.chat-ch-btn{padding:3px 8px;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--bdr);border-radius:4px;background:transparent;color:var(--t3);cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif}
.chat-ch-btn:hover{color:var(--tx);border-color:var(--t3)}
.chat-ch-btn.active{color:var(--tl);border-color:var(--tl);background:var(--td)}
.chat-messages{font-family:Verdana,Geneva,sans-serif;line-height:1.5;color:var(--tx)}
.chat-msg{padding:3px 0;border-bottom:1px solid var(--bdr)}
.chat-msg-user{font-weight:700;color:var(--tl);font-size:9px;margin-right:4px}
.chat-msg-time{font-size:8px;color:var(--t3);margin-left:4px}
/* ── Contacts List ── */
.contacts-list{display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px;max-height:200px;overflow-y:auto}
.contact-card{display:flex;align-items:center;gap:6px;padding:5px 6px;background:var(--bg3);border:1px solid var(--bdr);border-radius:5px;transition:.15s}
.contact-card:hover{border-color:rgba(0,153,168,.2);background:rgba(0,153,168,.1)}
.contact-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:10px;flex-shrink:0}
.contact-info{flex:1;min-width:0}
.contact-name{font-size:9px;font-weight:700;color:var(--tx);display:flex;align-items:center;gap:4px}
.contact-role{font-size:7px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.contact-loc{font-size:7px;color:var(--t3);font-family:'JetBrains Mono',monospace}
.contact-status{width:5px;height:5px;border-radius:50%;display:inline-block;flex-shrink:0}
.contact-status.online{background:var(--grn);box-shadow:0 0 3px rgba(39,174,96,.5)}
.contact-status.offline{background:var(--t3);opacity:.4}
.contact-chat-btn{padding:2px 7px;font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--teal);border-radius:3px;background:var(--td);color:var(--tl);cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif;flex-shrink:0}
.contact-chat-btn:hover{background:rgba(0,153,168,.25);color:var(--wh)}
.contact-you{font-size:7px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}
/* ── Users Management Tab ── */
.users-panel{max-height:260px;overflow-y:auto}
.user-card{background:var(--bg3);border:1px solid var(--bdr);border-radius:6px;padding:8px 10px;margin-bottom:6px;font-size:10px}
.user-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.user-card-name{font-weight:700;color:var(--tl);font-size:11px}
.user-card-role{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:1px 6px;border-radius:3px}
.user-card-role.admin{color:var(--amb);background:var(--ad)}
.user-card-role.guest{color:var(--pur);background:var(--pd)}
.user-card-row{display:flex;gap:6px;align-items:center;padding:2px 0}
.user-card-label{color:var(--t3);font-size:9px;min-width:55px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.user-card-val{color:var(--t2);font-family:'JetBrains Mono',monospace;font-size:10px;flex:1}
.user-card-input{background:transparent;border:1px dashed var(--bdr);border-radius:3px;padding:2px 6px;font-size:9px;color:var(--t2);font-family:'JetBrains Mono',monospace;outline:none;width:100%;transition:border-color .15s}
.user-card-input:focus{border-color:var(--tl)}
.user-add-btn{width:100%;padding:5px;background:var(--td);border:1px dashed var(--teal);border-radius:6px;color:var(--tl);font-size:9px;font-weight:600;cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif;text-align:center}
.user-add-btn:hover{background:rgba(0,153,168,.25)}
.user-pw-btn{padding:2px 8px;font-size:8px;font-weight:600;color:var(--pur);background:var(--pd);border:1px solid rgba(124,58,237,.25);border-radius:3px;cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif}
.user-pw-btn:hover{background:rgba(124,58,237,.2)}
.user-del-btn{padding:2px 6px;font-size:8px;color:var(--red);background:var(--rd);border:1px solid rgba(231,76,60,.2);border-radius:3px;cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif}
.user-del-btn:hover{background:rgba(231,76,60,.2)}
.info-btn-sm{width:18px;height:18px;font-size:9px}
.info-btn-sm:hover{border-color:var(--pur);color:var(--pur);background:var(--pd)}
.info-btn-sm.active{border-color:var(--pur);color:var(--pur);background:var(--pd)}

td.phase-cell{min-width:115px}
td.phase-cell .cell-input{font-family:'JetBrains Mono',monospace;font-size:11px}
td.phase-cell.done{background:var(--gd)}
td.phase-cell.done .cell-input{color:var(--grn)}
td.phase-cell.done .cell-input:focus{color:#fff;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
td.phase-cell.active{background:var(--ad)}
td.phase-cell.active .cell-input{color:var(--amb)}
td.phase-cell.active .cell-input:focus{color:#fff;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
/* 3-tier due flashing: yellow (>24h), orange (≤24h), red (past due) */
td.phase-cell.due-soon{animation:dueYellow 1.4s ease-in-out infinite}
td.phase-cell.due-soon .cell-input{color:#EAB308;font-weight:600}
td.phase-cell.due-soon .cell-input:focus{color:#fff;font-weight:400;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
@keyframes dueYellow{0%,100%{background:rgba(234,179,8,.10)}50%{background:rgba(234,179,8,.25)}}

td.phase-cell.due-now{animation:dueOrange 1.1s ease-in-out infinite}
td.phase-cell.due-now .cell-input{color:var(--amb);font-weight:600}
td.phase-cell.due-now .cell-input:focus{color:#fff;font-weight:400;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
@keyframes dueOrange{0%,100%{background:var(--ad)}50%{background:rgba(242,153,74,.30)}}

td.phase-cell.due-past{animation:dueRed .8s ease-in-out infinite}
td.phase-cell.due-past .cell-input{color:var(--red);font-weight:700}
td.phase-cell.due-past .cell-input:focus{color:#fff;font-weight:400;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
@keyframes dueRed{0%,100%{background:var(--rd)}50%{background:rgba(231,76,60,.30)}}

td.phase-cell.client-active{animation:dueGreen 1.6s ease-in-out infinite}
td.phase-cell.client-active .cell-input{color:var(--grn);font-weight:600}
td.phase-cell.client-active .cell-input:focus{color:#fff;font-weight:400;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
@keyframes dueGreen{0%,100%{background:var(--gd)}50%{background:rgba(39,174,96,.28)}}

/* ── PDF VERSION POPOVER ── */
.pdf-cell-wrap{position:relative;display:flex;align-items:center;gap:2px;padding:0 4px}
.pdf-cell-wrap .cell-input{flex:1;padding:10px 4px}
.pdf-ver-badge{font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;color:var(--pur);background:var(--pd);padding:1px 5px;border-radius:3px;white-space:nowrap;letter-spacing:.5px}
.pdf-ver-pop{position:absolute;top:calc(100% + 4px);right:0;width:320px;background:var(--bg2);border:1px solid var(--bdr);border-radius:8px;box-shadow:0 8px 24px rgba(0,0,0,.5);z-index:50;padding:12px;display:none}
.pdf-ver-pop.open{display:block}
.pdf-ver-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--pur);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.pdf-ver-close{background:none;border:none;color:var(--t3);font-size:14px;cursor:pointer;padding:0 2px;line-height:1}
.pdf-ver-close:hover{color:var(--tx)}
.pdf-ver-list{max-height:240px;overflow-y:auto}
.pdf-ver-item{display:flex;flex-direction:column;padding:6px 0;font-size:11px;border-bottom:1px solid rgba(255,255,255,.04)}
.pdf-ver-item:last-child{border:none}
.pdf-ver-main{display:flex;align-items:center;gap:6px}
.pdf-ver-sub{display:flex;align-items:center;gap:6px;padding:1px 0 1px 38px;font-size:10px}
.pdf-ver-sublabel{color:var(--t3);font-size:9px;font-weight:500;min-width:52px;text-align:right}
.pdf-ver-num{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:var(--pur);min-width:32px}
.pdf-ver-dinput{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--tx);background:transparent;border:none;outline:none;flex:1;padding:2px 0}
.pdf-ver-dinput:focus{background:rgba(124,58,237,.08);border-radius:3px}
.pdf-ver-dinput[readonly]{pointer-events:none;user-select:none;cursor:default}
.pdf-ver-dinput::placeholder{color:var(--t3);font-style:italic}
.pdf-ver-del{background:none;border:none;color:var(--t3);font-size:13px;cursor:pointer;padding:0 4px;opacity:.6;transition:.15s}
.pdf-ver-del:hover{color:var(--red);opacity:1}
.pdf-ver-empty{font-size:10px;color:var(--t3);font-style:italic;padding:6px 0;text-align:center}
.pdf-ver-add{margin-top:8px;padding:5px 10px;font-size:9px;font-weight:600;font-family:Verdana,Geneva,sans-serif;color:var(--pur);background:var(--pd);border:1px solid rgba(124,58,237,.25);border-radius:4px;cursor:pointer;transition:.15s;width:100%;text-align:center}
.pdf-ver-add:hover{background:rgba(124,58,237,.2);border-color:rgba(124,58,237,.4)}
.pdf-ver-add:disabled{opacity:.3;cursor:default}

.pdf-ver-status{font-family:Verdana,Geneva,sans-serif;font-size:9px;color:var(--tx);background:var(--bg3);border:1px solid var(--bdr);border-radius:3px;padding:2px 6px;outline:none;cursor:pointer;flex:1}
.pdf-ver-status:focus{border-color:var(--teal)}
.pdf-ver-status:disabled{opacity:.3;cursor:default}
.pdf-ver-status option{background:var(--bg2);color:var(--tx)}


input[type="checkbox"]{color-scheme:dark}
.row-check{width:16px;height:16px;accent-color:var(--teal);cursor:pointer;margin:0 8px}
.row-check:disabled{opacity:.3;cursor:default}

.market-cell{display:flex;align-items:center;gap:6px;padding:4px 8px}
.market-input{width:50px;padding:4px 6px;font-size:11px;font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--tx);background:var(--bg3);border:1px solid var(--bdr);border-radius:4px;outline:none;text-align:center;text-transform:uppercase}
.market-input:focus{border-color:var(--teal)}
.market-input:disabled{opacity:.3;cursor:default}
.market-input::placeholder{color:var(--t3);font-style:italic;text-transform:none}
.market-flag{font-size:14px;line-height:1}

/* ── DETAIL ROW ── */
tr.detail-row{display:none}
tr.detail-row.open{display:table-row}
tr.detail-row td{padding:0;background:var(--bg4);border-bottom:1px solid var(--bdr)}

.detail-panel{padding:16px 20px}
.det-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.det-section{background:var(--bg3);border-radius:8px;padding:12px 14px;position:relative;min-width:0;overflow:hidden}
.det-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--tl);margin-bottom:8px}
.det-title-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.det-title-row .det-title{margin-bottom:0}
.det-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03)}
.det-row:last-child{border:none}
.det-k{color:var(--t3);font-weight:500;white-space:nowrap;margin-right:12px}
.det-input{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--tx);background:transparent;border:none;outline:none;text-align:right;width:100%;padding:2px 0}
select.det-input{max-width:280px;background:var(--bg3);border:1px solid var(--bdr);border-radius:3px;padding:2px 6px;cursor:pointer;text-overflow:ellipsis}
.det-section .det-input{min-width:180px}
.det-input:focus{background:rgba(0,153,168,.08);border-radius:3px}
.det-input[readonly]{pointer-events:none;user-select:none;cursor:default}
.det-input:disabled{opacity:.5;cursor:default}
.det-input::placeholder{color:var(--t3);font-style:italic}

/* ── PROOFING sub-panel inside Production Information ── */
.prod-tabs{display:flex;flex-wrap:wrap;gap:0;margin-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.prod-tab{padding:5px 14px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif}
.prod-tab:hover{color:var(--tl)}
.prod-tab.active{color:var(--pur);border-bottom-color:var(--pur)}
.prod-tab-content{display:none}
.prod-tab-content.active{display:block}
/* Print Units — CSS Grid layout */
.cyl-grid{display:grid;grid-template-columns:18px 1fr 60px 60px 94px 88px 88px;gap:0;font-size:9px;width:100%}
.cyl-hdr{padding:2px 3px;color:var(--t3);font-weight:600;font-size:8px;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cyl-cell{padding:1px 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-bottom:1px solid rgba(255,255,255,.03);display:flex;align-items:center;min-width:0}
.cyl-cell input,.cyl-cell select{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--tx);background:transparent;border:none;outline:none;width:100%;min-width:0;padding:1px 2px;box-sizing:border-box}
.cyl-cell select{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%236B7280'/%3E%3C/svg%3E") no-repeat right 2px center;padding-right:12px}
.cyl-cell input:focus,.cyl-cell select:focus{background:rgba(0,153,168,.08);border-radius:2px}
.cyl-num{color:var(--t3);font-size:9px}
.cyl-summary{display:flex;align-items:center;gap:10px;margin-top:6px;padding:5px 8px;background:rgba(255,255,255,.03);border-radius:4px;font-size:9px;color:var(--t2);flex-wrap:wrap}
.cyl-summary .cyl-chip{font-weight:700}

/* ── SHIPMENTS ── */
.ship-list{margin-top:8px}
.ship-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:5px;padding:6px 8px;margin-bottom:6px;max-width:520px}
.ship-header{display:flex;align-items:center;gap:6px;margin-bottom:4px}
.ship-label{flex:1;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:700;color:var(--tl);background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.08);outline:none;padding:2px 0}
.ship-label:focus{border-bottom-color:var(--pur)}
.ship-label[readonly]{pointer-events:none;user-select:none;cursor:default}
.ship-label::placeholder{color:var(--t3);font-weight:400}
.ship-remove{background:none;border:none;color:var(--red);font-size:14px;cursor:pointer;padding:0 4px;line-height:1;opacity:.6;transition:.15s}
.ship-remove:hover{opacity:1}
.ship-fields{display:flex;flex-wrap:wrap;gap:4px 10px}
.ship-field{display:flex;align-items:center;gap:4px;font-size:9px}
.ship-k{color:var(--t3);font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.ship-v{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--tx);background:transparent;border:none;border-bottom:1px solid rgba(255,255,255,.06);outline:none;padding:1px 2px;min-width:0}
.ship-v:focus{border-bottom-color:var(--pur)}
.ship-v[readonly]{pointer-events:none;user-select:none;cursor:default}
select.ship-v{cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%236B7280'/%3E%3C/svg%3E") no-repeat right 2px center;padding-right:12px}
.ship-add-btn{padding:3px 10px;font-size:8px;font-weight:700;font-family:Inter,sans-serif;text-transform:uppercase;letter-spacing:.6px;color:var(--pur);background:rgba(168,85,247,.06);border:1px dashed rgba(168,85,247,.25);border-radius:4px;cursor:pointer;transition:.15s}
.ship-add-btn:hover{background:rgba(168,85,247,.12)}

.dhl-icon{font-size:11px}
.dhl-result{margin-top:8px;padding:8px 10px;background:rgba(255,255,255,.03);border-radius:6px;font-size:9px;font-family:Verdana,Geneva,sans-serif;color:var(--t2)}
.dhl-status-bar{display:flex;align-items:center;gap:6px;margin-bottom:6px}
.dhl-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dhl-status-label{font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.5px}
.dhl-status-desc{color:var(--t3);font-size:9px}
.dhl-route{display:flex;align-items:center;gap:6px;font-size:9px;color:var(--t2);margin-bottom:4px}
.dhl-arrow{color:var(--t3);font-size:11px}
.dhl-eta{font-size:9px;color:var(--amb);font-weight:600;margin-bottom:6px}
.dhl-timeline{border-left:2px solid rgba(255,255,255,.08);margin-left:4px;padding-left:0}
.dhl-ev{display:flex;align-items:flex-start;gap:0;padding:3px 0;position:relative}
.dhl-ev-dot{width:6px;height:6px;border-radius:50%;background:var(--t3);margin:5px -4px 0 0;margin-left:-4px;margin-right:8px;flex-shrink:0}
.dhl-ev-latest .dhl-ev-dot{background:var(--grn);box-shadow:0 0 4px rgba(52,211,153,.5)}
.dhl-ev-body{display:flex;flex-direction:column;gap:1px}
.dhl-ev-desc{font-size:9px;color:var(--t2)}
.dhl-ev-meta{font-size:8px;color:var(--t3)}

/* ── PROOFING DISCLAIMERS ── */
@keyframes discPulse{0%,100%{opacity:1}50%{opacity:.45}}
.disc-box{margin-top:10px;padding:8px 10px;border-radius:6px;font-size:10px;line-height:1.5;font-family:Verdana,Geneva,sans-serif;animation:discPulse 2.4s ease-in-out infinite}
.disc-diecut{color:#FBBF24;background:rgba(251,191,36,.08);border:1px solid rgba(251,191,36,.2)}
.disc-proof{color:var(--blu);background:var(--bd);border:1px solid rgba(0,154,222,.2)}
.disc-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;display:block}
.disc-proof textarea{width:100%;min-height:60px;max-height:200px;padding:6px 8px;font-family:Verdana,Geneva,sans-serif;font-size:10px;color:var(--blu);background:rgba(0,154,222,.06);border:1px solid rgba(0,154,222,.15);border-radius:4px;outline:none;resize:vertical;line-height:1.5;animation:discPulse 2.4s ease-in-out infinite}
.disc-proof textarea:focus{border-color:var(--blu);animation:none}
.disc-proof .disc-text{white-space:pre-wrap;word-break:break-word}

/* ── DHL TRACKING ── */
.dhl-track-row{display:flex;align-items:center;gap:6px;padding:4px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03)}
.dhl-track-row:last-child{border:none}
.dhl-track-input{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--tx);background:transparent;border:none;outline:none;text-align:right;flex:1;padding:2px 0}
.dhl-track-input:focus{background:rgba(0,153,168,.08);border-radius:3px}
.dhl-track-input:disabled{opacity:.5;cursor:default}
.dhl-track-input::placeholder{color:var(--t3);font-style:italic}
/* ── DHL Tracking Buttons ── */
.dhl-track-btn{padding:3px 8px;font-size:9px;font-weight:600;font-family:Verdana,Geneva,sans-serif;color:#FBBF24;background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.3);border-radius:4px;cursor:pointer;transition:.15s;text-decoration:none;white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
.dhl-track-btn:hover{background:rgba(251,191,36,.2);color:#FCD34D}
.dhl-track-btn.active{color:#FBBF24;background:rgba(251,191,36,.08);border-color:rgba(251,191,36,.2)}
.dhl-track-btn.active:hover{background:rgba(251,191,36,.15)}
.dhl-track-btn.disabled{opacity:.3;pointer-events:none}
.dhl-track-status{font-size:9px;font-weight:600;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}
.dhl-track-status.pending{color:var(--amb);background:var(--ad)}
.dhl-track-status.shipped{color:var(--grn);background:var(--gd)}
.dhl-track-status.ready{color:#FBBF24;background:rgba(251,191,36,.12)}
.po-warn{font-family:Verdana,Geneva,sans-serif;font-size:7px;font-weight:700;padding:1px 4px;border-radius:3px;color:var(--amb);background:var(--ad);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;animation:dueOrange 1.1s ease-in-out infinite;cursor:default}
.hold-badge{font-family:Verdana,Geneva,sans-serif;font-size:7px;font-weight:700;padding:1px 5px;border-radius:3px;color:var(--pur);background:var(--pd);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;animation:dueHold 2s ease-in-out infinite;cursor:default;margin-left:4px}
td.phase-cell.on-hold{animation:dueHold 2s ease-in-out infinite}
td.phase-cell.on-hold .cell-input{color:var(--pur);font-weight:600}
td.phase-cell.on-hold .cell-input:focus{color:#fff;font-weight:400;background:rgba(0,153,168,.10);box-shadow:inset 0 0 0 1px rgba(0,153,168,.35)}
@keyframes dueHold{0%,100%{background:var(--pd)}50%{background:rgba(124,58,237,.28)}}

/* ── COMMERCIAL LOCK ── */
.comm-locked{position:relative;overflow:hidden}
.comm-locked .det-row{filter:blur(4px);pointer-events:none;user-select:none}
.comm-lock-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(42,47,56,.85);border-radius:8px;z-index:5;cursor:pointer;gap:6px;transition:.15s}
.comm-lock-overlay:hover{background:rgba(42,47,56,.92)}
.comm-lock-icon{font-size:22px;opacity:.7}
.comm-lock-label{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--t3)}

/* ── MASTER AUTH OVERLAY ── */
/* Startup gate — completely hide everything until login */
.top,.dash,.main,.footer,.news-ticker-wrap,.fx-ticker,.risk-ticker{visibility:hidden;pointer-events:none;user-select:none}
body.gated{overflow:hidden;height:100vh}
body.unlocked .top,body.unlocked .dash,body.unlocked .main,body.unlocked .footer,body.unlocked .news-ticker-wrap,body.unlocked .fx-ticker,body.unlocked .risk-ticker{visibility:visible;pointer-events:auto;user-select:auto}
/* Auditor role: hide everything except top bar + Finances panel */
body.role-auditor .main,body.role-auditor .dash-board-row,body.role-auditor .dash-map{display:none}
body.role-auditor .btn-add,body.role-auditor .btn-save,body.role-auditor #btnDel{display:none}
.startup-gate{position:fixed;inset:0;background:#0a0b0f;z-index:9000;display:flex;align-items:center;justify-content:center}
.startup-gate .master-auth-box{animation:gateIn .4s ease}
@keyframes gateIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.loading-overlay{background:rgba(10,11,15,.97);z-index:9500;flex-direction:column}
.loading-overlay.loading-fade{opacity:0;transition:opacity .5s ease}
.loading-box{text-align:center;animation:gateIn .3s ease;padding:34px 40px;min-width:300px}
.loading-spinner{width:48px;height:48px;margin:0 auto 20px;border:2.5px solid rgba(0,188,212,.15);border-top-color:rgba(0,188,212,.7);border-radius:50%;animation:loadSpin .8s linear infinite}
@keyframes loadSpin{to{transform:rotate(360deg)}}
.loading-title{font-family:Verdana,Geneva,sans-serif;font-size:16px;font-weight:600;color:rgba(255,255,255,.81);margin-bottom:8px;letter-spacing:1px}
.loading-sub{font-size:11px;color:rgba(255,255,255,.55);letter-spacing:.3px}
.master-auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:8900;display:flex;align-items:center;justify-content:center}
.master-auth-box{background:var(--bg2);border:1px solid rgba(255,255,255,.04);border-radius:12px;padding:28px 32px;text-align:center;min-width:280px;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.master-auth-box h3{font-family:Verdana,Geneva,sans-serif;font-size:15px;font-weight:600;color:rgba(255,255,255,.81);margin-bottom:4px}
.master-auth-box p{font-size:11px;color:var(--t3);margin-bottom:16px}
.master-auth-box input{display:block;width:100%;padding:8px 12px;font-size:12px;font-family:Verdana,Geneva,sans-serif;color:var(--t2);background:var(--bg4);border:none;border-radius:5px;outline:2px solid transparent;outline-offset:2px;text-align:center;margin:0}
.master-auth-box input:focus-visible{outline:2px solid var(--tl)}
.master-auth-box .input-wrap{position:relative;margin-bottom:8px;border-radius:6px;padding:1px;background:linear-gradient(90deg,rgba(0,153,168,.1),rgba(0,188,212,.45),rgba(0,153,168,.1));background-size:200% 100%;animation:borderSweep 3s ease-in-out infinite}
.master-auth-box .input-wrap:focus-within{background:linear-gradient(90deg,rgba(0,153,168,.2),rgba(0,188,212,.7),rgba(0,153,168,.2));background-size:200% 100%;animation:borderSweep 2s ease-in-out infinite}
@keyframes borderSweep{0%{background-position:100% 0}50%{background-position:0% 0}100%{background-position:100% 0}}
.master-auth-box input:-webkit-autofill,.master-auth-box input:-webkit-autofill:hover,.master-auth-box input:-webkit-autofill:focus{-webkit-box-shadow:0 0 0 50px var(--bg4) inset;-webkit-text-fill-color:var(--t2);caret-color:var(--t2)}
.master-auth-box input::placeholder{color:var(--t3);font-style:italic}
.master-auth-btns{display:flex;gap:8px;margin-top:12px}
.master-auth-btns button{flex:1;padding:8px;font-size:11px;font-weight:600;font-family:Verdana,Geneva,sans-serif;border-radius:6px;cursor:pointer;transition:.15s}
.master-auth-unlock{color:rgba(0,188,212,.7);background:rgba(0,153,168,.08);border:1px solid rgba(0,153,168,.15)}
.master-auth-unlock:hover{background:rgba(0,153,168,.18)}
.master-auth-cancel{color:var(--t3);background:transparent;border:1px solid rgba(255,255,255,.06)}
.master-auth-cancel:hover{background:var(--bg3)}
.master-auth-err{font-size:10px;color:var(--red);min-height:16px;margin-top:8px}

/* Notes area — 2-column (PM + Production) */
.det-notes{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:12px 0}
.det-notes-col{display:flex;flex-direction:column}
.det-notes-col textarea{flex:1;width:100%;min-height:140px;padding:10px 12px;font-family:Verdana,Geneva,sans-serif;font-size:11px;color:var(--tx);background:var(--bg3);border:1px solid var(--bdr);border-radius:8px;outline:none;resize:vertical;line-height:1.5}
.det-notes-col textarea:focus{border-color:var(--teal)}
.det-notes-col textarea::placeholder{color:var(--t3);font-style:italic}
.note-images{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.note-img-wrap{position:relative;display:inline-block;border-radius:6px;overflow:hidden;border:1px solid var(--bdr);background:var(--bg2);cursor:pointer}
.note-img-wrap img{max-width:120px;max-height:90px;display:block;object-fit:cover}
.note-img-wrap:hover{border-color:var(--teal)}
.note-img-del{position:absolute;top:2px;right:2px;width:16px;height:16px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;font-size:10px;line-height:16px;text-align:center;cursor:pointer;display:none}
.note-img-wrap:hover .note-img-del{display:block}
.note-drop-zone{border:1.5px dashed var(--bdr);border-radius:6px;padding:8px;text-align:center;font-size:9px;color:var(--t3);cursor:pointer;transition:all .15s;margin-top:6px}
.note-drop-zone:hover,.note-drop-zone.drag-over{border-color:var(--teal);color:var(--teal);background:rgba(45,212,191,.04)}
.note-img-full{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;cursor:pointer}
.note-img-full img{max-width:90vw;max-height:90vh;border-radius:8px}
.det-notes-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.det-notes-label.pm{color:var(--pur)}
.det-notes-label.prod{color:var(--teal)}
.det-notes-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.pm-tabs{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap}
.pm-tab{padding:3px 8px;font-size:9.5px;font-weight:600;color:var(--t3);background:var(--bg2);border:1px solid var(--bdr);border-radius:4px;cursor:pointer;transition:all .15s;letter-spacing:.3px}
.pm-tab:hover{color:var(--tx);background:var(--bg3)}
.pm-tab.active{color:var(--pur);background:var(--bg3);border-color:var(--pur)}
.pm-tab-dot{display:inline-block;width:5px;height:5px;border-radius:50%;margin-right:4px;vertical-align:middle;flex-shrink:0}
.pm-tab-dot.core{background:var(--tl)}
.pm-tab-dot.ac{background:#F59E0B}
.pm-tab-dot.hc{background:#94A3AF}
.pm-tab-corr{position:relative}
.pm-tab-corr.ac{border-color:rgba(245,158,11,.3)}
.pm-tab-corr.ac.active{color:#F59E0B;border-color:#F59E0B}
.pm-tab-corr.hc{border-color:rgba(148,163,175,.3)}
.pm-tab-corr.hc.active{color:#94A3AF;border-color:#94A3AF}
.pm-tab-remove{margin-left:4px;font-size:11px;color:var(--t3);cursor:pointer;line-height:1;vertical-align:middle}
.pm-tab-remove:hover{color:var(--red)}
.pm-tab-add{color:var(--grn);border-color:rgba(39,174,96,.3);background:rgba(39,174,96,.08);min-width:24px;text-align:center;font-size:12px;font-weight:700}
.pm-tab-add:hover{background:rgba(39,174,96,.18);color:#6EE7B7}
.pm-tab-add-wrap{position:relative;display:inline-flex}
.pm-tab-add-menu{display:none;position:absolute;top:calc(100% + 4px);left:0;background:var(--bg2);border:1px solid var(--bdr);border-radius:6px;box-shadow:0 4px 16px rgba(0,0,0,.5);z-index:20;min-width:120px;overflow:hidden}
.pm-tab-add-menu.open{display:flex;flex-direction:column}
.pm-tab-add-opt{padding:6px 10px;font-size:10px;font-weight:600;color:var(--tx);background:none;border:none;border-bottom:1px solid var(--bdr);cursor:pointer;text-align:left;transition:.15s}
.pm-tab-add-opt:last-child{border-bottom:none}
.pm-tab-add-opt:hover{background:rgba(39,174,96,.12);color:var(--grn)}
.note-render{background:var(--bg3);border:1px solid var(--bdr);border-radius:8px;padding:10px 12px;min-height:140px;font-size:11px;line-height:1.5;overflow-y:auto;max-height:400px}
.note-hr{border:none;border-top:1px solid rgba(255,255,255,.08);margin:5px 0}
.note-hdr{font-weight:600;color:var(--tl);margin:4px 0 2px;font-size:11px}
.note-rev{font-weight:600;color:var(--wh);margin:4px 0 2px;font-size:11px}
.note-bul{padding-left:6px;color:var(--tx);margin:1px 0}
.note-bul .note-arr{color:var(--tl);margin-right:4px}
.note-sub{padding-left:22px;color:var(--t2);margin:1px 0;font-size:10px}
.note-sub .note-arr{color:var(--t3);margin-right:3px;font-size:9px}
.note-txt{color:var(--tx);margin:1px 0}
.note-gap{height:4px}
.note-empty{color:var(--t3);font-style:italic;font-size:11px}
.mod-stamp{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:4px 0;margin-top:2px}
.mod-stamp-text{font-family:'JetBrains Mono',monospace;font-size:9px;color:var(--t3);letter-spacing:.3px}
.status-pill{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border:1px solid;transition:.15s}
.status-pill.active{color:var(--grn);border-color:rgba(52,211,153,.25);background:rgba(52,211,153,.08)}
.status-pill.active:hover{background:rgba(52,211,153,.15)}
.status-pill.archived{color:var(--amb);border-color:rgba(251,191,36,.25);background:rgba(251,191,36,.08)}
.status-pill.archived:hover{background:rgba(251,191,36,.15)}
/* Inline Radio Player in header */
.rp-inline{display:inline-flex;align-items:center;gap:5px;margin-left:4px;vertical-align:middle}
.radio-toggle{display:inline-flex;align-items:center;padding:2px 5px;border-radius:4px;color:var(--t3);background:transparent;border:1px solid rgba(255,255,255,.08);cursor:pointer;transition:.15s;vertical-align:middle}
.radio-toggle:hover{color:var(--tl);border-color:var(--tl);background:rgba(0,153,168,.08)}
.radio-toggle.playing{color:#FBBF24;border-color:rgba(251,191,36,.3);background:rgba(251,191,36,.08);animation:radioPulse 2s ease-in-out infinite}
@keyframes radioPulse{0%,100%{opacity:1}50%{opacity:.7}}
.rp-select{background:var(--bg2);color:var(--t2);border:1px solid var(--bdr);border-radius:3px;padding:1px 4px;font-size:9px;font-family:inherit;cursor:pointer;max-width:120px}
.rp-select:focus{outline:1px solid var(--tl);border-color:var(--tl)}
.rp-vol{-webkit-appearance:none;appearance:none;width:40px;height:2px;background:var(--bdr);border-radius:2px;outline:none;cursor:pointer}
.rp-vol::-webkit-slider-thumb{-webkit-appearance:none;width:8px;height:8px;border-radius:50%;background:var(--tl);cursor:pointer}
.rp-vol::-moz-range-thumb{width:8px;height:8px;border-radius:50%;background:var(--tl);border:none;cursor:pointer}
.rp-label{color:var(--t3);font-size:8px;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}
.rp-label.live{color:#FBBF24;font-weight:600}

.empty{text-align:center;padding:60px 20px;color:var(--t3)}
.empty-icon{font-size:40px;margin-bottom:12px;opacity:.4}
.empty-title{font-family:Verdana,Geneva,sans-serif;font-size:var(--fs-base);font-weight:600;color:var(--t2);margin-bottom:var(--sp1)}
.empty-sub{font-size:12px}

.footer{padding:14px 24px;text-align:center;border-top:1px solid var(--bdr);margin-top:var(--sp4)}
.hud-status{font-size:13px;color:rgba(255,255,255,.3);letter-spacing:2px}
.hud-attr{font-size:7px;color:rgba(255,255,255,.25);letter-spacing:.8px;margin-top:4px}
body.locked .note-img-wrap img,body.locked .eotm-img-area img,body.locked [class*="det-row"] img,body.locked .cal-eotm-thumb{filter:blur(10px);-webkit-filter:blur(10px);user-select:none;transition:filter .3s;pointer-events:none}
body.locked .note-img-wrap,body.locked [class*="det-row"] div[style*="padding:4px"]{cursor:pointer;pointer-events:auto}
body.locked .eotm-img-area{pointer-events:none}
.note-img-full img{filter:none!important;-webkit-filter:none!important}
body.locked .note-drop-zone{display:none!important}
body.locked .note-img-del{display:none!important}
body.locked .eotm-img-del{display:none!important}
body.locked .note-img-wrap{cursor:pointer}
body.role-guest .note-img-del{display:none!important}
body.role-guest .eotm-img-del{display:none!important}
body.role-guest .note-drop-zone{display:none!important}
.news-ticker-wrap{overflow:hidden;background:var(--bg4);border:1px solid var(--bdr);border-radius:6px;position:relative;height:28px;display:flex;align-items:center;width:100%;contain:content}
.news-ticker-label{background:rgba(74,144,217,.12);color:#4A90D9;font-size:8px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:0 8px;height:100%;display:flex;align-items:center;white-space:nowrap;z-index:2;flex-shrink:0;border-right:1px solid rgba(74,144,217,.3);box-shadow:3px 0 8px rgba(0,0,0,.3);font-family:'JetBrains Mono',monospace}
.news-ticker-label-r{background:rgba(74,144,217,.12);color:#4A90D9;font-size:8px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:0 8px;height:100%;display:flex;align-items:center;white-space:nowrap;z-index:2;flex-shrink:0;border-left:1px solid rgba(74,144,217,.3);box-shadow:-3px 0 8px rgba(0,0,0,.3);font-family:'JetBrains Mono',monospace}.news-ticker-track{display:flex;white-space:nowrap;padding-left:8px;will-change:transform;-webkit-backface-visibility:hidden;backface-visibility:hidden;transform:translateZ(0)}
.news-ticker-item{display:inline-flex;align-items:center;padding:0 24px;font-size:11px;color:var(--tx);white-space:nowrap}
.news-ticker-item a{color:var(--tx);text-decoration:none;transition:.15s}
.news-ticker-item a:hover{color:var(--tl)}
.news-ticker-sep{color:#4A90D9;font-weight:700;margin:0 4px;font-size:10px}
.news-ticker-src{font-size:8px;color:var(--t3);margin-left:6px;text-transform:uppercase;letter-spacing:.5px}
/* tickerScroll keyframes removed — rAF engine handles all ticker scrolling */
.rss-loading{font-size:9px;color:var(--t3);padding:8px}
.sync-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle;transition:.3s}
.sync-dot.online{background:#27AE60;box-shadow:0 0 4px rgba(39,174,96,.5)}
.sync-dot.offline{background:#E74C3C;box-shadow:0 0 4px rgba(231,76,60,.5)}
.sync-dot.syncing{background:#F2994A;animation:syncPulse .8s ease-in-out infinite}
@keyframes syncPulse{0%,100%{opacity:1}50%{opacity:.3}}
.sync-status{font-size:var(--fs-xs);color:var(--t3);display:inline-flex;align-items:center;user-select:none;cursor:default}
.toast{position:fixed;top:8px;left:50%;transform:translateX(-50%) translateY(-6px);padding:5px 14px;background:rgba(16,20,28,.92);border:1px solid rgba(0,188,212,.35);border-radius:5px;font-size:10px;font-family:'JetBrains Mono',monospace;letter-spacing:.3px;color:var(--grn);opacity:0;transition:opacity .25s ease,transform .25s ease;pointer-events:none;z-index:9600;white-space:nowrap;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 2px 12px rgba(0,0,0,.4)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── PAYMENT ALERTS ── */
.pmt-row{display:flex;justify-content:space-between;padding:6px 0;font-size:12px;border-top:1px solid rgba(255,255,255,.08);margin-top:4px}
.pmt-row .pmt-k{color:var(--t3);font-weight:600;white-space:nowrap;margin-right:12px;font-size:10px;text-transform:uppercase;letter-spacing:.5px}
.pmt-row .pmt-v{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;text-align:right}
.pmt-ok .pmt-v{color:var(--grn)}
.pmt-soon .pmt-v{color:#EAB308;animation:pmtPulse 1.4s ease-in-out infinite}
.pmt-now .pmt-v{color:var(--amb);animation:pmtPulse 1.1s ease-in-out infinite}
.pmt-past .pmt-v{color:var(--red);font-weight:700;animation:pmtPulse .8s ease-in-out infinite}
@keyframes pmtPulse{0%,100%{opacity:1}50%{opacity:.5}}
/* ── KPI AUTO-CALC ROWS ── */
.kpi-section{border-top:1px solid rgba(255,255,255,.08);margin-top:8px;padding-top:8px}
.kpi-title-bar{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--teal);margin-bottom:6px}
.kpi-block{padding:5px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.kpi-block:last-child{border-bottom:none}
.kpi-label{font-size:10px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.kpi-vals{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.kpi-chip{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;white-space:nowrap}
.kpi-this{background:rgba(0,153,168,.12);color:var(--tl)}
.kpi-avg{background:rgba(255,255,255,.06);color:var(--t2)}
.kpi-lo{background:var(--gd);color:var(--grn)}
.kpi-hi{background:rgba(242,153,74,.12);color:var(--amb)}
.kpi-status{font-family:'JetBrains Mono',monospace;font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px}
.kpi-early{background:var(--gd);color:var(--grn)}
.kpi-late{background:var(--rd);color:var(--red)}
.kpi-waiting{background:rgba(255,255,255,.06);color:var(--t3);font-style:italic}
/* ── CORRECTION SUMMARY + PIE ── */
.corr-summary{display:flex;align-items:center;gap:14px;padding:6px 0;flex-wrap:wrap}
.corr-pie{width:36px;height:36px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.08)}
.corr-legends{display:flex;flex-direction:column;gap:2px}
.corr-leg{display:flex;align-items:center;gap:6px;font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600}
.corr-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}
.corr-dot-ac{background:var(--pur)}
.corr-dot-hc{background:#8B0000}
.corr-avgs{display:flex;gap:10px;margin-left:auto}
.corr-avg-box{text-align:center;padding:3px 10px;border-radius:4px;background:rgba(255,255,255,.04)}
.corr-avg-num{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;color:var(--tx)}
.corr-avg-label{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--t3)}

/* ── QM NAV ICON ── */
.nc-qm{color:#4FC3F7;border-color:rgba(0,154,222,.4);background:rgba(0,154,222,.12);box-shadow:0 0 6px rgba(0,154,222,.15)}
.nc-qm:hover,.nc-qm.active{color:#81D4FA;border-color:rgba(0,154,222,.7);background:rgba(0,154,222,.22);box-shadow:0 0 16px rgba(0,154,222,.45),0 0 4px rgba(0,154,222,.2) inset}

/* ── SLIDE-OUT PANELS (shared) ── */
body.panel-open{overflow:hidden}
.so-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1100;backdrop-filter:blur(2px)}
.so-overlay.open{display:block}
.so-panel{position:fixed;top:0;right:-1007px;width:987px;max-width:92vw;height:100vh;background:var(--bg);border-left:1px solid var(--bdr);z-index:1110;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px rgba(0,0,0,.4)}
.so-panel.open{right:0}
.so-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--bg2);border-bottom:1px solid var(--bdr);flex-shrink:0}
.so-title-row{display:flex;align-items:center;gap:10px}
.so-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;font-family:'JetBrains Mono',monospace;letter-spacing:-.5px}
.so-title{font-size:15px;font-weight:700;color:var(--wh);letter-spacing:.3px}
.so-tag{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;text-transform:uppercase;letter-spacing:.8px}
.so-close{width:28px;height:28px;border-radius:6px;border:1px solid var(--bdr);background:var(--bg3);color:var(--t2);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.15s;line-height:1}
.so-close:hover{color:var(--red);border-color:rgba(231,76,60,.3);background:rgba(231,76,60,.1)}
.so-nav{display:flex;gap:4px;padding:10px 18px 0;background:var(--bg2);flex-shrink:0}
.so-tab{padding:6px 12px;border:none;border-radius:6px 6px 0 0;background:transparent;color:var(--t3);font-size:11px;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit;border-bottom:2px solid transparent}
.so-tab:hover{color:var(--t2);background:rgba(255,255,255,.03)}
.so-body{flex:1;overflow:hidden;display:flex;flex-direction:column}
.so-view{flex:1;overflow-y:auto;padding:16px 18px}
.so-iframe{width:100%;height:100%;border:none;border-radius:0;background:var(--bg)}

/* ── QM panel colours ── */
.so-icon.qm{background:linear-gradient(135deg,#0077B6,#4FC3F7)}
.so-tag.qm{color:#4FC3F7;background:rgba(0,154,222,.12)}
.so-tab.qm.active{color:#4FC3F7;border-bottom-color:#4FC3F7}

/* ── FIN panel colours ── */
.so-icon.fin{background:linear-gradient(135deg,#1E8449,#34D399)}
.so-tag.fin{color:#34D399;background:rgba(52,211,153,.12)}
.so-tab.fin.active{color:#34D399;border-bottom-color:#34D399}

/* ── CON (CMH Athina) panel colours ── */
.so-icon.con{background:linear-gradient(135deg,#0099A8,#00BCD4)}
.so-tag.con{color:#00BCD4;background:rgba(0,188,212,.12)}
.so-tab.con.active{color:#00BCD4;border-bottom-color:#00BCD4}

/* ── TRA (travel) panel colours ── */
.so-icon.tra{background:linear-gradient(135deg,#4338CA,#818CF8)}
.so-tag.tra{color:#818CF8;background:rgba(99,102,241,.12)}
.so-tab.tra.active{color:#818CF8;border-bottom-color:#818CF8}

/* ── CVT (converters) panel colours ── */
.so-icon.cvt{background:linear-gradient(135deg,#B45309,#F59E0B);font-size:9px;font-weight:700;letter-spacing:.5px}
.so-tag.cvt{color:#F59E0B;background:rgba(245,158,11,.12)}
.so-tab.cvt.active{color:#F59E0B;border-bottom-color:#F59E0B}
.nc-cvt{color:#F59E0B}
.nc-cvt.active,.nc-cvt:hover{background:rgba(245,158,11,.15)}

/* ── Converter panel form styles ── */
.cvt-directory{display:flex;flex-direction:column;gap:8px;padding:2px 0}
.cvt-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 20px;color:var(--t3);font-size:11px;text-align:center}
.cvt-empty-icon{opacity:.4}
.cvt-add-btn{padding:8px 18px;border-radius:6px;border:1px solid rgba(245,158,11,.4);background:rgba(245,158,11,.1);color:#F59E0B;font-size:10px;font-weight:600;cursor:pointer;transition:.15s;letter-spacing:.3px}
.cvt-add-btn:hover{background:rgba(245,158,11,.2)}
.cvt-form{display:flex;flex-direction:column;gap:0;padding:0 0 20px}
.cvt-section{border-bottom:1px solid var(--bdr);padding:16px 18px}
.cvt-section:last-of-type{border-bottom:none}
.cvt-section-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#F59E0B;margin-bottom:12px}
.cvt-subsection{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);margin:12px 0 6px;padding-top:4px}
.cvt-field-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:8px}
.cvt-row-3{grid-template-columns:1fr 1fr 1fr}
.cvt-label{display:flex;flex-direction:column;gap:3px;font-size:9px;color:var(--t3);font-weight:500;letter-spacing:.3px}
.cvt-input,.cvt-input-sm{background:var(--bg2);border:1px solid var(--bdr);border-radius:4px;padding:6px 8px;font-size:11px;color:var(--t1);font-family:JetBrains Mono,monospace;transition:border-color .15s}
.cvt-input:focus,.cvt-input-sm:focus{border-color:#F59E0B;outline:none;box-shadow:0 0 0 2px rgba(245,158,11,.15)}
.cvt-input-sm{width:100%;min-width:0}
.cvt-textarea{width:100%;background:var(--bg2);border:1px solid var(--bdr);border-radius:4px;padding:8px;font-size:11px;color:var(--t1);font-family:JetBrains Mono,monospace;resize:vertical;min-height:60px}
.cvt-textarea:focus{border-color:#F59E0B;outline:none;box-shadow:0 0 0 2px rgba(245,158,11,.15)}
.cvt-dual-row{display:grid;grid-template-columns:1fr 100px 100px;gap:8px;align-items:center;margin-bottom:6px}
.cvt-dual-label{font-size:9px;color:var(--t2);font-weight:500}
.cvt-contacts-grid{display:flex;flex-direction:column;gap:4px}
.cvt-grid-header{display:grid;grid-template-columns:1.2fr 1fr 1.3fr .8fr;gap:6px;font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);padding:0 2px 4px}
.cvt-contact-row{display:grid;grid-template-columns:1.2fr 1fr 1.3fr .8fr;gap:6px}
.cvt-contact-row input{background:var(--bg2);border:1px solid var(--bdr);border-radius:4px;padding:5px 7px;font-size:10px;color:var(--t1);font-family:JetBrains Mono,monospace}
.cvt-contact-row input:focus{border-color:#F59E0B;outline:none}
.cvt-form-actions{display:flex;gap:8px;padding:16px 18px;border-top:1px solid var(--bdr);position:sticky;bottom:0;background:var(--bg);z-index:2}
.cvt-btn{padding:8px 16px;border-radius:6px;font-size:10px;font-weight:600;cursor:pointer;transition:.15s;border:none;letter-spacing:.3px}
.cvt-btn-save{background:#F59E0B;color:#1a1a2e}
.cvt-btn-save:hover{background:#D97706}
.cvt-btn-secondary{background:rgba(245,158,11,.12);color:#F59E0B;border:1px solid rgba(245,158,11,.3)}
.cvt-btn-secondary:hover{background:rgba(245,158,11,.2)}
.cvt-btn-cancel{background:var(--bg2);color:var(--t3);border:1px solid var(--bdr)}
.cvt-btn-cancel:hover{background:var(--bg3,var(--bg2));color:var(--t2)}

/* Converter directory card */
.cvt-card{display:flex;gap:12px;padding:12px 14px;border:1px solid var(--bdr);border-radius:8px;background:var(--bg2);cursor:pointer;transition:border-color .15s,background .15s}
.cvt-card:hover{border-color:rgba(245,158,11,.4);background:rgba(245,158,11,.04)}
.cvt-card-icon{width:42px;height:42px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.5px}
.cvt-card-info{flex:1;min-width:0}
.cvt-card-name{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:2px}
.cvt-card-loc{font-size:9px;color:var(--t3);margin-bottom:4px}
.cvt-card-meta{display:flex;gap:8px;font-size:8px;color:var(--t3)}
.cvt-card-meta span{background:rgba(245,158,11,.08);color:#F59E0B;padding:2px 6px;border-radius:3px}
.cvt-card-actions{display:flex;gap:4px;align-items:flex-start;flex-shrink:0}
.cvt-card-btn{padding:4px 8px;border-radius:4px;border:1px solid var(--bdr);background:transparent;color:var(--t3);font-size:9px;cursor:pointer;transition:.15s}
.cvt-card-btn:hover{border-color:#F59E0B;color:#F59E0B}
.cvt-card-btn.del:hover{border-color:var(--red);color:var(--red)}

/* Detail view (read-only spec sheet) */
.cvt-detail-header{display:flex;align-items:center;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--bdr);margin-bottom:16px}
.cvt-detail-name{font-size:16px;font-weight:700;color:var(--t1)}
.cvt-detail-loc{font-size:11px;color:var(--t3)}
.cvt-detail-section{margin-bottom:16px}
.cvt-detail-section-title{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#F59E0B;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid rgba(245,158,11,.2)}
.cvt-detail-table{width:100%;font-size:10px;border-collapse:collapse}
.cvt-detail-table td{padding:4px 8px;border-bottom:1px solid var(--bdr);color:var(--t2)}
.cvt-detail-table td:first-child{color:var(--t3);font-weight:500;width:40%;white-space:nowrap}
.cvt-detail-actions{display:flex;gap:8px;padding:16px 0}

/* Views with sub-tabs — flex column to fill height */
.so-view.so-view-tabs{display:flex;flex-direction:column;padding:0;overflow:hidden}
.so-sub-view{flex:1;overflow:hidden}
.so-sub-view.iframe-view{padding:0}
.so-sub-view .so-iframe{width:100%;height:100%;border:none}

/* Fleet printer selector */
.fleet-selector{display:flex;gap:4px;padding:6px 8px;border-bottom:1px solid var(--bdr);background:rgba(0,0,0,.15);flex-shrink:0}
.fleet-btn{display:flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--bdr);border-radius:6px;background:transparent;color:var(--t3);font-size:10px;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit}
.fleet-btn:hover{color:var(--t2);border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.03)}
.fleet-btn.active{color:var(--wh,#fff);border-color:rgba(0,188,212,.3);background:rgba(0,188,212,.08)}
.fleet-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.fleet-printer{display:flex;flex-direction:column;flex:1;min-height:0}

/* Sub-tabs (nested inside a view) */
.so-sub-nav{display:flex;gap:2px;padding:4px 8px 8px;border-bottom:1px solid var(--bdr)}
.so-sub-tab{padding:4px 10px;border:none;border-radius:4px 4px 0 0;background:transparent;color:var(--t3);font-size:10px;font-weight:600;cursor:pointer;transition:.15s;font-family:inherit;border-bottom:2px solid transparent}
.so-sub-tab:hover{color:var(--t2);background:rgba(255,255,255,.03)}
#epsonSubNav .so-sub-tab.con.active{color:#1A5BC6;border-bottom-color:#1A5BC6}
#canonSubNav .so-sub-tab.con.active{color:#E53935;border-bottom-color:#E53935}

/* Doc Cards (shared for index views) */
.so-doc-card{display:flex;gap:14px;padding:16px;background:var(--bg2);border:1px solid var(--bdr);border-radius:10px;margin-bottom:10px;cursor:pointer;transition:.2s;align-items:flex-start}
.so-doc-card:hover{border-color:rgba(99,102,241,.3);background:rgba(99,102,241,.04);transform:translateX(3px)}
#conPanel .so-doc-card:hover{border-color:rgba(0,188,212,.3);background:rgba(0,188,212,.04)}
.so-doc-icon{width:42px;height:42px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;font-family:'JetBrains Mono',monospace;flex-shrink:0;letter-spacing:-.5px}
.so-doc-info{flex:1;min-width:0}
.so-doc-name{font-size:14px;font-weight:700;color:var(--wh);margin-bottom:4px}
.so-doc-desc{font-size:11px;color:var(--t2);line-height:1.5;margin-bottom:8px}
.so-doc-meta-row{display:flex;align-items:center;gap:8px}
.so-doc-id{font-family:'JetBrains Mono',monospace;font-size:10px;font-weight:600;color:#4FC3F7}
.so-doc-ver{font-size:10px;color:var(--t3)}
.so-doc-status{font-size:9px;font-weight:700;padding:2px 7px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}
.so-doc-status.active{background:var(--gd);color:var(--grn)}

/* iframe views no padding */
.so-view.iframe-view{padding:0;overflow:hidden}

/* ═══════ RESPONSIVE BREAKPOINTS (v3.7.33) ═══════ */

/* Tablet */
@media (max-width: 1024px) {
  .dash-header-row { flex-wrap: wrap; }
  .dash-card-status { flex: 1 1 100% !important; width: auto !important; }
  .dash-card-cal { min-width: 100%; }
  .dash-board-row { flex-wrap: wrap; height: auto !important; transition: none !important; }
  .dash-board-row.row-collapsed { height: auto !important; }
  .board-card { flex: 1 1 calc(50% - 5px) !important; width: auto !important; min-width: 140px; height: 260px !important; }
  .board-card.card-min { height: 58px !important; }
  .board-card-workspace { flex: 1.6 1 calc(50% - 5px) !important; }
  .aktenschrank-card { width: auto !important; flex: 1 1 calc(50% - 5px) !important; }
  .eotm-card { min-width: 100% !important; flex: 1 1 100% !important; max-width: 100% !important; }
  .tbl-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .so-panel { width: 90vw; max-width: 90vw; }
  .top-nav-icons { gap: 4px; }
  .search-actions { gap: 2px; }
}

/* Mobile */
@media (max-width: 640px) {
  .top { flex-direction: column; gap: 6px; padding: 6px 8px; }
  .top-center { order: -1; }
  .top-left, .top-right { width: 100%; justify-content: center; }
  .hud-brand { text-align: center; }
  .utc-clock { text-align: center; }
  .dash { padding: 6px; }
  .dash-header-row { gap: 6px; }
  .dash-card { min-width: 100%; }
  .dash-card-status { flex: 1 1 100% !important; width: 100% !important; }
  .dash-center-col { min-width: 100%; }
  .aktenschrank-card { width: auto; flex: 1 1 100%; }
  .board-card { flex: 1 1 100% !important; width: 100% !important; }
  .main { padding: 0 4px; }
  table { font-size: 10px; }
  th.phase { min-width: 60px; }
  .so-panel { width: 100vw; max-width: 100vw; left: 0; border-radius: 0; }
  .rp-inline { display: none; }
  #assignFilterWrap { display: none; }
  .fx-ticker { display: none; }
  .risk-ticker { display: none; }
  .news-ticker { display: none; }
}

/* ═══════ JOB LOCK SYSTEM ═══════ */
.job-lock-cb {
  width: 8px; height: 8px; cursor: pointer; accent-color: var(--amb);
  position: absolute; bottom: 1px; left: 1px; opacity: 0; transition: opacity .15s;
}
.job-row:hover .job-lock-cb { opacity: 0.35; }
.job-lock-cb:hover { opacity: 0.7 !important; }
.job-lock-cb:checked { opacity: 0.8 !important; }
.job-lock-cb:disabled { cursor: not-allowed; opacity: 0 !important; }
.job-row:hover .job-lock-cb:disabled { opacity: 0.15 !important; }
.lock-indicator { font-size: 10px; position: absolute; top: 1px; right: 1px; }
tr.job-row.locked-by-other { opacity: 0.7; }
tr.job-row.locked-by-other .cell-input {
  background: rgba(255,76,76,.04) !important; color: var(--t3); pointer-events: none;
}

/* ═══════ FILE ATTACHMENTS ═══════ */
.detail-docs { border-top: 1px solid var(--bdr); padding-top: 10px; margin-top: 12px; }
.section-header {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; color: var(--t3); margin-bottom: 8px;
}
.doc-upload-btn {
  background: var(--tl); color: #000; border: none; border-radius: 4px;
  padding: 3px 8px; font-size: 9px; font-weight: 600; cursor: pointer; transition: opacity .15s;
}
.doc-upload-btn:hover { opacity: 0.8; }
.documents-list {
  display: flex; flex-direction: column; gap: 4px;
  border: 1.5px dashed var(--bdr); border-radius: 6px; padding: 8px; min-height: 36px; transition: all .2s;
}
.documents-list.drag-over { border-color: var(--tl); background: rgba(0,153,168,.04); }
.doc-item {
  display: flex; align-items: center; gap: 8px; padding: 5px 8px;
  background: var(--bg3); border-radius: 4px; font-size: 9px; color: var(--t2);
}
.doc-icon { font-size: 12px; flex-shrink: 0; }
.doc-meta { flex: 1; min-width: 0; }
.doc-name { font-weight: 500; color: var(--tx); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.doc-info { font-size: 8px; color: var(--t3); margin-top: 1px; }
.doc-action-btn {
  background: transparent; border: 1px solid var(--bdr); border-radius: 4px;
  padding: 2px 6px; font-size: 10px; cursor: pointer; transition: all .15s; flex-shrink: 0; color: var(--t2);
}
.doc-action-btn:hover { border-color: var(--tl); color: var(--tl); }
.doc-action-btn.doc-delete:hover { border-color: var(--red); color: var(--red); }
.doc-empty { padding: 10px; text-align: center; color: var(--t3); font-size: 9px; font-style: italic; }

/* Personal File Locker */
.files-upload-area {
  border: 1.5px dashed var(--bdr); border-radius: 6px; transition: all .2s; cursor: pointer;
}
.files-upload-area:hover, .files-upload-area.drag-over {
  border-color: var(--tl); background: rgba(0,153,168,.04);
}
.file-item {
  display: flex; align-items: center; gap: 6px; padding: 5px 6px;
  background: var(--bg3); border-radius: 4px;
}
.file-info { flex: 1; min-width: 0; }
.file-name { font-weight: 500; color: var(--tx); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 10px; }
.file-meta { font-size: 8px; color: var(--t3); margin-top: 1px; }
.file-actions { display: flex; gap: 3px; }
.file-action-btn {
  background: transparent; border: 1px solid var(--bdr); border-radius: 4px;
  padding: 2px 5px; font-size: 9px; cursor: pointer; transition: all .15s; color: var(--t2);
}
.file-action-btn.fa-view{color:var(--tl);border-color:rgba(0,188,212,.2)}
.file-action-btn.fa-view:hover{background:rgba(0,188,212,.15);border-color:var(--tl);color:#fff}
.file-action-btn.fa-share{color:var(--grn);border-color:rgba(39,174,96,.2)}
.file-action-btn.fa-share:hover{background:rgba(39,174,96,.15);border-color:var(--grn);color:#fff}
.file-action-btn.fa-delete{color:var(--red);border-color:rgba(231,76,60,.2)}
.file-action-btn.fa-delete:hover{background:rgba(231,76,60,.15);border-color:var(--red);color:#fff}
.file-action-btn:hover { border-color: var(--tl); color: var(--tl); }
.fl-shared-badge{display:inline-block;font-size:8px;color:var(--grn);margin-left:4px;vertical-align:middle;opacity:.8}

/* ── File Comments ── */
.file-comment-item{margin-bottom:6px;padding:6px 8px;background:var(--bg3);border-radius:6px;font-size:10px;border-left:2px solid var(--tl)}
.file-comment-item:first-child{border-left-color:var(--grn)}
.file-comments-scroll{overflow-y:auto}

/* ── Map POI Markers ── */
.poi-pin{pointer-events:auto!important}
.poi-pin svg{filter:drop-shadow(0 1px 4px rgba(0,0,0,.6))}
.poi-pulse svg{animation:poiPulse 2.5s ease-in-out infinite}
@keyframes poiPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}
/* City name labels below pins */
.poi-city-label{background:none!important;border:none!important;box-shadow:none!important;font-size:8px!important;font-weight:700!important;color:rgba(255,255,255,.6)!important;text-transform:uppercase!important;letter-spacing:1px!important;text-shadow:0 1px 4px rgba(0,0,0,.9)!important;font-family:'JetBrains Mono',monospace!important;white-space:nowrap!important;padding:0!important}
.poi-city-label::before{display:none!important}
.crisis-zone-label{background:none!important;border:none!important;box-shadow:none!important;font-size:7px!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:1px!important;text-shadow:0 1px 4px rgba(0,0,0,.9)!important;font-family:'JetBrains Mono',monospace!important;white-space:nowrap!important;padding:0!important;line-height:1.4!important}
.crisis-zone-label::before{display:none!important}
/* Chat unread badge */
.chat-unread-badge{display:inline-block;min-width:14px;height:14px;line-height:14px;text-align:center;font-size:8px;font-weight:700;color:#fff;background:rgba(0,188,212,.55);border-radius:8px;padding:0 4px;margin-left:4px;vertical-align:middle;animation:unreadPop .3s ease}
@keyframes unreadPop{0%{transform:scale(0)}60%{transform:scale(1.2)}100%{transform:scale(1)}}
/* Post-it notes */
.postit-btn{width:32px;height:32px;border:1px solid var(--bdr);border-radius:6px;background:var(--bg3);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.15s}
.postit-btn:hover{border-color:var(--tl);background:var(--bg4)}
.postit-board{display:flex;flex-wrap:wrap;gap:6px;max-height:120px;overflow-y:auto;padding:2px 0}
.postit-note{position:relative;width:calc(33.33% - 4px);min-height:40px;padding:6px 16px 6px 6px;border-radius:4px;font-size:9px;line-height:1.3;font-family:Verdana,Geneva,sans-serif;color:#222;word-break:break-word;box-shadow:1px 2px 6px rgba(0,0,0,.25)}
.postit-note:nth-child(4n+1){background:#fef68a}
.postit-note:nth-child(4n+2){background:#a8e6cf}
.postit-note:nth-child(4n+3){background:#ffb3ba}
.postit-note:nth-child(4n+4){background:#bae1ff}
.postit-del{position:absolute;top:2px;right:4px;background:none;border:none;cursor:pointer;font-size:10px;color:rgba(0,0,0,.35);padding:0;line-height:1}
.postit-del:hover{color:rgba(0,0,0,.7)}
/* Legacy crisis pins (kept for compat) */
@keyframes crisisPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}
.crisis-pin{pointer-events:auto!important}
.crisis-pin.crisis-pulse svg{animation:crisisPulse 2s ease-in-out infinite}
.crisis-tooltip{max-width:280px!important;white-space:normal!important;font-size:11px!important;line-height:1.4!important}
.dash-map .leaflet-popup-content-wrapper{background:var(--bg2)!important;color:var(--tx)!important;border:1px solid var(--bdr)!important;border-radius:6px!important;box-shadow:0 4px 16px rgba(0,0,0,.5)!important;font-size:11px!important;line-height:1.4!important;font-family:'JetBrains Mono',monospace!important}
.dash-map .leaflet-popup-content{margin:8px 12px!important;max-width:260px!important}
.dash-map .leaflet-popup-tip{background:var(--bg2)!important;border:1px solid var(--bdr)!important}

/* ── Visitor Log ── */
.visitor-log-card{background:var(--bg2);border:1px solid var(--bdr);border-radius:6px;padding:0 12px 10px;margin-top:8px}
.visitor-stats{display:flex;gap:8px;padding:6px 0;font-size:9px;color:var(--t2);font-family:'JetBrains Mono',monospace}
.visitor-stat{background:var(--bg3);border:1px solid var(--bdr);border-radius:4px;padding:4px 10px;display:flex;flex-direction:column;align-items:center;gap:2px}
.visitor-stat-val{font-size:14px;font-weight:700;color:var(--tl)}
.visitor-stat-label{font-size:7px;text-transform:uppercase;letter-spacing:1px;color:var(--t3)}
.visitor-list{max-height:80px;overflow-y:auto;font-size:9px;font-family:'JetBrains Mono',monospace}
.visitor-row{display:flex;gap:10px;padding:4px 0;border-bottom:1px solid rgba(0,153,168,.06);color:var(--t2);align-items:center}
.visitor-row:last-child{border-bottom:none}
.vr-time{color:var(--t3);min-width:55px}
.vr-ip{color:var(--amb);min-width:90px}
.vr-page{color:var(--tl);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.vr-device{min-width:50px;color:var(--t3)}
.vr-browser{min-width:50px;color:var(--t3)}
.vr-bot{color:var(--red)!important}

/* ═══════ ACCESSIBILITY — Focus Indicators (A1, v3.8.3) ═══════ */

/* Global focus-visible ring for keyboard users — not triggered by mouse clicks */
:focus-visible{outline:2px solid var(--tl);outline-offset:2px}
/* Inputs already style their own focus; keep outline subtle */
input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--tl);outline-offset:0}
/* Buttons: teal ring */
button:focus-visible,.btn:focus-visible,.top-action:focus-visible{outline:2px solid var(--tl);outline-offset:2px;border-radius:4px}
/* Nav icons */
.top-nav-icons div:focus-visible{outline:2px solid var(--tl);outline-offset:2px;border-radius:4px}
/* Cards */
.clock-card:focus-visible,.dash-card:focus-visible{outline:2px solid var(--tl);outline-offset:2px}
/* Tabs */
.aktenschrank-tab:focus-visible,.fids-tab:focus-visible{outline:2px solid var(--tl);outline-offset:-2px}
/* Radio controls */
.rp-vol:focus-visible{outline:2px solid var(--tl);outline-offset:2px}

/* ═══════ ACCESSIBILITY — Reduced Motion (A3, v3.8.3) ═══════ */

@media (prefers-reduced-motion: reduce) {
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important}
  .delayed-item{animation:none!important}
  .sync-dot.syncing{animation:none!important}
  .crisis-pin.crisis-pulse svg{animation:none!important}
  /* rAF ticker engine checks prefers-reduced-motion in JS — no CSS override needed */
  .master-auth-box .input-wrap{animation:none!important}
}

/* ═══════ ACCESSIBILITY — Additional Breakpoints (A5, v3.8.3) ═══════ */

/* Large screens: full width, no cap */
@media (min-width: 1600px) {
  .dash{max-width:100%}
  .main{max-width:100%}
  .footer{max-width:100%}
}

/* Medium phones 481-767px */
@media (max-width: 767px) and (min-width: 481px) {
  .dash-header-row{flex-wrap:wrap;gap:6px}
  .dash-card-status{flex:1 1 100%!important;width:100%!important}
  .dash-card-cal{min-width:100%}
  .dash-center-col{min-width:100%}
  .board-card{flex:1 1 100%!important;width:100%!important}
  .so-panel{width:95vw;max-width:95vw}
  .det-notes{grid-template-columns:1fr}
}

/* Small phones <=480px */
@media (max-width: 480px) {
  .top{padding:4px 6px;gap:4px}
  .hud-title{font-size:12px;letter-spacing:1px}
  .utc-clock .utc-time{font-size:11px}
  .dash-clocks-row{gap:4px}
  .clock-card{min-width:65px;max-width:80px;padding:4px 2px 3px}
  .clock-time{font-size:9px}
  .clock-city{font-size:7px}
  .dash-card{padding:8px 10px}
  .det-notes{grid-template-columns:1fr}
  .tbl-wrap{font-size:9px}
  th.phase{min-width:50px}
  .so-panel{width:100vw;max-width:100vw;border-radius:0}
}

/* ═══════════════════════════════════════════
   Missions
   ═══════════════════════════════════════════ */
.msn-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 0 6px;border-bottom:1px solid var(--bdr,rgba(255,255,255,.06));margin-bottom:6px}
.msn-toolbar-title{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--tl,#00BCD4);opacity:.7}
.msn-add-btn{width:24px;height:24px;border:1px solid var(--bdr,rgba(255,255,255,.08));border-radius:4px;background:var(--bg4,#1e1e1e);color:var(--tl,#00BCD4);font-size:16px;line-height:22px;text-align:center;cursor:pointer;padding:0}
.msn-add-btn:hover{background:rgba(0,188,212,.1)}

/* Sub-tabs (My Missions / Shared) */
.msn-subtab-bar{display:flex;gap:3px;margin-bottom:8px}
.msn-subtab{padding:3px 8px;font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--bdr);border-radius:4px;background:transparent;color:var(--t3);cursor:pointer;transition:.15s;font-family:Verdana,Geneva,sans-serif}
.msn-subtab:hover{color:var(--tx);border-color:var(--t3)}
.msn-subtab.active{color:var(--tl);border-color:var(--tl);background:var(--td)}

/* 2-column mission grid */
.msn-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;max-height:300px;overflow-y:auto;padding-right:2px}
.msn-grid .msn-card.expanded{grid-column:1/-1}

/* Mission card */
.msn-card{background:var(--bg3,#1a1a1a);border:1px solid var(--bdr,rgba(255,255,255,.06));border-radius:6px;padding:8px;transition:background .15s}
.msn-card:hover{background:rgba(0,153,168,.1)}
.msn-card.completed{opacity:.55}
.msn-card.expanded{border-color:rgba(0,188,212,.15)}

.msn-header{display:flex;align-items:center;gap:5px;cursor:pointer}
.msn-owner-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.msn-title{flex:1;font-size:10px;font-weight:600;color:var(--t2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.msn-pri{padding:1px 5px;border-radius:3px;font-size:7px;font-weight:700;letter-spacing:.4px;white-space:nowrap}

.msn-meta{display:flex;align-items:center;gap:6px;margin-top:4px;font-size:9px;color:var(--t3,#666)}
.msn-progress-wrap{flex:1;height:2px;background:var(--bg4,#1e1e1e);border-radius:2px;overflow:hidden}
.msn-progress-bar{height:100%;border-radius:2px;transition:width .3s}
.msn-progress-text{font-size:8px;color:var(--t3,#666);white-space:nowrap}
.msn-shares{display:flex;gap:2px;margin-left:auto}
.msn-avatar{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;font-size:7px;font-weight:700;color:#fff}

/* Mission detail / expanded */
.msn-detail{margin-top:8px;padding-top:8px;border-top:1px solid var(--bdr,rgba(255,255,255,.06))}
.msn-desc{font-size:10px;color:var(--t2,#999);margin-bottom:8px;line-height:1.5}

/* Steps timeline */
.msn-steps{position:relative}
.msn-step{display:flex;gap:8px;margin-bottom:2px;min-height:28px}
.msn-step:last-child{margin-bottom:0}

.msn-step-line{display:flex;flex-direction:column;align-items:center;width:14px;flex-shrink:0}
.msn-step-dot{font-size:12px;cursor:pointer;line-height:1;user-select:none;transition:color .2s}
.msn-step-dot:hover{filter:brightness(1.3)}
.msn-step-connector{flex:1;width:1px;background:var(--bdr,rgba(255,255,255,.08));margin:2px 0}

.msn-step-body{flex:1;padding-bottom:6px}
.msn-step-title{font-size:10px;font-weight:500;color:var(--tx,#e0e0e0);line-height:1.4}
.msn-step-title.done{text-decoration:line-through;opacity:.5}
.msn-step-loc,.msn-step-date{font-size:8px;color:var(--t3,#666);margin-top:1px}
.msn-step-notes{font-size:8px;color:var(--t2,#999);margin-top:2px;font-style:italic;line-height:1.4}

/* Action buttons */
.msn-actions{display:flex;gap:4px;margin-top:8px;flex-wrap:wrap}
.msn-btn{padding:3px 8px;font-size:8px;font-weight:600;border:1px solid var(--bdr,rgba(255,255,255,.08));border-radius:4px;background:var(--bg4,#1e1e1e);color:var(--tx,#e0e0e0);cursor:pointer;letter-spacing:.3px}
.msn-btn:hover{background:rgba(0,188,212,.08);border-color:rgba(0,188,212,.15)}
.msn-btn-done{color:#27AE60;border-color:rgba(39,174,96,.2)}
.msn-btn-done:hover{background:rgba(39,174,96,.08)}
.msn-btn-del{color:#EF4444;border-color:rgba(239,68,68,.15)}
.msn-btn-del:hover{background:rgba(239,68,68,.08)}

/* ─── Calendar view toggle (Month / Week / Day) ─── */
.cal-view-toggle{display:flex;gap:3px;justify-content:center;margin:4px 0 6px}
.cal-view-btn{background:var(--bg3);border:1px solid var(--bdr);color:var(--t3);cursor:pointer;font-family:'JetBrains Mono',monospace;font-size:8px;font-weight:700;letter-spacing:.6px;padding:3px 9px;border-radius:3px;text-transform:uppercase;transition:.15s}
.cal-view-btn:hover{color:var(--wh);border-color:rgba(0,188,212,.3)}
.cal-view-btn.active{background:rgba(0,188,212,.15);color:var(--tl);border-color:rgba(0,188,212,.4)}
/* ─── Week view ─── */
.cal-week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-top:2px}
.cal-week-col{background:var(--bg3);border:1px solid transparent;border-radius:3px;padding:4px 3px;min-height:160px;display:flex;flex-direction:column}
.cal-week-col.cal-wk-today{background:rgba(242,201,76,.06);border-color:rgba(242,201,76,.28)}
.cal-week-hdr{text-align:center;font-size:7px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:1px}
.cal-week-hdr.cal-wk-today{color:#F2C94C}
.cal-week-daynum{text-align:center;font-size:12px;font-weight:700;color:var(--wh);font-family:'JetBrains Mono',monospace;margin-bottom:3px;padding-bottom:3px;border-bottom:1px solid rgba(255,255,255,.06)}
.cal-week-col.cal-wk-today .cal-week-daynum{color:#F2C94C}
.cal-week-events{display:flex;flex-direction:column;gap:2px;overflow:hidden}
.cal-week-ev{font-size:7px;line-height:1.35;padding:2px 4px;border-radius:2px;background:rgba(0,188,212,.12);color:var(--tl);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:default}
.cal-week-ev.ev-task{background:rgba(242,156,56,.12);color:var(--amb)}
.cal-week-ev.ev-task.ev-future{background:rgba(39,174,96,.15);color:#6EE7B7}
.cal-week-ev.ev-task.ev-today{background:rgba(242,201,76,.15);color:#F2C94C}
.cal-week-ev.ev-task.ev-overdue{background:rgba(231,76,60,.15);color:#e74c3c}
.cal-week-ev.ev-files{background:rgba(155,89,182,.15);color:#bb6bd9}
.cal-week-ev.ev-gcal{background:rgba(66,133,244,.15);color:#6ea4f2}
/* ─── Day view ─── */
.cal-day-view{margin-top:4px}
.cal-day-events{display:flex;flex-direction:column;gap:4px}
.cal-day-ev{display:flex;align-items:center;gap:8px;padding:6px 8px;background:var(--bg3);border-left:3px solid var(--tl);border-radius:0 4px 4px 0;font-size:10px;color:var(--t1)}
.cal-day-ev.ev-task{border-left-color:var(--amb)}
.cal-day-ev.ev-task.ev-future{border-left-color:#27ae60}
.cal-day-ev.ev-task.ev-today{border-left-color:#F2C94C}
.cal-day-ev.ev-task.ev-overdue{border-left-color:#e74c3c}
.cal-day-ev.ev-files{border-left-color:#bb6bd9}
.cal-day-ev.ev-gcal{border-left-color:#6ea4f2}
.cal-day-ev-type{font-size:7px;text-transform:uppercase;font-weight:700;color:var(--t3);letter-spacing:.6px;min-width:40px;font-family:'JetBrains Mono',monospace}
.cal-day-ev-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-day-empty{text-align:center;font-size:9px;color:var(--t3);font-style:italic;padding:28px 0;opacity:.6}
