@font-face{font-family:Inter;src:url(/assets/Inter-Regular-BOOGhInR.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/assets/Inter-Medium-D2bGa7uu.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/assets/Inter-SemiBold-D273HNI0.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}@media (max-width: 768px){.app-wrapper{flex-direction:column;overflow-y:auto}.sidebar{height:auto;width:100%;border-right-width:0px;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1))}.logo-area{justify-content:center}.side-nav{flex-direction:row;overflow-x:auto;padding:.625rem}.nav-item{width:auto;flex-direction:column;gap:.375rem;white-space:nowrap;padding:.5rem .75rem;text-align:center;font-size:12px;line-height:1.5}.main-content{height:auto;min-height:calc(100vh - 120px)}.content-scroll-area{overflow:visible}.stats-grid,.dashboard-grid{grid-template-columns:1fr}.chart-card.full-width{grid-column:span 1}.charts-container{grid-template-columns:1fr}}.mcp-status-badge{display:inline-block;padding:2px 8px;border-radius:9999px;font-size:12px;font-weight:500}.mcp-status-badge.running,.mcp-status-badge.connected{background-color:#dcfce7;color:#166534}.mcp-status-badge.connecting{background-color:#e0f2fe;color:#075985}.mcp-status-badge.disconnected{background-color:#fef3c7;color:#92400e}.mcp-status-badge.stopped{background-color:#f3f4f6;color:#6b7280}.mcp-status-badge.error{background-color:#fef2f2;color:#991b1b}.mcp-status-dot{display:inline-flex;align-items:center;font-size:10px;line-height:1}.face-tenant-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fafafa;border:1px solid #f0f0f0;border-radius:6px;margin-bottom:12px}.face-tenant-label{font-size:13px;color:#666;white-space:nowrap;font-weight:500}.face-tenant-bar select{flex:0 1 320px;min-width:200px;padding:6px 10px;border:1px solid #e5e7eb;border-radius:4px;background:#fff;font-size:13px}.face-config-card .section-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.face-enable-toggle{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:#555;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin:0}.face-enable-toggle input[type=checkbox]{margin:0}.face-config-body{padding:16px}.face-config-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 20px}.face-config-grid .form-group{margin:0}.face-config-grid .form-group.span-2{grid-column:1 / -1}.face-inline-hint{font-size:11px;color:#999;font-weight:400;margin-left:4px}.face-config-actions{display:flex;align-items:center;gap:10px;margin-top:16px;padding-top:12px;border-top:1px solid #f0f0f0}.face-config-actions .form-hint{margin:0;font-size:12px}@media (max-width: 768px){.face-config-grid{grid-template-columns:1fr}.face-config-card .section-header{flex-direction:column;align-items:flex-start;gap:8px;padding:12px 14px}.face-config-body{padding:12px 14px}.face-config-actions{gap:8px;flex-wrap:wrap}.face-config-actions .btn,.face-config-actions button{flex:1 1 auto;min-height:40px}}.face-enroll-grid{display:grid;grid-template-columns:260px 1fr;gap:16px;padding:16px}.face-enroll-users{display:flex;flex-direction:column;min-height:320px}.face-enroll-users-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:#444;margin-bottom:8px}.face-enroll-users-count{background:#f0f0f0;color:#666;font-weight:400;font-size:11px;padding:1px 8px;border-radius:10px}.face-enroll-users-list{border:1px solid #e5e7eb;border-radius:6px;max-height:480px;overflow:auto;background:#fff}.face-enroll-users-empty{padding:16px 12px;color:#999;font-size:13px;text-align:center}.face-enroll-user-item{display:block;position:relative;width:100%;text-align:left;border:0;border-bottom:1px solid #f0f0f0;background:transparent;border-radius:0;padding:10px 12px;cursor:pointer;transition:background .12s}.face-enroll-user-item:last-child{border-bottom:0}.face-enroll-user-item:hover{background:#fafafa}.face-enroll-user-item.is-active{background:#f0f9ec;box-shadow:inset 3px 0 #84cc16}.face-enroll-user-name{font-size:13px;color:#222;font-weight:500}.face-enroll-user-sub{font-size:11px;color:#999;margin-top:1px}.face-enroll-user-role{position:absolute;top:10px;right:12px;font-size:10px;color:#888;background:#f5f5f5;padding:1px 6px;border-radius:8px}.face-enroll-user-item.is-active .face-enroll-user-role{background:#fff;color:#65a30d}.face-enroll-detail{min-height:320px}.face-enroll-detail-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 4px 14px;border-bottom:1px solid #f0f0f0;margin-bottom:14px}.face-enroll-detail-name{font-size:16px;font-weight:600;color:#222}.face-enroll-detail-meta{font-size:12px;color:#888;margin-top:2px}.face-enroll-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}@media (max-width: 768px){.face-enroll-grid{grid-template-columns:1fr}.face-enroll-users{min-height:0}.face-enroll-users-list{max-height:220px}}.face-enroll-all-row{display:flex!important;align-items:center;gap:8px}.face-enroll-all-hint{font-size:11px;color:#999;font-weight:400;margin-left:4px}.face-enroll-wh-list{max-height:160px;overflow:auto;border:1px solid #e5e7eb;border-radius:4px;padding:8px;margin-top:8px;transition:opacity .15s,background .15s}.face-enroll-wh-list.is-disabled{opacity:.55;background:#fafafa;cursor:not-allowed}.face-enroll-wh-list.is-disabled .face-enroll-wh-item{cursor:not-allowed}.face-enroll-wh-item{display:flex!important;align-items:center;gap:8px;padding:4px 0;font-size:13px}.face-enroll-wh-empty{font-size:12px;color:#999;text-align:center;padding:8px 0}.tenant-info-card{margin:0 0 16px;padding:14px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}.tenant-info-header{display:flex;align-items:center;gap:10px;padding-right:20px;border-right:1px solid #f0f0f0}.tenant-info-name{color:#222;font-size:16px;font-weight:600;letter-spacing:.2px}.tenant-info-meta{display:flex;align-items:center;flex-wrap:wrap;gap:8px 24px;color:#666;font-size:13px}.tenant-info-item{display:inline-flex;align-items:center;gap:6px}.tenant-info-label{color:#999}.tenant-info-meta code{background:#f5f5f5;color:#555;padding:2px 6px;border-radius:4px;font-size:12px}.help-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#d1d5db;color:#fff;font-size:11px;font-weight:700;cursor:help;margin-left:4px;vertical-align:middle;position:relative;transition:background .2s}.help-icon:hover{background:var(--primary-color, #3b82f6)}.help-tooltip{display:none;position:absolute;top:calc(100% + 6px);left:-12px;background:#fff;color:#374151;font-size:12px;font-weight:400;line-height:1.6;padding:10px 14px;border-radius:8px;box-shadow:0 4px 16px #00000026;white-space:normal;width:260px;z-index:10001;pointer-events:auto}.help-tooltip:after{content:"";position:absolute;bottom:100%;left:16px;border:6px solid transparent;border-bottom-color:#fff}.help-tooltip a{color:var(--primary-color, #3b82f6);text-decoration:underline}.help-tooltip:before{content:"";position:absolute;bottom:100%;left:0;width:100%;height:8px}.help-icon:hover .help-tooltip,.help-tooltip:hover{display:block}.onboarding-spotlight{position:relative;z-index:9999!important;box-shadow:0 0 0 4px #3b82f666,0 0 16px #3b82f640!important;border-radius:8px;animation:spotlight-pulse 2s ease-in-out infinite}@keyframes spotlight-pulse{0%,to{box-shadow:0 0 0 4px #3b82f666,0 0 16px #3b82f640}50%{box-shadow:0 0 0 8px #3b82f633,0 0 24px #3b82f666}}.onboarding-bubble{position:fixed;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000002e;padding:20px 24px;z-index:10000;max-width:320px;font-size:14px;line-height:1.6;color:#1f2937}.onboarding-bubble .ob-step{font-size:11px;font-weight:700;color:var(--primary-color, #3b82f6);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.onboarding-bubble .ob-text{margin-bottom:16px}.onboarding-bubble .ob-actions{display:flex;gap:8px;justify-content:flex-end}.onboarding-bubble .ob-btn{padding:6px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:all .15s}.onboarding-bubble .ob-btn-primary{background:var(--primary-color, #3b82f6);color:#fff}.onboarding-bubble .ob-btn-primary:hover{opacity:.9}.onboarding-bubble .ob-btn-ghost{background:transparent;color:#9ca3af}.onboarding-bubble .ob-btn-ghost:hover{color:#6b7280}.onboarding-bubble:before{content:"";position:absolute;top:-16px;left:24px;border:8px solid transparent;border-bottom-color:#fff}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:9998;pointer-events:all}@media (max-width: 640px){.tenant-info-card{gap:12px}.tenant-info-header{border-right:none;border-bottom:1px solid #f0f0f0;padding-right:0;padding-bottom:10px;width:100%}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
 */*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{--tw-bg-opacity: 1;background-color:rgb(244 247 240 / var(--tw-bg-opacity, 1));line-height:1.5;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1));height:100vh;overflow:hidden}h1,h2,h3,h4,h5,h6{font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}h1{font-size:20px;line-height:1.5}h2{font-size:18px;line-height:1.5}h3{font-size:16px;line-height:1.5;font-weight:600}a{--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1));text-decoration-line:none;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}a:hover{--tw-text-opacity: 1;color:rgb(122 179 47 / var(--tw-text-opacity, 1))}input,select,textarea,button{font-family:inherit;font-size:inherit}input:focus,select:focus,textarea:focus{outline:2px solid transparent;outline-offset:2px}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background-color:transparent}::-webkit-scrollbar-thumb{border-radius:6px;--tw-bg-opacity: 1;background-color:rgb(232 232 232 / var(--tw-bg-opacity, 1))}::-webkit-scrollbar-thumb:hover{--tw-bg-opacity: 1;background-color:rgb(153 153 153 / var(--tw-bg-opacity, 1))}table{width:100%;border-collapse:collapse}thead{border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1))}th{border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(233 240 225 / var(--tw-bg-opacity, 1));padding:1rem 1.5rem;text-align:left;font-weight:500;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}td{border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(240 240 240 / var(--tw-border-opacity, 1));padding:1rem 1.5rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}tbody tr:hover{--tw-bg-opacity: 1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1))}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.app-wrapper{display:flex;height:100vh;width:100vw}.sidebar{width:240px;display:flex;flex-shrink:0;flex-direction:column;border-right-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));transition:width .3s}.main-content{display:flex;min-width:0px;flex:1 1 0%;flex-direction:column;--tw-bg-opacity: 1;background-color:rgb(244 247 240 / var(--tw-bg-opacity, 1))}.content-scroll-area{flex:1 1 0%;overflow-y:auto;padding:1.5rem}.page-header{margin-bottom:1.5rem}.page-title{font-size:20px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.logo-area{height:64px;display:flex;align-items:center;gap:.75rem;border-bottom-width:1px;border-color:transparent;padding-left:1.25rem;padding-right:1.25rem}.logo-icon{display:flex;height:2rem;width:2rem;align-items:center;justify-content:center;border-radius:8px;--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.logo-text .brand{font-size:16px;line-height:1.5;font-weight:700;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.side-nav{display:flex;flex:1 1 0%;flex-direction:column;gap:.5rem;padding:1.25rem .75rem}.nav-item{display:flex;width:100%;cursor:pointer;align-items:center;border-radius:12px;border-style:none;background-color:transparent;padding:.75rem 1rem;text-align:left;font-size:14px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));text-decoration-line:none;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.nav-item svg{flex-shrink:0;width:24px;height:24px;margin-right:16px}.nav-item span{display:block;flex:1 1 0%;min-width:0}.nav-item:hover{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.nav-item.active,.nav-item.\!active{--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));font-weight:600;--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.top-header{height:64px;display:flex;flex-shrink:0;align-items:center;justify-content:space-between;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding-left:1.5rem;padding-right:1.5rem}.breadcrumb{display:flex;align-items:center}.current-page-title{font-size:18px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.header-right{display:flex;align-items:center;gap:1rem}.sub-tabs{margin-bottom:1rem;display:flex;gap:.25rem;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding-bottom:0}.sub-tab{display:flex;cursor:pointer;align-items:center;gap:.375rem;border-top-left-radius:6px;border-top-right-radius:6px;border-bottom-width:2px;border-color:transparent;background-color:transparent;padding:.5rem 1rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.sub-tab:hover{--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.sub-tab.active,.sub-tab.\!active{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));font-weight:600;--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.warehouse-switcher{position:relative}.warehouse-btn{display:flex;height:2rem;cursor:pointer;align-items:center;gap:.375rem;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));background-color:transparent;padding:.375rem .75rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.warehouse-btn:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.warehouse-dropdown{position:absolute;top:100%;left:0;z-index:1000;margin-top:.25rem;display:none;max-height:320px;min-width:140px;overflow-y:auto;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.warehouse-dropdown.show{display:block}.warehouse-option{cursor:pointer;padding:.5rem .75rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.warehouse-option:hover{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.warehouse-option.active,.warehouse-option.\!active{--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));font-weight:600;--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.lang-dropdown{position:relative}.lang-btn,.refresh-btn{display:flex;height:2rem;cursor:pointer;align-items:center;gap:.375rem;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));background-color:transparent;padding:.375rem .75rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.lang-btn:hover,.refresh-btn:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.lang-dropdown-menu{position:absolute;top:100%;right:0;z-index:1000;margin-top:.25rem;display:none;min-width:100px;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.lang-dropdown-menu.show{display:block}.lang-option{cursor:pointer;padding:.5rem .75rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.lang-option:hover{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.update-info{display:flex;align-items:center;gap:.25rem;border-radius:6px;--tw-bg-opacity: 1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1));padding:.25rem .5rem;font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}#countdown{min-width:16px;text-align:center;font-weight:600;--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.tab-pane{display:none;animation:fadeIn .3s ease}.tab-pane.active,.tab-pane.\!active{display:block}.stats-grid{margin-bottom:1.5rem;display:grid;gap:1.25rem;grid-template-columns:repeat(4,1fr)}.stat-card{display:flex;align-items:center;justify-content:space-between;border-radius:12px;border-width:1px;border-color:transparent;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1.5rem;--tw-shadow: 0 2px 8px rgba(0, 0, 0, .05);--tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transition:all .3s ease}.stat-card:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);transform:translateY(-2px)}.stat-card.clickable{cursor:pointer}.stat-info{display:flex;flex-direction:column}.stat-label{margin-bottom:.75rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.stat-value-group{display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:32px;font-weight:700;line-height:1;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.stat-subtitle{font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.stat-change{font-size:13px;line-height:1.5;font-weight:500}.stat-change.positive{--tw-text-opacity: 1;color:rgb(82 196 26 / var(--tw-text-opacity, 1))}.stat-change.negative{--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.stat-icon-bg{display:flex;height:3rem;width:3rem;flex-shrink:0;align-items:center;justify-content:center;border-radius:12px}.stat-icon-bg.green{--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.stat-icon-bg.blue{--tw-bg-opacity: 1;background-color:rgb(230 247 255 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(24 144 255 / var(--tw-text-opacity, 1))}.stat-icon-bg.orange{--tw-bg-opacity: 1;background-color:rgb(255 247 230 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(250 173 20 / var(--tw-text-opacity, 1))}.stat-icon-bg.red{--tw-bg-opacity: 1;background-color:rgb(255 241 240 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.dashboard-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(2,1fr)}.chart-card{display:flex;flex-direction:column;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1.5rem;--tw-shadow: 0 2px 8px rgba(0, 0, 0, .05);--tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.chart-card.full-width{grid-column:span 2}.card-header{margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between}.card-title{position:relative;padding-left:.75rem;font-size:16px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.card-title:before{content:"";position:absolute;left:0;top:50%;height:1rem;width:.25rem;border-radius:4px;--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1));transform:translateY(-50%)}.charts-container{margin-bottom:1.5rem;display:grid;gap:1.25rem;grid-template-columns:repeat(2,1fr)}.chart-wrapper{display:flex;flex-direction:column;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1.5rem;--tw-shadow: 0 2px 8px rgba(0, 0, 0, .05);--tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.chart-title{position:relative;margin-bottom:1rem;padding-left:.75rem;font-size:16px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.chart-title:before{content:"";position:absolute;left:0;top:50%;height:1rem;width:.25rem;border-radius:4px;--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1));transform:translateY(-50%)}.chart{width:100%;height:300px}.filter-bar{margin-bottom:1.25rem;display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.25rem;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1.25rem;--tw-shadow: 0 2px 8px rgba(0, 0, 0, .05);--tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:12px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.filter-group input,.filter-group select{border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding:.5rem .75rem;font-size:14px;line-height:1.5;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;min-width:180px}.filter-group input:focus,.filter-group select:focus{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #8cc63f33}.filter-actions{margin-left:auto;display:flex;gap:.75rem}.section-header{display:flex;align-items:center;justify-content:space-between;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding:1.25rem 1.5rem;border-radius:12px 12px 0 0}.section-title{font-size:18px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.action-buttons{display:flex;gap:.75rem}.table-container{overflow:hidden;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:0;--tw-shadow: 0 2px 8px rgba(0, 0, 0, .05);--tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.btn,.filter-btn,.action-btn{display:inline-flex;cursor:pointer;align-items:center;justify-content:center;gap:.5rem;border-radius:12px;border-width:1px;border-color:transparent;padding:.5rem 1rem;font-size:14px;line-height:1.5;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.filter-btn.primary,.btn.confirm-btn{--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter-btn.primary:hover,.btn.confirm-btn:hover{--tw-bg-opacity: 1;background-color:rgb(122 179 47 / var(--tw-bg-opacity, 1))}.filter-btn.secondary,.btn.cancel-btn{--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.filter-btn.secondary:hover,.btn.cancel-btn:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.action-btn{--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.action-btn:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.back-btn{border-style:none;padding:.5rem .75rem;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.back-btn:hover{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.action-btn-small{margin-right:.5rem;cursor:pointer;border-radius:8px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.375rem .75rem;font-size:13px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.action-btn-small:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1));box-shadow:0 2px 4px #0000000d}.action-btn-small.danger{--tw-border-opacity: 1;border-color:rgb(255 204 199 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 241 240 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.action-btn-small.danger:hover{--tw-border-opacity: 1;border-color:rgb(255 77 79 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 77 79 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.action-btn-small.success{--tw-border-opacity: 1;border-color:rgb(183 235 143 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(246 255 237 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(82 196 26 / var(--tw-text-opacity, 1))}.action-btn-small.success:hover{--tw-border-opacity: 1;border-color:rgb(82 196 26 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(82 196 26 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.status-badge{white-space:nowrap;border-radius:6px;padding:.25rem .5rem;font-size:12px;line-height:1.5;font-weight:500}.status-badge.status-normal{--tw-bg-opacity: 1;background-color:rgb(239 252 232 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(82 196 26 / var(--tw-text-opacity, 1))}.status-badge.status-warning{--tw-bg-opacity: 1;background-color:rgb(255 247 230 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(250 173 20 / var(--tw-text-opacity, 1))}.status-badge.status-danger{--tw-bg-opacity: 1;background-color:rgb(255 241 240 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.status-badge.status-disabled{--tw-bg-opacity: 1;background-color:rgb(245 245 245 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.type-badge{border-radius:6px;padding:.125rem .5rem;font-size:12px;line-height:1.5}.type-badge.type-in{--tw-bg-opacity: 1;background-color:rgb(230 247 255 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(24 144 255 / var(--tw-text-opacity, 1))}.type-badge.type-out{--tw-bg-opacity: 1;background-color:rgb(255 241 240 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.\!badge,.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));padding:.125rem .5rem;font-size:12px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.pagination{display:flex;align-items:center;justify-content:space-between;border-top-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1rem 1.5rem}.pagination-controls{display:flex;align-items:center;gap:.5rem}.page-size-select{margin-right:.5rem;cursor:pointer;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.375rem .75rem;font-size:14px;line-height:1.5}.pagination-controls button{cursor:pointer;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.375rem .75rem;font-size:14px;line-height:1.5}.pagination-controls button:disabled{cursor:not-allowed;opacity:.5}.\!modal,.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:none;align-items:center;justify-content:center;background-color:#00000080}.\!modal.show,.modal.show{display:flex}.modal-content{display:flex;max-height:90vh;width:90%;flex-direction:column;overflow-y:auto;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);max-width:500px}.modal-content.modal-large{max-width:800px}.modal-content.modal-small{max-width:400px}.modal-header{display:flex;align-items:center;justify-content:space-between;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding:1.25rem 1.5rem}.modal-header h3{margin:0;font-size:18px;line-height:1.5;font-weight:600}.close-btn{cursor:pointer;border-style:none;background-color:transparent;font-size:1.5rem;line-height:2rem;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.close-btn:hover{--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;border-top-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding:1.25rem 1.5rem}.form-group{margin-bottom:1rem}.form-group label{margin-bottom:.375rem;display:block;font-size:13px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.form-group input,.form-group select,.form-group textarea{width:100%;border-radius:8px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.5rem .75rem;font-size:14px;line-height:1.5;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{cursor:not-allowed;--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1));opacity:1}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #8cc63f1a}.form-group textarea{min-height:80px;resize:vertical;font-family:inherit}.radio-group{display:flex;width:-moz-fit-content;width:fit-content;gap:0px;border-radius:8px;--tw-bg-opacity: 1;background-color:rgb(240 242 245 / var(--tw-bg-opacity, 1));padding:.25rem}.radio-label{margin:0;display:flex;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;justify-content:center;border-radius:6px;padding:.375rem 1.25rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.radio-label input[type=radio]{display:none}.radio-label:has(input:checked){--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));font-weight:500;--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1));box-shadow:0 1px 2px #0000001a}.checkbox-group{display:flex;gap:.75rem}.checkbox-label{display:flex;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;border-radius:8px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.5rem 1rem;font-weight:500;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.checkbox-label:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.checkbox-label input[type=checkbox]{margin-right:.5rem;height:1rem;width:1rem;cursor:pointer;accent-color:var(--color-primary)}.checkbox-label:has(input:checked){--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1))}.upload-area{cursor:pointer;border-radius:12px;border-width:2px;border-style:dashed;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1));padding:2.5rem;text-align:center;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.upload-area:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1))}.required{margin-left:.25rem;--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.form-hint{margin-top:.25rem;padding-left:1.5rem;font-size:12px;line-height:1.625;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.form-error{margin-top:.75rem;border-radius:8px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(255 204 199 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 242 240 / var(--tw-bg-opacity, 1));padding:.5rem .75rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.warning-box{margin-top:1rem;border-radius:12px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(255 229 143 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 251 230 / var(--tw-bg-opacity, 1));padding:.75rem}.missing-skus-area{margin-top:1rem;margin-bottom:1.25rem;overflow:hidden;border-radius:12px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(255 229 143 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 251 230 / var(--tw-bg-opacity, 1))}.missing-skus-header{display:flex;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;align-items:center;justify-content:space-between;padding:.75rem}.missing-skus-header:hover{--tw-bg-opacity: 1;background-color:rgb(255 248 214 / var(--tw-bg-opacity, 1))}.missing-skus-title{display:flex;align-items:center;gap:.5rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(173 104 0 / var(--tw-text-opacity, 1))}.missing-skus-toggle{--tw-text-opacity: 1;color:rgb(173 104 0 / var(--tw-text-opacity, 1));transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.missing-skus-area.expanded .missing-skus-toggle{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.missing-skus-list{max-height:0px;overflow:hidden;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.missing-skus-area.expanded .missing-skus-list{max-height:300px;overflow-y:auto;border-top-width:1px;--tw-border-opacity: 1;border-color:rgb(255 229 143 / var(--tw-border-opacity, 1))}#preview-area h4{margin-bottom:.75rem;font-size:16px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.preview-summary{margin-bottom:1rem;display:flex;gap:1rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.preview-table-container{margin-bottom:1rem;overflow-x:auto}#preview-table{table-layout:fixed;width:100%}#preview-table th,#preview-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#preview-table th:nth-child(1){width:18%}#preview-table th:nth-child(2){width:32%}#preview-table th:nth-child(3){width:12%}#preview-table th:nth-child(4){width:12%}#preview-table th:nth-child(5){width:10%}#preview-table th:nth-child(6){width:10%}#preview-table.batch-mode{table-layout:auto}#preview-table.batch-mode th,#preview-table.batch-mode td{white-space:nowrap}.import-form{margin-top:1rem}.no-data-hint{display:flex;height:400px;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.panel-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 1.5rem;text-align:center;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.panel-empty-state .empty-icon{--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1));opacity:.4}.panel-empty-state .empty-title{font-size:16px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.panel-empty-state .empty-message{font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.panel-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding-top:4rem;padding-bottom:4rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.panel-loading-state .spinner{height:2.5rem;width:2.5rem;border-radius:9999px;border-width:4px;--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));border-top-color:transparent;animation:spin .8s linear infinite}.panel-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 1.5rem;text-align:center}.panel-error-state .error-icon{--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.panel-error-state .error-title{font-size:16px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.panel-error-state .error-message{font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.pagination .page-info{font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}@keyframes spin{to{transform:rotate(360deg)}}.divider-vertical{margin-left:.25rem;margin-right:.25rem;height:1.5rem;width:1px;--tw-bg-opacity: 1;background-color:rgb(232 232 232 / var(--tw-bg-opacity, 1))}.product-selector-bar{margin-bottom:1.25rem;display:flex;align-items:center;gap:.75rem;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1.25rem;--tw-shadow: 0 2px 8px rgba(0, 0, 0, .05);--tw-shadow-colored: 0 2px 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.product-selector-bar label{font-weight:500;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.product-selector-bar select{flex:1 1 0%;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding:.5rem .75rem;max-width:400px}.searchable-select{position:relative;flex:1 1 0%;max-width:400px}.searchable-select-input{width:100%;cursor:text;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.5rem 2rem .5rem .75rem;font-size:14px;line-height:1.5;box-sizing:border-box}.searchable-select-input:focus{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));outline:2px solid transparent;outline-offset:2px;box-shadow:0 0 0 2px #2563eb1a}.searchable-select-input::-moz-placeholder{--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.searchable-select-input::placeholder{--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.searchable-select-arrow{pointer-events:none;position:absolute;right:.625rem;top:50%;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1));transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;transform:translateY(-50%)}.searchable-select.open .searchable-select-arrow{transform:translateY(-50%) rotate(180deg)}.searchable-select-clear{position:absolute;top:50%;display:none;height:1.25rem;width:1.25rem;cursor:pointer;align-items:center;justify-content:center;border-style:none;background-color:transparent;font-size:16px;line-height:1.5;line-height:1.25rem;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1));right:28px;transform:translateY(-50%)}.searchable-select-clear:hover{--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.searchable-select.has-value .searchable-select-clear{display:flex}.searchable-select-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:.25rem;display:none;max-height:280px;overflow-y:auto;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.searchable-select.open .searchable-select-dropdown{display:block}.searchable-select-option{cursor:pointer;border-bottom-width:1px;--tw-border-opacity: 1;border-color:rgb(240 240 240 / var(--tw-border-opacity, 1));padding:.625rem .75rem;font-size:14px;line-height:1.5;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.searchable-select-option:last-child{border-bottom-width:0px}.searchable-select-option:hover,.searchable-select-option.highlighted{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1))}.searchable-select-option.selected{--tw-text-opacity: 1;color:rgb(140 198 63 / var(--tw-text-opacity, 1));background-color:#2563eb1a}.searchable-select-option .option-name{font-weight:500}.searchable-select-option .option-info{margin-top:.125rem;font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.searchable-select-option .option-sku{font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.searchable-select-option .option-stock{float:right;font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.searchable-select-option.disabled-product{opacity:.6}.searchable-select-option.disabled-product .option-name:after{content:" [禁用]";font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.searchable-select-empty{padding-top:1.25rem;padding-bottom:1.25rem;text-align:center;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.searchable-select-highlight{--tw-bg-opacity: 1;background-color:rgb(254 240 138 / var(--tw-bg-opacity, 1));font-weight:500}.form-group .searchable-select{max-width:none}.form-group .searchable-select-input{width:100%}.dropdown-multiselect{position:relative;min-width:180px}.dropdown-trigger{display:flex;cursor:pointer;align-items:center;justify-content:space-between;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.5rem .75rem;font-size:14px;line-height:1.5}.dropdown-menu{position:absolute;top:100%;left:0;z-index:10;margin-top:.25rem;display:none;max-height:200px;width:100%;overflow-y:auto;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.dropdown-multiselect.open .dropdown-menu{display:block}.dropdown-item{display:flex;cursor:pointer;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:14px;line-height:1.5}.dropdown-item:hover{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1))}.dropdown-item .checkbox{display:flex;height:1rem;width:1rem;align-items:center;justify-content:center;border-radius:4px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1))}.dropdown-item.selected .checkbox{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1))}.dropdown-item.selected .checkbox:after{content:"";border-style:solid;--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1));width:4px;height:8px;border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-2px}.user-info{margin-right:.5rem;display:flex;align-items:center;gap:.75rem;border-right-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));padding-right:1rem}.user-display{display:flex;align-items:center;gap:.5rem;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.user-role-badge{border-radius:6px;--tw-bg-opacity: 1;background-color:rgb(232 245 214 / var(--tw-bg-opacity, 1));padding:.125rem .375rem;font-size:11px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(122 179 47 / var(--tw-text-opacity, 1))}.user-role-badge.admin{--tw-bg-opacity: 1;background-color:rgb(255 241 240 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(207 19 34 / var(--tw-text-opacity, 1))}.user-role-badge.operate{--tw-bg-opacity: 1;background-color:rgb(230 247 255 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(24 144 255 / var(--tw-text-opacity, 1))}.login-btn,.logout-btn{cursor:pointer;border-radius:8px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.375rem .75rem;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1));transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.login-btn:hover{--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.logout-btn:hover{--tw-border-opacity: 1;border-color:rgb(255 77 79 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 77 79 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.setup-hint{margin-bottom:1rem;text-align:center;font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.api-key-display{margin-top:.75rem;display:flex;align-items:center;gap:.5rem;border-radius:12px;--tw-bg-opacity: 1;background-color:rgb(245 245 245 / var(--tw-bg-opacity, 1));padding:.75rem}.api-key-display code{flex:1 1 0%;word-break:break-all;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:13px;line-height:1.5;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.copy-btn{display:flex;cursor:pointer;align-items:center;justify-content:center;border-radius:8px;border-style:none;--tw-bg-opacity: 1;background-color:rgb(140 198 63 / var(--tw-bg-opacity, 1));padding:.5rem;--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.copy-btn:hover{--tw-bg-opacity: 1;background-color:rgb(122 179 47 / var(--tw-bg-opacity, 1))}.warning-text{font-size:14px;line-height:1.5;--tw-text-opacity: 1;color:rgb(250 173 20 / var(--tw-text-opacity, 1))}.toast-container{pointer-events:none;position:fixed;top:1.5rem;right:1.5rem;z-index:2000;display:flex;flex-direction:column;gap:.75rem}.toast{pointer-events:auto;display:flex;min-width:280px;max-width:400px;align-items:center;gap:.75rem;border-radius:12px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.75rem 1rem;--tw-shadow: 0 4px 16px rgba(0, 0, 0, .08);--tw-shadow-colored: 0 4px 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow);animation:toastIn .3s ease-out;transform:translate(0);transition:all .3s cubic-bezier(.4,0,.2,1)}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast.hide{opacity:0;transform:translate(20px)}.toast-icon{height:1.25rem;width:1.25rem;flex-shrink:0}.toast-content{flex:1 1 0%;font-size:14px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.toast-success .toast-icon{--tw-text-opacity: 1;color:rgb(82 196 26 / var(--tw-text-opacity, 1))}.toast-error .toast-icon{--tw-text-opacity: 1;color:rgb(255 77 79 / var(--tw-text-opacity, 1))}.toast-info .toast-icon{--tw-text-opacity: 1;color:rgb(24 144 255 / var(--tw-text-opacity, 1))}.expandable-row{cursor:pointer;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.expandable-row:hover{--tw-bg-opacity: 1;background-color:rgb(245 247 250 / var(--tw-bg-opacity, 1))}.expand-icon{margin-right:.5rem;display:inline-block;height:1rem;width:1rem;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1));transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}.expanded .expand-icon{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.expanded-content-row{display:none;--tw-bg-opacity: 1;background-color:rgb(250 250 250 / var(--tw-bg-opacity, 1))}.expanded-content-row.show{display:table-row}.expanded-content-cell{padding:0!important}.expanded-panel{border-left-width:4px;--tw-border-opacity: 1;border-color:rgb(140 198 63 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:1rem 3rem;--tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / .05);--tw-shadow-colored: inset 0 2px 4px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.expanded-panel-title{margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem;font-size:14px;line-height:1.5;font-weight:600;--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.expanded-panel-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.mini-card{display:flex;flex-direction:column;gap:.25rem;border-radius:6px;border-width:1px;--tw-border-opacity: 1;border-color:rgb(232 232 232 / var(--tw-border-opacity, 1));--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1));padding:.75rem}.mini-card-title{font-size:13px;line-height:1.5;font-weight:500;--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.mini-card-subtitle{font-size:12px;line-height:1.5;--tw-text-opacity: 1;color:rgb(153 153 153 / var(--tw-text-opacity, 1))}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.relative{position:relative}.top-header{top:64px}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline{display:inline}.flex{display:flex}.\!table{display:table!important}.table{display:table}.grid{display:grid}.\!hidden{display:none!important}.hidden{display:none}.h-12{height:3rem}.h-16{height:4rem}.w-12{width:3rem}.w-16{width:4rem}.min-w-\[280px\]{min-width:280px}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:12px}.border{border-width:1px}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-success\/10{background-color:#52c41a1a}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.p-4{padding:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.text-center{text-align:center}.text-lg{font-size:18px;line-height:1.5}.text-sm{font-size:14px;line-height:1.5}.text-xs{font-size:12px;line-height:1.5}.font-bold{font-weight:700}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-amber-800{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-success{--tw-text-opacity: 1;color:rgb(82 196 26 / var(--tw-text-opacity, 1))}.text-text-primary{--tw-text-opacity: 1;color:rgb(31 31 31 / var(--tw-text-opacity, 1))}.text-text-secondary{--tw-text-opacity: 1;color:rgb(102 102 102 / var(--tw-text-opacity, 1))}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){html,body{height:auto;overflow-x:hidden}body{overflow-y:auto}.app-wrapper{flex-direction:column!important;height:auto!important;min-height:100vh;width:100%;overflow-y:visible}.sidebar{width:100%!important;height:auto!important;flex-shrink:0;border-right:0;border-bottom:1px solid var(--color-border, #e8e8e8);position:sticky;top:0;z-index:30;background:#fff}.logo-area{height:52px;padding:0 16px;justify-content:flex-start;border-bottom:1px solid #f0f0f0}.logo-icon{width:28px;height:28px}.logo-text .brand{font-size:15px}.side-nav{flex-direction:row!important;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:6px 8px;gap:4px;flex-wrap:nowrap;-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent 100%);mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent 100%)}.side-nav::-webkit-scrollbar{display:none}.nav-item{flex:0 0 auto;width:auto!important;flex-direction:row!important;gap:6px!important;padding:8px 12px!important;font-size:13px;white-space:nowrap;text-align:left!important;min-height:40px}.nav-item svg{width:16px!important;height:16px!important;margin-right:0!important}.nav-item span{flex:none}.main-content{width:100%;min-height:0;height:auto!important}.content-scroll-area{overflow:visible;padding:12px 16px}.top-header{height:auto;min-height:48px;flex-wrap:wrap;gap:6px 8px;padding:8px 12px;align-items:center;justify-content:flex-end}.breadcrumb{display:none}.header-right{flex:1 1 100%;flex-wrap:wrap;gap:6px;justify-content:flex-end;align-items:center;min-width:0}.header-right .lang-btn,.header-right .refresh-btn,.header-right .warehouse-btn,.header-right .login-btn,.header-right .logout-btn{height:32px;padding:4px 8px;font-size:12px}.update-info{display:none}.user-display{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.user-display svg{flex-shrink:0}.warehouse-dropdown,.lang-dropdown-menu{right:0;left:auto;max-width:calc(100vw - 24px);max-height:60vh;overflow-y:auto}.page-header{margin-bottom:14px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.page-title{font-size:17px}.section-header{flex-wrap:wrap;gap:10px;padding:14px}.section-title{font-size:15px;flex:1 1 100%}.action-buttons{width:100%;flex-wrap:wrap;gap:8px}.action-buttons .action-btn{flex:1 1 auto;min-height:40px;justify-content:center}.sub-tabs{overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-bottom:12px;-webkit-mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent 100%);mask-image:linear-gradient(to right,#000 calc(100% - 24px),transparent 100%)}.sub-tabs::-webkit-scrollbar{display:none}.sub-tab{flex:0 0 auto;white-space:nowrap;min-height:40px;padding:8px 14px}.filter-bar{padding:12px;gap:10px;flex-direction:column;align-items:stretch}.filter-group{width:100%;gap:4px}.filter-group input,.filter-group select{width:100%;min-width:0!important;min-height:40px}.filter-actions{margin-left:0;width:100%;gap:8px}.filter-actions .filter-btn{flex:1 1 0;min-height:40px}.dropdown-multiselect{width:100%}.dropdown-multiselect .dropdown-trigger{min-height:40px}.dropdown-multiselect .dropdown-menu{max-width:100%;max-height:50vh;overflow-y:auto}.table-container{overflow:hidden}.table-container table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap;border-collapse:collapse}.table-container thead,.table-container tbody,.table-container tr{display:table;width:-moz-max-content;width:max-content;min-width:100%;table-layout:auto}.table-container th,.table-container td{padding:10px 12px;font-size:13px;white-space:nowrap}main table:not(.table-container table):not(#preview-table){display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.pagination{flex-direction:column;gap:10px;align-items:stretch;padding:12px}.pagination-info{text-align:center;font-size:12px}.pagination-controls{justify-content:space-between;flex-wrap:wrap;gap:6px}.pagination-controls button{min-height:36px;flex:0 0 auto}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important;margin-bottom:14px!important}.stat-card{padding:14px!important}.stat-label{font-size:12px;margin-bottom:6px!important}.stat-value{font-size:20px}.dashboard-grid{grid-template-columns:1fr!important;gap:14px!important}.chart-card.full-width{grid-column:1 / -1!important}.modal{align-items:flex-start;width:100vw!important;height:100vh!important;height:100dvh!important;background-color:#00000080;overscroll-behavior:contain}body:has(.modal.show),body:has(.modal[style*="display: flex"]),body:has(.modal[style*="display:flex"]){overflow:hidden!important;position:relative}.modal-content{width:100%!important;max-width:100%!important;max-height:100vh!important;max-height:100dvh!important;height:100vh;height:100dvh;border-radius:0!important;margin:0}.modal-content.modal-small,.modal-content.modal-large{max-width:100%!important}.modal-header{padding:14px 16px;position:sticky;top:0;background:#fff;z-index:5}.modal-header h3{font-size:16px}.close-btn{width:40px;height:40px;display:flex!important;align-items:center;justify-content:center;font-size:24px;line-height:1}.modal-body{padding:14px 16px}.modal-footer{padding:12px 16px;flex-wrap:wrap;gap:8px;position:sticky;bottom:0;background:#fff;z-index:5}.modal-footer .btn,.modal-footer button{flex:1 1 auto;min-height:44px}.form-grid,.form-grid-2,.form-row,.face-config-grid{grid-template-columns:1fr!important;display:grid!important;gap:10px!important}.form-group input,.form-group select,.form-group textarea{min-height:40px;font-size:14px}.radio-group{width:100%;display:flex}.radio-group .radio-label{flex:1 1 0;padding:8px 12px;text-align:center;justify-content:center}.checkbox-group{flex-wrap:wrap;gap:8px}.checkbox-label{flex:1 1 calc(50% - 4px);min-height:40px;padding:8px 10px;font-size:13px}.toast{max-width:calc(100vw - 24px)}.action-btn-small{min-height:36px;padding:8px 10px}.\!modal{align-items:flex-start!important;width:100vw!important;height:100vh!important;height:100dvh!important;background-color:#00000080!important;overscroll-behavior:contain!important}body:has(.\!modal.show),body:has(.\!modal[style*="display: flex"]),body:has(.\!modal[style*="display:flex"]){overflow:hidden!important;position:relative!important}}@media (max-width: 640px){.top-header{padding:6px 10px}.header-right .login-btn,.header-right .logout-btn{padding:4px 10px;font-size:12px}.header-right .lang-btn,.header-right .warehouse-btn,.header-right .refresh-btn{gap:4px}.header-right .refresh-btn span{display:none}.lang-btn span#current-lang-text{max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}.warehouse-btn span{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:inline-block}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px!important}.stat-card{padding:12px!important}.stat-value{font-size:18px}.checkbox-label{flex:1 1 100%}.filter-bar{padding:10px}.filter-group{gap:2px!important}.filter-group label{margin:0 0 0 2px;font-size:11px;line-height:1.3;color:var(--color-text-secondary, #8c8c8c)}.header-right .refresh-btn{padding:4px;min-width:32px;width:32px;justify-content:center}.user-display{max-width:90px}.user-role-badge{font-size:10px;padding:1px 4px}.update-info{display:none}}@media (max-width: 480px){.top-header{padding:6px 8px;gap:4px 6px}.header-right{gap:4px}.header-right .lang-btn,.header-right .warehouse-btn,.header-right .login-btn,.header-right .logout-btn{height:30px;padding:4px 6px;font-size:12px}.lang-btn>svg:last-child,.warehouse-btn>svg:last-child{display:none}.user-display{max-width:72px;font-size:11px}.sub-tab{padding:6px 10px;font-size:12px}}.filter-trigger-bar{display:none}.filter-bar>.filter-drawer-header{display:none}.filter-drawer-backdrop{display:none}@media (max-width: 640px){.filter-bar:not(.is-drawer-open){display:none!important}.filter-trigger-bar{display:flex;align-items:center;justify-content:flex-start;margin:0 0 12px;padding:0}.filter-trigger-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;background:var(--color-card-bg, #ffffff);border:1px solid var(--color-border, #d9d9d9);border-radius:999px;font-size:14px;font-weight:500;color:var(--color-text-primary, #262626);cursor:pointer;box-shadow:0 1px 2px #0000000a;line-height:1;min-height:38px}.filter-trigger-btn:active{transform:scale(.98)}.filter-trigger-btn.has-filters{background:var(--color-primary, #8cc63f);color:#fff;border-color:var(--color-primary, #8cc63f)}.filter-trigger-btn .filter-trigger-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#00000014;color:inherit;font-size:12px;font-weight:600;line-height:1}.filter-trigger-btn.has-filters .filter-trigger-badge{background:#ffffff40;color:#fff}.filter-drawer-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000;z-index:9998;pointer-events:none;transition:background .2s ease}.filter-drawer-backdrop.show{background:#00000073;pointer-events:auto}.filter-bar.is-drawer-open{display:grid!important;grid-template-columns:1fr 1fr;gap:12px;align-content:start;position:fixed;left:0;right:0;bottom:0;top:auto;width:100%;max-height:85vh;margin:0;padding:0 16px 16px;background:var(--color-card-bg, #ffffff);border-radius:16px 16px 0 0;box-shadow:0 -8px 24px #0000002e;z-index:9999;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:filterDrawerSlideUp .22s ease-out}@keyframes filterDrawerSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.filter-bar.is-drawer-open>.filter-drawer-header{display:flex;align-items:center;justify-content:space-between;grid-column:1 / -1;position:sticky;top:0;z-index:2;margin:0 -16px 4px;padding:18px 16px 12px;background:var(--color-card-bg, #ffffff);border-bottom:1px solid var(--color-border, #f0f0f0)}.filter-bar.is-drawer-open>.filter-drawer-header:before{content:"";position:absolute;top:6px;left:50%;transform:translate(-50%);width:36px;height:4px;border-radius:2px;background:var(--color-border, #d9d9d9)}.filter-drawer-title{font-size:16px;font-weight:600;color:var(--color-text-primary, #262626)}.filter-drawer-close{background:transparent;border:none;font-size:26px;line-height:1;color:var(--color-text-secondary, #8c8c8c);cursor:pointer;padding:4px 8px}.filter-bar.is-drawer-open>.filter-group{width:100%;min-width:0;margin:0}.filter-bar.is-drawer-open>.filter-group input,.filter-bar.is-drawer-open>.filter-group select,.filter-bar.is-drawer-open>.filter-group .dropdown-multiselect{width:100%;min-width:0!important}.filter-bar.is-drawer-open>.filter-actions{grid-column:1 / -1;position:sticky;bottom:0;margin:8px -16px 0;padding:12px 16px calc(12px + env(safe-area-inset-bottom,0));background:var(--color-card-bg, #ffffff);border-top:1px solid var(--color-border, #f0f0f0);display:flex;gap:10px;z-index:2}.filter-bar.is-drawer-open>.filter-actions .filter-btn{flex:1;min-height:44px;font-size:14px}body.filter-drawer-open{overflow:hidden}.filter-bar.is-drawer-open .dropdown-multiselect .dropdown-menu{max-height:240px}}.warehouse-group-label{padding:6px 12px 4px;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;background:#f9fafb}.warehouse-option-indent{padding-left:24px!important}
