:root{--primary: #10B981;--primary-dark: #059669;--primary-darker: #047857;--primary-darkest: #065F46;--sidebar-bg: #064E3B;--sidebar-hover: #065F46;--primary-light: #D1FAE5;--primary-lighter: #ECFDF5;--text-primary: #111827;--text-secondary: #6B7280;--text-muted: #9CA3AF;--bg-page: #F0FDF4;--bg-card: #FFFFFF;--border: #E5E7EB;--border-light: #F3F4F6;--danger: #EF4444;--danger-light: #FEE2E2;--warning: #F59E0B;--warning-light: #FEF3C7;--success: #10B981;--success-light: #D1FAE5;--info: #3B82F6;--info-light: #DBEAFE;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);--radius: 10px;--radius-sm: 6px;--radius-lg: 16px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg-page)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1fae5;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#10b981}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);font-size:13.5px;font-weight:500;border:none;cursor:pointer;transition:all .15s;text-decoration:none;line-height:1}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-primary:active{background:var(--primary-darker)}.btn-secondary{background:var(--primary-lighter);color:var(--primary-darker);border:1px solid var(--primary-light)}.btn-secondary:hover{background:var(--primary-light)}.btn-danger{background:var(--danger-light);color:var(--danger);border:1px solid #FECACA}.btn-danger:hover{background:var(--danger);color:#fff}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--border-light);color:var(--text-primary)}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-icon{padding:7px;border-radius:var(--radius-sm);background:transparent;border:none;cursor:pointer;color:var(--text-secondary);transition:all .15s;display:inline-flex;align-items:center;justify-content:center}.btn-icon:hover{background:var(--border-light);color:var(--text-primary)}.btn-icon-danger:hover{background:var(--danger-light)!important;color:var(--danger)!important}.btn-icon-primary:hover{background:var(--primary-lighter)!important;color:var(--primary-dark)!important}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}.card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border-light)}.card-header h2,.card-header h3{margin:0;font-size:15px;font-weight:600;color:var(--text-primary)}.card-body{padding:20px}.table-wrapper{overflow-x:auto}table{width:100%;border-collapse:collapse}table th{background:#f9fafb;color:var(--text-secondary);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}table td{padding:11px 14px;border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:13.5px;vertical-align:middle}table tr:last-child td{border-bottom:none}table tr:hover td{background:#fafffe}.td-actions{display:flex;gap:4px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:500;white-space:nowrap}.badge-success{background:var(--success-light);color:#065f46}.badge-warning{background:var(--warning-light);color:#92400e}.badge-danger{background:var(--danger-light);color:#991b1b}.badge-info{background:var(--info-light);color:#1e40af}.badge-gray{background:#f3f4f6;color:var(--text-secondary)}.badge-dot:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;display:inline-block}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:13px;font-weight:500;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;font-family:inherit;color:var(--text-primary);background:#fff;transition:border-color .15s,box-shadow .15s;outline:none}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #10b9811f}.form-group input.ng-invalid.ng-touched,.form-group select.ng-invalid.ng-touched,.form-group textarea.ng-invalid.ng-touched{border-color:var(--danger);box-shadow:0 0 0 3px #ef44441a}.form-group textarea{resize:vertical;min-height:80px}.form-group .form-error{font-size:12px;color:var(--danger)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.modal-overlay{position:fixed;inset:0;z-index:1000;background:#00000073;display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .18s ease}.modal-container{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border-light)}.modal-header h2{margin:0;font-size:16px;font-weight:600}.modal-header .modal-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--border-light);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s}.modal-header .modal-close:hover{background:var(--border);color:var(--text-primary)}.modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:16px 24px 20px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;gap:10px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header .page-title{font-size:20px;font-weight:700;margin:0;color:var(--text-primary)}.page-header .page-subtitle{font-size:13px;color:var(--text-secondary);margin:2px 0 0}.page-filters{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.page-filters .filter-search{position:relative;flex:1;min-width:200px}.page-filters .filter-search .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.page-filters .filter-search input{padding-left:34px;width:100%}.page-filters select{min-width:140px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.stat-card{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:18px 20px;display:flex;flex-direction:column;gap:8px}.stat-card .stat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.stat-card .stat-label{font-size:12.5px;font-weight:500;color:var(--text-secondary)}.stat-card .stat-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1}.stat-card .stat-change{font-size:12px;color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}.empty-state .empty-icon{font-size:48px;margin-bottom:12px}.empty-state p{margin:0;font-size:14px}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:13.5px;display:flex;align-items:center;gap:8px}.alert-warning{background:var(--warning-light);color:#92400e;border:1px solid #FDE68A}.alert-danger{background:var(--danger-light);color:#991b1b;border:1px solid #FECACA}.alert-success{background:var(--success-light);color:#065f46;border:1px solid #A7F3D0}.alert-info{background:var(--info-light);color:#1e40af;border:1px solid #BFDBFE}[title]{cursor:help}@media(max-width:768px){.form-row,.form-row-3{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr}.page-filters{flex-direction:column;align-items:stretch}}
