*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary:#2563eb;--color-primary-dark:#1d4ed8;--color-secondary:#0ea5e9;--color-success:#16a34a;--color-warning:#d97706;--color-danger:#dc2626;--color-info:#0284c7;--color-bg:#f1f5f9;--color-surface:#fff;--color-border:#e2e8f0;--color-text:#1e293b;--color-text-muted:#64748b;--radius:8px;--shadow:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--transition:.15s ease;--sidebar-w:240px}html,body{height:100%;color:var(--color-text);background:var(--color-bg);font-family:Inter,system-ui,sans-serif;font-size:14px}#app{height:100%}a{color:inherit;text-decoration:none}.app-shell{height:100vh;display:flex;overflow:hidden}.app-sidebar{width:var(--sidebar-w);color:#e2e8f0;background:#1e293b;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.app-main{flex-direction:column;flex:1;display:flex;overflow-y:auto}.app-topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:12px;height:56px;padding:0 24px;display:flex}.app-content{flex:1;padding:24px}.sidebar-logo{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:20px 16px 12px;display:flex}.sidebar-logo-icon{background:var(--color-primary);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:700;display:flex}.sidebar-logo-text{color:#fff;font-size:15px;font-weight:700;line-height:1.2}.sidebar-logo-sub{color:#94a3b8;font-size:11px}.sidebar-section{text-transform:uppercase;letter-spacing:.08em;color:#64748b;padding:16px 8px 4px;font-size:10px;font-weight:700}.sidebar-nav{padding:0 8px;list-style:none}.sidebar-nav li a,.sidebar-nav li button{color:#cbd5e1;cursor:pointer;text-align:left;width:100%;transition:background var(--transition), color var(--transition);background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:9px 10px;font-size:13.5px;display:flex}.sidebar-nav li a:hover,.sidebar-nav li button:hover{color:#fff;background:#ffffff12}.sidebar-nav li a.router-link-active{background:var(--color-primary);color:#fff}.sidebar-nav .nav-icon{text-align:center;flex-shrink:0;width:18px}.sidebar-footer{border-top:1px solid #ffffff14;margin-top:auto;padding:12px}.sidebar-user{border-radius:8px;align-items:center;gap:10px;padding:8px;display:flex}.sidebar-avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:#94a3b8;font-size:11px}.card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{font-size:16px;font-weight:600}.card-subtitle{color:var(--color-text-muted);margin-top:2px;font-size:12px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--color-surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px}.stat-label{color:var(--color-text-muted);margin-bottom:6px;font-size:12px;font-weight:500}.stat-value{font-size:28px;font-weight:700;line-height:1}.stat-sub{color:var(--color-text-muted);margin-top:4px;font-size:12px}.btn{cursor:pointer;transition:background var(--transition), opacity var(--transition);border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13.5px;font-weight:500;line-height:1.4;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:#d1d5db}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-warning{background:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background:#b45309}.btn-ghost{color:var(--color-primary);border:1px solid var(--color-primary);background:0 0}.btn-ghost:hover:not(:disabled){background:#eff6ff}.btn-sm{padding:5px 11px;font-size:12.5px}.btn-xs{padding:3px 8px;font-size:12px}.form-group{margin-bottom:16px}.form-label{margin-bottom:6px;font-size:13px;font-weight:500;display:block}.form-control{border:1px solid var(--color-border);width:100%;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition), box-shadow var(--transition);border-radius:6px;padding:9px 12px;font-size:13.5px}.form-control:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #2563eb1f}.form-control.is-invalid{border-color:var(--color-danger)}.form-error{color:var(--color-danger);margin-top:4px;font-size:12px}.form-hint{color:var(--color-text-muted);margin-top:4px;font-size:12px}textarea.form-control{resize:vertical;min-height:80px}select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:30px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=600px){.form-row{grid-template-columns:1fr}}.table-wrap{border-radius:var(--radius);border:1px solid var(--color-border);overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;background:#f8fafc;padding:10px 14px;font-size:12px;font-weight:600}tbody td{border-bottom:1px solid var(--color-border);padding:12px 14px;font-size:13.5px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#f8fafc}.badge{border-radius:999px;align-items:center;padding:2px 9px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-green{color:#15803d;background:#dcfce7}.badge-yellow{color:#854d0e;background:#fef9c3}.badge-red{color:#b91c1c;background:#fee2e2}.badge-purple{color:#7e22ce;background:#f3e8ff}.badge-gray{color:#475569;background:#f1f5f9}.badge-orange{color:#9a3412;background:#ffedd5}.alert{border-radius:6px;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13.5px;display:flex}.alert-info{color:#0369a1;background:#e0f2fe}.alert-success{color:#15803d;background:#dcfce7}.alert-warning{color:#854d0e;background:#fef9c3}.alert-danger{color:#b91c1c;background:#fee2e2}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:10px;flex-direction:column;width:100%;max-width:520px;max-height:90vh;display:flex;box-shadow:0 20px 40px #0000002e}.modal-header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-body{flex:1;padding:20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--color-border);flex-shrink:0;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.modal-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:20px;line-height:1}.modal-close:hover{background:var(--color-border)}.toast-container{z-index:200;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{box-shadow:var(--shadow-md);color:#fff;border-radius:8px;align-items:center;gap:10px;min-width:260px;max-width:380px;padding:12px 18px;font-size:13.5px;font-weight:500;animation:.2s slideIn;display:flex}.toast-success{background:#15803d}.toast-error{background:#b91c1c}.toast-info{background:#0369a1}.toast-warning{background:#b45309}@keyframes slideIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.rating-group{flex-direction:column;gap:12px;display:flex}.rating-item{align-items:center;gap:12px;display:flex}.rating-label{flex:1;font-size:13.5px}.rating-weight{color:var(--color-text-muted);font-size:11px}.rating-stars{gap:4px;display:flex}.rating-star{border:2px solid var(--color-border);cursor:pointer;width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.rating-star:hover,.rating-star.active{color:#92400e;background:#fef3c7;border-color:#f59e0b}.rating-star.active{color:#fff;background:#fbbf24;border-color:#f59e0b}.progress-steps{align-items:center;margin-bottom:28px;padding:4px 0;display:flex;overflow-x:auto}.step{flex-direction:column;flex:1;align-items:center;min-width:80px;display:flex;position:relative}.step-circle{border:2px solid var(--color-border);width:30px;height:30px;color:var(--color-text-muted);z-index:1;transition:all var(--transition);background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.step-label{color:var(--color-text-muted);text-align:center;margin-top:6px;font-size:11px;line-height:1.3}.step-connector{background:var(--color-border);z-index:0;height:2px;position:absolute;top:14px;left:50%;right:-50%}.step:last-child .step-connector{display:none}.step.done .step-circle{background:var(--color-success);border-color:var(--color-success);color:#fff}.step.done .step-connector{background:var(--color-success)}.step.done .step-label{color:var(--color-success)}.step.active .step-circle{border-color:var(--color-primary);color:var(--color-primary);background:#eff6ff}.step.active .step-label{color:var(--color-primary);font-weight:600}.page-header{margin-bottom:24px}.page-title{font-size:22px;font-weight:700}.page-sub{color:var(--color-text-muted);margin-top:4px;font-size:13.5px}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-muted{color:var(--color-text-muted);font-size:13px}.text-center{text-align:center}.empty-state{text-align:center;color:var(--color-text-muted);padding:48px 24px}.empty-icon{margin-bottom:12px;font-size:40px}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{justify-content:center;align-items:center;padding:60px;display:flex}.divider{background:var(--color-border);height:1px;margin:20px 0}.score-display{align-items:baseline;gap:4px;display:inline-flex}.score-num{color:var(--color-primary);font-size:32px;font-weight:800}.score-den{color:var(--color-text-muted);font-size:14px}
