*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%;background:#ffdca1;overflow:hidden;overscroll-behavior:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#ffdca1;color:#111827;min-height:100vh;-webkit-font-smoothing:antialiased}button,[role=button]{user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}input,textarea,select{font-size:16px;user-select:text;-webkit-user-select:text;-webkit-touch-callout:default}.shell{display:flex;flex-direction:column;min-height:100vh;background:#ffdca1}.shell--room{min-height:100svh;background:#ffdca1;overflow:hidden}.topbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#fffffff0;border-bottom:1px solid #e5e7eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-title{font-size:18px;font-weight:700}.back-btn{background:none;border:none;cursor:pointer;font-size:14px;color:#6b7280;padding:4px 0}.back-btn:hover{color:#111827}.topbar-right{display:flex;align-items:center;gap:8px}.ws-dot{width:8px;height:8px;border-radius:50%;background:#d1d5db}.ws-dot--connecting{background:#f59e0b}.ws-dot--connected{background:#22c55e}.ws-dot--disconnected{background:#ef4444}.ws-dot--paused{background:#9ca3af}.ws-label{font-size:12px;color:#6b7280}.content{flex:1;max-width:560px;width:100%;margin:0 auto;padding:16px}.content--entry{min-height:calc(100svh - 58px - env(safe-area-inset-top));display:flex;align-items:center}.content--entry>.phase-box,.content--entry>.empty{width:100%;margin:0 auto}.content--room{position:fixed;top:0;right:0;bottom:0;left:0;z-index:70;max-width:none;min-height:100svh;padding:0;overflow:hidden}.content--room>.error-banner{position:fixed;left:12px;right:12px;top:10px;z-index:120;max-width:560px;margin:0 auto}.error-banner{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c;border-radius:6px;padding:10px 12px;margin-bottom:12px;font-size:14px;cursor:pointer}.btn-primary{background:#111827;color:#fff;border:none;border-radius:6px;padding:9px 16px;font-size:14px;min-height:40px;cursor:pointer}.btn-primary:hover:not(:disabled){background:#374151}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:none;color:#374151;border:1px solid #d1d5db;border-radius:6px;padding:9px 16px;font-size:14px;min-height:40px;cursor:pointer}.btn-ghost:hover{background:#f3f4f6}.btn-small{background:none;color:#374151;border:1px solid #d1d5db;border-radius:4px;padding:4px 10px;font-size:13px;cursor:pointer}.btn-small:hover{background:#f3f4f6}.add-row{display:flex;gap:8px;margin-bottom:16px}.add-input{flex:1;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.add-input:focus{outline:2px solid #111827}.todo-list{list-style:none;margin-bottom:16px}.list-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:6px}.list-item-name{flex:1;font-size:14px;font-weight:500}.list-item-count{font-size:12px;color:#6b7280}.presence-badge{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}.presence-badge-dot{width:7px;height:7px;border-radius:50%;display:inline-block}.presence-badge--online .presence-badge-dot{background:#22c55e}.presence-badge--offline .presence-badge-dot{background:#ef4444}.lobby-roster-main{flex:1;min-width:0;display:flex;align-items:center;gap:8px}.lobby-roster-name-stack{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.lobby-roster-extra-status{font-size:12px;color:#6b7280;line-height:1.25}.lobby-roster-action{flex:0 0 auto;white-space:nowrap}.lobby-roster-item--offline{opacity:.52}.player-card-list{display:flex;flex-direction:column;gap:6px}.player-card{align-items:flex-start;justify-content:space-between}.player-card--with-form{align-items:stretch;flex-direction:column}.player-card-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:5px}.statement-form{width:100%;margin:4px 0 0}.statement-text{display:block;color:#374151;font-size:14px;line-height:1.35;overflow-wrap:anywhere}.statement-empty{color:#9ca3af;font-size:13px;line-height:1.35}.empty{color:#6b7280;font-size:14px;text-align:center;padding:24px 0}.section-title{font-size:13px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.hint{font-size:13px;color:#6b7280;margin-top:8px}.lobby-buttons{display:flex;flex-direction:column;align-items:center;gap:14px;padding:4px 12px 88px}.btn-lobby{width:100%;padding:16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-size:15px;font-weight:500;color:#111827;cursor:pointer;text-align:left}.btn-lobby:hover{background:#f9fafb;border-color:#d1d5db}.btn-lobby--toy{--toy-accent-a: #ffb52e;--toy-accent-b: #f97316;position:relative;width:min(100%,430px);min-height:66px;padding:11px 18px 13px;border:4px solid #b07be8;border-radius:24px;background:radial-gradient(circle at 14% 22%,rgba(255,255,255,.72) 0 5px,transparent 6px),linear-gradient(90deg,rgba(255,255,255,.18),transparent 20%,rgba(255,255,255,.16) 54%,transparent),repeating-linear-gradient(0deg,rgba(174,109,38,.08) 0 2px,transparent 2px 13px),linear-gradient(180deg,#fff1c8,#ffdca1 56%,#ffc76b);box-shadow:0 6px #7c4eba,0 13px 20px #4b2c0a3d,inset 0 3px #ffffffad,inset 0 -4px #a65d1e2e;color:#5a300a;display:grid;grid-template-columns:52px minmax(0,1fr) 52px;align-items:center;gap:12px;overflow:hidden;text-align:center;transform:translateY(0);transition:transform .12s ease,box-shadow .12s ease,filter .16s ease}.btn-lobby--toy:before,.btn-lobby--toy:after{content:"";position:absolute;pointer-events:none}.btn-lobby--toy:before{top:7px;right:7px;bottom:7px;left:7px;border:2px solid rgba(255,255,255,.52);border-radius:18px}.btn-lobby--toy:after{right:18px;top:12px;width:11px;height:11px;border-radius:3px;background:#ff6fa3;box-shadow:-25px 24px #59d7e5,-96px 2px #ffd23f;transform:rotate(18deg)}.btn-lobby--toy:hover{background:radial-gradient(circle at 14% 22%,rgba(255,255,255,.75) 0 5px,transparent 6px),linear-gradient(90deg,rgba(255,255,255,.22),transparent 20%,rgba(255,255,255,.18) 54%,transparent),repeating-linear-gradient(0deg,rgba(174,109,38,.08) 0 2px,transparent 2px 13px),linear-gradient(180deg,#fff5d5,#ffe1ac 56%,#ffcb72);border-color:#a76bea;filter:saturate(1.05)}.btn-lobby--toy:active{transform:translateY(4px);box-shadow:0 2px #7c4eba,0 7px 14px #4b2c0a3d,inset 0 3px #ffffffad,inset 0 -4px #a65d1e2e}.btn-lobby--create{--toy-accent-a: #ffbf36;--toy-accent-b: #ff7a1a}.btn-lobby--join{--toy-accent-a: #63d7ff;--toy-accent-b: #2f9cef}.btn-lobby--public{--toy-accent-a: #82e85d;--toy-accent-b: #35b45b}.btn-lobby-icon{position:relative;z-index:1;width:46px;height:46px;border-radius:16px;background:radial-gradient(circle at 34% 24%,rgba(255,255,255,.72) 0 6px,transparent 8px),linear-gradient(145deg,var(--toy-accent-a),var(--toy-accent-b));box-shadow:inset -4px -5px #3e21091f,0 3px #5f2d083d;color:#fff;display:grid;place-items:center;font-size:24px;font-weight:900;line-height:1;text-shadow:0 2px 0 rgba(90,48,10,.22)}.btn-lobby-title{position:relative;z-index:1;min-width:0;color:#60360f;font-size:18px;font-weight:900;line-height:1.1;text-align:center;text-shadow:0 2px 0 rgba(255,255,255,.76)}.lobby-utility-buttons{position:fixed;left:max(16px,env(safe-area-inset-left));bottom:calc(16px + env(safe-area-inset-bottom));z-index:45;display:inline-flex;align-items:center;gap:10px}.lobby-share-button,.lobby-help-button{min-height:44px;padding:8px 13px 9px 10px;border:3px solid #b07be8;border-radius:999px;background:linear-gradient(180deg,#fff8dc,#ffd78c);color:#5a300a;box-shadow:0 5px #7c4eba,0 12px 20px #4b2c0a38,inset 0 2px #ffffffb8;display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:900;cursor:pointer}.lobby-share-button:active,.lobby-help-button:active{transform:translateY(3px);box-shadow:0 2px #7c4eba,0 7px 14px #4b2c0a38,inset 0 2px #ffffffb8}.lobby-share-icon{width:26px;height:26px;border-radius:50%;background:#ff6fa3;color:#fff;display:grid;place-items:center;font-size:15px;line-height:1}.lobby-help-icon{width:26px;height:26px;border-radius:50%;background:#59d765;color:#fff;display:grid;place-items:center;font-size:15px;font-weight:900;line-height:1}.lobby-share-toast{position:fixed;left:max(16px,env(safe-area-inset-left));bottom:calc(70px + env(safe-area-inset-bottom));z-index:46;padding:8px 10px;border:2px solid #b07be8;border-radius:999px;background:#fff8dc;color:#60360f;font-size:12px;font-weight:800;box-shadow:0 8px 18px #4b2c0a2e}.how-to-play-panel{min-height:0;display:flex;flex-direction:column;gap:12px}.how-to-play-frame{min-height:0;display:grid;place-items:center}.how-to-play-image{display:block;width:min(100%,520px);max-height:calc(100svh - 150px);object-fit:contain;border:4px solid rgba(176,123,232,.46);border-radius:22px;background:#fff8dc;box-shadow:0 6px #7c4eba8c,0 14px 28px #4b2c0a38}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:none}.modal-overlay--closing{animation:none}.modal{background:#fff;border-radius:10px;padding:24px;width:100%;max-width:400px;max-height:calc(100svh - 32px);overflow:auto;display:flex;flex-direction:column;gap:16px;position:relative}.modal-overlay--closing .modal{opacity:1}.modal-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;font-size:16px;color:#6b7280;line-height:1}.modal-close:hover{color:#111827}.modal-qr{align-self:center;width:min(248px,100%);aspect-ratio:1;padding:10px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#6b7280;display:grid;place-items:center;text-align:center;font-size:13px}.modal-qr img{display:block;width:100%;height:100%;image-rendering:pixelated}.modal-field{display:flex;flex-direction:column;gap:8px}.modal-label{font-size:14px;font-weight:500;color:#374151}.modal-check{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.modal-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:6px;padding:9px 10px;font-size:13px;line-height:1.35}.avatar-picker{display:flex;flex-direction:column;gap:8px;min-height:0}.avatar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(74px,1fr));gap:8px;max-height:min(360px,42svh);overflow-y:auto;overscroll-behavior:contain;padding:2px 2px 4px;-webkit-overflow-scrolling:touch}.avatar-option{position:relative;min-height:76px;padding:8px 5px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;color:#111827;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;cursor:pointer;overflow:visible}.avatar-option:hover:not(:disabled){border-color:#111827;background:#f9fafb}.avatar-option--selected{border-color:#111827;box-shadow:inset 0 0 0 1px #111827}.avatar-option:disabled{opacity:.36;cursor:not-allowed}.avatar-option-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:4px;transform:translateY(-20px)}.avatar-option-emoji{font-size:84px;line-height:.88}.avatar-option-name{max-width:100%;font-size:10px;line-height:1.05;text-align:center;overflow-wrap:anywhere}.game-stage{--room-top-space: calc(112px + env(safe-area-inset-top)) ;--room-bottom-space: calc(66px + env(safe-area-inset-bottom)) ;position:fixed;top:0;right:0;bottom:0;left:0;overflow:hidden;background:#ffdca1;perspective:1200px}.game-stage--no-footer{--room-bottom-space: 0px}.game-stage--room{background:transparent}.game-stage-scene{position:absolute;top:0;right:0;bottom:0;left:0;transform-style:preserve-3d;transition:transform .42s cubic-bezier(.2,.8,.2,1)}.game-layer{position:absolute;top:0;right:0;bottom:0;left:0;min-width:0;min-height:0;transform-style:preserve-3d;transition:transform .42s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease,opacity .22s ease}.game-layer--hidden{opacity:0;visibility:hidden;pointer-events:none}.game-layer--background{z-index:0;pointer-events:none}.game-background-image{display:block;width:100%;height:100%;object-fit:cover;object-position:center center}.game-layer--atmosphere{z-index:10;pointer-events:none;overflow:hidden;background:transparent}.atmosphere-scene,.atmosphere-scene>*{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.atmosphere-light-wash,.atmosphere-floor-sheen{display:none}.atmosphere-dust{background-repeat:repeat;mix-blend-mode:screen;opacity:.26;will-change:transform,opacity}.atmosphere-dust--near{background-image:radial-gradient(circle at 12px 18px,rgba(255,255,255,.55) 0 1px,transparent 2px),radial-gradient(circle at 96px 72px,rgba(255,236,180,.34) 0 1px,transparent 2px),radial-gradient(circle at 172px 126px,rgba(255,192,203,.26) 0 1px,transparent 2px);background-size:210px 180px;animation:party-dust-near 12s linear infinite}.atmosphere-dust--far{background-image:radial-gradient(circle at 44px 38px,rgba(255,255,255,.38) 0 1px,transparent 2px),radial-gradient(circle at 144px 108px,rgba(184,230,255,.24) 0 1px,transparent 2px),radial-gradient(circle at 250px 162px,rgba(255,223,150,.22) 0 1px,transparent 2px);background-size:320px 240px;opacity:.24;animation:party-dust-far 18s linear infinite}.atmosphere-scene>.atmosphere-confetti,.atmosphere-scene>.atmosphere-balloon{inset:auto}.atmosphere-scene>.atmosphere-bubble-emitter{position:absolute;inset:auto 0 26svh auto;width:min(34vw,160px);height:min(22svh,150px);overflow:visible;pointer-events:none}.atmosphere-confetti{width:6px;height:15px;border-radius:2px;opacity:.45;will-change:transform;animation:party-confetti-float 9s ease-in-out infinite}.atmosphere-confetti--one{left:18%;top:23%;background:#f472b6;animation-duration:9s}.atmosphere-confetti--two{left:74%;top:28%;background:#38bdf8;animation-duration:11s;animation-delay:-3s}.atmosphere-confetti--three{left:33%;top:61%;background:#facc15;animation-duration:10s;animation-delay:-5s}.atmosphere-confetti--four{left:62%;top:73%;background:#c084fc;animation-duration:13s;animation-delay:-7s}.atmosphere-balloon{--balloon-a: #fb7185;--balloon-b: #f472b6;--balloon-duration: 20s;--balloon-delay: 0s;--balloon-x-mid: 28px;--balloon-x-end: -18px;--balloon-start-rotate: -5deg;--balloon-mid-rotate: 6deg;--balloon-end-rotate: -8deg;bottom:-110px;width:clamp(34px,7.2vw,62px);height:clamp(44px,9vw,80px);border-radius:52% 48% 48% 52%/45% 45% 55% 55%;background:radial-gradient(circle at 34% 25%,rgba(255,255,255,.78) 0 8%,transparent 11%),linear-gradient(145deg,var(--balloon-a),var(--balloon-b));box-shadow:inset -10px -14px 18px #11182729,0 10px 18px #1118271a;opacity:0;will-change:transform,opacity;animation:party-balloon-rise var(--balloon-duration) ease-in-out infinite;animation-delay:var(--balloon-delay)}.atmosphere-balloon:before{content:"";position:absolute;left:calc(50% - 5px);bottom:-6px;width:10px;height:9px;border-radius:3px 3px 7px 7px;background:var(--balloon-b)}.atmosphere-balloon:after{content:"";position:absolute;left:50%;top:calc(100% + 2px);width:1px;height:58px;background:linear-gradient(180deg,rgba(255,255,255,.62),transparent);transform-origin:top center;animation:party-balloon-string 2.8s ease-in-out infinite}.atmosphere-balloon--one{left:7%;--balloon-a: #fb7185;--balloon-b: #f97316;--balloon-duration: 58s;--balloon-delay: -9s;--balloon-x-mid: 38px;--balloon-x-end: 5px}.atmosphere-balloon--two{left:24%;width:clamp(28px,5.8vw,50px);height:clamp(38px,7.5vw,68px);--balloon-a: #38bdf8;--balloon-b: #2563eb;--balloon-duration: 76s;--balloon-delay: -38s;--balloon-x-mid: -32px;--balloon-x-end: 18px;--balloon-start-rotate: 7deg;--balloon-mid-rotate: -5deg}.atmosphere-balloon--three{left:42%;--balloon-a: #facc15;--balloon-b: #f59e0b;--balloon-duration: 64s;--balloon-delay: -23s;--balloon-x-mid: 20px;--balloon-x-end: -30px}.atmosphere-balloon--four{left:63%;width:clamp(30px,6.4vw,56px);height:clamp(40px,8vw,72px);--balloon-a: #c084fc;--balloon-b: #a855f7;--balloon-duration: 88s;--balloon-delay: -57s;--balloon-x-mid: -42px;--balloon-x-end: -8px;--balloon-start-rotate: -8deg;--balloon-mid-rotate: 8deg}.atmosphere-balloon--five{left:81%;--balloon-a: #34d399;--balloon-b: #14b8a6;--balloon-duration: 70s;--balloon-delay: -44s;--balloon-x-mid: -26px;--balloon-x-end: 22px}.atmosphere-balloon--six{left:92%;width:clamp(26px,5.4vw,48px);height:clamp(36px,7vw,64px);--balloon-a: #f9a8d4;--balloon-b: #ec4899;--balloon-duration: 96s;--balloon-delay: -74s;--balloon-x-mid: -54px;--balloon-x-end: -26px}.atmosphere-balloon--right-corner{right:-44px;left:auto;width:clamp(42px,8.6vw,76px);height:clamp(54px,10.8vw,96px);--balloon-a: #fb7185;--balloon-b: #db2777;--balloon-duration: 92s;--balloon-delay: -31s;--balloon-x-mid: -76px;--balloon-x-end: -132px;--balloon-start-rotate: 8deg;--balloon-mid-rotate: -7deg;--balloon-end-rotate: 5deg;animation-name:party-balloon-right-corner-rise}.atmosphere-bubble{--bubble-size: clamp(24px, 5vw, 44px);--bubble-a: rgba(56, 189, 248, .3);--bubble-b: rgba(244, 114, 182, .22);--bubble-rim: rgba(255, 255, 255, .58);--bubble-duration: 64s;--bubble-delay: 0s;position:absolute;right:8px;bottom:8px;width:var(--bubble-size);height:var(--bubble-size);border:2px solid var(--bubble-rim);border-radius:50%;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.82) 0 7%,transparent 10%),radial-gradient(circle at 68% 72%,rgba(255,255,255,.3) 0 9%,transparent 14%),linear-gradient(145deg,var(--bubble-a),var(--bubble-b));box-shadow:inset 7px 7px 16px #fff3,inset -10px -12px 18px #11182714,0 0 10px #ffffff29;opacity:0;mix-blend-mode:screen;will-change:transform,opacity;animation:party-bubble-right-rise var(--bubble-duration) ease-in-out infinite;animation-delay:var(--bubble-delay)}.atmosphere-bubble--right-one{--bubble-size: clamp(30px, 6vw, 52px);--bubble-a: rgba(34, 211, 238, .32);--bubble-b: rgba(168, 85, 247, .24);--bubble-duration: 168s;--bubble-delay: -20s}.atmosphere-bubble--right-two{right:54px;bottom:22px;--bubble-size: clamp(20px, 4vw, 34px);--bubble-a: rgba(251, 191, 36, .3);--bubble-b: rgba(251, 113, 133, .22);--bubble-duration: 214s;--bubble-delay: -90s}.atmosphere-bubble--right-three{right:-24px;bottom:50px;--bubble-size: clamp(24px, 4.8vw, 42px);--bubble-a: rgba(52, 211, 153, .28);--bubble-b: rgba(56, 189, 248, .22);--bubble-duration: 248s;--bubble-delay: -156s}@keyframes party-light-breathe{0%,to{opacity:.42;transform:translateZ(0) scaleY(1)}50%{opacity:.62;transform:translate3d(0,7px,0) scaleY(1.035)}}@keyframes party-floor-sheen{0%,to{opacity:.56;transform:translateZ(0) scale(1)}50%{opacity:.78;transform:translate3d(0,-10px,0) scale(1.035)}}@keyframes party-dust-near{0%{transform:translateZ(0)}to{transform:translate3d(-42px,-64px,0)}}@keyframes party-dust-far{0%{transform:translateZ(0)}to{transform:translate3d(36px,-84px,0)}}@keyframes party-confetti-float{0%,to{transform:translateZ(0) rotate(18deg)}35%{transform:translate3d(16px,-24px,0) rotate(88deg)}70%{transform:translate3d(-12px,20px,0) rotate(156deg)}}@keyframes party-balloon-rise{0%,58%{opacity:0;transform:translate3d(0,14svh,0) rotate(var(--balloon-start-rotate))}64%{opacity:.52}82%{transform:translate3d(var(--balloon-x-mid),-38svh,0) rotate(var(--balloon-mid-rotate))}95%{opacity:.48}to{opacity:0;transform:translate3d(var(--balloon-x-end),-94svh,0) rotate(var(--balloon-end-rotate))}}@keyframes party-balloon-string{0%,to{transform:rotate(-4deg)}50%{transform:rotate(5deg)}}@keyframes party-balloon-right-corner-rise{0%,64%{opacity:0;transform:translate3d(0,18svh,0) rotate(var(--balloon-start-rotate))}70%{opacity:.54}86%{transform:translate3d(var(--balloon-x-mid),-34svh,0) rotate(var(--balloon-mid-rotate))}96%{opacity:.5}to{opacity:0;transform:translate3d(var(--balloon-x-end),-86svh,0) rotate(var(--balloon-end-rotate))}}@keyframes party-bubble-right-rise{0%,72%{opacity:0;transform:translateZ(0) scale(.58)}80%{opacity:.16;transform:translate3d(-1.5vw,-5svh,0) scale(.7)}90%{opacity:.36;transform:translate3d(-4vw,-16svh,0) scale(.9) rotate(5deg)}97%{opacity:.26}to{opacity:0;transform:translate3d(-7vw,-28svh,0) scale(1) rotate(-6deg)}}.game-layer--home{z-index:20;pointer-events:auto;transition:opacity var(--layer-transition-duration, 1.6s) var(--layer-transition-easing, linear),visibility 0ms linear var(--layer-transition-duration, 1.6s)}.home-layer--hidden,.home-layer--exiting{opacity:0;pointer-events:none;visibility:hidden}.home-layer--under-room{opacity:1;pointer-events:none;visibility:visible}.home-layer--active{opacity:1;visibility:visible;transition:opacity var(--layer-transition-duration, 1.6s) var(--layer-transition-easing, linear),visibility 0ms}.game-layer--room-host,.game-layer--room-player{background:radial-gradient(circle at 50% 22%,#fffce8,#ffecbb 34%,#ffe1a0 58%),linear-gradient(180deg,#ffecb8,#ffd98f);box-shadow:inset 0 0 120px #7848101f;clip-path:circle(var(--room-reveal-radius, 75vmax) at 50% 50%);transform:none;transform-origin:50% 50%;will-change:clip-path}.game-layer--room-host{z-index:30;pointer-events:auto;touch-action:pan-y}.game-layer--room-player{z-index:40;pointer-events:auto;transition:transform .26s cubic-bezier(.2,.8,.2,1),opacity .22s ease,visibility 0ms linear .26s}.game-layer--room-player.room-layer--hidden-view{opacity:0;pointer-events:none;transform:translate3d(100%,0,0);visibility:hidden}.game-layer--room-player.room-layer--active{opacity:1;transform:translateZ(0);visibility:visible;touch-action:pan-y;transition:transform .26s cubic-bezier(.2,.8,.2,1),opacity .22s ease,visibility 0ms}.game-stage--room.game-stage--entering .game-layer--room-host,.game-stage--room.game-stage--entering .game-layer--room-player.room-layer--active{animation:room-world-circle-reveal var(--layer-transition-duration, 1.6s) var(--layer-transition-easing, linear) both}.game-stage--room.game-stage--exiting .game-layer--room-host,.game-stage--room.game-stage--exiting .game-layer--room-player{animation:room-world-circle-conceal var(--layer-transition-duration, 1.6s) var(--layer-transition-easing, linear) both}.game-stage--room.game-stage--exiting .game-layer--room-host,.game-stage--room.game-stage--exiting .game-layer--room-player{pointer-events:none}.home-name-plate{position:absolute;top:calc(-34px + env(safe-area-inset-top));left:50%;width:min(56vw,260px);transform:translate(-50%);pointer-events:none;filter:drop-shadow(0 18px 24px rgba(89,52,16,.28))}.home-name-plate img{display:block;width:100%;height:auto}.room-layer{padding-top:var(--room-top-space);padding-bottom:var(--room-bottom-space)}.game-layer--modal{z-index:100;background:#11182766;opacity:.05;pointer-events:none;transform:translate3d(0,100%,0);transform-origin:bottom center;visibility:hidden}.game-layer--modal.modal-layer--open{animation:popup-layer-slide-in var(--layer-transition-duration, 1.6s) var(--layer-transition-easing, linear) both;pointer-events:auto;visibility:visible}.game-layer--modal.modal-layer--closing{animation:popup-layer-slide-out var(--layer-transition-duration, 1.6s) var(--layer-transition-easing, linear) both;pointer-events:auto;visibility:visible}.game-layer--modal.game-layer--hidden{animation:none;opacity:0;pointer-events:none;visibility:hidden}.game-layer--modal>*{pointer-events:none}.game-modal-root{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.game-layer--modal.modal-layer--open .game-modal-root,.game-layer--modal.modal-layer--closing .game-modal-root{pointer-events:auto}.game-layer--modal .modal-overlay,.game-layer--modal .letter-overlay{position:absolute;background:transparent}.game-layer--modal .modal-overlay{animation:none}.game-layer--modal .modal{animation:none;opacity:1;transform:none}.game-layer--modal .modal-overlay--closing .modal{animation:none}.game-layer--modal .modal-overlay{display:block;padding:0;overflow:hidden}.game-layer--modal .modal{width:100%;height:100%;max-width:none;max-height:none;padding:calc(26px + env(safe-area-inset-top)) max(18px,env(safe-area-inset-right)) calc(26px + env(safe-area-inset-bottom)) max(18px,env(safe-area-inset-left));border-radius:0;border:none;background:radial-gradient(circle at 14% 10%,rgba(255,255,255,.72) 0 18px,transparent 19px),radial-gradient(circle at 87% 18%,rgba(255,111,163,.18) 0 34px,transparent 36px),radial-gradient(circle at 18% 88%,rgba(89,215,229,.2) 0 42px,transparent 44px),repeating-linear-gradient(0deg,rgba(174,109,38,.07) 0 2px,transparent 2px 14px),linear-gradient(180deg,#fff5d5,#ffdca1 56%,#ffc76b);color:#5a300a;box-shadow:inset 0 0 0 6px #b07be86b,inset 0 -10px #7c4eba2e;overflow-y:auto;-webkit-overflow-scrolling:touch}.game-layer--modal .modal:before{content:"";position:fixed;top:10px;right:10px;bottom:10px;left:10px;border:2px solid rgba(255,255,255,.5);border-radius:22px;pointer-events:none}.game-layer--modal .modal>*{width:min(100%,560px);margin-left:auto;margin-right:auto}.game-layer--modal .modal-short-panel{box-sizing:border-box;min-height:calc(100svh - 52px - env(safe-area-inset-top) - env(safe-area-inset-bottom));width:min(100%,430px);padding:88px 18px 96px;display:flex;flex-direction:column;align-items:stretch;justify-content:center;gap:12px}.game-layer--modal .modal-confirm-panel,.game-layer--modal .modal-empty-panel,.game-layer--modal .modal-share-panel{text-align:center}.game-layer--modal .modal-confirm-panel .row-gap,.game-layer--modal .modal-empty-panel .row-gap,.game-layer--modal .modal-share-panel .row-gap{justify-content:center}.game-layer--modal .modal-share-panel .modal-qr{width:min(230px,72vw);border-width:3px;border-color:#b07be88c;box-shadow:0 6px #7c4eba8c,0 14px 28px #4b2c0a2e}.share-code-card{width:min(100%,260px);margin:-2px auto 2px;padding:9px 12px 11px;border:3px solid rgba(176,123,232,.58);border-radius:18px;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.72) 0 6px,transparent 7px),repeating-linear-gradient(90deg,rgba(174,109,38,.07) 0 2px,transparent 2px 15px),linear-gradient(180deg,#fff8dc,#ffd78c);box-shadow:0 4px #7c4eba80,inset 0 2px #ffffffb8;display:grid;justify-items:center;gap:3px}.share-code-label{color:#60360fb8;font-size:11px;font-weight:950;letter-spacing:.12em;line-height:1;text-transform:uppercase}.share-code-number{color:#4a2a0c;font-size:clamp(34px,10vw,48px);font-weight:950;letter-spacing:.08em;line-height:1;font-variant-numeric:tabular-nums;text-shadow:0 2px 0 rgba(255,255,255,.8),0 5px 0 rgba(124,78,186,.18)}.open-game-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:12px;width:min(100%,560px);margin:4px auto 16px;align-items:stretch}.open-game-card{position:relative;min-height:92px;padding:14px 12px 13px;border:3px solid #b07be8;border-radius:22px;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.72) 0 6px,transparent 7px),repeating-linear-gradient(0deg,rgba(174,109,38,.08) 0 2px,transparent 2px 12px),linear-gradient(180deg,#fff4cf,#ffd98f);color:#5a300a;box-shadow:0 5px #7c4eba,0 12px 18px #4b2c0a33,inset 0 2px #ffffffa6,inset 0 -4px #a65d1e24;display:flex;flex-direction:column;justify-content:center;gap:7px;text-align:center;cursor:pointer}.open-game-card:before{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:2px solid rgba(255,255,255,.5);border-radius:16px;pointer-events:none}.open-game-card:after{content:"Join";position:absolute;right:10px;top:9px;padding:3px 7px;border-radius:999px;background:#111827e0;color:#fff8dc;font-size:10px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.open-game-card:hover{filter:saturate(1.05) brightness(1.02)}.open-game-card:active{transform:translateY(3px);box-shadow:0 2px #7c4eba,0 7px 12px #4b2c0a38,inset 0 3px #ffffffa6,inset 0 -3px #a65d1e24}.open-game-card-number{position:relative;z-index:1;font-size:23px;font-weight:950;line-height:1}.open-game-card-meta{position:relative;z-index:1;color:#5a300ab8;font-size:12px;font-weight:800}.game-layer--modal .modal-close{position:fixed;top:calc(14px + env(safe-area-inset-top));right:calc(14px + env(safe-area-inset-right));z-index:2;width:42px;height:42px;border:3px solid #b07be8;border-radius:999px;background:linear-gradient(180deg,#fff8dc,#ffd78c);color:#60360f;box-shadow:0 4px #7c4eba,0 10px 18px #4b2c0a38,inset 0 2px #ffffffb3;display:grid;place-items:center;font-size:19px;font-weight:900}.game-layer--modal .modal-close:active{transform:translateY(3px);box-shadow:0 1px #7c4eba,0 5px 12px #4b2c0a38,inset 0 2px #ffffffb3}.game-layer--modal .phase-title{color:#60360f;font-size:24px;font-weight:900;line-height:1.05;text-align:center;text-shadow:0 2px 0 rgba(255,255,255,.7)}.game-layer--modal .phase-desc,.game-layer--modal .modal-label,.game-layer--modal .modal-check{color:#6f4417}.game-layer--modal .modal-label{font-size:13px;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.host-game-form{--host-form-control-width: min(100%, 300px);box-sizing:border-box;min-height:calc(100svh - 52px - env(safe-area-inset-top) - env(safe-area-inset-bottom));padding:clamp(86px,22svh,170px) 0 96px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:16px}.visibility-segment{position:relative;width:var(--host-form-control-width);margin:0 auto;padding:4px;display:grid;grid-template-columns:1fr 1fr;gap:0;overflow:hidden;isolation:isolate;border:3px solid rgba(176,123,232,.62);border-radius:20px;background:repeating-linear-gradient(0deg,rgba(174,109,38,.08) 0 2px,transparent 2px 12px),linear-gradient(180deg,#fff8dce0,#ffd382e0);box-shadow:0 4px #7c4eba80,inset 0 2px #ffffffb3}.visibility-segment-thumb{position:absolute;z-index:0;left:4px;top:4px;bottom:4px;width:calc(50% - 4px);border-radius:15px;background:linear-gradient(180deg,#263f6e,#111827);box-shadow:0 3px #7c4ebab8,inset 0 2px #ffffff38;transition:transform .22s cubic-bezier(.2,.8,.2,1)}.visibility-segment--public .visibility-segment-thumb{transform:translate(100%)}.visibility-segment-option{position:relative;z-index:1;min-height:38px;border:0;border-radius:14px;background:transparent;color:#7b4a18;font-size:14px;font-weight:950;cursor:pointer;text-align:center;transition:color .18s ease}.visibility-segment-option--active{background:transparent;color:#fff8dc}.host-mode-toggle{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:9px;width:var(--host-form-control-width);min-height:58px;padding:8px 12px;border:2px solid rgba(176,123,232,.46);border-radius:18px;background:linear-gradient(180deg,#fff8dcf5,#ffe08ed1);color:#60360f;box-shadow:inset 0 2px #ffffffb8,0 4px #7c4eba73;cursor:pointer}.host-mode-toggle input{position:absolute;opacity:0;pointer-events:none}.host-mode-toggle-icon{width:34px;height:34px;border-radius:13px;display:grid;place-items:center;font-size:20px;background:#fff1c8;box-shadow:inset 0 2px #ffffffb8}.host-mode-toggle-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.host-mode-toggle-title{font-size:15px;font-weight:900;line-height:1.1}.host-mode-toggle-hint{font-size:11px;font-weight:700;line-height:1.15;color:#60360fb8}.host-mode-toggle-switch{width:38px;height:22px;padding:3px;border-radius:999px;background:#60360f33;box-shadow:inset 0 2px 3px #60360f38}.host-mode-toggle-switch span{display:block;width:16px;height:16px;border-radius:999px;background:#fff8dc;box-shadow:0 2px #60360f3d;transition:transform .16s ease}.host-mode-toggle--on{border-color:#b86af3}.host-mode-toggle--on .host-mode-toggle-icon{background:linear-gradient(180deg,#ffba45,#ff8f20)}.host-mode-toggle--on .host-mode-toggle-switch{background:linear-gradient(180deg,#72db75,#31b957)}.host-mode-toggle--on .host-mode-toggle-switch span{transform:translate(16px)}.word-pack-picker{width:min(100%,520px);display:flex;flex-direction:column;gap:8px}.host-game-form .word-pack-picker{width:min(100%,420px)}.word-pack-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px}.word-pack-card{position:relative;min-width:0;min-height:74px;padding:9px 10px;border:2px solid rgba(176,123,232,.42);border-radius:18px;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.72) 0 5px,transparent 6px),linear-gradient(180deg,#fff8dcf5,#ffe08edb);color:#60360f;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;text-align:left;font:inherit;cursor:pointer;box-shadow:0 3px #7c4eba57,inset 0 2px #ffffffb3}.word-pack-card--selected{border-color:#111827;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.18) 0 5px,transparent 6px),linear-gradient(180deg,#18345d,#111827);color:#fff8dc;box-shadow:0 3px #7c4eba8a,0 0 0 4px #ffbf368f,inset 0 2px #ffffff2e}.word-pack-card:disabled{cursor:default;opacity:.72}.word-pack-card:active:not(:disabled){transform:translateY(1px)}.word-pack-icon{width:34px;height:34px;border-radius:13px;display:grid;place-items:center;font-size:21px;line-height:1;background:#fff1c8db;box-shadow:inset 0 2px #ffffffa3}.word-pack-card--selected .word-pack-icon{background:#fff8dc2e}.word-pack-copy{min-width:0;display:flex;flex-direction:column;gap:2px}.word-pack-label{font-size:15px;font-weight:950;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.word-pack-desc{font-size:11px;font-weight:750;line-height:1.18;opacity:.72}.word-pack-summary{display:inline-grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:9px;max-width:100%;padding:9px 12px;border:2px solid rgba(176,123,232,.42);border-radius:18px;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.72) 0 5px,transparent 6px),linear-gradient(180deg,#fff8dceb,#ffe08ec7);color:#60360f;box-shadow:0 3px #7c4eba47,inset 0 2px #ffffffb3}.word-pack-summary-label{display:block;font-size:10px;font-weight:950;letter-spacing:.08em;text-transform:uppercase;color:#60360fad}.word-pack-summary strong{display:block;font-size:16px;line-height:1.1}.word-pack-popup-panel{align-items:center}.word-pack-popup-panel .word-pack-picker{width:min(100%,430px)}.word-pack-popup-panel .word-pack-summary{width:min(100%,280px)}.game-layer--modal .row-gap{justify-content:center}.host-game-form>.row-gap{width:auto;align-items:center}.game-layer--modal .modal-code-form{width:100%;margin-bottom:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;align-items:stretch}.game-layer--modal .modal-code-form .add-input{grid-column:1 / -1;min-height:50px;border-width:3px;border-color:#60360fc7;border-radius:14px;background:#fffaf0;color:#5a300a;font-size:16px}.game-layer--modal .modal-code-form .btn-primary,.game-layer--modal .modal-code-form .btn-ghost{min-width:0;padding-left:24px;padding-right:24px;width:100%;justify-content:center}.game-layer--modal .btn-primary,.game-layer--modal .btn-ghost,.game-layer--modal .btn-small{min-height:44px;border-width:3px;border-radius:16px;font-weight:900;box-shadow:0 4px #7c4ebaf2,0 10px 18px #4b2c0a33}.game-layer--modal .btn-primary{background:linear-gradient(180deg,#1f3763,#111827)}.game-layer--modal .btn-ghost{background:#fff8dc;border-color:#b07be8;color:#60360f}.game-layer--modal .modal-error{border-width:2px;border-color:#fb7185;background:#fff1f2;color:#9f1239}.game-layer--modal .avatar-picker{flex:0 1 auto;min-height:0}.game-layer--modal .avatar-grid{max-height:min(640px,calc(100svh - 250px - env(safe-area-inset-top) - env(safe-area-inset-bottom)));flex:0 1 auto;min-height:0;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));column-gap:8px;row-gap:38px;align-content:start;padding:48px 2px 14px;overflow-x:hidden}.game-layer--modal .avatar-option{min-height:82px;height:82px;padding:0 5px 4px;border:0;border-radius:18px;background:transparent;color:#60360f;box-shadow:none}.game-layer--modal .avatar-option:before{content:"";position:absolute;left:0;right:0;bottom:0;height:calc(100% - 20px);border:2px solid rgba(176,123,232,.34);border-radius:18px;background:#fff8dcdb;box-shadow:inset 0 2px #fff9;pointer-events:none}.game-layer--modal .avatar-option:hover:not(:disabled){background:transparent}.game-layer--modal .avatar-option:hover:not(:disabled):before{border-color:#b07be8;background:#fff8dc}.game-layer--modal .avatar-option--selected{background:transparent;box-shadow:none}.game-layer--modal .avatar-option--selected:before{border-color:#111827;background:#fff1c8;box-shadow:inset 0 0 0 2px #111827,0 4px #7c4ebab3}.game-layer--modal .avatar-option-name{color:#60360f;font-weight:800}.game-layer--modal .avatar-confirm-row{margin-top:6px;justify-content:center}.game-layer--modal .avatar-confirm-row .btn-primary{min-width:170px}@keyframes popup-layer-slide-in{0%{opacity:.05;transform:translate3d(0,100%,0)}to{opacity:.95;transform:translateZ(0)}}@keyframes popup-layer-slide-out{0%{opacity:.95;transform:translateZ(0)}to{opacity:.05;transform:translate3d(0,100%,0)}}@keyframes room-world-circle-reveal{0%{clip-path:circle(0 at 50% 50%)}to{clip-path:circle(var(--room-reveal-radius, 75vmax) at 50% 50%)}}@keyframes room-world-circle-conceal{0%{clip-path:circle(var(--room-reveal-radius, 75vmax) at 50% 50%)}to{clip-path:circle(0 at 50% 50%)}}.game-layer--debug{z-index:999;pointer-events:none}.game-stage-debug-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:999;pointer-events:none}.layer-debug-toggle{position:absolute;left:12px;top:calc(10px + env(safe-area-inset-top));z-index:1000;min-height:36px;padding:7px 10px;border:1px solid rgba(17,24,39,.8);border-radius:999px;background:#ffffffeb;color:#111827;font-size:12px;font-weight:800;line-height:1;cursor:pointer;pointer-events:auto;box-shadow:0 8px 22px #11182738;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.layer-debug-toggle--active{background:#111827;color:#fff}.layer-debug-legend{position:absolute;left:12px;top:calc(54px + env(safe-area-inset-top));z-index:1000;width:160px;padding:8px;border:1px solid rgba(17,24,39,.16);border-radius:8px;background:#ffffffeb;color:#111827;display:grid;gap:5px;font-size:11px;font-weight:700;line-height:1.2;box-shadow:0 14px 34px #11182733;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:auto}.layer-debug-row{display:inline-flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none}.layer-debug-row input{width:13px;height:13px;margin:0;accent-color:#111827}.layer-debug-row span{min-width:0}.layer-swatch{width:10px;height:10px;border-radius:2px;display:inline-block}.layer-swatch--background{background:#3b82f6b3}.layer-swatch--atmosphere{background:#a855f7b3}.layer-swatch--home{background:#22c55eb3}.layer-swatch--room-host{background:#f59e0bc2}.layer-swatch--room-player{background:#ef4444ad}.layer-swatch--modal{background:#14b8a6b8}.game-stage--layer-debug .game-stage-scene{transform:translate3d(0,1.5svh,0) rotateX(58deg) rotate(-23deg) scale(.7);transform-origin:center center;pointer-events:auto}.game-stage--layer-debug .game-layer{overflow:visible;outline:1px solid rgba(255,255,255,.8);box-shadow:0 18px 42px #00000047}.game-stage--layer-debug .game-layer:before,.game-stage--layer-debug .game-layer:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.game-stage--layer-debug .game-layer:after{z-index:200;opacity:.34;mix-blend-mode:multiply}.game-stage--layer-debug .game-layer:before{content:attr(data-layer);z-index:201;inset:auto auto 10px 10px;width:fit-content;max-width:180px;padding:5px 8px;border-radius:999px;background:#111827e0;color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;box-shadow:0 8px 18px #1118273d}.game-stage--layer-debug .game-layer--background{transform:translateZ(0)}.game-stage--layer-debug .game-layer--background:after{background:#3b82f6bf}.game-stage--layer-debug .game-layer--atmosphere{transform:translateZ(42px)}.game-stage--layer-debug .game-layer--atmosphere:after{background:#a855f7bf}.game-stage--layer-debug .game-layer--home{transform:translateZ(84px)}.game-stage--layer-debug .game-layer--home:after{background:#22c55ebf}.game-stage--layer-debug .game-layer--room-host{transform:translateZ(126px)}.game-stage--layer-debug .game-layer--room-host:after{background:#f59e0bc2}.game-stage--layer-debug .game-layer--room-player{transform:translateZ(168px)}.game-stage--layer-debug .game-layer--room-player:after{background:#ef4444b8}.game-stage--layer-debug .game-layer--modal{animation:none;opacity:1;transform:translateZ(210px);visibility:visible}.game-stage--layer-debug .game-layer--modal:after{background:#14b8a6c7}.home-stage-scroll{height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;pointer-events:auto}.home-stage-scroll--with-plate{box-sizing:border-box;padding-top:clamp(165px,26svh,235px)}.room-shell{min-height:100svh;display:grid;grid-template-rows:auto minmax(0,1fr) auto;background:#f3f4f6}.room-top{position:absolute;top:0;left:0;right:0;z-index:20;pointer-events:none}.room-plate{position:absolute;top:env(safe-area-inset-top);left:50%;transform:translate(-50%) translateY(-12px);display:inline-block;line-height:1;pointer-events:none;filter:drop-shadow(0 6px 14px rgba(89,52,16,.28))}.room-plate-bg{display:block;height:120px;width:auto}.room-plate-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;display:flex;align-items:center;gap:1px}.room-plate-label span{display:inline-block;font-size:24px;font-weight:900;line-height:1;paint-order:stroke fill;-webkit-text-stroke:2px rgba(255,255,255,.88);text-shadow:0 2px 0 rgba(0,0,0,.25),0 3px 8px rgba(0,0,0,.2)}.room-plate--clickable{pointer-events:auto;cursor:pointer}.room-plate--clickable:active .room-plate-bg{filter:brightness(.92)}.room-me-badge{position:absolute;top:calc(env(safe-area-inset-top) + 6px);right:12px;display:flex;flex-direction:column;align-items:center;gap:1px;pointer-events:none}.room-me-avatar{font-size:54px;line-height:1}.room-me-label{font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:#5a300a99}.word-pack-indicator{position:absolute;top:calc(env(safe-area-inset-top) + 12px);left:12px;max-width:min(34vw,150px);min-height:48px;padding:6px 9px 7px 7px;border:3px solid rgba(176,123,232,.62);border-radius:16px;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.72) 0 5px,transparent 6px),linear-gradient(180deg,#fff8dcf5,#ffe08ee0);color:#60360f;display:grid;grid-template-columns:32px minmax(0,1fr);align-items:center;gap:7px;pointer-events:auto;cursor:pointer;box-shadow:0 4px #7c4eba7a,0 10px 18px #4b2c0a24,inset 0 2px #ffffffad}.word-pack-indicator:active{transform:translateY(2px);box-shadow:0 2px #7c4eba7a,0 7px 14px #4b2c0a24,inset 0 2px #ffffffad}.word-pack-indicator-icon{width:32px;height:32px;border-radius:12px;display:grid;place-items:center;font-size:20px;line-height:1;background:#fff1c8db;box-shadow:inset 0 2px #ffffffa3}.word-pack-indicator-copy{min-width:0;display:flex;flex-direction:column;gap:1px;text-align:left}.word-pack-indicator-kicker{font-size:9px;font-weight:950;letter-spacing:.08em;line-height:1;text-transform:uppercase;color:#60360f94}.word-pack-indicator-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:950;line-height:1.05}.room-signal{display:inline-flex;align-items:center;justify-content:flex-end;gap:6px;min-height:22px;white-space:nowrap}.room-middle{height:100%;min-height:0;width:100%;max-width:none;margin:0;padding:0;overflow-x:clip;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-x:none}.room-view-slide{width:100vw;min-height:100%;overflow:clip;touch-action:pan-y;overscroll-behavior-x:none}.room-pages{display:flex;align-items:flex-start;width:200vw;min-height:100%;will-change:transform}.room-pages--at-host{transform:translate(0)}.room-pages--at-player{transform:translate(-100vw)}.room-pages--to-player{animation:role-slide-to-player .36s cubic-bezier(.2,.8,.2,1) both}.room-pages--to-host{animation:role-slide-to-host .36s cubic-bezier(.2,.8,.2,1) both}.room-pages--dragging{cursor:grabbing;-webkit-user-select:none;user-select:none}.room-pages--settling{transition:transform .22s cubic-bezier(.2,.8,.2,1)}.room-page{position:relative;flex:0 0 50%;width:50%;min-width:0;min-height:100%;padding:14px 0 18px}.room-layer--with-role-switch{padding-top:calc(var(--room-top-space) + 78px)}.room-page--single{flex-basis:100vw;width:100vw}.room-page-content{width:100%;max-width:640px;margin:0 auto;padding:0 14px;display:flex;flex-direction:column;gap:12px}@keyframes role-slide-to-player{0%{transform:translate(0)}to{transform:translate(-100vw)}}@keyframes role-slide-to-host{0%{transform:translate(-100vw)}to{transform:translate(0)}}.role-mode-switch{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:5px;border:3px solid #b07be8;border-radius:18px;background:radial-gradient(circle at 14% 18%,rgba(255,255,255,.75) 0 5px,transparent 6px),linear-gradient(180deg,#fff8dc,#ffd78c);box-shadow:0 4px #7c4eba,inset 0 2px #ffffffb8}.room-role-chrome{position:absolute;top:calc(env(safe-area-inset-top) + 104px);left:0;right:0;z-index:65;padding:0 16px;pointer-events:none}.room-role-chrome .role-mode-switch{width:min(360px,100%);margin:0 auto;pointer-events:auto}.role-mode-tab{position:relative;min-width:0;min-height:48px;padding:6px 10px;border:2px solid rgba(124,78,186,.28);border-radius:13px;background:#fffcefbd;color:#60360f;display:flex;align-items:center;justify-content:center;gap:8px;font:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:inset 0 1px #ffffffb3}.role-mode-tab--active{border-color:#111827;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.18) 0 5px,transparent 6px),linear-gradient(180deg,#18345d,#111827);color:#fff8dc;box-shadow:inset 0 2px #ffffff2e,0 2px #1118275c}.role-mode-tab--attention:not(.role-mode-tab--active){border-color:#f59e0b;background:radial-gradient(circle at 18% 18%,rgba(255,255,255,.85) 0 5px,transparent 6px),linear-gradient(180deg,#fff7d6,#ffc557);transform-origin:center;animation:role-tab-attention 1.65s ease-in-out infinite;box-shadow:0 5px #7c4eba80,0 0 #f59e0b57,inset 0 2px #ffffffb8}@keyframes role-tab-attention{0%,to{scale:1;box-shadow:0 5px #7c4eba80,0 0 #f59e0b57,inset 0 2px #ffffffb8}18%{scale:1.08;box-shadow:0 7px #7c4eba8f,0 0 0 8px #f59e0b33,inset 0 2px #ffffffc7}34%{scale:1}52%{scale:1.045;box-shadow:0 6px #7c4eba8a,0 0 0 5px #f59e0b24,inset 0 2px #ffffffc2}68%{scale:1}}.role-mode-tab:active{transform:translateY(1px)}.role-mode-tab-icon{flex:0 0 auto;font-size:20px;line-height:1}.role-mode-tab-copy{min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:1px;line-height:1.05}.role-mode-tab-title{max-width:100%;font-size:14px;font-weight:950;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-mode-tab-hint{max-width:100%;font-size:10px;font-weight:850;letter-spacing:.04em;text-transform:uppercase;opacity:.68;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-mode-tab-badge{position:absolute;top:6px;right:7px;width:11px;height:11px;border:2px solid currentColor;border-radius:999px;background:#ef4444;box-shadow:0 0 0 3px #ef444429}@keyframes action-nudge{0%,to{scale:1}14%{scale:1.02}28%{scale:1}42%{scale:1.013}56%{scale:1}}.action-nudge{animation:action-nudge 3s ease-in-out infinite}.room-me-badge.action-nudge{transform-origin:top right;animation:action-nudge-avatar 2.4s ease-in-out infinite}@keyframes action-nudge-avatar{0%,to{scale:1}15%{scale:1.18}30%{scale:1}45%{scale:1.1}60%{scale:1}}.action-nudge:disabled{animation:none}.btn-primary.action-nudge{font-size:18px;font-weight:950;padding:15px 32px;min-height:56px;border-radius:20px;letter-spacing:.01em;width:100%}.sticky-action-bar{position:sticky;bottom:0;padding:12px 0 4px;background:linear-gradient(transparent,#fff8f0 32%)}.room-bottom{position:absolute;left:0;right:0;bottom:0;z-index:20;display:grid;grid-template-columns:1fr;gap:8px;width:100%;max-width:640px;margin:0 auto;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:#fffffff5;border-top:1px solid #e5e7eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.room-bottom--split{grid-template-columns:1fr 1fr}.room-bottom-btn{width:100%;min-height:44px;text-align:center}.room-bottom-btn--danger{color:#991b1b;border-color:#fecaca}.room-bottom-btn--danger:hover:not(:disabled){background:#fef2f2}.room-meta{font-size:12px;color:#6b7280;line-height:1.35}.row-gap{display:flex;gap:8px;flex-wrap:wrap}.countdown-pill{display:inline-flex;align-items:center;justify-content:center;min-width:42px;min-height:28px;padding:4px 9px;border:1px solid #f59e0b;border-radius:999px;background:#fffbeb;color:#92400e;font-size:13px;font-weight:900;line-height:1;font-variant-numeric:tabular-nums}.phase-box.tie-break-box{display:flex;align-items:center;justify-content:center;gap:18px;padding:18px 16px 20px;background:#fff7ed;border:1px solid #fed7aa}.tie-break-copy{min-width:128px}.tie-break-copy .phase-title{font-size:18px}.tie-break-copy .phase-desc{margin-top:2px}.tie-break-candidates-line{margin-top:10px;max-width:160px;color:#111827;font-size:13px;font-weight:800;line-height:1.25;overflow-wrap:anywhere}.tie-break-clock{--tie-final-angle: 1440deg;position:relative;flex:0 0 174px;width:174px;height:174px;border:2px solid #1f2937;border-radius:50%;background:radial-gradient(circle at center,#111827 0 5px,transparent 6px),radial-gradient(circle at center,#fff 0,#fff 58%,#ffedd5 59%,#ffedd5 62%,#fff 63%);box-shadow:0 10px 24px #1118271f}.tie-break-clock:after{content:"";position:absolute;left:50%;top:50%;width:10px;height:10px;border-radius:50%;background:#111827;transform:translate(-50%,-50%);z-index:3}.tie-break-needle{position:absolute;left:calc(50% - 2px);top:20px;width:4px;height:67px;border-radius:999px;background:#dc2626;transform-origin:50% 67px;animation:tie-break-spin var(--tie-break-duration, 5s) cubic-bezier(.12,.66,.12,1) forwards;z-index:2}.tie-break-candidate{position:absolute;font-size:48px;line-height:1;transform:translate(-50%,-50%);filter:drop-shadow(0 2px 3px rgba(0,0,0,.18));z-index:1}.tie-break-candidate--selected{filter:drop-shadow(0 0 6px #dc2626) drop-shadow(0 2px 3px rgba(0,0,0,.18))}@keyframes tie-break-spin{0%{transform:rotate(0)}to{transform:rotate(var(--tie-final-angle))}}.private-tray{position:sticky;top:8px;z-index:24;display:flex;justify-content:flex-end;gap:8px;align-self:flex-end;margin-bottom:2px}.private-tray-item{position:relative;width:68px;min-height:48px;padding:7px 8px;border:2px solid #b07be8;border-radius:12px;background:radial-gradient(circle at 28% 18%,rgba(255,255,255,.7) 0 5px,transparent 6px),linear-gradient(160deg,#fff8dc,#ffd78c);color:#60360f;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:3px;cursor:pointer;text-align:left;-webkit-user-select:none;user-select:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent;box-shadow:0 3px #7c4eba,0 6px 14px #4b2c0a24,inset 0 1px #ffffffb3;transition:transform 80ms ease,box-shadow 80ms ease}.private-tray-item:active:not(:disabled){transform:translateY(2px);box-shadow:0 1px #7c4eba,0 3px 8px #4b2c0a24,inset 0 1px #ffffffb3}.private-tray-item:disabled{opacity:.55;cursor:default}.private-tray-item:focus-visible{outline:2px solid #b07be8;outline-offset:2px}.private-tray-item--cool{border-color:#60a5fa;box-shadow:0 3px #2563eb,0 6px 14px #2563eb24,inset 0 1px #ffffffb3}.private-tray-item--cool:active:not(:disabled){box-shadow:0 1px #2563eb,0 3px 8px #2563eb24,inset 0 1px #ffffffb3}.private-tray-item--warm{border-color:#fb923c;box-shadow:0 3px #ea580c,0 6px 14px #ea580c24,inset 0 1px #ffffffb3}.private-tray-item--warm:active:not(:disabled){box-shadow:0 1px #ea580c,0 3px 8px #ea580c24,inset 0 1px #ffffffb3}.private-tray-item--green{border-color:#4ade80;box-shadow:0 3px #16a34a,0 6px 14px #16a34a24,inset 0 1px #ffffffb3}.private-tray-item--green:active:not(:disabled){box-shadow:0 1px #16a34a,0 3px 8px #16a34a24,inset 0 1px #ffffffb3}.private-tray-item--plain{opacity:.6}.private-tray-item--new:not(.private-tray-item--locked):after{content:"";position:absolute;right:7px;top:7px;width:7px;height:7px;border-radius:50%;background:#ef4444}.private-tray-label{color:#60360f;font-size:11px;font-weight:900;line-height:1;letter-spacing:.04em}.private-tray-state{color:#60360fa6;font-size:9px;font-weight:750;line-height:1;text-transform:uppercase;letter-spacing:.06em}@keyframes letter-fly-in{0%{transform:translate(var(--from-x, 0px),var(--from-y, 0px)) scale(var(--from-s, .16)) rotateY(180deg);opacity:0}25%{opacity:1}to{transform:translate(0) scale(1) rotateY(0);opacity:1}}@keyframes letter-fly-out{0%{transform:translate(0) scale(1) rotateY(0);opacity:1}75%{opacity:1}to{transform:translate(var(--from-x, 0px),var(--from-y, 0px)) scale(var(--from-s, .16)) rotateY(180deg);opacity:0}}.letter-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:110;display:grid;place-items:center;padding:24px;pointer-events:none;perspective:900px}.letter-overlay:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:#11182761;opacity:0;transition:opacity .3s ease;pointer-events:none}.letter-overlay--active{pointer-events:auto}.letter-overlay--active:before{opacity:1}.letter-scene{position:relative;width:min(380px,calc(100vw - 48px));transform-style:preserve-3d;pointer-events:auto}.letter-scene--entering{animation:letter-fly-in .52s cubic-bezier(.2,.8,.2,1) both}.letter-scene--exiting{animation:letter-fly-out .46s cubic-bezier(.4,0,1,1) both;pointer-events:none}.letter-card,.letter-card-back{border-radius:20px;padding:22px 22px 20px;backface-visibility:hidden;-webkit-backface-visibility:hidden}.letter-card{display:flex;flex-direction:column;gap:12px;background:radial-gradient(circle at 20% 14%,rgba(255,255,255,.75) 0 8px,transparent 9px),linear-gradient(155deg,#fff8dc,#ffcf76);border:3px solid #b07be8;box-shadow:0 5px #7c4eba,0 14px 32px #4b2c0a38,inset 0 2px #ffffffbf;color:#60360f}.letter-card--human{background:radial-gradient(circle at 20% 14%,rgba(255,255,255,.78) 0 8px,transparent 9px),linear-gradient(155deg,#eff6ff,#bfdbfe);border-color:#60a5fa;box-shadow:0 5px #2563eb,0 14px 32px #2563eb2e,inset 0 2px #fffc;color:#1e3a5f}.letter-card--zombie{background:radial-gradient(circle at 20% 14%,rgba(255,255,255,.78) 0 8px,transparent 9px),linear-gradient(155deg,#fff8dc,#fed7aa);border-color:#fb923c;box-shadow:0 5px #ea580c,0 14px 32px #ea580c33,inset 0 2px #fffc;color:#7c2d12}.letter-card--word{background:radial-gradient(circle at 20% 14%,rgba(255,255,255,.78) 0 8px,transparent 9px),linear-gradient(155deg,#f0fdf4,#bbf7d0);border-color:#4ade80;box-shadow:0 5px #16a34a,0 14px 32px #16a34a2e,inset 0 2px #fffc;color:#14532d}.letter-card-back{position:absolute;top:0;right:0;bottom:0;left:0;transform:rotateY(180deg);display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 28% 22%,rgba(255,255,255,.72) 0 8px,transparent 9px),linear-gradient(180deg,#fff8dc,#ffcf76);border:3px solid #b07be8;box-shadow:0 5px #7c4eba,0 14px 32px #4b2c0a38,inset 0 2px #ffffffbf}.letter-card-back-label{font-size:15px;font-weight:950;color:#60360f59;letter-spacing:.12em;text-transform:uppercase;-webkit-user-select:none;user-select:none}.letter-stamp{align-self:flex-start;padding:3px 9px;border-radius:6px;border:2px solid currentColor;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.1em;opacity:.7}.letter-title{font-size:13px;font-weight:750;opacity:.8}.letter-secret{padding:14px 16px;border-radius:14px;background:#ffffff73;border:1.5px solid rgba(255,255,255,.6);display:flex;flex-direction:column;gap:5px}.letter-secret-title{font-size:28px;font-weight:950;line-height:1.1;overflow-wrap:anywhere}.letter-secret-hint{font-size:13px;font-weight:650;opacity:.78}.blank-word-boxes{display:inline-flex;gap:5px;align-items:center;vertical-align:middle}.blank-word-boxes span{display:inline-block;width:20px;height:28px;border:2.5px solid currentColor;border-radius:4px;opacity:.55}.letter-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.letter-progress{font-size:11px;font-weight:700;opacity:.6;text-align:center}@media(prefers-reduced-motion:reduce){.atmosphere-light-wash,.atmosphere-floor-sheen,.atmosphere-dust,.atmosphere-confetti,.atmosphere-balloon,.atmosphere-balloon:after,.atmosphere-bubble{animation:none}}.phase-box{position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px}.main-panel .todo-list{margin-bottom:0}.main-panel .section-title{margin-top:4px;padding-top:12px;border-top:1px solid #eef0f3}.phase-title{font-size:16px;font-weight:600}.phase-desc{font-size:14px;color:#6b7280}.phase-desc--with-pill{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.phase-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.host-focus-line{display:inline-flex;align-items:center;width:fit-content;max-width:100%;padding:7px 10px;border-radius:6px;background:#f1f5f9;color:#111827;font-size:15px;font-weight:700;line-height:1.3}.match-winner-line{font-size:16px}.match-outcome-stamp{position:absolute;top:18px;right:18px;font-size:38px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;opacity:.5;border:5px solid currentColor;border-radius:6px;padding:2px 10px;line-height:1;transform:rotate(-18deg) translate(10px,-18px);pointer-events:none;-webkit-user-select:none;user-select:none}.match-outcome-stamp--win{color:#15803d}.match-outcome-stamp--loss{color:#b91c1c}.speaking-order-pills{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.speaking-order-label{color:#6b7280;font-size:13px;font-weight:600}.speaking-order-pill{display:inline-flex;align-items:center;gap:4px;max-width:100%;padding:3px 7px;border:1px solid #e5e7eb;border-radius:999px;background:#f9fafb;color:#4b5563;font-size:11px;font-weight:700;line-height:1.2}.speaking-order-pill--done{border-color:#bbf7d0;background:#f0fdf4;color:#15803d}.speaking-order-pill--current{border-color:#bfdbfe;background:#eff6ff;color:#1d4ed8}.round-result-digest .phase-desc strong{color:#111827}.round-result-remaining{align-self:flex-start;padding:5px 9px;border-radius:999px;background:#fff7ed;color:#9a3412;font-size:15px;font-weight:800;line-height:1.25}.round-result-action{display:flex;justify-content:flex-end;align-items:center;gap:8px}.round-history-panel,.round-history-block{display:flex;flex-direction:column;gap:12px}.vote-breakdown{display:flex;flex-direction:column;gap:8px;padding-top:4px}.vote-breakdown .section-title{margin-bottom:0}.vote-secret-word{align-self:center;text-align:center;padding:6px 20px 10px;border-radius:14px;background:#a855f712;line-height:1}.vote-secret-word-label{display:block;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#7c3aed8c;margin-bottom:4px}.vote-secret-word strong{display:block;font-size:26px;font-weight:900;color:#7c3aed;text-shadow:0 2px 10px rgba(124,58,237,.3);letter-spacing:.04em;line-height:1.15}.vote-map{display:grid;grid-template-columns:minmax(0,1fr) 54px minmax(0,1fr);align-items:start;gap:8px}.vote-map-column{display:flex;flex-direction:column;gap:8px}.vote-map-lines{position:relative;height:var(--vote-map-height);min-height:var(--vote-map-height)}.vote-map-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;overflow:visible}.vote-map-line{stroke:#9ca3af;stroke-width:2;vector-effect:non-scaling-stroke}.vote-map-arrowhead{fill:#9ca3af}.vote-map-line-labels,.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.vote-player-card{position:relative;min-width:0;min-height:var(--vote-card-height, 68px);padding:8px 10px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;overflow:hidden}.vote-player-card--dinosaur{border-color:#bbf7d0;background:#f0fdf4}.vote-player-card--chicken{border-color:#c4b5fd;background:#f5f3ff}.vote-player-avatar{display:block;font-size:48px;line-height:1}.vote-player-role{position:absolute;top:4px;right:5px;font-size:16px;line-height:1}.lose-shower{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:990;overflow:hidden}.lose-shower-drop{position:absolute;top:-60px;line-height:1;animation:lose-drop-fall linear forwards}@keyframes lose-drop-fall{0%{transform:translate(0);opacity:1}75%{opacity:1}to{transform:translate(var(--dx, 0px),110vh);opacity:0}}.vote-player-me{position:absolute;top:4px;right:5px;font-size:9px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#7c3aedb3;line-height:1}.vote-player-statement{display:-webkit-box;color:#6b7280;font-size:11px;font-weight:600;line-height:1.2;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.vote-player-badge{position:absolute;left:9px;bottom:4px;max-width:calc(100% - 18px);padding:1px 6px;border-radius:999px;background:#fee2e2;color:#991b1b;font-size:9px;font-weight:800;line-height:1.35;letter-spacing:.02em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;z-index:3}.vote-player-card--crossed-out{border-color:#fecaca;background:#fef2f2}.vote-player-card--crossed-out:before,.vote-player-card--crossed-out:after{content:"";position:absolute;left:9px;right:9px;top:50%;height:3px;border-radius:999px;background:#dc2626d1;transform-origin:center;pointer-events:none;z-index:4}.vote-player-card--crossed-out:before{transform:translateY(-50%) rotate(17deg)}.vote-player-card--crossed-out:after{transform:translateY(-50%) rotate(-17deg)}@media(max-width:430px){.content{padding:12px}.content--room,.room-middle{padding:0}.room-signal .ws-label{max-width:92px;overflow:hidden;text-overflow:ellipsis}.add-row{flex-direction:column}.add-row .btn-primary,.add-row .btn-ghost{width:100%}.vote-map{grid-template-columns:minmax(0,1fr) 38px minmax(0,1fr);gap:6px}.vote-player-card{padding:8px 7px;gap:5px}.list-item{align-items:flex-start;flex-wrap:wrap}.list-item .btn-small{width:100%}.lobby-roster-item{align-items:center;flex-wrap:nowrap}.lobby-roster-item .btn-small{width:auto}.lobby-roster-main{flex-direction:column;align-items:flex-start;gap:3px}.phase-box.tie-break-box{align-items:center;flex-direction:column;text-align:center}.tie-break-candidates-line{max-width:100%}.tie-break-clock{margin:0 auto}}@media(min-width:480px){.room-bottom{grid-template-columns:repeat(2,minmax(0,1fr))}.room-bottom-btn:only-child{grid-column:1 / -1}}.room-meta,.ws-label{color:#5a300ab8;font-weight:750}.room-bottom{background:radial-gradient(circle at 86% 18%,rgba(255,111,163,.12) 0 24px,transparent 25px),repeating-linear-gradient(0deg,rgba(174,109,38,.08) 0 2px,transparent 2px 13px),linear-gradient(180deg,#ffefbff0,#ffcf76f5);border-top:3px solid rgba(176,123,232,.5);box-shadow:0 -8px 18px #4b2c0a1f}.phase-box,.main-panel,.round-history-panel{border:3px solid rgba(176,123,232,.62);border-radius:24px;background:radial-gradient(circle at 12% 16%,rgba(255,255,255,.72) 0 7px,transparent 8px),radial-gradient(circle at 90% 14%,rgba(255,111,163,.12) 0 22px,transparent 23px),repeating-linear-gradient(0deg,rgba(174,109,38,.07) 0 2px,transparent 2px 13px),linear-gradient(180deg,#fff5d5f5,#ffdca1f5 62%,#ffc76bf5);color:#5a300a;box-shadow:0 5px #7c4eba8c,0 14px 26px #4b2c0a29,inset 0 2px #ffffffb3}.phase-title{color:#5a300a;font-size:22px;font-weight:950;line-height:1.1;text-shadow:0 2px 0 rgba(255,255,255,.76)}.phase-desc,.hint{color:#5a300ab8;font-weight:750}.waiting-phrase{display:flex;flex-wrap:wrap;align-items:baseline;gap:0}.waiting-phrase-char{display:inline-block;animation:wave-letter 1.8s ease-in-out infinite;white-space:pre}.waiting-phrase-dots{display:inline-block}@keyframes wave-letter{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.section-title{color:#7c4a16;font-size:12px;font-weight:950;letter-spacing:.08em}.main-panel .section-title{border-top-color:#7c4eba38}.btn-primary,.btn-ghost,.btn-small{border:3px solid #b07be8;border-radius:16px;font-weight:900;box-shadow:0 4px #7c4eba,inset 0 2px #ffffffa6}.btn-primary{background:linear-gradient(180deg,#18345d,#111827);color:#fff8dc}.btn-ghost,.btn-small{background:linear-gradient(180deg,#fff8dc,#ffd78c);color:#60360f}.btn-primary:active:not(:disabled),.btn-ghost:active:not(:disabled),.btn-small:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #7c4eba,inset 0 2px #ffffffa6}.game-roster-list{display:grid;grid-template-columns:1fr;gap:10px;margin:0 0 16px}.game-player-card .vote-out-btn{width:auto;flex-shrink:0;white-space:nowrap}.list-item.game-player-card,.game-player-card{position:relative;align-items:center;border:2px solid rgba(176,123,232,.42);border-radius:18px;background:radial-gradient(circle at 12% 22%,rgba(255,255,255,.72) 0 5px,transparent 6px),linear-gradient(180deg,#fff8dce6,#ffe3abe6);color:#5a300a;box-shadow:0 3px #7c4eba57,0 8px 14px #4b2c0a1a}.roster-me-badge{position:absolute;top:5px;right:8px;font-size:9px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#7c3aedb3;line-height:1;pointer-events:none}.player-token-emoji{flex:0 0 auto;width:42px;height:42px;display:grid;place-items:center;font-size:28px;line-height:1;transform:scale(1.75);transform-origin:50% 50%;filter:drop-shadow(0 3px 0 rgba(75,44,10,.12))}.list-item-name{color:#4a2a0c;font-size:15px;font-weight:950}.list-item-count,.lobby-roster-extra-status,.statement-empty{color:#5a300aa3;font-weight:800}.statement-text{color:#5a300a;font-weight:850}.game-player-card .statement-text{font-size:17px;font-weight:950;color:#3a1a06}.presence-badge{font-weight:900}.presence-badge--online{color:#147a3d}.presence-badge--offline{color:#b91c1c}.vote-secret-word,.host-focus-line,.round-result-remaining,.speaking-order-pill,.countdown-pill{border:2px solid rgba(176,123,232,.36);background:#ffffff6b;color:#5a300a}.vote-player-card{border-width:2px;border-radius:16px;box-shadow:0 3px #7c4eba3d}@media(min-width:560px){.game-roster-list{grid-template-columns:repeat(2,minmax(0,1fr))}.player-card-list.game-roster-list{grid-template-columns:1fr}}@media(max-width:420px){.word-pack-indicator{max-width:54px;min-height:48px;padding-right:7px;grid-template-columns:32px}.word-pack-indicator-copy{display:none}.word-pack-card-grid{gap:7px}.word-pack-card{min-height:68px;padding:8px 7px;border-radius:15px;gap:6px}.word-pack-icon{width:30px;height:30px;border-radius:11px;font-size:18px}.word-pack-label{font-size:13px}.word-pack-desc{font-size:10px;line-height:1.12}}@media(min-width:431px){.room-role-chrome{top:calc(env(safe-area-inset-top) + 116px)}.room-layer--with-role-switch{padding-top:calc(var(--room-top-space) + 88px)}.game-player-card .lobby-roster-main{display:grid;grid-template-columns:52px minmax(0,1fr);grid-template-areas:"avatar name" "avatar status";column-gap:10px;row-gap:2px;align-items:center}.game-player-card .player-token-emoji{grid-area:avatar;width:52px;height:52px;font-size:42px;transform:none}.game-player-card .lobby-roster-name-stack{grid-area:name}.game-player-card .list-item-count{grid-area:status}}@media(min-width:560px)and (max-width:719px){.game-roster-list{grid-template-columns:1fr}}@media(min-width:720px){.game-roster-list{grid-template-columns:repeat(2,minmax(0,1fr))}}
