:root{color:#f5f7fa;background:#0b0d12;font-family:Inter,system-ui,sans-serif;color-scheme:dark}*{box-sizing:border-box}html,body,#app{margin:0;width:100%;height:100%;min-width:100%;min-height:100%}body{overflow:hidden;background:#05070c}.match-screen-root,.match-route-root{position:fixed;inset:0;width:100vw;min-width:100vw;height:100vh;min-height:100vh;background:#000;overflow:hidden;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) env(safe-area-inset-bottom,0) env(safe-area-inset-left,0)}@supports (height: 100dvh){.match-screen-root,.match-route-root{height:100dvh;min-height:100dvh}}.app-shell{position:relative;width:100%;height:100%;min-width:100%;min-height:100%;background:#05070c;overflow:hidden}.stage{position:relative;width:100%;height:100%;background:#000}.stage canvas{display:block}.stage-loader{position:absolute;inset:0;z-index:3;display:grid;place-items:center;padding:calc(env(safe-area-inset-top,0px) + 24px) calc(env(safe-area-inset-right,0px) + 24px) calc(env(safe-area-inset-bottom,0px) + 24px) calc(env(safe-area-inset-left,0px) + 24px);background:radial-gradient(circle at 50% 16%,rgba(107,142,180,.18),transparent 28%),linear-gradient(180deg,#081019,#0d1623 50%,#101319 50%,#07090d)}.stage-loader[hidden]{display:none}.stage-loader-card{width:min(320px,100%);display:grid;gap:14px;padding:22px 20px;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:#080c12eb;box-shadow:0 20px 60px #00000059;text-align:center}.stage-loader-title{font-size:22px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.stage-loader-copy{color:#ffffffbd;line-height:1.45}.stage-loader-bar{height:10px;border-radius:999px;overflow:hidden;background:#ffffff1a}.stage-loader-fill{height:100%;width:100%;transform:scaleX(0);transform-origin:left center;background:linear-gradient(90deg,#5cccff,#8b5cf6)}.stage-loader-status{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#ffffff9e}.hud{position:absolute;inset:0 0 auto;padding:18px 22px;display:grid;gap:12px;pointer-events:none;text-shadow:0 2px 10px rgba(0,0,0,.45)}.hud-row{display:grid;grid-template-columns:1fr auto 1fr;gap:12px;align-items:center}.bar{height:18px;border:2px solid rgba(255,255,255,.82);border-radius:999px;background:#0000007a;overflow:hidden;box-shadow:0 8px 18px #00000047,inset 0 0 0 1px #ffffff14}.bar-fill{height:100%;width:100%;background:linear-gradient(90deg,#32d074,#f6e05e 70%,#ff5a5f);transform-origin:left center}.bar-fill.cpu{transform-origin:right center}.hud-title{text-align:center;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:15px}.status{justify-self:center;min-height:24px;padding:6px 14px;border-radius:999px;background:#00000085;border:1px solid rgba(255,255,255,.08);font-size:14px}.combo-prompt{justify-self:center;display:grid;gap:6px;min-width:220px;padding:10px 14px;border:1px solid rgba(255,255,255,.16);border-radius:14px;background:#070b12c7;text-align:center}.combo-prompt[hidden]{display:none}.combo-prompt-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ffffffa6}.combo-prompt-row{display:flex;gap:10px;align-items:baseline;justify-content:center}.combo-prompt-word{font-size:24px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.combo-prompt-typed{min-width:48px;padding-bottom:2px;border-bottom:2px solid rgba(92,204,255,.65);color:#5cccff;font-size:16px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.match-overlay{position:absolute;inset:0;display:grid;place-items:center;padding:24px;background:#04070c73;pointer-events:auto}.match-overlay[hidden]{display:none}.match-overlay-card{width:min(420px,100%);padding:24px;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:#080c12f0;box-shadow:0 20px 60px #00000059;text-align:center}.match-overlay-title{font-size:26px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.match-overlay-hint{margin-top:10px;color:#ffffffc2;line-height:1.45}.match-overlay-button{margin-top:18px;padding:12px 18px;border:0;border-radius:999px;background:linear-gradient(90deg,#5cccff,#8b5cf6);color:#081019;font-weight:800;cursor:pointer}.info-stack{position:absolute;inset:auto 16px 16px auto;display:grid;gap:10px;width:min(330px,calc(100vw - 32px))}.controls{max-width:100%;padding:10px 12px;border-radius:12px;background:#00000080;border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 24px #0003;font-size:13px;line-height:1.4;color:#ffffffd9}.controls.mobile-friendly{background:#00000057}.touch-controls{position:absolute;inset:auto 0 0;z-index:4;display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding:18px;pointer-events:none}.touch-joystick-cluster,.touch-action-cluster{pointer-events:auto}.touch-joystick-cluster{display:grid;gap:10px;justify-items:start}.touch-cluster-label{padding-left:8px;color:#ffffffb8;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.4)}.touch-joystick{position:relative;width:132px;height:132px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:#ffffff14;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);touch-action:none}.touch-joystick.active{background:#ffffff1f}.touch-joystick-thumb{position:absolute;top:50%;left:50%;width:56px;height:56px;border-radius:999px;transform:translate(-50%,-50%);margin-left:-28px;margin-top:-28px;background:#5cccff52;border:1px solid rgba(255,255,255,.34);box-shadow:0 8px 22px #0000003d}.touch-action-cluster{display:grid;grid-template-columns:repeat(2,minmax(0,84px));gap:12px;justify-items:stretch}.touch-button{min-height:64px;padding:0 14px;border:1px solid rgba(255,255,255,.18);border-radius:999px;background:#ffffff1a;color:#fffffff0;font:inherit;font-size:14px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);touch-action:manipulation}.touch-button.active{background:#5cccff52;border-color:#5cccff85}.touch-button-small{min-height:48px;font-size:12px}.match-viewport-assist{position:absolute;inset:0;z-index:5;display:grid;place-items:center;padding:20px;background:#06090ead}.match-viewport-assist[hidden]{display:none}.match-viewport-card{width:min(360px,100%);padding:20px;border:1px solid rgba(255,255,255,.12);border-radius:20px;background:#0a0e14f5;box-shadow:0 20px 60px #00000061;text-align:center}.match-viewport-title{font-size:24px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.match-viewport-copy{margin-top:10px;color:#ffffffc2;line-height:1.5}.match-viewport-button{margin-top:18px;padding:12px 18px;border:0;border-radius:999px;background:linear-gradient(90deg,#5cccff,#8b5cf6);color:#081019;font:inherit;font-weight:800}.combo-guide{max-width:100%;display:grid;gap:10px;padding:12px;border-radius:12px;background:#00000073;color:#ffffffd9}.combo-guide-section{display:grid;gap:6px}.combo-guide-title{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.combo-guide-list{display:grid;gap:4px}.combo-guide-entry{font-size:12px;line-height:1.45;color:#ffffffbd}.select-screen{width:100%;height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,rgba(66,89,120,.42),transparent 42%),linear-gradient(180deg,#141a24,#0b0f16)}.select-panel{width:min(1040px,100%);padding:28px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:#0a0e14eb;box-shadow:0 20px 60px #00000059}.select-title{margin:0 0 8px;font-size:32px;line-height:1.1}.select-subtitle{margin:0 0 24px;max-width:760px;color:#ffffffb8;line-height:1.5}.select-group{margin-top:20px}.select-group-title{margin:0 0 10px;font-size:15px;letter-spacing:.08em;text-transform:uppercase;color:#ffffffc2}.select-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.select-card{padding:14px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:#ffffff08;color:inherit;text-align:left;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}.select-card:hover{transform:translateY(-2px);border-color:#ffffff38}.select-card[data-selected=true]{border-color:#5cccffd9;background:#5cccff24}.select-card-swatch{width:100%;height:60px;border-radius:10px;margin-bottom:12px}.select-card-title{font-weight:700;margin-bottom:6px}.select-card-summary{font-size:13px;line-height:1.45;color:#ffffffb8}.select-summary{margin-top:24px;display:flex;gap:12px;align-items:center;justify-content:space-between}.select-summary-text{font-size:15px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.select-start{padding:12px 18px;border:0;border-radius:999px;background:linear-gradient(90deg,#5cccff,#8b5cf6);color:#081019;font-weight:800;cursor:pointer}.select-start:disabled{cursor:not-allowed;opacity:.65}.arcade-select-screen{--arcade-bg-top: #3b125b;--arcade-bg-mid: #180d2f;--arcade-bg-bottom: #070b16;--arcade-panel-border: rgba(255, 255, 255, .12);--arcade-panel-fill: rgba(12, 10, 28, .88);--arcade-text-soft: rgba(244, 239, 255, .76);--arcade-text-muted: rgba(220, 212, 255, .58);--arcade-neon-purple: #b45cff;--arcade-neon-orange: #ff9f43;--arcade-neon-green: #7dff7a;--arcade-neon-blue: #86d8ff;height:100%;min-height:100dvh;align-content:start;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;background:radial-gradient(circle at top,rgba(180,92,255,.34),transparent 28%),radial-gradient(circle at 85% 12%,rgba(255,159,67,.26),transparent 24%),radial-gradient(circle at 18% 78%,rgba(125,255,122,.14),transparent 22%),linear-gradient(180deg,var(--arcade-bg-top) 0%,var(--arcade-bg-mid) 38%,var(--arcade-bg-bottom) 100%)}.arcade-select-panel{width:min(1280px,100%);display:grid;gap:24px;border:1px solid var(--arcade-panel-border);border-radius:30px;background:linear-gradient(180deg,#ffffff0f,#ffffff05),linear-gradient(135deg,#b45cff14,#ff9f430d),var(--arcade-panel-fill);box-shadow:0 24px 70px #00000073,inset 0 1px #ffffff0d,0 0 0 1px #ffffff05}.arcade-mobile-hint{display:none;padding:12px 14px;border:1px solid rgba(180,92,255,.26);border-radius:16px;background:linear-gradient(135deg,#b45cff1f,#ff9f4314);color:var(--arcade-text-soft);font-size:13px;font-weight:700;line-height:1.45}.arcade-select-header{display:flex;gap:16px;align-items:flex-start;justify-content:space-between}.arcade-select-kicker{display:inline-flex;align-items:center;padding:6px 10px;border:1px solid rgba(180,92,255,.28);border-radius:999px;background:#b45cff1f;color:#f1d4ff;font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.arcade-select-title{margin-top:12px;font-size:clamp(38px,4vw,64px);color:#fff4ff;text-shadow:0 0 16px rgba(180,92,255,.28),0 0 28px rgba(255,159,67,.18);letter-spacing:.04em;text-transform:uppercase}.arcade-select-active-side{min-width:180px;padding:12px 16px;border:1px solid rgba(255,255,255,.1);border-radius:18px;background:#08081470;box-shadow:inset 0 0 0 1px #ffffff08;font-size:13px;font-weight:800;letter-spacing:.08em;text-align:center;text-transform:uppercase}.arcade-select-active-side[data-side=player]{color:var(--arcade-neon-green);box-shadow:inset 0 0 0 1px #7dff7a2e,0 0 24px #7dff7a2e}.arcade-select-active-side[data-side=cpu]{color:var(--arcade-neon-orange);box-shadow:inset 0 0 0 1px #ff9f432e,0 0 24px #ff9f432e}.arcade-select-subtitle{margin-bottom:0;max-width:840px;color:var(--arcade-text-soft)}.arcade-select-stage{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px) minmax(0,1fr);gap:18px;align-items:stretch}.arcade-preview{--select-accent: var(--arcade-neon-purple);--select-accent-glow: rgba(180, 92, 255, .28);min-width:0;min-height:0;padding:18px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:radial-gradient(circle at top,var(--select-accent-glow),transparent 42%),linear-gradient(180deg,#ffffff0d,#ffffff04),#0a0a18e0;color:inherit;cursor:pointer;display:grid;gap:14px;text-align:left;transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease}.arcade-preview:hover{transform:translateY(-2px)}.arcade-preview[data-active=true]{border-color:var(--select-accent);box-shadow:inset 0 0 0 1px #ffffff0d,0 18px 48px #0000003d,0 0 36px var(--select-accent-glow)}.arcade-preview[data-side=player][data-active=true]{outline:1px solid rgba(125,255,122,.32)}.arcade-preview[data-side=cpu][data-active=true]{outline:1px solid rgba(255,159,67,.32)}.arcade-preview-header{display:flex;gap:12px;align-items:center;justify-content:space-between}.arcade-preview-label,.arcade-preview-slot{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--arcade-text-soft)}.arcade-preview-slot{color:var(--select-accent)}.arcade-preview-portrait{min-height:320px;border-radius:20px;background:radial-gradient(circle at top,rgba(180,92,255,.14),transparent 46%),linear-gradient(180deg,#ffffff0a,#ffffff03),#050610e0;display:grid;place-items:center;overflow:hidden}.arcade-preview-image{width:auto;height:116%;max-width:none;object-fit:cover;image-rendering:pixelated;filter:drop-shadow(0 18px 32px rgba(0,0,0,.38)) drop-shadow(0 0 20px var(--select-accent-glow))}.arcade-preview-image[data-facing=left]{transform:scaleX(-1)}.arcade-preview-empty{color:var(--arcade-text-muted);font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.arcade-preview-copy{display:grid;gap:6px}.arcade-preview-name{font-size:clamp(26px,2.4vw,42px);font-weight:900;color:#fff6ff;text-shadow:0 0 22px rgba(180,92,255,.16);letter-spacing:.04em;line-height:1;text-transform:uppercase}.arcade-preview-subtitle{color:var(--select-accent);font-size:13px;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.arcade-preview-quote{color:var(--arcade-text-soft);font-size:14px;line-height:1.5}.arcade-roster{--select-accent: var(--arcade-neon-purple);display:grid;gap:14px;align-content:start;padding:16px;width:min(100%,320px);justify-self:center;border:1px solid rgba(180,92,255,.18);border-radius:24px;background:radial-gradient(circle at top,rgba(180,92,255,.12),transparent 48%),linear-gradient(180deg,#ffffff08,#ffffff03),#070814eb}.arcade-roster-title{justify-self:center;padding:8px 14px;border-radius:999px;background:#b45cff24;color:#f4dcff;font-size:12px;font-weight:800;letter-spacing:.16em;text-transform:uppercase}.arcade-roster-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.arcade-roster-card{--select-accent: var(--arcade-neon-purple);--select-accent-glow: rgba(180, 92, 255, .26);position:relative;padding:8px;border:1px solid rgba(255,255,255,.08);border-radius:14px;background:radial-gradient(circle at top,var(--select-accent-glow),transparent 42%),linear-gradient(180deg,#ffffff0a,#ffffff03),#080812eb;color:inherit;cursor:pointer;display:grid;gap:4px;transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease}.arcade-roster-card:hover{transform:translateY(-2px);border-color:#ffffff3d}.arcade-roster-card[data-selected-player=true]{border-color:var(--arcade-neon-green);box-shadow:inset 0 0 0 1px #7dff7a38,0 0 24px #7dff7a2e}.arcade-roster-card[data-selected-cpu=true]{border-color:var(--arcade-neon-orange);box-shadow:inset 0 0 0 1px #ff9f4338,0 0 24px #ff9f432e}.arcade-roster-slot{position:absolute;top:8px;left:8px;z-index:1;padding:3px 5px;border-radius:999px;background:#050810bd;font-size:11px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--arcade-text-muted)}.arcade-roster-thumbnail{width:100%;aspect-ratio:1;border-radius:10px;overflow:hidden;background:radial-gradient(circle at top,rgba(180,92,255,.16),transparent 52%),#00000075;display:grid;place-items:center}.arcade-roster-image{width:100%;height:100%;object-fit:cover;object-position:var(--thumbnail-position, center top);transform:scale(var(--thumbnail-scale, 2.7));transform-origin:center top;image-rendering:pixelated;filter:saturate(1.12) contrast(1.06)}.arcade-roster-card:nth-child(odd) .arcade-roster-image{transform:scale(var(--thumbnail-scale, 2.7))}.arcade-roster-card:nth-child(2n) .arcade-roster-image{transform:scaleX(-1) scale(var(--thumbnail-scale, 2.7))}.arcade-roster-name{position:absolute;right:8px;bottom:8px;left:8px;padding:6px 7px 4px;border-radius:10px;background:linear-gradient(180deg,transparent 0%,rgba(4,6,12,.82) 28%,rgba(4,6,12,.94) 100%);font-size:10px;font-weight:900;color:#fff7ff;letter-spacing:.12em;line-height:1.1;text-transform:uppercase}.arcade-roster-subtitle{display:none}.arcade-roster-badges{position:absolute;top:8px;right:8px;min-height:0;display:flex;gap:4px;align-items:center;justify-content:flex-end;flex-wrap:wrap}.arcade-roster-badge{padding:3px 6px;border-radius:999px;background:#050810d1;font-size:9px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}.arcade-roster-badge.player{background:#7dff7a29;color:var(--arcade-neon-green)}.arcade-roster-badge.cpu{background:#ff9f4329;color:var(--arcade-neon-orange)}.arcade-select-summary{margin-top:0;padding:18px 22px;border-radius:22px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,#b45cff1f,#ff9f4314),#060612d1;box-shadow:0 0 30px #b45cff14}.arcade-select-summary-copy{display:grid;gap:4px}.arcade-select-summary-hint{color:var(--arcade-text-soft);font-size:13px;line-height:1.4}.arcade-select-start{min-width:168px;background:linear-gradient(90deg,var(--arcade-neon-purple) 0%,var(--arcade-neon-orange) 100%);box-shadow:0 14px 36px #b45cff38,0 0 18px #ff9f4329}@media(max-width:1120px){.arcade-select-stage{grid-template-columns:repeat(2,minmax(0,1fr))}.arcade-roster{grid-column:1 / -1;order:3;width:min(100%,520px)}.arcade-roster-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.arcade-roster-card{padding:7px;border-radius:12px}.arcade-roster-slot{top:6px;left:6px;padding:2px 4px;font-size:9px}.arcade-roster-badges{top:6px;right:6px;gap:3px}.arcade-roster-badge{padding:2px 5px;font-size:8px}.arcade-roster-name{right:6px;bottom:6px;left:6px;padding:5px 5px 3px;font-size:8px;letter-spacing:.08em}}@media(max-width:720px){.arcade-select-screen{padding:16px;place-items:start stretch}.arcade-select-panel{padding:20px;gap:18px;border-radius:20px}.arcade-mobile-hint{display:block}.arcade-select-header,.arcade-select-summary{flex-direction:column;align-items:stretch}.arcade-select-header{gap:12px}.arcade-select-active-side{min-width:0}.arcade-select-stage{grid-template-columns:minmax(0,1fr);gap:14px}.arcade-roster{order:2;padding:14px}.arcade-preview[data-side=player]{order:1}.arcade-preview[data-side=cpu]{order:3}.arcade-preview-portrait{min-height:180px}.arcade-roster-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.arcade-preview{padding:14px;border-radius:18px}.arcade-preview-name{font-size:clamp(22px,7vw,32px)}.arcade-preview-quote{font-size:13px}.arcade-roster-card{padding:10px}.arcade-roster-subtitle{min-height:auto;font-size:11px}.arcade-select-summary{position:sticky;bottom:0;z-index:1;margin:0 -4px -4px;padding:16px;border:1px solid rgba(180,92,255,.2);background:linear-gradient(135deg,#b45cff29,#ff9f431f),#080c14f0;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.arcade-select-start{width:100%;min-width:0}}@media(max-width:720px)and (orientation:portrait){.arcade-select-stage{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch}.arcade-preview[data-side=player]{order:1}.arcade-preview[data-side=cpu]{order:2}.arcade-roster{grid-column:1 / -1;order:3;width:100%}.arcade-preview{height:100%;gap:10px;padding:12px}.arcade-preview-copy{grid-template-rows:auto auto 1fr}.arcade-preview-header{gap:8px}.arcade-preview-label,.arcade-preview-slot{font-size:10px}.arcade-preview-portrait{min-height:128px;border-radius:16px}.arcade-preview-name{font-size:clamp(16px,4.1vw,22px)}.arcade-preview-subtitle{font-size:10px;letter-spacing:.08em}.arcade-preview-quote{display:none}.arcade-roster{padding:10px}.arcade-roster-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.arcade-roster-card{padding:6px;border-radius:12px;gap:4px}.arcade-roster-thumbnail{border-radius:10px}.arcade-roster-slot{font-size:9px}.arcade-roster-name{font-size:8px;letter-spacing:.08em}.arcade-roster-badges{min-height:16px;gap:4px}.arcade-roster-badge{padding:2px 5px;font-size:8px}}@media(max-width:480px){.arcade-select-screen{padding:12px}.arcade-select-panel{padding:16px}.arcade-select-title{font-size:clamp(28px,10vw,38px)}.arcade-select-subtitle{font-size:14px}.arcade-roster-grid{grid-template-columns:1fr 1fr;gap:10px}.arcade-preview-portrait{min-height:150px}.arcade-preview-copy{gap:4px}}@media(max-width:820px)and (orientation:landscape){.arcade-mobile-hint{display:none}}.home-screen{width:100%;height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,rgba(66,89,120,.42),transparent 42%),linear-gradient(180deg,#141a24,#0b0f16)}.home-card{width:min(720px,100%);padding:28px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:#0a0e14eb;box-shadow:0 20px 60px #00000059}.home-actions{display:flex;flex-wrap:wrap;gap:12px}.join-room-form{margin-top:16px;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px}.join-room-input{min-width:0;padding:12px 16px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:#ffffff0a;color:inherit;font:inherit}.join-room-error{grid-column:1 / -1;min-height:20px;font-size:13px;color:#ffb6b6}.online-shell{width:100%;height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,rgba(66,89,120,.42),transparent 42%),linear-gradient(180deg,#141a24,#0b0f16)}.online-match-root{width:100%;height:100%}.online-panel{width:min(1040px,100%);padding:28px;border:1px solid rgba(255,255,255,.08);border-radius:24px;background:#0a0e14eb;box-shadow:0 20px 60px #00000059;display:grid;gap:18px}.online-title{margin:0;font-size:32px;line-height:1.1}.online-subtitle{margin:0;max-width:760px;color:#ffffffb8;line-height:1.5}.online-link-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px}.online-link{min-width:0;padding:12px 16px;border:1px solid rgba(255,255,255,.14);border-radius:999px;background:#ffffff0a;color:inherit;font:inherit}.online-button{padding:12px 18px;border-radius:999px;font-weight:800;cursor:pointer}.online-button.primary{border:0;background:linear-gradient(90deg,#5cccff,#8b5cf6);color:#081019}.online-button.secondary{border:1px solid rgba(255,255,255,.16);background:#ffffff0a;color:inherit}.online-button:disabled{cursor:not-allowed;opacity:.65}.online-status{color:#ffffffc7;line-height:1.5}.online-player-grid{display:grid;gap:12px}.online-card{padding:18px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:#ffffff08}.online-card-title{margin:0 0 8px;font-size:18px;font-weight:700}.online-card-copy{margin:0;color:#ffffffb8;line-height:1.5}.online-room-link{display:inline-flex;margin-top:10px;color:#7edbff;font-weight:700;text-decoration:none}.online-room-code{margin-top:10px;font-size:28px;font-weight:800;letter-spacing:.2em}.online-players{display:grid;gap:12px;margin-top:14px}.online-player-card{padding:14px;border-radius:14px;background:#00000042}.online-player-title{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#ffffffa3}.online-player-card[data-active=true]{outline:1px solid rgba(92,204,255,.7)}.online-player-name{font-size:14px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.online-player-meta{margin-top:6px;font-size:13px;color:#ffffffb8}.online-fighter-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.online-fighter-card{padding:14px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:#ffffff08;color:inherit;text-align:left;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}.online-fighter-card:hover{transform:translateY(-2px);border-color:#ffffff38}.online-fighter-card[data-selected=true]{border-color:#5cccffd9;background:#5cccff24}.online-fighter-swatch{width:100%;height:60px;border-radius:10px;margin-bottom:12px}.online-fighter-title{font-weight:700;margin-bottom:6px}.online-fighter-summary{font-size:13px;line-height:1.45;color:#ffffffb8}.online-actions{display:flex;flex-wrap:wrap;gap:12px}.online-message{min-height:20px;font-size:13px;color:#ffb6b6}@media(max-width:960px){body{overflow:auto}.match-screen-root,.match-route-root{padding:max(env(safe-area-inset-top,0),10px) max(env(safe-area-inset-right,0),10px) max(env(safe-area-inset-bottom,0),10px) max(env(safe-area-inset-left,0),10px)}.hud{padding:14px;gap:8px}.hud-row{grid-template-columns:1fr;gap:8px}.hud-title{order:-1;font-size:13px}.bar{height:16px}.status{min-height:0;padding:5px 12px;font-size:12px}.info-stack{inset:auto 12px 12px;width:auto}.match-route-root .info-stack{inset:auto 12px 8px}.controls{font-size:12px;line-height:1.35}.select-screen,.home-screen,.online-shell{height:auto;min-height:100%;place-items:stretch;padding:16px}.select-panel,.home-card,.online-panel{width:100%;padding:20px;border-radius:20px}.select-title,.online-title{font-size:28px}.select-subtitle,.online-subtitle{margin-bottom:18px;font-size:14px}.select-summary{flex-direction:column;align-items:stretch}.select-summary-text{font-size:14px}.home-actions,.online-actions{flex-direction:column}.select-start,.online-button{width:100%}.join-room-form,.online-link-row{grid-template-columns:1fr}}@media(max-width:720px){.match-route-root .info-stack{inset:auto 10px 10px}.match-route-root .controls{padding:8px 10px;font-size:11px}.match-route-root .hud{padding:8px 10px 6px}.match-route-root .bar{height:14px}.match-route-root .status{padding:4px 10px;font-size:11px}.touch-controls{gap:12px;padding:12px}.touch-joystick{width:116px;height:116px}.touch-joystick-thumb{width:50px;height:50px;margin-left:-25px;margin-top:-25px}.touch-action-cluster{grid-template-columns:repeat(2,minmax(0,72px));gap:10px}.touch-button{min-height:56px;padding:0 10px;font-size:12px}.touch-button-small{min-height:44px}}@media(max-width:720px)and (orientation:portrait){.app-shell,.match-screen-root,.match-route-root{min-height:100dvh}.touch-controls{display:none}}
