:root{--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--brand-50: #fdf4e7;--brand-100: #fbe4c3;--brand-200: #f5c66e;--brand-400: #e6a22e;--brand-500: #d4891a;--brand-600: #b06e10;--brand-700: #8a5409;--color-success: #059669;--color-success-light: #d1fae5;--color-error: #dc2626;--color-error-light: #fee2e2;--color-warning: #d97706;--color-warning-light: #fef3c7;--color-info: #2563eb;--color-info-light: #dbeafe;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.04);--shadow-xl: 0 20px 25px -5px rgba(0,0,0,.08), 0 8px 10px -6px rgba(0,0,0,.04);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.45, 0, .55, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s}*,*:before,*:after{box-sizing:border-box}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--gray-900);background:var(--gray-50);margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.snackbar-container{position:fixed;top:var(--space-4);right:var(--space-4);z-index:9999;display:flex;flex-direction:column;gap:var(--space-3);pointer-events:none}.snackbar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:500;line-height:1.4;max-width:420px;pointer-events:auto;box-shadow:var(--shadow-lg);animation:snackbar-in var(--duration-slow) var(--ease-out) forwards}.snackbar.exiting{animation:snackbar-out var(--duration-normal) var(--ease-in-out) forwards}.snackbar-icon{flex-shrink:0;width:20px;height:20px}.snackbar-message{flex:1}.snackbar-close{flex-shrink:0;background:none;border:none;padding:var(--space-1);cursor:pointer;opacity:.5;transition:opacity var(--duration-fast);color:inherit;line-height:1;font-size:var(--text-lg)}.snackbar-close:hover{opacity:1}.snackbar--success{background:var(--color-success-light);color:#065f46;border:1px solid #a7f3d0}.snackbar--error{background:var(--color-error-light);color:#991b1b;border:1px solid #fecaca}.snackbar--warning{background:var(--color-warning-light);color:#92400e;border:1px solid #fde68a}.snackbar--info{background:var(--color-info-light);color:#1e40af;border:1px solid #bfdbfe}@keyframes snackbar-in{0%{opacity:0;transform:translate(100%) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes snackbar-out{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.95)}}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--gray-50);padding:var(--space-4)}.login-card{width:100%;max-width:400px;background:#fff;border-radius:var(--radius-xl);padding:var(--space-10);box-shadow:var(--shadow-xl);animation:login-appear var(--duration-slow) var(--ease-out) forwards}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{width:80px;height:80px;margin:0 auto var(--space-4);display:flex;align-items:center;justify-content:center;animation:logo-pop var(--duration-slow) var(--ease-out) .2s both}.login-logo img{width:100%;height:100%;object-fit:contain}.login-title{font-size:var(--text-2xl);font-weight:700;color:var(--gray-900);margin:0 0 var(--space-1)}.login-subtitle{font-size:var(--text-sm);color:var(--gray-500);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--gray-700)}.form-input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-base);color:var(--gray-900);background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-fast),box-shadow var(--duration-fast),background-color var(--duration-fast)}.form-input::placeholder{color:var(--gray-400)}.form-input:hover{border-color:var(--gray-300)}.form-input:focus{border-color:var(--gray-900);background:#fff;box-shadow:0 0 0 3px #11182714}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--text-base);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast),transform var(--duration-fast),box-shadow var(--duration-fast);outline:none}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn--primary{background:var(--gray-900);color:#fff}.btn--primary:hover:not(:disabled){background:var(--gray-800);box-shadow:var(--shadow-md)}.btn--primary:focus-visible{box-shadow:0 0 0 3px #11182733}.login-footer{text-align:center;margin-top:var(--space-6);font-size:var(--text-xs);color:var(--gray-400)}.login-footer kbd{display:inline-block;padding:1px 6px;font-family:var(--font-sans);font-size:var(--text-xs);background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--radius-sm);color:var(--gray-600)}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes login-appear{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes logo-pop{0%{opacity:0;transform:scale(.5) rotate(-8deg)}to{opacity:1;transform:scale(1) rotate(0)}}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);background:#fff;border-bottom:1px solid var(--gray-200);position:sticky;top:0;z-index:100}.app-header-left{display:flex;align-items:center;gap:var(--space-3)}.app-header-logo{width:32px;height:32px;display:flex;align-items:center;justify-content:center}.app-header-logo img{width:100%;height:100%;object-fit:contain}.app-header-title{font-size:var(--text-sm);font-weight:600;color:var(--gray-900)}.app-header-role{font-size:var(--text-xs);color:var(--gray-500);background:var(--gray-100);padding:2px 8px;border-radius:var(--radius-full)}.app-header-right{display:flex;align-items:center;gap:var(--space-3)}.app-user-name{font-size:var(--text-sm);font-weight:500;color:var(--gray-700)}.btn--ghost{background:transparent;color:var(--gray-600);padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn--ghost:hover:not(:disabled){background:var(--gray-100);color:var(--gray-900)}.app-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--space-6);animation:content-in var(--duration-normal) var(--ease-out)}@keyframes content-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:var(--space-4);transition:box-shadow var(--duration-fast)}.card:hover{box-shadow:var(--shadow-md)}
