html,body{overflow:hidden;color:#f8fafc;background:#101820;width:100%;height:100%;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif}#game-root,#hud-root{position:fixed;inset:0}#game-root canvas{display:block;width:100%;height:100%}#game-loading{position:fixed;z-index:100;display:flex;pointer-events:none;background:#101820;justify-content:center;align-items: center;transition:opacity .6s;inset:0}#game-loading.is-hidden{opacity:0}#game-loading span{color:#a8b3bd;letter-spacing:.2em;text-transform:uppercase;opacity:.7;font-size:14px}.game-loading__content{display:flex;flex-direction:column;align-items: center;gap:16px;width:200px}.game-loading__track{overflow:hidden;background:#1b2c3a;border-radius:1px;width:100%;height:2px}.game-loading__bar{background:#6ee7b7;border-radius:1px;width:0%;height:100%;transition:width .2s linear}.trex-cinematic-fade{position:fixed;z-index:5;pointer-events:none;opacity:0;background:#000;transition:opacity 80ms linear;inset:0}#hud-root{pointer-events:none}.ui-canvas{display:block;pointer-events:none;width:100%;height:100%}.builder-root{position:fixed;overflow:hidden;color:#e5edf2;background:#101820;font-size:13px;inset:0}.builder-canvas-host{position:fixed;inset:0}.builder-canvas-host canvas{display:block;width:100%;height:100%}.builder-selection-marquee{position:fixed;z-index:9;box-sizing:border-box;pointer-events:none;background:#facc1524;border:1px solid #facc15f2}.builder-compass{position:fixed;z-index:9;pointer-events:none;width:76px;height:76px;top:58px;left:50%;transform:translate(-50%)}.builder-compass__ring{position:relative;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f171fb8;border:1px solid #e2e8f07a;border-radius:50%;width:100%;height:100%;box-shadow:0 10px 28px #00000047}.builder-compass__ring span{position:absolute;color:#e5edf2;font-size:10px;font-weight:700;line-height:1}.builder-compass__n{top:7px;left:50%;transform:translate(-50%)}.builder-compass__e{top:50%;right:8px;transform:translateY(-50%)}.builder-compass__s{bottom:7px;left:50%;transform:translate(-50%)}.builder-compass__w{top:50%;left:8px;transform:translateY(-50%)}.builder-compass__needle{display:block;transform-origin:50% 100%;background:#f87171;border-radius:3px;width:3px;height:28px;top:50%;left:50%;box-shadow:0 0 10px #f87171b3}.builder-panel{position:fixed;z-index:10;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f171fe0;border:1px solid #94a3b847;width:min(340px,50vw - 20px);top:58px;bottom:48px;box-shadow:0 16px 38px #00000057}.builder-shell-tabs{position:fixed;z-index:13;display:flex;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f171fe6;border:1px solid #94a3b847;border-radius:8px;gap:6px;padding:5px;top:12px;left:50%;transform:translate(-50%);box-shadow:0 12px 28px #0000004d}.builder-shell-tab{color:#dbe7ee;cursor:pointer;font:inherit;background:#1e2933eb;border:1px solid #94a3b847;border-radius:6px;min-height:30px;padding:5px 10px;font-size:12px}.builder-shell-tab:hover,.builder-shell-tab.is-active{color:#f8fafc;background:#1f403af5;border-color:#6ee7b7b8}.builder-panel--left{left:12px}.builder-panel--right{display:flex;flex-direction:column;right:12px}.builder-panel__title{color:#f8fafc;padding:12px 14px 8px;font-size:15px;font-weight:700}.builder-toolbar,.builder-actions,.builder-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:0 12px 10px}.builder-actions--tight{padding:8px 0 0}.builder-action-select{display:grid;color:#b8c4cf;flex:1 0 100%;gap:5px}.builder-button,.builder-part-button{appearance:none;color:#e5edf2;cursor:pointer;font:inherit;background:#1e2933eb;border:1px solid #94a3b852;border-radius:6px}.builder-button{min-height:30px;padding:5px 9px}.builder-button:hover,.builder-part-button:hover,.builder-button.is-active,.builder-part-button.is-active{color:#f8fafc;background:#1f403af5;border-color:#6ee7b7b3}.builder-button:disabled{cursor:default;opacity:.42}.builder-level-section{padding:0 12px 10px}.builder-level-control{display:flex;overflow:hidden;background:#0e1e18e0;border:1px solid #6ee7b761;border-radius:8px;align-items:stretch}.builder-level-control__btn{color:#6ee7b7;cursor:pointer;display:flex;background:0 0;border:none;flex:none;justify-content:center;align-items: center;width:38px;padding:0;transition:background 80ms;font-size:13px}.builder-level-control__btn:hover:not(:disabled){color:#d1fae5;background:#6ee7b724}.builder-level-control__btn:disabled{opacity:.28;cursor:default}.builder-level-control__info{display:flex;pointer-events:none;border-left:1px solid #6ee7b733;border-right:1px solid #6ee7b733;flex-direction:column;flex:1;justify-content:center;align-items: center;gap:1px;padding:8px 4px}.builder-level-control__floor{color:#f0fdf4;letter-spacing:.01em;font-size:13px;font-weight:700}.builder-level-control__height{color:#6ee7b7;opacity:.8;letter-spacing:.04em;font-size:10px}.builder-level-control__btn--all{letter-spacing:.04em;color:#94a3b8;border-left:1px solid #6ee7b733;width:auto;padding:0 10px;font-size:11px;font-weight:600}.builder-level-control__btn--all:hover:not(:disabled){color:#d1fae5}.builder-level-control__btn--all.is-active{color:#6ee7b7;background:#6ee7b71a}.builder-palette{overflow:auto;height:calc(100% - 192px);padding:0 12px 12px}.builder-library-search{width:calc(100% - 24px);margin:0 12px 10px}.builder-library-count{color:#a8b3bd;margin-bottom:8px;font-size:11px}.builder-part-button{display:grid;grid-template-columns:1fr auto;text-align:left;gap:8px;width:100%;min-height:42px;margin-bottom:7px;padding:8px 10px}.builder-part-button small{color:#a8b3bd;text-transform:uppercase;align-self: center;font-size:11px}.builder-part-button.is-no-collision{border-left:3px solid #f59e0b}.builder-no-collision-badge{font-weight:600;color:#f59e0b!important}.builder-power-badge{font-weight:600;color:#facc15!important}.builder-zone-badge{font-weight:600;color:#34d399!important}.builder-info-badge{border-radius:5px;margin-top:8px;padding:5px 8px;font-size:12px;line-height:1.4}.builder-info-badge--power{color:#fde68a;background:#facc1514;border:1px solid #facc1547}.builder-info-badge--zone{color:#6ee7b7;background:#34d39914;border:1px solid #34d39947}.builder-text-input{box-sizing:border-box;color:#f8fafc;font:inherit;background:#060d14d1;border:1px solid #94a3b847;border-radius:5px;width:100%;min-height:30px;margin-top:6px;padding:4px 8px}.builder-text-input:focus{outline:1px solid #63b3ed9e;border-color:#63b3ed9e}.builder-field-hint{display:block;color:#7d97ae;margin-top:3px;font-size:11px}.builder-inspector{overflow:auto;flex:auto;min-height:0;padding:0 12px}.builder-meta,.builder-selected-card,.builder-summary,.builder-empty-selection{background:#02060c3d;border:1px solid #94a3b82e;border-radius:6px;margin-bottom:10px;padding:10px}.builder-inspector-section{margin-bottom:10px}.builder-inspector-section__header{display:flex;color:#dbeafe;cursor:pointer;text-align:left;background:#0f172aa3;border:1px solid #94a3b833;border-radius:6px;align-items: center;gap:8px;width:100%;min-height:28px;padding:6px 8px}.builder-inspector-section__header:hover,.builder-inspector-section.is-drop-target .builder-inspector-section__header{background:#0e749033;border-color:#38bdf8b8}.builder-inspector-section__chevron{color:#7dd3fc;transform-origin:center;flex:0 0 12px;width:12px;transition:transform .12s}.builder-inspector-section.is-collapsed .builder-inspector-section__chevron{transform:rotate(-90deg)}.builder-inspector-section__title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;font-size:12px;font-weight:700}.builder-inspector-section__drag-handle{color:#94a3b8;cursor:grab;letter-spacing:0;flex:none;font-weight:700}.builder-inspector-section__body{margin-top:6px}.builder-inspector-section__body>.builder-meta,.builder-inspector-section__body>.builder-selected-card,.builder-inspector-section__body>.builder-summary,.builder-inspector-section__body>.builder-empty-selection{margin-bottom:0}.builder-inspector-section.is-dragging{opacity:.58}.builder-selected-card strong,.builder-selected-card small{display:block}.builder-selected-card small{color:#a8b3bd;margin-top:2px}.builder-chip-row{display:grid;grid-template-columns:minmax(0,1fr)auto;color:#b8c4cf;border-bottom:1px solid #94a3b81a;align-items: center;gap:8px;min-height:24px}.builder-chip-row:last-child{border-bottom:0}.builder-chip-row strong{color:#f8fafc;min-width:0;font-weight:600}.builder-chip-row--path{grid-template-columns:minmax(0,82px)minmax(0,1fr)}.builder-chip-row--path strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.builder-shortcut-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px;margin-top:8px}.builder-shortcut-row{display:grid;color:#b8c4cf;background:#0f171f6b;border:1px solid #94a3b81f;border-radius:5px;align-items: start;gap:4px;min-height:42px;padding:5px}.builder-shortcut-row kbd{overflow:hidden;color:#e5edf2;text-overflow:ellipsis;white-space:nowrap;background:#0f171feb;border:1px solid #94a3b847;border-radius:5px;width:-moz-fit-content;width:fit-content;max-width:100%;padding:3px 5px;font:10px/1.2 ui-monospace,SFMono-Regular,Menlo,Consolas,Liberation Mono,monospace}.builder-field,.builder-field-title{display:grid;color:#b8c4cf;gap:5px;margin-top:9px}.builder-field-title{color:#f8fafc;font-weight:700}.builder-input,.builder-select{box-sizing:border-box;color:#f8fafc;font:inherit;background:#060d14d1;border:1px solid #94a3b847;border-radius:5px;width:100%;min-height:30px;padding:5px 7px}.builder-input--color{min-height:34px;padding:3px}.builder-texture-preview{display:grid;grid-template-columns:68px minmax(0,1fr);align-items:stretch;gap:10px;margin-top:10px}.builder-texture-preview__image{image-rendering:pixelated;background-color:#060d14d1;background-position:50%;background-repeat:repeat;background-size:68px 68px;border:1px solid #94a3b847;border-radius:5px;min-height:68px}.builder-texture-preview__label{min-width:0}.builder-texture-grid{display:grid;grid-template-columns:repeat(8,1fr);overflow:auto;gap:5px;max-height:104px;margin-top:9px;padding-right:2px}.builder-texture-swatch{aspect-ratio:1;cursor:pointer;image-rendering:pixelated;background-color:#060d14d1;background-position:50%;background-repeat:repeat;background-size:24px 24px;border:1px solid #94a3b842;border-radius:4px;width:100%;min-width:0}.builder-texture-swatch:hover,.builder-texture-swatch.is-active{outline:none;border-color:#6ee7b7e6;box-shadow:inset 0 0 0 1px #6ee7b799}.builder-texture-swatch:focus-visible{outline:none;border-color:#6ee7b7e6;box-shadow:inset 0 0 0 1px #6ee7b799}.builder-status{position:fixed;z-index:11;display:flex;box-sizing:border-box;color:#cbd5df;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f171fe0;border:1px solid #94a3b83d;border-radius:6px;justify-content:space-between;gap:12px;min-height:28px;padding:6px 10px;bottom:10px;left:12px;right:12px}.builder-test-hud{position:fixed;z-index:12;display:none;overflow:auto;box-sizing:border-box;color:#e5edf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f171fe6;border:1px solid #94a3b847;border-radius:6px;width:min(320px,100vw - 24px);max-height:calc(100vh - 72px);padding:12px;top:12px;right:12px}.builder-test-hud.is-visible{display:grid;gap:8px}.builder-root--test .builder-panel{display:none}.builder-root--test .builder-status{right:min(344px,100vw - 12px)}.builder-hidden-file{display:none}@media (max-width:900px){.builder-panel{width:calc(50vw - 18px)}}@media (max-width:700px){.builder-panel{width:min(178px,50vw - 16px);top:52px;bottom:44px}.builder-panel--left{left:8px}.builder-panel--right{height:min(320px,44vh);top:auto;right:8px}.builder-shell-tabs{overflow-x:auto;max-width:calc(100vw - 16px);top:8px}.builder-shell-tab{white-space:nowrap;padding-inline-start:8px;padding-inline-end:8px}.builder-compass{display:none}.builder-toolbar,.builder-actions,.builder-tabs{gap:5px;padding-inline-start:8px;padding-inline-end:8px}.builder-panel__title{padding-inline-start:10px;padding-inline-end:10px}.builder-palette{height:calc(100% - 190px);padding-inline-start:8px;padding-inline-end:8px}.builder-library-search{width:calc(100% - 16px);margin-inline-start:8px;margin-inline-end:8px}.builder-inspector{padding-inline-start:8px;padding-inline-end:8px}.builder-status{bottom:8px;left:8px;right:8px}.builder-root--test .builder-status{right:8px}}#sprite-editor-root{position:fixed;inset:0}.sprite-editor-canvas{display:block;width:100%;height:100%}.sprite-editor-panel{position:fixed;overflow-y:auto;backdrop-filter:blur(6px);background:#101820eb;border:1px solid #7896b438;border-radius:10px;width:270px;max-height:calc(100vh - 24px);padding:12px;font-size:13px;top:12px;left:12px;box-shadow:0 12px 30px #00000073}.se-title{display:flex;align-items:baseline;gap:8px;margin-bottom:10px}.se-title-main{font-size:15px;font-weight:700}.se-title-sub{color:#8aa0b4;letter-spacing:.04em;text-transform:uppercase;font-size:11px}.se-seg{display:flex;gap:4px;margin-bottom:12px}.se-seg-btn{color:#cdd9e4;cursor:pointer;background:#283440b3;border:1px solid #7896b440;border-radius:7px;flex:1;padding:6px 8px;font-size:12px}.se-seg-btn.is-active{color:#fff;background:#3b82f6;border-color:#3b82f6}.se-section{margin-bottom:14px}.se-section-title{text-transform:uppercase;letter-spacing:.05em;color:#8aa0b4;margin:10px 0 5px;font-size:11px}.se-select{color:#f1f5f9;background:#283440d9;border:1px solid #7896b440;border-radius:6px;width:100%;padding:6px}.se-transport{display:flex;gap:6px;margin:8px 0}.se-btn{color:#f1f5f9;cursor:pointer;background:#283440d9;border:1px solid #7896b440;border-radius:6px;flex:1;padding:6px 0;font-size:13px}.se-btn:hover{background:#3c4c5cf2}.se-range{width:100%}.se-field-label{color:#aebccb;margin:6px 0 2px;font-size:11px}.se-link{color:#6fb0ff;cursor:pointer;background:0 0;border:none;padding:2px 0;font-size:11px}.se-check{display:flex;cursor:pointer;align-items: center;gap:7px;padding:3px 0}.se-help{color:#9fb1c2;margin-bottom:8px;font-size:11px;line-height:1.45}.sprite-editor-hud{position:fixed;text-align:center;font-variant-numeric:tabular-nums;background:#101820e6;border:1px solid #7896b438;border-radius:8px;padding:8px 14px;bottom:12px;left:50%;transform:translate(-50%)}.se-hud-frame{color:#fff;font-size:14px;font-weight:700}.se-hud-detail{color:#9fb1c2;margin-top:2px;font-size:11px}.sprite-editor-edit-canvas{cursor:crosshair;background:#161d24}.se-seg-sub{margin-top:4px}.se-frame-list{overflow-y:auto;border:1px solid #7896b42e;border-radius:6px;max-height:180px;margin-bottom:6px}.se-frame-row{display:block;text-align:left;color:#cdd9e4;cursor:pointer;background:0 0;border:none;width:100%;padding:4px 8px;font-family:ui-monospace,monospace;font-size:11px}.se-frame-row:hover{background:#3c4c5c8c}.se-frame-row.is-active{color:#fff;background:#3b82f6}.se-inspector{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.se-field{display:flex;justify-content:space-between;align-items: center;gap:8px}.se-field-name{color:#aebccb;font-family:ui-monospace,monospace;font-size:12px}.se-num{color:#f1f5f9;background:#283440d9;border:1px solid #7896b440;border-radius:5px;width:96px;padding:4px 6px}.se-actions{display:flex;gap:6px;margin:8px 0 6px}.se-btn:disabled{opacity:.4;cursor:default}.se-btn-primary{color:#fff;background:#2f9e57;border-color:#2f9e57;width:100%;font-weight:600}.se-btn-primary:hover{background:#36b463}.se-btn.is-active{color:#fff;background:#ff5078;border-color:#ff5078}.se-prompt{box-sizing:border-box;resize:vertical;color:#f1f5f9;background:#283440d9;border:1px solid #7896b440;border-radius:6px;width:100%;margin-bottom:6px;padding:6px;font-family:inherit;font-size:12px}.se-inpaint-review{margin-bottom:8px}.se-inpaint-compare{display:flex;gap:8px;margin-bottom:6px}.se-inpaint-cell{text-align:center;flex:1}.se-thumb{image-rendering:pixelated;background:#0c1116;border:1px solid #7896b440;border-radius:4px;max-width:100%;max-height:96px}.se-frame-row.is-derived{color:#8aa0b4;font-style:italic}
