*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--brand:#1e1b4b;--accent:#6366f1;--vendor:#0891b2;--urgent:#ef4444;--warn:#f59e0b;--ok:#22c55e;--purple:#7c3aed;--bg:#f1f5f9;--card:#fff;--text:#0f172a;--muted:#64748b;--border:#e2e8f0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg);overflow:hidden;height:100vh;display:flex;flex-direction:column}
.hdr{background:var(--brand);color:#fff;padding:12px 14px 0;flex-shrink:0;box-shadow:0 2px 12px rgba(0,0,0,.3)}
.hdr-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.hdr-logo{font-size:15px;font-weight:900}
.hdr-user{font-size:10px;background:rgba(255,255,255,.15);border-radius:100px;padding:4px 10px;display:flex;align-items:center;gap:6px}
.hdr-role{font-size:9px;font-weight:800;background:rgba(255,255,255,.2);border-radius:100px;padding:2px 6px}
.nav-tabs{display:flex;background:var(--brand);border-top:1px solid rgba(255,255,255,.1);overflow-x:auto;scrollbar-width:none}
.nav-tabs::-webkit-scrollbar{display:none}
.ntab{flex-shrink:0;padding:9px 10px;font-size:11px;font-weight:700;color:rgba(255,255,255,.5);border:none;background:none;cursor:pointer;border-bottom:3px solid transparent;font-family:inherit;white-space:nowrap}
.ntab.on{color:#fff;border-bottom-color:#6366f1}
.tbadge{border-radius:100px;padding:1px 5px;font-size:9px;font-weight:800;margin-left:3px;background:#ef4444;color:#fff}
.tbadge-w{background:#f59e0b}
.tbadge-b{background:#0891b2}
.app{flex:1;overflow:hidden;display:flex;flex-direction:column}
.panel{display:none;flex:1;overflow:hidden;flex-direction:column}
.panel.on{display:flex}
.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}
.subtabs{display:flex;gap:6px;padding:10px 14px 8px;overflow-x:auto;align-items:center;flex-shrink:0;scrollbar-width:none}
.subtabs::-webkit-scrollbar{display:none}
.stab{flex-shrink:0;padding:6px 12px;border-radius:100px;border:1.5px solid var(--border);background:var(--card);font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);font-family:inherit}
.stab.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.stab.on-r{background:var(--urgent);color:#fff;border-color:var(--urgent)}
.stab.on-v{background:var(--vendor);color:#fff;border-color:var(--vendor)}
.stab.on-w{background:var(--warn);color:#fff;border-color:var(--warn)}
.stab-n{background:rgba(255,255,255,.25);border-radius:100px;padding:1px 5px;font-size:10px}
.stab:not(.on):not(.on-r):not(.on-v):not(.on-w) .stab-n{background:var(--bg);color:var(--muted)}
.card{background:var(--card);border-radius:14px;padding:14px;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.lpad{padding:10px 14px;display:flex;flex-direction:column;gap:8px}
/* STAT CARDS */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:10px 14px 0}
.stat-card{background:var(--card);border-radius:14px;padding:14px;box-shadow:0 1px 4px rgba(0,0,0,.07);cursor:pointer;border-top:3px solid var(--border);position:relative}
.stat-val{font-size:26px;font-weight:900;line-height:1}
.stat-lbl{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-top:3px}
.stat-sub{font-size:10px;color:var(--muted);margin-top:2px}
.stat-arrow{position:absolute;top:12px;right:12px;font-size:16px;color:var(--border)}
/* PILLS */
.pill{display:inline-flex;align-items:center;gap:3px;border-radius:100px;padding:2px 8px;font-size:10px;font-weight:700;text-transform:uppercase;white-space:nowrap}
.pill::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.7;flex-shrink:0}
/* WO CARDS */
.wo-card{background:var(--card);border-radius:14px;padding:14px;border-left:4px solid var(--border);box-shadow:0 1px 4px rgba(0,0,0,.07);cursor:pointer}
/* PREOP */
.po-asset{background:var(--card);border-radius:14px;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.po-head{padding:14px;display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}
.po-body{display:none;border-top:1px solid var(--border)}
.po-body.open{display:block}
.po-section{padding:12px 14px;border-bottom:1px solid var(--border)}
.po-section:last-child{border-bottom:none}
.po-sec-t{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.check-item{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid #f8fafc}
.check-item:last-child{border-bottom:none}
.chkbox{width:24px;height:24px;border-radius:7px;border:2px solid var(--border);flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;background:#fff}
.chkbox.ok{background:var(--ok);border-color:var(--ok);color:#fff}
.chkbox.major{background:var(--urgent);border-color:var(--urgent);color:#fff}
.chkbox.minor{background:var(--warn);border-color:var(--warn);color:#fff}
.sev-badge{font-size:9px;font-weight:800;border-radius:4px;padding:2px 5px;display:inline-block;margin-top:2px}
.sev-major{background:#fee2e2;color:#991b1b}
.sev-minor{background:#fef3c7;color:#92400e}
.flag-btns{display:flex;gap:6px;margin-top:6px}
.fbtn{border-radius:6px;border:none;padding:4px 10px;font-size:11px;font-weight:700;cursor:pointer;font-family:inherit}
.fbtn-major{background:#fee2e2;color:#991b1b}
.fbtn-minor{background:#fef3c7;color:#92400e}
.flag-inp{width:100%;margin-top:6px;border:1.5px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12px;font-family:inherit;color:var(--text)}
.flag-inp.maj{border-color:var(--urgent)}
.flag-inp.min{border-color:var(--warn)}
.flag-inp:focus{outline:none}
.mfr-block{background:var(--bg);border-radius:10px;padding:12px 14px;margin:0 14px 14px;border:1.5px dashed var(--border)}
/* KART FLEET */
.kart-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:6px}
.kart-tile{background:var(--card);border-radius:10px;padding:10px 8px;box-shadow:0 1px 3px rgba(0,0,0,.07);border-top:3px solid var(--border);text-align:center;cursor:pointer}
.kart-tile.k-ok{border-top-color:var(--ok)}
.kart-tile.k-minor{border-top-color:var(--warn)}
.kart-tile.k-major{border-top-color:var(--urgent)}
.kart-tile.k-oos{border-top-color:#94a3b8;opacity:.6}
.kart-tile.k-svc{border-top-color:var(--purple)}
/* COMPLIANCE */
.comp-card{background:var(--card);border-radius:14px;padding:14px;box-shadow:0 1px 4px rgba(0,0,0,.07);border-left:4px solid var(--ok)}
.comp-card.warn-c{border-left-color:var(--warn)}
.comp-card.urgent-c{border-left-color:var(--urgent)}
.comp-card.overdue-c{border-left-color:var(--urgent);background:#fff5f5}
/* HANDOFF */
.ho-card{background:var(--card);border-radius:14px;padding:14px;box-shadow:0 1px 4px rgba(0,0,0,.07);border-left:4px solid var(--accent)}
/* CERT */
.cert-card{background:var(--card);border-radius:14px;padding:14px;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.cert-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border)}
.cert-row:last-child{border-bottom:none}
/* MODALS */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;align-items:flex-end;justify-content:center}
.overlay.on{display:flex}
.modal{background:#fff;border-radius:22px 22px 0 0;padding:22px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto}
.mt{font-size:16px;font-weight:800;margin-bottom:4px}
.mt-d{color:var(--urgent)}.mt-v{color:var(--vendor)}.mt-w{color:var(--warn)}
.ms{font-size:12px;color:var(--muted);margin-bottom:16px}
.mf{margin-bottom:12px}
.mf label{display:block;font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.mf input,.mf select,.mf textarea{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;font-size:15px;font-family:inherit;color:var(--text);background:#fff;-webkit-appearance:none}
.mf input:focus,.mf select:focus,.mf textarea:focus{outline:none;border-color:var(--accent)}
.mf textarea{resize:none;min-height:70px}
.mf2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mbtns{display:flex;gap:8px;margin-top:6px}
.mc{flex:1;background:var(--bg);border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;font-family:inherit}
.ms2{flex:2;background:var(--accent);border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit}
.mv{flex:2;background:var(--vendor);border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit}
.md{flex:2;background:var(--urgent);border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit}
.mw{flex:2;background:var(--warn);border:none;border-radius:10px;padding:13px;font-size:14px;font-weight:700;color:#fff;cursor:pointer;font-family:inherit}
.mdel{flex:1;background:#fee2e2;border:1.5px solid #fca5a5;border-radius:10px;padding:13px;font-size:14px;font-weight:700;color:var(--urgent);cursor:pointer;font-family:inherit}
.dsheet{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150;align-items:flex-end;justify-content:center}
.dsheet.on{display:flex}
.dbody{background:#fff;border-radius:22px 22px 0 0;padding:20px;width:100%;max-width:580px;max-height:87vh;overflow-y:auto;position:relative}
.dclose{position:absolute;top:18px;right:18px;background:var(--bg);border:none;border-radius:50%;width:30px;height:30px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted)}
.ds-sec{margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}
.ds-st{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.sbtns{display:flex;gap:6px;flex-wrap:wrap}
.sbtn{border-radius:9px;border:1.5px solid var(--border);background:var(--bg);color:var(--muted);padding:6px 12px;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit}
.sbtn.on{color:#fff;border-color:transparent}
.note-row{display:flex;gap:7px;margin-top:8px}
.note-inp{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:10px 12px;font-size:13px;font-family:inherit}
.note-inp:focus{outline:none;border-color:var(--accent)}
.note-item{font-size:12px;padding:5px 0;border-bottom:1px solid var(--border)}
.note-item::before{content:'> ';color:var(--muted)}
/* SCHEDULING */
.sched-tb{display:flex;gap:7px;align-items:center;padding:10px 14px;flex-wrap:wrap;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--card)}
.vtoggle{display:flex;background:var(--bg);border-radius:8px;padding:3px;border:1px solid var(--border)}
.vtbtn{padding:5px 13px;border-radius:6px;border:none;background:transparent;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;color:var(--muted)}
.vtbtn.on{background:var(--accent);color:#fff}
.nbtn{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:6px 10px;font-size:14px;cursor:pointer;font-family:inherit}
.sched-body{flex:1;display:flex;overflow:hidden;min-height:0}
.wo-sidebar{width:200px;flex-shrink:0;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.wos-head{padding:10px 12px;font-size:11px;font-weight:800;border-bottom:1px solid var(--border);flex-shrink:0}
.wos-scroll{flex:1;overflow-y:auto;padding:8px}
.sec-lbl{font-size:9px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;padding:3px 4px 5px}
.drag-wo{background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:8px 10px;margin-bottom:5px;cursor:grab;user-select:none}
.drag-wo.vt{border-left:3px solid var(--vendor);background:#f0f9ff;cursor:default}
.push-mini{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;border-radius:5px;padding:2px 7px;font-size:10px;font-weight:700;cursor:pointer;font-family:inherit}
.cal-wrap{flex:1;overflow:auto}
.cal-grid{display:flex;min-height:100%}
.hr-labels{width:44px;flex-shrink:0;padding-top:40px}
.hr-lbl{height:64px;display:flex;align-items:flex-start;justify-content:flex-end;padding-right:7px;padding-top:2px;font-size:9px;color:var(--muted);font-family:monospace}
.cal-cols{flex:1;display:flex;overflow-x:auto}
.cal-col{flex:1;min-width:110px;border-left:1px solid var(--border);position:relative;display:flex;flex-direction:column}
.col-head{height:40px;padding:6px 8px;display:flex;flex-direction:column;justify-content:center;position:sticky;top:0;background:var(--card);border-bottom:1px solid var(--border);z-index:5;cursor:pointer}
.col-head.td{background:#eff6ff}
.tslot{height:64px;border-top:1px solid #f1f5f9;position:relative}
.tslot.dt{background:#eff6ff;outline:2px dashed var(--accent)}
.sblock{position:absolute;left:3px;right:3px;border-radius:8px;padding:4px 7px;cursor:pointer;overflow:hidden;z-index:3;border:1.5px solid transparent;user-select:none}
.sblock.fl{border-color:var(--urgent)!important;background:#fee2e2!important}
.wl-row{display:flex;gap:8px;flex-wrap:wrap;padding:8px 14px 0;flex-shrink:0}
.wl-item{flex:1 1 100px;background:var(--card);border-radius:10px;padding:8px 12px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.wl-bar-bg{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:4px}
.wl-bar{height:100%;border-radius:2px}
.banner{border-radius:12px;padding:11px 14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:6px 14px 0;flex-shrink:0}
.banner-r{background:#fee2e2;border:1.5px solid #fca5a5}
.banner-w{background:#fff7ed;border:1.5px solid #fed7aa}
.banner-b{background:#cffafe;border:1.5px solid #67e8f9}
/* AI */
.ai-panel{position:fixed;right:0;top:0;bottom:0;width:320px;background:#fff;border-left:1px solid var(--border);display:flex;flex-direction:column;z-index:300;box-shadow:-4px 0 20px rgba(0,0,0,.1)}
.ai-head{padding:14px 16px 12px;background:var(--brand);display:flex;justify-content:space-between;align-items:center}
.ai-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 5px #22c55e}
.ai-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:9px}
.ai-msg{max-width:86%;font-size:12px;line-height:1.5;padding:9px 12px;border-radius:12px}
.ai-msg.u{align-self:flex-end;background:var(--accent);color:#fff;border-radius:12px 12px 2px 12px}
.ai-msg.b{align-self:flex-start;background:var(--bg);border-radius:12px 12px 12px 2px}
.ai-ir{padding:12px;border-top:1px solid var(--border);display:flex;gap:7px}
.ai-in{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:9px 12px;font-size:13px;font-family:inherit}
.ai-in:focus{outline:none;border-color:var(--accent)}
.ai-snd{background:var(--accent);border:none;color:#fff;border-radius:9px;padding:9px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit}
.ai-typing{display:flex;gap:4px;padding:8px 12px;background:var(--bg);border-radius:12px;width:fit-content}
.ai-dp{width:5px;height:5px;border-radius:50%;background:var(--muted);animation:aipulse 1s infinite}
.empty{text-align:center;padding:40px 20px;color:var(--muted)}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--vendor);border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:5px}
.fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:var(--accent);border:none;color:#fff;font-size:22px;cursor:pointer;box-shadow:0 4px 16px rgba(99,102,241,.4);z-index:90;display:flex;align-items:center;justify-content:center;font-family:inherit}
.dtbl{width:100%;border-collapse:collapse;font-size:12px}
.dtbl th{text-align:left;padding:8px 12px;font-size:9px;color:var(--muted);font-weight:800;text-transform:uppercase;background:var(--bg);border-bottom:1.5px solid var(--border)}
.dtbl td{padding:9px 12px;border-bottom:1px solid var(--border)}
.dtbl tr:last-child td{border-bottom:none}
.qty-btn{background:var(--bg);border:1px solid var(--border);border-radius:6px;width:26px;height:26px;cursor:pointer;font-size:14px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;font-family:inherit}
@keyframes aipulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1)}}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:500px){.mf2{grid-template-columns:1fr}.wo-sidebar{display:none}.ai-panel{width:100%}}
.insp-section-body.collapsed{display:none!important}
