:root{--sidebar-width:208px;--sidebar-collapsed-width:72px;--color-bg-base:#f8f9fa;--color-bg-surface:#fff;--color-bg-surface-active:#f3f4f6;--color-bg-surface-hover:#f9fafb;--color-border:#e5e7eb;--color-text-primary:#1f2937;--color-text-secondary:#4b5563;--color-text-muted:#9ca3af;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-success:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-info:#3b82f6;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:24px;--spacing-2xl:32px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--glow-primary:none}body{background-color:var(--color-bg-base);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;margin:0;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.text-base{font-size:14px}.text-lg{font-size:16px}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.text-success{color:var(--color-success)}@media (width>=1440px){:root{--sidebar-width:240px;--sidebar-collapsed-width:80px;--spacing-xs:5px;--spacing-sm:10px;--spacing-md:14px;--spacing-lg:18px;--spacing-xl:28px;--spacing-2xl:36px}body{font-size:15.5px!important}.text-xs{font-size:13.5px!important}.text-sm{font-size:14.5px!important}.text-base{font-size:15.5px!important}.text-lg{font-size:18px!important}.input{height:auto!important;padding:8px 14px!important;font-size:14.5px!important}.btn{height:auto!important;padding:8px 18px!important;font-size:14.5px!important}.erp-table{font-size:14.5px!important}.erp-table th,.erp-table td{padding:10px 14px!important}}@media (width>=2500px){:root{--spacing-xs:6px;--spacing-sm:12px;--spacing-md:16px;--spacing-lg:20px;--spacing-xl:32px;--spacing-2xl:40px}body{font-size:17.5px!important}.text-xs{font-size:15.5px!important}.text-sm{font-size:16.5px!important}.text-base{font-size:17.5px!important}.text-lg{font-size:20px!important}.input{padding:10px 16px!important;font-size:16.5px!important}.btn{padding:10px 22px!important;font-size:16.5px!important}.erp-table{font-size:16.5px!important}.erp-table th,.erp-table td{padding:12px 18px!important}}:root{--color-bg-base:#f8f9fa;--color-bg-surface:#fff;--color-bg-surface-active:#f3f4f6;--color-bg-surface-hover:#f9fafb;--color-border:#e5e7eb;--color-text-primary:#1f2937;--color-text-secondary:#4b5563;--color-text-muted:#9ca3af;--color-text-inverse:#fff;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-subtle:#3b82f626;--color-success:#10b981;--color-success-subtle:#10b98126;--color-warning:#f59e0b;--color-warning-subtle:#f59e0b26;--color-danger:#ef4444;--color-danger-subtle:#ef444426;--color-info:#3b82f6;--color-info-subtle:#3b82f626}body{background-color:var(--color-bg-base);color:var(--color-text-primary)}:root{--spacing-2xs:2px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:12px;--spacing-lg:16px;--spacing-xl:24px;--spacing-2xl:32px;--radius-xs:4px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 6px -1px #0006, 0 2px 4px -1px #0003;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -2px #0000004d;--glow-primary:0 0 0 1px var(--color-primary);--glow-danger:0 0 0 1px var(--color-danger);--font-sans:"Inter", "Noto Sans TC", "Noto Sans JP", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", Consolas, monospace}body{font-family:var(--font-sans);background-color:var(--color-bg-base);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px;line-height:1.5}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);margin:0;font-weight:600}h1{letter-spacing:-.02em;font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.125rem}h4{font-size:1rem}.text-sm{font-size:12px}.text-xs{font-size:11px}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.font-mono{font-family:var(--font-mono)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.input{background-color:var(--color-bg-base);border:1px solid var(--color-border);color:var(--color-text-primary);border-radius:var(--radius-sm);box-sizing:border-box;outline:none;width:100%;padding:6px 10px;font-size:13px;transition:border-color .1s,box-shadow .1s}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}.input::placeholder{color:var(--color-text-muted)}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;outline:none;justify-content:center;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;transition:all .1s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-outline{color:var(--color-text-primary);border:1px solid var(--color-border);background-color:#0000}.btn-outline:hover:not(:disabled){background-color:var(--color-bg-surface-active)}.btn-ghost{color:var(--color-text-secondary);background-color:#0000}.btn-ghost:hover:not(:disabled){background-color:var(--color-bg-surface-active);color:var(--color-text-primary)}.card{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.badge{border-radius:var(--radius-sm);align-items:center;padding:2px 6px;font-size:12px;font-weight:600;display:inline-flex}.badge-success{color:var(--color-success);background-color:#ecfdf5}.badge-warning{color:var(--color-warning);background-color:#fffbeb}.badge-danger{color:var(--color-danger);background-color:#fef2f2}.badge-info{color:var(--color-info);background-color:#eff6ff}.badge-neutral{color:var(--color-text-secondary);background-color:#f3f4f6}.kpi-grid{gap:var(--spacing-md);margin-bottom:var(--spacing-md);display:grid}@media (width>=1024px){.kpi-grid{grid-template-columns:repeat(5,1fr)}}@media (width>=768px) and (width<=1023px){.kpi-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=767px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}.erp-table{border-collapse:collapse;width:100%;font-size:13px}.erp-table th{text-align:left;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);padding:8px 12px;font-weight:500}.erp-table td{border-bottom:1px solid var(--color-border);padding:8px 12px}.erp-table tr:hover:not(.detail-row){background-color:var(--color-bg-surface-hover)}.cell-danger{color:var(--color-danger);font-weight:600}.cell-danger span.box{border-radius:var(--radius-sm);background-color:#fef2f2;padding:4px 12px;display:inline-block}.cell-warning{color:var(--color-warning);font-weight:600}.cell-warning span.box{border-radius:var(--radius-sm);background-color:#fffbeb;padding:4px 12px;display:inline-block}.cell-neutral{color:var(--color-text-secondary)}.sidebar-collapsed .logo-text,.sidebar-collapsed .nav-label{display:none}@media (width<=767px){.app-shell{flex-direction:column;overflow:visible}.app-sidebar.mobile-hidden{display:none!important}.app-sidebar.mobile-open{z-index:100;background-color:var(--color-bg-base);width:280px;max-width:80%;height:100vh;position:fixed;top:0;left:0;box-shadow:4px 0 24px #00000026;display:flex!important}.sidebar-logo{padding:24px 20px!important;font-size:20px!important}.sidebar-nav-container{padding:0 12px!important}.nav-item{white-space:normal!important;gap:12px!important;padding:0 18px!important;font-size:15px!important}.sidebar-section-title{margin:18px 20px 8px!important;font-size:12px!important}.main-area{height:auto;overflow-y:visible}.app-header{z-index:50;padding:12px 16px;position:sticky;top:0}.page-content{padding:16px}.hide-on-mobile{display:none!important}.mobile-scroll-wrapper{-webkit-overflow-scrolling:touch;width:100%;max-width:100%;margin-bottom:16px;overflow-x:auto}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}}*{box-sizing:border-box;margin:0;padding:0}.app-shell{background-color:var(--color-bg-base);width:100vw;min-height:100vh;display:flex;overflow:hidden}.app-sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);max-width:var(--sidebar-width);flex:0 0 var(--sidebar-width);background-color:var(--color-bg-base);border-right:1px solid var(--color-border);flex-direction:column;height:100vh;transition:width .2s cubic-bezier(.4,0,.2,1),min-width .2s cubic-bezier(.4,0,.2,1),max-width .2s cubic-bezier(.4,0,.2,1),flex .2s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:0}.sidebar-logo{padding:38px 20px 32px}.logo-text-group{align-items:center;gap:12px;display:flex}.logo-icon-box{background-color:var(--color-primary);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.logo-text{color:var(--color-text-primary);letter-spacing:-.5px;white-space:nowrap;font-size:20px;font-weight:800}.btn-toggle-sidebar{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;justify-content:center;align-items:center;padding:6px;transition:all .15s;display:flex}.btn-toggle-sidebar:hover{color:var(--color-text-primary);background:#0000000d}.sidebar-nav-container{padding:0 12px}.nav-item{height:64px;color:var(--color-text-secondary);white-space:nowrap;border-radius:14px;align-items:center;gap:14px;margin:4px 0;padding:0 18px;font-size:16px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,padding .2s,justify-content .2s;display:flex}.nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.nav-icon svg{width:24px!important;height:24px!important}.nav-item.active{color:#5865f2;background:#4c6fff1f}.nav-item:hover:not(.active){color:var(--color-text-primary);background:#94a3b81a}.sidebar-section-title{color:#8b95a7;text-transform:uppercase;letter-spacing:.05em;margin:24px 20px 12px;font-size:13px;font-weight:500;transition:opacity .2s,height .2s,margin .2s}.sidebar-collapsed{--sidebar-width:var(--sidebar-collapsed-width)}.sidebar-collapsed .logo-text,.sidebar-collapsed .nav-label{display:none}.sidebar-collapsed .sidebar-section-title{opacity:0;pointer-events:none;height:0;margin:0;overflow:hidden}.sidebar-collapsed .nav-item{justify-content:center;gap:0!important;padding:0!important}.sidebar-collapsed .sidebar-logo{flex-direction:column;justify-content:center;gap:16px;padding:36px 0 24px!important}.sidebar-collapsed .logo-text-group{justify-content:center}.sidebar-collapsed .btn-toggle-sidebar{margin-top:4px}.main-area{flex-direction:column;flex:1;min-width:0;height:100vh;display:flex;overflow-y:auto}.app-header{border-bottom:1px solid var(--color-border);background-color:var(--color-bg-surface);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 32px;display:flex}.page-content{box-sizing:border-box;flex:1;width:100%;padding:24px 32px}.page-content-full{width:100%!important;max-width:none!important}@media (width<=767px){.app-shell{flex-direction:column;overflow:visible}.app-sidebar.mobile-hidden{display:none!important}.app-sidebar.mobile-open{z-index:100;background-color:var(--color-bg-base);width:280px;max-width:80%;height:100vh;position:fixed;top:0;left:0;box-shadow:4px 0 24px #00000026;display:flex!important}.sidebar-logo{padding:24px 20px!important;font-size:20px!important}.sidebar-nav-container{padding:0 12px!important}.nav-item{white-space:normal!important;gap:12px!important;padding:0 18px!important;font-size:15px!important}.sidebar-section-title{margin:18px 20px 8px!important;font-size:12px!important}.main-area{height:auto;overflow-y:visible}.app-header{z-index:50;padding:12px 16px;position:sticky;top:0}.page-content{padding:16px}.hide-on-mobile{display:none!important}.mobile-scroll-wrapper{-webkit-overflow-scrolling:touch;width:100%;max-width:100%;margin-bottom:16px;overflow-x:auto}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}}.mobile-preview-frame{border:1px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg-base);max-width:400px;box-shadow:var(--shadow-md);margin:0 auto;padding:16px;overflow:hidden}.mobile-preview-frame .hide-on-mobile{display:none!important}
