:root{color:#f8fafc;font-synthesis:none;text-rendering:optimizelegibility;background:#0b1020;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input{font:inherit}button{color:#101214;cursor:pointer;background:linear-gradient(#ffe889 0%,#f4d35e 56%,#d99b28 100%);border:2px solid #ffffff2e;border-radius:8px;min-height:44px;padding:0 18px;font-weight:800;transition:transform .12s,box-shadow .12s,filter .12s;box-shadow:0 4px #7a4a14}button:not(:disabled):hover{filter:brightness(1.06);transform:translateY(-1px)}button:not(:disabled):active{transform:translateY(2px);box-shadow:0 2px #7a4a14}button:disabled{cursor:not-allowed;opacity:.48}a{color:#f4d35e;word-break:break-word}.app-shell{background:linear-gradient(#ffffff06 1px,#0000 1px) 0 0/28px 28px,linear-gradient(90deg,#ffffff06 1px,#0000 1px) 0 0/28px 28px,radial-gradient(circle at 16% 0,#21ccb738,#0000 24rem),radial-gradient(circle at 86% 12%,#f4d35e29,#0000 26rem),linear-gradient(#151b35 0%,#0b1020 54%,#101214 100%);min-height:100vh}.app-shell--lobby{align-items:center;padding:40px;display:grid}.app-shell--controller{place-items:center;padding:18px;display:grid}.app-shell--game{align-items:center;padding:28px;display:grid}.host-workspace{width:min(1180px,100%);margin:0 auto}.game-workspace{width:min(1440px,100%);margin:0 auto}.host-header,.phone-header,.game-header{justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px;display:flex}.eyebrow,.label{color:#9aa4b2;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px;font-size:.78rem;font-weight:800}h1,h2,p{margin-top:0}h1{letter-spacing:0;text-transform:uppercase;max-width:760px;margin-bottom:0;font-size:clamp(2.8rem,7vw,6.2rem);line-height:.86}h2{margin-bottom:0;font-size:1.35rem}.host-layout{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);align-items:stretch;gap:28px;display:grid}.results-layout{grid-template-columns:minmax(0,.9fr) minmax(320px,1.1fr);align-items:stretch;gap:28px;display:grid}.room-panel,.player-panel,.phone-surface{background:#070c18b8;border:2px solid #f8fafc24;border-radius:8px;box-shadow:inset 0 0 0 2px #00000047,0 22px 60px #00000052}.room-panel,.player-panel{padding:28px}.lobby-stage{min-height:250px;image-rendering:pixelated;background:linear-gradient(#ffffff0d 1px,#0000 1px) 0 0/24px 24px,linear-gradient(90deg,#ffffff0d 1px,#0000 1px) 0 0/24px 24px,linear-gradient(#296dc2 0%,#58c7d8 58%,#182748 58% 100%);border:2px solid #f8fafc2e;border-radius:8px;position:relative;overflow:hidden}.stage-sky,.stage-ground,.stage-platform,.stage-sprite,.pixel-cloud{position:absolute}.stage-sky{inset:0}.pixel-cloud{opacity:.72;background:#dff8ff;width:76px;height:28px;box-shadow:20px -12px #dff8ff,44px 0 #dff8ff,24px 12px #ffffff80}.pixel-cloud--one{animation:11s ease-in-out infinite alternate cloud-drift;top:38px;left:40px}.pixel-cloud--two{animation:14s ease-in-out infinite alternate-reverse cloud-drift;top:74px;right:76px;transform:scale(.72)}.stage-ground{background:linear-gradient(90deg,#1012143d 1px,#0000 1px) 0 0/28px 100%,linear-gradient(#32c07c 0 14px,#17864f 14px 22px,#6b4b28 22px 100%);height:54px;inset:auto 0 0}.stage-platform{background:#7a4a28;border-top:6px solid #3ee08b;height:18px;box-shadow:0 5px #00000040}.stage-platform--high{width:150px;top:92px;right:32px}.stage-platform--low{width:190px;bottom:92px;left:34px}.stage-sprite{z-index:2;object-fit:contain;width:56px;height:56px;image-rendering:pixelated;filter:drop-shadow(0 8px #00000040)}.stage-sprite--player{animation:.8s steps(2,end) infinite player-bob;bottom:50px;left:68px}.stage-sprite--key{width:40px;height:40px;animation:1.4s ease-in-out infinite alternate float-token;bottom:126px;left:252px}.stage-sprite--door{width:58px;height:72px;bottom:50px;right:112px}.stage-sprite--portal{width:76px;height:84px;animation:1.4s ease-in-out infinite alternate portal-pulse;bottom:48px;right:36px}@keyframes cloud-drift{0%{translate:-8px}to{translate:14px}}@keyframes player-bob{50%{translate:0 -5px}}@keyframes float-token{to{translate:0 -8px}}@keyframes portal-pulse{to{filter:drop-shadow(0 0 16px #48ffa0b8)}}.room-code-block strong{color:#fff6b5;letter-spacing:.04em;text-shadow:0 5px #7a4a14,0 10px 28px #0000008c;font-size:clamp(5rem,16vw,10rem);line-height:.86;display:block}.room-code-block--empty strong{color:#f8fafc70;text-shadow:none}.join-block{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:22px;margin-top:24px;display:grid}.qr-code{background:#fff;border-radius:8px;width:190px;height:190px;box-shadow:0 8px #00000042}.qr-code--loading{border:10px solid #fff}.host-actions,.join-form{gap:12px;margin-top:28px;display:flex}.host-actions button:last-child{color:#f8fafc;background:linear-gradient(#43d39f 0%,#149463 100%);box-shadow:0 4px #0e583d}.text-button,.secondary-button{color:#f8fafc;background:#f8fafc1f;min-height:40px;box-shadow:0 3px #00000057}.release-panel,.seed-panel,.room-not-found{background:#0000002e;border:1px solid #f8fafc1f;border-radius:8px;margin-bottom:22px;padding:14px}.seed-panel{justify-content:space-between;align-items:center;gap:16px;margin:18px 0 0;display:flex}.seed-panel strong{overflow-wrap:anywhere;display:block}.how-to-list{color:#cbd5e1;gap:8px;margin:14px 0 0;padding-left:18px;line-height:1.4;display:grid}.room-options{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:12px;margin-top:18px;display:grid}.room-options label{color:#cbd5e1;gap:8px;font-weight:800;display:grid}.room-options input[type=number]{color:#f8fafc;background:#00000052;border:1px solid #f8fafc2e;border-radius:8px;width:100%;min-height:44px;padding:0 12px}.room-option-toggle{background:#f8fafc1a;border-radius:8px;grid-template-columns:auto auto;align-items:center;min-height:44px;padding:0 12px}.room-option-toggle input,.debug-toggle input{accent-color:#f4d35e}.hint,.quiet-copy,.empty-state,.error-message{color:#cbd5e1;line-height:1.55}.hint{margin:14px 0 0;font-size:.95rem}.error-message{color:#fca5a5;margin:16px 0 0}.room-not-found h2{margin:0 0 8px}.room-not-found p{color:#cbd5e1;margin:0;line-height:1.45}.network-warning{color:#fde68a;background:#f4d35e1a;border:1px solid #f4d35e57;border-radius:8px;margin:16px 0 0;padding:12px;line-height:1.45}.crowd-summary{color:#cbd5e1;border-top:1px solid #f8fafc1f;gap:6px;margin-top:16px;padding-top:12px;line-height:1.35;display:grid}.crowd-summary span:not(.label){font-size:.9rem}.section-heading{justify-content:space-between;align-items:baseline;gap:16px;margin-bottom:20px;display:flex}.section-heading span{color:#9aa4b2;font-size:.9rem}.player-list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.player-list li{border-top:1px solid #f8fafc1a;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-height:70px;padding:12px 0;display:grid}.player-list img{width:40px;height:40px;image-rendering:pixelated}.player-list strong,.player-list span{display:block}.player-list div span{color:#9aa4b2;margin-top:4px;font-size:.9rem}.player-list .input-debug{color:#f4d35e;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.82rem}.player-list .input-debug--idle{color:#64748b}.player-list .network-status{color:#cbd5e1;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.82rem}.player-list .network-status--good{color:#86efac}.player-list .network-status--okay{color:#fde68a}.player-list .network-status--laggy,.player-list .network-status--polling-fallback{color:#fca5a5}.role-pill,.connection-badge{text-transform:uppercase;border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:800}.role-pill--active,.connection-badge--connected{color:#101214;background:#f4d35e}.role-pill--queued,.role-pill--spectator,.connection-badge--connecting{color:#f8fafc;background:#f8fafc29}.connection-badge--disconnected{color:#fee2e2;background:#ef44443d}.phone-surface{width:min(460px,100%);min-height:min(760px,100vh - 36px);padding:24px}.phone-surface--controller{flex-direction:column;width:min(980px,100%);min-height:min(560px,100svh - 36px);display:flex}.phone-surface--controller .phone-header{align-items:center;margin-bottom:18px}.phone-surface h1{font-size:clamp(2.2rem,12vw,4.5rem)}.phone-surface--controller h1{font-size:clamp(2rem,6vw,4.1rem)}.join-form{flex-direction:column}.join-form label{color:#cbd5e1;font-weight:800}.join-form input{color:#f8fafc;background:#0003;border:1px solid #f8fafc2e;border-radius:8px;width:100%;min-height:52px;padding:0 14px}.controller-meta{grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 18px;display:grid}.controller-meta div{border-top:1px solid #f8fafc24;padding-top:12px}.controller-meta dt{color:#9aa4b2;text-transform:uppercase;font-size:.8rem}.controller-meta dd{margin:4px 0 0;font-size:1.3rem;font-weight:800}.controller-rotate-prompt{display:none}.controller-play-area{touch-action:none;-webkit-user-select:none;user-select:none;grid-template-columns:minmax(220px,.9fr) minmax(220px,1fr);justify-content:space-between;align-items:center;gap:clamp(18px,8vw,90px);margin-top:auto;display:grid}.controller-pad{justify-self:center;display:grid}.controller-pad--movement{grid-template-rows:repeat(3,minmax(68px,1fr));grid-template-columns:repeat(3,minmax(68px,1fr));gap:8px;width:min(276px,100%)}.controller-pad--actions{grid-template-rows:repeat(2,minmax(82px,1fr));grid-template-columns:repeat(2,minmax(96px,1fr));gap:16px;width:min(330px,100%)}.control-button{color:#f8fafc;text-transform:uppercase;touch-action:none;background:#f8fafc1c;place-items:center;gap:2px;min-width:0;min-height:68px;display:grid}.control-button__face,.control-button__caption{line-height:1;display:block}.control-button__face{font-size:clamp(1.8rem,5vw,2.8rem)}.control-button__caption{color:#cbd5e1;letter-spacing:.08em;font-size:.72rem}.control-button:active,.control-button[aria-pressed=true]{color:#101214;background:#f4d35e;transform:translateY(2px)}.control-button[aria-pressed=true] .control-button__caption{color:#101214}.control-button--up{grid-area:1/2}.control-button--left{grid-area:2/1}.control-button--down{grid-area:3/2}.control-button--right{grid-area:2/3}.control-button--jump{grid-area:2/2;min-height:96px}.control-button--action{grid-area:1/1;min-height:96px}.ready-button{width:100%;margin-top:18px}.controller-debug{background:#0000002e;border:1px solid #f8fafc1f;border-radius:8px;margin-top:18px;padding:14px}.controller-debug strong{color:#f4d35e;text-transform:uppercase;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:1rem;display:block}.controller-debug p{color:#9aa4b2;margin:8px 0 0;font-size:.88rem}.game-layout{grid-template-columns:minmax(0,1fr) 290px;align-items:stretch;gap:22px;display:grid}.game-stage{background:#101214;border:1px solid #f8fafc24;border-radius:8px;min-width:0;min-height:520px;overflow:hidden}.phaser-game{place-items:center;width:100%;height:100%;min-height:520px;display:grid}.phaser-game canvas{width:100%;height:100%;display:block}.game-sidebar{border-left:1px solid #f8fafc24;padding-left:22px}.game-sidebar p{color:#cbd5e1;line-height:1.55}.game-actions{align-items:center;gap:12px;display:flex}.debug-toggle{color:#f8fafc;background:#f8fafc1f;border-radius:8px;align-items:center;gap:8px;min-height:44px;padding:0 14px;font-weight:800;display:inline-flex}.movement-stats{gap:12px;margin:24px 0;display:grid}.spectator-panel{background:#0000002e;border:1px solid #f8fafc1f;border-radius:8px;gap:18px;padding:14px;display:grid}.spectator-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.spectator-actions button{color:#f8fafc;background:#f8fafc1f;min-height:58px;padding:0 10px}.help-overlay{z-index:20;background:#101214d1;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.help-card{background:#171a1d;border:1px solid #f8fafc29;border-radius:8px;width:min(440px,100%);padding:22px}.help-card h2{margin-bottom:12px}.help-card p{color:#cbd5e1;line-height:1.5}.round-summary{border-top:1px solid #f8fafc1f;gap:4px;margin:20px 0 18px;padding-top:14px;display:grid}.round-summary strong{letter-spacing:.04em;font-size:2rem}.round-summary span{color:#9aa4b2;font-size:.92rem}.avatar-list{gap:10px;margin:0 0 22px;padding:0;list-style:none;display:grid}.avatar-list li{color:#f8fafc;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:10px;font-size:.95rem;display:grid}.avatar-color{border-radius:999px;width:14px;height:14px}.avatar-list em{color:#9aa4b2;font-size:.8rem;font-style:normal}.objective-list{color:#f8fafc;gap:8px;margin:18px 0 0;padding-left:18px;display:grid}.objective-list li{color:#cbd5e1;padding-left:4px;line-height:1.4}.movement-stats div{border-top:1px solid #f8fafc1f;padding-top:12px}.movement-stats dt{color:#9aa4b2;text-transform:uppercase;font-size:.78rem;font-weight:800}.movement-stats dd{color:#f8fafc;margin:5px 0 0;font-size:1.08rem;font-weight:800}@media (width<=820px){.app-shell--lobby{align-items:start;padding:22px}.host-header,.phone-header,.game-header{flex-direction:column}.phone-surface--controller .phone-header{flex-direction:row}.host-layout,.join-block,.results-layout,.game-layout{grid-template-columns:1fr}.room-panel,.player-panel{padding:22px}.room-code-block strong{font-size:clamp(4.5rem,26vw,8rem)}.host-actions{flex-direction:column}.seed-panel{flex-direction:column;align-items:stretch}.room-options,.spectator-actions{grid-template-columns:1fr}.controller-meta{grid-template-columns:repeat(2,1fr)}.controller-play-area{grid-template-columns:1fr;gap:18px}.game-actions{flex-direction:column;align-items:stretch;width:100%}.game-sidebar{border-top:1px solid #f8fafc24;border-left:0;padding:20px 0 0}.game-stage,.phaser-game{min-height:360px}}@media (orientation:portrait) and (width<=820px){.phone-surface--active-controller{min-height:min(760px,100svh - 36px)}.phone-surface--active-controller .controller-rotate-prompt{color:#f8fafc;text-align:center;background:#f4d35e14;border:2px dashed #f4d35e6b;border-radius:8px;flex:1;align-content:center;place-items:center;gap:10px;padding:24px;display:grid}.controller-rotate-prompt strong,.controller-rotate-prompt span{display:block}.controller-rotate-prompt strong{color:#fff6b5;text-transform:uppercase;font-size:clamp(1.8rem,10vw,3.4rem);line-height:.95}.controller-rotate-prompt span{color:#cbd5e1;line-height:1.4}.phone-surface--active-controller .controller-play-area,.phone-surface--active-controller .controller-debug,.phone-surface--active-controller .ready-button{display:none}}@media (orientation:landscape) and (height<=520px){.app-shell--controller{padding:8px}.phone-surface--controller{width:100%;min-height:calc(100svh - 16px);padding:12px}.phone-surface--controller .phone-header{margin-bottom:8px}.phone-surface--controller .eyebrow{margin-bottom:4px;font-size:.64rem}.phone-surface--controller h1{font-size:clamp(1.35rem,7vh,2.25rem);line-height:.92}.phone-surface--controller .connection-badge{padding:5px 8px;font-size:.68rem}.phone-surface--active-controller .controller-meta{display:none}.controller-play-area{grid-template-columns:minmax(180px,.9fr) minmax(180px,1fr);gap:clamp(18px,9vw,72px)}.controller-pad--movement{grid-template-rows:repeat(3,minmax(52px,1fr));grid-template-columns:repeat(3,minmax(52px,1fr));gap:6px;width:min(212px,100%)}.controller-pad--actions{grid-template-rows:repeat(2,minmax(62px,1fr));grid-template-columns:repeat(2,minmax(76px,1fr));gap:12px;width:min(260px,100%)}.control-button{min-height:52px;padding:0 10px}.control-button--jump,.control-button--action{min-height:74px}.control-button__face{font-size:clamp(1.5rem,8vh,2.15rem)}.control-button__caption{font-size:.62rem}.phone-surface--active-controller .controller-debug{margin-top:8px;padding:8px 10px}.phone-surface--active-controller .controller-debug p{display:none}.phone-surface--active-controller .ready-button{min-height:36px;margin-top:8px}}
