*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#f4f4f5;--s:#fff;--sh:#fafafa;--b:#e4e4e7;--bl:#f0f0f0;--t1:#2d5f8a;--t2:#52525b;--t3:#a1a1aa;--green:#22c55e;--gs:#f0fdf4;--red:#ef4444;--rs:#fef2f2;--amber:#f59e0b;--as:#fffbeb;--blue:#3b82f6;--bs:#eff6ff;--violet:#2563eb;--r:10px;--rs:8px;--sh1:0 1px 3px rgba(0,0,0,.05);--sh2:0 4px 12px rgba(0,0,0,.08);--f:'Geist',system-ui,sans-serif;--m:'Geist Mono',monospace;--sw:240px}
html{font-size:14px}body{font-family:var(--f);background:var(--bg);color:var(--t1);-webkit-font-smoothing:antialiased}

/* DARK MODE */
body.dark{--bg:#142d54;--s:#2d5f8a;--sh:#1f4068;--b:#3a6090;--bl:#1f4068;--t1:#fafafa;--t2:#a1a1aa;--t3:#71717a}
body.dark .login-screen{background:#142d54}body.dark .login-box{background:#2d5f8a;border-color:#3a6090}
body.dark .login-field{background:#142d54;border-color:#3a6090}body.dark .login-field input{color:#fafafa}
body.dark .login-btn{background:#fafafa;color:#2d5f8a}

/* LOGIN — EPIC ANIMATED */
.login-screen{position:fixed;inset:0;z-index:1000;background:#0b1628;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:opacity .5s,transform .5s}
.login-screen.hide{opacity:0;transform:scale(1.05);pointer-events:none}
.login-bg{position:absolute;inset:0;overflow:hidden}
.login-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(45,95,138,.1) 1px,transparent 1px),linear-gradient(90deg,rgba(45,95,138,.1) 1px,transparent 1px);background-size:40px 40px;animation:gridMove 20s linear infinite}
@keyframes gridMove{from{transform:translate(0,0)}to{transform:translate(40px,40px)}}
.login-glow{position:absolute;border-radius:50%;filter:blur(80px);animation:orbFloat 8s ease-in-out infinite}
.login-glow.g1{width:400px;height:400px;background:rgba(45,95,138,.25);top:-10%;left:20%}
.login-glow.g2{width:300px;height:300px;background:rgba(37,99,235,.2);bottom:-5%;right:10%;animation-delay:3s;animation-duration:10s}
@keyframes orbFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.08)}}
.login-particles{position:absolute;inset:0}.login-particle{position:absolute;width:3px;height:3px;border-radius:50%;background:rgba(45,95,138,.5);animation:particleFloat linear infinite}
@keyframes particleFloat{0%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-10vh) rotate(720deg);opacity:0}}
.login-ring{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.login-ring svg{animation:ringRotate 30s linear infinite;opacity:.07}
@keyframes ringRotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.login-box{position:relative;width:400px;background:rgba(255,255,255,.97);border:1px solid rgba(45,95,138,.15);border-radius:20px;padding:44px 40px;box-shadow:0 24px 80px rgba(0,0,0,.3),0 0 40px rgba(37,99,235,.05);animation:loginBoxIn .7s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(20px)}
@keyframes loginBoxIn{from{opacity:0;transform:translateY(30px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}
body.dark .login-box{background:rgba(15,27,50,.95);border-color:rgba(45,95,138,.2)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo-icon{width:60px;height:60px;margin:0 auto 16px;background:linear-gradient(135deg,#2d5f8a,#2563eb);color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 8px 24px rgba(37,99,235,.3);animation:iconGlow 3s ease-in-out infinite;position:relative}
.login-logo-icon::after{content:'';position:absolute;inset:-4px;border-radius:20px;border:2px solid rgba(37,99,235,.2);animation:iconRing 3s ease-in-out infinite}
@keyframes iconGlow{0%,100%{box-shadow:0 8px 24px rgba(37,99,235,.3)}50%{box-shadow:0 8px 36px rgba(37,99,235,.5)}}
@keyframes iconRing{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.15);opacity:0}}
.login-logo h1{font-size:22px;font-weight:700;letter-spacing:-.5px;color:#1a1a2e}
body.dark .login-logo h1{color:#fafafa}
.login-logo p{font-size:13px;color:#6b7280;margin-top:5px}
.login-status{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;font-size:11px;color:#6b7280;font-family:var(--m)}
.login-status-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:statusBlink 2s ease infinite}
@keyframes statusBlink{0%,100%{opacity:1}50%{opacity:.3}}
.login-field{display:flex;align-items:center;gap:10px;background:#f4f6f9;border:1.5px solid #e5e7eb;border-radius:10px;padding:0 14px;margin-bottom:12px;transition:all .25s}
.login-field:focus-within{border-color:#2563eb;background:#fff;box-shadow:0 0 0 4px rgba(37,99,235,.08)}
body.dark .login-field{background:rgba(10,20,40,.5);border-color:rgba(45,95,138,.3)}
body.dark .login-field:focus-within{background:rgba(10,20,40,.7);border-color:#2563eb}
.login-field i{font-size:18px;color:#9ca3af;transition:color .2s}.login-field:focus-within i{color:#2563eb}
.login-field input{flex:1;border:0;background:0;font-family:var(--f);font-size:14px;padding:13px 0;outline:0;color:#1a1a2e}
body.dark .login-field input{color:#fafafa}
.login-opts{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;font-size:12px}
.login-remember{display:flex;align-items:center;gap:6px;color:#6b7280;cursor:pointer}.login-forgot{color:#2563eb;text-decoration:none;font-weight:500;transition:opacity .2s}.login-forgot:hover{opacity:.7}
.login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border:0;border-radius:10px;background:linear-gradient(135deg,#2d5f8a,#2563eb);color:#fff;font-family:var(--f);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(37,99,235,.3);position:relative;overflow:hidden}
.login-btn:hover{box-shadow:0 6px 28px rgba(37,99,235,.4);transform:translateY(-1px)}.login-btn:active{transform:translateY(0) scale(.98)}
.login-btn::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .5s}.login-btn:hover::after{left:100%}
.login-demo{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:18px;font-size:12px;color:#6b7280}
.login-demo button{font-family:var(--f);font-size:11px;font-weight:600;padding:5px 12px;border-radius:6px;border:1.5px solid #e5e7eb;background:#fff;color:#4b5563;cursor:pointer;transition:all .2s}
.login-demo button:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff;transform:translateY(-1px)}
body.dark .login-demo button{background:rgba(10,20,40,.5);border-color:rgba(45,95,138,.3);color:#9ca3af}
.login-footer{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:28px;font-size:11px;color:#9ca3af}

/* LAYOUT */
.app-wrap{display:flex;min-height:100vh}
.sidebar{width:var(--sw);background:var(--s);border-right:1px solid var(--b);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:60;transition:transform .25s}
.sb-head{padding:16px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--bl)}
.sb-logo{width:32px;height:32px;background:var(--t1);border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--s);font-size:17px}
.sb-brand{font-weight:700;font-size:14px;letter-spacing:-.3px;line-height:1.1}.sb-brand small{display:block;font-size:11px;font-weight:400;color:var(--t3);margin-top:1px}
.sb-nav{flex:1;padding:12px 10px;overflow-y:auto}
.sb-section{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;padding:8px 10px 6px;margin-top:8px}.sb-section:first-child{margin-top:0}
.sb-item{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:var(--rs);font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;transition:all .15s;user-select:none;position:relative}
.sb-item:hover{background:var(--bg);color:var(--t1)}.sb-item.active{background:var(--t1);color:#fff}.sb-item.active i{color:#fff}.sb-item i{font-size:18px;color:var(--t3);width:20px;text-align:center;transition:color .15s}.sb-item:hover i{color:var(--t1)}
.sb-badge{margin-left:auto;font-family:var(--m);font-size:10px;font-weight:600;background:var(--red);color:#fff;padding:1px 6px;border-radius:4px;min-width:18px;text-align:center}.sb-item.active .sb-badge{background:rgba(255,255,255,.25)}
.sb-user{padding:12px 14px;border-top:1px solid var(--bl);display:flex;align-items:center;gap:10px}
.sb-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.sb-uinfo{flex:1;min-width:0}.sb-uname{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-urole{font-size:11px;color:var(--t3)}
.sb-logout{font-size:18px;color:var(--t3);cursor:pointer;padding:4px;border-radius:4px;transition:all .15s}.sb-logout:hover{color:var(--red);background:var(--rs)}

.main{margin-left:var(--sw);flex:1;min-width:0}
.topbar{height:52px;background:var(--s);border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:40}
.topbar-left{display:flex;align-items:center;gap:10px}.breadcrumb{font-size:13px;color:var(--t3)}.breadcrumb span{color:var(--t1);font-weight:600}
.topbar-right{display:flex;align-items:center;gap:6px}
.topbar-time{font-family:var(--m);font-size:12px;color:var(--t3);margin-right:8px}
.top-btn{width:34px;height:34px;border:1px solid var(--b);border-radius:var(--rs);background:var(--s);color:var(--t3);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:all .15s}.top-btn:hover{border-color:var(--t3);color:var(--t1)}
.top-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--red);border:2px solid var(--s)}
.top-user{cursor:pointer}.top-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.content{padding:20px 24px 48px}
.page{display:none}.page.vis{display:block}

/* KPI */
.kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px}
.kpi{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:16px 18px;box-shadow:var(--sh1);transition:all .2s}.kpi:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.kpi-label{font-size:12px;color:var(--t3);font-weight:500;display:flex;align-items:center;gap:6px}.kpi-label i{font-size:14px}
.kpi-val{font-family:var(--m);font-size:26px;font-weight:600;letter-spacing:-.5px;line-height:1.3}.kpi-sub{font-size:11px;color:var(--t3)}
.kpi.danger{background:var(--rs);border-color:#fecaca}.kpi.danger .kpi-val{color:var(--red)}.kpi.warn{background:var(--as);border-color:#fde68a}.kpi.warn .kpi-val{color:var(--amber)}

/* GRID */
.row{display:grid;gap:16px;margin-bottom:16px}.r21{grid-template-columns:2.1fr 1fr}.r11{grid-template-columns:1fr 1fr}.r1{grid-template-columns:1fr}.r31{grid-template-columns:1fr 1fr 1fr}
.card{background:var(--s);border:1px solid var(--b);border-radius:var(--r);box-shadow:var(--sh1);overflow:hidden;transition:box-shadow .2s}.card:hover{box-shadow:var(--sh2)}
.card-h{display:flex;align-items:center;justify-content:space-between;padding:13px 18px;border-bottom:1px solid var(--bl)}
.card-t{font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px}.card-t i{font-size:17px;color:var(--t3)}
.card-badge{font-family:var(--m);font-size:11px;font-weight:500;background:var(--bg);border:1px solid var(--b);border-radius:5px;padding:2px 8px;color:var(--t3)}
.card-b{padding:14px 18px}.card-b.flush{padding:0}

/* TABLE */
.tbl{width:100%;border-collapse:collapse}
.tbl th{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;padding:10px 16px;text-align:left;background:var(--bg);border-bottom:1px solid var(--b)}
.tbl td{padding:10px 16px;font-size:13px;border-bottom:1px solid var(--bl);vertical-align:middle}.tbl tr:last-child td{border-bottom:none}
.tbl tr{transition:background .12s;cursor:pointer}.tbl tr:hover{background:var(--sh)}
.eq-p{font-weight:600;line-height:1.25}.eq-s{font-family:var(--m);font-size:11px;color:var(--t3)}
.pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px;background:var(--bg);border:1px solid var(--b);color:var(--t2)}.pill i{font-size:13px}
.health{display:flex;align-items:center;gap:8px}.health-bar{flex:1;height:5px;background:var(--bl);border-radius:3px;overflow:hidden}.health-fill{height:100%;border-radius:3px;transition:width .7s ease}.health-num{font-family:var(--m);font-size:12px;font-weight:600;min-width:28px;text-align:right}
.status{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px}.status::before{content:'';width:5px;height:5px;border-radius:50%}
.s-run{background:var(--gs);color:#16a34a}.s-run::before{background:#16a34a}.s-idle{background:var(--bg);color:var(--t3);border:1px solid var(--b)}.s-idle::before{background:var(--t3)}.s-maint{background:var(--as);color:#d97706}.s-maint::before{background:#d97706}.s-fault{background:var(--rs);color:var(--red)}.s-fault::before{background:var(--red);animation:pls 1.2s infinite}
@keyframes pls{0%,100%{opacity:1}50%{opacity:.35}}
.rul-v{font-family:var(--m);font-size:12px;font-weight:500}.rul-d{color:var(--red);font-weight:600}.rul-w{color:var(--amber)}.rul-o{color:var(--t3)}
.abadge{font-family:var(--m);font-size:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:5px}.abadge.on{background:var(--red);color:#fff}.abadge.off{color:var(--t3)}

/* ALARM/WO ROWS */
.al-row{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--bl);transition:background .12s}.al-row:last-child{border-bottom:none}.al-row:hover{background:var(--sh)}
.al-ic{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.al-ic.emergency{background:var(--rs);color:var(--red)}.al-ic.critical{background:var(--as);color:var(--amber)}.al-ic.warning{background:var(--as);color:#d97706}.al-ic.info{background:var(--bs);color:var(--blue)}
.al-body{flex:1;min-width:0}.al-body .at{font-size:13px;font-weight:600;line-height:1.3}.al-body .ad{font-size:12px;color:var(--t3);margin-top:1px}.al-ts{font-family:var(--m);font-size:11px;color:var(--t3);flex-shrink:0;padding-top:2px}
.wo-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--bl);transition:background .12s}.wo-row:last-child{border-bottom:none}.wo-row:hover{background:var(--sh)}
.wo-ic{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.wo-ic.urgent{background:var(--rs);color:var(--red)}.wo-ic.high{background:var(--as);color:var(--amber)}.wo-ic.medium{background:var(--bs);color:var(--blue)}.wo-ic.low{background:var(--bg);color:var(--t3)}
.wo-body{flex:1}.wo-body .wt{font-size:13px;font-weight:600}.wo-body .wm{font-size:12px;color:var(--t3)}.wo-dt{font-family:var(--m);font-size:11px;color:var(--t3)}

/* RUL */
.rul-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.rul-item{padding:14px;border:1px solid var(--b);border-radius:var(--rs);display:flex;align-items:center;gap:12px;transition:all .2s;cursor:pointer}.rul-item:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.rul-ring{position:relative;width:52px;height:52px;flex-shrink:0}.rul-ring svg{transform:rotate(-90deg)}.rul-ring .rb{stroke:var(--bl);fill:none;stroke-width:4.5}.rul-ring .rf{fill:none;stroke-width:4.5;stroke-linecap:round;transition:stroke-dashoffset 1s ease}
.rul-ring .rn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--m);font-size:14px;font-weight:600}
.rul-info .rc{font-family:var(--m);font-size:11px;color:var(--t3)}.rul-info .rd{font-size:13px;font-weight:600}.rul-info .rl{font-size:11px;color:var(--t3)}
.ch{height:260px;position:relative}.ch-s{height:200px;position:relative}.ch-l{height:320px;position:relative}

/* DETAIL */
.detail-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:16px}
.dh-left{display:flex;align-items:center;gap:14px}
.dh-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;border:1px solid var(--b);background:var(--s);color:var(--t2)}
.dh-info h2{font-size:18px;font-weight:700;letter-spacing:-.3px}.dh-meta{display:flex;align-items:center;gap:12px;margin-top:4px}.dh-meta span{font-size:12px;color:var(--t3);display:flex;align-items:center;gap:4px}.dh-meta span i{font-size:14px}
.sensor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.sensor-card{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:14px 16px;box-shadow:var(--sh1);transition:all .2s}.sensor-card:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.sc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sc-name{font-size:12px;font-weight:500;color:var(--t3);display:flex;align-items:center;gap:5px}.sc-name i{font-size:14px}
.sc-status{width:6px;height:6px;border-radius:50%}.sc-status.ok{background:var(--green)}.sc-status.warn{background:var(--amber)}.sc-status.crit{background:var(--red);animation:pls 1s infinite}
.sc-val{font-family:var(--m);font-size:24px;font-weight:600;line-height:1}.sc-unit{font-size:12px;color:var(--t3);font-weight:400;margin-left:2px}
.sc-bar{height:3px;background:var(--bl);border-radius:2px;margin-top:10px;overflow:hidden}.sc-bar-fill{height:100%;border-radius:2px;transition:width .5s ease}
.sc-range{display:flex;justify-content:space-between;font-family:var(--m);font-size:9px;color:var(--t3);margin-top:3px}
.sensor-card.alert{border-color:#fecaca;background:var(--rs)}.sensor-card.warn-st{border-color:#fde68a;background:var(--as)}
.sc-spark{height:32px;margin-top:8px}

/* ALARM FILTER + STATUS */
.al-filter{font-family:var(--f);font-size:11px;font-weight:600;padding:5px 12px;border-radius:6px;border:1px solid var(--b);background:var(--s);color:var(--t2);cursor:pointer;transition:all .15s}
.al-filter:hover{border-color:var(--t3)}.al-filter.active{background:#2d5f8a;color:#fff;border-color:var(--t1)}
.al-status{font-size:11px;font-weight:600;padding:3px 9px;border-radius:5px;display:inline-block}
.al-status.active{background:var(--rs);color:var(--red)}.al-status.acknowledged{background:var(--as);color:var(--amber)}.al-status.resolved{background:var(--gs);color:var(--green)}
.act-btn{font-family:var(--f);font-size:11px;font-weight:600;padding:4px 10px;border-radius:5px;border:1px solid var(--b);background:var(--s);color:var(--t2);cursor:pointer;transition:all .15s}
.act-btn:hover{border-color:var(--t3)}.act-btn.green{background:var(--gs);color:var(--green);border-color:var(--green)}.act-btn.blue{background:var(--bs);color:var(--blue);border-color:var(--blue)}

/* MODAL */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:200;display:flex;align-items:center;justify-content:center;animation:fi .2s;backdrop-filter:blur(4px)}
@keyframes fi{from{opacity:0}to{opacity:1}}
.modal-box{background:var(--s);border-radius:12px;box-shadow:0 20px 60px rgba(0,0,0,.15);width:90%;max-width:480px;max-height:85vh;overflow-y:auto;animation:modalIn .25s ease}
@keyframes modalIn{from{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--b);font-size:15px;font-weight:700}
.modal-body{padding:20px}

/* FORM */
.form-group{margin-bottom:14px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--t2);margin-bottom:5px}
.f-input{width:100%;font-family:var(--f);font-size:13px;padding:8px 12px;border:1px solid var(--b);border-radius:var(--rs);background:var(--bg);color:var(--t1);outline:none;transition:border .2s}.f-input:focus{border-color:var(--blue)}
textarea.f-input{resize:vertical;min-height:60px}
.tb-btn{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--t2);padding:6px 12px;border-radius:6px;border:1px solid var(--b);background:var(--s);cursor:pointer;transition:all .15s;font-family:var(--f)}
.tb-btn:hover{border-color:var(--t3)}.tb-btn i{font-size:15px}.tb-btn.primary{background:#2d5f8a;color:#fff;border-color:var(--t1)}.tb-btn.primary:hover{opacity:.9}

/* TOGGLE */
.toggle{position:relative;display:inline-block;width:36px;height:20px;cursor:pointer}.toggle input{opacity:0;width:0;height:0}
.tog-track{position:absolute;top:0;left:0;right:0;bottom:0;background:var(--b);border-radius:10px;transition:.25s}
.tog-track::before{content:'';position:absolute;width:16px;height:16px;left:2px;top:2px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.toggle input:checked+.tog-track{background:var(--green)}.toggle input:checked+.tog-track::before{transform:translateX(16px)}
.setting-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--bl);font-size:13px}.setting-row span{display:flex;align-items:center;gap:8px}.setting-row span i{font-size:16px;color:var(--t3)}
.sys-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--bl);font-size:13px;color:var(--t2)}.sys-row:last-child{border-bottom:none}.sys-val{font-family:var(--m);font-size:12px;font-weight:500}

/* CALENDAR */
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-header{font-size:11px;font-weight:600;color:var(--t3);text-align:center;padding:8px 4px;text-transform:uppercase}
.cal-day{min-height:72px;padding:6px;border:1px solid var(--bl);border-radius:4px;font-family:var(--m);font-size:11px;background:var(--s);transition:background .12s}.cal-day:hover{background:var(--sh)}.cal-day.other{opacity:.35}.cal-day.today{border-color:var(--blue);background:var(--bs)}.cal-day .cd-num{font-weight:600;margin-bottom:4px;color:var(--t2)}
.cal-event{font-size:9px;font-weight:600;padding:2px 4px;border-radius:3px;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-event.urgent{background:var(--rs);color:var(--red)}.cal-event.high{background:var(--as);color:var(--amber)}.cal-event.medium{background:var(--bs);color:var(--blue)}.cal-event.low{background:var(--bg);color:var(--t3)}
.wo-view-btn.active{background:var(--t1);color:#fff;border-color:var(--t1)}

/* THRESHOLD */
.th-profile{border:1px solid var(--b);border-radius:var(--rs);padding:14px;margin-bottom:10px;transition:box-shadow .2s}.th-profile:hover{box-shadow:var(--sh2)}
.th-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.th-name{font-size:13px;font-weight:700}.th-type{font-size:11px;color:var(--t3)}
.th-row{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:6px}.th-label{width:100px;color:var(--t3);font-weight:500}.th-bar{flex:1;height:8px;background:var(--bl);border-radius:4px;position:relative;overflow:hidden}.th-zone{position:absolute;height:100%;border-radius:4px}

/* SIM */
.sim-panel{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:20px;margin-bottom:16px;box-shadow:var(--sh1)}
.sim-controls{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.sim-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 16px;border-radius:var(--rs);font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--b);background:var(--s);color:var(--t1);transition:all .15s;font-family:var(--f)}.sim-btn:hover{background:var(--sh)}.sim-btn.running{background:var(--green);color:#fff;border-color:var(--green)}.sim-btn i{font-size:16px}
.sim-log{margin-top:14px;background:#1a3660;border-radius:var(--rs);padding:14px;font-family:var(--m);font-size:11px;color:#a1a1aa;max-height:280px;overflow-y:auto;line-height:1.7}
.sim-log .log-ok{color:var(--green)}.sim-log .log-warn{color:var(--amber)}.sim-log .log-err{color:var(--red)}.sim-log .log-ts{color:#555}

/* DEVICE CARD */
.dev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.dev-card{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:18px;box-shadow:var(--sh1);transition:all .2s;cursor:pointer}.dev-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.dev-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.dev-chip{width:36px;height:36px;border-radius:8px;background:var(--bs);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:18px}
.dev-chip.online{background:var(--gs);color:var(--green)}.dev-chip.offline{background:var(--rs);color:var(--red)}
.dev-name{font-weight:600;font-size:13px}.dev-mac{font-family:var(--m);font-size:10px;color:var(--t3)}
.dev-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}
.dev-stat{padding:8px;background:var(--bg);border-radius:6px}.dev-stat-label{font-size:10px;color:var(--t3)}.dev-stat-val{font-family:var(--m);font-size:14px;font-weight:600}

/* REPORT */
.rpt-card{border:1px solid var(--b);border-radius:var(--r);padding:18px;background:var(--s);display:flex;align-items:center;gap:14px;margin-bottom:10px;cursor:pointer;transition:all .2s;box-shadow:var(--sh1)}.rpt-card:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.rpt-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rpt-icon.pdf{background:var(--rs);color:var(--red)}.rpt-icon.xls{background:var(--gs);color:var(--green)}.rpt-icon.csv{background:var(--bs);color:var(--blue)}
.rpt-body{flex:1}.rpt-title{font-weight:600;font-size:13px}.rpt-desc{font-size:12px;color:var(--t3);margin-top:2px}
.rpt-action{font-family:var(--f);font-size:11px;font-weight:600;padding:5px 12px;border-radius:6px;border:1px solid var(--b);background:var(--s);color:var(--t2);cursor:pointer;transition:all .15s}.rpt-action:hover{border-color:var(--blue);color:var(--blue)}

/* TOAST */
.toast-container{position:fixed;top:60px;right:20px;z-index:999;display:flex;flex-direction:column;gap:8px;max-width:360px}
.toast{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:var(--r);background:var(--s);border:1px solid var(--b);box-shadow:0 8px 24px rgba(0,0,0,.12);animation:ti .3s;font-size:13px;transition:opacity .3s,transform .3s}
.toast.removing{opacity:0;transform:translateX(40px)}.toast .t-icon{font-size:18px;flex-shrink:0}.toast .t-icon.critical,.toast .t-icon.emergency{color:var(--red)}.toast .t-icon.warning{color:var(--amber)}.toast .t-icon.info{color:var(--blue)}
.toast .t-body{flex:1}.toast .t-title{font-weight:600}.toast .t-msg{font-size:12px;color:var(--t3);margin-top:2px}
.toast .t-close{cursor:pointer;color:var(--t3);font-size:16px;flex-shrink:0}.toast .t-close:hover{color:var(--t1)}
@keyframes ti{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}

/* ROLE BADGE */
.role-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;display:inline-block}
.role-badge.admin{background:var(--rs);color:var(--red)}.role-badge.tech{background:var(--bs);color:var(--blue)}.role-badge.viewer{background:var(--bg);color:var(--t3)}

/* RESPONSIVE */
.sb-toggle{display:none;cursor:pointer;font-size:20px;color:var(--t2)}
@media(max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0);box-shadow:0 0 40px rgba(0,0,0,.15)}.main{margin-left:0}.sb-toggle{display:block}.kpi-row{grid-template-columns:repeat(3,1fr)}.sensor-grid,.dev-grid{grid-template-columns:repeat(2,1fr)}.rul-grid{grid-template-columns:repeat(2,1fr)}.r21,.r11,.r31{grid-template-columns:1fr}}
@media(max-width:640px){.kpi-row{grid-template-columns:repeat(2,1fr)}.sensor-grid,.dev-grid{grid-template-columns:1fr 1fr}}

/* ═══════ FACTORY FLOOR MAP ═══════ */
.floor-container{position:relative;background:var(--s);border:1px solid var(--b);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh1)}
.floor-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--bl)}
.floor-canvas{position:relative;width:100%;height:520px;background:var(--bg);overflow:hidden}
.floor-grid{position:absolute;inset:0;background-image:linear-gradient(var(--bl) 1px,transparent 1px),linear-gradient(90deg,var(--bl) 1px,transparent 1px);background-size:40px 40px;opacity:.6}
.floor-zone{position:absolute;border:2px dashed var(--b);border-radius:12px;padding:8px;display:flex;flex-direction:column}
.floor-zone-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--t3);padding:2px 8px;background:var(--s);border-radius:4px;align-self:flex-start;border:1px solid var(--bl)}
.floor-eq{position:absolute;cursor:pointer;transition:all .2s;z-index:5}
.floor-eq:hover{transform:scale(1.08);z-index:10}
.floor-eq-box{width:72px;height:72px;border-radius:12px;border:2px solid var(--b);background:var(--s);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;box-shadow:var(--sh1);position:relative;transition:all .3s}
.floor-eq-box.running{border-color:var(--green);box-shadow:0 0 0 3px rgba(34,197,94,.1)}.floor-eq-box.fault{border-color:var(--red);box-shadow:0 0 0 3px rgba(239,68,68,.15);animation:faultPulse 2s infinite}
.floor-eq-box.maintenance{border-color:var(--amber);box-shadow:0 0 0 3px rgba(245,158,11,.1)}.floor-eq-box.idle{border-color:var(--b);opacity:.7}
@keyframes faultPulse{0%,100%{box-shadow:0 0 0 3px rgba(239,68,68,.15)}50%{box-shadow:0 0 0 6px rgba(239,68,68,.25)}}
.floor-eq-box i{font-size:22px}.floor-eq-box.running i{color:var(--green)}.floor-eq-box.fault i{color:var(--red)}.floor-eq-box.maintenance i{color:var(--amber)}.floor-eq-box.idle i{color:var(--t3)}
.floor-eq-label{font-size:9px;font-weight:600;color:var(--t2);text-align:center;white-space:nowrap}
.floor-eq-name{position:absolute;bottom:-18px;left:50%;transform:translateX(-50%);font-size:9px;font-weight:600;color:var(--t2);white-space:nowrap;background:var(--s);padding:1px 6px;border-radius:3px;border:1px solid var(--bl)}
.floor-eq-health{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;font-family:var(--m);font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid var(--s)}
.floor-eq-alarm{position:absolute;top:-6px;left:-6px;width:18px;height:18px;border-radius:50%;background:var(--red);color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid var(--s);animation:pls 1.2s infinite}
.floor-tooltip{position:absolute;z-index:100;background:var(--s);border:1px solid var(--b);border-radius:var(--rs);padding:12px 14px;box-shadow:0 8px 24px rgba(0,0,0,.12);font-size:12px;min-width:200px;pointer-events:none;opacity:0;transition:opacity .15s}
.floor-tooltip.show{opacity:1;pointer-events:auto}
.floor-legend{display:flex;align-items:center;gap:16px;padding:12px 18px;border-top:1px solid var(--bl);font-size:11px;color:var(--t3)}
.floor-legend-item{display:flex;align-items:center;gap:5px}.floor-legend-dot{width:8px;height:8px;border-radius:50%}

/* CONVEYOR BELT ANIMATION */
.floor-conveyor{position:absolute;height:6px;background:repeating-linear-gradient(90deg,var(--t3) 0,var(--t3) 8px,transparent 8px,transparent 16px);border-radius:3px;opacity:.25;animation:conveyorMove 2s linear infinite}
@keyframes conveyorMove{from{background-position:0 0}to{background-position:16px 0}}
.floor-pipe{position:absolute;background:var(--b);border-radius:3px;opacity:.4}

/* ═══════ NOTIFICATION PANEL ═══════ */
.notif-panel{position:absolute;top:44px;right:50px;width:360px;max-height:440px;background:var(--s);border:1px solid var(--b);border-radius:var(--r);box-shadow:0 12px 40px rgba(0,0,0,.12);z-index:100;display:none;overflow:hidden;animation:fi .2s}
.notif-panel.show{display:block}
.notif-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--bl);font-size:13px;font-weight:700}
.notif-clear{font-size:11px;font-weight:500;color:var(--blue);cursor:pointer;background:0;border:0;font-family:var(--f)}
.notif-list{max-height:360px;overflow-y:auto}
.notif-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-bottom:1px solid var(--bl);cursor:pointer;transition:background .12s}.notif-item:hover{background:var(--sh)}.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:var(--bs)}
.notif-ic{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.notif-body{flex:1;min-width:0}.notif-title{font-size:12px;font-weight:600;line-height:1.3}.notif-desc{font-size:11px;color:var(--t3);margin-top:2px}.notif-time{font-family:var(--m);font-size:10px;color:var(--t3);margin-top:3px}
.notif-empty{text-align:center;padding:30px;color:var(--t3);font-size:13px}

/* ═══════ ANIMATED KPI ═══════ */
.kpi-spark{height:28px;margin-top:6px}
.kpi-trend{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;margin-top:2px}
.kpi-trend.up{color:var(--green)}.kpi-trend.down{color:var(--red)}.kpi-trend.flat{color:var(--t3)}
@keyframes countUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.kpi-val{animation:countUp .4s ease}

/* ═══════ LIVE GAUGES ═══════ */
.gauge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}
.gauge-card{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:20px;box-shadow:var(--sh1);text-align:center;transition:all .2s}.gauge-card:hover{box-shadow:var(--sh2);transform:translateY(-2px)}
.gauge-card-title{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.gauge-card-eq{font-size:13px;font-weight:700;margin-bottom:12px}
.gauge-svg{display:block;margin:0 auto}
.gauge-val{font-family:var(--m);font-size:28px;font-weight:700;margin-top:8px;line-height:1}
.gauge-unit{font-size:12px;color:var(--t3);font-weight:400}
.gauge-range{display:flex;justify-content:space-between;font-family:var(--m);font-size:9px;color:var(--t3);margin-top:6px;padding:0 8px}
.gauge-status{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;margin-top:8px;padding:2px 8px;border-radius:4px}
.gauge-status.ok{background:var(--gs);color:var(--green)}.gauge-status.warn{background:var(--as);color:var(--amber)}.gauge-status.crit{background:var(--rs);color:var(--red)}

/* Needle animation */
.gauge-needle{transition:transform .8s cubic-bezier(.4,2,.55,.7);transform-origin:50% 85%}
.gauge-arc{transition:stroke-dashoffset .8s ease}

/* Big center gauge */
.big-gauge{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:24px;box-shadow:var(--sh1);text-align:center}
.big-gauge-title{font-size:14px;font-weight:700;margin-bottom:16px}

/* ═══════ AI ASSISTANT ═══════ */
.ai-container{display:grid;grid-template-columns:1fr 340px;gap:16px;height:calc(100vh - 120px)}
.ai-chat{background:var(--s);border:1px solid var(--b);border-radius:var(--r);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--sh1)}
.ai-chat-head{padding:14px 18px;border-bottom:1px solid var(--bl);display:flex;align-items:center;gap:10px}
.ai-chat-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}
.ai-chat-info{flex:1}.ai-chat-name{font-size:14px;font-weight:700}.ai-chat-status{font-size:11px;color:var(--green);display:flex;align-items:center;gap:4px}
.ai-chat-status::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--green)}
.ai-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.ai-msg{max-width:85%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.5;animation:msgIn .3s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ai-msg.bot{background:var(--bg);border:1px solid var(--bl);align-self:flex-start;border-bottom-left-radius:4px}
.ai-msg.user{background:var(--t1);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ai-msg .msg-label{font-size:10px;font-weight:600;color:var(--t3);margin-bottom:4px}.ai-msg.user .msg-label{color:rgba(255,255,255,.5)}
.ai-typing{display:flex;gap:4px;padding:8px 12px;align-self:flex-start}
.ai-typing span{width:6px;height:6px;border-radius:50%;background:var(--t3);animation:typeDot 1.4s infinite}
.ai-typing span:nth-child(2){animation-delay:.2s}.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes typeDot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}
.ai-input-bar{display:flex;gap:8px;padding:14px 16px;border-top:1px solid var(--bl);background:var(--s)}
.ai-input{flex:1;font-family:var(--f);font-size:13px;padding:10px 14px;border:1px solid var(--b);border-radius:var(--rs);background:var(--bg);color:var(--t1);outline:none;transition:border .2s}.ai-input:focus{border-color:var(--blue)}
.ai-send{width:38px;height:38px;border-radius:var(--rs);border:0;background:var(--t1);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:17px;transition:opacity .15s}.ai-send:hover{opacity:.85}
.ai-sidebar{display:flex;flex-direction:column;gap:12px}
.ai-quick{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:16px;box-shadow:var(--sh1)}
.ai-quick-title{font-size:12px;font-weight:700;margin-bottom:10px;color:var(--t2)}
.ai-quick-btn{display:block;width:100%;text-align:left;font-family:var(--f);font-size:12px;padding:8px 12px;border:1px solid var(--bl);border-radius:6px;background:var(--bg);color:var(--t2);cursor:pointer;transition:all .15s;margin-bottom:6px}.ai-quick-btn:last-child{margin-bottom:0}
.ai-quick-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--bs)}
.ai-quick-btn i{margin-right:6px;font-size:14px;vertical-align:middle}
@media(max-width:1024px){.gauge-grid{grid-template-columns:repeat(2,1fr)}.ai-container{grid-template-columns:1fr;height:auto}.ai-chat{min-height:500px}}

/* ═══════ HEATMAP ═══════ */
.hm-wrap{overflow-x:auto}
.hm-table{border-collapse:collapse;width:100%}
.hm-table th{font-size:10px;font-weight:600;color:var(--t3);padding:6px 4px;text-align:center;position:sticky;top:0;background:var(--s);z-index:2;white-space:nowrap}
.hm-table th:first-child{text-align:left;min-width:130px;padding-left:10px}
.hm-table td{padding:0;text-align:center;position:relative}
.hm-cell{width:100%;height:32px;display:flex;align-items:center;justify-content:center;font-family:var(--m);font-size:9px;font-weight:600;color:#fff;transition:all .15s;cursor:pointer;border:1px solid transparent}
.hm-cell:hover{border-color:var(--t1);transform:scale(1.15);z-index:5;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.hm-row-label{font-size:11px;font-weight:600;padding:6px 10px;white-space:nowrap;display:flex;align-items:center;gap:6px;color:var(--t2)}
.hm-row-label i{font-size:14px;color:var(--t3)}
.hm-legend{display:flex;align-items:center;gap:4px;margin-top:12px;justify-content:center}
.hm-legend-bar{width:200px;height:10px;border-radius:5px;background:linear-gradient(90deg,#22c55e,#84cc16,#eab308,#f97316,#ef4444)}
.hm-legend span{font-size:10px;color:var(--t3);font-family:var(--m)}
.hm-tooltip{position:fixed;z-index:200;background:var(--s);border:1px solid var(--b);border-radius:var(--rs);padding:10px 14px;box-shadow:0 8px 24px rgba(0,0,0,.15);font-size:12px;pointer-events:none;display:none}

/* ═══════ OEE ═══════ */
.oee-big{display:flex;align-items:center;justify-content:center;gap:40px;padding:30px;margin-bottom:16px}
.oee-ring-wrap{text-align:center}
.oee-ring-wrap .oee-label{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-top:8px}
.oee-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:16px}
.oee-detail{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:16px;box-shadow:var(--sh1)}
.oee-detail-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.oee-detail-title{font-size:12px;font-weight:700}.oee-detail-val{font-family:var(--m);font-size:22px;font-weight:700}
.oee-bar{height:6px;background:var(--bl);border-radius:3px;margin-top:8px;overflow:hidden}.oee-bar-fill{height:100%;border-radius:3px;transition:width 1s ease}
.oee-factor{display:flex;justify-content:space-between;align-items:center;font-size:11px;padding:6px 0;border-bottom:1px solid var(--bl)}.oee-factor:last-child{border-bottom:none}
.oee-factor-label{color:var(--t3)}.oee-factor-val{font-family:var(--m);font-weight:600}

/* ═══════ PREDICTIVE TIMELINE ═══════ */
.tl-container{position:relative;padding:20px 0 20px 140px}
.tl-axis{position:absolute;left:130px;top:0;bottom:0;width:3px;background:var(--bl);border-radius:2px}
.tl-item{position:relative;margin-bottom:24px;padding-left:30px;animation:msgIn .4s ease}
.tl-dot{position:absolute;left:-7px;top:4px;width:16px;height:16px;border-radius:50%;border:3px solid var(--s);z-index:2;box-shadow:0 0 0 2px var(--bl)}
.tl-dot.green{background:var(--green);box-shadow:0 0 0 2px var(--green),0 0 0 5px rgba(34,197,94,.15)}
.tl-dot.amber{background:var(--amber);box-shadow:0 0 0 2px var(--amber),0 0 0 5px rgba(245,158,11,.15)}
.tl-dot.red{background:var(--red);box-shadow:0 0 0 2px var(--red),0 0 0 5px rgba(239,68,68,.15);animation:pls 1.5s infinite}
.tl-dot.blue{background:var(--blue);box-shadow:0 0 0 2px var(--blue),0 0 0 5px rgba(59,130,246,.15)}
.tl-dot.gray{background:var(--t3);box-shadow:0 0 0 2px var(--t3)}
.tl-date{position:absolute;left:-160px;top:0;width:120px;text-align:right;font-family:var(--m);font-size:11px;color:var(--t3)}
.tl-date strong{display:block;font-size:12px;color:var(--t1)}
.tl-card{background:var(--s);border:1px solid var(--b);border-radius:var(--rs);padding:12px 16px;box-shadow:var(--sh1);transition:all .2s}.tl-card:hover{box-shadow:var(--sh2);transform:translateX(4px)}
.tl-card-head{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.tl-card-eq{font-size:13px;font-weight:700}.tl-card-type{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px}
.tl-card-type.failure{background:var(--rs);color:var(--red)}.tl-card-type.maintenance{background:var(--as);color:var(--amber)}.tl-card-type.prediction{background:var(--bs);color:var(--blue)}.tl-card-type.ok{background:var(--gs);color:var(--green)}
.tl-card-desc{font-size:12px;color:var(--t2);line-height:1.4}
.tl-card-metrics{display:flex;gap:12px;margin-top:8px;font-size:11px}
.tl-card-metric{display:flex;align-items:center;gap:4px;color:var(--t3)}.tl-card-metric strong{color:var(--t1);font-family:var(--m)}
.tl-predict{border-left:3px dashed var(--blue);margin-left:-2px}
@media(max-width:1024px){.oee-big{flex-wrap:wrap;gap:20px}.oee-detail-grid{grid-template-columns:1fr}.tl-container{padding-left:100px}.tl-date{left:-110px;width:90px}}

/* ═══════════════════════════════════════════════
   UI POLISH PASS — Micro-animations, Skeletons, 
   Page Transitions, Empty States, Details
   ═══════════════════════════════════════════════ */

/* PAGE TRANSITIONS */
.page{opacity:0;visibility:hidden;transition:opacity .3s ease;pointer-events:none;position:absolute;width:100%}
.page.vis{opacity:1;visibility:visible;pointer-events:auto;position:relative;width:auto}

/* STAGGERED CARD ENTRANCE */
.page.vis .kpi{animation:staggerIn .4s ease both}.page.vis .card{animation:staggerIn .4s ease both}
.page.vis .kpi:nth-child(1),.page.vis .card:nth-child(1){animation-delay:.05s}
.page.vis .kpi:nth-child(2),.page.vis .card:nth-child(2){animation-delay:.1s}
.page.vis .kpi:nth-child(3){animation-delay:.15s}.page.vis .kpi:nth-child(4){animation-delay:.2s}
.page.vis .kpi:nth-child(5){animation-delay:.25s}.page.vis .kpi:nth-child(6){animation-delay:.3s}
@keyframes staggerIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* SKELETON LOADING */
.skeleton{background:linear-gradient(90deg,var(--bl) 25%,var(--bg) 50%,var(--bl) 75%);background-size:200% 100%;animation:shimmer 1.5s ease infinite;border-radius:6px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.sk-text{height:13px;margin-bottom:8px;border-radius:4px}.sk-text.w60{width:60%}.sk-text.w80{width:80%}.sk-text.w40{width:40%}
.sk-circle{width:48px;height:48px;border-radius:50%}.sk-box{height:100%;border-radius:var(--r)}
.sk-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--bl)}
.sk-kpi{height:88px;border-radius:var(--r)}.sk-chart{height:260px;border-radius:var(--r)}

/* EMPTY STATES */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--t3)}
.empty-state-icon{width:64px;height:64px;border-radius:16px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:16px;color:var(--t3);border:1px solid var(--bl)}
.empty-state-title{font-size:15px;font-weight:700;color:var(--t2);margin-bottom:6px}
.empty-state-desc{font-size:13px;max-width:320px;line-height:1.5;margin-bottom:16px}
.empty-state-btn{font-family:var(--f);font-size:12px;font-weight:600;padding:8px 16px;border-radius:var(--rs);border:1px solid var(--b);background:var(--s);color:var(--t2);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px}.empty-state-btn:hover{border-color:var(--blue);color:var(--blue)}

/* TABLE ROW ENTRANCE */
.tbl tbody tr{animation:rowIn .3s ease both}
.tbl tbody tr:nth-child(1){animation-delay:.02s}.tbl tbody tr:nth-child(2){animation-delay:.04s}
.tbl tbody tr:nth-child(3){animation-delay:.06s}.tbl tbody tr:nth-child(4){animation-delay:.08s}
.tbl tbody tr:nth-child(5){animation-delay:.1s}.tbl tbody tr:nth-child(6){animation-delay:.12s}
.tbl tbody tr:nth-child(7){animation-delay:.14s}.tbl tbody tr:nth-child(8){animation-delay:.16s}
@keyframes rowIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}

/* MICRO-INTERACTIONS */
.sb-item{transition:all .15s cubic-bezier(.4,0,.2,1)}
.sb-item:active{transform:scale(.97)}
.tb-btn{transition:all .15s cubic-bezier(.4,0,.2,1)}.tb-btn:active{transform:scale(.96)}
.al-filter{transition:all .15s cubic-bezier(.4,0,.2,1)}.al-filter:active{transform:scale(.95)}
.login-btn{transition:all .2s cubic-bezier(.4,0,.2,1)}.login-btn:active{transform:scale(.97)}
.login-demo button:active{transform:scale(.93)}

/* KPI VALUE COUNTER ANIMATION */
.kpi-val{animation:countPop .5s cubic-bezier(.4,0,.2,1)}
@keyframes countPop{0%{opacity:0;transform:translateY(10px) scale(.9)}60%{transform:translateY(-2px) scale(1.02)}100%{opacity:1;transform:translateY(0) scale(1)}}

/* HEALTH BAR ANIMATION */
.health-fill{animation:barGrow .8s cubic-bezier(.4,0,.2,1) both}
@keyframes barGrow{from{width:0 !important}}

/* RUL RING ANIMATION */
.rul-ring .rf{animation:ringDraw 1s cubic-bezier(.4,0,.2,1) both}
@keyframes ringDraw{from{stroke-dashoffset:125.66}}

/* CARD HOVER GLOW */
.card{transition:all .2s cubic-bezier(.4,0,.2,1)}.card:hover{box-shadow:var(--sh2)}
.kpi{transition:all .2s cubic-bezier(.4,0,.2,1)}.kpi:hover{box-shadow:var(--sh2);transform:translateY(-2px)}

/* TOOLTIP SMOOTH */
.floor-tooltip{transition:opacity .2s ease,transform .2s ease;transform:translateY(4px)}
.floor-tooltip.show{transform:translateY(0)}

/* ALARM PULSE */
.kpi.danger{animation:dangerPulse 3s ease infinite}
@keyframes dangerPulse{0%,100%{box-shadow:var(--sh1)}50%{box-shadow:0 0 0 3px rgba(239,68,68,.08),var(--sh1)}}

/* SIDEBAR ACTIVE INDICATOR */
.sb-item.active{position:relative}
.sb-item.active::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:20px;background:#fff;border-radius:0 2px 2px 0;animation:indicatorIn .2s ease}
@keyframes indicatorIn{from{height:0;opacity:0}to{height:20px;opacity:1}}

/* BADGE BOUNCE */
.sb-badge{animation:badgeBounce .4s cubic-bezier(.4,0,.2,1)}
@keyframes badgeBounce{0%{transform:scale(0)}60%{transform:scale(1.2)}100%{transform:scale(1)}}

/* TOAST IMPROVED */
.toast{backdrop-filter:blur(8px);background:rgba(255,255,255,.95);border:1px solid rgba(0,0,0,.06)}
body.dark .toast{background:rgba(24,24,27,.95);border-color:rgba(255,255,255,.06)}

/* SCROLL BEHAVIOR */
.sb-nav{scrollbar-width:thin;scrollbar-color:var(--bl) transparent}
.sb-nav::-webkit-scrollbar{width:4px}.sb-nav::-webkit-scrollbar-track{background:transparent}.sb-nav::-webkit-scrollbar-thumb{background:var(--bl);border-radius:2px}
.card-b{scrollbar-width:thin;scrollbar-color:var(--bl) transparent}

/* INPUT FOCUS RING */
.f-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.08)}
.login-field:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.08)}

/* SMOOTH NUMBER TRANSITIONS */
.gauge-val,.health-num,.kpi-val,.oee-detail-val{transition:color .3s ease}

/* MODAL BACKDROP */
.modal-overlay{backdrop-filter:blur(6px)}

/* DEVICE CARD STAGGER */
.dev-grid .dev-card{animation:staggerIn .4s ease both}
.dev-grid .dev-card:nth-child(1){animation-delay:.05s}.dev-grid .dev-card:nth-child(2){animation-delay:.1s}
.dev-grid .dev-card:nth-child(3){animation-delay:.15s}.dev-grid .dev-card:nth-child(4){animation-delay:.2s}
.dev-grid .dev-card:nth-child(5){animation-delay:.25s}.dev-grid .dev-card:nth-child(6){animation-delay:.3s}

/* GAUGE CARD STAGGER */
.gauge-grid .gauge-card{animation:staggerIn .4s ease both}
.gauge-grid .gauge-card:nth-child(1){animation-delay:.05s}.gauge-grid .gauge-card:nth-child(2){animation-delay:.1s}
.gauge-grid .gauge-card:nth-child(3){animation-delay:.15s}.gauge-grid .gauge-card:nth-child(4){animation-delay:.2s}

/* SENSOR CARD STAGGER */
.sensor-grid .sensor-card{animation:staggerIn .35s ease both}
.sensor-grid .sensor-card:nth-child(1){animation-delay:.05s}.sensor-grid .sensor-card:nth-child(2){animation-delay:.1s}
.sensor-grid .sensor-card:nth-child(3){animation-delay:.12s}.sensor-grid .sensor-card:nth-child(4){animation-delay:.15s}

/* RUL ITEM STAGGER */
.rul-grid .rul-item{animation:staggerIn .35s ease both}
.rul-grid .rul-item:nth-child(1){animation-delay:.05s}.rul-grid .rul-item:nth-child(2){animation-delay:.1s}
.rul-grid .rul-item:nth-child(3){animation-delay:.15s}

/* FLOOR EQUIPMENT ENTRANCE */
.floor-eq{animation:floorPop .4s cubic-bezier(.4,0,.2,1) both}
.floor-eq:nth-child(5){animation-delay:.1s}.floor-eq:nth-child(6){animation-delay:.15s}
.floor-eq:nth-child(7){animation-delay:.2s}.floor-eq:nth-child(8){animation-delay:.25s}
.floor-eq:nth-child(9){animation-delay:.3s}.floor-eq:nth-child(10){animation-delay:.35s}
.floor-eq:nth-child(11){animation-delay:.4s}.floor-eq:nth-child(12){animation-delay:.45s}
@keyframes floorPop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}

/* HEATMAP CELL HOVER EFFECT */
.hm-cell{transition:all .12s cubic-bezier(.4,0,.2,1)}

/* TIMELINE STAGGER */
.tl-item{animation:staggerIn .4s ease both}
.tl-item:nth-child(1){animation-delay:.05s}.tl-item:nth-child(2){animation-delay:.12s}
.tl-item:nth-child(3){animation-delay:.19s}.tl-item:nth-child(4){animation-delay:.26s}
.tl-item:nth-child(5){animation-delay:.33s}.tl-item:nth-child(6){animation-delay:.4s}
.tl-item:nth-child(7){animation-delay:.47s}.tl-item:nth-child(8){animation-delay:.54s}

/* TOPBAR ICONS */
.top-btn{transition:all .15s cubic-bezier(.4,0,.2,1)}.top-btn:hover{background:var(--bg);transform:scale(1.05)}.top-btn:active{transform:scale(.93)}

/* NOTIFICATION DOT PULSE */
.top-dot{animation:dotPulse 2s ease infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.4)}50%{box-shadow:0 0 0 4px rgba(239,68,68,0)}}

/* REPORT CARD STAGGER */
.rpt-card{animation:staggerIn .35s ease both}
.rpt-card:nth-child(1){animation-delay:.05s}.rpt-card:nth-child(2){animation-delay:.1s}
.rpt-card:nth-child(3){animation-delay:.15s}

/* FOCUS VISIBLE */
.tb-btn:focus-visible,.al-filter:focus-visible,.sim-btn:focus-visible,.login-btn:focus-visible{outline:2px solid var(--blue);outline-offset:2px}

/* SELECTION COLOR */
::selection{background:rgba(59,130,246,.15);color:var(--t1)}

/* ═══════ FLOOR MAP EDITOR ═══════ */
.floor-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.floor-edit-btn{font-family:var(--f);font-size:11px;font-weight:600;padding:5px 12px;border-radius:6px;border:1px solid var(--b);background:var(--s);color:var(--t2);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:5px}
.floor-edit-btn:hover{border-color:var(--blue);color:var(--blue)}.floor-edit-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.floor-edit-btn svg{width:14px;height:14px}
.floor-eq.dragging{opacity:.7;z-index:20;cursor:grabbing}
.floor-eq.editable{cursor:grab}.floor-eq.editable:hover{filter:brightness(1.1)}
.floor-eq.editable .floor-eq-box{border-style:dashed}
.floor-zone.editable{cursor:move;border-color:var(--blue)}.floor-zone.editable:hover{background:rgba(59,130,246,.03)}
.floor-zone.resizable{position:absolute}
.floor-resize-handle{position:absolute;bottom:-4px;right:-4px;width:10px;height:10px;background:var(--blue);border-radius:2px;cursor:se-resize;opacity:0;transition:opacity .2s}
.floor-zone.editable:hover .floor-resize-handle{opacity:1}
.floor-coord{position:absolute;bottom:4px;left:4px;font-family:var(--m);font-size:9px;color:var(--t3);opacity:0;transition:opacity .2s;background:var(--s);padding:1px 4px;border-radius:3px}
.floor-canvas.editing .floor-coord{opacity:1}
.floor-canvas.editing{cursor:crosshair;background:var(--bg)}
.floor-canvas.editing .floor-grid{opacity:1}
.floor-snap-lines{position:absolute;inset:0;pointer-events:none;z-index:15}
.floor-snap-line{position:absolute;background:rgba(37,99,235,.3)}
.floor-snap-line.h{height:1px;left:0;right:0}.floor-snap-line.v{width:1px;top:0;bottom:0}

/* ═══════ GANTT CHART ═══════ */
.gantt-wrap{overflow-x:auto;position:relative}
.gantt{display:grid;min-width:800px}
.gantt-header{display:flex;border-bottom:2px solid var(--b);position:sticky;top:0;background:var(--s);z-index:3}
.gantt-label-col{width:200px;flex-shrink:0;padding:8px 12px;font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;border-right:1px solid var(--b)}
.gantt-timeline{flex:1;display:flex;position:relative}.gantt-day{flex:1;min-width:36px;text-align:center;padding:6px 0;font-family:var(--m);font-size:9px;color:var(--t3);border-right:1px solid var(--bl)}.gantt-day.today{background:var(--bs);color:var(--blue);font-weight:700}
.gantt-row{display:flex;border-bottom:1px solid var(--bl);transition:background .12s}.gantt-row:hover{background:var(--sh)}
.gantt-row-label{width:200px;flex-shrink:0;padding:8px 12px;border-right:1px solid var(--bl);display:flex;align-items:center;gap:8px;font-size:12px}
.gantt-row-label .gr-eq{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-row-label .gr-id{font-family:var(--m);font-size:10px;color:var(--t3)}
.gantt-row-timeline{flex:1;display:flex;position:relative;min-height:36px;align-items:center}
.gantt-bar{position:absolute;height:22px;border-radius:4px;font-size:9px;font-weight:600;color:#fff;display:flex;align-items:center;padding:0 6px;white-space:nowrap;overflow:hidden;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.1)}
.gantt-bar:hover{transform:scaleY(1.2);z-index:5;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.gantt-bar.urgent{background:var(--red)}.gantt-bar.high{background:var(--amber)}.gantt-bar.medium{background:var(--blue)}.gantt-bar.low{background:var(--t3)}
.gantt-bar.completed{opacity:.5}
.gantt-today-line{position:absolute;top:0;bottom:0;width:2px;background:var(--red);z-index:4;pointer-events:none}
.gantt-today-line::before{content:'Bugün';position:absolute;top:-18px;left:-14px;font-size:8px;font-weight:700;color:var(--red);font-family:var(--m)}

/* ═══════ KANBAN ═══════ */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;min-height:400px}
.kanban-col{background:var(--bg);border:1px solid var(--bl);border-radius:var(--r);padding:12px;display:flex;flex-direction:column}
.kanban-col-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding-bottom:8px;border-bottom:2px solid var(--bl)}
.kanban-col-title{font-size:12px;font-weight:700;display:flex;align-items:center;gap:6px}
.kanban-col-count{font-family:var(--m);font-size:11px;font-weight:600;background:var(--s);border:1px solid var(--b);padding:1px 7px;border-radius:4px}
.kanban-col.pending .kanban-col-head{border-color:var(--amber)}.kanban-col.approved .kanban-col-head{border-color:var(--blue)}
.kanban-col.in_progress .kanban-col-head{border-color:#2563eb}.kanban-col.completed .kanban-col-head{border-color:var(--green)}
.kanban-cards{flex:1;display:flex;flex-direction:column;gap:8px;min-height:60px}
.kanban-card{background:var(--s);border:1px solid var(--b);border-radius:var(--rs);padding:10px 12px;cursor:grab;transition:all .15s;box-shadow:var(--sh1)}
.kanban-card:hover{box-shadow:var(--sh2);transform:translateY(-1px)}.kanban-card:active{cursor:grabbing;opacity:.8}
.kanban-card.dragging{opacity:.4;border-style:dashed}
.kanban-card-title{font-size:12px;font-weight:600;margin-bottom:4px}.kanban-card-eq{font-size:11px;color:var(--t3)}
.kanban-card-meta{display:flex;align-items:center;justify-content:space-between;margin-top:8px;font-size:10px;color:var(--t3)}
.kanban-card-pri{font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;color:#fff}
.kanban-card-pri.urgent{background:var(--red)}.kanban-card-pri.high{background:var(--amber)}.kanban-card-pri.medium{background:var(--blue)}.kanban-card-pri.low{background:var(--t3)}
.kanban-col.drag-over{background:rgba(59,130,246,.03);border-color:var(--blue);border-style:dashed}

/* ═══════ WO DETAIL MODAL ═══════ */
.wo-detail-section{margin-bottom:16px}.wo-detail-section:last-child{margin-bottom:0}
.wo-detail-label{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.wo-checklist{list-style:none}.wo-checklist li{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--bl);font-size:12px;cursor:pointer;transition:color .15s}
.wo-checklist li:last-child{border-bottom:none}.wo-checklist li.done{color:var(--t3);text-decoration:line-through}
.wo-checklist li .ck{width:16px;height:16px;border:1.5px solid var(--b);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .15s;flex-shrink:0}
.wo-checklist li.done .ck{background:var(--green);border-color:var(--green);color:#fff}
.wo-materials{display:grid;gap:4px}.wo-mat{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:var(--bg);border-radius:4px;font-size:11px}
.wo-mat-name{font-weight:600}.wo-mat-qty{font-family:var(--m);color:var(--t3)}

/* ═══════ TECHNICIAN WORKLOAD ═══════ */
.tech-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.tech-card{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:14px;box-shadow:var(--sh1)}
.tech-card-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.tech-avatar{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.tech-name{font-size:13px;font-weight:700}.tech-role{font-size:11px;color:var(--t3)}
.tech-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:8px}
.tech-stat{text-align:center;padding:6px;background:var(--bg);border-radius:4px}.tech-stat-num{font-family:var(--m);font-size:16px;font-weight:700}.tech-stat-lbl{font-size:9px;color:var(--t3)}
.tech-load-bar{height:6px;background:var(--bl);border-radius:3px;margin-top:8px;overflow:hidden}.tech-load-fill{height:100%;border-radius:3px;transition:width .6s ease}

/* WO VIEW TABS */
.wo-tabs{display:flex;gap:6px;flex-wrap:wrap}
@media(max-width:1024px){.kanban{grid-template-columns:repeat(2,1fr)}.tech-grid{grid-template-columns:1fr 1fr}}

/* ═══════ COST ANALYSIS ═══════ */
.cost-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.cost-kpi{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:16px;box-shadow:var(--sh1)}
.cost-kpi-label{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.cost-kpi-val{font-family:var(--m);font-size:24px;font-weight:700}.cost-kpi-sub{font-size:11px;color:var(--t3);margin-top:2px}
.cost-kpi-trend{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;margin-top:4px;padding:2px 6px;border-radius:4px}
.cost-kpi-trend.up{color:var(--red);background:var(--rs)}.cost-kpi-trend.down{color:var(--green);background:var(--gs)}
.roi-card{background:linear-gradient(135deg,#2d5f8a,#2563eb);color:#fff;border-radius:var(--r);padding:24px;text-align:center;margin-bottom:16px}
.roi-val{font-family:var(--m);font-size:42px;font-weight:700;margin:8px 0}.roi-label{font-size:13px;opacity:.8}
.cost-table{width:100%;border-collapse:collapse}.cost-table th{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--t3);padding:8px 12px;text-align:left;border-bottom:2px solid var(--b)}
.cost-table td{padding:10px 12px;border-bottom:1px solid var(--bl);font-size:12px}.cost-table tr:hover{background:var(--sh)}
.cost-bar{width:100%;height:6px;background:var(--bl);border-radius:3px}.cost-bar-fill{height:100%;border-radius:3px}

/* ═══════ INVENTORY ═══════ */
.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.inv-card{background:var(--s);border:1px solid var(--b);border-radius:var(--r);padding:14px;box-shadow:var(--sh1);transition:all .2s;cursor:pointer}.inv-card:hover{box-shadow:var(--sh2);transform:translateY(-1px)}
.inv-card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.inv-card-name{font-size:13px;font-weight:700}.inv-card-code{font-family:var(--m);font-size:10px;color:var(--t3)}
.inv-stock{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.inv-stock-num{font-family:var(--m);font-size:22px;font-weight:700}.inv-stock-unit{font-size:11px;color:var(--t3)}
.inv-stock-status{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;display:inline-flex;align-items:center;gap:3px}
.inv-stock-status.ok{background:var(--gs);color:var(--green)}.inv-stock-status.low{background:var(--as);color:var(--amber)}.inv-stock-status.critical{background:var(--rs);color:var(--red)}
.inv-bar{height:4px;background:var(--bl);border-radius:2px;margin-top:8px}.inv-bar-fill{height:100%;border-radius:2px;transition:width .6s}
.inv-meta{display:flex;justify-content:space-between;margin-top:8px;font-size:10px;color:var(--t3)}

/* ═══════ RBAC ═══════ */
.rbac-lock{display:flex;align-items:center;justify-content:center;padding:40px;flex-direction:column;gap:12px;color:var(--t3)}
.rbac-lock-icon{width:56px;height:56px;border-radius:14px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:24px;border:1px solid var(--bl)}
.rbac-lock-title{font-size:14px;font-weight:700;color:var(--t2)}.rbac-lock-desc{font-size:12px;text-align:center;max-width:300px}
@media(max-width:1024px){.cost-kpi-row{grid-template-columns:repeat(2,1fr)}.inv-grid{grid-template-columns:1fr 1fr}}
