:root{font-family:Space Grotesk,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:radial-gradient(circle at top,#eef4ff,#f3f6fb 60%,#fdfdfd);color:#0f1c3b}*{box-sizing:border-box}body{margin:0;min-height:100vh}.page{min-height:100vh;padding:2rem;display:flex;flex-direction:column;align-items:center}.panel{width:min(100%,960px);background:#fff;border-radius:1.25rem;padding:2rem 2.5rem;box-shadow:0 15px 50px #1f377a26;margin-bottom:2rem}.auth-panel h1,.loading-panel h1{margin-top:0;font-size:2.25rem}.loading-panel{text-align:center}.loading-panel .loading-message{margin:2rem 0}.loading-panel .loading-message p{margin:.5rem 0}.loading-panel .loading-message #loadingStatus{font-size:1.1rem;color:#0f1c3b;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.progress-container{margin:1.5rem 0}.progress-bar{width:100%;height:20px;background:#f0f2f5;border-radius:10px;overflow:hidden;position:relative}.progress-fill{height:100%;background:#879643;border-radius:10px;width:0%;transition:width .3s ease}.progress-text{text-align:center;margin-top:.5rem;font-size:.9rem;color:#516086}.intro{color:#516086;line-height:1.6}.session-form{display:grid;gap:1rem;margin-top:1.25rem}.session-form label{display:flex;flex-direction:column;gap:.35rem;font-weight:600;color:#24325a}.session-form input{border-radius:.6rem;border:1px solid #c8d3f0;padding:.9rem 1rem;font-size:1rem}.session-form button{background:#879643;border:none;border-radius:.75rem;color:#fff;padding:.95rem;font-size:1.05rem;cursor:pointer;font-weight:600;transition:background .2s ease-in-out}.session-form button:hover{background:#768438}.form-error{color:#c43333;min-height:1.2rem}.hint{font-size:.9rem;color:#7a88ad}.hidden{display:none}.game-header{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}.subtle{color:#7a88ad;margin-top:.25rem}.stats-container{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem}.erode-logo{height:24px;width:auto}.stats{display:flex;gap:1.5rem}.score-label{text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;color:#7a88ad}.score-value{font-size:1.5rem;margin:.15rem 0 0}.actions{display:flex;align-items:center;gap:1.25rem;margin:1.5rem 0}button.primary{background:#879643;border:none;color:#fff;padding:.9rem 1.4rem;border-radius:.9rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}button.primary:hover:not(:disabled){background:#768438}button.primary:disabled{opacity:.6;cursor:not-allowed}.status{color:#516086}.chart-card{background:#f6f8ff;border-radius:1rem;padding:1rem 1.5rem;border:1px solid #dbe3ff;min-height:360px}.chart-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}.meta-label{text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;color:#7a88ad;margin:0}.meta-value{font-size:1.05rem;margin:.2rem 0 0}.chart-card canvas{width:100%!important;height:260px!important}.choices{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-top:1.5rem}.choice{border-radius:.9rem;padding:.85rem 1rem;border:1px solid #c8d3f0;background:#fff;font-size:1rem;cursor:pointer;transition:transform .15s ease,border-color .15s ease}.choice:hover{transform:translateY(-2px)}.choice:disabled{cursor:not-allowed;opacity:.7}.choice.pending{opacity:.6}.choice.correct{border-color:#2ecc71;color:#1f8a4c;background:#e4f7ec}.choice.incorrect{border-color:#d14f4f;color:#a02828;background:#fde8e8}.feedback{min-height:1.5rem;font-weight:600;color:#24325a}.leaderboard-panel h2{margin:0}.leaderboard-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}button.ghost{background:transparent;border:1px solid #c8d3f0;color:#879643;padding:.55rem 1.2rem;border-radius:.8rem;font-weight:600;cursor:pointer;transition:all .2s}button.ghost:hover:not(:disabled){border-color:#879643;background:#8796430d}button.ghost:disabled{opacity:.6;cursor:not-allowed}.leaderboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:1.25rem}.leaderboard-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.leaderboard-list li{display:flex;justify-content:space-between;align-items:center;background:#f8f9ff;border:1px solid #e1e6ff;border-radius:.8rem;padding:.65rem .9rem;font-weight:500}.leader-name{flex:1;margin-left:.4rem}.leader-detail{color:#516086;font-size:.9rem}.rank{font-weight:700;color:#7a88ad;min-width:1.5rem}@media (max-width: 720px){.panel{padding:1.5rem}.stats{width:100%;justify-content:space-between}}
