*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{width:100%;height:100%;overflow:hidden}:root{--black: #080808;--ink: #111111;--surface: #1a1a1a;--rule: #242424;--muted: #3a3a3a;--dim: #555555;--secondary: #888888;--text: #e8e8e8;--bright: #ffffff;--accent: #e8ff00;--accent-dim: #5a6300;--panel-w: 220px;--topbar-h: 44px;--font-ui: system-ui, -apple-system, "Helvetica Neue", sans-serif;--font-mono: "JetBrains Mono", "IBM Plex Mono", "Cascadia Code", ui-monospace, monospace}body{background:var(--black);color:var(--text);font-family:var(--font-ui);font-size:13px;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;width:100%;height:100%}.topbar{display:flex;align-items:center;height:var(--topbar-h);padding:0 16px;background:var(--ink);border-bottom:1px solid var(--rule);flex-shrink:0;gap:16px}.topbar-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}.brand-mark{display:grid;place-items:center;width:26px;height:26px;background:var(--accent);color:var(--black);font-size:10px;font-weight:900;letter-spacing:.05em}.brand-name{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--secondary)}.topbar-center{flex:1;display:flex;justify-content:center}.scene-name{background:transparent;border:none;color:var(--text);font-family:var(--font-ui);font-size:13px;font-weight:500;text-align:center;width:200px;outline:none;border-bottom:1px solid transparent;padding:2px 4px;transition:border-color .15s}.scene-name:focus{border-bottom-color:var(--muted)}.topbar-actions{display:flex;gap:8px;flex-shrink:0}.tb-btn{height:28px;padding:0 14px;background:transparent;color:var(--secondary);border:1px solid var(--muted);font-family:var(--font-ui);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:color .12s,border-color .12s}.tb-btn:hover{color:var(--text);border-color:var(--dim)}.tb-btn--primary{background:var(--accent);color:var(--black);border-color:var(--accent)}.tb-btn--primary:hover{background:var(--bright);border-color:var(--bright);color:var(--black)}.workspace{flex:1;display:grid;grid-template-columns:var(--panel-w) 1fr var(--panel-w);overflow:hidden}.layers-panel,.params-panel{background:var(--ink);display:flex;flex-direction:column;overflow:hidden}.layers-panel{border-right:1px solid var(--rule)}.params-panel{border-left:1px solid var(--rule)}.panel-head{display:flex;align-items:center;justify-content:space-between;height:36px;padding:0 12px;border-bottom:1px solid var(--rule);flex-shrink:0}.panel-title{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--dim)}.panel-subtitle{font-size:9px;font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;color:var(--accent);opacity:.8}.head-actions{display:flex;gap:4px}.icon-btn{width:22px;height:22px;background:transparent;border:1px solid var(--muted);color:var(--secondary);font-size:14px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:color .12s,border-color .12s}.icon-btn:hover{color:var(--text);border-color:var(--dim)}.text-btn{background:transparent;border:1px solid var(--muted);color:var(--secondary);font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;cursor:pointer;transition:color .12s,border-color .12s}.text-btn:hover{color:var(--text);border-color:var(--dim)}.add-row{display:flex;gap:4px;padding:6px 8px;border-bottom:1px solid var(--muted)}.add-select,.comp-select{flex:1;background:var(--surface);border:1px solid var(--muted);color:var(--text);font-size:11px;padding:3px 6px;cursor:pointer}.layer-comp-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.comp-label{font-size:11px;color:var(--secondary);width:52px;flex-shrink:0}.comp-select{text-transform:capitalize}.layer-actions{display:flex;align-items:center;gap:2px;flex-shrink:0}.move-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:8px;padding:0 1px;opacity:0;transition:opacity .1s,color .1s}.layer-item:hover .move-btn{opacity:1}.move-btn:hover{color:var(--text)}.move-btn:disabled{opacity:0;cursor:default}.layer-list{list-style:none;overflow-y:auto;flex:1;padding:4px 0}.layer-item{display:flex;align-items:center;gap:6px;padding:0 10px 0 6px;height:36px;cursor:pointer;border-left:2px solid transparent;transition:background .1s;position:relative}.layer-item:hover{background:var(--surface)}.layer-item.selected{background:var(--surface);border-left-color:var(--accent)}.layer-item.hidden{opacity:.35}.vis-btn{background:none;border:none;color:var(--dim);cursor:pointer;font-size:11px;width:16px;padding:0;flex-shrink:0;line-height:1}.vis-btn:hover{color:var(--text)}.layer-icon{width:14px;height:14px;flex-shrink:0;fill:none;stroke:var(--dim);stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}.layer-item.selected .layer-icon{stroke:var(--accent)}.layer-name{flex:1;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.del-btn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:10px;padding:0;opacity:0;transition:opacity .1s,color .1s}.layer-item:hover .del-btn{opacity:1}.del-btn:hover{color:#f44}.layers-empty,.params-empty{padding:24px 16px;color:var(--dim);font-size:11px;line-height:1.6;text-align:center}.canvas-col{display:flex;flex-direction:column;overflow:hidden;background:var(--black)}.canvas-toolbar{display:flex;align-items:center;justify-content:center;gap:6px;height:36px;flex-shrink:0;border-bottom:1px solid var(--rule)}.ratio-btn{display:grid;place-items:center;width:26px;height:22px;background:transparent;border:1px solid var(--muted);color:var(--secondary);cursor:pointer;transition:border-color .12s,color .12s}.ratio-btn:hover{border-color:var(--secondary);color:var(--bright)}.ratio-btn.active{border-color:var(--accent);color:var(--accent)}.ratio-glyph{display:block;height:12px;max-width:16px;border:1.5px solid currentColor}.canvas-wrap{position:relative;flex:1;container-type:size;display:grid;place-items:center;padding:20px;background:#050505;overflow:hidden}.canvas-frame{position:relative;width:min(100cqw,100cqh * var(--ar, 1.7778));max-width:100%;max-height:100%;overflow:hidden}.webgl-canvas{display:block;width:100%;height:100%}.canvas-init{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--dim);font-size:11px;letter-spacing:.1em;text-transform:uppercase}.params-body{flex:1;overflow-y:auto;padding:8px 0}.control{padding:10px 14px;border-bottom:1px solid var(--rule)}.control-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}.control-label{font-size:9px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--secondary)}.control-value{font-family:var(--font-mono);font-size:11px;color:var(--text);min-width:28px;text-align:right}.control-value.hex{font-size:10px;color:var(--secondary)}.control-value--editable{background:transparent;border:none;outline:none;cursor:text;width:44px;padding:1px 3px;border-bottom:1px solid transparent;transition:border-color .12s,background .12s;border-radius:0;text-align:right;color:var(--text);font-family:var(--font-mono);font-size:11px}.control-value--editable:hover{border-bottom-color:var(--muted)}.control-value--editable:focus{background:var(--surface);border-bottom-color:var(--accent);color:var(--bright)}.slider-track-wrap{position:relative;height:16px;display:flex;align-items:center}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:2px;background:var(--muted);outline:none;cursor:pointer;position:relative;z-index:1}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;background:var(--text);border-radius:50%;cursor:pointer;transition:background .12s,transform .12s}.slider::-webkit-slider-thumb:hover{background:var(--accent);transform:scale(1.2)}.slider::-moz-range-thumb{width:10px;height:10px;background:var(--text);border:none;border-radius:50%;cursor:pointer}.slider-fill{position:absolute;left:0;height:2px;background:var(--accent);pointer-events:none;z-index:0;transition:width .04s}.color-swatch-wrap{display:flex;align-items:center;gap:10px;cursor:pointer}.color-swatch{width:100%;height:24px;border:1px solid var(--muted);transition:border-color .12s}.color-swatch-wrap:hover .color-swatch{border-color:var(--dim)}.color-input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}.select-wrap{position:relative}.select{width:100%;height:28px;background:var(--surface);color:var(--text);border:1px solid var(--muted);padding:0 28px 0 8px;font-family:var(--font-ui);font-size:12px;-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;outline:none;transition:border-color .12s}.select:hover{border-color:var(--dim)}.select:focus{border-color:var(--accent)}.select-arrow{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--dim);font-size:10px;pointer-events:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:grid;place-items:center;z-index:100}.modal{background:var(--ink);border:1px solid var(--rule);width:min(600px,90vw);display:flex;flex-direction:column;max-height:80vh}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--rule);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--secondary)}.modal-close{background:none;border:none;color:var(--dim);cursor:pointer;font-size:12px}.modal-close:hover{color:var(--text)}.modal-body{flex:1;overflow:auto;padding:12px}.modal-code{width:100%;height:240px;background:var(--black);color:var(--text);border:1px solid var(--rule);font-family:var(--font-mono);font-size:11px;line-height:1.6;padding:12px;resize:none;outline:none}.modal-foot{padding:12px 16px;border-top:1px solid var(--rule);display:flex;justify-content:flex-end}.tb-divider{width:1px;height:18px;background:var(--rule);margin:0 4px}.tb-user{font-size:11px;color:var(--secondary);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal--narrow{width:min(380px,92vw)}.auth-body{padding:18px}.auth-blurb{font-size:12px;color:var(--secondary);line-height:1.5;margin:0 0 14px}.auth-form{display:flex;flex-direction:column;gap:8px}.auth-input{background:var(--black);border:1px solid var(--rule);color:var(--text);font-size:13px;padding:8px 10px;outline:none}.auth-input:focus{border-color:var(--accent)}.auth-submit{width:100%;padding:8px}.auth-error{color:#f66;font-size:11px;margin:10px 0 0}.auth-sent{font-size:13px;color:var(--text);line-height:1.6;margin:0}.modal--wide{width:min(880px,92vw)}.backend-tag{font-size:8px;letter-spacing:.08em;color:var(--accent);background:var(--accent-dim);padding:1px 5px;margin-left:6px;vertical-align:middle}.gallery-body{min-height:200px}.gallery-state{display:grid;place-items:center;min-height:200px;color:var(--dim);font-size:12px;text-align:center;padding:0 24px}.gallery-error{color:#f66}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.gallery-card{position:relative;border:1px solid var(--rule);background:var(--black);cursor:pointer;transition:border-color .12s}.gallery-card:hover{border-color:var(--accent)}.gallery-thumb{aspect-ratio:16 / 9;overflow:hidden;background:#050505}.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}.gallery-thumb--empty{width:100%;height:100%;display:grid;place-items:center;color:var(--muted);font-size:10px}.gallery-meta{display:flex;flex-direction:column;gap:2px;padding:6px 8px}.gallery-name{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gallery-date{font-size:9px;color:var(--dim)}.gallery-del{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#0009;border:none;color:var(--secondary);cursor:pointer;font-size:10px;opacity:0;transition:opacity .1s,color .1s}.gallery-card:hover .gallery-del{opacity:1}.gallery-del:hover{color:#f44}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--muted)}::-webkit-scrollbar-thumb:hover{background:var(--dim)}
