:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#10131d;color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#app{width:100%;min-width:320px;height:100%;margin:0}button,input,select{font:inherit}button{min-height:44px;border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:0 16px;background:#263244;color:#fff;cursor:pointer}button:hover{background:#314057}button:disabled,input:disabled,select:disabled{cursor:not-allowed;opacity:.48}.primary{border-color:transparent;background:#28b485;color:#071318;font-weight:800}.primary:hover{background:#40f0aa}.ghost{background:#ffffff14}.shell{display:grid;min-height:100%;place-items:center;padding:24px;background:linear-gradient(135deg,rgba(255,209,102,.12),transparent 34%),linear-gradient(315deg,rgba(93,224,230,.12),transparent 38%),#10131d}.lobby{width:min(100%,760px);padding:24px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#0f172adb;box-shadow:0 24px 90px #00000047}.lobby.wide{width:min(100%,1040px)}.home-card{display:grid;gap:22px}.brand,.topline,.room-header{display:flex;align-items:center;justify-content:space-between;gap:18px}.brand{justify-content:flex-start}.home-brand{padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.1)}.language-switch{display:inline-grid;grid-template-columns:repeat(2,42px);gap:4px;margin-left:auto;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:4px;background:#ffffff0f}.language-switch button{min-height:34px;border:0;padding:0;background:transparent;color:#b8c4d8;font-size:.82rem;font-weight:900}.language-switch button.selected{background:#ffd166;color:#111827}.home-thumb{width:76px;height:76px;flex:0 0 76px;border:2px solid rgba(255,255,255,.16);border-radius:8px;object-fit:cover;box-shadow:0 12px 28px #00000047}h1,p{margin:0}h1{font-size:clamp(2rem,7vw,4.25rem);line-height:.95}h2{margin:0;font-size:1.1rem;line-height:1.2}.brand p,.home-copy p,.note,.eyebrow,.player-card span,.room-summary{color:#b8c4d8}.home-copy{display:grid;gap:8px;max-width:640px}.home-copy h2{font-size:clamp(1.25rem,3vw,1.75rem)}.player-panel,.actions,.room-layout,.score-list{margin-top:24px}label{display:grid;gap:8px;color:#dbeafe;font-weight:700}input,select{min-height:44px;width:100%;border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:0 12px;background:#111827;color:#f8fafc}.compact{max-width:430px}.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(132px,1fr));gap:10px;margin-top:16px}.cat-chip{display:flex;align-items:center;justify-content:flex-start;gap:10px;min-width:0}.cat-chip small{margin-left:auto;color:#9fb0c7;font-size:.75rem;font-weight:800}.cat-chip.selected{outline:2px solid #ffd166}.cat-chip.taken{background:#ffffff0a}.cat-dot{display:inline-block;width:16px;height:16px;flex:0 0 16px;border:2px solid rgba(255,255,255,.78);border-radius:50%}.actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.home-actions{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:0}.join-form{display:grid;grid-template-columns:1fr auto;gap:12px}.hidden{display:none}.note{margin-top:18px;font-size:.95rem;line-height:1.5}.settings-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:22px}.span,.map-picker{grid-column:1 / -1}.map-picker{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;margin:0;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:16px}.map-picker legend{padding:0 8px;color:#ffd166;font-weight:800}.controls-summary{display:grid;gap:14px;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:16px;background:#ffffff0b}.controls-summary .section-title{margin-bottom:0}.controls-summary .section-title span{color:#b8c4d8;font-size:.9rem}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.control-row{display:grid;grid-template-columns:minmax(112px,auto) 1fr;align-items:center;gap:12px;min-height:48px;border-radius:8px;padding:8px 10px;background:#1118279e}.key-group{display:flex;flex-wrap:wrap;gap:5px}kbd{display:inline-grid;min-width:30px;height:30px;place-items:center;border:1px solid rgba(255,255,255,.22);border-bottom-width:3px;border-radius:6px;padding:0 7px;background:#e5e7eb;color:#111827;font-family:inherit;font-size:.78rem;font-weight:900;line-height:1}.map-option{position:relative;display:grid;grid-template-columns:auto 74px 1fr;align-items:center;gap:12px;min-height:74px;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px;background:#ffffff0b;font-weight:600}.map-option input{min-height:auto;width:auto}.map-option:has(input:checked){border-color:#ffd166b3;background:#ffd1661c}.map-option:has(input:disabled){opacity:.5}.map-preview{position:relative;display:block;width:74px;aspect-ratio:16 / 9;overflow:hidden;border:1px solid rgba(255,255,255,.16);border-radius:6px;background:#18243a;box-shadow:inset 0 -18px 34px #0000002e}.map-preview:before{position:absolute;inset:0;content:"";background:radial-gradient(circle at 18% 30%,rgba(255,255,255,.22),transparent 8%),linear-gradient(180deg,rgba(255,255,255,.1),transparent 60%)}.map-theme-greenhouse{background:#12352e}.map-theme-subway{background:#1e2330}.map-theme-arcade{background:#201739}.map-theme-bakery{background:#3a2431}.map-theme-dojo{background:#2e2438}.map-theme-lab{background:#162c36}.map-theme-harbor{background:#183140}.preview-platform,.preview-hazard,.preview-booster{position:absolute;display:block;border-radius:999px}.preview-platform{background:#6fd4dd;box-shadow:0 1px #00000052}.preview-hazard{background:#ff4d6d;box-shadow:0 0 8px #ff4d6db3}.preview-booster{background:#40f99b;box-shadow:0 0 8px #40f99bb3}.preview-booster.jump{background:#ffd166;box-shadow:0 0 8px #ffd166b3}.room-header h1{letter-spacing:0}.eyebrow{font-size:.78rem;font-weight:800;text-transform:uppercase}.room-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}.section-title{display:flex;align-items:end;justify-content:space-between;gap:12px;margin-bottom:10px}.roster{display:grid;gap:10px}.room-side{display:grid;align-content:start;gap:18px}.cat-selection{display:grid;gap:2px}.cat-preview-card{display:grid;grid-template-columns:48px 1fr 48px;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:14px;background:#ffffff0d}.cat-nav{min-height:48px;border-radius:50%;padding:0;font-size:1.25rem;font-weight:900}.cat-preview{display:grid;justify-items:center;gap:8px;min-width:0;text-align:center}.cat-preview strong{font-size:1.25rem}.cat-preview>span{color:#b8c4d8;font-size:.9rem}.pixel-cat{display:block;width:152px;height:152px;image-rendering:pixelated;filter:drop-shadow(0 18px 0 rgba(0,0,0,.16))}.css-cat{--cat-body: #f28c28;--cat-accent: #ffcf75;--cat-ear: #ffb347;position:relative;width:132px;height:112px;image-rendering:pixelated}.css-cat span{position:absolute;display:block}.css-cat .body{left:42px;bottom:20px;width:44px;height:50px;border:5px solid #111827;border-radius:0;background:var(--cat-body);box-shadow:inset 0 -10px #0000001f}.css-cat .head{left:39px;bottom:68px;width:52px;height:42px;border:5px solid #111827;border-radius:0;background:var(--cat-body);box-shadow:inset 0 -8px #0000001f}.css-cat .ear{bottom:105px;width:20px;height:24px;border:4px solid #111827;border-bottom:0;background:var(--cat-ear);clip-path:polygon(50% 0,100% 100%,0 100%)}.css-cat .ear.left{left:44px;transform:rotate(-12deg)}.css-cat .ear.right{left:73px;transform:rotate(17deg)}.css-cat .eye{bottom:91px;width:8px;height:10px;border-radius:0;background:#111827;box-shadow:inset 2px 2px #fff}.css-cat .eye.left{left:53px}.css-cat .eye.right{left:73px}.css-cat .muzzle{left:58px;bottom:79px;width:22px;height:12px;border-radius:0;background:var(--cat-accent)}.css-cat .tail{right:9px;bottom:56px;width:34px;height:10px;border:4px solid #111827;border-radius:0;background:var(--cat-body);transform:rotate(10deg)}.css-cat .leg{bottom:5px;width:16px;height:22px;border:4px solid #111827;border-radius:0;background:var(--cat-body)}.css-cat .leg.left{left:50px}.css-cat .leg.right{right:42px}.css-cat:before,.css-cat:after{position:absolute;z-index:2;bottom:42px;width:20px;height:14px;border:4px solid #111827;border-radius:0;background:var(--cat-body);content:""}.css-cat:before{left:30px;transform:rotate(16deg)}.css-cat:after{right:27px;transform:rotate(-16deg)}.css-cat.striped .body,.css-cat.striped .head{background:repeating-linear-gradient(78deg,transparent 0 11px,rgba(0,0,0,.26) 12px 16px),var(--cat-body)}.room-cat-grid{grid-template-columns:repeat(auto-fit,minmax(168px,1fr));margin-top:0}.player-card,.score-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-height:52px;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 12px;background:#ffffff0d}.player-card.muted{display:block;color:#94a3b8}.room-summary{border-top:1px solid rgba(255,255,255,.12);padding-top:16px;line-height:1.6}.host-panel{display:grid;gap:10px;padding:16px;border:1px solid rgba(255,209,102,.22);border-radius:8px;background:#ffd16614}.muted-panel{border-color:#ffffff1f;background:#ffffff0d;color:#b8c4d8;line-height:1.45}.game-shell{position:relative;display:grid;width:100%;height:100%;min-height:100%;place-items:center;overflow:hidden;background:#050816}.game-root{width:100%;height:100%;min-width:100vw;min-height:100vh}.game-root canvas{display:block;width:100%;height:100%;image-rendering:pixelated;image-rendering:crisp-edges}.game-topbar{position:fixed;top:max(12px,env(safe-area-inset-top));right:12px;left:12px;z-index:5;display:flex;align-items:flex-start;justify-content:flex-end;gap:12px;pointer-events:none}.game-topbar button,.game-topbar div{pointer-events:auto}#round-feed{max-width:min(680px,62vw);border-radius:8px;padding:10px 12px;background:#080d1994;color:#e5e7eb;font-size:.9rem}.mobile-controls{position:fixed;right:16px;bottom:max(16px,env(safe-area-inset-bottom));left:16px;z-index:6;display:none;align-items:flex-end;justify-content:space-between;pointer-events:none}.pad{display:flex;gap:10px;pointer-events:auto}.pad button{width:58px;height:58px;border-radius:50%;padding:0;background:#f8fafc2b;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:1.35rem;font-weight:900}.score-list{display:grid;gap:10px}.score-row{grid-template-columns:42px 1fr auto}.toast{position:fixed;bottom:22px;left:50%;z-index:10;transform:translate(-50%);border-radius:8px;padding:12px 16px;background:#ffd166;color:#111827;font-weight:800}@media(hover:none),(pointer:coarse){.mobile-controls{display:flex}}@media(max-width:760px){.shell{padding:12px}.lobby{padding:18px}.brand,.topline,.room-header{align-items:stretch;flex-direction:column}.language-switch{margin-left:0}.actions,.home-actions,.settings-grid,.room-layout,.join-form,.control-row{grid-template-columns:1fr}.room-summary{border-left:0;border-top:1px solid rgba(255,255,255,.12);padding-top:16px;padding-left:0}#round-feed{display:none}.pad button{width:54px;height:54px}}
