@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--secondary-50: #f8fafc;--secondary-100: #f1f5f9;--secondary-200: #e2e8f0;--secondary-300: #cbd5e1;--secondary-400: #94a3b8;--secondary-500: #64748b;--secondary-600: #475569;--secondary-700: #334155;--secondary-800: #1e293b;--secondary-900: #0f172a;--success-50: #f0fdf4;--success-500: #22c55e;--success-600: #16a34a;--success-700: #15803d;--warning-50: #fffbeb;--warning-500: #f59e0b;--warning-600: #d97706;--error-50: #fef2f2;--error-500: #ef4444;--error-600: #dc2626;--accent-500: #0ea5e9;--accent-600: #0284c7;--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--sidebar-width: 240px;--header-height: 56px;--border-radius: 6px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;line-height:1.5}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-size:1rem}#app{min-height:100vh}a{color:var(--primary-600);text-decoration:none}a:hover{color:var(--primary-700)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:2rem}h2{font-size:1.625rem}h3{font-size:1.375rem}h4{font-size:1.25rem}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--border-radius);font-size:.933rem;font-weight:500;border:1px solid transparent;cursor:pointer;transition:all .15s ease;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary-600);color:#fff;border-color:var(--primary-600)}.btn-primary:hover:not(:disabled){background:var(--primary-700);border-color:var(--primary-700)}.btn-secondary{background:var(--surface);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--secondary-100)}.btn-success{background:var(--success-600);color:#fff;border-color:var(--success-600)}.btn-success:hover:not(:disabled){background:var(--success-700)}.btn-danger{background:var(--error-600);color:#fff;border-color:var(--error-600)}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-warning{background:var(--warning-600);color:#fff;border-color:var(--warning-600)}.btn-sm{padding:5px 10px;font-size:.8125rem}.btn-lg{padding:10px 20px;font-size:1rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--border-radius);box-shadow:var(--shadow-sm)}.card-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.card-body{padding:16px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px}.form-label.required:after{content:" *";color:var(--error-500)}.form-control{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--border-radius);font-size:.933rem;color:var(--text-primary);background:var(--surface);transition:border-color .15s,box-shadow .15s;outline:none}.form-control:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.form-control:disabled{background:var(--secondary-100);color:var(--text-muted);cursor:not-allowed}.form-control.error{border-color:var(--error-500)}select.form-control{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2364748b' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:20px;padding-right:36px}.form-error{font-size:.75rem;color:var(--error-500);margin-top:4px}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:4px}.table-container{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}.card-body>.table-container{margin:-16px;padding:16px}table{width:100%;border-collapse:collapse;font-size:.933rem}thead th{padding:8px 10px;text-align:left;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--secondary-50);border-bottom:1px solid var(--border);white-space:nowrap}tbody td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle;font-size:.933rem}tbody tr:hover{background:var(--secondary-50)}tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:99px;font-size:.75rem;font-weight:500}.badge-success{background:var(--success-50);color:var(--success-700)}.badge-warning{background:var(--warning-50);color:var(--warning-600)}.badge-error{background:var(--error-50);color:var(--error-600)}.badge-secondary{background:var(--secondary-100);color:var(--secondary-700)}.badge-primary{background:var(--primary-50);color:var(--primary-700)}.badge-accent{background:#e0f2fe;color:var(--accent-600)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}.page-title{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.page-subtitle{font-size:.8125rem;color:var(--text-secondary);margin-top:2px}.alert{padding:12px 16px;border-radius:var(--border-radius);font-size:.875rem;margin-bottom:16px;display:flex;gap:8px;align-items:flex-start}.alert-error{background:var(--error-50);color:var(--error-600);border:1px solid #fecaca}.alert-success{background:var(--success-50);color:var(--success-700);border:1px solid #bbf7d0}.alert-warning{background:var(--warning-50);color:var(--warning-600);border:1px solid #fde68a}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.text-right{text-align:right}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-medium{font-weight:500}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.p-4{padding:16px}.p-6{padding:24px}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--primary-600);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--text-muted);gap:10px}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state-icon{font-size:2.5rem;margin-bottom:12px;opacity:.5}.empty-state h3{font-size:1rem;color:var(--text-secondary);margin-bottom:4px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border-radius:12px;box-shadow:var(--shadow-lg);width:100%;max-height:90vh;overflow-y:auto;animation:modalIn .2s ease}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1000px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:8px}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--border-radius);padding:20px;display:flex;flex-direction:column;gap:8px}.stat-card-label{font-size:.8125rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.stat-card-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.stat-card-sub{font-size:.8125rem;color:var(--text-muted)}.filters-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:16px}.filter-group{display:flex;flex-direction:column;gap:4px;min-width:150px}.filter-label{font-size:.75rem;font-weight:500;color:var(--text-secondary)}.filter-group--checkbox{min-width:auto;align-self:center}.filter-label--inline{display:inline-flex;align-items:center;gap:8px;cursor:pointer;margin:0;font-size:.8125rem}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--primary-100)}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}@media (max-width: 1400px){html{font-size:15px}.card-body{padding:14px}.modal-body{padding:20px}thead th{padding:7px 8px;font-size:.8rem}tbody td{padding:7px 8px;font-size:.9rem}.stat-card{padding:16px}.stat-card-value{font-size:1.5rem}}@media (max-width: 1024px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.filters-row{flex-direction:column}html{font-size:14px}}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-container::-webkit-scrollbar{height:8px}.table-container::-webkit-scrollbar-track{background:var(--secondary-100);border-radius:4px}.table-container::-webkit-scrollbar-thumb{background:var(--secondary-400);border-radius:4px}.table-container::-webkit-scrollbar-thumb:hover{background:var(--secondary-500)}
