@import url(https://fonts.googleapis.com/css2?family=Fredoka+One&family=Nunito:wght@400;600;700;800&display=swap);:root{--bg:#0f0f1a;--surface:#1a1a2e;--surface2:#16213e;--accent:#f7c948;--accent2:#ff6b6b;--green:#4ade80;--blue:#60a5fa;--purple:#a78bfa;--text:#f0f0f8;--muted:#88a;--border:#ffffff14;--radius:14px}*{box-sizing:border-box;margin:0;padding:0}body{background:#0f0f1a;background:var(--bg);color:#f0f0f8;color:var(--text);font-family:Nunito,sans-serif;min-height:100vh;overflow-x:hidden;overflow-y:auto}.lobby-screen{align-items:center;background:radial-gradient(ellipse at 30% 20%,#1e1040 0,#0f0f1a 60%),radial-gradient(ellipse at 80% 80%,#0d2040 0,#0000 60%);display:flex;justify-content:center;min-height:100vh}.lobby-card{background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:24px;box-shadow:0 24px 80px #00000080;display:flex;flex-direction:column;gap:20px;max-width:95vw;padding:48px 40px;width:400px}.logo{color:#f7c948;color:var(--accent);font-family:Fredoka One,cursive;font-size:2.4rem;letter-spacing:1px;text-align:center}.logo span{color:#f0f0f8;color:var(--text)}.tagline{color:#88a;color:var(--muted);font-size:.9rem;letter-spacing:2px;margin-top:-12px;text-align:center;text-transform:uppercase}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{color:#88a;color:var(--muted);font-size:.7rem;font-weight:800;letter-spacing:2px}.form-group input{background:#0f0f1a;background:var(--bg);border:1.5px solid #ffffff14;border:1.5px solid var(--border);border-radius:14px;border-radius:var(--radius);color:#f0f0f8;color:var(--text);font-family:Nunito,sans-serif;font-size:1rem;font-weight:700;outline:none;padding:12px 16px;transition:border-color .2s}.form-group input:focus{border-color:#f7c948;border-color:var(--accent)}.btn-primary{background:#f7c948;background:var(--accent);border:none;border-radius:14px;border-radius:var(--radius);box-shadow:0 4px 20px #f7c9484d;color:#111;cursor:pointer;font-family:Fredoka One,cursive;font-size:1.1rem;letter-spacing:1px;padding:14px;transition:transform .15s,box-shadow .15s}.btn-primary:hover{box-shadow:0 8px 30px #f7c94866;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.4;transform:none}.hint{color:#88a;color:var(--muted);font-size:.8rem;text-align:center}.error-msg{background:#ff6b6b26;border:1px solid #ff6b6b;border:1px solid var(--accent2);border-radius:8px;color:#ff6b6b;color:var(--accent2);font-size:.85rem;padding:10px 14px}.waiting-room{align-items:center;background:radial-gradient(ellipse at center,#1e1040 0,#0f0f1a 70%);display:flex;justify-content:center;min-height:100vh}.waiting-card{background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:24px;box-shadow:0 24px 80px #00000080;display:flex;flex-direction:column;gap:20px;max-width:95vw;padding:40px;width:460px}.waiting-card h2{font-family:Fredoka One,cursive;font-size:1.6rem}.waiting-card h2 span{background:#f7c9481a;border-radius:8px;color:#f7c948;color:var(--accent);padding:2px 12px}.share-hint{font-size:.85rem}.player-list h3,.share-hint{color:#88a;color:var(--muted)}.player-list h3{font-size:.75rem;letter-spacing:2px;margin-bottom:10px;text-transform:uppercase}.player-item{background:#0f0f1a;background:var(--bg);border-radius:10px;font-weight:700;gap:10px;margin-bottom:6px;padding:8px 12px}.avatar,.player-item{align-items:center;display:flex}.avatar{background:linear-gradient(135deg,#a78bfa,#60a5fa);background:linear-gradient(135deg,var(--purple),var(--blue));border-radius:50%;font-size:.85rem;font-weight:800;height:32px;justify-content:center;width:32px}.you-badge{background:#f7c948;background:var(--accent);border-radius:6px;color:#111;font-size:.7rem;font-weight:800;margin-left:auto;padding:2px 8px}.waiting-text{color:#88a;color:var(--muted);font-size:.9rem;text-align:center}.game-screen{background:#0f0f1a;background:var(--bg);display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.game-header{align-items:center;background:#1a1a2e;background:var(--surface);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);display:flex;flex-shrink:0;gap:16px;justify-content:space-between;padding:12px 20px}.round-info{color:#f7c948;color:var(--accent);font-family:Fredoka One,cursive;font-size:1rem;white-space:nowrap}.word-display{flex:1 1;font-size:1.2rem;font-weight:800;text-align:center}.blanks{color:#f7c948;color:var(--accent);font-size:1.4rem;letter-spacing:8px}.draw-label{color:#88a;color:var(--muted);font-size:.9rem}.revealed-word{color:#4ade80;color:var(--green)}.timer{color:#60a5fa;color:var(--blue);font-family:Fredoka One,cursive;font-size:1.2rem;min-width:70px;text-align:right;white-space:nowrap}.timer.urgent{animation:pulse .5s infinite alternate;color:#ff6b6b;color:var(--accent2)}@keyframes pulse{0%{opacity:1}to{opacity:.5}}.game-main{display:flex;flex:1 1;gap:0;min-height:0;overflow:hidden}.scoreboard{background:#1a1a2e;background:var(--surface);border-right:1px solid #ffffff14;border-right:1px solid var(--border);flex-shrink:0;min-width:190px;overflow-y:auto;padding:16px 12px;width:190px}.scoreboard h3{color:#88a;color:var(--muted);font-size:.7rem;letter-spacing:2px;margin-bottom:12px;text-transform:uppercase}.player-score{align-items:center;background:#0f0f1a;background:var(--bg);border:1px solid #0000;border-radius:10px;display:flex;gap:8px;margin-bottom:6px;padding:8px;transition:border-color .2s}.player-score.is-drawer{background:#f7c94812;border-color:#f7c948;border-color:var(--accent)}.player-score.guessed{background:#4ade8012;border-color:#4ade80;border-color:var(--green)}.p-avatar{align-items:center;background:linear-gradient(135deg,#a78bfa,#60a5fa);background:linear-gradient(135deg,var(--purple),var(--blue));border-radius:50%;display:flex;flex-shrink:0;font-size:.75rem;font-weight:800;height:28px;justify-content:center;width:28px}.p-info{flex:1 1;min-width:0}.p-name{display:block;font-size:.78rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.drawer-tag{color:#f7c948;color:var(--accent);font-size:.65rem}.guessed-tag{font-size:.75rem}.p-score{color:#f7c948;color:var(--accent);flex-shrink:0;font-family:Fredoka One,cursive;font-size:.95rem}.canvas-wrapper{align-items:center;background:linear-gradient(160deg,#0d0d1f,#111128 60%,#0a0a1a);display:flex;flex:1 1;flex-direction:column;gap:6px;justify-content:center;min-width:0;padding:6px 8px;position:relative}.canvas-wrapper:before{background:radial-gradient(ellipse at 50% 30%,#60a5fa0a 0,#0000 70%);content:"";inset:0;pointer-events:none;position:absolute}.draw-canvas{aspect-ratio:8/5;background:#fff;border-radius:12px;box-shadow:0 0 0 1px #ffffff0f,0 4px 20px #0009,0 0 80px #60a5fa0f;max-height:380px;max-width:100%;touch-action:none;transition:box-shadow .3s ease;width:100%}.draw-canvas.can-draw{box-shadow:0 0 0 2px #f7c94859,0 4px 20px #0009,0 0 40px #f7c94814;cursor:crosshair}.toolbar{align-items:center;display:flex;flex-direction:column;gap:5px;max-width:600px;width:100%}.toolbar-main{align-items:center;gap:6px;padding:7px 12px}.colors-panel,.toolbar-main{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#1a1a2ef2;border:1px solid #ffffff12;border-radius:14px;box-shadow:0 4px 16px #0006;display:flex;justify-content:center;width:100%}.colors-panel{animation:panelIn .15s ease;flex-wrap:wrap;gap:5px;padding:8px 12px}@keyframes panelIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.color-toggle-btn{align-items:center;border-radius:50%!important;display:flex;flex-shrink:0;font-size:.85rem!important;height:30px!important;justify-content:center;padding:0!important;transition:transform .15s,box-shadow .15s;width:30px!important}.color-toggle-btn:hover{transform:scale(1.15)}.colors{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}.color-btn{border:2.5px solid #0000;border-radius:50%;box-shadow:0 2px 6px #0000004d;cursor:pointer;height:26px;transition:transform .12s,border-color .12s,box-shadow .12s;width:26px}.color-btn.active,.color-btn:hover{border-color:#fff;box-shadow:0 0 0 3px #ffffff26,0 2px 8px #0006;transform:scale(1.3)}.toolbar-divider{background:#ffffff1a;flex-shrink:0;height:28px;width:1px}.tools{display:flex;gap:6px}.tool-btn{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;color:#f0f0f8;color:var(--text);cursor:pointer;font-size:1rem;padding:6px 11px;transition:background .15s,border-color .15s,transform .1s}.tool-btn:hover{background:#ffffff1a;transform:translateY(-1px)}.tool-btn.active{background:#f7c948;background:var(--accent);border-color:#f7c948;border-color:var(--accent);box-shadow:0 0 12px #f7c94859;color:#111}.brush-sizes{gap:6px}.brush-sizes,.size-btn{align-items:center;display:flex}.size-btn{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;cursor:pointer;height:36px;justify-content:center;padding:5px 8px;transition:background .15s,transform .1s;width:36px}.size-btn:hover{background:#ffffff1a;transform:translateY(-1px)}.size-btn.active{background:#f7c948;background:var(--accent);border-color:#f7c948;border-color:var(--accent);box-shadow:0 0 12px #f7c9484d}.chat-panel{background:#1a1a2e;background:var(--surface);border-left:1px solid #ffffff14;border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;min-width:220px;width:220px}.messages{display:flex;flex:1 1;flex-direction:column;gap:6px;overflow-y:auto;padding:12px}.msg{background:#0f0f1a;background:var(--bg);border-radius:8px;font-size:.8rem;line-height:1.4;padding:6px 8px;word-break:break-word}.msg.correct{background:#4ade801a;border:1px solid #4ade804d}.pts{color:#4ade80;color:var(--green);font-weight:800}.msg.divider{background:#0000;padding:4px 0;text-align:center}.divider-text{color:#88a;color:var(--muted);font-size:.7rem;letter-spacing:1px}.close{color:#f97316}.chat-input{align-self:center;border-radius:8px;border-top:1px solid #ffffff14;border-top:1px solid var(--border);display:flex;gap:0;margin:0 auto;overflow:hidden;width:75%}.chat-input input{background:#0000;border:none;color:#f0f0f8;color:var(--text);flex:1 1;font-family:Nunito,sans-serif;font-size:.85rem;outline:none;padding:12px}.chat-input input:disabled{opacity:.4}.chat-input button{background:#f7c948;background:var(--accent);border:none;color:#111;cursor:pointer;font-size:1rem;font-weight:800;padding:0 16px;transition:opacity .15s}.chat-input button:disabled{cursor:default;opacity:.3}.gameover-screen{align-items:center;background:radial-gradient(ellipse at center,#1e1040 0,#0f0f1a 70%);display:flex;flex-direction:column;gap:24px;justify-content:center;min-height:100vh}.gameover-screen h1{color:#f7c948;color:var(--accent);font-family:Fredoka One,cursive;font-size:2.5rem}.final-scores{background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:20px;display:flex;flex-direction:column;gap:10px;max-width:95vw;min-width:320px;padding:24px 32px;width:100%}.score-row{align-items:center;background:#0f0f1a;background:var(--bg);border-radius:10px;display:flex;gap:14px;padding:10px 12px}.score-row.rank-1{background:#f7c9481a;border:1px solid #f7c9484d}.score-row.rank-2{background:#c0c0c014}.score-row.rank-3{background:#cd7f3214}.rank{font-size:1.3rem;width:30px}.pname{flex:1 1;font-weight:700}.pscore{color:#f7c948;color:var(--accent);font-family:Fredoka One,cursive;font-size:1.1rem}.notification{animation:slideDown .3s ease;border-radius:12px;box-shadow:0 8px 30px #0006;font-weight:700;left:50%;max-width:90vw;padding:12px 24px;position:fixed;text-align:center;top:70px;transform:translateX(-50%);word-break:break-word;z-index:100}.notification.info{background:#16213e;background:var(--surface2);border:1px solid #60a5fa;border:1px solid var(--blue);color:#60a5fa;color:var(--blue)}.notification.success{background:#4ade8026;border:1px solid #4ade80;border:1px solid var(--green);color:#4ade80;color:var(--green)}.notification.reveal{background:#f7c94826;border:1px solid #f7c948;border:1px solid var(--accent);color:#f7c948;color:var(--accent)}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.connecting{background:#f7c948;background:var(--accent);color:#111;font-size:.9rem;font-weight:700;left:0;padding:10px;position:fixed;right:0;text-align:center;top:0;z-index:200}@media (max-width:768px){body,html{height:auto;overflow-x:hidden;overflow-y:auto}.game-screen{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.game-header{flex-shrink:0;gap:6px;padding:5px 10px}.round-info{font-size:.75rem}.word-display{font-size:.85rem}.blanks{font-size:.95rem;letter-spacing:4px}.timer{font-size:.85rem;min-width:44px}.game-main{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.scoreboard{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);border-right:none;display:flex;flex-direction:row;flex-shrink:0;gap:5px;height:auto;min-width:0;min-width:auto;overflow-x:auto;overflow-y:hidden;padding:3px 8px;width:100%}.scoreboard h3{display:none}.player-score{flex-shrink:0;gap:5px;margin-bottom:0;min-width:90px;padding:4px 7px}.p-avatar{height:22px;width:22px}.p-avatar,.p-name{font-size:.65rem}.drawer-tag{font-size:.55rem}.p-score{font-size:.75rem}.canvas-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:0;justify-content:center;min-height:0;overflow:hidden;padding:0 6px}.draw-canvas{aspect-ratio:16/9;border-radius:8px;height:auto;max-height:55%;width:100%}.toolbar{flex-shrink:0;gap:4px;width:100%}.toolbar-main{border-radius:10px;flex-wrap:nowrap;gap:4px;overflow-x:auto;padding:5px 8px}.colors-panel{border-radius:10px;gap:3px;padding:6px 8px}.color-btn{border-width:2px;height:20px;width:20px}.tool-btn{border-radius:8px;font-size:.85rem;padding:4px 8px}.brush-sizes{gap:4px}.size-btn{border-radius:8px;height:28px;width:28px}.chat-panel{border-left:none;border-top:1px solid #ffffff14;border-top:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;height:120px;min-width:0;min-width:auto;width:100%}.messages{flex:1 1;gap:3px;overflow-y:auto;padding:4px 8px}.msg{font-size:.7rem;padding:3px 6px}.chat-input input{font-size:.8rem;padding:8px 10px}.chat-input button{font-size:.9rem;padding:0 14px}.lobby-card{gap:14px;padding:28px 20px}.logo{font-size:1.9rem}.waiting-card{padding:24px 18px}.gameover-screen h1{font-size:1.7rem}.final-scores{min-width:0;min-width:auto;padding:14px 18px}}.auth-screen{align-items:center;background:radial-gradient(ellipse at 30% 20%,#1e1040 0,#0f0f1a 60%),radial-gradient(ellipse at 80% 80%,#0d2040 0,#0000 60%);display:flex;justify-content:center;min-height:100vh}.auth-card{background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:24px;box-shadow:0 24px 80px #00000080;display:flex;flex-direction:column;gap:20px;max-width:95vw;padding:48px 40px;width:420px}.auth-tabs{background:#0f0f1a;background:var(--bg);border-radius:12px;display:flex;gap:4px;padding:4px}.auth-tabs button{background:#0000;border:none;border-radius:9px;color:#88a;color:var(--muted);cursor:pointer;flex:1 1;font-family:Nunito,sans-serif;font-size:.9rem;font-weight:800;letter-spacing:.5px;padding:10px;transition:background .2s,color .2s}.auth-tabs button.active{background:#16213e;background:var(--surface2);color:#f7c948;color:var(--accent)}.auth-tabs button:hover:not(.active){color:#f0f0f8;color:var(--text)}.dashboard-screen{background:#0f0f1a;background:var(--bg);display:flex;flex-direction:column;min-height:100vh}.dashboard-header{align-items:center;background:#1a1a2e;background:var(--surface);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:14px 28px}.logo-small{color:#f7c948;color:var(--accent);font-family:Fredoka One,cursive;font-size:1.4rem}.logo-small span{color:#f0f0f8;color:var(--text)}.dashboard-stats{display:flex;flex-wrap:wrap;gap:10px}.stat-pill{background:#0f0f1a;background:var(--bg);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:20px;color:#88a;color:var(--muted);font-size:.8rem;font-weight:700;padding:5px 14px}.user-info{gap:10px;margin-left:auto}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#a78bfa,#60a5fa);background:linear-gradient(135deg,var(--purple),var(--blue));border-radius:50%;flex-shrink:0;font-size:.9rem;font-weight:800;height:34px;justify-content:center;width:34px}.user-name{font-size:.95rem;font-weight:700}.btn-logout{background:#0000;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:8px;color:#88a;color:var(--muted);cursor:pointer;font-family:Nunito,sans-serif;font-size:.8rem;font-weight:700;padding:6px 12px;transition:border-color .2s,color .2s}.btn-logout:hover{border-color:#ff6b6b;border-color:var(--accent2);color:#ff6b6b;color:var(--accent2)}.dashboard-body{display:flex;flex:1 1;flex-direction:column;gap:28px;margin:0 auto;max-width:1100px;padding:32px 24px;width:100%}.error-banner{background:#ff6b6b1f;border:1px solid #ff6b6b;border:1px solid var(--accent2);border-radius:10px;color:#ff6b6b;color:var(--accent2);font-size:.9rem;font-weight:700;padding:12px 16px}.dashboard-actions{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.btn-create,.btn-join-code{align-items:center;background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:18px;color:#f0f0f8;color:var(--text);cursor:pointer;display:flex;font-family:Nunito,sans-serif;gap:16px;padding:20px 24px;text-align:left;transition:transform .15s,border-color .2s,box-shadow .2s}.btn-create:hover{border-color:#f7c948;border-color:var(--accent);box-shadow:0 8px 30px #f7c94826;transform:translateY(-2px)}.btn-join-code:hover{border-color:#60a5fa;border-color:var(--blue);box-shadow:0 8px 30px #60a5fa26;transform:translateY(-2px)}.btn-icon{flex-shrink:0;font-size:2rem}.btn-create span:last-child,.btn-join-code span:last-child{display:flex;flex-direction:column;gap:2px}.btn-create strong,.btn-join-code strong{font-size:1rem;font-weight:800;letter-spacing:.3px}.btn-create small,.btn-join-code small{color:#88a;color:var(--muted);font-size:.78rem;font-weight:600}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:300}.modal-card{animation:modalIn .2s ease;background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:22px;box-shadow:0 32px 80px #0009;display:flex;flex-direction:column;gap:18px;max-width:100%;padding:36px 32px;position:relative;width:460px}@keyframes modalIn{0%{opacity:0;transform:scale(.94) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-card h2{color:#f0f0f8;color:var(--text);font-family:Fredoka One,cursive;font-size:1.5rem}.modal-close{align-items:center;background:#0000;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:50%;color:#88a;color:var(--muted);cursor:pointer;display:flex;font-size:.85rem;height:30px;justify-content:center;position:absolute;right:16px;top:16px;transition:background .15s,color .15s;width:30px}.modal-close:hover{background:#0f0f1a;background:var(--bg);color:#f0f0f8;color:var(--text)}.form-row{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.form-group select{background:#0f0f1a;background:var(--bg);border:1.5px solid #ffffff14;border:1.5px solid var(--border);border-radius:14px;border-radius:var(--radius);color:#f0f0f8;color:var(--text);cursor:pointer;font-family:Nunito,sans-serif;font-size:1rem;font-weight:700;outline:none;padding:12px 16px;transition:border-color .2s;width:100%}.form-group select:focus{border-color:#f7c948;border-color:var(--accent)}.label-hint{color:#88a;color:var(--muted);font-size:.65rem;font-weight:600;letter-spacing:0;text-transform:none}.password-preview{background:#f7c94814;border:1px solid #f7c94840;border-radius:8px;color:#f7c948;color:var(--accent);font-weight:700}.password-auto,.password-preview{font-size:.78rem;padding:6px 12px}.password-auto{background:#ffffff08;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:8px;color:#88a;color:var(--muted);font-weight:600}.toggle-row{align-items:center;background:#0f0f1a;background:var(--bg);border-radius:14px;border-radius:var(--radius);display:flex;gap:12px;justify-content:space-between;padding:12px 16px}.toggle-label{color:#f0f0f8;color:var(--text);font-size:.85rem;font-weight:800}.toggle-hint{font-size:.75rem;margin-top:2px}.toggle-btn,.toggle-hint{color:#88a;color:var(--muted)}.toggle-btn{background:#16213e;background:var(--surface2);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:20px;cursor:pointer;flex-shrink:0;font-family:Nunito,sans-serif;font-size:.85rem;font-weight:800;padding:7px 16px;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}.toggle-btn.on{background:#f7c9481f;border-color:#f7c948;border-color:var(--accent);color:#f7c948;color:var(--accent)}.rooms-section{display:flex;flex-direction:column;gap:16px}.rooms-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.rooms-header h2{color:#f0f0f8;color:var(--text);font-family:Fredoka One,cursive;font-size:1.3rem}.rooms-header-right{align-items:center;display:flex;gap:12px}.last-refresh{font-size:.72rem}.btn-refresh,.last-refresh{color:#88a;color:var(--muted)}.btn-refresh{background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:8px;cursor:pointer;font-family:Nunito,sans-serif;font-size:.82rem;font-weight:700;padding:7px 14px;transition:border-color .2s,color .2s}.btn-refresh:hover{border-color:#60a5fa;border-color:var(--blue);color:#60a5fa;color:var(--blue)}.rooms-placeholder{align-items:center;background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:18px;color:#88a;color:var(--muted);display:flex;flex-direction:column;font-size:.95rem;gap:8px;padding:60px 24px;text-align:center}.rooms-placeholder .hint{font-size:.82rem}.rooms-spinner{animation:spin 1.5s linear infinite;font-size:2rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.rooms-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.room-card{background:#1a1a2e;background:var(--surface);border:1px solid #ffffff14;border:1px solid var(--border);border-radius:16px;display:flex;flex-direction:column;gap:10px;padding:16px;transition:border-color .2s,transform .15s}.room-card:hover{border-color:#ffffff2e;transform:translateY(-1px)}.room-card.room-busy{opacity:.6}.room-card-top{align-items:center;display:flex;gap:8px;justify-content:space-between}.room-code-badge{color:#f7c948;color:var(--accent);font-family:Fredoka One,cursive;font-size:1.05rem;letter-spacing:1px}.room-status-badge{border-radius:20px;font-size:.7rem;font-weight:800;letter-spacing:.3px;padding:3px 10px}.room-status-badge.status-lobby{background:#60a5fa1f;border:1px solid #60a5fa4d;color:#60a5fa;color:var(--blue)}.room-status-badge.status-playing{background:#4ade801f;border:1px solid #4ade804d;color:#4ade80;color:var(--green)}.room-status-badge.status-gameOver,.room-status-badge.status-roundEnd{background:#a78bfa1f;border:1px solid #a78bfa4d;color:#a78bfa;color:var(--purple)}.room-card-mid{align-items:center;color:#88a;color:var(--muted);display:flex;font-size:.8rem;justify-content:space-between}.room-host-label{color:#f0f0f8;color:var(--text);font-weight:700;max-width:55%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-players-count{font-size:.82rem;font-weight:700}.room-players-bar{background:#0f0f1a;background:var(--bg);border-radius:4px;height:4px;overflow:hidden}.room-players-fill{background:linear-gradient(90deg,#60a5fa,#a78bfa);background:linear-gradient(90deg,var(--blue),var(--purple));border-radius:4px;height:100%;transition:width .5s ease}.room-card-bot{align-items:center;display:flex;gap:8px;justify-content:space-between}.room-meta-info{color:#88a;color:var(--muted);font-size:.75rem}.btn-join-small{background:#f7c948;background:var(--accent);border:none;border-radius:8px;color:#111;cursor:pointer;font-family:Nunito,sans-serif;font-size:.8rem;font-weight:800;padding:5px 14px;transition:opacity .15s,transform .1s;white-space:nowrap}.btn-join-small:hover{opacity:.9;transform:translateY(-1px)}.room-locked-label{color:#88a;color:var(--muted);font-size:.72rem}.btn-leave{align-self:flex-start;background:#0000;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:8px;color:#88a;color:var(--muted);cursor:pointer;font-family:Nunito,sans-serif;font-size:.82rem;font-weight:700;padding:6px 14px;transition:border-color .2s,color .2s}.btn-leave:hover{border-color:#ff6b6b;border-color:var(--accent2);color:#ff6b6b;color:var(--accent2)}.btn-secondary{background:#0000;border:1px solid #ffffff14;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);color:#88a;color:var(--muted);cursor:pointer;font-family:Fredoka One,cursive;font-size:1rem;padding:14px 24px;transition:border-color .2s,color .2s}.btn-secondary:hover{border-color:#60a5fa;border-color:var(--blue);color:#60a5fa;color:var(--blue)}.gameover-btns{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.host-badge{background:#a78bfa26;border:1px solid #a78bfa66;border-radius:6px;color:#a78bfa;color:var(--purple);font-size:.7rem;font-weight:800;margin-left:auto;padding:2px 8px}@media (max-width:600px){.dashboard-header{gap:10px;padding:12px 16px}.user-name{display:none}.dashboard-body{gap:20px;padding:20px 14px}.dashboard-actions{gap:10px;grid-template-columns:1fr 1fr}.btn-create,.btn-join-code{gap:10px;padding:14px 12px}.btn-icon{font-size:1.5rem}.btn-create strong,.btn-join-code strong{font-size:.85rem}.btn-create small,.btn-join-code small{display:none}.rooms-grid{grid-template-columns:1fr}.auth-card{gap:16px;padding:32px 20px}.modal-card{padding:28px 20px}.form-row{gap:12px;grid-template-columns:1fr}}
/*# sourceMappingURL=main.a5026ee4.css.map*/