:root{--bg: #0f1115;--surface: #1a1d24;--text: #f4f4f6;--text-dim: #9a9ea8;--accent: #ffb703;--error-bg: #3a1518;--error-text: #ff8a8a;font-family:Segoe UI,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text)}#app{min-height:100vh}h1{margin:0 0 .5em}button{font:inherit;cursor:pointer;border:none;border-radius:6px;padding:.5em 1em;background:var(--surface);color:var(--text)}button:disabled{cursor:default;opacity:.6}input,select{font:inherit;background:var(--surface);color:var(--text);border:1px solid #2c2f38;border-radius:6px;padding:.5em .75em}.error-banner{background:var(--error-bg);color:var(--error-text);padding:.75em 1em;border-radius:6px}.settings{max-width:480px;margin:4rem auto;padding:0 1.5rem}.settings form{display:flex;flex-direction:column;gap:1rem}.settings label{display:flex;flex-direction:column;gap:.4rem}.game-id-row{display:flex;gap:.5rem;margin-bottom:.5rem}.game-id-row input{flex:1}.share-link{display:flex;flex-direction:column;gap:.75rem}.share-link input{width:100%}.logout-button{float:right}.display{max-width:900px;margin:0 auto;padding:2rem 1.5rem 4rem}.display-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:1rem}.display-header h1{font-size:2.5rem;flex:1}.last-updated{color:var(--text-dim);font-size:.9rem}.view-toggle{display:flex;gap:.5rem;margin-bottom:1.5rem}.view-toggle button.active{background:var(--accent);color:var(--bg)}.leaderboard{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.team-row{background:var(--surface);border-radius:10px;overflow:hidden}.team-row-main{width:100%;display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:none;text-align:left}.rank{font-size:1.5rem;font-weight:700;width:2.5rem;text-align:center;color:var(--text-dim)}.avatar,.avatar-placeholder{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-placeholder{display:flex;align-items:center;justify-content:center;background:#2c2f38;font-weight:700}.name{flex:1;font-size:1.25rem}.points{font-size:1.5rem;font-weight:700;color:var(--accent)}.chevron{color:var(--text-dim)}.players{list-style:none;margin:0;padding:.5rem 1rem 1rem 4.5rem;display:flex;flex-direction:column;gap:.5rem}.player{display:flex;align-items:center;gap:.75rem}.player-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover}.captain-badge{color:var(--accent);font-size:.85rem}
