:root{color:#f7f7fb;background:#101116;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden}button,input{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.46}.auth-screen{min-height:100vh;display:grid;grid-template-columns:minmax(0,1fr) 380px;background:radial-gradient(circle at 18% 22%,rgba(236,72,153,.28),transparent 32%),radial-gradient(circle at 70% 58%,rgba(20,184,166,.22),transparent 30%),linear-gradient(135deg,#12131a,#191827 46%,#10151a)}.auth-hero{min-height:100vh;padding:56px;display:flex;flex-direction:column;justify-content:center}.brand-mark,.brand,.wallet,.home-title{display:inline-flex;align-items:center;gap:9px}.brand-mark{color:#f9a8d4;font-weight:800}.auth-hero h1{margin:20px 0 14px;font-size:clamp(48px,7vw,104px);line-height:.95;letter-spacing:0}.auth-hero p{margin:0;max-width:560px;color:#d6d3e6;font-size:20px;line-height:1.55}.auth-card{align-self:center;margin-right:38px;padding:22px;background:#1a1b26eb;border:1px solid rgba(255,255,255,.1);border-radius:8px;display:grid;gap:16px;box-shadow:0 24px 80px #00000052}.segmented,.tabs,.filter-row{display:flex;gap:6px;background:#ffffff0f;padding:5px;border-radius:8px}.segmented button,.filter-row button,.tabs button{flex:1;min-height:36px;border-radius:6px;color:#dbd9e8;background:transparent}.filter-row{overflow-x:auto;scrollbar-width:thin}.filter-row button{flex:0 0 auto;padding:0 10px;white-space:nowrap}.tabs button{display:inline-flex;align-items:center;justify-content:center;gap:6px}.segmented .active,.tabs .active,.filter-row .active{background:#fff;color:#12131a}label{display:grid;gap:8px;color:#cbc8d8;font-size:14px}input{width:100%;min-height:42px;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:#101116;color:#fff;padding:0 12px;outline:none}input:focus{border-color:#f9a8d4}.primary-button,.ghost-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;border-radius:6px;background:#f9a8d4;color:#141116;font-weight:800}.ghost-button,.icon-button{min-height:34px;padding:0 10px;background:#ffffff14;color:#fff}.active-build{background:#14b8a6;color:#061614}.icon-button{width:38px;padding:0}.form-error{color:#fecaca;background:#ef444429;border:1px solid rgba(248,113,113,.35);border-radius:6px;padding:10px 12px}.app-shell{height:100vh;display:grid;grid-template-rows:58px minmax(0,1fr);background:#101116}.topbar{display:grid;grid-template-columns:190px minmax(0,1fr) auto 42px;align-items:center;gap:14px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08);background:#11121af5}.brand{font-weight:900;color:#fff}.home-title{min-width:0;color:#ebe9f5;font-weight:800}.wallet{min-height:36px;padding:0 13px;border-radius:6px;background:#facc1524;color:#fde68a;font-weight:900}.game-layout{min-height:0;display:grid;grid-template-columns:minmax(0,1fr) 398px}.scene-wrap{position:relative;min-width:0;min-height:0}.scene-wrap canvas{width:100%;height:100%;display:block}.scene-hint,.toast{position:absolute;left:16px;bottom:16px;padding:9px 12px;border-radius:6px;background:#101116b3;border:1px solid rgba(255,255,255,.1);color:#dedbea;font-size:13px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toast{left:16px;bottom:58px;color:#fff;border-color:#f9a8d461}.build-toolbar{position:absolute;left:16px;right:16px;bottom:58px;min-height:54px;display:grid;grid-template-columns:minmax(0,1fr) repeat(5,auto);align-items:center;gap:8px;padding:9px;border-radius:8px;background:#101116d1;border:1px solid rgba(20,184,166,.34);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.build-selection{min-width:0;display:grid;gap:2px}.build-selection b,.build-selection span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.build-selection span{color:#b8f5ec;font-size:12px}.build-toolbar button{min-height:36px;border-radius:6px;padding:0 11px;display:inline-flex;align-items:center;justify-content:center;gap:7px;background:#fff;color:#101116;font-weight:900}.build-toolbar .sell-button{background:#fb7185;color:#21070d}.style-swatches{display:inline-flex;align-items:center;gap:5px;min-height:36px;padding:0 8px;border-radius:6px;background:#ffffff12}.style-swatches span{color:#d9f7f2;font-size:12px;font-weight:800}.build-toolbar .swatch{width:24px;height:24px;min-height:24px;padding:0;border:2px solid rgba(255,255,255,.18);border-radius:999px}.build-toolbar .swatch.active{border-color:#fff;box-shadow:0 0 0 2px #14b8a68c}.object-tip{min-width:120px;text-align:center;white-space:nowrap;border-radius:6px;background:#101116db;border:1px solid rgba(255,255,255,.14);padding:7px 10px;color:#fff;font-size:12px;pointer-events:none}.name-tag{padding:3px 7px;border-radius:6px;background:#101116b8;border:1px solid rgba(255,255,255,.14);color:#fff;font-size:12px;font-weight:800;white-space:nowrap;pointer-events:none;text-shadow:0 1px 4px rgba(0,0,0,.5)}.side-panel{min-height:0;display:grid;grid-template-rows:auto minmax(0,1fr) 258px;gap:10px;padding:12px;border-left:1px solid rgba(255,255,255,.08);background:#171820}.panel-body{min-height:0;overflow:auto;padding-right:2px}.stack{display:grid;align-content:start;gap:8px}.filter-row{margin-bottom:10px}.item-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.shop-card,.wide-card{min-height:92px;border-radius:8px;text-align:left;padding:11px;background:#22242e;color:#fff;border:1px solid rgba(255,255,255,.07);display:grid;gap:4px}.shop-card:hover:not(:disabled),.wide-card:hover{border-color:#f9a8d48c;background:#2a2d39}.shop-card.equipped{border-color:#14b8a6b8;background:#1f2f34}.item-emoji{font-size:22px}.item-name{font-weight:800;line-height:1.15}.item-meta{color:#b8b5c7;font-size:12px}.item-meta.equipped{color:#5eead4;font-weight:900}.shop-card.equipped .item-meta:not(.equipped){display:none}.wide-card{min-height:56px;grid-template-columns:minmax(0,1fr) auto;align-items:center}.wide-card b{color:#fde68a}.chat-box{min-height:0;display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;gap:8px;border-top:1px solid rgba(255,255,255,.08);padding-top:10px}.chat-title{display:inline-flex;align-items:center;gap:7px;font-weight:900}.voice-row{min-width:0;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px}.voice-button{min-height:34px;border-radius:6px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;gap:7px;background:#ffffff14;color:#f1eff8;border:1px solid rgba(255,255,255,.13);font-weight:900}.voice-button.active{background:#14b8a6;color:#061614;border-color:#14b8a6b3}.voice-status{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#b8f5ec;font-size:12px}.messages{min-height:0;overflow:auto;display:grid;align-content:end;gap:7px}.message{display:grid;gap:2px;background:#ffffff0e;border-radius:6px;padding:8px 10px}.message b{color:#fff;font-size:12px}.message span{color:#f1eff8;overflow-wrap:anywhere}.chat-input{display:grid;grid-template-columns:minmax(0,1fr) 62px;gap:7px}.chat-input button{border-radius:6px;background:#14b8a6;color:#061614;font-weight:900}@media(max-width:980px){body{overflow:auto}.auth-screen{grid-template-columns:1fr}.auth-hero{min-height:auto;padding:42px 20px 22px}.auth-card{margin:0 20px 28px}.app-shell{height:auto;min-height:100vh}.topbar,.game-layout{grid-template-columns:1fr}.topbar{grid-template-columns:1fr auto auto}.home-title{grid-column:1 / -1;order:3}.scene-wrap{height:58vh}.build-toolbar{grid-template-columns:minmax(0,1fr) auto auto}.style-swatches{grid-column:1 / -1;justify-content:flex-start;overflow-x:auto}.side-panel{border-left:0;grid-template-rows:auto 420px 240px}}
