.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:#64748b}.spinner{width:2rem;height:2rem;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}.card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #0000001a;margin-bottom:.75rem}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.kpi-card{background:#fff;border-radius:12px;padding:1rem;box-shadow:0 1px 3px #0000001a}.kpi-icon{font-size:1.25rem}.kpi-value{font-size:1.5rem;font-weight:700;margin-top:.5rem;display:block}.kpi-label{font-size:.8rem;color:#64748b;display:block}.btn{padding:.5rem 1rem;border-radius:8px;border:none;cursor:pointer;font-weight:500;transition:opacity .2s}.btn:active{opacity:.8}.btn-primary{background:#3b82f6;color:#fff}.btn-secondary{background:#f3f4f6;color:#374151}.btn-success{background:#22c55e;color:#fff}.list-item{display:flex;align-items:center;padding:.75rem;border-bottom:1px solid #f1f5f9;cursor:pointer}.list-item:active{background:#f8fafc}.filter-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;font-size:.85rem;cursor:pointer}.filter-toggle.active{background:#ede9fe;border-color:#c4b5fd;color:#6d28d9}.progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.progress-fill.green{background:linear-gradient(90deg,#22c55e,#16a34a)}.progress-fill.blue{background:linear-gradient(90deg,#3b82f6,#2563eb)}.progress-fill.orange{background:linear-gradient(90deg,#f59e0b,#d97706)}.progress-fill.red{background:linear-gradient(90deg,#ef4444,#dc2626)}.badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:999px;font-size:.75rem;font-weight:500}.badge-success{background:#dcfce7;color:#16a34a}.badge-warning{background:#fef3c7;color:#d97706}.badge-danger{background:#fee2e2;color:#dc2626}.badge-info{background:#dbeafe;color:#2563eb}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;font-size:.85rem}.table th,.table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid #f1f5f9}.table th{background:#f8fafc;font-weight:600;color:#475569}@media (max-width: 640px){.kpi-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.kpi-card{padding:.75rem}.kpi-value{font-size:1.25rem}.card{padding:.75rem;border-radius:8px}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:1rem;margin-bottom:.5rem}.skeleton-title{height:1.5rem;width:60%;margin-bottom:.75rem}.skeleton-card{height:80px;margin-bottom:.75rem}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--primary-color: #667eea;--primary-dark: #5a67d8;--primary-light: #a3b0ff;--success-color: #22c55e;--success-light: #dcfce7;--warning-color: #f59e0b;--warning-light: #fef3c7;--danger-color: #ef4444;--danger-light: #fee2e2;--info-color: #3b82f6;--info-light: #dbeafe;--text-primary: #1f2937;--text-secondary: #6b7280;--text-muted: #9ca3af;--background: #f3f4f6;--surface: #ffffff;--border-color: #e5e7eb;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15)}.page-container{min-height:100vh;background:var(--background)}.page-header{display:flex;align-items:center;padding:var(--spacing-md);background:var(--primary-gradient);color:#fff;position:sticky;top:0;z-index:100}.page-header-back{background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;margin-right:var(--spacing-md);font-size:18px}.page-header-title{flex:1}.page-header-title h1{margin:0;font-size:1.25rem;font-weight:600}.page-header-title p{margin:2px 0 0;font-size:.85rem;opacity:.9}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.card-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.content{padding:var(--spacing-md)}.tabs{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--surface);overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg);background:var(--background);color:var(--text-secondary);border:none;cursor:pointer;font-size:.9rem;white-space:nowrap;transition:all .2s}.tab.active,.tab-active{background:var(--primary-gradient);color:#fff}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-weight:500;cursor:pointer;border:none;transition:all .2s}.btn-primary{background:var(--primary-gradient);color:#fff}.btn-primary:hover{opacity:.9}.btn-success{background:var(--success-color);color:#fff}.btn-danger{background:var(--danger-color);color:#fff}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.85rem}.btn-lg{padding:var(--spacing-md) var(--spacing-lg);font-size:1rem}.btn-block{width:100%}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:.85rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs);font-weight:500}.form-input,.form-select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder{color:var(--text-muted)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:var(--surface);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.1rem;font-weight:600;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:0;line-height:1}.modal-body{padding:var(--spacing-md)}.modal-footer{display:flex;gap:var(--spacing-sm);justify-content:flex-end;padding:var(--spacing-md);border-top:1px solid var(--border-color)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);color:var(--text-muted)}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:100px;font-size:.75rem;font-weight:500}.badge-success{background:var(--success-light);color:var(--success-color)}.badge-warning{background:var(--warning-light);color:var(--warning-color)}.badge-danger{background:var(--danger-light);color:var(--danger-color)}.badge-info{background:var(--info-light);color:var(--info-color)}.pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-md)}.pagination-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{color:var(--text-secondary);font-size:.9rem}.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.kpi-card{background:var(--surface);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);border-left:4px solid var(--primary-color)}.kpi-card-success{border-left-color:var(--success-color)}.kpi-card-warning{border-left-color:var(--warning-color)}.kpi-card-danger{border-left-color:var(--danger-color)}.kpi-card-info{border-left-color:var(--info-color)}.kpi-label{font-size:.8rem;color:var(--text-muted);margin-bottom:var(--spacing-xs)}.kpi-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.text-center{text-align:center}.text-right{text-align:right}.text-success{color:var(--success-color)}.text-warning{color:var(--warning-color)}.text-danger{color:var(--danger-color)}.text-muted{color:var(--text-muted)}.mt-0{margin-top:0}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.p-0{padding:0}.p-1{padding:var(--spacing-sm)}.p-2{padding:var(--spacing-md)}.p-3{padding:var(--spacing-lg)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-sm)}.gap-2{gap:var(--spacing-md)}@media (max-width: 480px){.kpi-grid{grid-template-columns:1fr}.modal-content{max-height:100vh;border-radius:0}}
