.layout-container{background:var(--bg-primary);width:100vw;height:100vh;display:flex;overflow:hidden}.layout-content-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.layout-main{padding:var(--space-2xl);flex:1;overflow:hidden auto}.sidebar-overlay{z-index:990;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;display:none;position:fixed;inset:0}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--surface-border);z-index:1000;height:100vh;transition:transform var(--transition-slow);flex-direction:column;display:flex;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-header{padding:var(--space-xl) var(--space-xl);border-bottom:1px solid var(--surface-border);min-height:var(--topbar-height);justify-content:space-between;align-items:center;display:flex}.sidebar-brand{align-items:center;gap:var(--space-md);display:flex}.sidebar-brand-icon{border-radius:var(--radius-md);background:var(--accent-primary-soft);width:36px;height:36px;color:var(--accent-primary);justify-content:center;align-items:center;display:flex}.sidebar-brand-text{font-size:var(--font-lg);color:var(--text-primary);letter-spacing:-.01em;font-weight:700}.sidebar-close-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.sidebar-close-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-nav{padding:var(--space-lg) var(--space-md);flex:1;overflow-y:auto}.sidebar-section-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-lg) var(--space-md) var(--space-sm);font-weight:600}.sidebar-nav-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-md);color:var(--text-secondary);transition:all var(--transition-fast);margin-bottom:2px;font-weight:500;text-decoration:none;display:flex}.sidebar-nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-primary-soft);color:var(--accent-primary);font-weight:600}.sidebar-nav-item svg{opacity:.7;flex-shrink:0}.sidebar-nav-item.active svg{opacity:1}.sidebar-footer{padding:var(--space-lg);border-top:1px solid var(--surface-border)}.sidebar-user{align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);transition:background var(--transition-fast);display:flex}.sidebar-user:hover{background:var(--bg-glass-hover)}.sidebar-avatar{border-radius:var(--radius-full);background:var(--accent-tertiary-soft);width:36px;height:36px;font-size:var(--font-sm);color:var(--accent-tertiary);flex-shrink:0;justify-content:center;align-items:center;font-weight:600;display:flex;overflow:hidden}.sidebar-avatar img{object-fit:cover;width:100%;height:100%}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.sidebar-user-role{font-size:var(--font-xs);color:var(--text-muted)}.sidebar-logout-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout-btn:hover{background:var(--accent-danger-soft);color:var(--accent-danger)}.topbar{height:var(--topbar-height);min-height:var(--topbar-height);padding:0 var(--space-2xl);background:var(--bg-secondary);border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;gap:var(--space-lg);display:flex}.topbar-left{align-items:center;gap:var(--space-lg);display:flex}.topbar-hamburger{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;justify-content:center;align-items:center;display:flex}.topbar-hamburger:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.topbar-title{font-size:var(--font-xl);color:var(--text-primary);font-weight:600}.topbar-search{flex:1;max-width:400px;position:relative}.topbar-search svg{left:var(--space-md);color:var(--text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.topbar-search input{width:100%;padding:var(--space-sm) var(--space-lg);background:var(--bg-input);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-primary);transition:all var(--transition-fast);padding-left:38px}.topbar-search input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.topbar-search input::placeholder{color:var(--text-muted)}.topbar-right{align-items:center;gap:var(--space-md);display:flex}.topbar-icon-btn{border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex;position:relative}.topbar-icon-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.topbar-badge{border-radius:var(--radius-full);background:var(--accent-danger);border:2px solid var(--bg-secondary);width:8px;height:8px;position:absolute;top:4px;right:4px}.topbar-user{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);display:flex}.topbar-user:hover{background:var(--bg-glass-hover)}.topbar-user-avatar{border-radius:var(--radius-full);background:var(--accent-primary-soft);width:32px;height:32px;color:var(--accent-primary);font-size:var(--font-xs);justify-content:center;align-items:center;font-weight:600;display:flex;overflow:hidden}.topbar-user-avatar img{object-fit:cover;width:100%;height:100%}.topbar-user-name{font-size:var(--font-sm);color:var(--text-primary);font-weight:500}@media (width<=1024px){.layout-main{padding:var(--space-lg)}}@media (width<=768px){.topbar{padding:0 var(--space-lg)}.topbar-search,.topbar-user-name{display:none}.layout-main{padding:var(--space-md)}}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{z-index:0;position:absolute;inset:0;overflow:hidden}.login-bg-orb{filter:blur(80px);opacity:.3;border-radius:50%;animation:8s ease-in-out infinite float;position:absolute}.login-bg-orb:first-child{background:var(--accent-primary);width:400px;height:400px;animation-delay:0s;top:-100px;right:-100px}.login-bg-orb:nth-child(2){background:var(--accent-secondary);width:300px;height:300px;animation-delay:2s;bottom:-80px;left:-80px}.login-bg-orb:nth-child(3){background:var(--accent-tertiary);width:200px;height:200px;animation-delay:4s;top:50%;left:50%;transform:translate(-50%,-50%)}.login-bg-grid{background-image:linear-gradient(#0ea5e90d 1px,#0000 1px),linear-gradient(90deg,#0ea5e90d 1px,#0000 1px);background-size:60px 60px;position:absolute;inset:0}.login-card{z-index:1;width:100%;max-width:420px;margin:var(--space-xl);padding:var(--space-4xl) var(--space-3xl);border:1px solid var(--surface-border);border-radius:var(--radius-2xl);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-xl);background:#ffffffd9;animation:.5s ease-out scaleIn;position:relative}.login-logo{align-items:center;gap:var(--space-md);margin-bottom:var(--space-3xl);flex-direction:column;display:flex}.login-logo-icon{border-radius:var(--radius-xl);background:var(--accent-primary-soft);width:64px;height:64px;color:var(--accent-primary);box-shadow:0 0 30px var(--accent-primary-glow);justify-content:center;align-items:center;display:flex}.login-title{font-size:var(--font-2xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:700}.login-subtitle{font-size:var(--font-sm);color:var(--text-muted)}.login-form{gap:var(--space-xl);flex-direction:column;display:flex}.login-field{gap:var(--space-sm);flex-direction:column;display:flex}.login-field label{font-size:var(--font-sm);color:var(--text-secondary);font-weight:500}.login-input-wrap{align-items:center;display:flex;position:relative}.login-input-wrap svg{left:var(--space-lg);color:var(--text-muted);pointer-events:none;transition:color var(--transition-fast);position:absolute}.login-input-wrap input{width:100%;padding:var(--space-md) var(--space-lg);background:var(--bg-input);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-md);color:var(--text-primary);transition:all var(--transition-fast);padding-left:44px}.login-input-wrap input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.login-input-wrap input:focus+svg{color:var(--accent-primary)}.login-input-wrap:has(input:focus) svg{color:var(--accent-primary)}.login-input-wrap input::placeholder{color:var(--text-muted)}.login-btn{width:100%;padding:var(--space-md) var(--space-lg);background:var(--accent-primary);color:var(--text-inverse);font-size:var(--font-md);border-radius:var(--radius-md);justify-content:center;align-items:center;gap:var(--space-sm);transition:all var(--transition-fast);margin-top:var(--space-sm);font-weight:600;display:flex}.login-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);background:#0369a1;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{background:var(--accent-danger-soft);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg);color:var(--accent-danger);font-size:var(--font-sm);align-items:center;gap:var(--space-sm);animation:fadeIn var(--transition-fast);border:1px solid #ef44444d;display:flex}.login-footer{text-align:center;margin-top:var(--space-2xl);font-size:var(--font-xs);color:var(--text-muted)}.fullscreen-loader{z-index:9999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffffe6;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loader-spinner{border:5px solid var(--accent-primary-soft);border-top:5px solid var(--accent-primary);border-radius:50%;width:50px;height:50px;animation:1s linear infinite spin}.loader-text{margin-top:var(--space-lg);font-size:var(--font-lg);color:var(--text-primary);font-weight:600}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stat-card{align-items:flex-start;gap:var(--space-lg);padding:var(--space-xl);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:all var(--transition-normal);animation:.4s ease-out backwards fadeInUp;display:flex}.stat-card:hover{border-color:var(--surface-border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.stat-card-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.stat-card-icon.green{background:var(--accent-primary-soft);color:var(--accent-primary)}.stat-card-icon.blue{background:var(--accent-secondary-soft);color:var(--accent-secondary)}.stat-card-icon.purple{background:var(--accent-tertiary-soft);color:var(--accent-tertiary)}.stat-card-icon.orange{background:var(--accent-warning-soft);color:var(--accent-warning)}.stat-card-icon.cyan{background:var(--accent-info-soft);color:var(--accent-info)}.stat-card-icon.red{background:var(--accent-danger-soft);color:var(--accent-danger)}.stat-card-content{flex:1;min-width:0}.stat-card-label{font-size:var(--font-sm);color:var(--text-muted);margin-bottom:var(--space-xs)}.stat-card-value{font-size:var(--font-3xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:700;line-height:1.2}.stat-card-trend{font-size:var(--font-xs);margin-top:var(--space-xs);border-radius:var(--radius-sm);align-items:center;gap:2px;padding:2px 6px;font-weight:500;display:inline-flex}.stat-card-trend.up{color:var(--accent-primary);background:var(--accent-primary-soft)}.stat-card-trend.down{color:var(--accent-danger);background:var(--accent-danger-soft)}.status-badge{border-radius:var(--radius-full);font-size:var(--font-xs);white-space:nowrap;align-items:center;gap:4px;padding:3px 10px;font-weight:600;display:inline-flex}.status-badge.success{background:var(--accent-primary-soft);color:var(--accent-primary)}.status-badge.warning{background:var(--accent-warning-soft);color:var(--accent-warning)}.status-badge.danger{background:var(--accent-danger-soft);color:var(--accent-danger)}.status-badge.info{background:var(--accent-secondary-soft);color:var(--accent-secondary)}.status-badge.purple{background:var(--accent-tertiary-soft);color:var(--accent-tertiary)}.status-badge.default{background:var(--bg-glass-hover);color:var(--text-secondary)}.status-badge-dot{border-radius:var(--radius-full);background:currentColor;width:6px;height:6px}.data-table-wrap{border-radius:var(--radius-lg);border:1px solid var(--surface-border);background:var(--bg-card);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:var(--font-sm)}.data-table thead{z-index:5;position:sticky;top:0}.data-table th{padding:var(--space-md) var(--space-lg);text-align:left;color:var(--text-secondary);font-weight:600;font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--surface-border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast);background:#e0f2fee6}.data-table th:hover{color:var(--text-primary)}.data-table th.sorted{color:var(--accent-primary)}.data-table td{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--surface-border);color:var(--text-primary);white-space:nowrap;vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--bg-glass-hover)}.data-table-actions{gap:var(--space-sm);display:flex}.data-table-action-btn{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.data-table-action-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.data-table-action-btn.view:hover{color:var(--accent-secondary);background:var(--accent-secondary-soft)}.data-table-action-btn.edit:hover{color:var(--accent-warning);background:var(--accent-warning-soft)}.data-table-action-btn.delete:hover{color:var(--accent-danger);background:var(--accent-danger-soft)}.data-table-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--surface-border);font-size:var(--font-sm);color:var(--text-muted);justify-content:space-between;align-items:center;display:flex}.data-table-pagination{align-items:center;gap:var(--space-xs);display:flex}.data-table-page-btn{min-width:32px;height:32px;padding:0 var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-secondary);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.data-table-page-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.data-table-page-btn.active{background:var(--accent-primary);color:var(--text-inverse)}.data-table-page-btn:disabled{opacity:.3;cursor:not-allowed}.data-table-empty{text-align:center;padding:var(--space-5xl) var(--space-xl);color:var(--text-muted)}.data-table-empty svg{margin-bottom:var(--space-lg);opacity:.3}.search-filter-bar{gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap;align-items:center;display:flex}.search-input-wrap{flex:1;min-width:200px;max-width:360px;position:relative}.search-input-wrap svg{left:var(--space-md);color:var(--text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input-wrap input{width:100%;padding:var(--space-sm) var(--space-lg);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-primary);transition:all var(--transition-fast);padding-left:38px}.search-input-wrap input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.search-input-wrap input::placeholder{color:var(--text-muted)}.filter-select{padding:var(--space-sm) var(--space-lg);padding-right:var(--space-2xl);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-primary);cursor:pointer;appearance:none;transition:all var(--transition-fast);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;min-width:140px}.filter-select:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.filter-select option{background:var(--bg-secondary);color:var(--text-primary)}.filter-date-input{padding:var(--space-sm) var(--space-lg);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-primary);transition:all var(--transition-fast)}.filter-date-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.filter-btn{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-secondary);transition:all var(--transition-fast);white-space:nowrap;display:flex}.filter-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.filter-btn.active{background:var(--accent-primary-soft);border-color:var(--accent-primary);color:var(--accent-primary)}.filter-btn.primary{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--text-inverse)}.filter-btn.primary:hover{background:#0369a1}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;padding:var(--space-xl);background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-xl);width:100%;max-width:600px;max-height:85vh;box-shadow:var(--shadow-xl);flex-direction:column;animation:.25s ease-out scaleIn;display:flex}.modal-header{padding:var(--space-xl) var(--space-2xl);border-bottom:1px solid var(--surface-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-xl);color:var(--text-primary);font-weight:600}.modal-close-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.modal-close-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.modal-body{padding:var(--space-2xl);flex:1;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-2xl);border-top:1px solid var(--surface-border);display:flex}.form-group{margin-bottom:var(--space-lg)}.form-label{font-size:var(--font-sm);color:var(--text-secondary);margin-bottom:var(--space-sm);font-weight:500;display:block}.form-input{width:100%;padding:var(--space-sm) var(--space-lg);background:var(--bg-input);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-md);color:var(--text-primary);transition:all var(--transition-fast)}.form-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.form-input::placeholder{color:var(--text-muted)}textarea.form-input{resize:vertical;min-height:80px}.form-row{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=600px){.form-row{grid-template-columns:1fr}}.btn{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-xl);border-radius:var(--radius-md);font-size:var(--font-sm);transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;font-weight:500;display:inline-flex}.btn-primary{background:var(--accent-primary);color:var(--text-inverse)}.btn-primary:hover{box-shadow:var(--shadow-glow);background:#0369a1}.btn-secondary{background:var(--bg-glass-hover);color:var(--text-primary);border:1px solid var(--surface-border)}.btn-secondary:hover{border-color:var(--surface-border-hover);background:#ffffff14}.btn-danger{background:var(--accent-danger-soft);color:var(--accent-danger)}.btn-danger:hover{background:var(--accent-danger);color:#fff}.section-header{margin-bottom:var(--space-xl);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.section-title{font-size:var(--font-xl);color:var(--text-primary);font-weight:600}.section-subtitle{font-size:var(--font-sm);color:var(--text-muted);margin-top:var(--space-xs)}.tab-nav{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);margin-bottom:var(--space-xl);gap:2px;padding:3px;display:flex;overflow-x:auto}.tab-nav-item{padding:var(--space-sm) var(--space-xl);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-muted);white-space:nowrap;transition:all var(--transition-fast);font-weight:500}.tab-nav-item:hover{color:var(--text-primary)}.tab-nav-item.active{background:var(--accent-primary);color:var(--text-inverse)}.skeleton-row{gap:var(--space-lg);margin-bottom:var(--space-lg);display:flex}.skeleton-card{border-radius:var(--radius-lg);flex:1;height:100px}.skeleton-table{border-radius:var(--radius-lg);width:100%;height:300px}.skeleton-text{height:16px;margin-bottom:var(--space-sm)}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.img-preview{border-radius:var(--radius-sm);object-fit:cover;cursor:pointer;border:1px solid var(--surface-border);width:40px;height:40px;transition:transform var(--transition-fast)}.img-preview:hover{transform:scale(1.1)}.stat-grid{gap:var(--space-lg);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.chart-container{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-xl);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chart-title{font-size:var(--font-lg);color:var(--text-primary);margin-bottom:var(--space-lg);font-weight:600}.info-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-xl)}.info-card-title{font-size:var(--font-lg);color:var(--text-primary);margin-bottom:var(--space-lg);align-items:center;gap:var(--space-sm);font-weight:600;display:flex}.info-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.info-item{gap:var(--space-xs);flex-direction:column;display:flex}.info-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.info-value{font-size:var(--font-md);color:var(--text-primary);font-weight:500}@media (width<=768px){.search-filter-bar{flex-direction:column}.search-input-wrap{max-width:100%}.stat-grid{grid-template-columns:1fr 1fr}.section-header{flex-direction:column;align-items:flex-start}.modal-content{max-width:100%;margin:var(--space-md)}}@media (width<=480px){.stat-grid{grid-template-columns:1fr}}.dashboard-grid{gap:var(--space-xl);margin-bottom:var(--space-xl);grid-template-columns:2fr 1fr;display:grid}.dashboard-full{grid-column:1/-1}.dashboard-chart-row{gap:var(--space-xl);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.recent-section{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-xl);animation:.5s ease-out backwards fadeInUp}.recent-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.recent-title{font-size:var(--font-lg);color:var(--text-primary);font-weight:600}.recent-link{font-size:var(--font-sm);color:var(--accent-primary);transition:opacity var(--transition-fast);font-weight:500}.recent-link:hover{opacity:.8}.inactive-list{gap:var(--space-sm);flex-direction:column;max-height:320px;display:flex;overflow-y:auto}.inactive-item{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-md);background:var(--bg-glass);border:1px solid var(--surface-border);transition:all var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.inactive-item:hover{background:var(--bg-glass-hover);border-color:var(--surface-border-hover)}.inactive-item-info{flex-direction:column;gap:2px;display:flex}.inactive-item-name{font-size:var(--font-sm);color:var(--text-primary);font-weight:500}.inactive-item-meta{font-size:var(--font-xs);color:var(--text-muted)}.inactive-item-days{font-size:var(--font-xs);color:var(--accent-danger);background:var(--accent-danger-soft);border-radius:var(--radius-full);padding:2px 8px;font-weight:600}.dashboard-loading{gap:var(--space-xl);flex-direction:column;display:flex}@media (width<=1024px){.dashboard-grid,.dashboard-chart-row{grid-template-columns:1fr}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.customers-stats{gap:var(--space-md);margin-bottom:var(--space-lg);white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;padding-top:8px;padding-bottom:8px;display:flex;overflow-x:auto}.customers-stats::-webkit-scrollbar{display:none}.customers-stat-chip{align-items:center;gap:var(--space-md);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;box-shadow:var(--shadow-sm);flex-shrink:0;padding:10px 16px;display:flex}.customers-stat-chip:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary);transform:translateY(-1px)}.customers-stat-chip.active{background:linear-gradient(135deg, var(--accent-primary), #0284c7);color:#fff;border-color:#0000;box-shadow:0 4px 12px #0284c733}.stat-count-badge{color:var(--text-secondary);border-radius:var(--radius-sm);font-size:var(--font-xs);background:#0000000d;padding:2px 6px;font-weight:700}.customers-stat-chip.active .stat-count-badge{color:#fff;background:#fff3}.sales-breakdown-section{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-xl);animation:.4s ease-out slideDown}.sales-breakdown-title{font-size:var(--font-md);color:var(--text-primary);margin-bottom:var(--space-lg);font-weight:600}.sales-breakdown-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.sales-breakdown-card{padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border:1px solid var(--surface-border);border-radius:var(--radius-md);transition:all var(--transition-fast);justify-content:space-between;align-items:center;display:flex}.sales-breakdown-card:hover{border-color:var(--accent-primary);background:var(--bg-glass-hover)}.sales-breakdown-name{font-size:var(--font-sm);color:var(--text-primary);font-weight:500}.sales-breakdown-count{font-size:var(--font-sm);color:var(--accent-primary);font-weight:700}.customers-filter-bar{gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:nowrap;align-items:center;display:flex}.customers-filter-bar .search-input-wrap{flex:1;max-width:none}.customers-filter-bar .filter-select{min-width:160px}.customers-filter-bar .filter-btn{flex-shrink:0}@media (width<=768px){.customers-filter-bar{flex-direction:column;align-items:stretch}.customers-filter-bar .search-input-wrap{max-width:100%}}.customer-detail-header{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl);display:flex}.customer-detail-back{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--surface-border);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.customer-detail-back:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.customer-detail-name{font-size:var(--font-2xl);color:var(--text-primary);font-weight:700}.customer-detail-nickname{font-size:var(--font-md);color:var(--text-muted)}.customer-detail-tabs{margin-bottom:var(--space-xl)}.detail-grid{gap:var(--space-xl);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}@media (width<=768px){.detail-grid{grid-template-columns:1fr}}.orders-summary{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.orders-summary-chip{padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-fast);cursor:pointer;flex-direction:column;gap:2px;display:flex}.orders-summary-chip:hover{background:var(--bg-glass-hover);border-color:var(--accent-primary);transform:translateY(-2px)}.orders-summary-chip.active{background:linear-gradient(135deg, var(--accent-primary), #0284c7);color:#fff;border-color:#0000;box-shadow:0 4px 12px #0284c733}.orders-summary-value{font-size:var(--font-2xl);color:var(--text-primary);font-weight:700}.orders-summary-label{font-size:var(--font-xs);color:var(--text-muted)}.orders-summary-chip.active .orders-summary-value{color:#fff}.orders-summary-chip.active .orders-summary-label{color:#fffc}.order-detail-header{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl);display:flex}.order-detail-back{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--surface-border);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.order-detail-back:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.order-detail-title{font-size:var(--font-2xl);color:var(--text-primary);font-weight:700}.order-detail-subtitle{font-size:var(--font-md);color:var(--text-muted)}.order-nav-group{gap:var(--space-xs);margin-left:var(--space-md);display:flex}.order-nav-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--surface-border);transition:all var(--transition-fast);cursor:pointer;justify-content:center;align-items:center;display:flex}.order-nav-btn:hover:not(:disabled){background:var(--bg-glass-hover);color:var(--accent-primary);border-color:var(--accent-primary)}.order-nav-btn:disabled{opacity:.3;cursor:not-allowed}.order-timeline{flex-direction:column;padding-left:12px;display:flex;position:relative}.order-timeline:before{content:"";background:var(--surface-border);width:2px;position:absolute;top:10px;bottom:20px;left:21px}.order-timeline.horizontal{padding-left:0;padding-top:var(--space-md);padding-bottom:var(--space-lg);flex-direction:row}.order-timeline.horizontal:before{width:75%;height:2px;top:31px;left:12.5%;right:12.5%}.order-timeline.horizontal .order-timeline-item{text-align:center;align-items:center;gap:var(--space-md);flex-direction:column;flex:1;padding-bottom:0}.order-timeline.horizontal .order-timeline-dot{margin-top:0}.order-timeline.horizontal .order-timeline-content{flex-direction:column;align-items:center;padding-top:0;display:flex}.order-timeline-item{gap:var(--space-xl);padding-bottom:var(--space-xl);display:flex;position:relative}.order-timeline-item:last-child{padding-bottom:0}.order-timeline-dot{border-radius:var(--radius-full);background:var(--bg-card);border:2px solid var(--surface-border);z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;margin-top:2px;display:flex;position:relative}.order-timeline-dot.done{background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 0 0 4px #0284c71a}.order-timeline-dot.done:after{content:"✓";color:#fff;font-size:10px;font-weight:800}.order-timeline-content{flex:1;padding-top:2px}.order-timeline-content h4{font-size:var(--font-md);color:var(--text-primary);margin-bottom:2px;font-weight:600}.order-timeline-content .step-meta{align-items:center;gap:var(--space-md);font-size:var(--font-xs);color:var(--text-muted);display:flex}.order-timeline.horizontal .step-meta{flex-direction:column;gap:2px}.order-timeline-content .step-note{background:var(--bg-secondary);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-secondary);border-left:3px solid var(--accent-primary);margin-top:var(--space-sm);max-width:500px}.order-timeline.horizontal .step-note{border-left:none;border-top:3px solid var(--accent-primary);width:100%;max-width:100%}@media (width<=768px){.order-timeline.horizontal{flex-direction:column;padding-left:12px}.order-timeline.horizontal:before{width:2px;height:auto;inset:10px auto 20px 21px}.order-timeline.horizontal .order-timeline-item{text-align:left;align-items:flex-start;gap:var(--space-xl);padding-bottom:var(--space-xl);flex-direction:row}.order-timeline.horizontal .order-timeline-content{align-items:flex-start}.order-timeline.horizontal .step-meta{gap:var(--space-md);flex-direction:row}.order-timeline.horizontal .step-note{border-top:none;border-left:3px solid var(--accent-primary)}}.order-images{gap:var(--space-md);margin-top:var(--space-md);flex-wrap:wrap;display:flex}.order-image-thumb{border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--surface-border);cursor:pointer;width:80px;height:80px;transition:all var(--transition-fast)}.order-image-thumb:hover{border-color:var(--accent-primary);transform:scale(1.05)}.sales-cards-grid{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.sales-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-fast);flex-direction:column;justify-content:center;display:flex}.sales-card:hover{border-color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 4px 20px #0000001a}.sales-card.total-sales{text-align:center;background:linear-gradient(135deg,#0284c71a,#10b9811a);border-color:#0284c733}.sales-card-value{font-size:var(--font-2xl);color:var(--accent-primary);margin-bottom:4px;font-weight:700}.sales-card-label{font-size:var(--font-xs);color:var(--text-muted)}.sales-card-title{font-size:var(--font-sm);color:var(--text-primary);margin-bottom:var(--space-md);border-bottom:1px solid var(--surface-border);padding-bottom:4px;font-weight:600}.sales-card-list{flex-direction:column;gap:8px;display:flex}.sales-card-item{font-size:var(--font-xs);justify-content:space-between;display:flex}.item-label{color:var(--text-secondary)}.item-value{color:var(--text-primary);font-weight:600}.top-products{gap:var(--space-lg);margin-bottom:var(--space-2xl);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.top-product-card{align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);display:flex}.top-product-card:hover{border-color:var(--surface-border-hover);transform:translateY(-1px)}.top-product-rank{border-radius:var(--radius-full);background:var(--accent-primary-soft);width:32px;height:32px;color:var(--accent-primary);font-size:var(--font-sm);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.top-product-rank.gold{background:var(--accent-warning-soft);color:var(--accent-warning)}.top-product-info{flex:1;min-width:0}.top-product-name{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.top-product-qty{font-size:var(--font-xs);color:var(--text-muted)}.maint-stat-grid{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.maint-stat-chip{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;cursor:pointer;transition:all var(--transition-fast)}.maint-stat-chip:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.maint-stat-chip.active{background:linear-gradient(135deg, var(--accent-primary), #0284c7);border-color:#0000;box-shadow:0 4px 12px #0284c740}.maint-stat-chip.active .maint-chip-value,.maint-stat-chip.active .maint-chip-label{color:#fff}.maint-stat-chip.pending .maint-chip-value{color:var(--accent-warning)}.maint-stat-chip.done .maint-chip-value{color:#10b981}.maint-stat-chip.repair .maint-chip-value{color:var(--accent-danger)}.maint-chip-value{font-size:var(--font-2xl);color:var(--text-primary);font-weight:700}.maint-chip-label{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px}.machine-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.machine-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.machine-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.machine-card.selected{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-soft)}.machine-card-img{object-fit:cover;background:var(--bg-secondary);width:100%;height:120px}.machine-card-img-placeholder{background:var(--bg-secondary);width:100%;height:120px;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.machine-card-body{padding:var(--space-md) var(--space-lg)}.machine-card-name{font-weight:600;font-size:var(--font-md);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:4px;overflow:hidden}.machine-card-id{font-size:var(--font-xs);color:var(--text-muted);margin-bottom:var(--space-sm)}.machine-card-footer{padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--surface-border);background:var(--bg-secondary);justify-content:space-between;align-items:center;display:flex}.maint-detail-header{align-items:center;gap:var(--space-lg);margin-bottom:var(--space-xl);flex-wrap:wrap;display:flex}.maint-back-btn{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--surface-border);width:40px;height:40px;color:var(--text-secondary);transition:all var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.maint-back-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary)}.maint-images{gap:var(--space-sm);margin-top:var(--space-sm);flex-wrap:wrap;display:flex}.maint-img-thumb{border-radius:var(--radius-md);object-fit:cover;border:1px solid var(--surface-border);cursor:pointer;width:72px;height:72px;transition:all var(--transition-fast)}.maint-img-thumb:hover{border-color:var(--accent-primary);transform:scale(1.06)}.badge-pending{background:var(--accent-warning-soft);color:var(--accent-warning)}.badge-done{color:#059669;background:#10b9811f}.badge-repair{background:var(--accent-danger-soft);color:var(--accent-danger)}.badge-default{background:var(--bg-glass-hover);color:var(--text-secondary)}.badge-active{color:#10b981;background:#ecfdf5;border:1px solid #10b98133}.badge-stock{color:#8b5cf6;background:#f5f3ff;border:1px solid #8b5cf633}.maint-badge{border-radius:var(--radius-full);font-size:var(--font-xs);white-space:nowrap;box-shadow:var(--shadow-sm);padding:4px 12px;font-weight:600;display:inline-block}.maint-spin{animation:2s linear infinite spin}.req-container{gap:var(--space-lg);flex-direction:column;display:flex}.req-stat-grid{gap:var(--space-md);margin-bottom:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.req-stat-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);align-items:center;gap:var(--space-md);transition:all var(--transition-fast);display:flex}.req-stat-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.req-stat-icon-wrap{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;display:flex}.req-stat-icon-wrap.pending{color:var(--accent-warning);background:#f59e0b1a}.req-stat-icon-wrap.approved{color:var(--accent-primary);background:#3b82f61a}.req-stat-icon-wrap.prepared{color:#8b5cf6;background:#8b5cf61a}.req-stat-icon-wrap.used{color:#10b981;background:#10b9811a}.req-stat-info{flex-direction:column;display:flex}.req-stat-value{font-size:var(--font-xl);color:var(--text-primary);font-weight:700;line-height:1.2}.req-stat-label{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px;font-weight:500}.req-tabs{border-bottom:2px solid var(--border-color);gap:var(--space-lg);margin-bottom:var(--space-sm);display:flex}.req-tab-item{padding:var(--space-sm) var(--space-sm) var(--space-md);font-size:var(--font-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;font-weight:600;position:relative}.req-tab-item:hover{color:var(--text-primary)}.req-tab-item.active{color:var(--accent-primary)}.req-tab-item.active:after{content:"";background:var(--accent-primary);border-radius:var(--radius-full);height:3px;position:absolute;bottom:-2px;left:0;right:0}.req-badge{border-radius:var(--radius-full);white-space:nowrap;justify-content:center;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.req-badge.pending{color:var(--accent-warning);background:#f59e0b14;border:1px solid #f59e0b33}.req-badge.approved{color:var(--accent-primary);background:#3b82f614;border:1px solid #3b82f633}.req-badge.prepared{color:#8b5cf6;background:#8b5cf614;border:1px solid #8b5cf633}.req-badge.used{color:#10b981;background:#10b98114;border:1px solid #10b98133}.req-badge.received{color:#0891b2;background:#06b6d414;border:1px solid #06b6d433}.req-badge.rejected{color:var(--accent-danger);background:#ef444414;border:1px solid #ef444433}.req-badge.cancelled{background:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border-color)}.req-badge.personal{color:#7c3aed;background:#f5f3ff;border:1px solid #ddd6fe}.req-badge.customer{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0}.req-timeline{margin:var(--space-xl) 0;padding:0 var(--space-lg);justify-content:space-between;align-items:center;display:flex;position:relative}.req-timeline:before{content:"";top:15px;left:var(--space-xl);right:var(--space-xl);background:var(--border-color);z-index:1;height:3px;position:absolute}.req-timeline-step{z-index:2;flex-direction:column;flex:1;align-items:center;display:flex;position:relative}.req-timeline-node{background:var(--bg-card);border:3px solid var(--border-color);width:32px;height:32px;color:var(--text-muted);font-weight:700;font-size:var(--font-sm);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex}.req-timeline-step.active .req-timeline-node{border-color:var(--accent-primary);color:var(--accent-primary);background:#e0f2fe}.req-timeline-step.completed .req-timeline-node{color:#fff;background:#10b981;border-color:#10b981}.req-timeline-label{color:var(--text-muted);text-align:center;margin-top:6px;font-size:11px;font-weight:600}.req-timeline-step.active .req-timeline-label{color:var(--accent-primary);font-weight:700}.req-timeline-step.completed .req-timeline-label{color:#10b981}.req-modal-grid{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}@media (width<=768px){.req-modal-grid{grid-template-columns:1fr}}.req-modal-section{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);border:1px solid var(--border-color)}.req-modal-sec-title{font-size:var(--font-sm);color:var(--text-primary);margin-bottom:var(--space-sm);border-bottom:1px solid var(--border-color);padding-bottom:var(--space-xs);align-items:center;gap:6px;font-weight:700;display:flex}.req-info-row{margin-bottom:var(--space-xs);font-size:var(--font-sm);display:flex}.req-info-label{width:130px;color:var(--text-muted);flex-shrink:0;font-weight:600}.req-info-val{color:var(--text-primary);word-break:break-word;font-weight:500}.req-actions-bar{gap:var(--space-md);margin-top:var(--space-lg);border-top:1px solid var(--border-color);padding-top:var(--space-md);justify-content:flex-end;display:flex}.file-upload-container{gap:var(--space-xs);flex-direction:column;display:flex;position:relative}.file-upload-trigger{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);text-align:center;cursor:pointer;background:var(--bg-card);transition:all var(--transition-fast)}.file-upload-trigger:hover{border-color:var(--accent-primary);background:var(--bg-glass-hover)}.balance-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.balance-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);overflow:hidden}.balance-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.balance-header{background:var(--bg-secondary);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color);align-items:center;gap:var(--space-md);display:flex}.balance-avatar{background:var(--accent-primary-soft);width:40px;height:40px;color:var(--accent-primary);font-weight:700;font-size:var(--font-sm);border-radius:50%;justify-content:center;align-items:center;display:flex}.balance-user-name{color:var(--text-primary);font-weight:700}.balance-user-dept{color:var(--text-muted);font-size:11px;font-weight:500}.balance-body{padding:var(--space-md) var(--space-lg)}.balance-item{border-bottom:1px solid #00000008;justify-content:space-between;align-items:center;padding:8px 0;display:flex}.balance-item:last-child{border-bottom:none}.balance-prod-name{font-size:var(--font-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:180px;font-weight:600;overflow:hidden}.balance-qty{font-size:var(--font-md);color:var(--accent-primary);font-weight:700}.balance-qty.zero{color:var(--text-muted)}.clickable-row{transition:background-color var(--transition-fast) ease-in-out;cursor:pointer!important}.clickable-row:hover{background-color:#3b82f60d!important}.req-detail-modal-overlay{z-index:1000;padding:var(--space-lg);justify-content:center;align-items:center;display:flex;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;background:#0f172a99!important}.req-detail-modal-content{animation:.3s cubic-bezier(.34,1.56,.64,1) modalScaleUp;width:95vw!important;max-width:1050px!important;height:90vh!important;max-height:90vh!important;padding:var(--space-lg) var(--space-xl)!important;border-radius:var(--radius-xl)!important;flex-direction:column!important;display:flex!important;overflow:hidden!important;box-shadow:0 25px 50px -12px #00000040!important}.req-vertical-timeline-container{gap:var(--space-md);padding:var(--space-md) var(--space-sm);flex-direction:column;display:flex;position:relative}.req-vertical-step{gap:var(--space-md);display:flex;position:relative}.req-vertical-node-container{flex-direction:column;flex-shrink:0;align-items:center;width:40px;display:flex;position:relative}.req-vertical-node{z-index:2;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-weight:700;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.req-vertical-line{z-index:1;border-radius:2px;width:3px;transition:background-color .3s;position:absolute;top:40px;bottom:-20px;left:50%;transform:translate(-50%)}.req-vertical-step:last-child .req-vertical-line{display:none}.req-vertical-content{flex:1;transition:opacity .3s}.req-step-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:all .3s}.req-step-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}@keyframes timelinePulse{0%{box-shadow:0 0 #3b82f666}70%{box-shadow:0 0 0 10px #3b82f600}to{box-shadow:0 0 #3b82f600}}.req-vertical-step.active .req-vertical-node{animation:2s infinite timelinePulse}@keyframes modalScaleUp{0%{opacity:0;transform:scale(.96)translateY(12px)}to{opacity:1;transform:scale(1)translateY(0)}}.req-modal-scrollable-body{padding-right:var(--space-sm);margin-bottom:var(--space-md);flex:1;overflow-y:auto}.req-modal-scrollable-body::-webkit-scrollbar{width:6px}.req-modal-scrollable-body::-webkit-scrollbar-track{background:0 0}.req-modal-scrollable-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.req-modal-scrollable-body::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.req-modal-grid-modern{gap:var(--space-lg);grid-template-columns:1.1fr 1fr;display:grid}@media (width<=992px){.req-modal-grid-modern{gap:var(--space-md);grid-template-columns:1fr}.req-detail-modal-content{height:95vh!important;max-height:95vh!important}}@media (width<=768px){.req-detail-modal-overlay{padding:0!important}.req-detail-modal-content{width:100vw!important;max-width:100vw!important;height:100vh!important;max-height:100vh!important;padding:var(--space-md)!important;border-radius:0!important}}.req-card-grid{margin-top:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}@media (width<=480px){.req-card-grid{grid-template-columns:1fr}}.req-data-card{background:var(--bg-card);border:1px solid var(--surface-border);cursor:pointer;border-radius:12px;flex-direction:column;gap:12px;padding:14px 16px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #00000004}.req-data-card:before{content:"";width:4px;height:100%;transition:width .2s cubic-bezier(.4,0,.2,1);position:absolute;top:0;left:0}.req-data-card.status-pending:before{background:#f59e0b}.req-data-card.status-approved:before{background:#3b82f6}.req-data-card.status-prepared:before{background:#8b5cf6}.req-data-card.status-received:before{background:#06b6d4}.req-data-card.status-used:before{background:#10b981}.req-data-card.status-rejected:before{background:#ef4444}.req-data-card.status-cancelled:before{background:var(--text-muted)}.req-data-card:hover{border-color:#0369a126;transform:translateY(-5px);box-shadow:0 12px 30px #0369a114}.req-data-card:hover:before{width:6px}.req-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:flex-start;padding-bottom:8px;display:flex}.req-card-meta{flex-direction:column;gap:4px;display:flex}.req-card-seq{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:800}.req-card-date{color:var(--text-primary);align-items:center;font-size:12px;font-weight:600;display:flex}.req-card-badges{flex-direction:column;align-items:flex-end;gap:6px;display:flex}.req-card-body{flex-direction:column;flex:1;gap:10px;display:flex}.req-card-products{border:1px solid var(--border-color);background:#0f172a03;border-radius:8px;flex-direction:column;gap:6px;padding:8px;display:flex}.req-card-product-item{background:var(--bg-card);border:1px solid #00000005;border-radius:6px;justify-content:space-between;align-items:center;gap:10px;padding:6px 8px;font-size:11px;transition:all .2s;display:flex}.req-card-product-item:hover{background:#0284c705;border-color:#0284c71a}.req-card-product-name{color:var(--text-primary);align-items:center;font-weight:600;display:flex}.req-card-product-qty{color:#0369a1;white-space:nowrap;background:#e0f2fe;border:1px solid #bae6fd;border-radius:12px;padding:2px 6px;font-size:10px;font-weight:800}.req-card-purpose{background:#0284c705;border:1px solid #0284c70f;border-left:3px solid #0284c7;border-radius:8px;flex-direction:column;gap:6px;padding:8px 10px;font-size:10.5px;line-height:1.4;display:flex}.req-purpose-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:3px;margin-bottom:1px;font-size:8.5px;font-weight:800;display:flex}.req-purpose-item{color:var(--text-primary);background:var(--bg-card);border:1px solid #00000005;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:600}.req-card-use-note{background:#10b9810a;border:1px solid #10b9810f;border-left:3px solid #10b981;border-radius:6px;flex-direction:column;gap:2px;padding:6px 8px;display:flex}.req-card-footer{border-top:1px solid var(--border-color);justify-content:space-between;align-items:center;padding-top:10px;display:flex}.req-card-requester{color:var(--text-primary);border-radius:var(--radius-full);background:#f0f9ff;border:1px solid #e0f2fe;align-items:center;padding:4px 10px;font-size:12px;font-weight:700;display:flex}:root{--bg-primary:#f0f9ff;--bg-secondary:#e0f2fe;--bg-card:#ffffffd9;--bg-card-hover:#fff;--bg-glass:#ffffff80;--bg-glass-hover:#fffc;--bg-input:#ffffffe6;--surface-border:#0ea5e926;--surface-border-hover:#0ea5e94d;--accent-primary:#0284c7;--accent-primary-soft:#0284c726;--accent-primary-glow:#0284c74d;--accent-secondary:#3b82f6;--accent-secondary-soft:#3b82f626;--accent-tertiary:#8b5cf6;--accent-tertiary-soft:#8b5cf626;--accent-warning:#f59e0b;--accent-warning-soft:#f59e0b26;--accent-danger:#ef4444;--accent-danger-soft:#ef444426;--accent-info:#06b6d4;--accent-info-soft:#06b6d426;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--text-inverse:#f8fafc;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:24px;--space-3xl:32px;--space-4xl:40px;--space-5xl:48px;--font-family:"Noto Sans Thai", "Noto Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-xs:.75rem;--font-sm:.8125rem;--font-md:.875rem;--font-lg:1rem;--font-xl:1.125rem;--font-2xl:1.25rem;--font-3xl:1.5rem;--font-4xl:2rem;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px #0000004d;--shadow-lg:0 10px 25px #0006;--shadow-xl:0 20px 50px #00000080;--shadow-glow:0 0 20px var(--accent-primary-glow);--transition-fast:.15s ease;--transition-normal:.25s ease;--transition-slow:.35s ease;--sidebar-width:260px;--sidebar-collapsed:0px;--topbar-height:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow:hidden}#root{min-height:100vh}a{color:var(--accent-primary);text-decoration:none}button{font-family:var(--font-family);cursor:pointer;color:var(--text-primary);background:0 0;border:none;outline:none}input,select,textarea{font-family:var(--font-family);color:var(--text-primary);background:0 0;border:none;outline:none}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0ea5e933;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0ea5e966}svg.lucide{stroke-width:1.5px;fill:none!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.glass-card{background:var(--bg-card);border:1px solid var(--surface-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px)}.glass-card:hover{border-color:var(--surface-border-hover)}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,#e0f2fe66 25%,#e0f2fecc 50%,#e0f2fe66 75%) 0 0/200% 100%;animation:1.5s infinite shimmer}.fade-in{animation:fadeIn var(--transition-normal)}.fade-in-up{animation:.4s ease-out fadeInUp}html{font-size:16px}@media (width<=1400px){html{font-size:15px}}@media (width<=1024px){html{font-size:14px}}@media (width<=768px){html{font-size:13.5px}}@media (width<=480px){html{font-size:13px}}@media (width<=768px){.data-table-wrap{box-shadow:none!important;background:0 0!important;border:none!important;padding:0!important;overflow-x:visible!important}.data-table-wrap table.data-table{background:0 0!important;border:none!important;width:100%!important;display:block!important}.data-table-wrap table.data-table thead{display:none!important}.data-table-wrap table.data-table tbody{gap:var(--space-md)!important;background:0 0!important;flex-direction:column!important;width:100%!important;display:flex!important}.data-table-wrap table.data-table tr{background:var(--bg-card)!important;border:1px solid var(--surface-border)!important;border-radius:var(--radius-lg)!important;padding:var(--space-md)!important;box-shadow:var(--shadow-sm)!important;transition:transform var(--transition-fast), box-shadow var(--transition-fast)!important;flex-direction:column!important;margin-bottom:0!important;display:flex!important}.data-table-wrap table.data-table tr:hover{background:var(--bg-card-hover)!important;border-color:var(--surface-border-hover)!important;box-shadow:var(--shadow-md)!important;transform:translateY(-2px)!important}.data-table-wrap table.data-table td{padding:var(--space-sm) 0!important;text-align:right!important;font-size:var(--font-sm)!important;background:0 0!important;border-bottom:1px dashed #0ea5e91a!important;justify-content:space-between!important;align-items:center!important;width:100%!important;min-height:36px!important;display:flex!important}.data-table-wrap table.data-table td:last-child{border-bottom:none!important}.data-table-wrap table.data-table td:before{content:attr(data-label)!important;color:var(--text-muted)!important;text-align:left!important;padding-right:var(--space-md)!important;font-weight:600!important}}
