*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:#0d0b14;color:#ede9fe;font-family:Nunito,ui-sans-serif,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.webgl-ambient{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;opacity:.9}.webgl-ambient.game{opacity:.62}.correct-burst{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:6;mix-blend-mode:screen}button,input,textarea,select{font:inherit;color:inherit}button{border:1px solid rgba(255,255,255,.1);background:#1a1733;color:#ede9fe;cursor:pointer;border-radius:8px;padding:8px 14px;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,opacity .15s}button:hover:not(:disabled){background:#211e3d;border-color:#ffffff2b}button:active:not(:disabled){opacity:.85}button:disabled{cursor:not-allowed;opacity:.35}input,textarea{width:100%;border:1px solid rgba(255,255,255,.1);background:#1a1733;color:#ede9fe;padding:10px 12px;border-radius:8px;outline:none;transition:border-color .15s,box-shadow .15s}input::placeholder,textarea::placeholder{color:#5e5280}input:focus,textarea:focus{border-color:#a78bfa;box-shadow:0 0 0 3px #7c3aed52}.entry-shell{position:relative;isolation:isolate;min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:20px;overflow:hidden;background:radial-gradient(ellipse 60% 50% at 15% 55%,rgba(124,58,237,.18) 0%,transparent 70%),radial-gradient(ellipse 50% 40% at 85% 20%,rgba(96,165,250,.12) 0%,transparent 65%),#0d0b14}.brand-panel,.join-panel{position:relative;z-index:1;width:min(420px,100%);background:#13102a;border:1px solid rgba(255,255,255,.17);border-radius:24px;padding:36px;box-shadow:0 0 0 1px #ffffff08,0 24px 64px #0000008c}.brand-panel h1,.join-panel h1{margin:6px 0 10px;font-size:44px;font-weight:900;line-height:1;background:linear-gradient(130deg,#a78bfa 20%,#60a5fa 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-panel p,.join-panel p{margin:0 0 28px;color:#9d8ec4;font-size:16px}.brand-panel label,.join-panel label{display:grid;gap:6px;margin:18px 0;font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#9d8ec4}.brand-panel label input,.brand-panel label textarea,.join-panel label input,.join-panel label textarea{text-transform:none;letter-spacing:normal;font-size:15px;font-weight:700}.brand-mark{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:#a78bfa;background:#7c3aed24;border:1px solid rgba(167,139,250,.28);border-radius:100px;padding:5px 14px;margin-bottom:20px}.room-label{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:800;color:#9d8ec4;background:#1a1733;border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:5px 14px;margin-bottom:12px}.primary-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:13px 20px;background:#7c3aed;border:1px solid rgba(255,255,255,.12);border-radius:12px;color:#fff;font-weight:900;font-size:15px;transition:background .15s,box-shadow .15s}.primary-action:hover:not(:disabled){background:#8b4cf6;box-shadow:0 6px 24px #7c3aed52;border-color:#ffffff1f}.primary-action:active:not(:disabled){background:#6315e9;box-shadow:none}.secondary-action{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px 16px;font-weight:700;margin-bottom:10px}.swatches{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.swatches button{min-height:38px;background:var(--swatch);border:2px solid transparent;border-radius:8px;padding:0}.swatches button:hover:not(:disabled){transform:scale(1.08);background:var(--swatch)}.swatches button.active{border-color:#fff;box-shadow:0 0 0 2px #a78bfa;transform:scale(1.08)}.avatar{display:inline-grid;place-items:center;border-radius:50%;background:var(--avatar);font-weight:900;flex-shrink:0;width:32px;height:32px;font-size:22px;line-height:1;overflow:hidden;border:1.5px solid rgba(255,255,255,.2)}.avatar.large{width:84px;height:84px;font-size:58px;margin:16px auto 0;display:flex;border-width:2px}.game-shell{position:relative;isolation:isolate;height:100vh;height:100dvh;display:grid;grid-template-rows:auto 1fr;overflow:hidden;background:#0d0b14}.game-shell>:not(.webgl-ambient):not(.correct-burst){position:relative;z-index:1}.top-bar{display:grid;grid-template-columns:200px 1fr auto;align-items:center;gap:12px;padding:8px 16px;background:#13102a;border-bottom:1px solid rgba(255,255,255,.06);z-index:20}.top-bar .top-brand{display:flex;align-items:center;gap:8px;min-width:0}.top-bar .top-brand strong{font-size:18px;font-weight:900;background:linear-gradient(130deg,#a78bfa,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.top-bar .top-brand span{font-size:11px;font-weight:700;color:#5e5280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.top-center{display:flex;align-items:center;justify-content:center;gap:10px;min-width:0}.top-right{display:flex;align-items:center;gap:8px;justify-content:flex-end}.state-badge{padding:3px 10px;border-radius:100px;font-size:10px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.state-badge.LOBBY{background:#94a3b81f;color:#94a3b8}.state-badge.SELECTING{background:#fbbf2424;color:#fbbf24}.state-badge.DRAWING{background:#34d39921;color:#34d399}.state-badge.REVEAL{background:#7c3aed24;color:#a78bfa}.timer-ring{position:relative;width:44px;height:44px;flex-shrink:0}.timer-ring svg{transform:rotate(-90deg);overflow:visible}.timer-ring .timer-track{fill:none;stroke:#ffffff2b;stroke-width:3.5}.timer-ring .timer-arc{fill:none;stroke:#a78bfa;stroke-width:3.5;stroke-linecap:round;transition:stroke-dashoffset 1s linear,stroke .4s}.timer-ring .timer-arc.urgent{stroke:#f87171}.timer-ring .timer-num{position:absolute;inset:0;display:grid;place-items:center;font-size:13px;font-weight:900;color:#ede9fe}.word-display{display:flex;align-items:flex-end;gap:3px;padding:6px 16px;background:#1a1733;border:1px solid rgba(255,255,255,.1);border-radius:100px;max-width:380px;overflow:hidden}.word-display .wl{display:inline-block;min-width:14px;text-align:center;font-size:17px;font-weight:900;line-height:1;padding-bottom:2px;border-bottom:2px solid #9D8EC4}.word-display .wl.blank{color:transparent;border-color:#5e5280}.word-display .wl.gap{min-width:14px;border-bottom:none}.word-display.waiting{color:#5e5280;font-size:14px;font-weight:700;letter-spacing:.04em;border-style:dashed}.notice-toast{position:fixed;top:68px;left:50%;transform:translate(-50%);z-index:200;background:#fbbf2424;border:1px solid rgba(251,191,36,.35);border-radius:100px;padding:8px 20px;font-size:13px;font-weight:800;color:#fbbf24;white-space:nowrap;pointer-events:none;animation:toastIn .2s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-6px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.conn-pill{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:#5e5280;padding:5px 12px;border:1px solid rgba(255,255,255,.1);border-radius:100px;background:#1a1733;white-space:nowrap}.conn-pill:before{content:"";width:7px;height:7px;border-radius:50%;flex-shrink:0;background:#5e5280}.conn-pill.live{color:#34d399;border-color:#34d39940;background:#34d39921}.conn-pill.live:before{background:#34d399;box-shadow:0 0 6px #34d399}.conn-pill.offline{color:#f87171;border-color:#f8717140;background:#f8717121}.conn-pill.offline:before{background:#f87171}.play-grid{min-height:0;display:grid;grid-template-columns:240px minmax(0,1fr) 300px;overflow:hidden}.side-rail{display:flex;flex-direction:column;background:#13102a;border-right:1px solid rgba(255,255,255,.06);overflow:hidden}.scoreboard{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.17) transparent}.scoreboard h2{position:sticky;top:0;margin:0;padding:10px 14px;font-size:11px;font-weight:900;letter-spacing:.1em;text-transform:uppercase;color:#5e5280;background:#13102a;border-bottom:1px solid rgba(255,255,255,.06);z-index:1}.player-row{display:grid;grid-template-columns:32px minmax(0,1fr) auto 18px;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid rgba(255,255,255,.06);transition:background .1s}.player-row:hover{background:#1a1733}.player-row .player-info{min-width:0}.player-row .player-info strong{display:block;font-size:13px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-row .player-info .player-status{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#5e5280}.player-row .player-info .player-status.drawing{color:#34d399}.player-row .player-info .player-status.guessed{color:#a78bfa}.player-row .player-score{font-size:14px;font-weight:900;color:#a78bfa}.player-row .crown{color:#fbbf24;flex-shrink:0}.rail-actions{padding:10px 12px;display:grid;gap:6px;border-top:1px solid rgba(255,255,255,.06)}.rail-button{display:inline-flex;align-items:center;justify-content:center;gap:7px;font-weight:800;font-size:13px;padding:9px 12px;border-radius:8px;width:100%}.rail-button.primary{background:#7c3aed;border-color:#ffffff1f;color:#fff}.rail-button.primary:hover:not(:disabled){background:#8b4cf6;box-shadow:0 4px 18px #7c3aed52;border-color:#ffffff1f}.canvas-zone{min-width:0;min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;background:#0d0b14}.canvas-wrapper{display:flex;align-items:center;justify-content:center;overflow:hidden;padding:14px}.drawing-canvas{width:min(100% - 28px,(100dvh - 61px - 57px - 28px) * 4 / 3);max-height:calc(100dvh - 146px);aspect-ratio:4/3;background:#fff;border-radius:12px;box-shadow:0 0 0 1px #ffffff14,0 20px 60px #0000008c;touch-action:none;cursor:not-allowed;display:block;transition:box-shadow .2s}.drawing-canvas.active{cursor:crosshair;box-shadow:0 0 0 2px #a78bfa,0 20px 60px #0000008c}.tool-bar{display:flex;align-items:center;gap:6px;padding:9px 12px;background:#13102a;border-top:1px solid rgba(255,255,255,.06);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tool-bar::-webkit-scrollbar{display:none}.tool-bar .tool-sep{width:1px;height:26px;background:#ffffff2b;flex-shrink:0;margin:0 2px}.tool-btn{width:40px;min-width:40px;height:40px;display:grid;place-items:center;border-radius:8px;padding:0;flex-shrink:0;color:#9d8ec4}.tool-btn:hover:not(:disabled){color:#ede9fe;background:#211e3d}.tool-btn.active{background:#7c3aed24;border-color:#a78bfa66;color:#a78bfa}.color-strip{display:flex;gap:5px}.color-strip button{width:26px;min-width:26px;height:26px;padding:0;border-radius:50%;background:var(--swatch);border:2px solid rgba(255,255,255,.12);flex-shrink:0;transition:transform .12s,box-shadow .12s}.color-strip button:hover:not(:disabled){transform:scale(1.18)}.color-strip button.active{border-color:#fff;box-shadow:0 0 0 2px #a78bfa;transform:scale(1.12)}.size-strip{display:flex;align-items:center;gap:4px}.size-strip button{width:36px;min-width:36px;height:36px;padding:0;border-radius:8px;display:grid;place-items:center;flex-shrink:0}.size-strip button span{display:block;border-radius:50%;background:#ede9fe;pointer-events:none}.size-strip button.active{background:#7c3aed24;border-color:#a78bfa66}.chat-panel{display:flex;flex-direction:column;background:#13102a;border-left:1px solid rgba(255,255,255,.06);min-height:0}.activity-log{flex:1;min-height:0;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.17) transparent}.activity-log p{margin:0;padding:6px 10px;border-radius:8px;font-size:13px;overflow-wrap:anywhere;line-height:1.4}.activity-log p strong{font-weight:800}.activity-log p.system{background:#60a5fa21;color:#60a5fa;font-weight:700}.activity-log p.guess{background:#1a1733;color:#ede9fe}.activity-log p.correct{background:#34d39921;color:#34d399;font-weight:800}.chat-empty{flex:1;display:grid;place-items:center;color:#5e5280;font-size:13px;font-weight:700;text-align:center;padding:20px}.guess-form{display:grid;grid-template-columns:minmax(0,1fr) 46px;gap:6px;padding:10px;border-top:1px solid rgba(255,255,255,.06)}.guess-form input{height:46px}.guess-form button{width:46px;height:46px;display:grid;place-items:center;padding:0;border-radius:8px;background:#7c3aed;border-color:transparent;color:#fff}.guess-form button:hover:not(:disabled){background:#8b4cf6;box-shadow:0 4px 14px #7c3aed52}.guess-form button:disabled{background:#1a1733;color:#5e5280;opacity:.6}.modal-backdrop{position:fixed;inset:0;display:grid;place-items:center;padding:20px;background:#000000b8;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:100;animation:bd-in .18s ease}@keyframes bd-in{0%{opacity:0}to{opacity:1}}.word-dialog,.settings-dialog{width:min(480px,100%);background:#13102a;border:1px solid rgba(255,255,255,.17);border-radius:24px;padding:28px;box-shadow:0 32px 72px #000000a6;animation:modal-in .22s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.word-dialog h2,.settings-dialog h2{margin:0 0 20px;font-size:22px;font-weight:900}.choice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.choice-grid button{min-height:84px;font-size:17px;font-weight:900;border-radius:12px;background:#1a1733;border:1px solid rgba(255,255,255,.17);transition:background .15s,border-color .15s,transform .12s,box-shadow .15s,color .15s}.choice-grid button:hover:not(:disabled){background:#7c3aed24;border-color:#a78bfa73;color:#a78bfa;transform:translateY(-3px);box-shadow:0 10px 28px #7c3aed52}.choice-grid button:active:not(:disabled){transform:translateY(-1px)}.settings-dialog{display:grid;gap:16px;max-height:calc(100dvh - 48px);overflow-y:auto}.settings-dialog label{display:grid;gap:6px;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#9d8ec4}.settings-dialog label input,.settings-dialog label textarea{text-transform:none;letter-spacing:normal;font-size:15px;font-weight:700}.settings-dialog textarea{min-height:92px;resize:vertical}.check-row{display:flex!important;flex-direction:row!important;align-items:center;gap:10px}.check-row input[type=checkbox]{width:18px;height:18px;min-width:18px;flex-shrink:0;cursor:pointer;accent-color:#7C3AED}.dialog-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:4px}.dialog-actions .primary-action{width:auto;padding:10px 20px}.loading-screen{position:relative;isolation:isolate;height:100vh;height:100dvh;display:grid;place-items:center;overflow:hidden;background:#0d0b14}.loading-screen .loading-inner{position:relative;z-index:1;text-align:center}.loading-screen .loading-inner .spinner{width:44px;height:44px;border:3px solid rgba(255,255,255,.17);border-top-color:#a78bfa;border-radius:50%;animation:spin .75s linear infinite;margin:0 auto 16px}.loading-screen .loading-inner p{color:#9d8ec4;font-size:15px;font-weight:700;margin:0}@keyframes spin{to{transform:rotate(360deg)}}.mobile-tab-bar{display:none}.mobile-player-count{display:none;align-items:center;gap:5px;font-size:12px;font-weight:800;color:#9d8ec4}@media(max-width:1080px){.play-grid{grid-template-columns:200px minmax(0,1fr) 260px}}@media(max-width:768px){.top-bar{grid-template-columns:auto 1fr auto;padding:7px 10px;gap:8px}.top-bar .top-brand span,.state-badge{display:none}.mobile-player-count{display:flex}.play-grid{grid-template-columns:1fr;grid-template-rows:minmax(0,1fr);position:relative}.side-rail,.play-grid[data-tab=canvas] .chat-panel,.play-grid[data-tab=chat] .canvas-zone{display:none}.canvas-zone{display:flex;flex-direction:column}.canvas-wrapper{flex:1;min-height:0;padding:8px}.drawing-canvas{width:min(100% - 16px,(100dvh - 57px - 57px - 48px) * 4 / 3);max-height:calc(100dvh - 162px);border-radius:8px}.mobile-tab-bar{display:flex;background:#13102a;border-top:1px solid rgba(255,255,255,.06);flex-shrink:0}.mobile-tab-bar button{flex:1;border:none;border-radius:0;border-top:2px solid transparent;padding:11px 8px 8px;font-size:12px;font-weight:800;color:#5e5280;background:#13102a;display:flex;align-items:center;justify-content:center;gap:6px;transition:color .15s,border-color .15s,background .15s}.mobile-tab-bar button.active{color:#a78bfa;border-top-color:#a78bfa;background:#7c3aed0f}.mobile-tab-bar button:hover:not(.active){color:#9d8ec4;background:#1a1733;border-color:#ffffff2b}}@media(max-width:480px){.brand-panel,.join-panel{padding:24px 20px;border-radius:18px}.brand-panel h1,.join-panel h1{font-size:36px}.word-display{max-width:180px}.word-display .wl{font-size:14px;min-width:11px}.top-brand strong{font-size:16px}.timer-ring{width:36px;height:36px}.timer-ring .timer-num{font-size:11px}.choice-grid{grid-template-columns:1fr}}
