*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--surface: #222244;--surface-alt: #2a2a4a;--border: #3a3a5c;--text: #e0e0f0;--text-muted: #8888aa;--accent: #00d4aa;--accent-dim: rgba(0, 212, 170, .15);--danger: #ff6b6b;--danger-dim: rgba(255, 107, 107, .12);--installed: rgba(0, 212, 170, .08);--missing: rgba(255, 107, 107, .06);--radius: 8px;--shadow: 0 2px 12px rgba(0, 0, 0, .4)}html{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}body{min-height:100vh}#app{max-width:960px;margin:0 auto;padding:2rem 1.5rem 4rem}h1{font-size:1.6rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem;color:#fff}h2{font-size:1.1rem;font-weight:500;color:var(--text-muted);margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.car-nickname{color:var(--text);font-style:italic}.build-tag{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.05em;background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:.15rem .5rem;color:var(--accent);vertical-align:middle}h3{font-size:1rem;font-weight:600;color:var(--text);margin-top:2rem;margin-bottom:.75rem}p{margin-bottom:1rem;color:var(--text-muted)}button{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.2rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}button:hover{background:var(--surface-alt);border-color:var(--accent)}button:active{transform:scale(.98)}button[type=submit],#refresh{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:600}button[type=submit]:hover,#refresh:hover{background:#00e8bb;border-color:#00e8bb}#key-form{display:flex;gap:.75rem;margin-top:1rem;max-width:480px}#key-input{flex:1;padding:.6rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:.95rem;font-family:SF Mono,Fira Code,Cascadia Code,monospace;outline:none;transition:border-color .15s}#key-input::placeholder{color:var(--text-muted)}#key-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.error{color:var(--danger);background:var(--danger-dim);border:1px solid rgba(255,107,107,.25);padding:.6rem 1rem;border-radius:var(--radius);font-size:.9rem;margin-bottom:1rem}.next-upgrade{display:flex;align-items:center;gap:1.25rem;background:var(--accent-dim);border:1px solid rgba(0,212,170,.3);border-radius:var(--radius);padding:2.25rem 1.5rem 1.25rem;margin-bottom:1.5rem;position:relative}.next-upgrade:before{content:"NEXT UPGRADE";position:absolute;top:.7rem;left:1.5rem;font-size:.65rem;font-weight:700;letter-spacing:.08em;color:var(--accent)}.next-upgrade__points{font-size:3.5rem;font-weight:800;line-height:1;color:var(--accent);flex-shrink:0;display:flex;flex-direction:column;align-items:center;min-width:70px}.next-upgrade__points span{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent);opacity:.7}.next-upgrade__info{min-width:0}.next-upgrade__name{font-size:1.2rem;font-weight:600;color:#fff}.next-upgrade__category{font-size:.85rem;color:var(--text-muted);margin-top:.2rem}.progress-rows{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1.5rem}.progress-row{display:flex;align-items:center;gap:.75rem}.progress-row__label{width:75px;flex-shrink:0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.progress-row__bar{flex:1;min-width:0}.progress-row__value{width:90px;flex-shrink:0;text-align:right;font-size:.95rem;font-weight:700;color:#fff;font-variant-numeric:tabular-nums}.progress-row__of{font-weight:400;color:var(--text-muted)}table{width:100%;border-collapse:collapse;font-size:.85rem;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}thead{background:var(--surface)}thead th{padding:.55rem .6rem;text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border)}tbody td{padding:.5rem .6rem;border-bottom:1px solid rgba(58,58,92,.5)}tbody tr:last-child td{border-bottom:none}.upgrade-checklist thead th:first-child{width:60px;text-align:center}.pts-cell{font-size:1.1rem;font-weight:700;color:var(--accent);text-align:center;font-variant-numeric:tabular-nums}.upgrade--installed .pts-cell{color:var(--text-muted);font-weight:500}.upgrade-checklist{margin-bottom:.5rem}.upgrade-checklist tbody tr{transition:background .1s}.upgrade-checklist tbody tr:hover{background:#ffffff0a}.upgrade--missing td:first-child{color:#fff;font-weight:500}.upgrade--installed td{color:var(--text-muted)}.upgrade-checklist--installed{opacity:.7}.checklist-header{display:flex;align-items:baseline;gap:1rem;margin-top:2rem;margin-bottom:.75rem}.checklist-header h3{margin:0}.checklist-toggle{font-size:.8rem;color:var(--accent);text-decoration:none;cursor:pointer}.checklist-toggle:hover{text-decoration:underline}.progress-bar{height:6px;background:var(--surface);border-radius:3px;overflow:hidden}.progress-bar__fill{height:100%;background:var(--accent);border-radius:3px;transition:width .4s ease}.actions{display:flex;gap:.75rem;margin-top:1.5rem}.loading-spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle;margin-right:.5rem}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:640px){#app{padding:1.25rem 1rem 3rem}h1{font-size:1.3rem}.progress-stats{grid-template-columns:repeat(2,1fr)}table{font-size:.78rem}thead th,tbody td{padding:.4rem}.upgrade-checklist{display:block;overflow-x:auto}}
