:root{--sidebar-collapsed-width: 64px;--sidebar-expanded-width: 260px}.sidebar{width:var(--sidebar-collapsed-width);background-color:#1e293b;color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;height:100dvh;z-index:100;overflow:visible;transition:width .25s ease}.sidebar-overlay-panel{position:fixed;top:0;left:var(--sidebar-collapsed-width);width:calc(var(--sidebar-expanded-width) - var(--sidebar-collapsed-width));height:100vh;height:100dvh;background-color:#1e293b;z-index:99;border-right:1px solid rgba(255,255,255,.08);box-shadow:4px 0 24px #00000059;display:flex;flex-direction:column;overflow:hidden;transform:translate(-100%);pointer-events:none;transition:transform .22s ease}.sidebar-overlay-panel.open{transform:translate(0);pointer-events:all}.logo-section{width:var(--sidebar-collapsed-width);height:64px;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.logo{width:36px;height:36px;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}.logo-image{width:100%;height:100%;object-fit:contain;padding:3px}.sidebar-panel-header{height:64px;display:flex;align-items:center;padding:0 16px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.logo-text{font-size:13px;color:#cbd5e1;white-space:nowrap;font-weight:500}.menu{padding:10px 0;flex:1;display:flex;flex-direction:column;gap:2px;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.menu::-webkit-scrollbar{display:none}.menu-icon-btn{width:var(--sidebar-collapsed-width);height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;color:#64748b;transition:color .2s,background .2s;border-radius:0;background:none;border:none;flex-shrink:0}.menu-icon-btn:hover,.menu-icon-btn.hovered-icon{color:#94a3b8;background:#ffffff0d}.menu-icon-btn.active-icon{color:#fff;background:#6366f133;border-right:3px solid #6366f1}.menu-icon-btn svg{width:20px;height:20px;flex-shrink:0}.panel-menu{padding:10px 0;flex:1;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.panel-menu-item{height:48px;display:flex;align-items:center;padding:0 16px;gap:12px;cursor:pointer;color:#94a3b8;font-size:14px;font-weight:500;transition:color .2s,background .2s;white-space:nowrap;text-decoration:none}.panel-menu-item:hover,.panel-menu-item.hovered-panel{color:#fff;background:#ffffff0f}.panel-menu-item.active-panel{color:#fff;background:#6366f126;border-left:3px solid #6366f1;padding-left:13px}.sidebar-badge{margin-left:auto;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;animation:badgePop .4s cubic-bezier(.34,1.56,.64,1) both}.icon-badge{position:absolute;top:6px;right:8px;background:#ef4444;color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;animation:badgePop .4s cubic-bezier(.34,1.56,.64,1) both;pointer-events:none}.icon-tooltip{position:fixed;left:calc(var(--sidebar-collapsed-width) + 8px);background:#0f172a;color:#e2e8f0;font-size:12px;font-weight:600;padding:6px 10px;border-radius:6px;white-space:nowrap;pointer-events:none;z-index:300;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 12px #0000004d;opacity:0;transition:opacity .15s ease}.icon-tooltip.visible{opacity:1}.sidebar-popup{position:fixed;z-index:200;background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px;min-width:220px;box-shadow:0 8px 32px #0000004d;animation:trkFadeIn .15s ease}@keyframes trkFadeIn{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}.sidebar-popup-title{font-size:12px;font-weight:700;color:#e2e8f0;display:flex;align-items:center;gap:6px;margin-bottom:10px;text-transform:uppercase;letter-spacing:.06em}.sidebar-popup-body{display:flex;flex-direction:column;gap:8px}.sidebar-popup-row{display:flex;align-items:center;gap:8px}.sidebar-popup-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sidebar-popup-label{font-size:13px;color:#94a3b8;flex:1}.sidebar-popup-val{font-size:13px;font-weight:700}.sidebar-popup-footer{font-size:10px;color:#475569;margin-top:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-badge-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.sidebar-badge-clickable:hover{transform:scale(1.15);box-shadow:0 2px 8px #ef444480}.sidebar-popup-row-clickable{cursor:pointer;border-radius:6px;padding:4px 6px;margin:-4px -6px;transition:background .15s}.sidebar-popup-row-clickable:hover{background:#ffffff14}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:98;background:transparent}a{text-decoration:none}.header-right{position:fixed;top:0;right:0;height:64px;display:flex;align-items:center;gap:10px;padding-right:24px;z-index:51}.header-login-btn{display:flex;align-items:center;gap:8px;padding:8px 18px;background:#6366f1;color:#fff;border:none;border-radius:8px;font-size:13.5px;font-weight:600;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;letter-spacing:.01em;box-shadow:0 2px 8px #6366f140}.header-login-btn:hover{background:#4f46e5;transform:translateY(-1px);box-shadow:0 4px 14px #6366f159}.header-login-btn:active{transform:translateY(0)}.header-login-btn svg{flex-shrink:0}.header-greeting{font-size:13px;color:#64748b;font-weight:500;white-space:nowrap}.header-greeting strong{color:#1e293b;font-weight:700}.header-icon-btn{position:relative;width:38px;height:38px;border-radius:50%;border:none;background:#f1f5f9;color:#475569;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s,color .2s,transform .15s}.header-icon-btn:hover{background:#e2e8f0;color:#1e293b;transform:scale(1.06)}.header-icon-btn.active{background:#ede9fe;color:#6366f1}.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;background:#ef4444;border-radius:50%;border:2px solid white}.header-avatar-btn{width:38px;height:38px;border-radius:50%;border:2px solid #6366f1;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,box-shadow .2s;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.header-avatar-btn:hover{transform:scale(1.08);box-shadow:0 4px 14px #6366f166}.header-divider{width:1px;height:22px;background:#e2e8f0;margin:0 2px}.header-popup{position:fixed;top:68px;right:20px;z-index:300;background:#fff;border:1px solid #e2e8f0;border-radius:14px;box-shadow:0 12px 40px #0000001f,0 2px 8px #0000000f;animation:popupSlide .18s cubic-bezier(.34,1.2,.64,1) both;overflow:hidden;min-width:240px}@keyframes popupSlide{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.profile-popup{width:260px;padding:0}.profile-popup-header{background:linear-gradient(135deg,#6366f1,#8b5cf6);padding:20px 18px 16px;display:flex;align-items:center;gap:14px}.profile-popup-avatar{width:46px;height:46px;border-radius:50%;background:#ffffff40;border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff;text-transform:uppercase;flex-shrink:0}.profile-popup-info{flex:1;min-width:0}.profile-popup-name{font-size:14px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-popup-username{font-size:12px;color:#ffffffbf;margin-top:2px}.profile-popup-body{padding:12px 18px}.profile-popup-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f1f5f9}.profile-popup-row:last-of-type{border-bottom:none}.profile-popup-row-label{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;font-weight:600;width:52px;flex-shrink:0}.profile-popup-row-val{font-size:13px;color:#1e293b;font-weight:600}.profile-role-badge{display:inline-flex;align-items:center;padding:2px 10px;background:#ede9fe;color:#6366f1;border-radius:20px;font-size:11.5px;font-weight:700;text-transform:capitalize}.profile-popup-footer{padding:10px 18px 14px;border-top:1px solid #f1f5f9}.profile-logout-btn{width:100%;padding:9px;background:#fef2f2;border:1px solid #fecaca;color:#ef4444;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .2s,border-color .2s}.profile-logout-btn:hover{background:#fee2e2;border-color:#fca5a5}.notif-popup{width:300px}.notif-popup-header{padding:16px 18px 12px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:space-between}.notif-popup-title{font-size:14px;font-weight:700;color:#1e293b}.notif-popup-badge{font-size:10px;font-weight:700;background:#f1f5f9;color:#64748b;border-radius:10px;padding:2px 8px}.notif-popup-empty{padding:32px 18px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.notif-popup-empty-icon{width:44px;height:44px;background:#f8fafc;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#cbd5e1}.notif-popup-empty-text{font-size:13px;color:#94a3b8;font-weight:500}.login-card{background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:36px 40px;width:360px;box-shadow:0 24px 64px #0000002e,0 4px 16px #00000014;animation:cardRise .35s cubic-bezier(.34,1.1,.64,1) both;border:1px solid rgba(255,255,255,.6)}.popup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:299}*,*:before,*:after{box-sizing:border-box}.container{display:flex;width:100vw;max-width:100vw;min-height:100vh;overflow-x:hidden}.main-content{margin-left:64px;flex:1 1 0;min-width:0;width:calc(100vw - 64px);max-width:calc(100vw - 64px);display:flex;flex-direction:column;overflow:hidden}.content{margin-top:64px;flex:1 1 0;min-height:0;min-width:0;width:100%;max-width:100%;overflow-x:hidden;overflow-y:auto;padding:20px 24px}.header{background-color:#fff;height:64px;position:fixed;top:0;left:64px;right:0;z-index:50;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;padding:0 24px;gap:16px}.back-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#94a3b8;transition:color .2s;border-radius:8px}.back-button:hover{color:#64748b;background-color:#f1f5f9}.page-title{font-size:24px;font-weight:600;color:#64748b;margin:0}.header-right-group{margin-left:auto;display:flex;align-items:center;gap:10px}@font-face{font-family:Gotham Bold;src:url(/fonts/gotham-bold.otf) format("opentype");font-weight:700}.content.home-bg{background-image:url(/images/background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:local;position:relative}.content.home-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/images/background.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;filter:blur(1.5px);opacity:0;transition:opacity .35s ease;z-index:0;pointer-events:none}.content.home-bg.login-active{background-image:none}.content.home-bg.login-active:before{opacity:1}.home-title-wrapper{display:flex;justify-content:center;align-items:center;height:100%;min-height:calc(100vh - 64px);position:relative;z-index:1}.home-title{text-align:center;font-family:Gotham Bold,sans-serif;font-weight:700;color:#fff;line-height:1.4;text-shadow:0 2px 8px rgba(0,0,0,.4)}.home-title .line1,.home-title .line2{font-size:42px}.home-title .line3{font-size:36px;margin-top:8px}.login-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;display:flex;align-items:center;justify-content:center;animation:overlayFade .3s ease both}@keyframes overlayFade{0%{opacity:0}to{opacity:1}}.login-card{background:#fffffff5;border-radius:20px;padding:36px 40px;width:360px;box-shadow:0 24px 64px #0000002e,0 4px 16px #00000014;animation:cardRise .35s cubic-bezier(.34,1.1,.64,1) both;border:1px solid rgba(255,255,255,.6);position:relative;z-index:11}@keyframes cardRise{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card-logo{display:flex;align-items:center;justify-content:center;margin-bottom:24px}.login-card-logo-inner{width:52px;height:52px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 20px #6366f159}.login-card-title{text-align:center;font-size:20px;font-weight:800;color:#1e293b;margin-bottom:4px;letter-spacing:-.02em}.login-card-subtitle{text-align:center;font-size:13px;color:#94a3b8;margin-bottom:28px}.login-field{margin-bottom:16px}.login-field label{display:block;font-size:12px;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.login-field input{width:100%;padding:11px 14px;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:10px;font-size:14px;color:#1e293b;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.login-input-wrapper{position:relative;display:flex;align-items:center}.login-input-wrapper input{padding-right:44px}.login-field input:focus{border-color:#6366f1;background:#fff;box-shadow:0 0 0 3px #6366f11f}.login-field input::placeholder{color:#cbd5e1}.login-eye-btn{position:absolute;right:12px;background:none;border:none;cursor:pointer;padding:4px;color:#94a3b8;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .2s}.login-eye-btn:hover{color:#475569}.login-error{font-size:12.5px;color:#ef4444;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:9px 12px;margin-bottom:16px;display:flex;align-items:center;gap:7px}.login-submit-btn{width:100%;padding:12px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:14.5px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 14px #6366f159;letter-spacing:.01em;margin-top:4px}.login-submit-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 20px #6366f173}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-cancel-btn{width:100%;margin-top:10px;padding:10px;background:transparent;color:#94a3b8;border:none;border-radius:10px;font-size:13.5px;font-weight:500;cursor:pointer;transition:color .2s,background .2s}.login-cancel-btn:hover{color:#475569;background:#f8fafc}.flatpickr-calendar{background:transparent;opacity:0;display:none;text-align:center;visibility:hidden;padding:0;-webkit-animation:none;animation:none;direction:ltr;border:0;font-size:14px;line-height:24px;border-radius:5px;position:absolute;width:307.875px;-webkit-box-sizing:border-box;box-sizing:border-box;-ms-touch-action:manipulation;touch-action:manipulation;background:#fff;-webkit-box-shadow:1px 0 0 #e6e6e6,-1px 0 0 #e6e6e6,0 1px 0 #e6e6e6,0 -1px 0 #e6e6e6,0 3px 13px rgba(0,0,0,.08);box-shadow:1px 0 #e6e6e6,-1px 0 #e6e6e6,0 1px #e6e6e6,0 -1px #e6e6e6,0 3px 13px #00000014}.flatpickr-calendar.open,.flatpickr-calendar.inline{opacity:1;max-height:640px;visibility:visible}.flatpickr-calendar.open{display:inline-block;z-index:99999}.flatpickr-calendar.animate.open{-webkit-animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1);animation:fpFadeInDown .3s cubic-bezier(.23,1,.32,1)}.flatpickr-calendar.inline{display:block;position:relative;top:2px}.flatpickr-calendar.static{position:absolute;top:calc(100% + 2px)}.flatpickr-calendar.static.open{z-index:999;display:block}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+1) .flatpickr-day.inRange:nth-child(7n+7){-webkit-box-shadow:none!important;box-shadow:none!important}.flatpickr-calendar.multiMonth .flatpickr-days .dayContainer:nth-child(n+2) .flatpickr-day.inRange:nth-child(7n+1){-webkit-box-shadow:-2px 0 0 #e6e6e6,5px 0 0 #e6e6e6;box-shadow:-2px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-calendar .hasWeeks .dayContainer,.flatpickr-calendar .hasTime .dayContainer{border-bottom:0;border-bottom-right-radius:0;border-bottom-left-radius:0}.flatpickr-calendar .hasWeeks .dayContainer{border-left:0}.flatpickr-calendar.hasTime .flatpickr-time{height:40px;border-top:1px solid #e6e6e6}.flatpickr-calendar.noCalendar.hasTime .flatpickr-time{height:auto}.flatpickr-calendar:before,.flatpickr-calendar:after{position:absolute;display:block;pointer-events:none;border:solid transparent;content:"";height:0;width:0;left:22px}.flatpickr-calendar.rightMost:before,.flatpickr-calendar.arrowRight:before,.flatpickr-calendar.rightMost:after,.flatpickr-calendar.arrowRight:after{left:auto;right:22px}.flatpickr-calendar.arrowCenter:before,.flatpickr-calendar.arrowCenter:after{left:50%;right:50%}.flatpickr-calendar:before{border-width:5px;margin:0 -5px}.flatpickr-calendar:after{border-width:4px;margin:0 -4px}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowTop:after{bottom:100%}.flatpickr-calendar.arrowTop:before{border-bottom-color:#e6e6e6}.flatpickr-calendar.arrowTop:after{border-bottom-color:#fff}.flatpickr-calendar.arrowBottom:before,.flatpickr-calendar.arrowBottom:after{top:100%}.flatpickr-calendar.arrowBottom:before{border-top-color:#e6e6e6}.flatpickr-calendar.arrowBottom:after{border-top-color:#fff}.flatpickr-calendar:focus{outline:0}.flatpickr-wrapper{position:relative;display:inline-block}.flatpickr-months{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flatpickr-months .flatpickr-month{background:transparent;color:#000000e6;fill:#000000e6;height:34px;line-height:1;text-align:center;position:relative;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1}.flatpickr-months .flatpickr-prev-month,.flatpickr-months .flatpickr-next-month{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;text-decoration:none;cursor:pointer;position:absolute;top:0;height:34px;padding:10px;z-index:3;color:#000000e6;fill:#000000e6}.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,.flatpickr-months .flatpickr-next-month.flatpickr-disabled{display:none}.flatpickr-months .flatpickr-prev-month i,.flatpickr-months .flatpickr-next-month i{position:relative}.flatpickr-months .flatpickr-prev-month.flatpickr-prev-month,.flatpickr-months .flatpickr-next-month.flatpickr-prev-month{left:0}.flatpickr-months .flatpickr-prev-month.flatpickr-next-month,.flatpickr-months .flatpickr-next-month.flatpickr-next-month{right:0}.flatpickr-months .flatpickr-prev-month:hover,.flatpickr-months .flatpickr-next-month:hover{color:#959ea9}.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:#f64747}.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{width:14px;height:14px}.flatpickr-months .flatpickr-prev-month svg path,.flatpickr-months .flatpickr-next-month svg path{-webkit-transition:fill .1s;transition:fill .1s;fill:inherit}.numInputWrapper{position:relative;height:auto}.numInputWrapper input,.numInputWrapper span{display:inline-block}.numInputWrapper input{width:100%}.numInputWrapper input::-ms-clear{display:none}.numInputWrapper input::-webkit-outer-spin-button,.numInputWrapper input::-webkit-inner-spin-button{margin:0;-webkit-appearance:none}.numInputWrapper span{position:absolute;right:0;width:14px;padding:0 4px 0 2px;height:50%;line-height:50%;opacity:0;cursor:pointer;border:1px solid rgba(57,57,57,.15);-webkit-box-sizing:border-box;box-sizing:border-box}.numInputWrapper span:hover{background:#0000001a}.numInputWrapper span:active{background:#0003}.numInputWrapper span:after{display:block;content:"";position:absolute}.numInputWrapper span.arrowUp{top:0;border-bottom:0}.numInputWrapper span.arrowUp:after{border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:4px solid rgba(57,57,57,.6);top:26%}.numInputWrapper span.arrowDown{top:50%}.numInputWrapper span.arrowDown:after{border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(57,57,57,.6);top:40%}.numInputWrapper span svg{width:inherit;height:auto}.numInputWrapper span svg path{fill:#00000080}.numInputWrapper:hover{background:#0000000d}.numInputWrapper:hover span{opacity:1}.flatpickr-current-month{font-size:135%;line-height:inherit;font-weight:300;color:inherit;position:absolute;width:75%;left:12.5%;padding:7.48px 0 0;line-height:1;height:34px;display:inline-block;text-align:center;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}.flatpickr-current-month span.cur-month{font-family:inherit;font-weight:700;color:inherit;display:inline-block;margin-left:.5ch;padding:0}.flatpickr-current-month span.cur-month:hover{background:#0000000d}.flatpickr-current-month .numInputWrapper{width:6ch;width:7ch�;display:inline-block}.flatpickr-current-month .numInputWrapper span.arrowUp:after{border-bottom-color:#000000e6}.flatpickr-current-month .numInputWrapper span.arrowDown:after{border-top-color:#000000e6}.flatpickr-current-month input.cur-year{background:transparent;-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;cursor:text;padding:0 0 0 .5ch;margin:0;display:inline-block;font-size:inherit;font-family:inherit;font-weight:300;line-height:inherit;height:auto;border:0;border-radius:0;vertical-align:initial;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.flatpickr-current-month input.cur-year:focus{outline:0}.flatpickr-current-month input.cur-year[disabled],.flatpickr-current-month input.cur-year[disabled]:hover{font-size:100%;color:#00000080;background:transparent;pointer-events:none}.flatpickr-current-month .flatpickr-monthDropdown-months{appearance:menulist;background:transparent;border:none;border-radius:0;box-sizing:border-box;color:inherit;cursor:pointer;font-size:inherit;font-family:inherit;font-weight:300;height:auto;line-height:inherit;margin:-1px 0 0;outline:none;padding:0 0 0 .5ch;position:relative;vertical-align:initial;-webkit-box-sizing:border-box;-webkit-appearance:menulist;-moz-appearance:menulist;width:auto}.flatpickr-current-month .flatpickr-monthDropdown-months:focus,.flatpickr-current-month .flatpickr-monthDropdown-months:active{outline:none}.flatpickr-current-month .flatpickr-monthDropdown-months:hover{background:#0000000d}.flatpickr-current-month .flatpickr-monthDropdown-months .flatpickr-monthDropdown-month{background-color:transparent;outline:none;padding:0}.flatpickr-weekdays{background:transparent;text-align:center;overflow:hidden;width:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;height:28px}.flatpickr-weekdays .flatpickr-weekdaycontainer{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1}span.flatpickr-weekday{cursor:default;font-size:90%;background:transparent;color:#0000008a;line-height:1;margin:0;text-align:center;display:block;-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;font-weight:bolder}.dayContainer,.flatpickr-weeks{padding:1px 0 0}.flatpickr-days{position:relative;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start;width:307.875px}.flatpickr-days:focus{outline:0}.dayContainer{padding:0;outline:0;text-align:left;width:307.875px;min-width:307.875px;max-width:307.875px;-webkit-box-sizing:border-box;box-sizing:border-box;display:inline-block;display:-ms-flexbox;display:-webkit-box;display:-webkit-flex;display:flex;-webkit-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-wrap:wrap;-ms-flex-pack:justify;-webkit-justify-content:space-around;justify-content:space-around;-webkit-transform:translate3d(0,0,0);transform:translateZ(0);opacity:1}.dayContainer+.dayContainer{-webkit-box-shadow:-1px 0 0 #e6e6e6;box-shadow:-1px 0 #e6e6e6}.flatpickr-day{background:none;border:1px solid transparent;border-radius:150px;-webkit-box-sizing:border-box;box-sizing:border-box;color:#393939;cursor:pointer;font-weight:400;width:14.2857143%;-webkit-flex-basis:14.2857143%;-ms-flex-preferred-size:14.2857143%;flex-basis:14.2857143%;max-width:39px;height:39px;line-height:39px;margin:0;display:inline-block;position:relative;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;text-align:center}.flatpickr-day.inRange,.flatpickr-day.prevMonthDay.inRange,.flatpickr-day.nextMonthDay.inRange,.flatpickr-day.today.inRange,.flatpickr-day.prevMonthDay.today.inRange,.flatpickr-day.nextMonthDay.today.inRange,.flatpickr-day:hover,.flatpickr-day.prevMonthDay:hover,.flatpickr-day.nextMonthDay:hover,.flatpickr-day:focus,.flatpickr-day.prevMonthDay:focus,.flatpickr-day.nextMonthDay:focus{cursor:pointer;outline:0;background:#e6e6e6;border-color:#e6e6e6}.flatpickr-day.today{border-color:#959ea9}.flatpickr-day.today:hover,.flatpickr-day.today:focus{border-color:#959ea9;background:#959ea9;color:#fff}.flatpickr-day.selected,.flatpickr-day.startRange,.flatpickr-day.endRange,.flatpickr-day.selected.inRange,.flatpickr-day.startRange.inRange,.flatpickr-day.endRange.inRange,.flatpickr-day.selected:focus,.flatpickr-day.startRange:focus,.flatpickr-day.endRange:focus,.flatpickr-day.selected:hover,.flatpickr-day.startRange:hover,.flatpickr-day.endRange:hover,.flatpickr-day.selected.prevMonthDay,.flatpickr-day.startRange.prevMonthDay,.flatpickr-day.endRange.prevMonthDay,.flatpickr-day.selected.nextMonthDay,.flatpickr-day.startRange.nextMonthDay,.flatpickr-day.endRange.nextMonthDay{background:#569ff7;-webkit-box-shadow:none;box-shadow:none;color:#fff;border-color:#569ff7}.flatpickr-day.selected.startRange,.flatpickr-day.startRange.startRange,.flatpickr-day.endRange.startRange{border-radius:50px 0 0 50px}.flatpickr-day.selected.endRange,.flatpickr-day.startRange.endRange,.flatpickr-day.endRange.endRange{border-radius:0 50px 50px 0}.flatpickr-day.selected.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.startRange.startRange+.endRange:not(:nth-child(7n+1)),.flatpickr-day.endRange.startRange+.endRange:not(:nth-child(7n+1)){-webkit-box-shadow:-10px 0 0 #569ff7;box-shadow:-10px 0 #569ff7}.flatpickr-day.selected.startRange.endRange,.flatpickr-day.startRange.startRange.endRange,.flatpickr-day.endRange.startRange.endRange{border-radius:50px}.flatpickr-day.inRange{border-radius:0;-webkit-box-shadow:-5px 0 0 #e6e6e6,5px 0 0 #e6e6e6;box-shadow:-5px 0 #e6e6e6,5px 0 #e6e6e6}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover,.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay,.flatpickr-day.notAllowed,.flatpickr-day.notAllowed.prevMonthDay,.flatpickr-day.notAllowed.nextMonthDay{color:#3939394d;background:transparent;border-color:transparent;cursor:default}.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover{cursor:not-allowed;color:#3939391a}.flatpickr-day.week.selected{border-radius:0;-webkit-box-shadow:-5px 0 0 #569ff7,5px 0 0 #569ff7;box-shadow:-5px 0 #569ff7,5px 0 #569ff7}.flatpickr-day.hidden{visibility:hidden}.rangeMode .flatpickr-day{margin-top:1px}.flatpickr-weekwrapper{float:left}.flatpickr-weekwrapper .flatpickr-weeks{padding:0 12px;-webkit-box-shadow:1px 0 0 #e6e6e6;box-shadow:1px 0 #e6e6e6}.flatpickr-weekwrapper .flatpickr-weekday{float:none;width:100%;line-height:28px}.flatpickr-weekwrapper span.flatpickr-day,.flatpickr-weekwrapper span.flatpickr-day:hover{display:block;width:100%;max-width:none;color:#3939394d;background:transparent;cursor:default;border:none}.flatpickr-innerContainer{display:block;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.flatpickr-rContainer{display:inline-block;padding:0;-webkit-box-sizing:border-box;box-sizing:border-box}.flatpickr-time{text-align:center;outline:0;display:block;height:0;line-height:40px;max-height:40px;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flatpickr-time:after{content:"";display:table;clear:both}.flatpickr-time .numInputWrapper{-webkit-box-flex:1;-webkit-flex:1;-ms-flex:1;flex:1;width:40%;height:40px;float:left}.flatpickr-time .numInputWrapper span.arrowUp:after{border-bottom-color:#393939}.flatpickr-time .numInputWrapper span.arrowDown:after{border-top-color:#393939}.flatpickr-time.hasSeconds .numInputWrapper{width:26%}.flatpickr-time.time24hr .numInputWrapper{width:49%}.flatpickr-time input{background:transparent;-webkit-box-shadow:none;box-shadow:none;border:0;border-radius:0;text-align:center;margin:0;padding:0;height:inherit;line-height:inherit;color:#393939;font-size:14px;position:relative;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-appearance:textfield;-moz-appearance:textfield;appearance:textfield}.flatpickr-time input.flatpickr-hour{font-weight:700}.flatpickr-time input.flatpickr-minute,.flatpickr-time input.flatpickr-second{font-weight:400}.flatpickr-time input:focus{outline:0;border:0}.flatpickr-time .flatpickr-time-separator,.flatpickr-time .flatpickr-am-pm{height:inherit;float:left;line-height:inherit;color:#393939;font-weight:700;width:2%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-align-self:center;-ms-flex-item-align:center;align-self:center}.flatpickr-time .flatpickr-am-pm{outline:0;width:18%;cursor:pointer;text-align:center;font-weight:400}.flatpickr-time input:hover,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:focus{background:#eee}.flatpickr-input[readonly]{cursor:pointer}@-webkit-keyframes fpFadeInDown{0%{opacity:0;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:1;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}@keyframes fpFadeInDown{0%{opacity:0;-webkit-transform:translate3d(0,-20px,0);transform:translate3d(0,-20px,0)}to{opacity:1;-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}}.wo-page{display:flex;flex-direction:column;gap:0;min-height:100%;background:#f1f5f9;width:100%}.bk-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px;width:100%;max-width:100%;overflow:hidden;flex-wrap:nowrap;box-sizing:border-box}.bk-toolbar-left{display:flex;align-items:center;gap:8px;flex:1 1 0;min-width:0;overflow:hidden}.wo-filter-count{display:inline-flex;align-items:center;justify-content:center;background:#6366f1;color:#fff;font-size:11px;font-weight:700;width:18px;height:18px;border-radius:50%;line-height:1}.bk-search-container{display:flex;align-items:center;gap:10px;padding:10px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:1 1 120px;min-width:80px;max-width:260px;transition:all .2s;overflow:hidden}.bk-search-container:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background-color:#fff}.bk-refresh-btn{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;border-radius:8px;transition:all .2s;flex-shrink:0}.bk-table{width:100%;min-width:800px;border-collapse:collapse}.wo-footer{display:flex;align-items:center;justify-content:space-between;padding:0 20px}.wo-page-info{font-size:13px;color:#94a3b8}.pagination-btn{background:#fff;border:1px solid #e2e8f0;cursor:pointer;padding:7px;display:flex;align-items:center;color:#64748b;border-radius:6px;transition:all .2s}.bk-detail-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#334155}.bk-detail-section:first-child{margin-top:0}.wo-add-modal{width:660px}.bk-location-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#eff0fe;border-radius:8px;margin-bottom:16px;font-size:13px;color:#6366f1;font-weight:600}.bk-section-title{font-size:14px;font-weight:700;color:#1e293b;margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.bk-section-title:not(:first-child){margin-top:24px}.bk-form-label{display:block;font-size:13px;font-weight:600;color:#334155;margin-bottom:7px}.bk-form-input{width:100%;padding:11px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;font-family:inherit}.bk-date-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:40px}.bk-form-select{width:100%;padding:11px 40px 11px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;cursor:pointer;transition:all .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;font-family:inherit}.bk-form-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.bk-form-textarea{width:100%;padding:11px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;resize:vertical;min-height:80px;font-family:inherit}.bk-select-list{max-height:200px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:0 0 8px 8px;background:#f8fafc}.bk-select-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#6366f1;flex-shrink:0;margin-top:2px}.bk-select-option-label{flex:1;font-size:13px;color:#334155;line-height:1.4}.bk-select-option-sub{font-size:11px;color:#94a3b8;margin-top:2px}.bk-select-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid #e2e8f0;border-bottom:none;background:#fff;border-radius:8px 8px 0 0}.bk-qty-item-name{flex:1;color:#334155;font-weight:500;min-width:100px}.bk-submit-btn{padding:11px 32px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.flatpickr-current-month,.flatpickr-current-month .cur-month,.flatpickr-current-month input.cur-year{color:#fff!important}.flatpickr-prev-month svg,.flatpickr-next-month svg{fill:#fff!important}.wo-complete-section{margin-top:28px;padding:16px 18px;background:#f5f3ff;border:1px solid #c7d2fe;border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:16px}.wo-complete-info{display:flex;align-items:flex-start;gap:12px;flex:1}.wo-complete-info svg{flex-shrink:0;margin-top:2px}.wo-complete-title{font-size:14px;font-weight:700;color:#3730a3;margin:0 0 3px}.wo-complete-desc{font-size:12px;color:#6366f1;margin:0;line-height:1.5}.wo-complete-btn{padding:9px 20px;background:#6366f1;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0;font-family:inherit}.wo-complete-btn:hover{background:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.wo-complete-modal{width:440px}.wo-downtime-row{display:flex;align-items:center;gap:12px}.wo-downtime-input-wrap{display:flex;align-items:center;gap:8px;flex:1}.wo-downtime-input{width:100%;text-align:center;font-size:20px!important;font-weight:700!important;color:#1e293b!important;padding:12px 16px!important}.wo-downtime-input::-webkit-outer-spin-button,.wo-downtime-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.wo-downtime-unit{font-size:13px;font-weight:600;color:#64748b;white-space:nowrap}.wo-downtime-sep{font-size:24px;font-weight:700;color:#94a3b8;flex-shrink:0}.wo-runtest-row{display:flex;gap:12px}.wo-runtest-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:10px;border:2px solid #e2e8f0;background:#fff;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;color:#94a3b8;font-family:inherit}.wo-runtest-btn:hover{border-color:#cbd5e1;color:#64748b}.wo-runtest-btn.pass.active{background:#f0fdf4;border-color:#22c55e;color:#16a34a}.wo-runtest-btn.denied.active{background:#fef2f2;border-color:#ef4444;color:#dc2626}.wo-runtest-btn.pass:hover:not(.active){border-color:#86efac;color:#16a34a}.wo-runtest-btn.denied:hover:not(.active){border-color:#fca5a5;color:#dc2626}.wo-bulk-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#ef4444}.wo-bulk-count-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;font-size:13px;font-weight:600;color:#ef4444;white-space:nowrap;flex-shrink:0}.wo-bulk-cancel-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;transition:all .15s;flex-shrink:0}.wo-bulk-cancel-btn:hover{background:#f1f5f9;color:#334155}.wo-bulk-confirm-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:#ef4444;color:#fff;cursor:pointer;transition:all .15s;flex-shrink:0}.wo-bulk-confirm-btn:hover:not(:disabled){background:#dc2626}.wo-bulk-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.wo-tabs{display:flex;gap:4px;margin-bottom:4px;padding:4px 0}.wo-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.wo-tab-btn.active{background-color:#6366f1;color:#fff}.wo-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.wo-combobox-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px #0000001a,0 2px 6px #0000000f;z-index:9999;overflow:hidden;max-height:240px;overflow-y:auto;animation:comboboxFadeIn .15s ease}@keyframes comboboxFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.wo-combobox-option{padding:10px 14px;font-size:14px;cursor:pointer;transition:background .12s;border-radius:0}.wo-combobox-option:hover{background:#f1f5f9!important}.wo-runtest-btn.ongoing.active{background:#eff6ff;border-color:#3b82f6;color:#2563eb;font-weight:700}.wo-runtest-btn.ongoing:hover:not(.active){border-color:#93c5fd;color:#3b82f6}.asset-tabs{display:flex;gap:4px;margin-bottom:4px;padding:4px 0}.asset-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.asset-tab-btn.active{background-color:#6366f1;color:#fff}.asset-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.assets-wrapper{display:flex;flex-direction:column;gap:0;min-height:100%;background:#f1f5f9;width:100%}.toolbar-section{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px;width:100%;max-width:100%;overflow:hidden;flex-wrap:nowrap;box-sizing:border-box}.asset-left-toolbar{display:flex;align-items:center;gap:8px;flex:1 1 0;min-width:0;overflow:hidden}.asset-filter-btn{padding:10px 20px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .3s;white-space:nowrap;flex-shrink:0}.asset-filter-btn:hover{background-color:#6366f126;border-color:#6366f14d;color:#6366f1}.asset-filter-btn.active{background-color:#6366f1;color:#fff;border-color:#6366f1}.search-container{display:flex;align-items:center;gap:10px;padding:10px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:1 1 120px;min-width:80px;max-width:260px;transition:all .2s;overflow:hidden}.search-container:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.search-container svg{color:#94a3b8;flex-shrink:0}.search-input{border:none;outline:none;flex:1;font-size:14px;color:#334155;background:transparent;min-width:0}.search-input::placeholder{color:#cbd5e1}.toolbar-actions{display:flex;gap:12px;align-items:center;flex-shrink:0}.refresh-button,.more-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;transition:all .2s;border-radius:8px;flex-shrink:0}.refresh-button:hover,.more-button:hover{background-color:#f1f5f9;color:#334155}.create-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0}.create-button:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;min-width:0;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.table-scroll{width:100%;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 260px);--header-h: 49px;box-sizing:border-box}.table-scroll::-webkit-scrollbar{height:8px;width:8px}.table-scroll::-webkit-scrollbar-track{background:#f1f5f9;margin-top:var(--header-h)}.table-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.table-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.table-scroll::-webkit-scrollbar-corner{background:#f1f5f9}.assets-table{width:max-content;min-width:100%;border-collapse:collapse}.assets-table thead{background-color:#f8fafc;position:sticky;top:0;z-index:10}.assets-table th{text-align:left;padding:16px 20px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap;background-color:#f8fafc}.assets-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s}.assets-table tbody tr:hover{background-color:#f8fafc}.assets-table td{padding:16px 20px;font-size:14px;color:#334155;white-space:nowrap}.table-footer{height:51px;background-color:#fff;border-top:1px solid #f1f5f9;flex-shrink:0}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:8px 0}.pagination-info{display:flex;align-items:center;gap:12px;font-size:14px;color:#64748b}.rows-select{padding:6px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;color:#334155;cursor:pointer;background-color:#fff;outline:none}.rows-select:focus{border-color:#6366f1}.page-info{color:#94a3b8}.pagination-controls-left{display:flex;gap:8px}.pagination-btn{background:none;border:1px solid #e2e8f0;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;border-radius:6px;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1;color:#334155}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.asset-filter-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0003;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1001;opacity:0}.asset-filter-overlay.active{display:block;animation:assetFadeIn .35s ease forwards}.asset-filter-overlay.closing{animation:assetFadeOut .35s ease forwards}.asset-filter-sidebar{position:fixed;top:0;left:0;width:400px;height:100vh;background-color:#fff;box-shadow:2px 0 10px #0000001a;overflow-y:auto;overflow-x:hidden;z-index:1002}.asset-filter-sidebar.active{animation:assetSlideIn .35s ease forwards}.asset-filter-sidebar.closing{animation:assetSlideOut .35s ease forwards}@keyframes assetSlideIn{0%{transform:translate(-400px)}to{transform:translate(0)}}@keyframes assetSlideOut{0%{transform:translate(0)}to{transform:translate(-400px)}}.asset-filter-sidebar::-webkit-scrollbar{width:8px}.asset-filter-sidebar::-webkit-scrollbar-track{background:#f1f5f9}.asset-filter-sidebar::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.asset-filter-sidebar::-webkit-scrollbar-thumb:hover{background:#94a3b8}.asset-filter-header{padding:24px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background-color:#fff;z-index:10}.asset-filter-header h2{font-size:20px;font-weight:600;color:#1e293b;margin:0}.asset-filter-content{padding:24px}.asset-filter-section{margin-bottom:20px}.asset-filter-section-title{font-size:16px;font-weight:600;color:#1e293b;margin:24px 0 16px;padding-bottom:8px;border-bottom:1px solid #e2e8f0}.asset-filter-label{display:block;font-size:14px;font-weight:500;color:#64748b;margin-bottom:8px}.asset-filter-select{width:100%;padding:10px 40px 10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(/images/dropdown.svg);background-repeat:no-repeat;background-position:right 12px center;background-size:16px 16px;transition:all .2s}.asset-filter-select.placeholder{color:#94a3b8}.asset-filter-select option{color:#334155}.asset-filter-select option[value=""]{color:#94a3b8}.asset-filter-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.asset-filter-search-input{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box}.asset-filter-search-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.asset-filter-search-input::placeholder{color:#94a3b8}.asset-filter-date-range{display:flex;align-items:center;gap:8px}.asset-filter-date-input{flex:1;max-width:155px;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box}.asset-filter-date-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.asset-filter-date-input::placeholder{color:#94a3b8}.asset-date-separator{font-size:14px;color:#94a3b8;flex-shrink:0}.asset-filter-footer{margin-top:8px;padding-top:20px;border-top:1px solid #e2e8f0}.asset-filter-save-btn{min-width:100px;padding:12px 32px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.asset-filter-save-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.add-asset-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1100;justify-content:center;align-items:center}.add-asset-overlay.active{display:flex}@keyframes assetModalIn{0%{opacity:0;transform:translateY(-16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes assetModalOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-16px) scale(.98)}}.add-asset-modal{background-color:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:700px;max-width:90vw;max-height:85vh;display:flex;flex-direction:column}.add-asset-modal.animating-in{animation:assetModalIn .25s ease forwards}.add-asset-modal.animating-out{animation:assetModalOut .2s ease forwards}.log-modal-animating-in{animation:assetModalIn .25s ease forwards}.log-modal-animating-out{animation:assetModalOut .2s ease forwards}.add-asset-header{padding:28px 32px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.add-asset-header h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px}.add-asset-header p{font-size:14px;color:#64748b;margin:0}.add-asset-body{padding:24px 32px;overflow-y:auto;flex:1}.add-asset-body::-webkit-scrollbar{width:6px}.add-asset-body::-webkit-scrollbar-track{background:#f1f5f9}.add-asset-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.add-asset-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.add-asset-section-title{font-size:16px;font-weight:700;color:#1e293b;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.add-asset-section-title:not(:first-child){margin-top:28px}.add-asset-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.add-asset-row .add-asset-field{margin-bottom:0}.add-asset-field{margin-bottom:16px}.add-asset-label{display:block;font-size:14px;font-weight:500;color:#334155;margin-bottom:8px}.add-asset-input{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box}.add-asset-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.add-asset-input::placeholder{color:#94a3b8}.add-asset-select{width:100%;padding:12px 40px 12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;cursor:pointer;transition:all .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(/images/dropdown.svg);background-repeat:no-repeat;background-position:right 14px center;background-size:16px 16px}.add-asset-select.placeholder{color:#94a3b8}.add-asset-select option{color:#334155}.add-asset-select option[value=""]{color:#94a3b8}.add-asset-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.add-asset-select option:not([disabled]){color:#334155}.add-asset-textarea{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;resize:vertical;min-height:100px;font-family:inherit}.add-asset-textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.add-asset-textarea::placeholder{color:#94a3b8}.add-asset-submit-btn{padding:10px 32px;background-color:#6366f1;color:#fff;border:1.5px solid transparent;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.add-asset-submit-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.asset-detail-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0003;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1001;opacity:0}.asset-detail-overlay.active{display:block;animation:assetFadeIn .35s ease forwards}.asset-detail-overlay.closing{animation:assetFadeOut .35s ease forwards}.asset-detail-panel{position:fixed;top:0;right:0;width:420px;height:100vh;background-color:#fff;box-shadow:-2px 0 20px #0000001f;overflow-y:auto;overflow-x:hidden;z-index:1002;transform:translate(420px)}.asset-detail-panel.active{animation:assetDetailSlideIn .35s ease forwards}.asset-detail-panel.closing{animation:assetDetailSlideOut .35s ease forwards}.asset-detail-panel::-webkit-scrollbar{width:6px}.asset-detail-panel::-webkit-scrollbar-track{background:#f1f5f9}.asset-detail-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.asset-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 24px 20px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10}.asset-detail-title-area{flex:1;min-width:0}.asset-detail-name{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px;line-height:1.3}.asset-detail-tag{font-size:13px;color:#64748b;margin:0}.asset-detail-actions{display:flex;gap:8px;margin-left:12px;flex-shrink:0}.asset-detail-edit-btn,.asset-detail-delete-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.asset-detail-edit-btn:hover{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.asset-detail-delete-btn:hover{background:#fef2f2;border-color:#ef4444}.asset-detail-body{padding:20px 24px 32px}.asset-detail-badges{display:flex;gap:8px;margin-bottom:24px}.asset-detail-badge{display:inline-block;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;color:#fff;text-transform:uppercase}.asset-detail-section-title{font-size:13px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:24px 0 14px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.asset-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.asset-detail-field{display:flex;flex-direction:column;gap:4px}.asset-detail-field--full{grid-column:1 / -1}.asset-detail-label{font-size:12px;color:#94a3b8;font-weight:500}.asset-detail-value{font-size:14px;color:#1e293b;font-weight:500;word-break:break-word}.asset-delete-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:420px;max-width:90vw;padding:36px 32px;text-align:center}.asset-delete-modal.animating-in{animation:assetModalIn .25s ease forwards}.asset-delete-modal.animating-out{animation:assetModalOut .2s ease forwards}.asset-delete-icon{width:64px;height:64px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.asset-delete-title{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 10px}.asset-delete-desc{font-size:14px;color:#64748b;margin:0 0 28px;line-height:1.6}.asset-delete-actions{display:flex;gap:12px;justify-content:center}.asset-delete-cancel-btn{padding:10px 24px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.asset-delete-cancel-btn:hover{background:#f8fafc;border-color:#cbd5e1}.asset-delete-confirm-btn{padding:10px 24px;border:none;background:#ef4444;color:#fff;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s}.asset-delete-confirm-btn:hover{background:#dc2626}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sp-table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;min-width:0;flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden;position:relative}.sp-table-scroll{width:100%;overflow-x:auto;overflow-y:auto;flex:1;min-height:0;--header-h: 49px}.sp-form-select{width:100%;padding:12px 40px 12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;cursor:pointer;transition:all .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(/images/dropdown.svg);background-repeat:no-repeat;background-position:right 14px center;background-size:16px 16px;font-family:inherit}.add-asset-footer{padding:16px 32px 24px;border-top:1px solid #e2e8f0;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px}.draft-list-close-btn{background:transparent;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background .15s;flex-shrink:0}.draft-list-close-btn:hover{color:#334155;background:#f1f5f9}.locations-wrapper{display:flex;flex-direction:column;gap:0;min-height:100%;background:#f1f5f9;width:100%}.loc-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px;width:100%;max-width:100%;overflow:hidden;flex-wrap:nowrap;box-sizing:border-box}.loc-view-tabs{display:flex;gap:8px}.loc-tab-button{padding:10px 20px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.loc-tab-button.active{background-color:#6366f1;color:#fff}.loc-map-btn:hover{background-color:#6366f11a;color:#6366f1}.loc-map-btn.active{background-color:transparent;color:#64748b}.loc-toolbar-actions{display:flex;gap:12px;align-items:center;flex-shrink:0}.loc-refresh-button{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;transition:all .2s;border-radius:8px;flex-shrink:0}.loc-refresh-button:hover{background-color:#f1f5f9;color:#334155}.loc-create-button{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0}.loc-create-button:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.loc-table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;min-width:0;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.loc-table-header-wrap{flex-shrink:0;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;display:flex;align-items:center;justify-content:center;padding:14px 20px}.loc-header-title{font-size:13px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px}.loc-table-scroll{width:100%;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 260px);--header-h: 49px;box-sizing:border-box}.loc-table-scroll::-webkit-scrollbar{height:8px;width:8px}.loc-table-scroll::-webkit-scrollbar-track{background:#f1f5f9}.loc-table-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.loc-table-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.loc-table-scroll::-webkit-scrollbar-corner{background:#f1f5f9}.locations-table{width:max-content;min-width:100%;border-collapse:collapse}.locations-table thead{background-color:#f8fafc}.locations-table th{text-align:left;padding:16px 12px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap;background-color:#f8fafc}.locations-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s}.locations-table tbody tr:hover{background-color:#f8fafc}.locations-table td{padding:1x 12px;font-size:14px;color:#334155;white-space:nowrap}.empty-row td{height:320px;vertical-align:middle;text-align:center}.empty-state{text-align:center;padding:40px}.empty-title{font-size:16px;font-weight:500;color:#334155;margin-bottom:8px}.empty-subtitle{font-size:14px;color:#94a3b8}.loc-table-footer{height:51px;background-color:#fff;border-top:1px solid #f1f5f9;flex-shrink:0}.loc-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:8px 0}.loc-pagination-info{display:flex;align-items:center;gap:12px;font-size:14px;color:#64748b}.loc-rows-select{padding:6px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px;color:#334155;cursor:pointer;background-color:#fff;outline:none}.loc-rows-select:focus{border-color:#6366f1}.loc-page-info{color:#94a3b8}.loc-pagination-controls{display:flex;gap:8px}.loc-pagination-btn{background:none;border:1px solid #e2e8f0;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;border-radius:6px;transition:all .2s}.loc-pagination-btn:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1;color:#334155}.loc-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.add-loc-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1100;justify-content:center;align-items:center}.add-loc-overlay.active{display:flex}@keyframes locModalIn{0%{opacity:0;transform:translateY(-16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes locModalOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-16px) scale(.98)}}.add-loc-modal{background-color:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:560px;max-width:90vw;max-height:85vh;display:flex;flex-direction:column}.add-loc-modal.animating-in{animation:locModalIn .25s ease forwards}.add-loc-modal.animating-out{animation:locModalOut .2s ease forwards}.add-loc-header{padding:28px 32px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.add-loc-header h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px}.add-loc-header p{font-size:14px;color:#64748b;margin:0}.add-loc-body{padding:24px 32px;overflow-y:auto;flex:1}.add-loc-body::-webkit-scrollbar{width:6px}.add-loc-body::-webkit-scrollbar-track{background:#f1f5f9}.add-loc-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.add-loc-body::-webkit-scrollbar-thumb:hover{background:#94a3b8}.add-loc-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.add-loc-row .add-loc-field{margin-bottom:0}.add-loc-field{margin-bottom:16px}.add-loc-label{display:block;font-size:14px;font-weight:500;color:#334155;margin-bottom:8px}.add-loc-input{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box}.add-loc-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.add-loc-input::placeholder{color:#94a3b8}.add-loc-select{width:100%;padding:12px 40px 12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#94a3b8;background-color:#fff;cursor:pointer;transition:all .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(/images/dropdown.svg);background-repeat:no-repeat;background-position:right 14px center;background-size:16px 16px}.add-loc-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.add-loc-select option:not([disabled]){color:#334155}.add-loc-footer{padding:16px 32px 24px;border-top:1px solid #e2e8f0;flex-shrink:0;display:flex;justify-content:flex-start}.add-loc-submit-btn{padding:10px 32px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.add-loc-submit-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.add-loc-select.placeholder{color:#94a3b8}.add-loc-select option{color:#334155}.add-loc-select option[value=""]{color:#94a3b8}@keyframes locSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loc-city-block{width:100%}.loc-city-row{display:block;width:100%;cursor:pointer;border-bottom:1px solid #e2e8f0;background-color:#fafafa;box-sizing:border-box}.loc-site-row{display:block;width:100%;cursor:pointer;border-bottom:1px solid #e2e8f0;background-color:#fdfdfd;box-sizing:border-box}.loc-area-row{display:block;width:100%;cursor:pointer;border-bottom:1px solid #e2e8f0;background-color:#fff;box-sizing:border-box}.loc-city-row:hover{background-color:#f0f4ff}.loc-site-row:hover{background-color:#f5f7ff}.loc-area-row:hover{background-color:#f8fafc}.loc-tree-cell{display:flex;align-items:center;gap:8px;padding:15px 18px;width:100%;box-sizing:border-box}.loc-indent-1{padding-left:40px}.loc-indent-2{padding-left:60px}.loc-city-label{font-size:14px;font-weight:700;color:#1e293b;letter-spacing:.03em}.loc-site-label{font-size:14px;font-weight:600;color:#334155}.loc-area-label{font-size:14px;font-weight:500;color:#475569}.loc-asset-table{width:100%;border-collapse:collapse;table-layout:auto}.loc-asset-table thead tr{background-color:#f1f5f9;border-bottom:1px solid #e2e8f0}.loc-asset-table th{padding:11px 16px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;text-align:left}.loc-asset-table td{padding:10px 16px;font-size:14px;color:#334155;white-space:nowrap;text-align:left}.loc-asset-row{border-bottom:1px solid #f1f5f9;background-color:#fff}.loc-asset-row:hover{background-color:#f8fafc}.loc-asset-table th:first-child,.loc-asset-table td:first-child{padding-left:70px}.loc-search-container{display:flex;align-items:center;gap:10px;padding:10px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:0 0 220px;transition:all .3s}.loc-search-container:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.loc-search-container svg{color:#94a3b8;flex-shrink:0}.loc-search-input{border:none;outline:none;flex:1;font-size:14px;color:#334155;background:transparent;min-width:0}.loc-search-input::placeholder{color:#cbd5e1}.loc-panel-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0003;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1001;opacity:0}.loc-panel-overlay.active{display:block;animation:assetFadeIn .35s ease forwards}.loc-panel-overlay.closing{animation:assetFadeOut .35s ease forwards}@keyframes assetFadeIn{0%{opacity:0}to{opacity:1}}@keyframes assetFadeOut{0%{opacity:1}to{opacity:0}}.loc-detail-panel{position:fixed;top:0;right:0;width:420px;height:100vh;background-color:#fff;box-shadow:-2px 0 20px #0000001f;overflow-y:auto;overflow-x:hidden;z-index:1002;transform:translate(420px)}.loc-detail-panel.active{animation:assetDetailSlideIn .35s ease forwards}.loc-detail-panel.closing{animation:assetDetailSlideOut .35s ease forwards}@keyframes assetDetailSlideIn{0%{transform:translate(420px)}to{transform:translate(0)}}@keyframes assetDetailSlideOut{0%{transform:translate(0)}to{transform:translate(420px)}}.loc-detail-panel::-webkit-scrollbar{width:6px}.loc-detail-panel::-webkit-scrollbar-track{background:#f1f5f9}.loc-detail-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.loc-panel-close-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#64748b}.loc-panel-close-btn:hover{background:#f1f5f9;border-color:#cbd5e1}.loc-complete-section{margin-top:32px;padding:20px;border:1px solid #e0e7ff;border-radius:12px;background-color:#f5f3ff}.loc-complete-info{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}.loc-complete-title{font-size:14px;font-weight:600;color:#1e293b;margin:0 0 4px}.loc-complete-desc{font-size:13px;color:#64748b;margin:0;line-height:1.5}.loc-complete-btn{width:100%;padding:10px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.loc-complete-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.add-loc-asset-search{display:flex;align-items:center;gap:8px;padding:9px 14px;border:1px solid #e2e8f0;border-radius:8px 8px 0 0;background:#f8fafc;border-bottom:none}.add-loc-asset-search-input{border:none;outline:none;background:transparent;font-size:13px;color:#334155;flex:1}.add-loc-asset-search-input::placeholder{color:#cbd5e1}.add-loc-asset-list{border:1px solid #e2e8f0;border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;background:#fff}.add-loc-asset-list::-webkit-scrollbar{width:5px}.add-loc-asset-list::-webkit-scrollbar-track{background:#f1f5f9}.add-loc-asset-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.add-loc-asset-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;transition:background-color .15s;border-bottom:1px solid #f1f5f9}.add-loc-asset-item:last-child{border-bottom:none}.add-loc-asset-item:hover{background-color:#f8fafc}.add-loc-asset-item.selected{background-color:#eff0fe}.add-loc-asset-all{background-color:#f8fafc;border-bottom:1px solid #e2e8f0!important;position:sticky;top:0;z-index:1}.add-loc-asset-cb{width:16px;height:16px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.loc-add-location-btn{display:flex;align-items:center;gap:7px;padding:10px 18px;background-color:#fff;color:#64748b;border:1.5px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.loc-add-location-btn:hover{border-color:#6366f1;color:#6366f1;background-color:#fff;box-shadow:0 0 0 3px #6366f114}.loc-add-location-btn svg{transition:stroke .2s}.loc-add-location-btn:hover svg{stroke:#6366f1}.loc-autocomplete-dropdown{position:absolute;top:calc(100% - 2px);left:0;right:0;background:#fff;border:1.5px solid #6366f1;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 8px 24px #6366f11a;z-index:9999;max-height:220px;overflow-y:auto}.loc-autocomplete-dropdown::-webkit-scrollbar{width:4px}.loc-autocomplete-dropdown::-webkit-scrollbar-track{background:#f1f5f9}.loc-autocomplete-dropdown::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.loc-autocomplete-item{display:flex;align-items:center;gap:10px;padding:10px 14px;font-size:13px;color:#334155;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .15s}.loc-autocomplete-item:last-child{border-bottom:none}.loc-autocomplete-item:hover{background-color:#eef2ff;color:#4f46e5}.add-loc-field:focus-within .add-loc-input{border-color:#6366f1;border-radius:8px 8px 0 0;box-shadow:none}.loc-row-actions{margin-left:auto;display:flex;align-items:center;gap:4px;opacity:0;transition:opacity .15s ease;flex-shrink:0}.loc-city-row:hover .loc-row-actions,.loc-site-row:hover .loc-row-actions,.loc-area-row:hover .loc-row-actions{opacity:1}.loc-row-edit-btn,.loc-row-delete-btn{width:28px;height:28px;border-radius:6px;border:1px solid transparent;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;color:#94a3b8}.loc-row-edit-btn:hover{background-color:#eef2ff;border-color:#c7d2fe;color:#6366f1}.loc-row-delete-btn:hover{background-color:#fef2f2;border-color:#fecaca;color:#ef4444}.loc-dup-warning{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background-color:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin-top:4px}.loc-dup-warning span{font-size:13px;color:#92400e;line-height:1.5}.loc-dup-warning svg{flex-shrink:0;margin-top:1px}.loc-panel-header{display:flex;align-items:flex-start;justify-content:space-between;padding:24px 20px 16px;border-bottom:1px solid #f1f5f9;gap:12px}.loc-panel-title-area{flex:1;min-width:0}.loc-panel-title{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loc-panel-subtitle{font-size:13px;color:#94a3b8;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loc-panel-btn{width:34px;height:34px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#64748b;transition:all .2s;flex-shrink:0}.loc-panel-btn:hover{background:#f1f5f9;border-color:#cbd5e1;color:#334155}.loc-panel-btn-delete:hover{background:#fef2f2;border-color:#fecaca;color:#ef4444}.loc-panel-body{padding:20px;flex:1}.loc-detail-info-grid{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:20px;padding:14px 16px;background:#f8fafc;border-radius:10px;border:1px solid #f1f5f9}.loc-detail-info-field{display:flex;flex-direction:column;gap:4px}.loc-detail-info-label{font-size:11px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.loc-detail-info-value{font-size:13px;font-weight:500;color:#334155}.loc-items-section-title{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:#334155;margin-bottom:10px}.loc-items-list{display:flex;flex-direction:column;gap:8px}.loc-item-card{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid #f1f5f9;border-radius:10px;transition:border-color .15s}.loc-item-card:hover{border-color:#e2e8f0}.loc-item-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.loc-item-icon-unit{background-color:#eef2ff;color:#6366f1}.loc-item-icon-tool{background-color:#fff7ed;color:#f97316}.loc-item-info{flex:1;min-width:0}.loc-item-name{font-size:13px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loc-panel-footer{padding:16px 20px;border-top:1px solid #f1f5f9}.loc-complete-section--done{background-color:#f0fdf4;border-color:#bbf7d0}.loc-complete-section--done .loc-complete-info{margin-bottom:0;align-items:center}.loc-completed-badge{display:inline-block;margin-top:12px;width:100%;text-align:center;padding:8px;background-color:#16a34a;color:#fff;border-radius:8px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.loc-tab-row{display:flex;gap:4px;padding:4px 0 8px;flex-shrink:0}.loc-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}.loc-tab-btn.active{background-color:#6366f1;color:#fff}.loc-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.trk-wrapper{display:flex;flex-direction:column;gap:0;min-height:100%;background:#f1f5f9;width:100%}.trk-tabs{display:flex;gap:4px;margin-bottom:4px;padding:4px 0}.trk-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.trk-tab-btn.active{background-color:#6366f1;color:#fff}.trk-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.trk-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px;width:100%;max-width:100%;overflow:hidden;flex-wrap:nowrap;box-sizing:border-box}.trk-toolbar-left{display:flex;align-items:center;gap:8px;flex:1 1 0;min-width:0;overflow:hidden}.trk-toolbar-right{display:flex;gap:8px;align-items:center;flex-shrink:0}.trk-filter-btn{display:flex;align-items:center;gap:7px;padding:10px 16px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;font-family:inherit}.trk-type-dropdown-wrap{position:relative}.trk-date-wrap{position:relative;display:flex;align-items:center}.trk-date-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.trk-date-clear{position:absolute;right:-20px;background:none;border:none;color:#94a3b8;cursor:pointer;font-size:16px;padding:0 4px}.trk-date-clear:hover{color:#ef4444}.trk-refresh-btn{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;border-radius:8px;transition:all .2s}.trk-refresh-btn:hover{background-color:#f1f5f9;color:#334155}@keyframes trkSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.trk-search-container{display:flex;align-items:center;gap:10px;padding:10px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:1 1 120px;min-width:80px;max-width:260px;transition:all .2s;overflow:hidden}.trk-search-container:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;background-color:#fff}.trk-search-container svg{color:#94a3b8;flex-shrink:0}.trk-search-input{border:none;outline:none;flex:1;font-size:14px;color:#334155;background:transparent;min-width:0}.trk-search-input::placeholder{color:#cbd5e1}.trk-table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;min-width:0;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.trk-super-header-wrap{flex-shrink:0;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;display:flex;align-items:center;justify-content:center;padding:14px 20px}.trk-super-header{font-size:13px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px}.trk-table-scroll{width:100%;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 280px);--header-h: 49px;box-sizing:border-box}.trk-table-scroll::-webkit-scrollbar{height:8px;width:8px}.trk-table-scroll::-webkit-scrollbar-track{background:#f1f5f9;margin-top:var(--header-h)}.trk-table-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.trk-table-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.trk-table-scroll::-webkit-scrollbar-corner{background:#f1f5f9}.trk-table-footer{height:8px}.trk-table{width:max-content;min-width:100%;border-collapse:collapse;table-layout:auto}.trk-table thead{position:sticky;top:0;z-index:10;background-color:#f8fafc}.trk-table th{padding:12px 16px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap;text-align:left;background-color:#f8fafc}.trk-th-expand{width:40px;padding:12px 8px 12px 16px!important}.trk-col-date,.trk-col-assetname,.trk-col-type,.trk-col-project,.trk-col-company,.trk-col-result{padding:12px 16px}.trk-col-p2hscore{padding:12px 16px;width:110px;text-align:center}.trk-table td{padding:12px 16px;font-size:13px;color:#334155;white-space:nowrap;border-bottom:1px solid #f1f5f9}.trk-td-expand{padding:12px 8px 12px 16px!important}.trk-row{cursor:pointer;transition:background-color .15s}.trk-row:hover{background-color:#f8fafc}.trk-row.expanded{background-color:#f5f3ff}.trk-expand-arrow{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background-color:#f1f5f9;color:#64748b;transition:transform .25s ease,background-color .2s}.trk-expand-arrow.open{transform:rotate(180deg);background-color:#eff0fe;color:#6366f1}.trk-detail-tr td{border-bottom:1px solid #e2e8f0}.trk-detail-wrap{background-color:#fafbff;border-top:1px solid #e2e8f0}.trk-detail-super-header{padding:12px 20px 12px 16px;font-size:13px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid #e2e8f0;background-color:#f1f5f9;text-align:left}.trk-detail-scroll{max-height:260px;overflow-y:auto;overflow-x:hidden}.trk-detail-scroll--hm{max-height:206px}.trk-detail-scroll::-webkit-scrollbar{width:6px}.trk-detail-scroll::-webkit-scrollbar-track{background:#f1f5f9}.trk-detail-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.trk-detail-table{width:100%;min-width:0;border-collapse:collapse;table-layout:auto}.trk-detail-table thead{background-color:#f1f5f9;position:sticky;top:0;z-index:4}.trk-detail-th-q,.trk-detail-th-r{padding:10px 16px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;border-bottom:1px solid #e2e8f0;text-align:left}.trk-detail-th-q{padding-left:16px;padding-right:20px}.trk-detail-th-r{border-left:1px solid #e2e8f0;padding-left:24px}.trk-detail-row{border-bottom:1px solid #f1f5f9}.trk-detail-row:last-child{border-bottom:none}.trk-detail-row:hover{background-color:#f5f3ff}.trk-detail-q{padding:10px 20px 10px 16px;font-size:13px;color:#334155;white-space:nowrap;vertical-align:middle;max-width:220px;overflow:hidden;text-overflow:ellipsis}.trk-detail-r{padding:10px 16px;white-space:nowrap;border-left:1px solid #f1f5f9;vertical-align:middle}.trk-check-result{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;white-space:nowrap}.trk-check-option{display:flex;align-items:center;gap:6px;font-size:12px;color:#94a3b8;font-weight:500}.trk-check-option.checked.good{color:#16a34a;font-weight:700}.trk-check-option.checked.broken{color:#dc2626;font-weight:700}.trk-check-circle{width:18px;height:18px;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#fff}.trk-check-option.checked.good .trk-check-circle{border-color:#16a34a;background-color:#dcfce7;color:#16a34a}.trk-check-option.checked.broken .trk-check-circle{border-color:#dc2626;background-color:#fee2e2;color:#dc2626}.trk-detail-loading,.trk-detail-empty{padding:24px;text-align:center;font-size:13px;color:#94a3b8}.trk-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;gap:12px}.trk-empty-title{font-size:16px;font-weight:600;color:#334155;margin:0}.trk-empty-sub{font-size:13px;color:#94a3b8;margin:0;text-align:center;max-width:380px;line-height:1.6}.trk-page-title{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 8px}.trk-modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:transparent;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1000;animation:trkFadeIn .2s ease}.trk-modal-content{position:absolute;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:8px;min-width:200px;max-height:320px;overflow-y:auto}.trk-type-option{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;border-radius:8px;transition:background-color .2s}.trk-type-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#6366f1}.trk-type-option label{font-size:14px;color:#334155;cursor:pointer;flex:1}.trk-detail-tr>td{white-space:normal!important;padding:0!important}.trk-extra-info-wrap{display:flex;flex-wrap:wrap;gap:0;padding:14px 16px;background-color:#fafbff;border-bottom:1px solid #e8ecf4}.trk-extra-info-row{display:flex;align-items:center;gap:8px;min-width:200px;flex:0 0 auto}.trk-extra-col-operator,.trk-extra-col-workshift,.trk-extra-col-fittowork,.trk-extra-col-sleephours,.trk-extra-col-medicine,.trk-extra-col-medicinename,.trk-extra-col-remarks{padding:5px 20px 5px 0}.trk-extra-info-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.trk-extra-info-label:after{content:":"}.trk-extra-info-value{font-size:13px;color:#334155;white-space:nowrap}.trk-fit-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase}.trk-fit-badge.fit{background-color:#22c55e;color:#fff}.trk-fit-badge.notfit{background-color:#ef4444;color:#fff}.trk-col-status{width:40px;padding:12px 8px 12px 16px!important;text-align:center}.trk-row-empty{cursor:default!important;opacity:.7}.trk-row-empty:hover{background-color:transparent!important}.p2h-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f172a66;backdrop-filter:blur(1.5px);-webkit-backdrop-filter:blur(1.5px);z-index:1200;display:flex;align-items:center;justify-content:center;animation:p2hFadeIn .2s ease forwards}.p2h-modal-overlay.closing{animation:p2hFadeOut .18s ease forwards}@keyframes p2hFadeIn{0%{opacity:0}to{opacity:1}}@keyframes p2hFadeOut{0%{opacity:1}to{opacity:0}}.p2h-modal-box{background:#fff;border-radius:16px;box-shadow:0 24px 64px #00000038;width:680px;max-width:calc(100vw - 48px);max-height:82vh;display:flex;flex-direction:column;overflow:hidden;animation:p2hModalIn .22s ease forwards}.p2h-modal-box.closing{animation:p2hModalOut .18s ease forwards}@keyframes p2hModalIn{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes p2hModalOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.96) translateY(10px)}}.p2h-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9;flex-shrink:0}.p2h-modal-title{font-size:17px;font-weight:700;color:#1e293b}.p2h-modal-subtitle{font-size:12px;color:#94a3b8;margin-top:3px}.p2h-modal-close-btn{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background-color .15s;flex-shrink:0}.p2h-modal-close-btn:hover{color:#334155;background-color:#f1f5f9}.p2h-modal-body{overflow-y:auto;flex:1;min-height:0;padding:20px 24px 24px}.p2h-modal-body::-webkit-scrollbar{width:6px}.p2h-modal-body::-webkit-scrollbar-track{background:#f8fafc}.p2h-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.p2h-modal-section-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}.p2h-modal-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.p2h-modal-info-card{background-color:#f8fafc;border:1px solid #e8ecf4;border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:5px;min-width:0}.p2h-modal-info-card-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}.p2h-modal-info-card-value{font-size:13px;font-weight:600;color:#334155;word-break:break-word}.p2h-modal-questions-grid{column-count:2;column-gap:8px}.p2h-modal-q-card{background-color:#f8fafc;border:1px solid #e8ecf4;border-radius:10px;padding:11px 14px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px;min-width:0;break-inside:avoid;margin-bottom:8px}.p2h-modal-q-card.broken{background-color:#fff5f5;border-color:#fecaca}.p2h-modal-q-text{font-size:13px;color:#334155;line-height:1.5;flex:1;min-width:0;word-break:break-word;white-space:normal}.p2h-modal-q-text-value{font-size:13px;font-weight:600;color:#334155;flex-shrink:0}.p2h-modal-check-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.p2h-modal-check-icon.good{background-color:#dcfce7;color:#16a34a}.p2h-modal-check-icon.broken{background-color:#fee2e2;color:#dc2626}.p2h-modal-check-icon.unknown{background-color:#f1f5f9;color:#94a3b8;font-size:13px;font-weight:600}.p2h-modal-loading,.p2h-modal-empty{padding:24px 0;text-align:center;font-size:13px;color:#94a3b8}.trk-col-approval{padding:12px 16px;white-space:nowrap}.trk-modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:transparent;backdrop-filter:blur(1.5px);-webkit-backdrop-filter:blur(1.5px);z-index:1000;animation:trkFadeIn .2s ease}.trk-modal-overlay.active{display:block}@keyframes trkFadeIn{0%{opacity:0}to{opacity:1}}.trk-modal-content{position:fixed;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:8px;min-width:160px;max-height:320px;overflow-y:auto;z-index:1001}.trk-modal-content.animating-in{animation:trkSlideDown .2s ease forwards}@keyframes trkSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.trk-type-option{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;border-radius:8px;transition:background-color .2s}.trk-type-option:hover{background-color:#f8fafc}.trk-type-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.trk-type-option label{font-size:13px;color:#334155;cursor:pointer;flex:1}.trk-filter-btn{display:flex;align-items:center;gap:6px;padding:7px 12px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:12px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;font-family:inherit}.trk-filter-btn:hover{background-color:#6366f10f;border-color:#6366f14d;color:#6366f1}.trk-filter-btn.active{background-color:#eff0fe;border-color:#6366f1;color:#6366f1}.dashboard-page{padding:0 0 40px;display:flex;flex-direction:column;gap:20px;min-height:100%;background:#f1f5f9}.dash-topbar{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.dash-tabs{display:flex;gap:4px;padding:4px 0}.dash-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.dash-tab-btn.active{background-color:#6366f1;color:#fff;overflow:visible}.dash-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.dash-sparepart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:12px}.dash-sparepart-icon{font-size:48px;opacity:.3}.dash-sparepart-title{font-size:16px;font-weight:600;color:#64748b;margin:0}.dash-sparepart-sub{font-size:13px;color:#94a3b8;margin:0}.dash-range-btns{display:flex;gap:6px}.dash-range-btn{background:#fff;border:1px solid #e2e8f0;color:#64748b;font-size:12px;padding:6px 14px;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.dash-range-btn:hover{border-color:#6366f1;color:#6366f1}.dash-range-btn.active{background:#6366f1;border-color:#6366f1;color:#fff}.dash-spinner{display:flex;justify-content:center;align-items:center;height:300px}.dash-spin{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dash-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.mt-kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}.kpi-card{background:#fff;border-radius:12px;padding:22px 24px;position:relative;overflow:hidden;box-shadow:0 1px 3px #00000012;border-top:3px solid transparent;animation:fadeUp .4s ease both;display:flex;flex-direction:column;justify-content:center;min-height:110px}.mt-kpi-row .kpi-card{padding:16px 18px;min-height:96px}.kpi-card:nth-child(1){animation-delay:.05s;border-top-color:#00d4ff}.kpi-card:nth-child(2){animation-delay:.1s;border-top-color:#7c3aed}.kpi-card:nth-child(3){animation-delay:.15s;border-top-color:#f59e0b}.kpi-card:nth-child(4){animation-delay:.2s;border-top-color:#10b981}.kpi-card:nth-child(5){animation-delay:.25s;border-top-color:#7c3aed}.mt-kpi-row .kpi-card:nth-child(1){border-top-color:#00d4ff}.mt-kpi-row .kpi-card:nth-child(2){border-top-color:#ef4444}.mt-kpi-row .kpi-card:nth-child(3){border-top-color:#f59e0b}.mt-kpi-row .kpi-card:nth-child(4){border-top-color:#10b981}.mt-kpi-row .kpi-card:nth-child(5){border-top-color:#7c3aed}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-18px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}@keyframes donutSpin{0%{stroke-dashoffset:220;opacity:0}to{opacity:1}}@keyframes countUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes barGrow{0%{width:0!important}}@keyframes heatPop{0%{transform:scale(0);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes rankSlide{0%{opacity:0;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes accPop{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.kpi-icon{position:absolute;right:20px;top:50%;transform:translateY(-50%);opacity:.25;pointer-events:none;z-index:0}.kpi-blue .kpi-icon{color:#0284c7}.kpi-purple .kpi-icon{color:#7c3aed}.kpi-amber .kpi-icon{color:#d97706}.kpi-green .kpi-icon{color:#059669}.kpi-red .kpi-icon{color:#dc2626}.kpi-label,.kpi-value,.kpi-sub{padding-right:56px;position:relative;z-index:1}.kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:#94a3b8;margin-bottom:8px;font-weight:600}.kpi-value{font-size:32px;font-weight:700;line-height:1;margin-bottom:6px;font-variant-numeric:tabular-nums}.mt-kpi-row .kpi-value{font-size:26px}.kpi-blue .kpi-value{color:#0284c7}.kpi-purple .kpi-value{color:#7c3aed}.kpi-amber .kpi-value{color:#d97706}.kpi-green .kpi-value{color:#059669}.kpi-red .kpi-value{color:#dc2626}.kpi-sub{font-size:12px;color:#94a3b8}.dash-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000012;overflow:hidden;animation:fadeUp .45s ease both}.dash-grid2>.dash-card:nth-child(1),.sp-row2>.dash-card:nth-child(1){animation-delay:.05s}.dash-grid2>.dash-card:nth-child(2),.sp-row2>.dash-card:nth-child(2){animation-delay:.12s}.sp-page>.dash-card:nth-child(1){animation-delay:.08s}.sp-page>.dash-card:nth-child(2){animation-delay:.14s}.sp-page>.dash-card:nth-child(3){animation-delay:.2s}.sp-page>.dash-card:nth-child(4){animation-delay:.26s}.sp-page>.dash-card:nth-child(5){animation-delay:.32s}.dash-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #f1f5f9}.dash-card-title{font-size:16px;font-weight:700;color:#1e293b;letter-spacing:-.01em}.dash-card-subtitle{font-size:11px;color:#94a3b8;margin-top:3px}.dash-card-right{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:12px}.dash-tag{font-size:10px;font-weight:600;letter-spacing:.8px;color:#64748b;background:#f1f5f9;border:1px solid #e2e8f0;padding:3px 9px;border-radius:99px;white-space:nowrap}.dash-card-body{padding:16px 20px}.dash-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dash-grid3{display:grid;grid-template-columns:1.4fr 1fr;gap:16px}.dash-grid3b{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.dash-col-right{display:flex;flex-direction:column;gap:16px}.loc-history-card{height:260px;display:flex;flex-direction:column}.loc-history-card .dash-card-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column;padding-bottom:12px}.loc-history-card .loc-timeline{flex:1;min-height:0;max-height:none;overflow-y:auto}.loc-timeline{display:flex;flex-direction:column;max-height:260px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.loc-timeline::-webkit-scrollbar{width:4px}.loc-timeline::-webkit-scrollbar-track{background:transparent}.loc-timeline::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:99px}.loc-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid #f1f5f9}.loc-item:last-child{border-bottom:none}.loc-dot{width:10px;height:10px;border-radius:50%;margin-top:4px;flex-shrink:0}.dot-active{background:#10b981;box-shadow:0 0 0 3px #10b98133}.dot-past{background:#cbd5e1}.loc-info{flex:1;min-width:0}.loc-name{font-size:13px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loc-meta{font-size:11px;color:#94a3b8;margin-top:2px}.dash-pill{font-size:10px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap;flex-shrink:0}.pill-active{background:#dbeafe;color:#1d4ed8}.pill-maintenance{background:#fef9c3;color:#854d0e}.pill-standby{background:#dcfce7;color:#15803d}.pill-disposed{background:#fee2e2;color:#b91c1c}.pill-idle{background:#f1f5f9;color:#64748b}.bar-chart{display:flex;flex-direction:column;gap:10px}.bar-row{display:flex;align-items:center;gap:10px}.bar-label{width:96px;font-size:11px;color:#64748b;text-align:right;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bar-track{flex:1;height:22px;background:#f1f5f9;border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px;display:flex;align-items:center;padding-left:8px;font-size:11px;font-weight:700;color:#fff;transition:width .8s ease;min-width:4px}.bar-high{background:linear-gradient(90deg,#ef4444,#f87171)}.bar-med{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.bar-low{background:linear-gradient(90deg,#10b981,#34d399)}.bar-count{font-size:11px;font-weight:600;color:#64748b;width:28px;text-align:right;flex-shrink:0}.bar-insight{display:flex;gap:16px;margin-top:14px;padding-top:12px;border-top:1px solid #f1f5f9;font-size:11px;color:#64748b}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px}.dot.red{background:#ef4444}.dot.green{background:#10b981}.dot.amber{background:#f59e0b}.rank-list{display:flex;flex-direction:column;gap:8px}.rank-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border-radius:10px;border:1.5px solid #e2e8f0;box-shadow:0 1px 4px #0000000d;transition:border-color .2s,box-shadow .2s;animation:rankSlide .4s ease both}.rank-list .rank-item:nth-child(1){animation-delay:.1s}.rank-list .rank-item:nth-child(2){animation-delay:.16s}.rank-list .rank-item:nth-child(3){animation-delay:.22s}.rank-list .rank-item:nth-child(4){animation-delay:.28s}.rank-list .rank-item:nth-child(5){animation-delay:.34s}.rank-list .rank-item:nth-child(6){animation-delay:.4s}.rank-list .rank-item:nth-child(7){animation-delay:.46s}.rank-list .rank-item:nth-child(8){animation-delay:.52s}.rank-list .rank-item:nth-child(9){animation-delay:.58s}.rank-list .rank-item:nth-child(10){animation-delay:.64s}.rank-item:hover{border-color:#6366f1;box-shadow:0 2px 8px #6366f11a}.rank-num{font-size:12px;font-weight:700;width:22px;text-align:center;flex-shrink:0;font-variant-numeric:tabular-nums}.rank-1,.rank-2,.rank-3,.rank-rest{color:#475569}.rank-info{flex:1;min-width:0}.rank-name{font-size:13px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rank-type{font-size:11px;color:#94a3b8}.rank-bar{width:60px;height:4px;background:#e2e8f0;border-radius:99px;overflow:hidden;flex-shrink:0}.rank-bar-fill{height:100%;background:#10b981;border-radius:99px;transition:width .8s ease}.rank-score{font-size:13px;font-weight:700;width:28px;text-align:right;flex-shrink:0}.score-green{color:#059669}.score-amber{color:#d97706}.score-red{color:#dc2626}.donut-wrap{display:flex;align-items:center;justify-content:center;gap:24px;padding:8px 0}.donut-wrap svg{animation:scaleIn .55s cubic-bezier(.34,1.56,.64,1) both;animation-delay:.15s}.donut-wrap circle:not(:first-child){animation:donutSpin .7s ease both}.donut-wrap circle:nth-child(2){animation-delay:.2s}.donut-wrap circle:nth-child(3){animation-delay:.3s}.donut-wrap circle:nth-child(4){animation-delay:.4s}.donut-wrap circle:nth-child(5){animation-delay:.5s}.donut-wrap .donut-legend{animation:slideInRight .45s ease both;animation-delay:.35s}.donut-legend{display:flex;flex-direction:column;gap:10px}.legend-row{display:flex;align-items:center;gap:8px;font-size:13px;animation:fadeIn .4s ease both}.legend-row:nth-child(1){animation-delay:.4s}.legend-row:nth-child(2){animation-delay:.5s}.legend-row:nth-child(3){animation-delay:.6s}.legend-row:nth-child(4){animation-delay:.7s}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-label{color:#475569;flex:1}.legend-val{font-weight:700;font-size:14px;min-width:20px;text-align:right}.heatmap-linechart-card{max-height:200px;overflow:hidden}.heatmap-linechart-card .dash-card-body{display:flex;flex-direction:column;overflow:hidden}.heat-month-labels{display:grid;grid-template-columns:repeat(12,1fr);gap:4px;margin-bottom:5px}.heat-month-label{font-size:9px;color:#94a3b8;text-align:center}.heat-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:4px}.heat-cell{aspect-ratio:1;border-radius:3px;cursor:default;transition:transform .15s;animation:heatPop .35s ease both}.heat-cell:hover{transform:scale(1.3)}.heat-0{background:#f1f5f9}.heat-1{background:#10b98140}.heat-2{background:#10b98180}.heat-3{background:#f59e0b80}.heat-4{background:#ef444473}.heat-5{background:#ef4444cc}.heat-legend{display:flex;align-items:center;gap:5px;font-size:10px;color:#94a3b8;margin-top:8px}.heat-legend-cell{width:12px;height:12px;border-radius:2px}.heat-nav{display:flex;align-items:center;gap:6px}.heat-nav-btn{background:none;border:1px solid #e2e8f0;border-radius:6px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;font-size:16px;color:#64748b;cursor:pointer;line-height:1;padding:0;transition:all .2s;font-family:inherit}.heat-nav-btn:hover:not(:disabled){border-color:#6366f1;color:#6366f1}.heat-nav-btn:disabled{opacity:.3;cursor:not-allowed}.heat-nav-dots{display:flex;gap:5px;align-items:center}.heat-nav-dot{width:6px;height:6px;border-radius:50%;background:#e2e8f0;cursor:pointer;transition:background .2s}.heat-nav-dot.active{background:#6366f1}.linechart-wrap{position:relative;width:100%;-webkit-user-select:none;user-select:none;flex:1;display:flex;flex-direction:column}.linechart-svg{width:100%;height:90px;display:block;overflow:visible;cursor:crosshair}.linechart-xlabels{position:relative;height:18px;margin-top:2px}.linechart-xlabel{position:absolute;transform:translate(-50%);font-size:9px;color:#94a3b8;white-space:nowrap}.linechart-ymax{position:absolute;top:2px;right:0;font-size:9px;color:#94a3b8;font-variant-numeric:tabular-nums}.linechart-tooltip{position:absolute;background:#1e293b;border-radius:7px;padding:6px 10px;pointer-events:none;z-index:10;white-space:nowrap;box-shadow:0 4px 12px #00000026}.linechart-tooltip-label{font-size:10px;color:#94a3b8;margin-bottom:2px}.linechart-tooltip-value{font-size:13px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.linechart-tooltip-value span{font-size:10px;font-weight:400;color:#6366f1;margin-left:2px}.downtime-list{display:flex;flex-direction:column;gap:12px}.downtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px;gap:8px}.downtime-label{font-size:11px;color:#64748b;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.downtime-label-full{font-size:12px;font-weight:500;color:#1e293b;flex:1}.downtime-val{font-size:12px;font-weight:700;flex-shrink:0}.downtime-track{height:6px;background:#f1f5f9;border-radius:99px;overflow:hidden}.downtime-fill{height:100%;border-radius:99px;transition:width .8s ease}.dt-red{color:#dc2626}.dt-amber{color:#d97706}.dt-green{color:#059669}.dt-fill-red{background:linear-gradient(90deg,#ef4444,#f87171)}.dt-fill-amber{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.dt-fill-green{background:linear-gradient(90deg,#10b981,#34d399)}.downtime-insight{font-size:11px;color:#64748b;margin-top:8px;padding-top:8px;border-top:1px solid #f1f5f9}.detail-filters{display:flex;gap:8px;align-items:center}.detail-search-wrap{display:flex;align-items:center;gap:6px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:0 10px;transition:border-color .2s}.detail-search-wrap:focus-within{border-color:#6366f1}.detail-search-input{background:transparent;border:none;outline:none;color:#1e293b;font-size:12px;padding:6px 0;width:160px;font-family:inherit}.dash-input{background:#f8fafc;border:1px solid #e2e8f0;color:#1e293b;font-size:12px;padding:6px 12px;border-radius:6px;outline:none;width:180px;font-family:inherit;transition:border-color .2s}.dash-input:focus{border-color:#6366f1}.dash-select{background:#f8fafc;border:1px solid #e2e8f0;color:#1e293b;font-size:12px;padding:6px 10px;border-radius:6px;font-family:inherit;cursor:pointer}.detail-table-wrap{overflow-x:auto;margin:0 -20px;padding:0 20px}.detail-table{width:100%;border-collapse:collapse;font-size:12px}.detail-table thead{position:sticky;top:0;z-index:2;background:#f8fafc}.detail-table th{text-align:left;padding:10px 12px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#64748b;font-weight:700;background:#f8fafc;border-bottom:1.5px solid #e2e8f0;white-space:nowrap}.detail-table td{padding:11px 12px;border-bottom:1px solid #f8fafc;color:#1e293b;vertical-align:middle}.detail-table tr:last-child td{border-bottom:none}.detail-table tbody tr:hover td{background:#f8fafc}.td-tag{color:#1e293b;font-weight:600;font-size:11px}.td-muted{color:#94a3b8!important}.td-center{text-align:center}.td-mono{font-variant-numeric:tabular-nums}.detail-empty{text-align:center;color:#94a3b8;padding:30px 0;font-size:13px}.score-wrap{display:flex;align-items:center;gap:8px}.score-bar{width:60px;height:4px;background:#e2e8f0;border-radius:99px;overflow:hidden;flex-shrink:0}.score-fill{height:100%;border-radius:99px}.score-fill.score-green{background:#10b981}.score-fill.score-amber{background:#f59e0b}.score-fill.score-red{background:#ef4444}.score-num{font-size:12px;font-weight:700}.detail-pagination{display:flex;justify-content:space-between;align-items:center;padding-top:14px;margin-top:4px;border-top:1px solid #f1f5f9}.pagination-info{font-size:12px;color:#94a3b8}.pagination-btns{display:flex;gap:6px}.pg-btn{background:#fff;border:1px solid #e2e8f0;color:#64748b;font-size:12px;padding:6px 14px;border-radius:6px;cursor:pointer;transition:all .2s;font-family:inherit}.pg-btn:hover:not(:disabled){border-color:#6366f1;color:#6366f1}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.dash-empty{text-align:center;color:#94a3b8;padding:24px 0;font-size:12px}.kpi-card-clickable{transition:transform .15s ease,box-shadow .15s ease}.kpi-card-clickable:hover{transform:translateY(-2px);box-shadow:0 8px 24px #6366f126}.kpi-card-clickable:active{transform:translateY(0)}.asset-modal-overlay{background-color:#0f172a59!important;-webkit-backdrop-filter:blur(1.5px)!important;backdrop-filter:blur(1.5px)!important}.asset-modal-overlay.closing{animation:trkFadeOut .18s ease forwards}@keyframes trkFadeOut{0%{opacity:1}to{opacity:0}}.asset-list-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:560px;max-width:calc(100vw - 48px);max-height:70vh;display:flex;flex-direction:column;animation:assetModalIn .22s ease forwards;overflow:hidden}.asset-list-modal.closing{animation:assetModalOut .18s ease forwards}@keyframes assetModalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes assetModalOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.96) translateY(8px)}}.asset-list-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9;flex-shrink:0}.asset-list-modal-title{font-size:16px;font-weight:700;color:#1e293b}.asset-list-modal-subtitle{font-size:12px;color:#94a3b8;margin-top:2px}.asset-list-modal-close{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background-color .15s;flex-shrink:0}.asset-list-modal-close:hover{color:#334155;background-color:#f1f5f9}.asset-list-modal-scroll{overflow-y:auto;flex:1;min-height:0}.asset-list-modal-scroll::-webkit-scrollbar{width:8px;height:8px}.asset-list-modal-scroll::-webkit-scrollbar-track{background:#f8fafc}.asset-list-modal-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.asset-list-table{width:100%;border-collapse:collapse;table-layout:fixed}.asset-list-table thead{position:sticky;top:0;z-index:2;background:#f8fafc}.asset-list-table th{padding:10px 20px;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid #e2e8f0}.asset-list-table th:nth-child(1){width:44%}.asset-list-table th:nth-child(2){width:29%}.asset-list-table th:nth-child(3){width:27%}.asset-list-group-row td{padding:8px 20px 5px;background-color:#f8fafc;border-top:1px solid #e2e8f0;border-bottom:1px solid #f1f5f9}.asset-list-group-row:first-child td{border-top:none}.asset-list-group-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;display:flex;align-items:center;gap:8px}.asset-list-group-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:10px;padding:0 5px;font-size:10px;font-weight:700;color:#fff}.asset-list-row{border-bottom:1px solid #f8fafc;transition:background-color .12s}.asset-list-row:hover{background-color:#f8fafc}.asset-list-row td{padding:11px 20px;vertical-align:middle}.asset-list-name{font-size:13px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-list-tag{font-size:11px;color:#94a3b8;margin-top:1px}.asset-list-location{font-size:13px;color:#475569;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.dt-modal{width:500px}.dt-modal .asset-list-table{table-layout:fixed}.dt-modal .asset-list-table th:nth-child(1){width:fixed}.dt-modal .asset-list-table th:nth-child(2){width:fixed}.dt-modal .asset-list-table th:nth-child(3){width:0}.dt-log-table th:nth-child(1){width:60px}.dt-log-table th:nth-child(2){width:60px}.dt-log-table th:nth-child(3){width:70px}.dt-parent-row{cursor:pointer!important}.dt-parent-row.expanded{background-color:#f5f3ff}.dt-avg-val{font-size:13px;font-weight:700;color:#f59e0b;display:block}.dt-avg-sub{font-size:11px;color:#94a3b8;margin-top:1px;display:block}.dt-log-wrap{background-color:#fafbff;border-top:1px solid #e8ecf4}.dt-log-loading{padding:16px 24px;font-size:13px;color:#94a3b8;text-align:center}.dt-log-table{width:100%;border-collapse:collapse;table-layout:fixed}.dt-log-table thead{background-color:#f1f5f9;position:sticky;top:0;z-index:2}.dt-log-table th{padding:8px 20px;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid #e2e8f0}.dt-log-row{border-bottom:1px solid #f1f5f9;transition:background-color .12s}.dt-log-row:last-child{border-bottom:none}.dt-log-row:hover{background-color:#f5f3ff}.dt-log-row td{padding:9px 20px;font-size:13px;color:#334155;white-space:nowrap}.dt-log-row td:nth-child(3){font-weight:600;color:#f59e0b}.wo-incident-modal{width:740px}.wo-incident-modal .asset-list-table th:nth-child(1){width:25%}.wo-incident-modal .asset-list-table th:nth-child(2){width:13%}.wo-incident-modal .asset-list-table th:nth-child(3){width:14%}.wo-incident-modal .asset-list-table th:nth-child(4){width:48%}.wo-detail-modal{width:min(95vw,1100px)}.wo-detail-table{table-layout:auto;font-size:12px}.wo-detail-table th{white-space:nowrap;font-size:11px}.asset-search-wrap{position:relative;width:35%;margin-top:16px;margin-bottom:2px}.asset-search-box{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;padding:10px 16px;cursor:text;transition:border-color .15s;box-shadow:0 1px 4px #0000000a}.asset-search-box:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.asset-search-input{flex:1;border:none;outline:none;font-size:14px;color:#1e293b;background:transparent}.asset-search-input::placeholder{color:#94a3b8}.asset-search-clear{background:none;border:none;cursor:pointer;padding:2px;display:flex;align-items:center;opacity:.6}.asset-search-clear:hover{opacity:1}.asset-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:0 8px 24px #0000001a;z-index:200;max-height:320px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#e2e8f0 transparent}.asset-search-dropdown::-webkit-scrollbar{width:6px}.asset-search-dropdown::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}.asset-search-item{padding:12px 16px;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background .1s}.asset-search-item:last-child{border-bottom:none}.asset-search-item:hover{background:#f8fafc}.asset-search-empty{color:#94a3b8;font-size:13px;cursor:default;text-align:center;padding:20px}.asset-search-name{font-size:14px;font-weight:600;color:#1e293b;margin-bottom:4px}.asset-search-meta{display:flex;align-items:center;gap:8px}.asset-search-tag{font-size:12px;color:#64748b;font-family:monospace}.asset-tracking-card{height:fit-content;align-self:flex-start}.atrk-wrap{display:flex;flex-direction:column;gap:8px}.atrk-section-label{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em}.atrk-p2h-box{display:flex;align-items:center;gap:0;padding:0;overflow:hidden}.atrk-p2h-box.rank-item:hover{border-color:#e2e8f0;box-shadow:0 1px 4px #0000000d}.atrk-p2h-clickable{display:flex;align-items:center;gap:10px;flex:1;min-width:0;padding:12px 10px 12px 14px;border-radius:8px 0 0 8px;transition:background-color .15s}.atrk-p2h-clickable.is-clickable{cursor:pointer}.atrk-p2h-clickable.is-clickable:hover{background-color:#f5f5ff}.atrk-arrows-group{display:flex;align-items:center;gap:4px;flex-shrink:0;padding:12px 10px 12px 4px}.atrk-arrow{background:none;border:1px solid #e2e8f0;border-radius:6px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:16px;color:#64748b;cursor:pointer;flex-shrink:0;transition:all .15s;line-height:1}.atrk-arrow:hover:not(:disabled){border-color:#6366f1;color:#6366f1;background:#eff0fe}.atrk-arrow:disabled{opacity:.3;cursor:default}.atrk-p2h-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.atrk-shift-label{font-size:10px;font-weight:700;color:#6366f1;text-transform:uppercase;letter-spacing:.05em}.atrk-asset-name{font-size:13px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.atrk-p2h-meta{display:flex;align-items:center;gap:8px;margin-top:2px}.atrk-operator{font-size:11px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.atrk-fit-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;text-transform:uppercase;flex-shrink:0}.atrk-fit-badge.fit{background:#dcfce7;color:#16a34a}.atrk-fit-badge.notfit{background:#fee2e2;color:#dc2626}.atrk-not-submitted{font-size:11px;color:#94a3b8;margin-top:2px}.atrk-status-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.atrk-status-icon.submitted{background:#dcfce7;color:#16a34a}.atrk-status-icon.pending{background:#fee2e2;color:#ef4444}.atrk-dots{display:flex;justify-content:center;gap:5px;margin-top:2px}.atrk-dot{width:6px;height:6px;border-radius:50%;background:#e2e8f0;cursor:pointer;transition:all .2s}.atrk-dot.active{background:#6366f1;transform:scale(1.2)}.atrk-dot.done{background:#22c55e}.atrk-dot.active.done{background:#6366f1}.wo-inline-table{width:max-content;min-width:100%}.detail-table-wrap{overflow-x:auto}.atrk-hm-box{display:flex;align-items:center;gap:10px;padding:12px 14px}.atrk-hm-box--clickable{transition:background-color .15s}.atrk-hm-box--clickable:hover{background-color:#f5f5ff;border-color:#e2e8f0;box-shadow:0 1px 4px #0000000d}.atrk-hm-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.asset-detail-card{display:flex;flex-direction:column;gap:14px;height:fit-content;align-self:flex-start;padding:12px 20px 20px}.asset-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.asset-detail-title{font-size:16px;font-weight:700;color:#1e293b;margin-bottom:2px}.asset-detail-sub{font-size:12px;color:#94a3b8}.asset-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.asset-detail-box{display:flex;flex-direction:column;gap:4px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px}.asset-detail-wide{grid-column:1 / -1}.asset-detail-label{font-size:10px;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.asset-detail-value{font-size:13px;font-weight:500;color:#334155;word-break:break-word}.asset-detail-box span[style]{width:fit-content}.sp-page{display:flex;flex-direction:column;gap:20px}.sp-kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.sp-kpi-card{animation:fadeUp .4s ease both}.sp-kpi-row .sp-kpi-card:nth-child(1){animation-delay:.05s}.sp-kpi-row .sp-kpi-card:nth-child(2){animation-delay:.12s}.sp-kpi-row .sp-kpi-card:nth-child(3){animation-delay:.19s}.sp-kpi-row .sp-kpi-card:nth-child(4){animation-delay:.26s}.sp-kpi-card{background:#fff;border-radius:12px;padding:22px 24px;border:1px solid #e2e8f0;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;min-height:110px}.sp-kpi-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.sp-kpi-blue:before{background:#6366f1}.sp-kpi-amber:before{background:#f59e0b}.sp-kpi-red:before{background:#ef4444}.sp-kpi-green:before{background:#22c55e}.sp-kpi-icon{position:absolute;right:20px;top:50%;transform:translateY(-50%);pointer-events:none;opacity:.25;z-index:0}.sp-kpi-blue .sp-kpi-icon{color:#6366f1}.sp-kpi-amber .sp-kpi-icon{color:#f59e0b}.sp-kpi-red .sp-kpi-icon{color:#ef4444}.sp-kpi-green .sp-kpi-icon{color:#22c55e}.sp-kpi-label,.sp-kpi-value,.sp-kpi-sub{padding-right:56px;position:relative;z-index:1}.sp-kpi-label{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-weight:600;margin-bottom:6px}.sp-kpi-value{font-size:32px;font-weight:700;line-height:1;margin-bottom:4px}.sp-kpi-sub{font-size:12px;color:#94a3b8}.sp-kpi-blue .sp-kpi-value{color:#6366f1}.sp-kpi-amber .sp-kpi-value{color:#f59e0b}.sp-kpi-red .sp-kpi-value{color:#ef4444}.sp-kpi-green .sp-kpi-value{color:#22c55e}.sp-row2{display:grid;grid-template-columns:280px 1fr;gap:16px}.sp-donut-wrap{display:flex;align-items:center;justify-content:center;padding:12px 0}.sp-donut-inner{display:flex;align-items:center;gap:24px}.sp-donut-svg{width:140px;height:140px;flex-shrink:0}.sp-donut-legend{display:flex;flex-direction:column;gap:10px}.sp-legend-item{display:flex;align-items:center;gap:8px}.sp-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sp-legend-label{font-size:13px;color:#475569;flex:1}.sp-legend-val{font-size:14px;font-weight:700;color:#1e293b}.sp-usage-list{display:flex;flex-direction:column;gap:10px}.sp-usage-row{display:flex;align-items:center;gap:10px;animation:slideInLeft .38s ease both}.sp-usage-list .sp-usage-row:nth-child(1){animation-delay:.08s}.sp-usage-list .sp-usage-row:nth-child(2){animation-delay:.16s}.sp-usage-list .sp-usage-row:nth-child(3){animation-delay:.24s}.sp-usage-list .sp-usage-row:nth-child(4){animation-delay:.32s}.sp-usage-list .sp-usage-row:nth-child(5){animation-delay:.4s}.sp-usage-rank{font-size:12px;font-weight:700;color:#94a3b8;width:22px;flex-shrink:0}.sp-usage-info{flex:1;min-width:0;overflow:hidden}.sp-usage-name{font-size:13px;font-weight:500;color:#334155;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-usage-bar-wrap{background:#f1f5f9;border-radius:4px;height:6px;overflow:hidden}.sp-usage-bar{height:100%;background:linear-gradient(90deg,#6366f1,#818cf8);border-radius:4px;transition:width .4s;animation:barGrow .7s ease both}.sp-usage-qty{font-size:13px;font-weight:700;color:#6366f1;white-space:nowrap;flex-shrink:0;min-width:48px;text-align:right}.sp-usage-qty small{font-size:10px;color:#94a3b8;font-weight:400}.sp-stock-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;line-height:1.4;letter-spacing:.01em;transition:opacity .18s ease;-webkit-font-smoothing:antialiased}.sp-stock-normal{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}.sp-stock-kritis{background:#fef9c3;color:#a16207;border:1px solid #fde68a}.sp-stock-habis{background:#fee2e2;color:#b91c1c;border:1px solid #fecaca}.sp-pm-wrap{display:flex;flex-direction:column;gap:24px}.sp-pm-type-block{display:flex;flex-direction:column;gap:8px}.sp-pm-type-header{font-size:13px;font-weight:700;color:#6366f1;padding:6px 12px;background:#eef2ff;border-radius:6px;display:inline-block;margin-bottom:4px}.sp-pm-row{display:flex;gap:0;align-items:flex-start;border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;animation:fadeUp .4s ease both}.sp-pm-hm-sidebar{flex:0 0 90px;min-width:90px;background:#334155;padding:16px 10px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:4px;align-self:stretch}.sp-pm-hm-badge{font-size:12px;font-weight:800;color:#fff;text-align:center;line-height:1.2}.sp-pm-hm-count{font-size:10px;color:#94a3b8}.sp-pm-items-area{flex:1;padding:12px;min-width:0}.sp-pm-items-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:8px}.sp-pm-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;border-left:3px solid #e2e8f0}.sp-pm-item.sp-stock-kritis{border-left-color:#f59e0b;background:#fffbeb}.sp-pm-item.sp-stock-habis{border-left-color:#ef4444;background:#fff1f1}.sp-pm-item-name{font-size:12px;font-weight:600;color:#334155;margin-bottom:4px}.sp-pm-item-meta{display:flex;align-items:center;gap:8px;margin-bottom:3px;flex-wrap:wrap}.sp-pm-qty{font-size:11px;color:#64748b}.sp-pm-item-loc{font-size:10px;color:#94a3b8}.sp-pm-pagination{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:8px;border-top:1px solid #f1f5f9}.sp-pg-btn{width:28px;height:28px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.sp-pg-btn:hover:not(:disabled){background:#6366f1;color:#fff;border-color:#6366f1}.sp-pg-btn:disabled{opacity:.3;cursor:default}.sp-pg-info{font-size:12px;color:#64748b}.sp-acc-list{display:flex;flex-direction:column;gap:8px}.sp-acc-item{border:1px solid #e2e8f0;border-radius:10px;overflow:hidden;transition:border-color .2s;animation:accPop .35s ease both}.sp-acc-item.open{border-color:#6366f1}.sp-acc-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:#f8fafc;transition:background .15s}.sp-acc-header:hover{background:#f1f5f9}.sp-acc-item.open .sp-acc-header{background:#eef2ff}.sp-acc-left{display:flex;align-items:center;gap:10px}.sp-acc-chevron{font-size:18px;color:#94a3b8;transition:transform .2s;display:inline-block;line-height:1}.sp-acc-chevron.open{transform:rotate(90deg);color:#6366f1}.sp-acc-name{font-size:14px;font-weight:700;color:#1e293b;margin-bottom:4px}.sp-acc-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.sp-acc-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.sp-acc-badges{display:flex;gap:6px;align-items:center}.sp-acc-total{font-size:11px;color:#94a3b8}.sp-acc-body{padding:0 16px 14px;border-top:1px solid #e2e8f0;background:#fff}.sp-loc-tag{font-size:11px;background:#e0e7ff;color:#4338ca;padding:2px 8px;border-radius:20px;font-weight:600}.sp-loc-type{font-size:11px;background:#f1f5f9;color:#64748b;padding:2px 8px;border-radius:20px}.sp-loc-location{font-size:11px;color:#94a3b8}.sp-loc-categories{padding-top:12px;display:flex;flex-wrap:wrap;gap:12px}.sp-loc-cat{flex:0 0 auto;min-width:180px}.sp-loc-cat-name{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6366f1;margin-bottom:6px}.sp-loc-items{display:flex;flex-direction:column;gap:5px}.sp-loc-item{background:#f8fafc;border-radius:6px;padding:6px 8px;border:1px solid #f1f5f9;border-left:3px solid #e2e8f0}.sp-loc-item-empty{border-left-color:#ef4444;background:#fff1f1}.sp-loc-item-kritis{border-left-color:#f59e0b;background:#fffbeb}.sp-loc-item-ok{border-left-color:#22c55e}.sp-alt-loc{font-size:10px;color:#6366f1;font-weight:500;background:#eef2ff;padding:2px 6px;border-radius:4px}.sp-loc-item-name{font-size:12px;font-weight:500;color:#334155;margin-bottom:3px}.sp-loc-item-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.sp-loc-code{font-size:10px;color:#94a3b8}.sp-loc-wh{font-size:10px;color:#64748b}.sp-critical-table-wrap{overflow-x:auto}.sp-critical-table{width:100%;border-collapse:collapse;font-size:13px}.sp-critical-table th{text-align:left;padding:10px 12px;background:#f8fafc;color:#64748b;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e2e8f0;white-space:nowrap}.sp-critical-table td{padding:10px 12px;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle}.sp-critical-table tbody tr:hover{background:#f8fafc}.sp-crit-name{font-weight:600;color:#1e293b}.sp-crit-code{font-size:11px;color:#94a3b8;font-family:monospace}.sp-crit-stock{font-weight:700;color:#ef4444}@media (max-width: 1100px){.sp-kpi-row{grid-template-columns:repeat(2,1fr)}.sp-row2{grid-template-columns:1fr}}.pmdue-summary{display:flex;gap:6px;align-items:center}.pmdue-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap}.pmdue-overdue{background:#fef2f2;color:#ef4444}.pmdue-duesoon{background:#fffbeb;color:#f59e0b}.pmdue-normal{background:#f0fdf4;color:#22c55e}.pmdue-list{display:flex;flex-direction:column;gap:8px}.pmdue-item{border:1px solid #e2e8f0;border-left:3px solid var(--status-color, #e2e8f0);border-radius:10px;overflow:hidden;transition:border-color .2s;animation:accPop .35s ease both}.pmdue-item.open{border-color:var(--status-color, #6366f1)}.pmdue-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;cursor:pointer;background:#f8fafc;transition:background .15s}.pmdue-header:hover{background:#f1f5f9}.pmdue-item.open .pmdue-header{background:#f8fafc}.pmdue-header-left{display:flex;align-items:center;gap:10px}.pmdue-chevron{font-size:18px;color:#94a3b8;transition:transform .2s;line-height:1}.pmdue-chevron.open{transform:rotate(90deg);color:#6366f1}.pmdue-asset-name{font-size:14px;font-weight:700;color:#1e293b;margin-bottom:4px}.pmdue-asset-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.pmdue-hm-current{font-size:11px;color:#64748b}.pmdue-hm-current strong{color:#1e293b}.pmdue-status-pill{font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;flex-shrink:0}.pmdue-body{border-top:1px solid #e2e8f0;background:#fff}.pmdue-interval{padding:14px 16px;border-left:3px solid #e2e8f0;margin:10px 12px;border-radius:0 8px 8px 0;background:#fafafa}.pmdue-interval-header{display:flex;gap:16px;align-items:flex-start;margin-bottom:10px}.pmdue-interval-info{display:flex;flex-direction:column;gap:4px;flex-shrink:0;min-width:180px}.pmdue-hm-label{font-size:12px;font-weight:700;color:#334155}.pmdue-hm-next{font-size:11px;color:#64748b}.pmdue-hm-next strong{color:#1e293b}.pmdue-sisa{font-size:11px;font-weight:700;padding:2px 8px;border-radius:4px;display:inline-block}.pmdue-progress-wrap{flex:1}.pmdue-progress-track{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden;margin-bottom:4px}.pmdue-progress-fill{height:100%;border-radius:4px;transition:width .6s ease;animation:barGrow .8s ease both}.pmdue-progress-labels{display:flex;justify-content:space-between;font-size:10px;color:#94a3b8}.pmdue-parts{margin-top:8px}.pmdue-parts-title{font-size:11px;font-weight:600;color:#64748b;margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em}.pmdue-parts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.pmdue-part-card{background:#fff;border:1px solid #e2e8f0;border-left:3px solid #e2e8f0;border-radius:6px;padding:8px 10px;min-width:0}.pmdue-part-clickable{transition:box-shadow .15s,transform .1s;-webkit-user-select:none;user-select:none}.pmdue-part-clickable:hover{box-shadow:0 2px 8px #6366f126;transform:translateY(-1px)}.pmdue-part-name{font-size:12px;font-weight:600;color:#334155;margin-bottom:5px}.pmdue-part-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:3px}.pmdue-part-needed{font-size:11px;color:#64748b}.pmdue-part-loc{font-size:10px;color:#94a3b8;display:flex;align-items:center;gap:3px}.sp-alt-loc-block{display:flex;align-items:center;gap:5px;margin-top:5px;padding:4px 8px;background:#eef2ff;border-radius:5px;flex-wrap:wrap}.sp-alt-loc-block.sp-alt-loc-none{background:#fff1f2}.sp-alt-loc-label{font-size:10px;color:#6366f1;font-weight:600}.sp-alt-loc-block.sp-alt-loc-none .sp-alt-loc-label{color:#ef4444}.sp-alt-loc-stock{font-size:11px;font-weight:700;color:#4338ca;background:#c7d2fe;padding:1px 6px;border-radius:4px}.sp-alt-loc-place{font-size:10px;color:#4338ca;font-weight:500}.chart-item-clickable{cursor:pointer;border-radius:8px;transition:box-shadow .18s ease,background .18s ease,opacity .18s ease}.chart-item-clickable:hover{box-shadow:0 2px 12px #6366f126;background:#6366f10d!important}.chart-item-clickable.chart-item-active{background:#6366f114!important;box-shadow:0 0 0 1.5px #6366f1}.chart-item-clickable.chart-item-dimmed{opacity:.35}.legend-row-clickable{cursor:pointer;border-radius:6px;padding:3px 6px;transition:box-shadow .18s ease,background .18s ease,opacity .18s ease}.legend-row-clickable:hover{box-shadow:0 2px 10px #6366f121;background:#6366f10d}.sp-kpi-card-clickable{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease;position:relative;overflow:hidden}.sp-kpi-card-clickable:hover{transform:translateY(-3px);box-shadow:0 8px 28px #6366f12e}.sp-kpi-card-clickable:active{transform:translateY(-1px)}.sp-kpi-click-hint{position:absolute;bottom:8px;right:12px;font-size:10px;color:#ffffffa6;font-weight:600;letter-spacing:.04em;pointer-events:none;display:flex;align-items:center;gap:3px}.sp-kpi-click-hint:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:#ffffffb3;animation:kpiPulse 1.6s ease-in-out infinite}@keyframes kpiPulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}.sp-kpi-modal{max-width:700px;width:90vw;max-height:80vh}.sp-modal-table{table-layout:fixed;width:100%}.sp-modal-table th{font-size:11px;padding:8px 10px;white-space:nowrap;overflow:hidden;background:#f8fafc;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.sp-modal-table td{padding:8px 10px;vertical-align:middle;border-bottom:1px solid #f1f5f9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-modal-table tbody tr:hover{background:#f8fafc}.sp-modal-table tbody tr:last-child td{border-bottom:none}.sp-modal-table th:nth-child(1),.sp-modal-table td:nth-child(1){width:28%}.sp-modal-table th:nth-child(2),.sp-modal-table td:nth-child(2){width:20%}.sp-modal-table th:nth-child(3),.sp-modal-table td:nth-child(3){width:12%}.sp-modal-table th:nth-child(4),.sp-modal-table td:nth-child(4){width:16%}.sp-modal-table th:nth-child(5),.sp-modal-table td:nth-child(5){width:24%}.comp-asset-tbl{width:100%;border-collapse:collapse;table-layout:fixed}.comp-asset-tbl thead{position:sticky;top:0;z-index:2;background:#f8fafc}.comp-asset-tbl th{padding:8px 10px;font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;text-align:left;border-bottom:1px solid #e2e8f0;overflow:hidden;white-space:nowrap}.comp-asset-tbl td{padding:10px;vertical-align:middle;border-bottom:1px solid #f8fafc;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-size:13px;color:#1e293b}.comp-asset-tbl tbody tr:hover{background:#f8fafc}.comp-asset-tbl tbody tr:last-child td{border-bottom:none}.comp-asset-tbl col:nth-child(1){width:38%}.comp-asset-tbl col:nth-child(2){width:28%}.comp-asset-tbl col:nth-child(3){width:18%}.comp-asset-tbl col:nth-child(4){width:6%}.comp-asset-tbl col:nth-child(5){width:10%}.sp-value-modal-body{padding:4px 16px 16px}.sp-value-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;padding:0 0 8px;border-bottom:1px solid #f1f5f9;margin-bottom:12px}.sp-value-wh-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:4px}.sp-value-wh-row{display:grid;grid-template-columns:200px 1fr 120px;align-items:center;gap:16px}.sp-value-wh-info{display:flex;flex-direction:column;gap:1px}.sp-value-wh-name{font-size:13px;font-weight:600;color:#1e293b}.sp-value-wh-loc{font-size:11px;color:#94a3b8}.sp-value-wh-count{font-size:11px;color:#64748b}.sp-value-wh-bar-wrap{background:#f1f5f9;border-radius:99px;height:8px;overflow:hidden}.sp-value-wh-bar{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:99px;transition:width .5s ease;min-width:4px}.sp-value-wh-val{font-size:13px;font-weight:700;color:#22c55e;text-align:right;white-space:nowrap;padding-right:4px}.sp-asset-filter-bar{display:flex;align-items:center;gap:8px;margin-bottom:16px}.sp-asset-drop-btn{display:flex;align-items:center;gap:8px;padding:9px 14px;border:1.5px solid #e2e8f0;border-radius:10px;background:#fff;font-size:14px;color:#64748b;cursor:pointer;min-width:260px;transition:border-color .18s,box-shadow .18s;font-family:inherit}.sp-asset-drop-btn:hover,.sp-asset-drop-btn.active{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sp-asset-drop-btn.has-value{color:#1e293b;font-weight:600;border-color:#6366f1;background:#f5f3ff}.sp-asset-clear-btn{display:flex;align-items:center;gap:5px;padding:7px 12px;border:1.5px solid #e2e8f0;border-radius:8px;background:#fff;font-size:12px;color:#94a3b8;cursor:pointer;transition:all .15s;font-family:inherit}.sp-asset-clear-btn:hover{border-color:#ef4444;color:#ef4444}.sp-asset-dropdown{max-height:340px;padding:6px;border-radius:12px}.sp-asset-drop-search{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:6px;background:#f8fafc}.sp-asset-drop-input{border:none;background:none;outline:none;font-size:13px;color:#1e293b;flex:1;font-family:inherit}.sp-pm-item-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s;position:relative}.sp-pm-item-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 14px #6366f126}.sp-pm-click-hint{font-size:10px;color:#a5b4fc;margin-top:4px;font-weight:500}.sp-pm-item-clickable:hover .sp-pm-click-hint{color:#6366f1}.pmdue-part-clickable{transition:transform .15s,box-shadow .15s}.pmdue-part-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f121}.sp-loc-item-clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.sp-loc-item-clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f11f}.sp-detail-modal{max-width:680px;width:90vw;max-height:85vh}.sp-modal-close{background:none;border:1.5px solid #e2e8f0;border-radius:8px;cursor:pointer;padding:5px 10px;font-size:14px;color:#64748b;transition:all .15s;flex-shrink:0;align-self:flex-start}.sp-modal-close:hover{border-color:#ef4444;color:#ef4444}.sp-detail-body{padding:4px 2px 8px;display:flex;flex-direction:column;gap:14px}.sp-detail-banner{display:flex;flex-direction:column;gap:3px;padding:10px 14px;border-radius:8px;border-left-width:4px;border-left-style:solid}.sp-detail-banner-status{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.sp-detail-banner-msg{font-size:13px;color:#475569}.sp-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.sp-detail-box{background:#f8fafc;border-radius:8px;padding:10px 12px}.sp-detail-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:3px}.sp-detail-val{font-size:14px;color:#1e293b;font-weight:500}.sp-detail-coverage{background:#f8fafc;border-radius:8px;padding:12px}.sp-detail-bar-wrap{background:#e2e8f0;border-radius:99px;height:8px;overflow:hidden}.sp-detail-bar{height:100%;border-radius:99px;transition:width .5s ease;min-width:4px}.sp-detail-pm-progress{background:#f8fafc;border-radius:8px;padding:12px}.sp-detail-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;padding-bottom:6px;border-bottom:1px solid #f1f5f9}.sp-detail-wh-card{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#f8fafc;border-radius:8px;border:1.5px solid #e2e8f0}.crit-row-clickable:hover{background:#f8fafc!important}.crit-row-clickable:hover td{color:#1e293b}.crit-detail-modal-box{width:480px;max-width:calc(100vw - 48px);max-height:85vh;background:#fff;border-radius:16px;box-shadow:0 24px 64px #00000038,0 4px 16px #0000001a;overflow:hidden;display:flex;flex-direction:column;animation:critModalIn .22s cubic-bezier(.34,1.56,.64,1)}@keyframes critModalIn{0%{opacity:0;transform:scale(.92) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.crit-detail-panel{display:none}@keyframes critSlideIn{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.crit-detail-header{display:flex;align-items:flex-start;gap:8px;padding:14px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-shrink:0}.crit-detail-title{font-size:14px;font-weight:700;color:#1e293b;line-height:1.3}.crit-detail-code{font-size:11px;color:#94a3b8;font-family:monospace;margin-top:2px}.crit-detail-close{background:none;border:none;cursor:pointer;padding:4px;color:#94a3b8;border-radius:6px;flex-shrink:0;line-height:0;transition:color .15s,background .15s}.crit-detail-close:hover{color:#ef4444;background:#fee2e2}.crit-detail-body{overflow-y:auto;flex:1}.crit-detail-body::-webkit-scrollbar{width:4px}.crit-detail-body::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}.crit-detail-section{padding:12px 16px;border-bottom:1px solid #f1f5f9}.crit-detail-section:last-child{border-bottom:none}.crit-detail-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:8px;display:flex;align-items:center;gap:4px}.crit-detail-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:12px}.crit-detail-row span{color:#64748b}.crit-detail-row strong{color:#1e293b}.crit-detail-loc-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f8fafc;gap:8px}.crit-detail-loc-row:last-child{border-bottom:none}.crit-detail-usage-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid #f8fafc}.crit-detail-usage-row:last-child{border-bottom:none}.heat-cell-interactive{transition:transform .15s ease,box-shadow .15s ease,outline .15s ease}.heat-cell-interactive:hover{transform:scale(1.25);box-shadow:0 2px 8px #0000002e;outline:2px solid rgba(99,102,241,.5);outline-offset:1px;z-index:2;position:relative}.heat-click-hint{display:flex;align-items:center;gap:5px;font-size:10px;color:#94a3b8;margin-top:8px}.legend-row-clickable{position:relative}.legend-row-clickable:after{content:"filter";position:absolute;right:-2px;top:50%;transform:translateY(-50%);font-size:9px;font-weight:600;color:#6366f1;opacity:0;transition:opacity .15s;text-transform:uppercase;letter-spacing:.04em;pointer-events:none}.legend-row-clickable:hover:after{opacity:.7}.dash-tab-badge{position:absolute;top:-6px;right:-8px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;animation:badgePop .4s cubic-bezier(.34,1.56,.64,1) both;pointer-events:none}@keyframes badgePop{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.pmdue-badge-btn{cursor:pointer;border:none;font-family:inherit;transition:opacity .15s,transform .12s,box-shadow .15s}.pmdue-badge-btn:hover{opacity:.82;transform:translateY(-1px);box-shadow:0 3px 8px #00000026}.pmdue-badge-btn:active{transform:translateY(0)}@keyframes pmDuePulse{0%{box-shadow:inset 0 0 0 2px transparent}25%{box-shadow:inset 0 0 0 2px #6366f1;background:#f5f3ff}75%{box-shadow:inset 0 0 0 2px #6366f1;background:#f5f3ff}to{box-shadow:inset 0 0 0 2px transparent;background:transparent}}.pmdue-section-highlight{animation:pmDuePulse 2s ease forwards;border-radius:10px}.sp-pm-add-btn{margin-top:10px;padding:5px 0;width:100%;background:#6366f12e;color:#c7d2fe;border:1px dashed rgba(99,102,241,.5);border-radius:6px;font-size:11px;font-weight:700;cursor:pointer;transition:background .15s,color .15s,border-color .15s;letter-spacing:.02em}.sp-pm-add-btn:hover{background:#6366f1;color:#fff;border-color:#6366f1}.sp-pm-del-btn{flex-shrink:0;width:18px;height:18px;border-radius:50%;border:none;background:transparent;color:#cbd5e1;font-size:11px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s,color .15s;line-height:1;padding:0}.sp-pm-item:hover .sp-pm-del-btn{opacity:1}.sp-pm-del-btn:hover{background:#fee2e2;color:#b91c1c}.sp-pm-drag-hint{font-size:10px;color:#cbd5e1;margin-top:4px;opacity:0;transition:opacity .15s;cursor:grab}.sp-pm-item:hover .sp-pm-drag-hint{opacity:1}.sp-pm-item-dragging{opacity:.4;transform:scale(.97);box-shadow:0 4px 16px #6366f133}.sp-pm-row-drag-over{border-color:#6366f1!important;box-shadow:0 0 0 2px #6366f133;transition:border-color .15s,box-shadow .15s}.sp-pm-row-drag-over .sp-pm-hm-sidebar{background:#4338ca}.sp-pm-drop-hint{margin-top:6px;font-size:10px;color:#a5b4fc;text-align:center;animation:pulseFade 1s ease infinite}@keyframes pulseFade{0%,to{opacity:.6}50%{opacity:1}}.sp-pm-empty-drop{font-size:12px;color:#94a3b8;padding:20px;font-style:italic;border:2px dashed #e2e8f0;border-radius:8px;text-align:center;transition:all .15s}.sp-pm-empty-drop-active{border-color:#6366f1;background:#eef2ff;color:#6366f1;font-style:normal;font-weight:600}.sp-pm-hm-sidebar{flex:0 0 100px!important;min-width:100px!important}.pmdue-pm-done-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:7px;border:1.5px solid #c7d2fe;background:#eef2ff;color:#4f46e5;font-size:11px;font-weight:600;cursor:pointer;transition:all .18s ease;flex-shrink:0;white-space:nowrap;font-family:inherit;margin-right:10px;align-self:flex-start;margin-top:2px}.pmdue-pm-done-btn:hover{background:#6366f1;color:#fff;border-color:#6366f1;transform:translateY(-1px);box-shadow:0 3px 10px #6366f147}.pmdue-pm-done-btn:active{transform:translateY(0);box-shadow:none}.pmdue-pm-done-btn svg{flex-shrink:0;transition:stroke .18s}.pmdue-interval-header{display:flex;align-items:flex-start;gap:0;flex-wrap:wrap}.pm-wo-modal{animation:pmWoSlideUp .22s cubic-bezier(.16,1,.3,1)}@keyframes pmWoSlideUp{0%{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pmWoSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pmdue-interval-with-sidebar{display:flex;flex-direction:row;align-items:stretch;padding:0;border-left:none!important;border-radius:10px;overflow:hidden;margin-bottom:10px;border:1px solid #e2e8f0;background:#fff;transition:box-shadow .18s}.pmdue-interval-with-sidebar:hover{box-shadow:0 2px 12px #6366f114}.pmdue-interval-with-sidebar.sp-pm-row-drag-over{box-shadow:0 0 0 2px #6366f1}.pmdue-hm-sidebar{min-width:76px;max-width:88px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;background:#1e293b;flex-shrink:0}.pmdue-hm-sidebar .pmdue-pm-done-btn{width:100%;justify-content:center;margin-right:0;margin-top:0;align-self:stretch;padding:5px 6px;font-size:10px;gap:3px;background:#312e81;border-color:#4338ca;color:#c7d2fe;border-radius:6px}.pmdue-del-hm-btn{background:#ef44441a!important;color:#ef4444!important;border:1px dashed rgba(239,68,68,.4)!important;font-size:11px!important;padding:5px 0!important;margin-top:0!important;line-height:1}.pmdue-del-hm-btn:hover{background:#ef4444!important;color:#fff!important;border-color:#ef4444!important}.pmdue-interval-ctrl-btn{width:28px!important;height:28px!important;padding:0!important;margin-top:0!important;flex-shrink:0;border-radius:6px!important;display:flex!important;align-items:center!important;justify-content:center!important;background:#e0e7ff!important;color:#4f46e5!important;border:none!important}.pmdue-interval-ctrl-btn:hover{background:#c7d2fe!important;color:#3730a3!important}.pmdue-del-hm-btn.pmdue-interval-ctrl-btn{background:#fee2e2!important;color:#dc2626!important;border:none!important}.pmdue-del-hm-btn.pmdue-interval-ctrl-btn:hover{background:#fecaca!important;color:#b91c1c!important}.pmdue-sp-inline-add-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:5px;border:none;background:#1d4ed8;color:#fff;cursor:pointer;flex-shrink:0;transition:background .15s;padding:0}.pmdue-sp-inline-add-btn:hover{background:#1e40af}.pmdue-sp-inline-del-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:5px;border:none;background:#b91c1c;color:#fff;cursor:pointer;flex-shrink:0;transition:background .15s;padding:0}.pmdue-sp-inline-del-btn:hover{background:#991b1b}.pmdue-sp-btn-row{display:flex;flex-direction:row;gap:4px;width:100%}.pmdue-sp-btn-row .sp-pm-add-btn{flex:1;margin-top:0;padding:5px 0;min-width:0;width:auto!important}.pmdue-interval-content{flex:1;min-width:0;display:flex;flex-direction:column;padding:12px 14px}.pmdue-interval.pmdue-interval-with-sidebar{border-left:none;padding:0}.pmdue-parts-title{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.pmdue-date-interval-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 8px;border-radius:12px;background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe;margin-bottom:6px}.pmdue-ondemand-pill{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:12px;background:#ede9fe;color:#6d28d9;border:1px solid #ddd6fe}.sp-tabs{display:flex;gap:4px;margin-bottom:4px;padding:4px 0}.sp-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s}.sp-tab-btn.active{background-color:#6366f1;color:#fff}.sp-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.sp-wrapper{display:flex;flex-direction:column;gap:0;min-height:100%;background:#f1f5f9;width:100%}.sp-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px;width:100%;overflow:hidden;flex-wrap:nowrap}.sp-toolbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1 1 0;overflow:hidden}.sp-toolbar-right{display:flex;gap:8px;align-items:center;flex-shrink:0}.sp-filter-btn{display:flex;align-items:center;gap:7px;padding:10px 16px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;flex-shrink:0;font-family:inherit}.sp-filter-btn:hover{background-color:#6366f10f;border-color:#6366f14d;color:#6366f1}.sp-filter-btn.active{background-color:#eff0fe;border-color:#6366f1;color:#6366f1}.sp-modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:transparent;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1000;animation:spFadeIn .2s ease}.sp-modal-overlay.active{display:block}@keyframes spFadeIn{0%{opacity:0}to{opacity:1}}.sp-modal-content{position:fixed;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:8px;min-width:220px;max-height:320px;overflow-y:auto;animation:spSlideDown .2s ease forwards}@keyframes spSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sp-modal-content::-webkit-scrollbar{width:6px}.sp-modal-content::-webkit-scrollbar-track{background:#f1f5f9}.sp-modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sp-warehouse-option{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;border-radius:8px;transition:background-color .15s}.sp-warehouse-option:hover{background-color:#f8fafc}.sp-warehouse-option.selected{background-color:#eff0fe}.sp-warehouse-radio{width:16px;height:16px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.sp-warehouse-option label{font-size:14px;color:#334155;cursor:pointer;flex:1}.sp-warehouse-option.selected label{color:#6366f1;font-weight:600}.sp-search-container{display:flex;align-items:center;gap:10px;padding:10px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:1 1 120px;min-width:80px;max-width:220px;transition:all .2s;overflow:hidden}.sp-search-container:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sp-search-container svg{color:#94a3b8;flex-shrink:0}.sp-search-input{border:none;outline:none;flex:1;font-size:14px;color:#334155;background:transparent;min-width:0}.sp-search-input::placeholder{color:#cbd5e1}.sp-refresh-btn{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;border-radius:8px;transition:all .2s}.sp-refresh-btn:hover{background-color:#f1f5f9;color:#334155}@keyframes spSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sp-create-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0;font-family:inherit}.sp-create-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.sp-table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;min-width:0;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.sp-table-scroll{width:100%;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 260px);--header-h: 49px;box-sizing:border-box}.sp-table-scroll::-webkit-scrollbar{height:8px;width:8px}.sp-table-scroll::-webkit-scrollbar-track{background:#f1f5f9;margin-top:var(--header-h)}.sp-table-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sp-table-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.sp-table-scroll::-webkit-scrollbar-corner{background:#f1f5f9}.sp-table{width:max-content;min-width:100%;border-collapse:collapse}.sp-table thead{background-color:#f8fafc;position:sticky;top:0;z-index:10}.sp-table th{text-align:left;padding:16px 20px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap;background-color:#f8fafc}.sp-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .15s;cursor:pointer}.sp-table tbody tr:hover{background-color:#f8fafc}.sp-table td{padding:14px 20px;font-size:14px;color:#334155;white-space:nowrap}.sp-stock-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;white-space:nowrap}.sp-stock-badge.in{background-color:#22c55e}.sp-stock-badge.low{background-color:#eab308}.sp-stock-badge.out{background-color:#ef4444}.sp-empty-row td{height:320px;vertical-align:middle;text-align:center}.sp-empty-state{text-align:center;padding:40px}.sp-empty-title{font-size:16px;font-weight:500;color:#334155;margin-bottom:8px}.sp-empty-subtitle{font-size:14px;color:#94a3b8}.sp-table-footer{height:51px;background-color:#fff;border-top:1px solid #f1f5f9;flex-shrink:0}.sp-detail-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0003;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1001;opacity:0}.sp-detail-overlay.active{display:block;animation:spOverlayIn .35s ease forwards}.sp-detail-overlay.closing{animation:spOverlayOut .35s ease forwards}@keyframes spOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes spOverlayOut{0%{opacity:1}to{opacity:0}}.sp-detail-panel{position:fixed;top:0;right:0;width:460px;height:100vh;background-color:#fff;box-shadow:-2px 0 20px #0000001f;overflow-y:auto;overflow-x:hidden;z-index:1002;transform:translate(460px)}.sp-detail-panel.active{animation:spPanelIn .35s ease forwards}.sp-detail-panel.closing{animation:spPanelOut .35s ease forwards}@keyframes spPanelIn{0%{transform:translate(460px)}to{transform:translate(0)}}@keyframes spPanelOut{0%{transform:translate(0)}to{transform:translate(460px)}}.sp-detail-panel::-webkit-scrollbar{width:6px}.sp-detail-panel::-webkit-scrollbar-track{background:#f1f5f9}.sp-detail-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sp-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 24px 20px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10}.sp-detail-title-area{flex:1;min-width:0}.sp-detail-name{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px;line-height:1.3;word-break:break-word;white-space:normal}.sp-detail-code{font-size:13px;color:#64748b;margin:0}.sp-detail-actions{display:flex;gap:8px;margin-left:12px;flex-shrink:0}.sp-detail-edit-btn,.sp-detail-delete-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#64748b}.sp-detail-edit-btn:hover{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.sp-detail-delete-btn:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.sp-detail-body{padding:20px 24px 32px}.sp-detail-badges{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.sp-detail-section-title{font-size:13px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:24px 0 14px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.sp-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.sp-detail-field{display:flex;flex-direction:column;gap:4px}.sp-detail-field--full{grid-column:1 / -1}.sp-detail-label{font-size:12px;color:#94a3b8;font-weight:500}.sp-detail-value{font-size:14px;color:#1e293b;font-weight:500;word-break:break-word;white-space:normal}.sp-location-list{display:flex;flex-direction:column;gap:10px;margin-top:4px}.sp-location-card{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px 16px}.sp-location-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.sp-location-warehouse{font-size:14px;font-weight:700;color:#1e293b}.sp-location-rack{font-size:12px;color:#64748b;background-color:#e2e8f0;padding:3px 8px;border-radius:5px;font-weight:600}.sp-location-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.sp-location-stat{display:flex;flex-direction:column;gap:2px}.sp-location-stat-label{font-size:11px;color:#94a3b8;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.sp-location-stat-value{font-size:15px;font-weight:700;color:#1e293b}.sp-location-updated{font-size:11px;color:#94a3b8;margin-top:8px;padding-top:8px;border-top:1px solid #e2e8f0}.sp-modal-form-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1100;align-items:center;justify-content:center}.sp-modal-form-overlay.active{display:flex;animation:spFadeIn .2s ease forwards}.sp-modal-form{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:560px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column}.sp-modal-form.animating-in{animation:spModalIn .25s ease forwards}.sp-modal-form.animating-out{animation:spModalOut .2s ease forwards}@keyframes spModalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes spModalOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(10px)}}.sp-modal-form-header{padding:28px 32px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.sp-modal-form-header h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px}.sp-modal-form-header p{font-size:14px;color:#64748b;margin:0}.sp-modal-form-body{padding:24px 32px;overflow-y:auto;flex:1}.sp-modal-form-body::-webkit-scrollbar{width:6px}.sp-modal-form-body::-webkit-scrollbar-track{background:#f1f5f9}.sp-modal-form-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sp-modal-form-footer{padding:16px 32px 24px;border-top:1px solid #e2e8f0;flex-shrink:0;display:flex;justify-content:flex-start}.sp-form-section-title{font-size:15px;font-weight:700;color:#1e293b;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.sp-form-section-title:not(:first-child){margin-top:28px}.sp-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.sp-form-row .sp-form-field{margin-bottom:0}.sp-form-field{margin-bottom:16px}.sp-form-label{display:block;font-size:14px;font-weight:500;color:#334155;margin-bottom:8px}.sp-form-input{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;font-family:inherit}.sp-form-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sp-form-input::placeholder{color:#94a3b8}.sp-form-select{width:100%;padding:12px 40px 12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;cursor:pointer;transition:all .2s;box-sizing:border-box;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(/images/dropdown.svg);background-repeat:no-repeat;background-position:right 14px center;background-size:16px 16px;font-family:inherit}.sp-form-select.placeholder{color:#94a3b8}.sp-form-select option{color:#334155}.sp-form-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sp-form-textarea{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;resize:vertical;min-height:80px;font-family:inherit}.sp-form-textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.sp-form-textarea::placeholder{color:#94a3b8}.sp-submit-btn{padding:10px 32px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.sp-submit-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.sp-inv-table{width:100%;border-collapse:collapse;margin-top:4px}.sp-inv-table th{text-align:left;padding:10px 12px;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.sp-inv-table td{padding:10px 12px;font-size:13px;color:#334155;border-bottom:1px solid #f1f5f9;vertical-align:middle}.sp-inv-input{width:80px;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:13px;color:#334155;text-align:center;font-family:inherit}.sp-inv-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.sp-delete-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:420px;max-width:90vw;padding:36px 32px;text-align:center}.sp-delete-modal.animating-in{animation:spModalIn .25s ease forwards}.sp-delete-modal.animating-out{animation:spModalOut .2s ease forwards}.sp-delete-icon{width:64px;height:64px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.sp-delete-title{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 10px}.sp-delete-desc{font-size:14px;color:#64748b;margin:0 0 28px;line-height:1.6}.sp-delete-actions{display:flex;gap:12px;justify-content:center}.sp-delete-cancel-btn{padding:10px 24px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.sp-delete-cancel-btn:hover{background:#f8fafc;border-color:#cbd5e1}.sp-delete-confirm-btn{padding:10px 24px;border:none;background:#ef4444;color:#fff;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.sp-delete-confirm-btn:hover{background:#dc2626}.sp-bulk-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#ef4444;flex-shrink:0}.sp-bulk-cancel-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;color:#64748b;transition:all .15s}.sp-bulk-cancel-btn:hover{background:#f8fafc;border-color:#94a3b8}.sp-bulk-confirm-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid #ef4444;background:#ef4444;cursor:pointer;color:#fff;transition:all .15s}.sp-bulk-confirm-btn:hover{background:#dc2626;border-color:#dc2626}.sp-bulk-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.sp-bulk-count-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;font-size:13px;font-weight:600;color:#ef4444;white-space:nowrap}.sp-wh-delete-list{max-height:240px;overflow-y:auto;margin:12px 0;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.sp-wh-delete-option{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .15s}.sp-wh-delete-option:last-child{border-bottom:none}.sp-wh-delete-option:hover{background-color:#fff5f5}.sp-wh-delete-option.selected{background-color:#fef2f2}.sp-wh-delete-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#ef4444;flex-shrink:0}.sp-wh-delete-option-label{flex:1;font-size:14px;color:#334155;cursor:pointer}.sp-wh-delete-option.selected .sp-wh-delete-option-label{color:#ef4444;font-weight:600}.sp-wh-delete-option-sub{font-size:12px;color:#94a3b8;margin-top:2px}.sp-wh-delete-empty{padding:20px;text-align:center;color:#94a3b8;font-size:14px}.sp-autocomplete-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:9999;max-height:320px;overflow-y:auto}.sp-autocomplete-option{padding:9px 14px;font-size:14px;color:#334155;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.add-asset-view-drafts-btn{display:inline-flex;align-items:center;gap:4px;padding:9px 16px;background:transparent;color:#64748b;border:1px solid #e2e8f0;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;white-space:nowrap}.add-asset-view-drafts-btn:hover{border-color:#6366f1;color:#6366f1;background:#f5f5ff}.add-asset-draft-btn{padding:10px 22px;background-color:#fff;color:#6366f1;border:1.5px solid #6366f1;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .18s;white-space:nowrap}.add-asset-draft-btn:hover{background-color:#f0f0ff;box-shadow:0 2px 8px #6366f126}.add-asset-footer-right{display:flex;align-items:center;gap:10px}.draft-save-toast{font-size:13px;font-weight:500;padding:5px 12px;border-radius:6px;animation:toastFadeIn .2s ease}.draft-save-toast.success{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.draft-save-toast.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}@keyframes toastFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.draft-list-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1200;justify-content:center;align-items:center}.draft-list-overlay.active{display:flex;animation:draftOverlayIn .18s ease}@keyframes draftOverlayIn{0%{opacity:0}to{opacity:1}}.draft-list-modal{background:#fff;border-radius:14px;box-shadow:0 24px 60px #0000002e;width:500px;max-width:92vw;max-height:70vh;display:flex;flex-direction:column;animation:draftModalIn .22s cubic-bezier(.34,1.3,.64,1)}@keyframes draftModalIn{0%{opacity:0;transform:scale(.94) translateY(-12px)}to{opacity:1;transform:scale(1) translateY(0)}}.draft-list-header{padding:22px 24px 16px;border-bottom:1px solid #f1f5f9;display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-shrink:0}.draft-list-title{font-size:17px;font-weight:700;color:#1e293b;margin:0 0 3px}.draft-list-subtitle{font-size:13px;color:#64748b;margin:0}.draft-list-body{overflow-y:auto;flex:1;padding:12px 0}.draft-list-body::-webkit-scrollbar{width:5px}.draft-list-body::-webkit-scrollbar-track{background:#f8fafc}.draft-list-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.draft-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.draft-item-list{display:flex;flex-direction:column;gap:0}.draft-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 24px;border-bottom:1px solid #f1f5f9;transition:background .13s}.draft-item:last-child{border-bottom:none}.draft-item:hover{background:#f8fafc}.draft-item-info{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.draft-item-name{font-size:14px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.draft-item-date{font-size:12px;color:#94a3b8}.draft-item-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.draft-apply-btn{padding:7px 18px;background:#6366f1;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer;transition:all .16s;white-space:nowrap}.draft-apply-btn:hover{background:#5558e3;box-shadow:0 3px 10px #6366f147}.draft-delete-btn{display:flex;align-items:center;justify-content:center;padding:7px;background:transparent;color:#cbd5e1;border:1px solid #e2e8f0;border-radius:7px;cursor:pointer;transition:all .16s}.draft-delete-btn:hover{color:#ef4444;border-color:#fca5a5;background:#fff5f5}.draft-delete-btn:disabled{opacity:.4;cursor:not-allowed}.bk-tabs{display:flex;gap:4px;margin-bottom:4px;padding:4px 0}.bk-tab-btn{padding:10px 24px;border:none;background-color:transparent;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}.bk-tab-btn.active{background-color:#6366f1;color:#fff}.bk-tab-btn:not(.active):hover{background-color:#6366f11a;color:#6366f1}.bk-wrapper{display:flex;flex-direction:column;gap:0;min-height:100%;background:#f1f5f9;width:100%}.bk-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 0;gap:12px;width:100%;overflow:hidden;flex-wrap:nowrap}.bk-toolbar-left{display:flex;align-items:center;gap:12px;flex:1 1 0;min-width:0;overflow:hidden}.bk-toolbar-right{display:flex;gap:8px;align-items:center;flex-shrink:0}.bk-filter-btn{display:flex;align-items:center;gap:7px;padding:10px 16px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;flex-shrink:0;font-family:inherit}.bk-filter-btn:hover{background-color:#6366f10f;border-color:#6366f14d;color:#6366f1}.bk-filter-btn.active{background-color:#eff0fe;border-color:#6366f1;color:#6366f1}.bk-modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:transparent;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1000}.bk-modal-overlay.active{display:block}.bk-modal-content{position:fixed;background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:8px;min-width:220px;max-height:320px;overflow-y:auto;animation:bkSlideDown .2s ease forwards}@keyframes bkSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.bk-modal-content::-webkit-scrollbar{width:6px}.bk-modal-content::-webkit-scrollbar-track{background:#f1f5f9}.bk-modal-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.bk-filter-option{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;border-radius:8px;transition:background-color .15s}.bk-filter-option:hover{background-color:#f8fafc}.bk-filter-option.selected{background-color:#eff0fe}.bk-filter-radio{width:16px;height:16px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.bk-filter-option label{font-size:14px;color:#334155;cursor:pointer;flex:1}.bk-filter-option.selected label{color:#6366f1;font-weight:600}.bk-search-container{display:flex;align-items:center;gap:10px;padding:10px 16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;flex:1 1 120px;min-width:80px;max-width:240px;transition:all .2s;overflow:hidden}.bk-search-container:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.bk-search-container svg{color:#94a3b8;flex-shrink:0}.bk-search-input{border:none;outline:none;flex:1;font-size:14px;color:#334155;background:transparent;min-width:0;font-family:inherit}.bk-search-input::placeholder{color:#cbd5e1}.bk-refresh-btn{background:none;border:none;cursor:pointer;padding:8px;display:flex;align-items:center;color:#64748b;border-radius:8px;transition:all .2s}.bk-refresh-btn:hover{background-color:#f1f5f9;color:#334155}@keyframes bkSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.bk-create-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap;flex-shrink:0;font-family:inherit}.bk-create-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.bk-create-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.bk-table-container{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;width:100%;min-width:0;display:flex;flex-direction:column;overflow:hidden;box-sizing:border-box}.bk-table-scroll{width:100%;overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 260px);--header-h: 49px;box-sizing:border-box}.bk-table-scroll::-webkit-scrollbar{height:8px;width:8px}.bk-table-scroll::-webkit-scrollbar-track{background:#f1f5f9;margin-top:var(--header-h)}.bk-table-scroll::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.bk-table-scroll::-webkit-scrollbar-thumb:hover{background:#94a3b8}.bk-table{width:max-content;min-width:100%;border-collapse:collapse}.bk-table thead{background-color:#f8fafc;position:sticky;top:0;z-index:10}.bk-table th{text-align:left;padding:16px 20px;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e2e8f0;white-space:nowrap;background-color:#f8fafc}.bk-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .15s;cursor:pointer}.bk-table tbody tr:hover{background-color:#f8fafc}.bk-table td{padding:14px 20px;font-size:14px;color:#334155;white-space:nowrap}.bk-table-footer{height:51px;background-color:#fff;border-top:1px solid #f1f5f9;flex-shrink:0}.bk-empty-row td{height:320px;vertical-align:middle;text-align:center}.bk-empty-state{text-align:center;padding:40px}.bk-empty-title{font-size:16px;font-weight:500;color:#334155;margin-bottom:8px}.bk-empty-subtitle{font-size:14px;color:#94a3b8}.bk-detail-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0003;-webkit-backdrop-filter:blur(1.5px);backdrop-filter:blur(1.5px);z-index:1001;opacity:0}.bk-detail-overlay.active{display:block;animation:bkOverlayIn .35s ease forwards}.bk-detail-overlay.closing{animation:bkOverlayOut .35s ease forwards}@keyframes bkOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes bkOverlayOut{0%{opacity:1}to{opacity:0}}.bk-detail-panel{position:fixed;top:0;right:0;width:500px;height:100vh;background-color:#fff;box-shadow:-2px 0 20px #0000001f;overflow-y:auto;overflow-x:hidden;z-index:1002;transform:translate(500px)}.bk-detail-panel.active{animation:bkPanelIn .35s ease forwards}.bk-detail-panel.closing{animation:bkPanelOut .35s ease forwards}@keyframes bkPanelIn{0%{transform:translate(500px)}to{transform:translate(0)}}@keyframes bkPanelOut{0%{transform:translate(0)}to{transform:translate(500px)}}.bk-detail-panel::-webkit-scrollbar{width:6px}.bk-detail-panel::-webkit-scrollbar-track{background:#f1f5f9}.bk-detail-panel::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.bk-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 24px 20px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10}.bk-detail-title-area{flex:1;min-width:0}.bk-detail-name{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 4px}.bk-detail-sub{font-size:13px;color:#64748b;margin:0}.bk-detail-actions{display:flex;gap:8px;margin-left:12px;flex-shrink:0}.bk-detail-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#64748b}.bk-detail-btn.edit:hover{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.bk-detail-btn.delete:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.bk-detail-btn.approve:hover{background:#f0fdf4;border-color:#22c55e;color:#22c55e}.bk-detail-btn.deny:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.bk-detail-body{padding:20px 24px 32px}.bk-detail-section{font-size:13px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:24px 0 14px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.bk-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.bk-detail-field{display:flex;flex-direction:column;gap:4px}.bk-detail-field--full{grid-column:1 / -1}.bk-detail-label{font-size:12px;color:#94a3b8;font-weight:500}.bk-detail-value{font-size:14px;color:#1e293b;font-weight:500;word-break:break-word;white-space:normal}.bk-items-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}.bk-item-card{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:12px 16px;display:flex;align-items:center;gap:12px}.bk-item-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.bk-item-icon.asset{background:#eff0fe;color:#6366f1}.bk-item-icon.tool{background:#fef9c3;color:#a16207}.bk-item-icon.scaffold{background:#dcfce7;color:#16a34a}.bk-item-info{flex:1;min-width:0}.bk-item-name{font-size:14px;font-weight:600;color:#1e293b}.bk-item-sub{font-size:12px;color:#64748b;margin-top:2px}.bk-item-qty{font-size:13px;font-weight:600;color:#6366f1;white-space:nowrap}.bk-approval-section{margin-top:20px;padding:16px;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.bk-approval-title{font-size:13px;font-weight:600;color:#334155;margin-bottom:12px}.bk-approval-btns{display:flex;gap:10px}.bk-approve-btn{flex:1;padding:10px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;font-family:inherit}.bk-approve-btn.confirm{background:#22c55e;color:#fff}.bk-approve-btn.confirm:hover{background:#16a34a;transform:translateY(-1px)}.bk-approve-btn.deny{background:#fee2e2;color:#ef4444;border:1px solid #fca5a5}.bk-approve-btn.deny:hover{background:#ef4444;color:#fff;border-color:#ef4444}.bk-approve-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.bk-modal-form-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1100;align-items:center;justify-content:center}.bk-modal-form-overlay.active{display:flex;animation:bkFadeIn .2s ease forwards}@keyframes bkFadeIn{0%{opacity:0}to{opacity:1}}.bk-modal-form{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:600px;max-width:95vw;max-height:92vh;display:flex;flex-direction:column}.bk-modal-form.animating-in{animation:bkModalIn .25s ease forwards}.bk-modal-form.animating-out{animation:bkModalOut .2s ease forwards}@keyframes bkModalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes bkModalOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95) translateY(10px)}}.bk-modal-header{padding:28px 32px 20px;border-bottom:1px solid #e2e8f0;flex-shrink:0}.bk-modal-header h2{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 4px}.bk-modal-header p{font-size:14px;color:#64748b;margin:0}.bk-modal-body{padding:24px 32px;overflow-y:auto;flex:1}.bk-modal-body::-webkit-scrollbar{width:6px}.bk-modal-body::-webkit-scrollbar-track{background:#f1f5f9}.bk-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.bk-modal-footer{padding:16px 32px 24px;border-top:1px solid #e2e8f0;flex-shrink:0;display:flex;justify-content:flex-start}.bk-section-title{font-size:15px;font-weight:700;color:#1e293b;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #e2e8f0}.bk-section-title:not(:first-child){margin-top:28px}.bk-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.bk-form-row .bk-form-field{margin-bottom:0}.bk-form-field{margin-bottom:16px}.bk-form-label{display:block;font-size:14px;font-weight:500;color:#334155;margin-bottom:8px}.bk-form-input{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;font-family:inherit}.bk-form-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.bk-form-input::placeholder{color:#94a3b8}.bk-date-input{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px 16px;padding-right:40px}.flatpickr-calendar{border-radius:12px!important;box-shadow:0 10px 40px #00000026!important;font-family:inherit!important}.flatpickr-day.selected,.flatpickr-day.selected:hover{background:#6366f1!important;border-color:#6366f1!important}.flatpickr-day:hover{background:#eff0fe!important;border-color:#eff0fe!important}.flatpickr-months .flatpickr-month{background:#6366f1!important;border-radius:12px 12px 0 0!important}.flatpickr-current-month .flatpickr-monthDropdown-months{background:#6366f1!important}.flatpickr-weekday{color:#6366f1!important;font-weight:600!important}.bk-form-textarea{width:100%;padding:12px 16px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;color:#334155;background-color:#fff;transition:all .2s;box-sizing:border-box;resize:vertical;min-height:80px;font-family:inherit}.bk-form-textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.bk-form-textarea::placeholder{color:#94a3b8}.bk-select-list{max-height:200px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.bk-select-list::-webkit-scrollbar{width:5px}.bk-select-list::-webkit-scrollbar-track{background:#f1f5f9}.bk-select-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.bk-select-option{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .15s}.bk-select-option:last-child{border-bottom:none}.bk-select-option:hover,.bk-select-option.selected{background-color:#eff0fe}.bk-select-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.bk-select-option-label{flex:1;font-size:14px;color:#334155;white-space:normal;line-height:1.4}.bk-select-option.selected .bk-select-option-label{color:#6366f1;font-weight:600}.bk-select-option-sub{font-size:12px;color:#94a3b8;margin-top:2px}.bk-select-empty{padding:20px;text-align:center;color:#94a3b8;font-size:14px}.bk-select-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #e2e8f0;background:#fff;border-radius:8px 8px 0 0}.bk-select-search svg{color:#94a3b8;flex-shrink:0}.bk-select-search-input{border:none;outline:none;flex:1;font-size:13px;color:#334155;background:transparent;font-family:inherit}.bk-select-search-input::placeholder{color:#cbd5e1}.bk-selected-count{font-size:12px;color:#6366f1;font-weight:600;margin-top:6px}.bk-tool-qty-row{display:flex;align-items:center;gap:8px;margin-top:4px}.bk-qty-selected-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}.bk-qty-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#eff0fe;border-radius:8px;font-size:13px;flex-wrap:wrap}.bk-qty-item-name{flex:1;color:#334155;font-weight:500}.bk-qty-input{width:64px;padding:5px 8px;border:1px solid #c7d2fe;border-radius:6px;font-size:13px;text-align:center;font-family:inherit;color:#334155}.bk-qty-input:focus{outline:none;border-color:#6366f1}.bk-qty-remove{background:none;border:none;cursor:pointer;color:#94a3b8;padding:2px;display:flex;align-items:center;border-radius:4px;transition:color .15s}.bk-qty-remove:hover{color:#ef4444}.bk-submit-btn{padding:10px 32px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.bk-submit-btn:hover{background-color:#5558e3;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.bk-submit-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.bk-delete-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;width:420px;max-width:90vw;padding:36px 32px;text-align:center}.bk-delete-modal.animating-in{animation:bkModalIn .25s ease forwards}.bk-delete-modal.animating-out{animation:bkModalOut .2s ease forwards}.bk-delete-icon{width:64px;height:64px;background:#fef2f2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.bk-delete-title{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 10px}.bk-delete-desc{font-size:14px;color:#64748b;margin:0 0 28px;line-height:1.6}.bk-delete-actions{display:flex;gap:12px;justify-content:center}.bk-delete-cancel-btn{padding:10px 24px;border:1px solid #e2e8f0;background:#fff;color:#64748b;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.bk-delete-cancel-btn:hover{background:#f8fafc}.bk-delete-confirm-btn{padding:10px 24px;border:none;background:#ef4444;color:#fff;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-family:inherit}.bk-delete-confirm-btn:hover{background:#dc2626}.bk-location-bar{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#eff0fe;border-radius:8px;margin-bottom:8px;font-size:13px;color:#6366f1;font-weight:600}.bk-status-modal{position:absolute;top:calc(100% + 8px);left:0;z-index:1000;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:8px;min-width:200px;overflow:hidden;animation:bkSlideDown .2s ease forwards}.bk-status-option{display:flex;align-items:center;gap:12px;padding:10px 14px;cursor:pointer;border-radius:8px;transition:background-color .15s}.bk-status-option:hover{background-color:#f8fafc}.bk-status-option.selected{background-color:#eff0fe}.bk-status-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#6366f1;flex-shrink:0}.sp-autocomplete-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:9999;max-height:220px;overflow-y:auto}.sp-autocomplete-dropdown::-webkit-scrollbar{width:5px}.sp-autocomplete-dropdown::-webkit-scrollbar-track{background:#f1f5f9}.sp-autocomplete-dropdown::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.sp-autocomplete-option{padding:9px 14px;font-size:14px;color:#334155;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background-color .12s}.sp-autocomplete-option:last-child{border-bottom:none}.sp-autocomplete-option:hover{background-color:#eff0fe;color:#6366f1}.ctrl-filter-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;border:1px solid #e2e8f0;background-color:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer;border-radius:8px;transition:all .2s;white-space:nowrap;flex-shrink:0;font-family:inherit}.ctrl-filter-btn:hover{background-color:#6366f10f;border-color:#6366f14d;color:#6366f1}.ctrl-filter-btn.active{background-color:#eff0fe;border-color:#6366f1;color:#6366f1}.ctrl-add-btn{display:flex;align-items:center;gap:7px;padding:10px 18px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .15s;font-family:inherit;white-space:nowrap}.ctrl-add-btn:hover{background-color:#4f46e5}.ctrl-add-btn:active{transform:scale(.97)}.ctrl-row-btn{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;border:1px solid #e2e8f0;background-color:#fff;cursor:pointer;transition:all .15s}.ctrl-row-btn--edit:hover{background-color:#eff0fe;border-color:#6366f1;color:#6366f1}.ctrl-row-btn--delete:hover{background-color:#fee2e2;border-color:#ef4444;color:#ef4444}.ctrl-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#0f172a66;backdrop-filter:blur(1.5px);-webkit-backdrop-filter:blur(1.5px);z-index:1200;display:flex;align-items:center;justify-content:center;animation:ctrlFadeIn .2s ease forwards}.ctrl-modal-overlay.closing{animation:ctrlFadeOut .18s ease forwards}@keyframes ctrlFadeIn{0%{opacity:0}to{opacity:1}}@keyframes ctrlFadeOut{0%{opacity:1}to{opacity:0}}.ctrl-modal-box{background:#fff;border-radius:16px;box-shadow:0 24px 64px #00000038;width:580px;max-width:calc(100vw - 48px);max-height:85vh;display:flex;flex-direction:column;overflow:hidden;animation:ctrlModalIn .22s ease forwards}.ctrl-modal-box.closing{animation:ctrlModalOut .18s ease forwards}.ctrl-modal-box--sm{width:420px}@keyframes ctrlModalIn{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes ctrlModalOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.96) translateY(10px)}}.ctrl-modal-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid #f1f5f9;flex-shrink:0}.ctrl-modal-title{font-size:17px;font-weight:700;color:#1e293b}.ctrl-modal-subtitle{font-size:12px;color:#94a3b8;margin-top:3px}.ctrl-modal-close-btn{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;border-radius:6px;display:flex;align-items:center;transition:color .15s,background-color .15s;flex-shrink:0}.ctrl-modal-close-btn:hover{color:#334155;background-color:#f1f5f9}.ctrl-modal-body{overflow-y:auto;flex:1;min-height:0;padding:20px 24px}.ctrl-modal-body::-webkit-scrollbar{width:6px}.ctrl-modal-body::-webkit-scrollbar-track{background:#f8fafc}.ctrl-modal-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.ctrl-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:14px 24px 18px;border-top:1px solid #f1f5f9;flex-shrink:0}.ctrl-form-section{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid #f1f5f9;margin-top:4px}.ctrl-form-section:first-child{margin-top:0}.ctrl-form-error{background-color:#fee2e2;border:1px solid #fecaca;border-radius:8px;padding:10px 14px;font-size:13px;color:#dc2626;margin-bottom:16px}.ctrl-required{color:#ef4444}.ctrl-textarea{resize:vertical;min-height:80px;line-height:1.5}.ctrl-btn-primary{padding:10px 20px;background-color:#6366f1;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s;font-family:inherit}.ctrl-btn-primary:hover:not(:disabled){background-color:#4f46e5}.ctrl-btn-primary:disabled{opacity:.6;cursor:not-allowed}.ctrl-btn-secondary{padding:10px 20px;background-color:#fff;color:#64748b;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s,border-color .2s;font-family:inherit}.ctrl-btn-secondary:hover:not(:disabled){background-color:#f8fafc;border-color:#cbd5e1}.ctrl-btn-secondary:disabled{opacity:.6;cursor:not-allowed}.ctrl-btn-danger{padding:10px 20px;background-color:#ef4444;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s;font-family:inherit}.ctrl-btn-danger:hover{background-color:#dc2626}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f5f5f5;background-image:linear-gradient(to right,#1e293b 64px,#f5f5f5 64px)}.container{display:flex;height:100vh}.main-content{flex:1;margin-left:64px;display:flex;flex-direction:column;height:100vh;overflow-y:hidden}.content{margin-top:64px;padding:20px;flex:1;min-width:0;overflow-y:auto;height:calc(100vh - 64px)}
