:root{--primary-dark-blue: #1a237e;--primary-green: #2e7d32;--background: #f0f4ff;--white: #ffffff;--text-dark: #1a237e;--accent-green: #388e3c;--light-green: #e8f5e9;--light-blue: #e8eaf6;--border-color: #e0e0e0;--text-secondary: #546e7a;--text-muted: #90a4ae;--danger: #c62828;--warning: #f57f17;--success: #2e7d32;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(26,35,126,.1);--shadow-lg: 0 8px 32px rgba(26,35,126,.15);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px}.brand-logo{height:32px;width:32px;object-fit:contain}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:var(--background);color:var(--text-dark);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c5cae9;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark-blue)}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700}.font-semibold{font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:all .2s ease;cursor:pointer;border:2px solid transparent}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-dark-blue);color:#fff;border-color:var(--primary-dark-blue)}.btn-primary:hover:not(:disabled){background:#283593;border-color:#283593;transform:translateY(-1px);box-shadow:0 4px 12px #1a237e4d}.btn-success{background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.btn-success:hover:not(:disabled){background:#388e3c;border-color:#388e3c;transform:translateY(-1px);box-shadow:0 4px 12px #2e7d324d}.btn-outline{background:transparent;color:var(--primary-dark-blue);border-color:var(--primary-dark-blue)}.btn-outline:hover:not(:disabled){background:var(--light-blue)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:#b71c1c;transform:translateY(-1px)}.card{background:var(--white);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:24px}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600}.badge.badge-success{background:var(--light-green);color:var(--primary-green)}.badge.badge-warning{background:#fff8e1;color:var(--warning)}.badge.badge-danger{background:#ffebee;color:var(--danger)}.badge.badge-info{background:var(--light-blue);color:var(--primary-dark-blue)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:13px;font-weight:600;color:var(--text-dark);text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group textarea,.form-group select{padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-sm);font-size:15px;color:var(--text-dark);background:#fff;transition:border-color .2s,box-shadow .2s;outline:none}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary-dark-blue);box-shadow:0 0 0 3px #1a237e1a}.form-group input::placeholder,.form-group textarea::placeholder,.form-group select::placeholder{color:var(--text-muted)}.form-group input.ng-invalid.ng-touched,.form-group textarea.ng-invalid.ng-touched,.form-group select.ng-invalid.ng-touched{border-color:var(--danger)}.form-group .error-msg{font-size:12px;color:var(--danger);margin-top:2px}.progress-bar-container{width:100%;height:10px;background:#e0e0e0;border-radius:5px;overflow:hidden}.progress-bar-container .progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-green),var(--accent-green));border-radius:5px;transition:width .6s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .4s ease forwards}.spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@media (max-width: 768px){.card{padding:16px}}
