.app{justify-content:center;align-items:center;width:100%;min-height:100vh;display:flex}.loading{color:#888;font-size:1.2rem}.screen{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;width:100%;max-width:900px;padding:2rem;display:flex}.title{letter-spacing:.1em;background:linear-gradient(135deg,#0f8,#0bf);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:3.5rem;font-weight:900}.subtitle{color:#888;margin-bottom:1rem;font-size:1.2rem}.auth-section{border-top:1px solid #222;width:100%;max-width:400px;margin-top:1rem;padding-top:1rem}.user-info{justify-content:center;align-items:center;gap:.6rem;display:flex}.user-avatar,.player-avatar{border-radius:50%;width:28px;height:28px}.user-name{color:#ccc;font-weight:600}.sign-in-options{flex-direction:column;align-items:center;gap:.6rem;display:flex}.sign-in-label{color:#666;font-size:.85rem}.sign-in-buttons{gap:.5rem;display:flex}.btn-oauth{color:#ccc;cursor:pointer;background:#1a1a2e;border:1px solid #444;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;transition:all .15s}.btn-oauth:hover{color:#fff;border-color:#0f8}.btn{cursor:pointer;border:none;border-radius:8px;padding:.8rem 2rem;font-size:1.1rem;font-weight:600;transition:all .2s}.btn-primary{color:#000;background:linear-gradient(135deg,#0f8,#0c6)}.btn-primary:hover{transform:scale(1.05);box-shadow:0 0 20px #00ff884d}.btn-secondary{color:#fff;background:#333}.btn-secondary:hover{background:#444}.btn-small{color:#fff;cursor:pointer;background:#333;border:none;border-radius:4px;padding:.4rem .8rem;font-size:.85rem}.btn-small:hover{background:#555}.invite-box{background:#1a1a2e;border:1px solid #333;border-radius:8px;width:100%;max-width:500px;padding:1.2rem}.invite-box p{color:#888;margin-bottom:.5rem}.invite-link{align-items:center;gap:.5rem;display:flex}.invite-link code{word-break:break-all;text-align:left;background:#0a0a1a;border-radius:4px;flex:1;padding:.5rem;font-size:.8rem}.players{gap:1rem;margin:1rem 0;display:flex}.player-card{background:#1a1a2e;border:2px solid #333;border-radius:8px;flex-direction:column;align-items:center;gap:.5rem;min-width:150px;padding:1.5rem 2rem;transition:border-color .3s;display:flex}.player-card.ready{border-color:#0f8}.player-card.end-screen{border-color:#fa0}.player-card.end-screen .player-status{color:#fa0}.player-card.empty{opacity:.5;border-style:dashed}.player-label{font-size:1.1rem;font-weight:600}.player-status{color:#888;font-size:.9rem}.player-card.ready .player-status{color:#0f8}.you-tag{color:#0bf;font-size:.75rem}.countdown{color:#fa0;font-size:2rem;font-weight:700;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.lobby-not-found-screen h1{color:#f48;font-size:2.5rem}.error-message{color:#aaa;max-width:400px;font-size:1.1rem}.lobby-config{background:#1a1a2e;border:1px solid #333;border-radius:8px;width:100%;max-width:500px;padding:1.2rem}.config-row{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.config-row label{color:#ccc;font-weight:600}.slider-group{align-items:center;gap:.8rem;display:flex}.points-slider{appearance:none;cursor:pointer;background:#333;border-radius:3px;outline:none;width:180px;height:6px}.points-slider:disabled{cursor:default;opacity:.5}.points-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#0f8;border:none;border-radius:50%;width:20px;height:20px}.points-slider:disabled::-webkit-slider-thumb{cursor:default;background:#666}.points-slider::-moz-range-thumb{cursor:pointer;background:#0f8;border:none;border-radius:50%;width:20px;height:20px}.points-slider:disabled::-moz-range-thumb{cursor:default;background:#666}.slider-value{color:#0f8;text-align:center;min-width:2ch;font-size:1.3rem;font-weight:700}.config-value{color:#888}.config-options{gap:.4rem;display:flex}.config-row-vertical{flex-direction:column;align-items:stretch;gap:.5rem}.game-set-options{flex-direction:column;gap:.4rem;display:flex}.game-set-btn{cursor:pointer;text-align:left;background:#0a0a1a;border:1px solid #333;border-radius:6px;flex-direction:column;align-items:flex-start;padding:.6rem .8rem;transition:all .15s;display:flex}.game-set-btn:hover:not(:disabled){border-color:#0f8}.game-set-btn.active{background:#00ff8812;border-color:#0f8}.game-set-btn:disabled{cursor:default;opacity:.7}.game-set-name{color:#ccc;font-size:.9rem;font-weight:600}.game-set-btn.active .game-set-name{color:#0f8}.game-set-desc{color:#666;margin-top:.15rem;font-size:.75rem}.config-note{color:#666;text-align:center;margin-top:.5rem;font-size:.8rem}.transition-screen{gap:1rem}.round-info{color:#888;text-transform:uppercase;letter-spacing:.1em;font-size:1rem}.score-display{align-items:center;gap:1rem;font-size:1.5rem;font-weight:700;display:flex}.score-divider{color:#555}.game-title{color:#0f8;font-size:3rem;font-weight:900}.game-tagline{color:#aaa;max-width:500px;font-size:1.2rem;font-style:italic}.game-controls{color:#ccc;background:#ffffff08;border:1px solid #333;border-radius:6px;max-width:500px;padding:.6rem 1.2rem;font-size:.95rem;line-height:1.4}.prev-result{border-radius:8px;padding:.5rem 1.5rem;font-size:1.3rem;font-weight:700}.prev-result.win{color:#0f8;background:#00ff8815}.prev-result.lose{color:#f48;background:#ff448815}.playing-screen{padding:0;position:relative}.controls-sidebar{color:#888;white-space:nowrap;pointer-events:none;background:#000a;border-radius:4px;padding:.3rem .8rem;font-family:monospace;font-size:.75rem;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.game-container{flex-direction:column;align-items:center;gap:.5rem;display:flex}.game-canvas{border:2px solid #333;border-radius:4px;max-width:100%;height:auto}.controls-hint{color:#666;font-size:.85rem}.reaction-game{width:100%;max-width:600px}.reaction-scores{gap:2rem;font-size:1.2rem;font-weight:600;display:flex}.reaction-round-info{color:#888;font-size:.9rem}.reaction-zone{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;outline:none;justify-content:center;align-items:center;width:100%;min-height:300px;font-size:2rem;font-weight:700;transition:background .15s;display:flex}.reaction-zone.waiting{background:#1a1a2e}.reaction-zone.ready{background:#8b0000}.reaction-zone.go{background:#060}.reaction-zone.result,.reaction-zone.finished{background:#1a1a2e}.game-over-screen.win h1{color:#0f8;font-size:3rem}.game-over-screen.lose h1{color:#f48;font-size:3rem}.final-score{align-items:center;gap:1rem;font-size:2rem;font-weight:700;display:flex}.round-history{background:#1a1a2e;border-radius:8px;width:100%;max-width:400px;padding:1.5rem}.round-history h2{color:#888;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.8rem;font-size:1rem}.round-entry{border-bottom:1px solid #222;justify-content:space-between;padding:.5rem 0;display:flex}.round-entry:last-child{border-bottom:none}.round-number{color:#666;font-size:.9rem}.round-game{text-align:center;flex:1}.round-result{font-size:.9rem;font-weight:600}.round-entry.won .round-result{color:#0f8}.round-entry.lost .round-result{color:#f48}.round-feedback{gap:2px;margin-left:auto;display:flex}.feedback-btn{cursor:pointer;opacity:.35;background:0 0;border:1px solid #0000;border-radius:4px;padding:1px 4px;font-size:.85rem;transition:all .15s}.feedback-btn:hover{opacity:.8}.feedback-btn.active{opacity:1;border-color:#444}.feedback-btn.active.up{border-color:#0f8}.feedback-btn.active.down{border-color:#f48}.feedback-section{flex-direction:column;align-items:center;gap:.5rem;width:100%;max-width:400px;display:flex}.bug-report-toggle{opacity:.5;font-size:.8rem}.bug-report-toggle:hover{opacity:1}.bug-report-panel{flex-direction:column;gap:.5rem;width:100%;display:flex}.bug-report-input{color:#fff;resize:vertical;background:#0a0a1a;border:1px solid #444;border-radius:6px;outline:none;width:100%;padding:.5rem;font-family:monospace;font-size:.85rem}.bug-report-input:focus{border-color:#0f8}.bug-report-actions{justify-content:flex-end;gap:.5rem;display:flex}.btn-submit-bug{color:#0f8;background:#0f83;border:1px solid #0f8}.btn-submit-bug:disabled{opacity:.3;cursor:default}.bug-report-thanks{color:#0f8;font-size:.85rem}.game-over-actions{gap:1rem;display:flex}.lobby-home-btn{opacity:.6;margin-top:.5rem}.lobby-home-btn:hover{opacity:1}.profile-screen h1{color:#0f8;font-size:2rem}.profile-card{background:#1a1a2e;border:1px solid #333;border-radius:12px;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:420px;padding:2rem;display:flex}.profile-avatar-section{justify-content:center;display:flex}.profile-avatar-wrapper{cursor:pointer;border-radius:50%;width:80px;height:80px;position:relative;overflow:hidden}.profile-avatar-wrapper:hover .profile-avatar-overlay{opacity:1}.profile-avatar-large{object-fit:cover;border:3px solid #0f8;border-radius:50%;width:80px;height:80px}.profile-avatar-placeholder{color:#0f8;background:#333;border:3px solid #0f8;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;font-weight:700;display:flex}.profile-avatar-overlay{color:#fff;opacity:0;background:#000a;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;transition:opacity .15s;display:flex;position:absolute;inset:0}.profile-form{flex-direction:column;gap:1rem;width:100%;display:flex}.profile-label{color:#ccc;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;display:flex}.profile-input{color:#fff;background:#0a0a1a;border:1px solid #444;border-radius:6px;outline:none;padding:.6rem .8rem;font-size:1rem;transition:border-color .15s}.profile-input:focus{border-color:#0f8}.profile-hint{color:#666;font-size:.75rem;font-weight:400}.profile-message{text-align:center;border-radius:6px;width:100%;padding:.5rem 1rem;font-size:.9rem}.profile-message.success{color:#0f8;background:#00ff8815}.profile-message.error{color:#f48;background:#ff448815}.profile-actions{gap:.8rem;display:flex}.profile-account-section{flex-direction:column;align-items:center;gap:.5rem;margin-top:1rem;display:flex}.profile-account-id{color:#555;font-family:monospace;font-size:.75rem}.profile-logout{opacity:.6}.profile-logout:hover{opacity:1}.profile-guest-message{color:#888;font-size:1.1rem}.match-history-section{width:100%;max-width:420px;margin-top:1rem}.match-history-section h2{color:#888;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;font-size:1rem}.match-entry{border-bottom:1px solid #222;align-items:center;gap:.6rem;padding:.4rem .6rem;font-size:.85rem;display:flex}.match-result{text-align:center;width:1.5rem;font-weight:700}.match-entry.won .match-result{color:#0f8}.match-entry.lost .match-result{color:#f48}.match-opponent{color:#ccc;min-width:80px}.match-score{color:#fff;text-align:center;min-width:30px;font-weight:600}.match-set{color:#888;background:#ffffff0a;border:1px solid #333;border-radius:3px;padding:1px 6px;font-size:.7rem}.match-games{color:#666;text-align:right;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.75rem;overflow:hidden}*{box-sizing:border-box;margin:0;padding:0}body{color:#fff;background:#0a0a1a;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}#root{justify-content:center;align-items:center;min-height:100vh;display:flex}
