*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a56db;--primary-light:#e8f0fe;--primary-dark:#1240a8;--accent:#0ea5e9;--surface:#fff;--surface-2:#f8fafc;--surface-3:#f1f5f9;--border:#e2e8f0;--border-strong:#cbd5e1;--text-1:#0f172a;--text-2:#475569;--text-3:#94a3b8;--success:#059669;--success-light:#d1fae5;--warning:#d97706;--warning-light:#fef3c7;--danger:#dc2626;--danger-light:#fee2e2;--info:#0284c7;--info-light:#e0f2fe;--sidebar-w:260px;--header-h:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000000f,0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014,0 2px 6px #0000000d;--shadow-lg:0 10px 40px #0000001a,0 4px 12px #0000000f;--font-sans:"DM Sans",system-ui,sans-serif;--font-serif:"DM Serif Display",serif;--transition:all 0.2s cubic-bezier(0.4,0,0.2,1)}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;background:#f1f5f9;background:var(--surface-3);color:#0f172a;color:var(--text-1);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);line-height:1.6}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;background:var(--border-strong);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#94a3b8;background:var(--text-3)}input,select,textarea{background:#fff;background:var(--surface);border:1.5px solid #e2e8f0;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius-md);color:#0f172a;color:var(--text-1);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);font-size:14px;outline:none;padding:10px 14px;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);width:100%}input:focus,select:focus,textarea:focus{border-color:#1a56db;border-color:var(--primary);box-shadow:0 0 0 3px #1a56db1a}input::placeholder,textarea::placeholder{color:#94a3b8;color:var(--text-3)}textarea{min-height:100px;resize:vertical}select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;padding-right:36px}label{color:#475569;color:var(--text-2);display:block;font-size:13px;margin-bottom:6px}.btn,label{font-weight:500}.btn{align-items:center;border:1.5px solid #0000;border-radius:10px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);font-size:14px;gap:8px;padding:10px 20px;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition);white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:#1a56db;background:var(--primary);border-color:#1a56db;border-color:var(--primary);color:#fff}.btn-primary:hover{background:#1240a8;background:var(--primary-dark);box-shadow:0 4px 12px #1a56db4d}.btn-secondary{background:#fff;background:var(--surface);border-color:#e2e8f0;border-color:var(--border);color:#0f172a;color:var(--text-1)}.btn-secondary:hover{background:#f8fafc;background:var(--surface-2);border-color:#cbd5e1;border-color:var(--border-strong)}.btn-ghost{background:#0000;border-color:#0000;color:#475569;color:var(--text-2)}.btn-ghost:hover{background:#f1f5f9;background:var(--surface-3);color:#0f172a;color:var(--text-1)}.btn-danger{background:#dc2626;background:var(--danger);border-color:#dc2626;border-color:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-success{background:#059669;background:var(--success);border-color:#059669;border-color:var(--success);color:#fff}.btn-success:hover{background:#047857}.btn-sm{font-size:13px;padding:6px 14px}.btn-lg{font-size:15px;padding:13px 28px}.btn:disabled{cursor:not-allowed;opacity:.55;pointer-events:none}.card{background:#fff;background:var(--surface);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);padding:24px}.card-sm{border-radius:10px;border-radius:var(--radius-md);padding:16px}.badge{align-items:center;border-radius:99px;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:3px 10px}.badge-blue{background:#e8f0fe;background:var(--primary-light);color:#1a56db;color:var(--primary)}.badge-green{background:#d1fae5;background:var(--success-light);color:#059669;color:var(--success)}.badge-amber{background:#fef3c7;background:var(--warning-light);color:#d97706;color:var(--warning)}.badge-red{background:#fee2e2;background:var(--danger-light);color:#dc2626;color:var(--danger)}.badge-gray{background:#f1f5f9;background:var(--surface-3);color:#475569;color:var(--text-2)}.badge-sky{background:#e0f2fe;background:var(--info-light);color:#0284c7;color:var(--info)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;font-size:14px;width:100%}thead th{background:#f8fafc;background:var(--surface-2);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#475569;color:var(--text-2);font-size:12px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}thead th:first-child{border-radius:6px 0 0 0;border-radius:var(--radius-sm) 0 0 0}thead th:last-child{border-radius:0 6px 0 0;border-radius:0 var(--radius-sm) 0 0}tbody td{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);color:#0f172a;color:var(--text-1);padding:14px 16px;vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:#f8fafc;background:var(--surface-2)}.flex,.flex-col{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}.gap-6{gap:24px}.w-full{width:100%}.text-sm{font-size:13px}.text-xs{font-size:12px}.text-muted{color:#475569;color:var(--text-2)}.text-hint{color:#94a3b8;color:var(--text-3)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.grid-2{grid-gap:16px;grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:16px}.grid-3{grid-gap:16px;grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.score-bar{background:#f1f5f9;background:var(--surface-3);border-radius:99px;height:8px;overflow:hidden}.score-fill{border-radius:99px;height:100%;transition:width .8s cubic-bezier(.4,0,.2,1)}.divider{border:none;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);margin:20px 0}@keyframes spin{to{transform:rotate(1turn)}}.spinner{animation:spin .7s linear infinite;border:2px solid #e2e8f0;border-top-color:#1a56db;border:2px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:20px;width:20px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-up{animation:fadeInUp .4s ease both}.animate-fade{animation:fadeIn .3s ease both}.animate-scale{animation:scaleIn .3s ease both}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#f8fafc 25%,#f1f5f9 50%,#f8fafc 75%);background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-3) 50%,var(--surface-2) 75%);background-size:200% 100%;border-radius:6px;border-radius:var(--radius-sm)}.empty-state{color:#475569;color:var(--text-2);padding:60px 24px;text-align:center}.empty-state-icon{align-items:center;background:#f1f5f9;background:var(--surface-3);border-radius:16px;border-radius:var(--radius-lg);color:#94a3b8;color:var(--text-3);display:flex;height:56px;justify-content:center;margin:0 auto 16px;width:56px}.empty-state h3{color:#0f172a;color:var(--text-1);font-size:16px;font-weight:600;margin-bottom:6px}.empty-state p{color:#475569;color:var(--text-2);font-size:14px}.modal-backdrop{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:100}.modal{animation:scaleIn .25s ease;background:#fff;background:var(--surface);border-radius:24px;border-radius:var(--radius-xl);box-shadow:0 10px 40px #0000001a,0 4px 12px #0000000f;box-shadow:var(--shadow-lg);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;padding:24px 28px 0}.modal-body{padding:20px 28px 28px}.modal-title{color:#0f172a;color:var(--text-1);font-size:18px;font-weight:600}.tabs{background:#f8fafc;background:var(--surface-2);border-radius:10px;border-radius:var(--radius-md);display:flex;gap:4px;margin-bottom:24px;padding:4px}.tab{background:none;border:none;border-radius:6px;border-radius:var(--radius-sm);color:#475569;color:var(--text-2);cursor:pointer;flex:1 1;font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);font-size:13px;font-weight:500;padding:8px 16px;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1);transition:var(--transition)}.tab.active{background:#fff;background:var(--surface);box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;box-shadow:var(--shadow-sm);color:#1a56db;color:var(--primary)}.page-header{margin-bottom:28px}.page-title{color:#0f172a;color:var(--text-1);font-family:"DM Serif Display",serif;font-family:var(--font-serif);font-size:28px;margin-bottom:4px}.page-subtitle{color:#475569;color:var(--text-2);font-size:14px}.form-group{margin-bottom:18px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}