@import"https://fonts.googleapis.com/css2?family=Press+Start+2P&family=JetBrains+Mono:wght@400;700&family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #0a0a0a;--bg-2: #121212;--fg: #f5f1e8;--fg-muted: #8a8275;--border: #2a2520;--border-strong: #f5f1e8;--accent: #ff5722;--accent-fg: #0a0a0a;--danger: #f87171;--success: #a3e635;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--font-display: "Press Start 2P", "JetBrains Mono", ui-monospace, monospace;color-scheme:dark;font-family:var(--font-sans);color:var(--fg);background:var(--bg);-webkit-text-size-adjust:100%}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);min-height:100vh}body{padding-top:env(safe-area-inset-top,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);padding-bottom:env(safe-area-inset-bottom,0);box-sizing:border-box;background-image:repeating-linear-gradient(to bottom,transparent 0,transparent 3px,rgba(255,255,255,.025) 3px,rgba(255,255,255,.025) 4px)}.play-root,.play-stage,.canvas-wrapper,.play-canvas{background-image:none!important}h1,h2,h3{font-family:var(--font-display);font-weight:400;letter-spacing:.05em;line-height:1.4;margin:0 0 1rem}h1{font-size:1.25rem}h2{font-size:.95rem;margin-top:1.5rem}h3{font-size:.75rem;text-transform:uppercase;color:var(--fg-muted)}code,pre{font-family:var(--font-mono);font-size:.875em;color:var(--accent)}a{color:var(--fg);text-decoration:underline;text-decoration-color:var(--accent);text-underline-offset:3px;text-decoration-thickness:2px}a:hover{color:var(--accent)}.muted{color:var(--fg-muted)}.error{color:var(--danger)}.notice{color:var(--success)}.centered{max-width:40rem;margin:0 auto}.row{display:flex;align-items:center;gap:.75rem}header.row{justify-content:space-between;margin-bottom:2rem}.badge{display:inline-block;padding:.125rem .5rem;border:2px solid var(--accent);color:var(--accent);font-family:var(--font-display);font-size:.625rem;letter-spacing:.05em;text-transform:uppercase;line-height:1.4}.form{display:grid;gap:1rem;margin:1.5rem 0}.form label{display:grid;gap:.375rem;font-size:.875rem;font-weight:500}.form small{color:var(--fg-muted);font-size:.75rem}input,select{padding:.625rem .75rem;font:inherit;font-family:var(--font-mono);background:var(--bg-2);color:var(--fg);border:2px solid var(--border-strong);border-radius:0;outline:none}input:focus,select:focus{border-color:var(--accent)}select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--fg) 50%),linear-gradient(135deg,var(--fg) 50%,transparent 50%);background-position:right .75rem center,right .5rem center;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:1.75rem}button,.btn-link{display:inline-block;padding:.5rem 1rem;font:inherit;font-weight:600;font-family:var(--font-sans);border:2px solid var(--border-strong);background:var(--bg);color:var(--fg);cursor:pointer;text-decoration:none;letter-spacing:.025em;position:relative;transition:transform .1s ease,background .1s ease}@media(hover:hover)and (pointer:fine){button:hover:not(:disabled),.btn-link:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}}button:active:not(:disabled),.btn-link:active{transform:translate(2px,2px)}button:disabled{opacity:.45;cursor:not-allowed}button[type=submit]{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}button[type=submit]:hover:not(:disabled){background:var(--fg);color:var(--bg);border-color:var(--fg)}.users,.bindings,.games-table{width:100%;border-collapse:collapse}.users th,.users td,.bindings th,.bindings td{text-align:left;padding:.625rem .75rem;border-bottom:2px solid var(--border)}.users th,.bindings th{font-family:var(--font-display);font-size:.625rem;text-transform:uppercase;color:var(--fg-muted)}.games{list-style:none;margin:0;padding:0;display:grid;gap:.75rem}.game-card{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid var(--border-strong);background:var(--bg-2)}.game-card-icon{width:2rem;height:1.5rem;flex-shrink:0;color:var(--accent);image-rendering:pixelated}.game-card-body{flex:1;min-width:0}.game-name{font-family:var(--font-display);font-size:.875rem;margin-bottom:.25rem}.game-desc{margin-top:.25rem;font-size:.875rem}.game-meta{margin-top:.5rem;font-size:.75rem;font-family:var(--font-mono);color:var(--fg-muted)}.play-root{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg);color:var(--fg);touch-action:manipulation;padding-top:env(safe-area-inset-top,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0);padding-bottom:env(safe-area-inset-bottom,0)}.play-root:has(.touch-gamepad){padding-bottom:0}.play-root-cssfs{z-index:9999}.play-controls-bar{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-2);border-bottom:2px solid var(--border);gap:.5rem;flex-wrap:wrap;position:absolute;top:env(safe-area-inset-top,0);left:env(safe-area-inset-left,0);right:env(safe-area-inset-right,0);z-index:5;transform:translateY(0);transition:transform .18s ease}.play-controls-bar-hidden{transform:translateY(calc(-100% - env(safe-area-inset-top,0)));pointer-events:none}.play-reveal-strip{position:absolute;top:0;left:0;right:0;height:8px;z-index:4}@media(hover:none){.play-reveal-strip{display:none}}.play-controls-bar button{border-color:var(--fg);color:var(--fg);background:transparent;padding:.375rem .75rem;font-size:.75rem}.play-game-title{font-family:var(--font-display);font-size:.75rem;letter-spacing:.05em}.play-buttons{flex-wrap:wrap;gap:.375rem}.ctrl-assign{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-family:var(--font-display);letter-spacing:.05em}.ctrl-assign select{padding:.25rem .5rem;font-family:var(--font-sans);font-size:.875rem;background:var(--bg);color:var(--fg);border:2px solid var(--border-strong)}.play-stage{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;overflow:hidden;background:#000}.canvas-wrapper{display:flex;align-items:center;justify-content:center;background:#000}.canvas-wrapper[data-fit=stretch],.canvas-wrapper[data-fit=aspect]{width:100%;height:100%}.canvas-wrapper[data-fit=original]{width:max-content;height:max-content;max-width:100%;max-height:100%;overflow:auto}.play-canvas{background:#000;image-rendering:pixelated;display:block}.canvas-wrapper[data-fit=stretch] .play-canvas{width:100%;height:100%;object-fit:fill}.canvas-wrapper[data-fit=aspect] .play-canvas{width:100%;height:100%;object-fit:contain}.canvas-wrapper[data-fit=original] .play-canvas{width:640px;height:480px}.play-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0aeb;z-index:10;gap:1rem}.play-overlay p{font-family:var(--font-display);font-size:.75rem;letter-spacing:.05em}.play-notice{position:absolute;top:4rem;left:50%;transform:translate(-50%);padding:.5rem 1rem;background:var(--bg);border:2px solid var(--accent);color:var(--accent);font-family:var(--font-display);font-size:.625rem;letter-spacing:.05em;text-transform:uppercase;z-index:20}.room-bar{display:flex;flex-wrap:wrap;gap:.5rem 1rem;padding:.5rem .75rem;background:var(--bg-2);border-bottom:2px solid var(--border);font-size:.875rem}.room-bar-user{display:inline-flex;align-items:center;gap:.375rem}.room-bar-badge{font-size:.875rem}:root{--touch-dpad-size: 9rem;--touch-face-btn-size: 3.25rem;--touch-face-btn-gap: .625rem}.touch-gamepad{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;padding:.5rem .75rem .75rem;background:var(--bg);border-top:2px solid var(--border);user-select:none;-webkit-user-select:none;touch-action:none;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0))}.touch-gamepad button,.touch-gamepad .touch-dpad-wedge{-webkit-tap-highlight-color:transparent}.touch-gamepad button:focus,.touch-gamepad button:focus-visible{outline:none}.touch-gamepad-start-row{display:flex;justify-content:center}.touch-start{border:2px solid var(--fg);background:var(--bg-2);color:var(--fg);font-family:var(--font-display);font-size:.6rem;padding:.375rem 1.5rem;letter-spacing:.05em;cursor:pointer}.touch-gamepad-controls{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.touch-gamepad-dpad{position:relative;width:var(--touch-dpad-size);height:var(--touch-dpad-size);flex-shrink:0;touch-action:none}.touch-dpad-wedge{position:absolute;inset:0;background:var(--bg-2);border:2px solid var(--fg);color:var(--fg);font-size:1.1rem;display:flex;align-items:center;justify-content:center;pointer-events:none;box-sizing:border-box}.touch-dpad-up{clip-path:polygon(0% 0%,100% 0%,65% 30%,50% 50%,35% 30%);align-items:flex-start;padding-top:.4rem}.touch-dpad-down{clip-path:polygon(0% 100%,100% 100%,65% 70%,50% 50%,35% 70%);align-items:flex-end;padding-bottom:.4rem}.touch-dpad-left{clip-path:polygon(0% 0%,0% 100%,30% 65%,50% 50%,30% 35%);justify-content:flex-start;padding-left:.5rem}.touch-dpad-right{clip-path:polygon(100% 0%,100% 100%,70% 65%,50% 50%,70% 35%);justify-content:flex-end;padding-right:.5rem}.touch-dpad-wedge.active{background:var(--accent);color:var(--accent-fg)}.touch-joystick{width:var(--touch-dpad-size);height:var(--touch-dpad-size);border-radius:50%;background:var(--bg-2);border:2px solid var(--fg);position:relative;flex-shrink:0;touch-action:none}.touch-joystick-thumb{position:absolute;top:50%;left:50%;width:calc(var(--touch-dpad-size) * .45);height:calc(var(--touch-dpad-size) * .45);margin-top:calc(var(--touch-dpad-size) * -.225);margin-left:calc(var(--touch-dpad-size) * -.225);border-radius:50%;background:var(--fg);border:2px solid var(--bg);pointer-events:none}.touch-gamepad-face{display:grid;grid-template-columns:repeat(3,var(--touch-face-btn-size));grid-template-rows:repeat(2,var(--touch-face-btn-size));gap:var(--touch-face-btn-gap);width:max-content}.touch-face-btn{border:2px solid var(--fg);background:var(--bg-2);color:var(--fg);font-family:var(--font-display);font-size:.85rem;border-radius:50%;padding:0;width:var(--touch-face-btn-size);height:var(--touch-face-btn-size);display:flex;align-items:center;justify-content:center;cursor:pointer}.touch-face-x{grid-column:1;grid-row:1}.touch-face-y{grid-column:2;grid-row:1}.touch-face-z{grid-column:3;grid-row:1}.touch-face-a{grid-column:1;grid-row:2}.touch-face-b{grid-column:2;grid-row:2}.touch-face-c{grid-column:3;grid-row:2}.touch-face-btn.active,.touch-start.active{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}@media(orientation:landscape)and (max-height:480px){:root{--touch-translucent-bg: rgba(18, 18, 18, .55);--touch-translucent-border: rgba(245, 241, 232, .7);--touch-landscape-bottom: 1.25rem}.touch-gamepad{position:absolute;inset:0;background:transparent;border-top:none;pointer-events:none;padding:0}.touch-gamepad-dpad .touch-dpad-wedge,.touch-gamepad-face .touch-face-btn,.touch-gamepad-start-row .touch-start{background:var(--touch-translucent-bg);border-color:var(--touch-translucent-border);color:var(--touch-translucent-border)}.touch-gamepad-dpad .touch-dpad-wedge.active{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.touch-gamepad-controls{pointer-events:none;position:static}.touch-gamepad-dpad{pointer-events:auto;position:absolute;left:1rem;bottom:var(--touch-landscape-bottom)}.touch-gamepad-face{pointer-events:auto;position:absolute;right:1rem;bottom:var(--touch-landscape-bottom)}.touch-gamepad-start-row{pointer-events:none;position:absolute;right:1rem;bottom:calc(var(--touch-landscape-bottom) + 2 * var(--touch-face-btn-size) + var(--touch-face-btn-gap) + .5rem);width:calc(3 * var(--touch-face-btn-size) + 2 * var(--touch-face-btn-gap));display:flex;justify-content:center;top:auto;left:auto;transform:none}.touch-gamepad-start-row .touch-start{pointer-events:auto}.touch-gamepad-controls .touch-joystick{pointer-events:auto;position:absolute;left:1rem;bottom:var(--touch-landscape-bottom);background:var(--touch-translucent-bg);border-color:var(--touch-translucent-border)}}.save-panel-overlay{position:fixed;inset:0;background:#0a0a0abf;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.save-panel{background:var(--bg);color:var(--fg);border:2px solid var(--border-strong);width:100%;max-width:36rem;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.save-panel-header{padding:.75rem 1rem;border-bottom:2px solid var(--border)}.save-panel-header h2{margin:0;font-family:var(--font-display);font-size:.875rem}.save-panel-header button{border-color:var(--fg-muted);color:var(--fg-muted);background:transparent;padding:.125rem .5rem}.save-slots{list-style:none;margin:0;padding:0}.save-slot{display:grid;grid-template-columns:6rem 1fr auto;gap:.75rem;align-items:center;padding:.625rem .75rem;border-bottom:2px solid var(--border)}.save-slot:last-child{border-bottom:none}.save-slot-thumb{width:6rem;height:4.5rem;background:#000;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}.save-slot-thumb img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated}.save-slot-empty{font-size:.625rem;font-family:var(--font-display);color:var(--fg-muted)}.save-slot-name{font-family:var(--font-display);font-size:.75rem}.save-slot-ts{font-size:.75rem;font-family:var(--font-mono);margin-top:.25rem}.save-slot-actions{display:flex;gap:.25rem;flex-wrap:wrap;justify-content:end}.save-slot-actions button{padding:.25rem .5rem;font-size:.75rem}.control-settings{max-width:42rem}.control-section{padding:1rem;border-bottom:2px solid var(--border)}.control-section h3{margin:0 0 .625rem}.touch-toggle-row{flex-wrap:wrap;gap:1rem}.touch-toggle-row label{display:flex;align-items:center;gap:.375rem;font-size:.875rem}table.bindings td{padding:.25rem .5rem}table.bindings td:first-child{width:5rem;font-family:var(--font-display);font-size:.625rem;text-transform:uppercase}table.bindings button{padding:.25rem .5rem;font-size:.75rem;font-family:var(--font-mono);min-width:6rem;text-align:left}table.bindings button.capturing{border-color:var(--accent);color:var(--accent)}.control-actions{padding:1rem;justify-content:flex-end}.home-root{min-height:100%;display:flex;flex-direction:column;align-items:center;padding:2rem 1.5rem;position:relative}.profile-menu{position:relative}.profile-menu-fixed{position:fixed;top:calc(1rem + env(safe-area-inset-top,0));right:calc(1rem + env(safe-area-inset-right,0));z-index:100}.profile-trigger{display:inline-flex;align-items:center;gap:.625rem;padding:.375rem .875rem .375rem .375rem;border:2px solid var(--border-strong);background:var(--bg-2);color:var(--fg);font-family:var(--font-display);font-size:.875rem;letter-spacing:.05em;text-transform:uppercase;cursor:pointer}.profile-trigger:hover{border-color:var(--accent);color:var(--accent)}.profile-avatar{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;background:var(--accent);color:var(--accent-fg);font-family:var(--font-display);font-size:1rem}.profile-name{font-size:.8125rem}.profile-admin-dot{width:.5rem;height:.5rem;background:var(--accent);display:inline-block}.profile-chevron{font-size:1rem;line-height:1;color:var(--fg-muted)}.profile-dropdown{position:absolute;top:calc(100% + .375rem);right:0;min-width:11rem;background:var(--bg);border:2px solid var(--border-strong);z-index:101;display:flex;flex-direction:column}.profile-dropdown-header{padding:.625rem .75rem;border-bottom:2px solid var(--border);font-family:var(--font-mono);font-size:.875rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.profile-item{display:flex;align-items:center;gap:.625rem;width:100%;text-align:left;padding:.75rem .875rem;background:transparent;color:var(--fg);border:none;border-bottom:1px solid var(--border);font-family:var(--font-display);font-size:.75rem;letter-spacing:.08em;cursor:pointer}.profile-item-icon{font-size:1.25rem;line-height:1;display:inline-block;width:1.25rem;text-align:center;font-family:var(--font-sans)}.profile-item:last-child{border-bottom:none}.profile-item:hover{background:var(--accent);color:var(--accent-fg)}.profile-item-danger{color:var(--danger)}.profile-item-danger:hover{background:var(--danger);color:var(--bg)}.home-brand{display:flex;align-items:center;justify-content:center;width:100%;max-width:40rem;position:relative}.home-brand-image{width:100%;height:auto;image-rendering:pixelated;filter:drop-shadow(2px 2px 0 rgba(0,0,0,.6))}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.home-icon{width:12rem;height:auto;image-rendering:pixelated;flex-shrink:0}.home-brand{max-width:22rem}@media(min-width:720px){.home-root{padding-top:2rem;justify-content:flex-start}.home-brand{margin-bottom:3rem;max-width:40rem}}@media(max-width:719px){.home-root{justify-content:center;gap:1.5rem}}.home-stack{width:100%;max-width:26rem;display:grid;gap:1.5rem;text-align:center}.home-welcome{font-family:var(--font-mono);font-size:.875rem;color:var(--fg-muted)}.home-menu{display:grid;gap:.75rem;text-align:left}.home-btn{display:grid;grid-template-columns:2rem 1fr;align-items:center;gap:.75rem;padding:1rem 1.25rem;font-family:var(--font-display);font-size:.875rem;letter-spacing:.08em;border:2px solid var(--border-strong);background:var(--bg-2);color:var(--fg);text-decoration:none;cursor:pointer;transition:transform .1s ease,background .1s ease,color .1s ease,border-color .1s ease;width:100%;text-align:left}.home-btn:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.home-btn:active{transform:translate(2px,2px)}.home-btn-arrow{color:var(--accent);font-family:var(--font-mono);font-size:1.5rem;line-height:1;transition:color .1s ease}.home-btn:hover .home-btn-arrow{color:var(--accent-fg)}.page-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:2px solid var(--border);background:var(--bg);gap:1rem}.page-header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.page-header-right{display:flex;align-items:center;gap:.5rem}.page-title{font-family:var(--font-display);font-size:.875rem;letter-spacing:.08em;margin:0}.page-subtitle{font-family:var(--font-display);font-size:.625rem;letter-spacing:.15em;text-align:center;margin:0 0 1.5rem;color:var(--accent)}.back-link{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:2px solid var(--border-strong);font-family:var(--font-mono);text-decoration:none;color:var(--fg)}.back-link:hover{background:var(--accent);color:var(--accent-fg);border-color:var(--accent)}.page-content{max-width:40rem;margin:0 auto;padding:2rem 1.5rem}.form-create{max-width:28rem}.centered{padding:2rem 1.5rem}.auth-brand{display:flex;justify-content:center;width:100%;max-width:22rem;margin:0 auto 2rem}.auth-brand-image{width:100%;height:auto;image-rendering:pixelated;filter:drop-shadow(2px 2px 0 rgba(0,0,0,.6))}
