*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#eff6ff;--success:#16a34a;--success-light:#f0fdf4;--warning:#d97706;--warning-light:#fffbeb;--danger:#dc2626;--danger-light:#fef2f2;--bg:#f1f5f9;--card:#fff;--text:#0f172a;--text-muted:#64748b;--border:#e2e8f0;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012, 0 2px 4px #0000000f;--shadow-lg:0 10px 15px #00000014, 0 4px 6px #0000000d;--radius:12px;--radius-sm:8px}html{font-size:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.6}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit}h1,h2,h3{line-height:1.3}.app{flex-direction:column;min-height:100vh;display:flex}.nav{background:var(--card);border-bottom:1px solid var(--border);z-index:100;box-shadow:var(--shadow);position:sticky;top:0}.nav-inner{justify-content:space-between;align-items:center;max-width:1100px;height:64px;margin:0 auto;padding:0 24px;display:flex}.nav-logo{color:var(--primary);align-items:center;gap:10px;font-size:1.1rem;font-weight:700;display:flex}.nav-logo span{font-size:1.5rem}.nav-links{gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--text-muted);background:0 0;border:none;padding:8px 16px;font-size:.9rem;font-weight:500;transition:all .15s}.nav-link:hover{background:var(--bg);color:var(--text)}.nav-link.active{background:var(--primary-light);color:var(--primary)}.main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 24px}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border)}.card-pad{padding:24px}.btn{border-radius:var(--radius-sm);border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.9rem;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-outline{color:var(--primary);border:1.5px solid var(--primary);background:#fff}.btn-outline:hover{background:var(--primary-light)}.btn-ghost{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{background:var(--border);color:var(--text)}.btn-lg{padding:14px 28px;font-size:1rem}.btn-full{width:100%}.form-group{margin-bottom:20px}.form-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.form-label{color:var(--text);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.form-label .req{color:var(--danger)}.form-input,.form-textarea,.form-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:#fff;outline:none;padding:10px 14px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea{resize:vertical;min-height:90px}.badge{border-radius:999px;align-items:center;gap:4px;padding:4px 10px;font-size:.78rem;font-weight:600;display:inline-flex}.badge-green{background:var(--success-light);color:var(--success)}.badge-red{background:var(--danger-light);color:var(--danger)}.badge-blue{background:var(--primary-light);color:var(--primary)}.badge-yellow{background:var(--warning-light);color:var(--warning)}.badge-gray{background:var(--bg);color:var(--text-muted);border:1px solid var(--border)}.score-display{text-align:center}.score-number{font-size:3.5rem;font-weight:800;line-height:1}.score-label{color:var(--text-muted);margin-top:4px;font-size:.8rem;font-weight:600}.score-bar{background:var(--border);border-radius:999px;height:6px;margin-top:10px;overflow:hidden}.score-bar-fill{border-radius:999px;height:100%;transition:width .5s}.score-excellent .score-number,.score-excellent .score-bar-fill{color:var(--success);background:var(--success)}.score-good .score-number,.score-good .score-bar-fill{color:var(--primary);background:var(--primary)}.score-fair .score-number,.score-fair .score-bar-fill{color:var(--warning);background:var(--warning)}.score-poor .score-number,.score-poor .score-bar-fill{color:var(--danger);background:var(--danger)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.9rem}th{text-align:left;background:var(--bg);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);padding:10px 14px;font-size:.78rem;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg)}.spinner{border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-box{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px;font-weight:500;display:flex}.error-box{background:var(--danger-light);border-radius:var(--radius-sm);color:var(--danger);border:1px solid #fca5a5;align-items:center;gap:8px;padding:14px 18px;font-size:.9rem;display:flex}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.rank-chip{background:var(--bg);border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:inline-flex}.rank-chip.rank-1{color:#713f12;background:#fef9c3;border-color:#fde047}.rank-chip.rank-2{color:#475569;background:#f1f5f9;border-color:#cbd5e1}.rank-chip.rank-3{color:#92400e;background:#fef3c7;border-color:#fcd34d}.category-chip{background:var(--primary-light);color:var(--primary);border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:.78rem;font-weight:600;display:inline-flex}@media (width<=640px){.form-grid{grid-template-columns:1fr}.main{padding:20px 16px}.nav-inner{padding:0 16px}}
