.auth-wrap{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;width:100%;max-width:400px;padding:2.5rem}.auth-logo{letter-spacing:-.02em;margin-bottom:.2rem;font-size:1.5rem;font-weight:700}.auth-logo .loved{color:var(--loved)}.auth-logo .shoved{color:var(--shoved)}.auth-sub{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:2rem;font-size:.62rem}.auth-title{font-family:var(--mono);color:var(--mid);text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.4rem;font-size:.72rem}.auth-field{margin-bottom:1rem}.auth-label{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem;font-size:.62rem;display:block}.auth-btn{background:var(--accent);width:100%;color:var(--bg);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;border:none;border-radius:4px;margin-top:.5rem;padding:.75rem;font-size:.78rem;font-weight:700;transition:opacity .15s}.auth-btn:hover:not(:disabled){opacity:.88}.auth-btn:disabled{opacity:.45;cursor:not-allowed}.auth-error{color:var(--danger);font-family:var(--mono);background:#2a1020;border:1px solid #5a2040;border-radius:4px;margin-bottom:1rem;padding:.6rem .8rem;font-size:.72rem}.auth-notice{color:var(--accent2);font-family:var(--mono);background:#0a1f14;border:1px solid #1a5034;border-radius:4px;margin-bottom:1rem;padding:.6rem .8rem;font-size:.72rem}.auth-divider{border:none;border-top:1px solid var(--border);margin:1.2rem 0}.auth-google-btn{border:1px solid var(--border);width:100%;color:var(--mid);font-family:var(--mono);background:0 0;border-radius:4px;margin-bottom:.25rem;padding:.65rem;font-size:.72rem;transition:border-color .15s,color .15s}.auth-google-btn:hover{border-color:var(--accent);color:var(--text)}.auth-links{flex-direction:column;align-items:center;gap:.5rem;margin-top:1.4rem;display:flex}.auth-link{font-family:var(--mono);color:var(--muted);font-size:.7rem;text-decoration:none;transition:color .15s}.auth-link:hover{color:var(--accent)}.app-shell{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:1rem;height:54px;padding:0 2rem;display:flex}.header-logo{letter-spacing:-.02em;white-space:nowrap;font-size:1.1rem;font-weight:700}.header-logo .loved{color:var(--loved)}.header-logo .shoved{color:var(--shoved)}.header-nav{align-items:center;gap:.25rem;margin-left:auto;display:flex}.nav-link{color:var(--muted);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;background:0 0;border:none;border-radius:3px;padding:.35rem .7rem;font-size:.68rem;text-decoration:none;transition:color .15s,background .15s}.nav-link:hover,.nav-link.active{color:var(--text);background:var(--raised)}.nav-link.danger{color:var(--danger)}.nav-link.danger:hover{background:#2a1020}.header-user{font-family:var(--mono);color:var(--muted);margin-right:.5rem;font-size:.65rem}.app-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem}.page-header{align-items:baseline;gap:1rem;margin-bottom:1.8rem;display:flex}.page-title{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.page-sub{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-size:.68rem}.btn{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;white-space:nowrap;border:none;border-radius:4px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.72rem;font-weight:700;text-decoration:none;transition:opacity .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn:hover:not(:disabled){opacity:.85}.btn-primary{background:var(--accent);color:var(--bg)}.btn-loved{background:var(--loved);color:var(--bg)}.btn-shoved{background:var(--shoved);color:var(--bg)}.btn-ghost{background:var(--raised);color:var(--mid);border:1px solid var(--border)}.btn-danger{background:var(--danger);color:var(--bg)}.btn-sm{padding:.3rem .65rem;font-size:.65rem}.btn-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:1.4rem}.card:hover{border-color:var(--border2)}.card.clickable{cursor:pointer;transition:border-color .15s,transform .1s}.card.clickable:hover{border-color:var(--accent);transform:translateY(-1px)}.card-title{margin-bottom:.3rem;font-size:1.05rem;font-weight:600}.card-sub{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.8rem;font-size:.65rem}.card-desc{color:var(--mid);margin-bottom:1rem;font-size:.88rem}.score-badge{font-family:var(--mono);letter-spacing:.05em;border-radius:3px;align-items:center;gap:.4rem;padding:.25rem .65rem;font-size:.7rem;font-weight:700;display:inline-flex}.score-supergiant{color:#c87af0;background:#2a1a40;border:1px solid #5a3080}.score-giant{color:#7ab0f0;background:#1a2840;border:1px solid #305080}.score-main{color:#7af0a0;background:#1a2a1a;border:1px solid #306050}.score-dwarf{color:#f0c070;background:#2a2010;border:1px solid #806030}.score-dying{color:#f07070;background:#2a1010;border:1px solid #803030}.grid-2{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;display:grid}@media (width<=768px){.grid-2,.grid-3{grid-template-columns:1fr}.app-main{padding:1rem}}.form-card{max-width:640px}.form-field{margin-bottom:1.2rem}.form-label{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem;font-size:.65rem;display:block}.form-hint{color:var(--muted);margin-top:.3rem;font-size:.78rem}.form-error{color:var(--danger);margin-top:.3rem;font-size:.78rem}.stats-row{flex-wrap:wrap;gap:1rem;margin-bottom:2rem;display:flex}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:6px;min-width:120px;padding:1rem 1.4rem}.stat-label{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.4rem;font-size:.6rem}.stat-value{letter-spacing:-.03em;font-size:1.8rem;font-weight:700}.data-table{border-collapse:collapse;width:100%}.data-table th{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.1em;text-align:left;border-bottom:1px solid var(--border);padding:.6rem 1rem;font-size:.6rem}.data-table td{border-bottom:1px solid var(--border);padding:.85rem 1rem;font-size:.88rem}.data-table tr:hover td{background:var(--raised)}.data-table tr:last-child td{border-bottom:none}.section-title{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.14em;margin-bottom:1rem;font-size:.65rem}.tabs{border-bottom:1px solid var(--border);gap:.25rem;margin-bottom:1.5rem;display:flex}.tab-btn{color:var(--muted);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:.6rem .9rem;font-size:.68rem;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.mono{font-family:var(--mono)}.empty-state{color:var(--muted);padding:2rem 0;font-style:italic}.error-msg{color:var(--danger);margin:.5rem 0;font-size:.85rem}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-row{color:var(--muted);font-family:var(--mono);align-items:center;gap:.75rem;padding:2rem 0;font-size:.75rem;display:flex}.score-bar-wrap{margin-bottom:.6rem}.score-bar-label{font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.08em;justify-content:space-between;margin-bottom:.25rem;font-size:.62rem;display:flex}.score-bar-track{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.score-bar-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .4s}.pill{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;border-radius:3px;padding:.18rem .6rem;font-size:.62rem;font-weight:700;display:inline-block}.pill-loved{color:var(--loved);background:#2a0a14;border:1px solid #602040}.pill-shoved{color:var(--shoved);background:#0a1428;border:1px solid #204060}.pill-neutral{background:var(--raised);color:var(--mid);border:1px solid var(--border)}.pill-warn{color:var(--warn);background:#281a08;border:1px solid #604020}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d0b0f;--surface:#141018;--raised:#1c1824;--border:#2a2432;--border2:#3a3248;--text:#e8e0f0;--mid:#9888b0;--muted:#5a4a6a;--accent:#c87af0;--accent2:#7af0c8;--loved:#f06090;--shoved:#6090f0;--warn:#f0b060;--danger:#f06060;--mono:"Courier New", monospace}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.6}a{color:var(--accent);text-decoration:none}a:hover{color:var(--text)}button{cursor:pointer}input,textarea,select{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:4px;outline:none;width:100%;padding:.6rem .75rem;font-family:inherit;font-size:.9rem;transition:border-color .15s}input:focus,textarea:focus,select:focus{border-color:var(--accent)}textarea{resize:vertical;min-height:100px}select option{background:var(--surface)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
