:root{color:#f2f5ef;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#101412;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:#101412;min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{color:#fff;cursor:pointer;background:#1f4f46;border:0;border-radius:6px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:0 14px;display:inline-flex}button:disabled{cursor:not-allowed;opacity:.48}input,select{color:#18201d;background:#fff;border:1px solid #c9d2cb;border-radius:6px;width:100%;min-height:40px;padding:0 10px}input[type=range]{accent-color:#74d1ad;padding:0}h1,h2,p,dl{margin:0}h1{font-size:2rem;line-height:1.1}h2{font-size:1rem;line-height:1.2}.app-shell{background:#07090a;min-height:100vh;position:relative}.topbar{background:#101412e6;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;gap:16px;max-width:none;min-height:48px;margin:0;padding:8px 14px;display:flex}.topbar p,.muted{color:#8f9b93;font-size:.92rem;line-height:1.45}.topbar h1{color:#f6f3e8;font-size:.98rem}.identity-pill{color:#d9e1da;overflow-wrap:anywhere;background:#18201d;border:1px solid #ffffff24;border-radius:999px;max-width:100%;padding:7px 12px}.topbar-identity{align-items:center;gap:8px;display:inline-flex}.identity-logout{color:#d9e1da;cursor:pointer;font:inherit;background:0 0;border:1px solid #ffffff24;border-radius:999px;padding:6px 11px}.identity-logout:hover{background:#ffffff0f}.login-shell{background:#0c100e;place-items:center;min-height:100vh;display:grid}.login-form{background:#161b18;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;gap:14px;width:280px;padding:28px 24px;display:flex}.login-field{color:#b6bdb7;flex-direction:column;gap:4px;font-size:13px;display:flex}.login-field input{color:#f6f3e8;font:inherit;background:#0c100e;border:1px solid #ffffff1f;border-radius:4px;padding:8px 10px}.login-field input:focus{border-color:#6f8a78;outline:none}.login-form button[type=submit]{color:#f6f3e8;cursor:pointer;font:inherit;background:#2c3a32;border:1px solid #ffffff24;border-radius:4px;margin-top:6px;padding:9px}.login-form button[type=submit]:disabled{opacity:.55;cursor:progress}.login-error{color:#f0a4a4;margin:0;font-size:13px}.session-pill{color:#26332e;background:#f7fbf8;border:1px solid #cbd6cf;border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-size:.82rem;display:inline-flex}.workspace-grid{grid-template-columns:minmax(0,1fr) minmax(320px,400px);gap:18px;max-width:1360px;margin:0 auto;display:grid}.game-shell{flex:1;align-items:start;padding:10px;display:grid;position:relative}.game-viewport{gap:6px;width:100%;display:grid}.game-command-bar{color:#f7f4e9;background:#171d1a;border:1px solid #ffffff1a;border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;display:flex}.game-session-meta{gap:2px;min-width:0;display:grid}.game-session-meta strong,.game-session-meta span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.game-session-meta span{color:#9faaa3;font-size:.82rem}.game-command-controls{flex:none;align-items:center;gap:8px;display:flex}.play-strip{color:#9faaa3;justify-content:space-between;align-items:center;gap:12px;min-height:20px;padding:0 4px;font-size:.78rem;display:flex;overflow:hidden}.play-strip span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.save-pill{color:#dfe7e2;white-space:nowrap;background:#0709088c;border:1px solid #ffffff1f;border-radius:999px;padding:6px 9px;font-size:.82rem}.volume-control{align-items:center;gap:8px;display:flex}.volume-control input[type=range]{width:130px}.icon-button{width:36px;min-height:36px;padding:0}.volume-value{color:#c5d1c9;text-align:right;min-width:38px;font-size:.84rem}.primary-column,.side-column{align-content:start;gap:18px;display:grid}.panel{color:#18201d;background:#fffdfa;border:1px solid #d8ded8;border-radius:8px;padding:16px;box-shadow:0 1px 2px #18201d0f}.compact-panel{padding:14px}.auth-panel{max-width:640px;margin:0 auto}.section-heading{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.button-row{flex-wrap:wrap;gap:8px;display:flex}.secondary-button{background:#365a77}.drop-zone{color:#1f4f46;background:#f7fbf8;border:1px dashed #8ba59b;place-items:center;width:100%;min-height:116px;display:grid}.drop-zone.active{background:#e5f5ee;border-color:#1f4f46}.rom-meta{gap:10px;margin-top:14px;display:grid}.local-rom-banner{color:#24473e;background:#edf8f1;border:1px solid #c6d8ce;border-radius:6px;padding:10px 12px;font-size:.9rem;line-height:1.4}.rom-meta div,.debug-grid div,.controls-grid div{gap:4px;display:grid}.rom-meta span,.debug-grid dt,.controls-grid dt,.room-controls span{color:#66746c;text-transform:uppercase;font-size:.78rem}.rom-meta strong,.debug-grid dd,.controls-grid dd{overflow-wrap:anywhere;margin:0}.hash-row strong{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.82rem}.emulator-panel{min-width:0}.screen-frame{background:#070908;border-radius:8px;place-items:center;min-height:420px;display:grid;position:relative;overflow:hidden}.game-screen{outline:none;max-width:100%;min-height:auto;box-shadow:0 24px 80px #00000073,0 0 0 1px #ffffff14}.screen-host{place-items:center;width:100%;min-height:180px;display:grid}canvas{width:100%;height:100%;image-rendering:pixelated;background:#070908}.game-status{z-index:3;color:#f7f4e9;background:#070908bd;border:1px solid #ffffff1f;border-radius:8px;gap:2px;max-width:min(420px,100% - 32px);padding:9px 11px;font-size:.82rem;line-height:1.25;display:grid;position:absolute}.game-status strong,.game-status span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.game-status span{color:#b9c4bd}.game-status-left{top:14px;left:14px}.game-status-right{top:14px;right:14px}.start-overlay,.empty-game-message{z-index:4;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.start-overlay{min-height:48px;padding:0 18px}.empty-game-message{color:#d9e1da;background:#070908b3;border-radius:8px;padding:12px 14px}.game-error{color:#fff2ef;background:#3b1612eb;border-left:3px solid #e05b4f;border-radius:6px;max-width:100%;padding:9px 11px;font-size:.86rem;line-height:1.35}.rom-prompt-layer{z-index:6;pointer-events:none;place-items:center;display:grid;position:absolute;inset:82px 18px 18px}.rom-prompt-layer .panel{pointer-events:auto;width:min(500px,100%)}.controls-grid,.debug-grid{gap:10px;display:grid}.error-list{gap:8px;margin-top:12px;display:grid}.error-list p{color:#7c241c;background:#fff1ef;border-left:3px solid #b53a2d;padding:8px 10px}.room-controls{margin-bottom:12px}.room-controls label{gap:6px;display:grid}.presence-stage{background-color:#f7fbf8;background-image:linear-gradient(90deg,#1f4f4617 1px,#0000 1px),linear-gradient(#1f4f4617 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:24px 24px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border:1px solid #d8ded8;border-radius:8px;min-height:180px;position:relative;overflow:hidden}.presence-marker{border:2px solid #fff;border-radius:50%;width:16px;height:16px;position:absolute;transform:translate(-50%,-50%);box-shadow:0 2px 8px #18201d47}.player-list{gap:7px;margin:12px 0;padding:0;list-style:none;display:grid}.player-list li{overflow-wrap:anywhere;align-items:center;gap:8px;display:flex}.player-list span{border-radius:50%;flex:none;width:10px;height:10px}.visually-hidden{clip:rect(0 0 0 0);white-space:nowrap;width:1px;height:1px;position:absolute;overflow:hidden}@media (width<=920px){.app-shell{padding:0}.topbar,.workspace-grid{display:grid}.workspace-grid{grid-template-columns:1fr}.game-command-bar{flex-direction:column;align-items:stretch}.game-command-controls{justify-content:space-between}}@media (width<=560px){.section-heading{flex-direction:column;align-items:stretch}.button-row{grid-template-columns:1fr 1fr;display:grid}.play-strip{gap:2px;display:grid}.game-command-controls{display:flex}.volume-control{grid-template-columns:36px 1fr 42px;display:grid}.volume-control input[type=range]{width:100%}}:root{--bg-deep:#07090a;--bg-card:#11161a;--bg-card-hover:#161d22;--bg-input:#0b0f12;--line-soft:#ffffff0f;--line:#ffffff1a;--text-primary:#f3f5f4;--text-secondary:#aab2b5;--text-muted:#6b7479;--text-faint:#4d5358;--accent-green:#6fbe88;--game-accent:#b62b1e}.profile-menu{z-index:50;position:fixed;top:18px;right:20px}.profile-trigger{width:38px;height:38px;color:var(--text-primary);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:999px;place-items:center;min-height:0;padding:0;transition:background .12s;display:grid}.profile-trigger:hover{background:#ffffff24}.profile-avatar{letter-spacing:.04em;font-size:13px;font-weight:600}.profile-popover{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;flex-direction:column;gap:8px;min-width:200px;padding:14px;display:flex;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 32px #00000073}.profile-popover-name{color:var(--text-primary);font-size:14px;font-weight:600}.profile-popover-username{color:var(--text-muted);font-size:12px}.profile-popover-signout{border:1px solid var(--line);color:var(--text-primary);cursor:pointer;font:inherit;background:0 0;border-radius:6px;min-height:0;margin-top:6px;padding:7px 10px;font-size:13px}.profile-popover-signout:hover{background:#ffffff0f}.profile-popover-meta{color:var(--text-faint);margin-top:4px;font-size:11px}.screen{min-height:100vh;color:var(--text-primary);background:var(--bg-deep)}.screen-header{flex-direction:column;align-items:flex-start;gap:4px;padding:80px 56px 28px;display:flex}.screen-back{color:var(--text-muted);cursor:pointer;font:inherit;background:0 0;border:0;min-height:0;margin-bottom:16px;padding:0;font-size:13px}.screen-back:hover{color:var(--text-primary)}.screen-eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--text-muted);margin:0;font-size:11px}.screen-title{color:var(--text-primary);letter-spacing:-.01em;margin:0;font-size:28px;font-weight:600}.screen-error{color:#f3a8a8;background:#f0646414;border:1px solid #f0646433;border-radius:8px;margin:0 56px;padding:12px 16px;font-size:14px}.screen-muted{color:var(--text-muted);margin:0 56px}.screen-muted.small{font-size:12px}@media (width<=720px){.screen-header{padding:76px 24px 20px}.screen-error,.screen-muted{margin:0 24px}}.game-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;padding:12px 56px 80px;display:grid}@media (width<=720px){.game-grid{gap:16px;padding:12px 24px 64px}}.game-tile{text-align:left;background:var(--bg-card);border:1px solid var(--line-soft);width:100%;color:inherit;cursor:pointer;font:inherit;border-radius:14px;flex-direction:column;min-height:0;padding:0;transition:transform .18s,border-color .18s,box-shadow .18s;display:flex;position:relative;overflow:hidden}.game-tile:hover{border-color:var(--line);transform:translateY(-2px);box-shadow:0 12px 32px #0006}.game-tile-art{aspect-ratio:1;background-color:#0b0e10;background-position:50%;background-size:cover;width:100%;position:relative}.game-tile-art:after{content:"";background:linear-gradient(#0000 55%,#07090aa6 100%);position:absolute;inset:0}.game-tile-fallback{color:var(--text-faint);background:linear-gradient(135deg,#14191c,#0a0d0f);place-items:center;font-size:64px;font-weight:700;display:grid;position:absolute;inset:0}.game-tile-body{flex-direction:column;gap:4px;padding:16px 18px 18px;display:flex}.game-tile-eyebrow{text-transform:uppercase;letter-spacing:.16em;color:var(--game-accent);font-size:10px;font-weight:600}.game-tile-title{color:var(--text-primary);letter-spacing:-.01em;font-size:18px;font-weight:600}.game-tile-summary{color:var(--text-muted);font-size:13px;line-height:1.45}.screen-hub{flex-direction:column;display:flex}.hub-hero{background-color:#14191c;background-position:50%;background-size:cover;flex-direction:column;justify-content:flex-end;gap:16px;min-height:340px;padding:64px 56px 40px;display:flex;position:relative}.hub-hero-overlay{background:linear-gradient(180deg, #07090a66 0%, #07090ad9 70%, var(--bg-deep) 100%), linear-gradient(90deg, #07090ab3 0%, transparent 50%);pointer-events:none;position:absolute;inset:0}.hub-back{color:var(--text-primary);cursor:pointer;font:inherit;z-index:2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:999px;min-height:0;padding:7px 14px;font-size:12px;position:absolute;top:24px;left:28px}.hub-back:hover{background:#ffffff1f}.hub-hero-content{z-index:1;flex-direction:column;gap:6px;max-width:720px;display:flex;position:relative}.hub-hero-eyebrow{text-transform:uppercase;letter-spacing:.18em;color:var(--game-accent);margin:0;font-size:11px;font-weight:700}.hub-hero-title{letter-spacing:-.015em;color:var(--text-primary);margin:0;font-size:44px;font-weight:700}.hub-hero-stats{color:var(--text-secondary);margin:4px 0 0;font-size:14px}.hub-cta{background:var(--game-accent);color:#fff;cursor:pointer;font:inherit;letter-spacing:.01em;border:0;border-radius:999px;align-self:flex-start;min-height:0;margin-top:18px;padding:12px 26px;font-size:14px;font-weight:600;transition:filter .12s,transform .12s;box-shadow:0 6px 22px #00000059}.hub-cta:hover{filter:brightness(1.1);transform:translateY(-1px)}.hub-body{flex-direction:column;gap:20px;padding:32px 56px 80px;display:flex}@media (width<=720px){.hub-hero{min-height:260px;padding:64px 24px 32px}.hub-hero-title{font-size:32px}.hub-body{padding:24px 24px 64px}}.hub-columns{grid-template-columns:1fr;gap:20px;display:grid}@media (width>=900px){.hub-columns{grid-template-columns:minmax(0,380px) minmax(0,1fr)}}.hub-section{flex-direction:column;gap:10px;display:flex}.hub-section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);align-items:baseline;gap:8px;margin:0;font-size:13px;font-weight:600;display:flex}.hub-section-count{color:var(--text-faint);font-size:12px;font-weight:400}.character-feed{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.character-feed.compact .character-card{padding:8px 12px}.character-card{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:10px;flex-direction:column;gap:4px;padding:12px 14px;display:flex}.character-card-row{align-items:baseline;gap:10px;display:flex}.character-card-name{color:var(--text-primary);font-size:14px;font-weight:600}.character-card-trainer{color:var(--text-muted);font-size:12px}.character-card-spacer{flex:1}.character-card-time{color:var(--text-faint);font-size:11px}.character-card-meta{color:var(--text-secondary);flex-wrap:wrap;gap:8px;font-size:12px;display:flex}.adventurer-list{flex-direction:column;gap:14px;margin:0;padding:0;list-style:none;display:flex}.adventurer-entry{border-bottom:1px solid var(--line-soft);flex-direction:column;gap:8px;padding-bottom:14px;display:flex}.adventurer-entry:last-child{border-bottom:none;padding-bottom:0}.adventurer-head{align-items:baseline;gap:10px;display:flex}.adventurer-name{color:var(--text-primary);font-weight:600}.user-dot{color:var(--text-muted);margin-left:auto;font-size:11px}.user-dot.playing{color:var(--accent-green)}.user-dot.online{color:#b0d4be}.screen-characters .screen-header{padding-top:80px}.character-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;padding:18px 56px 80px;display:grid}@media (width<=720px){.character-grid{padding:18px 24px 64px}}.character-tile{background:var(--bg-card);border:1px solid var(--line-soft);border-radius:12px;flex-direction:column;gap:4px;min-height:132px;padding:18px;transition:border-color .12s,background .12s;display:flex;position:relative}.character-tile:hover{border-color:var(--line);background:var(--bg-card-hover)}.character-tile-main{text-align:left;color:inherit;cursor:pointer;font:inherit;background:0 0;border:0;flex-direction:column;gap:6px;min-height:0;padding:0;display:flex}.character-tile-name{color:var(--text-primary);font-size:16px;font-weight:600}.character-tile-name.muted{color:var(--text-muted);font-weight:500}.character-tile-meta{color:var(--text-muted);font-size:12px}.character-tile-delete{width:24px;height:24px;color:var(--text-muted);cursor:pointer;font:inherit;opacity:0;background:#ffffff0a;border:0;border-radius:999px;place-items:center;min-height:0;padding:0;font-size:18px;line-height:1;transition:opacity .12s,color .12s,background .12s;display:grid;position:absolute;top:8px;right:8px}.character-tile:hover .character-tile-delete{opacity:1}.character-tile-delete:hover{color:#f3a8a8;background:#f3a8a81a}.character-tile-new{border-style:dashed;border-color:var(--line);background:0 0}.character-tile-new input{background:var(--bg-input);border:1px solid var(--line);color:var(--text-primary);font:inherit;border-radius:6px;width:100%;min-height:0;padding:8px 10px}.character-tile-new input:focus{border-color:var(--game-accent);outline:none}.character-tile-create{background:var(--game-accent);color:#fff;cursor:pointer;font:inherit;border:0;border-radius:6px;min-height:0;margin-top:6px;padding:8px 12px;font-size:13px;font-weight:600}.character-tile-create:disabled{opacity:.4;cursor:not-allowed}.character-tile-create:not(:disabled):hover{filter:brightness(1.1)}.play-topbar{border-bottom:1px solid var(--line-soft);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#07090aeb;align-items:center;gap:14px;padding:10px 18px;display:flex;position:sticky;top:0}.play-exit{border:1px solid var(--line);color:var(--text-secondary);cursor:pointer;font:inherit;background:0 0;border-radius:999px;min-height:0;padding:5px 12px;font-size:12px}.play-exit:hover{color:var(--text-primary);background:#ffffff0d}.play-character-name{color:var(--text-muted);font-size:13px}.play-character-name strong{color:var(--text-primary);font-weight:600}
