@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--color-primary:#3b82f6;--color-primary-hover:#6366f1;--color-primary-light:#3b82f614;--color-primary-glow:#3b82f640;--gradient-primary:linear-gradient(135deg, #3b82f6, #6366f1);--gradient-accent:linear-gradient(135deg, #6366f1, #8b5cf6);--color-background:#0b1020;--color-surface:#151c2d;--color-surface-secondary:#1b2438;--color-surface-hover:#1f2b42;--color-surface-elevated:#1e293b;--color-text:#e2e8f0;--color-text-secondary:#94a3b8;--color-text-tertiary:#64748b;--color-text-muted:#475569;--color-border:#ffffff0f;--color-border-light:#ffffff0a;--color-border-focus:#3b82f680;--color-danger:#ef4444;--color-danger-bg:#ef444414;--color-warning:#f59e0b;--color-warning-bg:#f59e0b14;--color-success:#22c55e;--color-success-bg:#22c55e14;--color-info:#3b82f6;--color-info-bg:#3b82f614;--shadow-xs:0 1px 2px #0000004d;--shadow-sm:0 1px 3px #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #00000080, 0 8px 10px -6px #0000004d;--shadow-2xl:0 25px 50px -12px #0009;--shadow-glow:0 0 20px var(--color-primary-glow);--shadow-glow-lg:0 0 40px #3b82f626;--glass-bg:#151c2dbf;--glass-border:#ffffff0f;--glass-blur:16px;--radius-xs:6px;--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:22px;--radius-full:9999px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:28px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px}[data-theme=light]{--color-primary:#1a56db;--color-primary-hover:#2563eb;--color-primary-light:#1a56db14;--color-primary-glow:#1a56db40;--gradient-primary:linear-gradient(135deg, #1a56db, #2563eb);--gradient-accent:linear-gradient(135deg, #2563eb, #7c3aed);--color-background:#f1f5f9;--color-surface:#fff;--color-surface-secondary:#f8fafc;--color-surface-hover:#f1f5f9;--color-surface-elevated:#fff;--color-text:#0f172a;--color-text-secondary:#64748b;--color-text-tertiary:#94a3b8;--color-text-muted:#94a3b8;--color-border:#e2e8f0;--color-border-light:#f1f5f9;--color-border-focus:#1a56db80;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014, 0 8px 10px -6px #0000000a;--shadow-2xl:0 25px 50px -12px #0000002e;--glass-bg:#ffffffb8;--glass-border:#ffffff4d}[data-theme=light] input,[data-theme=light] select,[data-theme=light] textarea{color:#0f172a!important;background:#fff!important;border-color:#e2e8f0!important}[data-theme=light] input:focus,[data-theme=light] select:focus,[data-theme=light] textarea:focus{border-color:#1a56db!important;box-shadow:0 0 0 3px #1a56db1f!important}[data-theme=light] select option{color:#0f172a;background:#fff}[data-theme=light] ::-webkit-scrollbar-thumb{background:#e2e8f0}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#cbd5e1}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{font-family:var(--font-family);background-color:var(--color-background);color:var(--color-text);line-height:1.5;overflow-x:hidden}.app-loading{z-index:99999;background:var(--color-background);justify-content:center;align-items:center;transition:opacity .4s,visibility .4s;display:flex;position:fixed;inset:0}.app-loading.hidden{opacity:0;visibility:hidden;pointer-events:none}.app-loading-spinner{text-align:center}.pl{width:5em;height:5em;margin:0 auto 16px}.pl__ring--a{stroke:var(--color-primary)}.pl__ring--b{stroke:var(--color-warning);animation-name:ringB}.pl__ring--c{stroke:var(--color-primary-hover);animation-name:ringC}.pl__ring--d{stroke:var(--color-danger);animation-name:ringD}.pl__ring{animation:2s linear infinite ringA}@keyframes ringA{0%,4%{stroke-dasharray:0 660;stroke-width:20px;stroke-dashoffset:-330px}12%{stroke-dasharray:60 600;stroke-width:30px;stroke-dashoffset:-335px}32%{stroke-dasharray:60 600;stroke-width:30px;stroke-dashoffset:-595px}40%,54%{stroke-dasharray:0 660;stroke-width:20px;stroke-dashoffset:-660px}62%{stroke-dasharray:60 600;stroke-width:30px;stroke-dashoffset:-665px}82%{stroke-dasharray:60 600;stroke-width:30px;stroke-dashoffset:-925px}90%,to{stroke-dasharray:0 660;stroke-width:20px;stroke-dashoffset:-990px}}@keyframes ringB{0%,12%{stroke-dasharray:0 220;stroke-width:20px;stroke-dashoffset:-110px}20%{stroke-dasharray:20 200;stroke-width:30px;stroke-dashoffset:-115px}40%{stroke-dasharray:20 200;stroke-width:30px;stroke-dashoffset:-195px}48%,62%{stroke-dasharray:0 220;stroke-width:20px;stroke-dashoffset:-220px}70%{stroke-dasharray:20 200;stroke-width:30px;stroke-dashoffset:-225px}90%{stroke-dasharray:20 200;stroke-width:30px;stroke-dashoffset:-305px}98%,to{stroke-dasharray:0 220;stroke-width:20px;stroke-dashoffset:-330px}}@keyframes ringC{0%{stroke-dasharray:0 440;stroke-width:20px;stroke-dashoffset:0}8%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-5px}28%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-175px}36%,58%{stroke-dasharray:0 440;stroke-width:20px;stroke-dashoffset:-220px}66%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-225px}86%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-395px}94%,to{stroke-dasharray:0 440;stroke-width:20px;stroke-dashoffset:-440px}}@keyframes ringD{0%,8%{stroke-dasharray:0 440;stroke-width:20px;stroke-dashoffset:0}16%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-5px}36%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-175px}44%,50%{stroke-dasharray:0 440;stroke-width:20px;stroke-dashoffset:-220px}58%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-225px}78%{stroke-dasharray:40 400;stroke-width:30px;stroke-dashoffset:-395px}86%,to{stroke-dasharray:0 440;stroke-width:20px;stroke-dashoffset:-440px}}.spinner-text{color:var(--color-text);font-size:16px;font-weight:700;font-family:var(--font-family)}.spinner-sub{color:var(--color-text-secondary);font-size:12px;font-family:var(--font-family);margin-top:4px}.app-container{min-height:100vh;display:flex;position:relative}.main-content{flex-direction:column;flex-grow:1;align-items:center;min-height:100vh;transition:opacity .15s,margin-left .3s;display:flex}@media (width>=1024px){.app-container{min-height:100vh;display:flex;position:relative}.app-main-area{flex-direction:column;flex:1;width:calc(100% - 260px);min-height:100vh;margin-left:260px;transition:margin-left .3s,width .3s;display:flex}.app-main-area.full-width{width:100%;margin-left:0}.main-content{flex-direction:column;flex:1;align-items:center;min-height:calc(100vh - 56px);padding:32px 40px 40px;transition:opacity .15s;display:flex}.page-exit{opacity:0;transform:translateY(8px)}.page-enter{animation:.35s forwards pageEnter}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.sidebar-edge-toggle{z-index:9999;cursor:pointer;background:linear-gradient(#162d4e 0%,#1e3a5f 100%);border:1px solid #ffffff1f;border-left:none;border-radius:0 10px 10px 0;justify-content:center;align-items:center;width:22px;height:56px;margin:0;padding:0;transition:left .3s cubic-bezier(.4,0,.2,1),box-shadow .25s,background .25s,width .25s;display:flex;position:fixed;top:50%;left:260px;transform:translateY(-50%);box-shadow:3px 0 12px #00000040}.sidebar-edge-toggle:hover{background:linear-gradient(#21416b 0%,#2a4f7f 100%);width:26px;box-shadow:4px 0 20px #0006}.sidebar-edge-toggle:active{transform:translateY(-50%)scale(.95)}.sidebar-edge-toggle.sidebar-edge-collapsed{left:0}.edge-toggle-arrow{color:#ffffffe6;-webkit-user-select:none;user-select:none;font-size:20px;font-weight:300;line-height:1;transition:transform .25s,color .2s}.sidebar-edge-toggle:hover .edge-toggle-arrow{color:#c8a951;transform:scale(1.15)}}@media (width<=1023px){.app-container{flex-direction:column;min-height:100vh;display:flex;position:relative}.app-main-area{flex-direction:column;flex:1;width:100%;min-height:100vh;display:flex}.app-main-area.full-width{width:100%;margin-left:0}.main-content{flex-direction:column;flex:1;align-items:center;min-height:100vh;padding:16px 16px 24px;transition:opacity .15s;display:flex;width:100%!important;margin-left:0!important}}@media (width>=1024px){.sidebar{color:#fff;z-index:1000;width:260px;transition:transform var(--transition-slow), box-shadow var(--transition);background:linear-gradient(#0b1020 0%,#111827 30%,#1a2332 60%,#1e293b 100%);flex-direction:column;justify-content:space-between;padding:0;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(0);box-shadow:4px 0 30px #00000040}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:99px}.sidebar::-webkit-scrollbar-track{background:0 0}.sidebar.hidden{box-shadow:none;transform:translate(-260px)}}.sidebar-brand{text-align:left;flex-shrink:0;padding:24px 22px 16px;position:relative}.sidebar-brand:after{content:"";background:linear-gradient(90deg,#0000,#ffffff1f 20% 80%,#0000);height:1px;position:absolute;bottom:0;left:16px;right:16px}.sidebar-brand-title{color:#fff;letter-spacing:.3px;text-shadow:0 1px 3px #00000026;margin-bottom:0;font-size:16px;font-weight:700;line-height:1.35}.sidebar-brand-divider{background:linear-gradient(90deg,#fff3,#ffffff0d);border:none;height:1px;margin:7px 0 8px}.sidebar-brand-sub{color:#ffffff80;letter-spacing:.25px;white-space:nowrap;text-overflow:ellipsis;font-size:10.5px;font-weight:400;line-height:1.4;overflow:hidden}.sidebar-menu{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;flex-grow:1;padding:10px 0 8px;list-style:none;display:flex;overflow:hidden auto}.sidebar-menu::-webkit-scrollbar{width:3px}.sidebar-menu::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:99px}.menu-section{color:#ffffff4d;letter-spacing:2px;text-transform:uppercase;padding:18px 22px 5px;font-size:9.5px;font-weight:700}.menu-divider{background:linear-gradient(90deg,#0000,#ffffff0f,#0000);height:1px;margin:5px 18px}.sidebar-menu li a{color:#fff9;border-radius:var(--radius-md);transition:background var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), padding-left var(--transition-fast);align-items:center;gap:11px;margin:1.5px 10px;padding:10px 18px;font-size:13.5px;font-weight:500;text-decoration:none;display:flex;position:relative}.sidebar-menu li a:hover{color:#fffffff2;background:#ffffff14;padding-left:22px}.sidebar-menu li a:active{background:#ffffff1a;transform:scale(.97)}.sidebar-menu li.active>a{color:#fff;-webkit-backdrop-filter:blur(4px);background:#ffffff1f;font-weight:600}.sidebar-menu li.active>a:before{content:"";background:var(--gradient-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;width:3.5px;height:55%;animation:.25s ease-out indicatorSlideIn;position:absolute;top:50%;left:-10px;transform:translateY(-50%);box-shadow:0 0 12px #3b82f680,0 0 24px #3b82f633}@keyframes indicatorSlideIn{0%{opacity:0;height:0%}to{opacity:1;height:55%}}.menu-icon{color:#ffffff80;flex-shrink:0;justify-content:center;align-items:center;width:22px;transition:transform .2s,color .2s;display:flex}.sidebar-menu li a:hover .menu-icon,.sidebar-menu li.active>a .menu-icon{color:#ffffffe6}.sidebar-menu li a:hover .menu-icon{transform:scale(1.1)}.menu-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.arrow{color:#ffffff59;flex-shrink:0;margin-left:auto;font-size:9px;transition:transform .3s cubic-bezier(.4,0,.2,1),color .2s}.sidebar-menu li a:hover .arrow{color:#fff9}.submenu{opacity:0;max-height:0;list-style:none;transition:max-height .35s cubic-bezier(.4,0,.2,1),opacity .25s;overflow:hidden}.submenu.open{opacity:1;max-height:200px}.submenu li a{color:#ffffff8c;border-radius:6px;gap:9px;margin:1px 10px 1px 22px;padding:8px 18px 8px 26px;font-size:12.5px}.submenu li a:hover{color:#ffffffd9;background:#ffffff12;padding-left:30px}.submenu li.active a{color:#fff;background:#ffffff1f;font-weight:600}.submenu .menu-icon{width:18px;font-size:13px}.sidebar-footer{border-top:1px solid #ffffff0f;flex-shrink:0;padding:12px 10px 14px;position:relative}.sidebar-footer:before{content:"";background:linear-gradient(90deg,#0000,#ffffff14,#0000);height:1px;position:absolute;top:-1px;left:16px;right:16px}.sidebar-footer-location{text-align:center;color:#ffffff59;letter-spacing:.3px;margin-bottom:7px;font-size:10.5px;font-weight:400}#realtime-clock{text-align:center;border-radius:var(--radius-md);letter-spacing:1px;color:#ffffffd9;font-variant-numeric:tabular-nums;-webkit-backdrop-filter:blur(8px);transition:background var(--transition-fast);background:#ffffff0f;border:1px solid #ffffff0f;margin-bottom:8px;padding:9px 12px;font-size:14px;font-weight:600}#realtime-clock:hover{background:#ffffff1a}.app-version{text-align:center;color:#ffffff38;letter-spacing:.4px;font-size:9.5px;font-weight:400}@media (width<=1023px){.sidebar{z-index:10001;color:#fff;background:linear-gradient(#0b1020 0%,#111827 25%,#1a2332 50%,#1e293b 75% 100%);flex-direction:column;justify-content:space-between;width:280px;max-width:85vw;padding:0;transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:4px 0 25px #0000004d}.sidebar.open{transform:translate(0)}.drawer-overlay{z-index:10000;opacity:0;visibility:hidden;background:#00000080;width:100vw;height:100vh;transition:opacity .3s,visibility .3s;position:fixed;top:0;left:0}.drawer-overlay.open{opacity:1;visibility:visible}.sidebar.hidden{transform:translate(-100%)}.sidebar-edge-toggle{display:none!important}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:99px}.sidebar::-webkit-scrollbar-track{background:0 0}}#top-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:500;height:56px;transition:background var(--transition), border-color var(--transition);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 28px;display:flex;position:sticky;top:0}[data-theme=dark] #top-nav{background:#111827;border-bottom-color:#ffffff0f}.tn-left{flex:1;align-items:center;max-width:420px;display:flex}.tn-search{align-items:center;width:100%;display:flex;position:relative}.tn-search-icon{color:var(--color-text-tertiary);pointer-events:none;transition:color var(--transition-fast);align-items:center;display:flex;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.tn-search-focused .tn-search-icon{color:var(--color-primary)}.tn-search-input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;height:36px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 36px 0 40px}.tn-search-input::placeholder{color:var(--color-text-tertiary)}.tn-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);background:var(--color-surface)}[data-theme=dark] .tn-search-input{background:#ffffff0d;border-color:#ffffff14}[data-theme=dark] .tn-search-input:focus{background:var(--color-surface);border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f61f}.tn-search-clear{width:22px;height:22px;color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;display:none;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.tn-search-input:not(:placeholder-shown)~.tn-search-clear{display:flex}.tn-search-clear:hover{background:var(--color-surface-hover);color:var(--color-text)}.tn-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.tn-btn{color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-family:inherit;display:inline-flex}.tn-btn-icon{border-radius:var(--radius-sm);width:34px;height:34px;position:relative}.tn-btn-icon:hover{background:var(--color-surface-hover);color:var(--color-text)}.tn-badge-dot{background:var(--color-danger);border:2px solid var(--color-surface);border-radius:50%;width:7px;height:7px;display:none;position:absolute;top:7px;right:7px}[data-theme=dark] .tn-badge-dot{border-color:#111827}.tn-user{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;margin-left:6px;padding:4px 10px 4px 4px;display:flex}.tn-user:hover{background:var(--color-surface-hover)}.tn-user-avatar-wrap{flex-shrink:0;position:relative}.tn-user-avatar{background:var(--gradient-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex;overflow:hidden}.tn-avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.tn-online-dot{border:2px solid var(--color-surface);background:#22c55e;border-radius:50%;width:9px;height:9px;position:absolute;bottom:0;right:0;box-shadow:0 0 6px #22c55e80}[data-theme=dark] .tn-online-dot{border-color:#111827}.tn-online-dot.offline{box-shadow:none;background:#6b7280}.tn-user-info{flex-direction:column;min-width:0;line-height:1.2;display:flex}.tn-user-name{color:var(--color-text);white-space:nowrap;font-size:13px;font-weight:600}.tn-user-role{letter-spacing:.3px;text-transform:uppercase;white-space:nowrap;font-size:10px;font-weight:600}.tn-role-developer{color:#fca5a5}.tn-role-leader{color:#fcd34d}.tn-role-staff{color:#93c5fd}.tn-role-guest{color:#9ca3af}.tn-chevron{color:var(--color-text-tertiary);transition:transform var(--transition-fast);align-items:center;display:flex}.tn-chevron.open{transform:rotate(180deg)}.tn-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:260px;box-shadow:var(--shadow-xl);opacity:0;pointer-events:none;z-index:1000;transition:opacity .2s,transform .2s cubic-bezier(.4,0,.2,1);position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;transform:translateY(8px)scale(.96)}.tn-dropdown.open{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}[data-theme=dark] .tn-dropdown{border-color:#ffffff14;box-shadow:0 12px 48px #0006}.tn-dd-header{background:var(--gradient-primary);color:#fff;align-items:center;gap:12px;padding:16px;display:flex}.tn-dd-avatar{color:#fff;background:#fff3;border:2px solid #ffffff40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;font-weight:700;display:flex;overflow:hidden}.tn-dd-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.tn-dd-info{flex:1;min-width:0;line-height:1.3}.tn-dd-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.tn-dd-email{opacity:.7;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.tn-dd-menu{padding:6px}.tn-dd-item{border-radius:var(--radius-sm);width:100%;color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:10px 12px;font-family:inherit;font-size:13px;font-weight:500;display:flex}.tn-dd-item:hover{background:var(--color-primary-light);color:var(--color-primary);padding-left:16px}.tn-dd-icon{color:var(--color-text-tertiary);transition:color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;width:18px;display:flex}.tn-dd-item:hover .tn-dd-icon{color:var(--color-primary)}.tn-dd-logout{color:var(--color-danger)!important}.tn-dd-logout .tn-dd-icon{color:var(--color-danger)}.tn-dd-logout:hover{background:var(--color-danger-bg)!important;color:var(--color-danger)!important}.tn-dd-logout:hover .tn-dd-icon{color:var(--color-danger)}.tn-dd-divider{background:var(--color-border);height:1px;margin:4px 10px}.tn-dd-badge{border-radius:var(--radius-full);margin-left:auto;padding:2px 8px;font-size:10px;font-weight:600}.tn-badge-dark{color:#60a5fa;background:#3b82f61f}.tn-badge-light{color:#f59e0b;background:#f59e0b1f}.tn-dd-footer{color:var(--color-text-muted);text-align:center;border-top:1px solid var(--color-border);background:var(--color-surface-secondary);letter-spacing:.2px;padding:10px 16px;font-size:10px}[data-theme=light] .tn-dropdown{box-shadow:0 12px 40px #0000001f}[data-theme=light] .tn-dd-item:hover{color:#1a56db;background:#1a56db0f}[data-theme=light] .tn-dd-item:hover .tn-dd-icon{color:#1a56db}[data-theme=light] .tn-online-dot,[data-theme=light] .tn-badge-dot{border-color:#fff}[data-theme=light] #top-nav{background:#fff}@media (width<=1023px){#top-nav{height:50px;padding:0 14px}.tn-left{flex:1;max-width:none}.tn-search-input{height:32px;padding:0 30px 0 34px;font-size:12px}.tn-search-icon{left:10px}.tn-user-info{display:none}.tn-user{gap:4px;padding:2px 6px 2px 2px}.tn-user-avatar{width:28px;height:28px;font-size:11px}.tn-chevron{display:none}.tn-btn-icon{width:30px;height:30px}.tn-dropdown{width:220px;right:8px}}#custom-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:99999;opacity:0;background:#00000080;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.25s cubic-bezier(.4,0,.2,1) forwards modalFadeIn;display:flex;position:fixed;top:0;left:0}#custom-modal-box{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl), 0 0 60px #3b82f60f;text-align:center;opacity:0;overflow-wrap:break-word;word-break:break-word;border:1px solid var(--color-border);width:400px;max-width:90vw;max-height:80vh;padding:40px 32px 32px;animation:.3s cubic-bezier(.34,1.56,.64,1) forwards modalScaleUp;position:relative;overflow-y:auto;transform:scale(.92)translateY(10px)}#custom-modal-close{cursor:pointer;transition:transform var(--transition), color var(--transition);font-size:28px;font-weight:700;line-height:1;position:absolute;top:10px;right:16px;color:var(--color-text-secondary)!important;background:0 0!important;border:none!important;width:30px!important;height:30px!important;margin-top:0!important;padding:0!important}#custom-modal-close:hover{transform:rotate(90deg);color:#ef4444!important}#custom-modal-box h3{color:#ef4444;margin-bottom:12px;font-size:22px}#custom-modal-box p{color:var(--color-text);font-size:15px;line-height:1.5}@keyframes modalFadeIn{to{opacity:1}}@keyframes modalScaleUp{to{opacity:1;transform:scale(1)translateY(0)}}@media (width<=1023px){#warehouse-modal-overlay{z-index:99999;opacity:0;background:#00000080;justify-content:center;align-items:flex-end;width:100vw;height:100vh;animation:.2s forwards modalFadeIn;display:flex;position:fixed;top:0;left:0}#warehouse-modal-box{background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:100%;max-height:85vh;margin:0;padding:28px 20px 24px;animation:.3s forwards bottomSheetUp;position:relative;overflow-y:auto;transform:translateY(100%);box-shadow:0 -8px 32px #0003}@keyframes bottomSheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}#warehouse-modal-box h3{text-align:center;color:var(--color-text);margin-bottom:20px;font-size:18px}#warehouse-modal-box:before{content:"";background:var(--color-border);border-radius:99px;width:36px;height:4px;margin:-8px auto 16px;display:block}#warehouse-modal-close{top:8px;right:12px}#custom-modal-overlay{align-items:flex-end}#custom-modal-box{border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:100%;padding:28px 20px 24px;animation:.3s forwards bottomSheetUp;transform:translateY(100%)}#custom-modal-box:before{content:"";background:var(--color-border);border-radius:99px;width:36px;height:4px;margin:-8px auto 16px;display:block}}#toast-container{z-index:999999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);pointer-events:all;opacity:0;color:#fff;-webkit-backdrop-filter:blur(8px);align-items:center;gap:10px;min-width:280px;max-width:400px;padding:14px 18px;font-size:14px;font-weight:500;transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);display:flex;transform:translate(40px)scale(.95)}.toast-show{opacity:1;transform:translate(0)scale(1)}.toast-hide{opacity:0;transform:translate(40px)scale(.95)}.toast-success{background:linear-gradient(135deg,#16a34a,#15803d)}.toast-error{background:linear-gradient(135deg,#dc2626,#b91c1c)}.toast-warning{background:linear-gradient(135deg,#ca8a04,#a16207)}.toast-info{background:linear-gradient(135deg, var(--color-primary), var(--color-primary-hover))}.toast-icon{flex-shrink:0;font-size:16px}.toast-msg{overflow-wrap:break-word;word-break:break-word;flex:1;line-height:1.4}.toast-close{flex-shrink:0;line-height:1;color:#fffc!important;cursor:pointer!important;background:0 0!important;border:none!important;width:auto!important;height:auto!important;margin:0!important;padding:0 2px!important;font-size:14px!important;transition:color .2s!important}.toast-close:hover{color:#fff!important;background:0 0!important}#main-content{transition:opacity var(--transition-fast), transform var(--transition-fast)}.page-exit{opacity:0;transform:translateY(6px)}.page-enter{animation:.3s forwards pageEnter}@keyframes pageEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.warehouse-container h1,.dashboard-container h1,.hc-container h1,.st-container h1{letter-spacing:-.3px}.db-table tbody tr{transition:background var(--transition)}.sidebar-menu li a{transition:background var(--transition), color var(--transition), border-left-color var(--transition), padding-left var(--transition)}.hc-card{transition:transform var(--transition), box-shadow var(--transition)}.hc-card:hover{box-shadow:0 12px 28px #00000026}.st-row{transition:background var(--transition)}button:not(.st-toggle):not(.toast-close):not(.btn-action):not(.hc-btn-delete):active{transform:scale(.96)}.empty-state{text-align:center;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-state-icon{opacity:.6;filter:grayscale(.3);margin-bottom:20px;font-size:52px}.empty-state-title{color:var(--color-text);margin-bottom:6px;font-size:17px;font-weight:700}.empty-state-desc{color:var(--color-text-secondary);max-width:320px;margin-bottom:24px;font-size:13px;line-height:1.6}.empty-state-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);box-shadow:var(--shadow-sm);border:none;align-items:center;gap:6px;padding:10px 22px;font-size:14px;font-weight:600;display:inline-flex;width:auto!important;margin-top:0!important}.empty-state-btn:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}input:focus-visible,select:focus-visible,button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}label{cursor:default;-webkit-user-select:none;user-select:none}.ss{width:100%;font-size:14px;position:relative}.ss-trigger{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text);cursor:pointer;text-align:left;transition:border-color var(--transition), box-shadow var(--transition);-webkit-user-select:none;user-select:none;outline:none;justify-content:space-between;align-items:center;gap:8px;padding:11px 14px;font-family:inherit;font-size:14px;line-height:1.4;display:flex}.ss-trigger:hover{border-color:var(--color-primary)}.ss-trigger:focus-visible{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d47a126}.ss-trigger-text{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.ss-trigger-text.ss-placeholder{color:var(--color-text-secondary);font-weight:400}.ss-arrow{color:var(--color-text-secondary);flex-shrink:0;width:12px;height:8px;transition:transform .25s cubic-bezier(.4,0,.2,1)}.ss-open .ss-arrow{transform:rotate(180deg)}.ss-dropdown{z-index:9999;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s cubic-bezier(.4,0,.2,1);position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;transform:translateY(-8px)scale(.97);box-shadow:0 12px 32px #0000002e}.ss-open .ss-dropdown{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.ss-search-wrap{border-bottom:1px solid var(--color-border);background:var(--color-surface-secondary);padding:8px}.ss-search-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:100%;color:var(--color-text);box-sizing:border-box;outline:none;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .2s}.ss-search-input::placeholder{color:var(--color-text-secondary);opacity:.7}.ss-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d47a11f}.ss-list-wrap{scroll-behavior:smooth;max-height:270px;overflow:hidden auto}.ss-list-wrap::-webkit-scrollbar{width:5px}.ss-list-wrap::-webkit-scrollbar-track{background:0 0}.ss-list-wrap::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:99px}.ss-list-wrap::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.ss-list-wrap{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.ss-list{flex-direction:column;gap:1px;margin:0;padding:4px;list-style:none;display:flex}.ss-option{cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text);-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;font-size:14px;transition:background .12s,color .12s;display:flex}.ss-option:hover{color:var(--color-primary);background:#0d47a114}.ss-option.ss-highlighted{color:var(--color-primary);background:#0d47a11f}.ss-option.ss-selected{background:var(--color-primary);color:#fff;font-weight:600}.ss-option.ss-selected:hover{background:var(--color-primary-hover)}.ss-option-text{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ss-check{opacity:.9;flex-shrink:0;font-size:13px;font-weight:700}.ss-no-results{text-align:center;color:var(--color-text-secondary);padding:28px 16px;font-size:13px;display:none}[data-theme=dark] .ss-trigger{background:#111b2b}[data-theme=dark] .ss-dropdown{background:#111b2b;border-color:#2d3a4e;box-shadow:0 12px 32px #00000080}[data-theme=dark] .ss-search-input{color:#e2e8f0;background:#0b1121;border-color:#2d3a4e}[data-theme=dark] .ss-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}[data-theme=dark] .ss-option:hover,[data-theme=dark] .ss-option.ss-highlighted{color:#60a5fa;background:#3b82f61f}[data-theme=dark] .ss-option.ss-selected{color:#fff;background:#1d4ed8}[data-theme=dark] .ss-option.ss-selected:hover{background:#2563eb}[data-theme=dark] .ss-search-wrap{background:#0b1121}@media (width<=480px){.ss-dropdown{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:60vh;position:fixed;inset:auto 0 0;transform:translateY(40px)scale(1)}.ss-open .ss-dropdown{transform:translateY(0)scale(1)}.ss-list-wrap{max-height:40vh}}.badge{border-radius:var(--radius-full);white-space:nowrap;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{color:#22c55e;background:#22c55e1f}.badge-yellow{color:#f59e0b;background:#f59e0b1f}.badge-red{color:#ef4444;background:#ef44441f}.badge-blue{color:#3b82f6;background:#3b82f61f}.badge-purple{color:#8b5cf6;background:#8b5cf61f}.badge-teal{color:#14b8a6;background:#14b8a61f}.badge-gray{color:#64748b;background:#64748b1f}[data-theme=dark] .badge-green{color:#4ade80;background:#16a34a33}[data-theme=dark] .badge-yellow{color:#facc15;background:#ca8a0433}[data-theme=dark] .badge-red{color:#f87171;background:#dc262633}[data-theme=dark] .badge-blue{color:#60a5fa;background:#1d4ed833}[data-theme=dark] .badge-purple{color:#a78bfa;background:#7c3aed33}[data-theme=dark] .badge-teal{color:#2dd4bf;background:#0f766e33}[data-theme=dark] .badge-gray{color:#9ca3af;background:#6b728033}.wh-form input{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;transition:var(--transition);background:var(--color-surface);color:var(--color-text);outline:none;padding:10px 14px;font-size:14px}.wh-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d47a11a}.wh-form select.custom-select{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);outline:none;margin-bottom:4px;padding:10px 14px;font-size:14px}.wh-berat-readonly{background:var(--color-surface-secondary);border-radius:var(--radius-md);color:var(--color-primary);margin-top:4px;padding:10px 14px;font-size:14px;font-weight:600}.wh-form-hint{color:var(--color-text-secondary);margin-top:6px;font-size:12px}.wh-form-hint a{color:var(--color-primary);font-weight:600;text-decoration:none}.wh-form-hint a:hover{text-decoration:underline}#wh-btn-simpan,#pk-btn-simpan{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;width:100%;transition:all var(--transition);box-shadow:var(--shadow-sm);border:none;margin-top:24px;padding:12px;font-size:15px;font-weight:600}#wh-btn-simpan:hover,#pk-btn-simpan:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}#btn-konfirm-hapus{border-radius:var(--radius-md);color:#fff;cursor:pointer;width:100%;transition:background var(--transition);background:#ef4444;border:none;margin-top:12px;padding:12px;font-size:15px;font-weight:700}#btn-konfirm-hapus:hover{background:#dc2626}.custom-select{border-radius:var(--radius-md);border:1px solid var(--color-border);background-color:var(--color-surface);width:100%;color:var(--color-text);cursor:pointer;transition:border-color var(--transition), box-shadow var(--transition);appearance:none;text-overflow:ellipsis;white-space:nowrap;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;background-size:12px 8px;outline:none;margin:0;padding:11px 40px 11px 14px;font-size:14px;overflow:hidden}.custom-select:hover{border-color:var(--color-primary)}.custom-select option{background:var(--color-surface);color:var(--color-text);white-space:normal;word-break:break-word;padding:10px}.custom-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0d47a126}[data-theme=dark] .custom-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394a3b8' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")!important;background-position:right 14px center!important;background-repeat:no-repeat!important;background-size:12px 8px!important}.auth-container{background:var(--color-background);min-height:100vh;display:flex}.auth-left{color:#fff;text-align:center;background:linear-gradient(135deg,#0c1e3a 0%,#143663 50%,#1a4a80 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:60px 40px;display:flex;position:relative;overflow:hidden}.auth-left:before{content:"";filter:blur(40px);pointer-events:none;background:#ffffff08;border-radius:50%;width:400px;height:400px;position:absolute;top:-100px;right:-100px}.auth-brand-icon{margin-bottom:20px;font-size:72px}.auth-brand h1{margin-bottom:8px;font-size:28px;font-weight:700}.auth-brand p{opacity:.85;margin-bottom:4px;font-size:16px}.auth-brand span{opacity:.6;font-size:13px}.auth-illustration{margin-top:60px}.auth-quote{opacity:.75;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff14;border-left:3px solid #c8a951;padding:16px 24px;font-size:16px;font-style:italic}.auth-right{background:var(--color-background);justify-content:center;align-items:center;width:480px;padding:40px;display:flex}.auth-box{width:100%;max-width:380px}.auth-header{text-align:center;margin-bottom:28px}.auth-header h2{color:var(--color-text);margin-bottom:6px;font-size:26px;font-weight:700}.auth-header p{color:var(--color-text-secondary);font-size:14px}.auth-tabs{background:var(--color-surface-secondary);border-radius:var(--radius-md);margin-bottom:24px;padding:4px;display:flex}.auth-tab{border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;flex:1;padding:9px;font-size:14px;font-weight:600;width:auto!important;margin:0!important}.auth-tab.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-md)}.auth-field{margin-bottom:16px}.auth-field label{color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.auth-field input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);transition:var(--transition);outline:none;padding:11px 14px;font-size:14px}.auth-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f1a}.auth-forgot{text-align:right;margin-top:-8px;margin-bottom:20px}.auth-forgot a{color:var(--color-primary);font-size:13px;font-weight:500;text-decoration:none}.auth-forgot a:hover{text-decoration:underline}.auth-btn-primary{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition);box-shadow:var(--shadow-sm);border:none;padding:13px;font-size:15px;font-weight:700;margin:0!important}.auth-btn-primary:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.auth-divider{color:var(--color-text-secondary);align-items:center;gap:12px;margin:20px 0;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-btn-google{background:var(--color-surface);width:100%;color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;gap:10px;padding:12px;font-size:14px;font-weight:600;display:flex;margin:0!important}.auth-btn-google:hover{border-color:var(--color-primary);background:var(--color-surface-secondary)}.auth-btn-google img{width:20px;height:20px}.auth-error{color:#dc2626;border-radius:var(--radius-md);text-align:center;background:#fee2e2;margin-top:16px;padding:12px 16px;font-size:13px;font-weight:500}[data-theme=dark] .auth-error{color:#f87171;background:#dc262626}@media (width<=768px){.auth-left{display:none}.auth-right{width:100%;padding:24px}}.db-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.db-welcome{justify-content:space-between;align-items:center;min-height:80px;margin-bottom:28px;display:flex}.db-greeting{color:var(--color-text);letter-spacing:-.3px;font-size:24px;font-weight:700;line-height:1.3}.db-date{color:var(--color-text-secondary);margin-top:4px;font-size:14px;font-weight:400}.db-kpi-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;display:grid}.db-kpi-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition);flex-direction:column;gap:16px;padding:20px;display:flex}.db-kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light);transform:translateY(-2px)}[data-theme=dark] .db-kpi-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .db-kpi-card:hover{border-color:#3b82f633;box-shadow:0 8px 24px #0000004d}.db-kpi-icon-wrap{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.db-kpi-icon-blue{background:#3b82f61a}.db-kpi-icon-yellow{background:#f59e0b1a}.db-kpi-icon-red{background:#ef44441a}.db-kpi-body{flex-direction:column;gap:2px;display:flex}.db-kpi-label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.db-kpi-value{color:var(--color-text);letter-spacing:-.5px;font-size:32px;font-weight:800;line-height:1.1}.db-kpi-desc{color:var(--color-text-tertiary);margin-top:2px;font-size:12px}.db-trend-badge{border-radius:var(--radius-full);white-space:nowrap;transition:all var(--transition-fast);align-self:flex-start;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.db-trend-up{color:#22c55e;background:#22c55e1a}.db-trend-down{color:#ef4444;background:#ef44441a}.db-trend-neutral{color:var(--color-text-tertiary);background:#64748b1a}[data-theme=dark] .db-trend-up{color:#4ade80;background:#16a34a33}[data-theme=dark] .db-trend-down{color:#f87171;background:#dc262633}[data-theme=dark] .db-trend-neutral{color:#9ca3af;background:#6b728026}.db-section-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.db-section-title{color:var(--color-text);letter-spacing:-.2px;font-size:16px;font-weight:700}.db-section-badge{border-radius:var(--radius-full);background:var(--color-surface-secondary);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:2px 9px;font-size:11px;font-weight:600}.db-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);margin-bottom:0;overflow:hidden}[data-theme=dark] .db-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}.db-toolbar{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.db-toolbar-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.db-toolbar-right{align-items:center;gap:8px;display:flex}.db-search{flex:1;align-items:center;max-width:280px;display:flex;position:relative}.db-search-icon{opacity:.5;font-size:13px;position:absolute;left:10px}.db-search-input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 10px 0 32px}[data-theme=dark] .db-search-input{background:#ffffff0a;border-color:#ffffff0f}.db-search-input::placeholder{color:var(--color-text-tertiary)}.db-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.db-filter{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 28px 0 10px}[data-theme=dark] .db-filter{background:#ffffff0a;border-color:#ffffff0f}.db-filter:focus{border-color:var(--color-primary)}.db-tb-btn{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:32px;color:var(--color-text-secondary);font-size:12px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:5px;padding:0 12px;display:inline-flex}[data-theme=dark] .db-tb-btn{background:#ffffff0a;border-color:#ffffff0f}.db-tb-btn:hover{background:var(--color-surface);border-color:var(--color-primary-light);color:var(--color-text)}.db-tb-btn:active{transform:scale(.97)}.db-table-scroll{overflow-x:auto}.db-table{border-collapse:collapse;width:100%}.db-table th{text-align:left;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-tertiary);background:var(--color-surface-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}.db-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);transition:background var(--transition-fast);padding:12px 16px;font-size:13px}.db-table tbody tr:last-child td{border-bottom:none}.db-table tbody tr:hover td{background:var(--color-surface-hover)}.db-cell-batch{color:var(--color-primary);font-size:12px;font-weight:600}.db-cell-stock{font-variant-numeric:tabular-nums;font-weight:600}.db-cell-date{color:var(--color-text-secondary);font-size:12px}.db-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.db-empty-icon{opacity:.5;margin-bottom:12px;font-size:32px}.db-empty-title{color:var(--color-text-secondary);margin-bottom:4px;font-size:14px;font-weight:600}.db-empty-desc{color:var(--color-text-tertiary);font-size:12px}@media (width<=1023px){.db-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.db-greeting{font-size:20px}.db-kpi-value{font-size:26px}.db-toolbar{flex-direction:column;align-items:stretch}.db-toolbar-left{flex-wrap:wrap}.db-search{max-width:none}.db-toolbar-right{justify-content:flex-end}}@media (width<=480px){.db-kpi-grid{grid-template-columns:1fr}.db-welcome{min-height:60px}.db-greeting{font-size:18px}.db-date{font-size:12px}}.wh-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.wh-hero{justify-content:space-between;align-items:center;min-height:72px;margin-bottom:28px;display:flex}.wh-hero-text h1{color:var(--color-text);letter-spacing:-.3px;margin:0 0 4px;font-size:24px;font-weight:700;line-height:1.3}.wh-hero-text p{color:var(--color-text-secondary);margin:0;font-size:14px;font-weight:400}.wh-hero-icon{opacity:.7;flex-shrink:0;font-size:40px}.wh-kpi-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px;display:grid}.wh-kpi-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition);flex-direction:column;gap:14px;padding:20px;display:flex}.wh-kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light);transform:translateY(-2px)}[data-theme=dark] .wh-kpi-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .wh-kpi-card:hover{border-color:#3b82f633;box-shadow:0 8px 24px #0000004d}.wh-kpi-icon-wrap{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.wh-kpi-icon-blue{background:#3b82f61a}.wh-kpi-icon-yellow{background:#f59e0b1a}.wh-kpi-icon-red{background:#ef44441a}.wh-kpi-icon-green{background:#22c55e1a}.wh-kpi-icon-gray{background:#64748b1a}.wh-kpi-body{flex-direction:column;gap:2px;display:flex}.wh-kpi-label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.wh-kpi-value{color:var(--color-text);letter-spacing:-.5px;font-size:32px;font-weight:800;line-height:1.1}.wh-kpi-desc{color:var(--color-text-tertiary);margin-top:2px;font-size:12px}.wh-section-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.wh-section-title{color:var(--color-text);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.wh-toolbar{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.wh-toolbar-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.wh-toolbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.wh-search{flex:1;align-items:center;max-width:280px;display:flex;position:relative}.wh-search-icon{opacity:.5;pointer-events:none;font-size:13px;position:absolute;left:10px}.wh-search-input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 10px 0 32px}[data-theme=dark] .wh-search-input{background:#ffffff0a;border-color:#ffffff0f}.wh-search-input::placeholder{color:var(--color-text-tertiary)}.wh-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.wh-filter{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 28px 0 10px}[data-theme=dark] .wh-filter{background:#ffffff0a;border-color:#ffffff0f}.wh-filter:focus{border-color:var(--color-primary)}.wh-btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-xs);height:32px;font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;align-items:center;gap:6px;padding:0 14px;display:inline-flex;box-shadow:0 1px 4px #3b82f633}.wh-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.wh-btn-primary:active{box-shadow:none;transform:translateY(0)}.wh-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);margin-bottom:0;overflow:hidden}[data-theme=dark] .wh-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}.wh-table-scroll{overflow-x:auto}.wh-table{border-collapse:collapse;width:100%}.wh-table thead{z-index:2;position:sticky;top:0}.wh-table th{text-align:left;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-tertiary);background:var(--color-surface-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}.wh-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);transition:background var(--transition-fast);padding:12px 16px;font-size:13px}.wh-table tbody tr:last-child td{border-bottom:none}.wh-table tbody tr:hover td{background:var(--color-surface-hover)}.wh-cell-batch{color:var(--color-primary);font-size:12px;font-weight:600}.wh-cell-stock{font-variant-numeric:tabular-nums;font-weight:600}.wh-cell-date{color:var(--color-text-secondary);font-size:12px}.wh-satuan-badge{background:var(--color-surface-secondary);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.wh-btn-action{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast), transform var(--transition-fast);background:0 0;border:none;padding:4px 6px;font-size:15px;line-height:1}.wh-btn-action:hover{background:var(--color-surface-hover);transform:scale(1.1)}.wh-btn-action:active{transform:scale(.95)}.wh-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 20px;display:flex}.wh-empty-icon{opacity:.5;margin-bottom:12px;font-size:36px}.wh-empty-title{color:var(--color-text-secondary);margin-bottom:4px;font-size:14px;font-weight:600}.wh-empty-desc{color:var(--color-text-tertiary);max-width:320px;font-size:12px;line-height:1.5}.wh-pagination{border-top:1px solid var(--color-border);background:var(--color-surface-secondary);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.wh-pagination-info{color:var(--color-text-tertiary);font-size:12px}.wh-pagination-controls{align-items:center;gap:4px;display:flex}.wh-page-btn{border:1px solid var(--color-border);border-radius:var(--radius-xs);min-width:28px;height:28px;color:var(--color-text-secondary);font-size:12px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;padding:0 6px;display:inline-flex}.wh-page-btn:hover{background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-text-tertiary)}.wh-page-btn:active{transform:scale(.95)}.wh-page-btn.wh-page-active{background:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 1px 4px #3b82f640}.wh-page-btn.wh-page-disabled{opacity:.35;cursor:not-allowed}.wh-page-btn.wh-page-disabled:hover{color:var(--color-text-secondary);border-color:var(--color-border);background:0 0}#warehouse-modal-overlay{z-index:99999;background:#0000008c;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.15s forwards whFadeIn;display:flex;position:fixed;top:0;left:0}@keyframes whFadeIn{to{opacity:1}}#warehouse-modal-box{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-2xl);border:1px solid var(--color-border);width:440px;max-width:92vw;max-height:85vh;padding:32px 28px 28px;animation:.25s cubic-bezier(.34,1.56,.64,1) forwards whModalIn;position:relative;overflow-y:auto}@keyframes whModalIn{0%{opacity:0;transform:scale(.96)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}#warehouse-modal-box h3{color:var(--color-text);border-bottom:1px solid var(--color-border);margin:0 0 20px;padding-bottom:12px;font-size:18px;font-weight:700}#warehouse-modal-close{color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-xs);width:28px;height:28px;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:22px;font-weight:500;line-height:1;display:flex;position:absolute;top:12px;right:14px}#warehouse-modal-close:hover{color:var(--color-danger);background:var(--color-danger-bg)}.wh-form label{color:var(--color-text-secondary);margin-top:14px;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.wh-form label:first-child{margin-top:0}.wh-form input[type=number],.wh-form input[type=text],.wh-form input[type=date]{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;height:38px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 12px}.wh-form input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);background:var(--color-surface)}.wh-form-hint{color:var(--color-text-tertiary);margin:4px 0 0;font-size:11px;line-height:1.4}.wh-berat-readonly{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);align-items:center;min-height:38px;padding:9px 12px;font-size:13px;display:flex}.wh-form>button{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-sm);width:100%;font-size:14px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;margin-top:18px;padding:10px 0;box-shadow:0 2px 8px #3b82f633}.wh-form>button:hover{transform:translateY(-1px);box-shadow:0 4px 14px #3b82f64d}.wh-form>button:active{box-shadow:none;transform:translateY(0)}.wh-pagination-ellipsis{min-width:24px;height:28px;color:var(--color-text-tertiary);letter-spacing:2px;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;font-size:12px;display:inline-flex}@media (width<=1023px){.wh-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.wh-hero-text h1{font-size:20px}.wh-kpi-value{font-size:26px}.wh-toolbar{flex-direction:column;align-items:stretch}.wh-toolbar-left{flex-wrap:wrap}.wh-search{max-width:none}.wh-toolbar-right{justify-content:flex-start}.wh-pagination{flex-direction:column;align-items:center;gap:8px}}@media (width<=480px){.wh-kpi-grid{grid-template-columns:1fr}.wh-hero{min-height:auto}.wh-hero-text h1{font-size:18px}.wh-hero-icon{font-size:30px}.wh-table th,.wh-table td{padding:10px 12px;font-size:12px}}.pk-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.pk-hero{justify-content:space-between;align-items:center;min-height:72px;margin-bottom:28px;display:flex}.pk-hero-text h1{color:var(--color-text);letter-spacing:-.3px;margin:0 0 4px;font-size:24px;font-weight:700;line-height:1.3}.pk-hero-text p{color:var(--color-text-secondary);margin:0;font-size:14px;font-weight:400}.pk-hero-icon{opacity:.7;flex-shrink:0;font-size:40px}.pk-kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.pk-kpi-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:all var(--transition);flex-direction:column;gap:14px;padding:20px;display:flex}.pk-kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light);transform:translateY(-2px)}[data-theme=dark] .pk-kpi-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .pk-kpi-card:hover{border-color:#3b82f633;box-shadow:0 8px 24px #0000004d}.pk-kpi-icon-wrap{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex}.pk-kpi-icon-blue{background:#3b82f61a}.pk-kpi-body{flex-direction:column;gap:2px;display:flex}.pk-kpi-label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.pk-kpi-value{color:var(--color-text);letter-spacing:-.5px;font-size:32px;font-weight:800;line-height:1.1}.pk-kpi-desc{color:var(--color-text-tertiary);margin-top:2px;font-size:12px}.pk-section-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;display:flex}.pk-section-title{color:var(--color-text);letter-spacing:-.2px;margin:0;font-size:16px;font-weight:700}.pk-toolbar{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.pk-toolbar-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.pk-toolbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.pk-search{flex:1;align-items:center;max-width:280px;display:flex;position:relative}.pk-search-icon{opacity:.5;pointer-events:none;font-size:13px;position:absolute;left:10px}.pk-search-input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 10px 0 32px}[data-theme=dark] .pk-search-input{background:#ffffff0a;border-color:#ffffff0f}.pk-search-input::placeholder{color:var(--color-text-tertiary)}.pk-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.pk-filter{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 28px 0 10px}[data-theme=dark] .pk-filter{background:#ffffff0a;border-color:#ffffff0f}.pk-filter:focus{border-color:var(--color-primary)}.pk-btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-xs);height:32px;font-size:12px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;align-items:center;gap:6px;padding:0 14px;display:inline-flex;box-shadow:0 1px 4px #3b82f633}.pk-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.pk-btn-primary:active{box-shadow:none;transform:translateY(0)}.pk-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);margin-bottom:24px;overflow:hidden}[data-theme=dark] .pk-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}.pk-table-scroll{overflow-x:auto}.pk-table{border-collapse:collapse;width:100%}.pk-table thead{z-index:2;position:sticky;top:0}.pk-table th{text-align:left;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-tertiary);background:var(--color-surface-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:12px 16px;font-size:11px;font-weight:600}.pk-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);transition:background var(--transition-fast);padding:12px 16px;font-size:13px}.pk-table tbody tr:last-child td{border-bottom:none}.pk-table tbody tr:hover td{background:var(--color-surface-hover)}.pk-satuan-badge{background:var(--color-primary-light);color:var(--color-primary);letter-spacing:.3px;border:1px solid #3b82f626;border-radius:4px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-block}[data-theme=dark] .pk-satuan-badge{color:#7aa9e6;background:#4a7fc726;border-color:#4a7fc733}.pk-btn-action{cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast), transform var(--transition-fast);background:0 0;border:none;padding:4px 6px;font-size:15px;line-height:1}.pk-btn-action:hover{background:var(--color-surface-hover);transform:scale(1.1)}.pk-btn-action:active{transform:scale(.95)}.pk-empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 20px;display:flex}.pk-empty-icon{opacity:.5;margin-bottom:12px;font-size:36px}.pk-empty-title{color:var(--color-text-secondary);margin-bottom:4px;font-size:14px;font-weight:600}.pk-empty-desc{color:var(--color-text-tertiary);max-width:320px;font-size:12px;line-height:1.5}.pk-tips{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:24px;padding:16px 20px}.pk-tips-title{color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:600}.pk-tips-body{color:var(--color-text-tertiary);font-size:12px;line-height:1.5}.pk-berat-row{grid-template-columns:1fr 110px;align-items:center;gap:10px;display:grid}.pk-berat-row input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;height:38px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 12px}.pk-berat-row input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);background:var(--color-surface)}.pk-berat-row select{height:38px;margin:0!important}@media (width<=1023px){.pk-hero-text h1{font-size:20px}.pk-kpi-value{font-size:26px}.pk-toolbar{flex-direction:column;align-items:stretch}.pk-toolbar-left{flex-wrap:wrap}.pk-search{max-width:none}.pk-toolbar-right{justify-content:flex-start}}@media (width<=480px){.pk-hero-text h1{font-size:18px}.pk-hero-icon{font-size:30px}.pk-berat-row{grid-template-columns:1fr}.pk-table th,.pk-table td{padding:10px 12px;font-size:12px}}.dl-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.dl-hero{justify-content:space-between;align-items:center;min-height:72px;margin-bottom:28px;display:flex}.dl-hero-text h1{color:var(--color-text);letter-spacing:-.3px;margin:0 0 4px;font-size:24px;font-weight:700;line-height:1.3}.dl-hero-text p{color:var(--color-text-secondary);margin:0;font-size:14px;font-weight:400}.dl-hero-icon{opacity:.7;flex-shrink:0;font-size:40px}.dl-toolbar-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.dl-btn-secondary{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);font-size:13px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:6px;padding:9px 16px;display:inline-flex}.dl-btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary);color:var(--color-text)}.dl-btn-secondary:active{transform:scale(.97)}.dl-btn-danger{color:#ef4444;border-radius:var(--radius-xs);font-size:13px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:1px solid #ef44444d;align-items:center;gap:6px;padding:9px 16px;display:inline-flex}.dl-btn-danger:hover{background:#ef444414;border-color:#ef4444}.dl-btn-danger:active{transform:scale(.97)}.dl-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}[data-theme=dark] .dl-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}.dl-card-title{letter-spacing:.4px;color:var(--color-text-secondary);text-transform:uppercase;padding:16px 20px 0;font-size:13px;font-weight:700}.dl-card-body{padding:16px 20px 20px}.dl-submit-row{border-top:1px solid var(--color-border);padding:16px 20px 20px}.dl-input-list{flex-direction:column;gap:12px;display:flex}.dl-input-row{background:var(--color-surface-secondary);border-radius:var(--radius-sm);border:1px solid var(--color-border);flex-direction:column;gap:12px;padding:16px;display:flex}.dl-row-main{grid-template-columns:1fr 180px 40px;align-items:end;gap:14px;display:grid}.dl-field label{color:var(--color-text);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.dl-select-pakan,.dl-select-nama,.dl-select-batch,.dl-input-qty{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:36px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 12px}.dl-select-pakan:focus,.dl-select-nama:focus,.dl-select-batch:focus,.dl-input-qty:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.dl-btn-remove{border:1px solid var(--color-border);border-radius:var(--radius-xs);background:var(--color-surface);color:#ef4444;cursor:pointer;width:36px;height:36px;transition:all var(--transition-fast);justify-content:center;align-self:end;align-items:center;font-size:15px;display:flex}.dl-btn-remove:hover{background:#ef444414;border-color:#ef4444}.dl-mode-toggle{flex-wrap:wrap;gap:16px;display:flex}.dl-mode-option{color:var(--color-text);cursor:pointer;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.dl-mode-option input[type=radio]{accent-color:var(--color-primary);width:auto;margin:0}.dl-manual-field label{color:var(--color-text);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.dl-preview{background:var(--color-surface);border-radius:var(--radius-xs);border:1px dashed var(--color-border);color:var(--color-text-secondary);padding:10px 12px;font-size:13px;line-height:1.5}.dl-preview-label{color:var(--color-primary);font-weight:600}.dl-preview-list{margin:6px 0 0 18px;padding:0}.dl-preview-list li{margin-bottom:4px}.dl-preview-hint{color:var(--color-text-secondary);font-style:italic}.dl-preview-error{color:#dc2626;font-weight:600}.dl-preview-ok{color:var(--color-text)}.dl-btn-add{border:1px dashed var(--color-border);border-radius:var(--radius-xs);width:100%;color:var(--color-text-secondary);font-size:13px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;gap:6px;max-width:calc(100% - 40px);margin:0 20px;padding:12px;display:flex}.dl-btn-add:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.dl-btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-xs);width:100%;font-size:14px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:6px;padding:11px 0;display:inline-flex;box-shadow:0 1px 4px #3b82f633}.dl-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.dl-btn-primary:active{box-shadow:none;transform:translateY(0)}.dl-tips{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:24px;padding:16px 20px}.dl-tips-title{color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:600}.dl-tips-body{color:var(--color-text-tertiary);overflow-wrap:break-word;word-break:break-word;font-size:12px;line-height:1.6}.dr-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.dr-toolbar .dr-search{flex:1;align-items:center;min-width:200px;max-width:300px;display:flex;position:relative}.dr-toolbar .dr-search-icon{opacity:.5;pointer-events:none;font-size:13px;position:absolute;left:10px}.dr-toolbar input[type=text]{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:34px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 10px 0 32px}[data-theme=dark] .dr-toolbar input[type=text]{background:#ffffff0a;border-color:#ffffff0f}.dr-toolbar input[type=text]:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.dr-toolbar input[type=text]::placeholder{color:var(--color-text-tertiary)}.dr-select-filter{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:34px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 28px 0 10px}[data-theme=dark] .dr-select-filter{background:#ffffff0a;border-color:#ffffff0f}.dr-select-filter:focus{border-color:var(--color-primary)}.dr-date-filter{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:34px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);outline:none;padding:0 10px}[data-theme=dark] .dr-date-filter{background:#ffffff0a;border-color:#ffffff0f}.dr-date-filter:focus{border-color:var(--color-primary)}.dr-cards-container{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.dr-card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all var(--transition);overflow-wrap:break-word;word-break:break-word;overflow:hidden}.dr-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.dr-card-cancelled{opacity:.6}.dr-card-header{background:var(--color-surface-secondary);border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:10px;padding:12px 16px;display:flex}.dr-timestamp{color:var(--color-text-secondary);flex:1;font-size:12px}.dr-btn-cancel{color:#d97706;border-radius:var(--radius-xs);font-size:12px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:#d977061a;border:1px solid #d9770633;align-items:center;gap:4px;padding:5px 11px;display:inline-flex}.dr-btn-cancel:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.dr-card-body{overflow-wrap:break-word;word-break:break-word;padding:14px 16px;overflow:hidden}.dr-section-label{letter-spacing:.5px;color:var(--color-text-secondary);margin-bottom:8px;font-size:11px;font-weight:700}.dr-item-row{border-bottom:1px solid var(--color-border);overflow-wrap:break-word;word-break:break-word;justify-content:space-between;align-items:center;gap:12px;padding:7px 0;font-size:13px;display:flex}.dr-item-row small{color:var(--color-text-secondary);font-size:11px}.dr-item-fifo{border-bottom:none!important;padding-bottom:3px!important}.dr-sub-item{color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);padding:2px 0 2px 12px;font-size:12px}.dr-total-row{color:var(--color-primary);justify-content:space-between;align-items:center;margin-top:4px;padding-top:10px;font-size:14px;font-weight:600;display:flex}@media (width<=1023px){.dl-hero-text h1{font-size:20px}.dl-row-main{grid-template-columns:1fr}.dl-btn-remove{place-self:auto end}.dl-toolbar-top{flex-direction:column;align-items:stretch}.dr-toolbar{flex-direction:column}.dr-toolbar .dr-search{width:100%;max-width:none}}@media (width<=480px){.dl-hero-text h1{font-size:18px}.dl-hero-icon{font-size:30px}.dl-btn-add{max-width:calc(100% - 32px);margin:0 16px}.dl-input-row{padding:12px}.dl-card-body,.dl-submit-row{padding:12px 14px 16px}.dr-cards-container{grid-template-columns:1fr}}.hc-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.hc-hero{justify-content:space-between;align-items:center;min-height:72px;margin-bottom:28px;display:flex}.hc-hero-text h1{color:var(--color-text);letter-spacing:-.3px;margin:0 0 4px;font-size:24px;font-weight:700;line-height:1.3}.hc-hero-text p{color:var(--color-text-secondary);margin:0;font-size:14px;font-weight:400}.hc-hero-icon{opacity:.7;flex-shrink:0;font-size:40px}.hc-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.hc-search{flex:1;align-items:center;min-width:200px;max-width:300px;display:flex;position:relative}.hc-search-icon{opacity:.5;pointer-events:none;font-size:13px;position:absolute;left:10px}.hc-search-input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:34px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 10px 0 32px}[data-theme=dark] .hc-search-input{background:#ffffff0a;border-color:#ffffff0f}.hc-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.hc-search-input::placeholder{color:var(--color-text-tertiary)}.hc-filter{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:34px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 28px 0 10px}[data-theme=dark] .hc-filter{background:#ffffff0a;border-color:#ffffff0f}.hc-filter:focus{border-color:var(--color-primary)}.hc-date-input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:34px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);outline:none;padding:0 10px}[data-theme=dark] .hc-date-input{background:#ffffff0a;border-color:#ffffff0f}.hc-date-input:focus{border-color:var(--color-primary)}.hc-cards-container{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;display:grid}.hc-card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:all var(--transition);overflow-wrap:break-word;word-break:break-word;overflow:hidden}.hc-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}[data-theme=dark] .hc-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .hc-card:hover{box-shadow:0 8px 24px #0000004d}.hc-card-header{background:var(--color-surface-secondary);border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:12px 16px;display:flex}.hc-timestamp{color:var(--color-text-secondary);flex:1;font-size:12px}.hc-btn-delete{cursor:pointer;border-radius:var(--radius-xs);transition:background var(--transition-fast), transform var(--transition-fast);opacity:.6;background:0 0;border:none;padding:4px 7px;font-size:14px;line-height:1}.hc-btn-delete:hover{opacity:1;background:#ef44441a;transform:scale(1.1)}.hc-btn-delete:active{transform:scale(.95)}.hc-card-body{overflow-wrap:break-word;word-break:break-word;align-items:stretch;gap:12px;padding:16px;display:flex;overflow:hidden}.hc-section{flex:1;min-width:0}.hc-section-label{letter-spacing:1px;color:var(--color-text-tertiary);text-transform:uppercase;margin-bottom:10px;font-size:10px;font-weight:700}.hc-detail-row,.hc-result-row{justify-content:space-between;align-items:center;gap:8px;margin-bottom:5px;font-size:13px;display:flex}.hc-detail-row span,.hc-result-row span{color:var(--color-text-secondary);white-space:nowrap;font-size:12px}.hc-detail-row strong,.hc-result-row strong{color:var(--color-text);text-align:right;font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.hc-highlight strong{color:var(--color-primary);font-size:14px}.hc-divider{color:var(--color-text-tertiary);opacity:.4;align-self:center;align-items:center;padding:0 2px;font-size:18px;display:flex}.hc-btn-danger{color:#ef4444;border-radius:var(--radius-xs);font-size:13px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:1px solid #ef44444d;align-items:center;gap:6px;padding:9px 16px;display:inline-flex}.hc-btn-danger:hover{background:#ef444414;border-color:#ef4444}.hc-btn-danger:active{transform:scale(.97)}@media (width<=1023px){.hc-hero-text h1{font-size:20px}.hc-toolbar{flex-direction:column;align-items:stretch}.hc-search{width:100%;max-width:none}}@media (width<=480px){.hc-hero-text h1{font-size:18px}.hc-hero-icon{font-size:30px}.hc-cards-container{grid-template-columns:1fr}.hc-card-body{flex-direction:column;padding:12px}.hc-divider{align-self:center;transform:rotate(90deg)}}.cc-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.cc-hero{justify-content:space-between;align-items:center;min-height:72px;margin-bottom:28px;display:flex}.cc-hero-text h1{color:var(--color-text);letter-spacing:-.3px;margin:0 0 4px;font-size:24px;font-weight:700;line-height:1.3}.cc-hero-text p{color:var(--color-text-secondary);margin:0;font-size:14px;font-weight:400}.cc-hero-icon{opacity:.7;flex-shrink:0;font-size:40px}.cc-grid{grid-template-columns:1fr 1fr;align-items:start;gap:20px;display:grid}.cc-left,.cc-right{flex-direction:column;gap:16px;display:flex}.cc-card{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}[data-theme=dark] .cc-card{border-color:#ffffff0d;box-shadow:0 1px 3px #0000004d}.cc-card-padded{padding:20px}.cc-card-title{letter-spacing:.4px;color:var(--color-text-secondary);text-transform:uppercase;border-bottom:1px solid var(--color-border);margin-bottom:16px;padding-bottom:10px;font-size:13px;font-weight:700}.cc-field{margin-bottom:14px}.cc-field label{color:var(--color-text);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.cc-field input{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:38px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;padding:0 12px}.cc-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.cc-ratio-inputs{align-items:center;gap:8px;display:flex}.cc-ratio-inputs input{text-align:center;background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:38px;color:var(--color-text);font-size:13px;font-family:var(--font-family);transition:all var(--transition-fast);outline:none;flex:1;padding:0 8px}.cc-ratio-inputs input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background:var(--color-surface)}.cc-ratio-sep{color:var(--color-text-tertiary);flex-shrink:0;font-size:18px;font-weight:700}.cc-select{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);width:100%;height:38px;color:var(--color-text);font-size:13px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 32px 0 12px}[data-theme=dark] .cc-select{background:#ffffff0a;border-color:#ffffff0f}.cc-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.cc-select option{background:var(--color-surface);color:var(--color-text)}.cc-btn-primary{background:var(--gradient-primary);color:#fff;border-radius:var(--radius-xs);width:100%;font-size:14px;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:6px;margin-top:4px;padding:11px 0;display:inline-flex;box-shadow:0 1px 4px #3b82f633}.cc-btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.cc-btn-primary:active{box-shadow:none;transform:translateY(0)}.cc-result{border:1px solid var(--color-border);border-radius:var(--radius-xs);margin-top:16px;overflow:hidden}.cc-result-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 14px;font-size:14px;display:flex}.cc-result-row:last-of-type{border-bottom:none}.cc-result-row span{color:var(--color-text-secondary);font-size:13px}.cc-result-row strong{color:var(--color-text);text-align:right;overflow-wrap:break-word;word-break:break-word;max-width:65%;font-size:14px;font-weight:600}.cc-result-highlight{background:var(--color-surface-secondary)}.cc-result-highlight strong{color:var(--color-primary);font-size:15px;font-weight:700}.cc-btn-copy{border:none;border-top:1px solid var(--color-border);background:var(--color-surface-secondary);width:100%;color:var(--color-text-secondary);font-size:13px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);padding:10px}.cc-btn-copy:hover{background:var(--color-surface-hover);color:var(--color-text)}.cc-tips{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px 20px}.cc-tips-title{color:var(--color-text);margin-bottom:6px;font-size:13px;font-weight:600}.cc-tips-body{color:var(--color-text-tertiary);font-size:12px;line-height:1.6}.cc-stat-row{border-bottom:1px solid var(--color-border);overflow-wrap:break-word;word-break:break-word;justify-content:space-between;align-items:center;gap:12px;padding:10px 0;font-size:13px;display:flex}.cc-stat-row:last-child{border-bottom:none;padding-bottom:0}.cc-stat-row span{color:var(--color-text-secondary);flex:1}.cc-stat-row strong{color:var(--color-primary);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:14px;font-weight:700}.cc-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-xs);margin-top:4px;overflow:hidden}.cc-table{border-collapse:collapse;width:100%}.cc-table th{background:var(--color-surface-secondary);color:var(--color-text-tertiary);text-align:left;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--color-border);padding:9px 12px;font-size:11px;font-weight:600}.cc-table td{color:var(--color-text);border-bottom:1px solid var(--color-border);overflow-wrap:break-word;word-break:break-word;padding:9px 12px;font-size:13px}.cc-table tr:last-child td{border-bottom:none}.cc-table tbody tr:hover{background:var(--color-surface-secondary)}@media (width<=1023px){.cc-hero-text h1{font-size:20px}.cc-grid{grid-template-columns:1fr}.cc-card-padded{padding:16px}}@media (width<=480px){.cc-hero-text h1{font-size:18px}.cc-hero-icon{font-size:30px}.cc-ratio-inputs{gap:6px}.cc-ratio-inputs input{padding:0 6px}}.st-container{width:100%;max-width:1200px;color:var(--color-text);margin:0 auto;padding:0}.st-hero{justify-content:space-between;align-items:center;min-height:72px;margin-bottom:32px;display:flex}.st-hero-text h1{color:var(--color-text);letter-spacing:-.3px;margin:0 0 4px;font-size:24px;font-weight:700;line-height:1.3}.st-hero-text p{color:var(--color-text-secondary);margin:0;font-size:14px;font-weight:400}.st-hero-icon{opacity:.7;flex-shrink:0;font-size:40px}.st-section{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);margin-bottom:20px;overflow:hidden}.st-section-header{border-bottom:1px solid var(--color-border);background:var(--color-surface-secondary);align-items:center;gap:10px;padding:16px 24px;display:flex}.st-section-header-icon{opacity:.8;flex-shrink:0;font-size:18px}.st-section-header-text h3{color:var(--color-text);letter-spacing:-.1px;margin:0;font-size:14px;font-weight:700}.st-section-header-text p{color:var(--color-text-tertiary);margin:2px 0 0;font-size:12px}.st-section-danger{border-color:#ef444433}.st-section-danger .st-section-header{background:#ef44440f;border-bottom-color:#ef444426}.st-section-danger .st-section-header-text h3{color:var(--color-danger)}[data-theme=dark] .st-section-danger{border-color:#ef444426}[data-theme=dark] .st-section-danger .st-section-header{background:#ef444414;border-bottom-color:#ef44441f}.st-row{border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);justify-content:space-between;align-items:center;gap:20px;min-height:56px;padding:16px 24px;display:flex}.st-row:last-child{border-bottom:none}.st-row:hover{background:var(--color-surface-hover)}.st-row-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.st-row-label{color:var(--color-text);font-size:14px;font-weight:500}.st-row-desc{color:var(--color-text-tertiary);font-size:12px;line-height:1.4}.st-row-control{flex-shrink:0;align-items:center;gap:10px;display:flex}.st-toggle{cursor:pointer;flex-shrink:0;width:44px;height:24px;display:inline-block;position:relative}.st-toggle input{opacity:0;width:0;height:0;position:absolute}.st-toggle-slider{background:var(--color-text-tertiary);border-radius:var(--radius-full);transition:all var(--transition-fast);opacity:.4;position:absolute;inset:0}.st-toggle-slider:before{content:"";width:18px;height:18px;transition:all var(--transition-fast);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000026}.st-toggle input:checked+.st-toggle-slider{background:var(--color-primary);opacity:1}.st-toggle input:checked+.st-toggle-slider:before{transform:translate(20px)}.st-btn{border:1px solid var(--color-border);border-radius:var(--radius-xs);height:32px;font-size:12px;font-weight:500;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:var(--color-surface-secondary);color:var(--color-text);align-items:center;gap:6px;padding:0 14px;display:inline-flex}.st-btn:hover{background:var(--color-surface);border-color:var(--color-text-tertiary);color:var(--color-text)}.st-btn:active{transform:scale(.97)}.st-btn-outline{color:var(--color-text-secondary);background:0 0}.st-btn-outline:hover{background:var(--color-surface-secondary);color:var(--color-text)}.st-btn-danger{color:var(--color-danger);background:0 0;border-color:#ef444440}.st-btn-danger:hover{background:#ef444414;border-color:#ef444466}.st-btn-danger-filled{background:var(--color-danger);color:#fff;border-color:var(--color-danger);font-weight:600;box-shadow:0 1px 4px #ef444433}.st-btn-danger-filled:hover{background:#dc2626;border-color:#dc2626;box-shadow:0 2px 8px #ef44444d}.st-btn-accent{background:var(--gradient-primary);color:#fff;border:none;font-weight:600;box-shadow:0 1px 4px #3b82f633}.st-btn-accent:hover{color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.st-select{background:var(--color-surface-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xs);height:32px;color:var(--color-text);font-size:12px;font-family:var(--font-family);cursor:pointer;transition:border-color var(--transition-fast);appearance:auto;outline:none;padding:0 28px 0 10px}.st-select:focus{border-color:var(--color-primary)}[data-theme=dark] .st-select{background:#ffffff0a;border-color:#ffffff0f}.st-sysinfo{grid-template-columns:1fr 1fr;gap:0;display:grid}.st-sysinfo-item{border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);flex-direction:column;gap:4px;padding:16px 24px;display:flex}.st-sysinfo-item:nth-child(2n){border-right:none}.st-sysinfo-item:nth-last-child(-n+2){border-bottom:none}.st-sysinfo-label{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-tertiary);font-size:11px;font-weight:600}.st-sysinfo-value{color:var(--color-text);font-size:14px;font-weight:600}.st-sysinfo-value-mono{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:13px}.st-danger-confirm{color:var(--color-text-tertiary);max-width:240px;margin-top:2px;font-size:11px;line-height:1.4}.st-footer{color:var(--color-text-muted);border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:8px;padding:20px 0 10px;font-size:12px;display:flex}@media (width<=1023px){.st-hero-text h1{font-size:20px}.st-hero-icon{font-size:32px}.st-sysinfo{grid-template-columns:1fr}.st-sysinfo-item{border-right:none}.st-sysinfo-item:nth-last-child(-n+2){border-bottom:1px solid var(--color-border)}.st-sysinfo-item:last-child{border-bottom:none}}@media (width<=480px){.st-hero-text h1{font-size:18px}.st-row{flex-direction:column;align-items:flex-start;gap:10px;padding:14px 16px}.st-row-control{justify-content:flex-end;width:100%}}.ac-container{padding:var(--space-8);width:100%;max-width:1100px;margin:0 auto}.ac-header{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.ac-header-left{flex-direction:column;gap:4px;display:flex}.ac-header-title{color:var(--color-text);letter-spacing:-.4px;font-size:22px;font-weight:700;line-height:1.3}.ac-header-subtitle{color:var(--color-text-tertiary);margin:0;font-size:14px}.ac-header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.ac-btn{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;white-space:nowrap;border-radius:8px;align-items:center;gap:8px;padding:9px 18px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.ac-btn:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}.ac-btn-outline{border-color:var(--color-border);color:var(--color-text-secondary);background:0 0}.ac-btn-outline:hover{background:var(--color-surface);border-color:var(--color-text-tertiary);color:var(--color-text)}.ac-profile-summary{border-bottom:1px solid var(--color-border);align-items:center;gap:20px;margin-bottom:36px;padding:24px 0 28px;display:flex}.ac-avatar-wrap{flex-shrink:0;position:relative}.ac-avatar{background:var(--color-surface-elevated);width:60px;height:60px;color:var(--color-text);border:1px solid var(--color-border);-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;font-weight:600;display:flex}.ac-avatar-img{border:1px solid var(--color-border)}.ac-online-dot{border:2px solid var(--color-background);background:#22c55e;border-radius:50%;width:12px;height:12px;position:absolute;bottom:2px;right:2px}.ac-profile-info{flex-direction:column;gap:4px;min-width:0;display:flex}.ac-profile-name{color:var(--color-text);letter-spacing:-.2px;font-size:18px;font-weight:700;line-height:1.3}.ac-profile-email{color:var(--color-text-tertiary);font-size:14px}.ac-profile-role{margin-top:3px}.ac-role-badge{letter-spacing:.3px;text-transform:uppercase;border-radius:9999px;align-items:center;gap:5px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.ac-role-developer{color:#f87171;background:#ef44441f;border:1px solid #ef444433}.ac-role-leader{color:#fbbf24;background:#f59e0b1f;border:1px solid #f59e0b33}.ac-role-staff{color:#60a5fa;background:#3b82f61f;border:1px solid #3b82f633}.ac-role-guest{color:#94a3b8;background:#64748b1f;border:1px solid #64748b33}.ac-role-sm{padding:3px 10px;font-size:10px}.ac-section{margin-bottom:8px}.ac-section-header{color:var(--color-text-tertiary);letter-spacing:.6px;text-transform:uppercase;align-items:center;gap:8px;padding:0 0 14px;font-size:12px;font-weight:600;display:flex}.ac-section-header i{opacity:.5}.ac-section-body{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;overflow:hidden}.ac-section-divider{background:0 0;height:1px;margin:4px 0 16px}.ac-field{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:20px;min-height:52px;padding:15px 24px;display:flex}.ac-field-last{border-bottom:none}.ac-field-label{color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0;align-items:center;gap:10px;font-size:14px;font-weight:500;display:inline-flex}.ac-field-label i{opacity:.4;color:var(--color-text-tertiary);width:15px;height:15px}.ac-field-value{color:var(--color-text);text-align:right;word-break:break-word;justify-content:flex-end;align-items:center;gap:10px;font-size:14px;font-weight:500;display:inline-flex}.ac-field-value-uid{max-width:400px}.ac-uid-text{color:var(--color-text-tertiary);background:var(--color-background);border:1px solid var(--color-border);text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;border-radius:6px;max-width:260px;padding:4px 12px;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;display:inline-block;overflow:hidden}.ac-btn-copy{border:1px solid var(--color-border);width:30px;height:30px;color:var(--color-text-tertiary);cursor:pointer;opacity:.6;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.ac-btn-copy:hover{opacity:1;background:var(--color-surface-hover);color:var(--color-text);border-color:var(--color-text-tertiary)}.ac-pw-dots{letter-spacing:2px;color:var(--color-text-tertiary);margin-right:6px;font-size:16px}.ac-btn-change{color:var(--color-text-tertiary);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:6px;align-items:center;padding:5px 14px;font-size:12px;font-weight:500;transition:all .15s;display:inline-flex}.ac-btn-change:hover{color:var(--color-text);background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}.ac-footer{color:var(--color-text-muted);border-top:1px solid var(--color-border);justify-content:space-between;margin-top:28px;padding:24px 0;font-size:12px;display:flex}#ac-modal-overlay{z-index:99999;opacity:0;background:#0009;justify-content:center;align-items:center;width:100vw;height:100vh;animation:.15s forwards acFadeIn;display:flex;position:fixed;top:0;left:0}@keyframes acFadeIn{to{opacity:1}}#ac-modal-box{background:var(--color-surface);border:1px solid var(--color-border);width:420px;max-width:92vw;max-height:85vh;box-shadow:var(--shadow-xl);opacity:0;border-radius:14px;animation:.2s forwards acSlideUp;position:relative;overflow-y:auto;transform:translateY(8px)}@keyframes acSlideUp{to{opacity:1;transform:translateY(0)}}#ac-modal-close{cursor:pointer;transition:color .15s;position:absolute;top:14px;right:16px;color:var(--color-text-tertiary)!important;background:0 0!important;border:none!important;width:auto!important;height:auto!important;margin:0!important;padding:4px!important}#ac-modal-close:hover{color:var(--color-text)!important}.ac-modal-header{padding:20px 24px 0}.ac-modal-header h3{color:var(--color-text);align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.ac-modal-body{padding:20px 24px 24px}.ac-field-group{margin-bottom:16px}.ac-field-group label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.ac-field-group input{background:var(--color-background);border:1px solid var(--color-border);width:100%;color:var(--color-text);border-radius:8px;outline:none;padding:10px 14px;font-size:14px;transition:border-color .15s}.ac-field-group input:focus{border-color:var(--color-primary)}.ac-field-hint{color:var(--color-text-muted);margin-top:6px;font-size:11px}.ac-btn-primary{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;padding:11px 20px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.ac-btn-primary:hover{background:var(--color-primary-hover)}@media (width<=768px){.ac-container{padding:var(--space-5);max-width:100%}.ac-header{flex-direction:column;align-items:flex-start;gap:14px}.ac-header-actions{width:100%}.ac-header-actions .ac-btn{flex:1;justify-content:center}.ac-field{flex-direction:column;align-items:flex-start;gap:8px;min-height:auto;padding:14px 20px}.ac-field-value{text-align:left;justify-content:flex-start;width:100%}.ac-field-value-uid,.ac-uid-text{max-width:100%}}@media (width<=1023px){.db-table thead{display:none}.db-table tbody tr{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-xs);margin-bottom:10px;padding:14px;display:block}.db-table tbody tr td{border:none;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;display:flex}.db-table tbody tr td:before{content:attr(data-label);color:var(--color-text-secondary);flex-shrink:0;margin-right:12px;font-size:11px;font-weight:600}.db-table-wrapper{overflow-x:hidden}.hc-cards-container{grid-template-columns:1fr}.hc-toolbar{flex-direction:column;gap:8px}.hc-toolbar input,.hc-toolbar select{width:100%}.dr-cards-container{grid-template-columns:1fr}.dr-toolbar{flex-direction:column;gap:8px}.dr-toolbar input,.dr-toolbar select{width:100%}.st-row{flex-direction:column;gap:10px}.st-row-control{align-self:flex-start}#custom-modal-box{border-radius:var(--radius-md);width:95vw;max-width:95vw;padding:28px 20px 24px}#warehouse-modal-box{border-radius:var(--radius-md);width:95vw;max-width:95vw;margin:10px;padding:28px 20px 24px}.empty-state{padding:40px 16px}.empty-state-icon{font-size:40px}.ss-dropdown{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:60vh;position:fixed;inset:auto 0 0;box-shadow:0 -8px 32px #0003}.ss-open .ss-trigger{border-radius:var(--radius-sm) var(--radius-sm) 0 0}.drawer-toggle-btn{z-index:9999;border-radius:var(--radius-md);background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(12px);width:42px;height:42px;box-shadow:var(--shadow-md);cursor:pointer;color:var(--color-text);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:center;display:flex;position:fixed;top:12px;left:12px}.drawer-toggle-btn:active{background:var(--color-surface-secondary);box-shadow:var(--shadow-sm);transform:scale(.95)}[data-theme=dark] .drawer-toggle-btn{color:#e2e8f0;background:#1a2332e6;border-color:#ffffff14}#toast-container{bottom:24px;left:12px;right:12px}.toast{border-radius:var(--radius-md);min-width:auto;max-width:100%}}.sp-overlay{-webkit-backdrop-filter:blur(12px);z-index:999999;opacity:0;pointer-events:none;width:100vw;height:100vh;transition:opacity var(--transition);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0}.sp-overlay.sp-open{opacity:1;pointer-events:all}.sp-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);width:560px;max-width:92vw;max-height:85vh;transition:transform var(--transition-spring);overflow-wrap:break-word;word-break:break-word;border:1px solid var(--color-border);position:relative;overflow-y:auto;transform:scale(.92)translateY(10px)}.sp-open .sp-card{transform:scale(1)translateY(0)}.sp-close{cursor:pointer;z-index:2;justify-content:center;align-items:center;font-size:28px;font-weight:700;line-height:1;display:flex;position:absolute;top:12px;right:16px;color:var(--color-text-secondary)!important;background:0 0!important;border:none!important;border-radius:8px!important;width:32px!important;height:32px!important;margin:0!important;padding:0!important;transition:all .2s!important}.sp-close:hover{transform:rotate(90deg);color:#ef4444!important;background:#ef44441a!important}.sp-header{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:24px 28px 16px;display:flex}.sp-header-icon{flex-shrink:0;font-size:28px}.sp-header-text h2{color:var(--color-text);margin-bottom:4px;font-size:18px;font-weight:700}.sp-header-text p{color:var(--color-text-secondary);font-size:12px}.sp-body{padding:20px 28px 24px}.sp-gate-success{text-align:center;padding:20px}.sp-gate-success-icon{margin-bottom:12px;font-size:64px}.sp-gate-success-title{color:var(--color-text);margin-bottom:4px;font-size:16px;font-weight:600}.sp-gate-success-sub{color:var(--color-text-secondary);font-size:13px}.sp-loading-wrap{text-align:center;padding:40px}.sp-loading-text{color:var(--color-text-secondary);font-size:14px}.sp-user-count{color:var(--color-text-secondary);margin-bottom:12px;font-size:12px}.sp-gate{text-align:center;padding:40px 20px}.sp-gate-icon{opacity:.8;margin-bottom:16px;font-size:56px}.sp-gate h3{color:var(--color-text);margin-bottom:8px;font-size:18px;font-weight:700}.sp-gate p{color:var(--color-text-secondary);margin-bottom:24px;font-size:13px}.sp-gate-input-wrap{gap:10px;max-width:340px;margin:0 auto;display:flex}.sp-gate-input{border:2px solid var(--color-border);border-radius:var(--radius-md);letter-spacing:2px;background:var(--color-surface);color:var(--color-text);text-align:center;outline:none;flex:1;padding:12px 16px;font-size:16px;font-weight:600;transition:border-color .2s,box-shadow .2s}.sp-gate-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a5f1f}.sp-gate-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;box-shadow:var(--shadow-sm);border:none;padding:12px 24px;font-size:14px;font-weight:700}.sp-gate-btn:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.sp-gate-error{color:#dc2626;min-height:20px;margin-top:12px;font-size:13px;font-weight:500}.sp-user-list{flex-direction:column;gap:8px;display:flex}.sp-user-card{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);transition:all var(--transition-fast);align-items:center;gap:14px;padding:14px 16px;display:flex}.sp-user-card:hover{background:var(--color-surface-hover);border-color:var(--color-primary);box-shadow:var(--shadow-xs)}.sp-user-avatar{color:#fff;background:linear-gradient(135deg,#1e3a5f,#2a4f7f);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex}.sp-user-info{flex:1;min-width:0}.sp-user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:14px;font-weight:600;overflow:hidden}.sp-user-email{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.sp-online-indicator{text-align:center;flex-shrink:0;width:24px;font-size:14px;transition:opacity .3s}.sp-user-role-wrap{flex-shrink:0;align-items:center;gap:8px;display:flex}.sp-role-select{border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b7280' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:10px 6px;outline:none;min-width:110px;padding:7px 32px 7px 12px;font-size:12px;font-weight:600;transition:border-color .2s}.sp-role-select:focus{border-color:var(--color-primary)}.sp-role-select option{background:var(--color-surface);color:var(--color-text)}.sp-role-select[data-role=developer]{color:#dc2626;border-color:#fca5a5}.sp-role-select[data-role=leader]{color:#c8a951;border-color:#fcd34d}.sp-role-select[data-role=staff]{color:#1d4ed8;border-color:#93c5fd}.sp-role-select[data-role=guest]{color:#6b7280;border-color:#d1d5db}[data-theme=dark] .sp-role-select[data-role=developer]{color:#f87171;border-color:#ef44444d}[data-theme=dark] .sp-role-select[data-role=leader]{color:#fbbf24;border-color:#c8a9514d}[data-theme=dark] .sp-role-select[data-role=staff]{color:#60a5fa;border-color:#3b82f64d}[data-theme=dark] .sp-role-select[data-role=guest]{color:#9ca3af;border-color:#6b72804d}.sp-role-save-btn{border-radius:var(--radius-sm);cursor:pointer;background:var(--color-primary);color:#fff;white-space:nowrap;border:none;padding:7px 12px;font-size:12px;font-weight:600;transition:background .2s,transform .15s}.sp-role-save-btn:hover{background:var(--color-primary-hover)}.sp-role-save-btn:active{transform:scale(.95)}.sp-role-save-btn:disabled{opacity:.5;cursor:not-allowed}.sp-user-me{letter-spacing:.5px;text-transform:uppercase;color:var(--color-primary);background:#1e3a5f1a;border-radius:4px;margin-left:6px;padding:2px 8px;font-size:10px;font-weight:700}[data-theme=dark] .sp-user-me{color:#5a8fd7;background:#4a7fc726}.sp-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:10px;padding:16px 28px 20px;display:flex}.sp-btn-close-bottom{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:9px 20px;font-size:13px;font-weight:600;transition:all .2s}.sp-btn-close-bottom:hover{background:var(--color-surface-secondary);border-color:var(--color-text-secondary)}.sp-empty{text-align:center;color:var(--color-text-secondary);padding:40px 20px}.sp-empty-icon{opacity:.6;margin-bottom:12px;font-size:48px}.sp-empty p{margin-bottom:4px;font-size:14px}.sp-empty small{font-size:12px}.sp-toast{border-radius:var(--radius-md);color:#fff;opacity:0;pointer-events:none;z-index:9999999;white-space:nowrap;padding:12px 24px;font-size:14px;font-weight:600;transition:all .3s;position:fixed;bottom:80px;left:50%;transform:translate(-50%)translateY(20px)}.sp-toast.sp-toast-show{opacity:1;transform:translate(-50%)translateY(0)}.sp-toast-success{background:#16a34a}.sp-toast-error{background:#dc2626}.sp-toast-info{background:var(--color-primary)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@media (width<=600px){.sp-card{border-radius:var(--radius-md);max-height:90vh}.sp-body{padding:16px}.sp-header{padding:18px 16px 14px}.sp-user-card{flex-wrap:wrap}.sp-user-role-wrap{justify-content:flex-end;width:100%}.sp-gate-input-wrap{flex-direction:column}.sp-footer{padding:12px 16px 16px}}
