.sidebar-nav{width:68px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:8px 0;gap:4px;background:var(--surface);border-right:1px solid var(--border)}.sidebar-items{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.sidebar-bottom{display:flex;flex-direction:column;align-items:center;gap:2px}.sidebar-item{display:flex;flex-direction:column;align-items:center;gap:3px;width:56px;padding:8px 0 5px;border:0;border-radius:var(--r-md);background:transparent;color:var(--text-3);cursor:pointer;transition:background .12s,color .12s}.sidebar-item:hover{background:var(--surface-raised);color:var(--text-2)}.sidebar-item.active{background:#81a1c11a;color:#88c0d0}.sidebar-item-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sidebar-item-label{font-size:10px;font-weight:500;line-height:1;letter-spacing:.01em;white-space:nowrap}.home-topbar{display:flex;align-items:center;gap:16px;height:48px;padding:0 20px 0 0;gap:12px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--surface);position:relative;z-index:30}.home-topbar-brand{flex-shrink:0;display:flex;align-items:center;gap:8px;height:100%;padding:0 18px 0 20px;cursor:pointer}.home-topbar-logo{width:24px;height:24px;object-fit:contain;flex-shrink:0;filter:none}.home-topbar-brand-name{font-size:15px;font-weight:700;letter-spacing:-.03em;color:var(--text-1);white-space:nowrap}.home-topbar-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.home-topbar-lang-btn{height:28px;padding:0 10px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-2);font-size:11px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:border-color .12s,background .12s,color .12s;white-space:nowrap;flex-shrink:0}.home-topbar-lang-btn:hover{border-color:var(--border-strong);background:var(--surface-overlay);color:var(--text-1)}.home-topbar-user-wrap{position:relative}.home-topbar-avatar{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--border-med);background:var(--surface-raised);color:var(--text-3);cursor:pointer;transition:border-color .12s,background .12s;padding:0;overflow:hidden}.home-topbar-avatar:hover{border-color:var(--border-strong);background:var(--surface-overlay);color:var(--text-2)}.home-topbar-avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.home-topbar-avatar-letter{font-size:13px;font-weight:600;color:var(--text-2);line-height:1}.home-topbar-login-btn{height:30px;padding:0 14px;border:none;border-radius:var(--r-sm);background:var(--accent-grad);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .12s;white-space:nowrap}.home-topbar-login-btn:hover{opacity:.9}.home-topbar-menu{position:absolute;top:calc(100% + 6px);right:0;width:220px;background:var(--surface-raised);border:1px solid var(--border-med);border-radius:var(--r-md);box-shadow:0 8px 24px #0006;z-index:100;padding:4px 0}.home-topbar-menu-user{padding:10px 14px 8px;display:flex;flex-direction:column;gap:2px}.home-topbar-menu-name{font-size:13px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-topbar-menu-email{font-size:11px;color:var(--text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-topbar-menu-divider{height:1px;background:var(--border);margin:4px 0}.home-topbar-menu-item{width:100%;padding:8px 14px;border:none;background:none;color:var(--text-2);font-size:13px;text-align:left;cursor:pointer;transition:background .1s,color .1s}.home-topbar-menu-item:hover{background:var(--surface-overlay);color:var(--text-1)}.hero-section{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;grid-template-rows:220px;gap:10px;padding:16px 20px 0;margin-bottom:6px;overflow:hidden}.hero-create-card{display:flex;flex-direction:column;align-items:flex-start;gap:10px;padding:20px 18px;border:1px solid var(--border);border-radius:var(--r-2xl);background:var(--surface);cursor:pointer;transition:border-color .15s,background .15s}.hero-create-card:hover{border-color:var(--accent-border);background:var(--surface-raised)}.hero-create-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:var(--r-lg);background:#81a1c11a;color:#88c0d0}.hero-create-title{margin:0;font-size:15px;font-weight:700;color:var(--text-1);letter-spacing:-.02em}.hero-create-desc{margin:0;font-size:12px;color:var(--text-3);line-height:1.4}.hero-create-btn{margin-top:auto;display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border:0;border-radius:var(--r-sm);background:var(--accent-grad);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s,box-shadow .15s}.hero-create-btn:hover{opacity:.9;box-shadow:0 0 16px #81a1c138}.hero-banner-card{position:relative;border-radius:var(--r-2xl);overflow:hidden;min-height:0;background:var(--surface-raised);cursor:pointer}.hero-banner-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.hero-banner-card:hover img{transform:scale(1.04)}.hero-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;padding:14px 16px;background:linear-gradient(0deg,rgba(0,0,0,.5) 0%,transparent 50%)}.hero-banner-title{font-size:14px;font-weight:600;color:#fff;letter-spacing:-.01em}.hero-topic-card{position:relative;border-radius:var(--r-2xl);overflow:hidden;min-height:0;background:var(--surface-raised);cursor:pointer}.hero-topic-card img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}.hero-topic-card:hover img{transform:scale(1.04)}.hero-topic-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;gap:4px;padding:14px;background:linear-gradient(0deg,rgba(0,0,0,.55) 0%,transparent 50%)}.hero-topic-label{font-size:14px;font-weight:600;color:#fff}.hero-topic-more{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:#ffffffb3;transition:color .12s}.hero-topic-card:hover .hero-topic-more{color:#fff}.content-tabs{display:flex;align-items:center;gap:12px;padding:4px 20px;position:sticky;top:0;z-index:20;background:var(--bg);border-bottom:1px solid var(--border)}.content-tabs-list{display:flex;gap:4px}.content-tab{padding:6px 14px 8px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-3);font-size:13px;font-weight:600;cursor:pointer;position:relative;transition:color .12s}.content-tab:hover{color:var(--text-2)}.content-tab.active{color:var(--text-1)}.content-tab.active:after{content:"";position:absolute;left:8px;right:8px;bottom:0;height:2px;border-radius:1px;background:var(--accent-grad)}.inspiration-card{position:relative;break-inside:avoid;margin-bottom:10px;border-radius:var(--r-lg);overflow:hidden;background:var(--surface-raised);cursor:pointer;border:1px solid var(--border);transition:border-color .15s}.inspiration-card:hover{border-color:var(--border-strong)}.inspiration-card img{width:100%;display:block;object-fit:cover}.inspiration-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:flex-end;gap:2px;padding:10px 12px;background:linear-gradient(0deg,rgba(0,0,0,.5) 0%,transparent 45%);opacity:0;transition:opacity .18s}.inspiration-card:hover .inspiration-card-overlay{opacity:1}.inspiration-card-title{font-size:12px;font-weight:600;color:#fff;letter-spacing:-.01em}.inspiration-card-author{font-size:10px;color:#ffffffb3}.masonry-feed{padding:10px 20px 20px;columns:6 160px;column-gap:10px}.ba-slider{position:relative;width:100%;aspect-ratio:16 / 10;overflow:hidden;border-radius:var(--r-lg) var(--r-lg) 0 0;cursor:col-resize;-webkit-user-select:none;user-select:none;touch-action:none;background:var(--surface-raised)}.ba-slider-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;pointer-events:none}.ba-before-clip{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.ba-slider-line{position:absolute;top:0;bottom:0;z-index:2;width:2px;transform:translate(-50%);background:#fff;box-shadow:0 0 6px #0006;pointer-events:none}.toolbox-card{border-radius:var(--r-lg);overflow:hidden;background:var(--surface);border:1px solid var(--border);transition:border-color .18s,box-shadow .18s,transform .18s;cursor:pointer}.toolbox-card:hover{border-color:var(--border-strong);box-shadow:0 4px 20px #0000004d;transform:translateY(-2px)}.toolbox-card-info{padding:10px 12px 12px}.toolbox-card-title{margin:0;font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.02em;line-height:1.35}.toolbox-card-desc{margin:4px 0 0;font-size:11px;color:var(--text-3);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.toolbox-page{flex:1;display:flex;flex-direction:column;overflow:hidden;animation:page-fade-in .2s ease}.toolbox-tabs{display:flex;align-items:center;gap:12px;padding:6px 20px;flex-shrink:0;position:sticky;top:0;z-index:20;background:var(--bg);border-bottom:1px solid var(--border)}.toolbox-tabs-list{display:flex;gap:4px}.toolbox-tab{padding:6px 14px 8px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-3);font-size:13px;font-weight:600;cursor:pointer;position:relative;transition:color .12s,background .12s}.toolbox-tab:hover{color:var(--text-2)}.toolbox-tab.active{color:var(--text-1);background:var(--surface-raised)}.toolbox-tab.active:after{content:"";position:absolute;left:8px;right:8px;bottom:0;height:2px;border-radius:1px;background:var(--accent-grad)}.toolbox-scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.toolbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:16px 20px 24px}@media (min-width: 1400px){.toolbox-grid{grid-template-columns:repeat(5,1fr)}}@media (max-width: 900px){.toolbox-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;padding:12px 14px 20px}}@media (max-width: 500px){.toolbox-grid{grid-template-columns:repeat(2,1fr);gap:8px}}.asset-panel{position:absolute;top:0;right:0;bottom:0;width:456px;max-width:90%;display:flex;flex-direction:column;background:#111113f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-left:1px solid var(--bp-border);z-index:20;transform:translate(100%);transition:transform .35s cubic-bezier(.16,1,.3,1);will-change:transform;pointer-events:none}.asset-panel.open{transform:translate(0);pointer-events:auto}.asset-panel-header{display:flex;align-items:center;gap:10px;padding:14px 18px 12px;border-bottom:1px solid var(--bp-border);flex-shrink:0}.asset-panel-title{font-size:14px;font-weight:600;color:var(--bp-text);white-space:nowrap}.asset-panel-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--bp-text-dim);font-size:16px;cursor:pointer;transition:background .15s,color .15s;margin-left:auto;flex-shrink:0}.asset-panel-close:hover{background:var(--bp-surface2);color:var(--bp-text)}.asset-panel-search{padding:8px 18px;flex-shrink:0}.asset-panel-search input{width:100%;padding:8px 12px;border:1px solid var(--bp-border);border-radius:6px;background:var(--bp-surface);color:var(--bp-text);font-size:13px;outline:none;transition:border-color .15s}.asset-panel-search input::placeholder{color:var(--bp-text-dim)}.asset-panel-search input:focus{border-color:var(--bp-accent)}.asset-panel-tabs{display:flex;flex-wrap:wrap;gap:5px;padding:6px 18px 10px;flex-shrink:0}.asset-tab{padding:5px 12px;border:1px solid var(--bp-border);border-radius:12px;background:transparent;color:var(--bp-text-dim);font-size:12px;white-space:nowrap;cursor:pointer;transition:all .15s;flex-shrink:0}.asset-tab:hover{background:var(--bp-surface2);color:var(--bp-text)}.asset-tab.active{background:var(--bp-accent);color:#fff;border-color:var(--bp-accent)}.asset-panel-body{flex:1;overflow-y:auto;padding:4px 0 18px;scrollbar-width:thin;scrollbar-color:var(--bp-border) transparent}.asset-accordion{border-bottom:1px solid rgba(255,255,255,.04)}.asset-accordion-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 18px;border:none;background:transparent;color:var(--bp-text);font-size:13px;font-weight:500;cursor:pointer;transition:background .12s;text-align:left}.asset-accordion-header:hover{background:var(--bp-surface2)}.asset-accordion-icon{font-size:16px;flex-shrink:0;width:22px;text-align:center}.asset-accordion-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-accordion-count{font-size:11px;color:var(--bp-text-dim);flex-shrink:0;background:#ffffff0f;padding:1px 7px;border-radius:8px;font-weight:400}.asset-accordion-arrow{flex-shrink:0;color:var(--bp-text-dim);transition:transform .2s ease}.asset-accordion-header.expanded .asset-accordion-arrow{transform:rotate(90deg)}.asset-accordion-body{padding:0 14px 10px;animation:accordion-slide-in .15s ease-out}@keyframes accordion-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.asset-subcat-section{margin-bottom:6px}.asset-subcat-label{display:flex;align-items:center;gap:6px;padding:6px 4px 4px;font-size:11px;font-weight:600;color:var(--bp-text-dim);letter-spacing:.02em;text-transform:none}.asset-subcat-count{font-size:10px;font-weight:400;color:#ffffff47}.asset-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;align-items:start}.asset-thumb{display:flex;flex-direction:column;align-items:stretch;gap:4px;width:100%;min-width:0;box-sizing:border-box;justify-self:stretch;cursor:grab;user-select:none;-webkit-user-select:none;border-radius:8px;padding:6px 4px;transition:background .15s}.asset-thumb:hover{background:var(--bp-surface2)}.asset-thumb:active{cursor:grabbing}.asset-thumb-img{width:100%;max-width:100%;min-width:0;aspect-ratio:1;border-radius:6px;background:var(--bp-surface);border:1px solid var(--bp-border);display:flex;align-items:center;justify-content:center;color:var(--bp-text-dim);font-size:22px;overflow:hidden;flex-shrink:0}.asset-thumb-img img{width:100%;height:100%;object-fit:cover;display:block}.asset-thumb-name{font-size:11px;color:var(--bp-text-dim);text-align:left;line-height:1.2;max-width:100%;min-height:2.4em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;word-break:break-word}.asset-panel-empty{display:flex;align-items:center;justify-content:center;height:140px;color:var(--bp-text-dim);font-size:13px}.asset-panel-trigger{position:absolute;top:8px;right:8px;z-index:15;display:flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid var(--bp-border);border-radius:6px;background:#111113d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--bp-text-dim);font-size:12px;cursor:pointer;transition:all .15s}.asset-panel-trigger:hover{background:var(--bp-surface2);color:var(--bp-text);border-color:var(--bp-accent)}.asset-panel-trigger .trigger-icon{font-size:14px;transition:transform .25s ease}.asset-panel-trigger.panel-open .trigger-icon{transform:rotate(180deg)}.asset-drag-ghost{position:fixed;pointer-events:none;z-index:9999;width:84px;padding:0;display:flex;flex-direction:column;align-items:stretch;gap:5px;color:var(--bp-accent);opacity:.96;transform:translate(-50%,-50%)}.asset-drag-ghost-thumb{width:100%;aspect-ratio:1;overflow:hidden;border-radius:8px;border:1px solid var(--bp-border);background:var(--bp-surface);display:flex;align-items:center;justify-content:center;font-size:24px}.asset-drag-ghost-thumb img{width:100%;height:100%;object-fit:cover;display:block}.asset-drag-ghost-progress{height:6px;overflow:hidden;border-radius:999px;background:#1111136b;border:1px solid rgba(255,255,255,.08)}.asset-drag-ghost-progress-fill{height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,#6ea8ff,#91c1ff);transition:width .08s linear}.asset-drag-ghost-progress-fill.indeterminate{animation:asset-ghost-progress 1s linear infinite}@keyframes asset-ghost-progress{0%{transform:translate(-120%)}to{transform:translate(220%)}}.build-save-status{font-size:11px;font-weight:500;padding:2px 8px;border-radius:var(--r-xs);margin-left:12px;flex-shrink:0}.build-save-saving{color:var(--text-3)}.build-save-saved{color:#34d399}.build-save-error{color:var(--danger)}.build-page{display:flex;flex-direction:column;height:100%;padding:10px 14px 14px;overflow:hidden;--bp-bg: var(--bg);--bp-surface: var(--surface);--bp-surface2: var(--surface-raised);--bp-border: var(--border-med);--bp-text: var(--text-1);--bp-text-dim: var(--text-2);--bp-accent: var(--accent);--bp-accent-hover: var(--accent-hover);--bp-accent-subtle: var(--accent-subtle);--bp-accent-border: var(--accent-border);--bp-wall-color: var(--text-3);--bp-wall-selected: var(--accent);--bp-room-fill: rgba(129, 161, 193, .06)}.build-page .build-body{display:flex;flex:1;overflow:hidden}.build-page .panel-2d{display:flex;flex-direction:column;flex:1;min-width:0;border-right:1px solid var(--bp-border);position:relative;overflow:hidden}.build-page .floor-plan-editor-root{flex:1;min-height:0;display:flex;flex-direction:column}.build-page .panel-3d{flex:2;min-width:0;position:relative;background:var(--bp-bg)}.build-page .panel-3d iframe{width:100%;height:100%;border:none}.build-page .gpu-lost-banner{position:absolute;left:50%;bottom:48px;transform:translate(-50%);z-index:8;font-size:13px;line-height:1.4;color:#fff;background:#b42828e0;padding:8px 32px 8px 14px;border-radius:6px;white-space:nowrap;-webkit-user-select:none;user-select:none}.build-page .gpu-lost-banner button{position:absolute;top:4px;right:6px;background:none;border:none;color:#fff;font-size:16px;cursor:pointer;line-height:1;opacity:.7}.build-page .gpu-lost-banner button:hover{opacity:1}.build-page .engine-3d-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;display:flex;align-items:center;justify-content:center;padding:16px;background:#09090b}.build-page .engine-3d-loading-lottie{width:92px;max-width:100%}.build-page .engine-3d-loading-lottie svg{width:100%;height:auto;display:block}.build-page .toolbar{display:flex;align-items:center;gap:2px;padding:6px 10px;background:var(--bp-surface);border-bottom:1px solid var(--bp-border);flex-shrink:0;min-width:0}.build-page .toolbar-spacer{flex:1}.build-page .build-toolbar-shell{position:relative;flex-shrink:0}.build-page .toolbar.toolbar-with-slot{position:relative}.build-page .toolbar.toolbar-with-slot:before{content:"";position:absolute;left:33.333%;top:15%;height:70%;width:1px;background:var(--bp-border);pointer-events:none}.build-page .toolbar-main{display:flex;align-items:center;gap:2px;min-width:0}.build-page .toolbar-right-slot{position:absolute;top:50%;left:calc(33.333% + 10px);right:10px;transform:translateY(-50%);display:flex;align-items:center;min-width:0;z-index:1}.build-page .build-gizmo-slot{display:flex;align-items:center;min-width:0;flex:1;width:100%}.build-page .toolbar-hint{font-size:11px;color:var(--bp-text-dim);margin-left:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:min(28vw,420px)}.build-page .toolbar-btn{display:flex;align-items:center;gap:5px;padding:5px 12px;border:1px solid transparent;border-radius:6px;background:transparent;color:var(--bp-text-dim);font-size:12px;cursor:pointer;transition:all .15s}.build-page .toolbar-btn:hover{background:var(--bp-surface2);color:var(--bp-text)}.build-page .toolbar-btn.active{background:var(--bp-accent);color:#fff;border-color:var(--bp-accent)}.build-page .toolbar-btn.delete-btn{color:var(--danger);border-color:#ef44444d}.build-page .toolbar-btn.delete-btn:hover{background:var(--danger);color:#fff}.build-page .toolbar-btn:disabled{opacity:.3;cursor:default;pointer-events:none}.build-page .toolbar-icon{font-size:15px}.build-page .toolbar-label{font-size:12px}.build-page .gizmo-bar{--gizmo-bar-item-height: 30px;display:flex;align-items:center;gap:2px;flex:1;min-width:0;width:100%;height:var(--gizmo-bar-item-height);min-height:var(--gizmo-bar-item-height);overflow:hidden}.build-page .gizmo-bar .toolbar-btn{min-height:var(--gizmo-bar-item-height);box-sizing:border-box}.build-page .gizmo-bar .toolbar-label{line-height:1}.build-page .gizmo-bar>*:not(.shot-list){flex-shrink:0}.build-page .gizmo-bar-sep-wrap{display:flex;align-items:center;flex-shrink:0;align-self:center;box-sizing:border-box}.build-page .gizmo-bar-sep-wrap--after-tools{margin-left:2px;padding:0 16px 0 6px}.build-page .gizmo-bar-sep-wrap--after-camera{margin-left:10px;padding:0 6px 0 20px}.build-page .gizmo-bar-sep{display:block;width:1px;height:18px;background:var(--bp-border);flex-shrink:0;opacity:.95}.build-page .gizmo-rotate90-compound{display:flex;align-items:stretch;flex-shrink:0;min-height:var(--gizmo-bar-item-height)}.build-page .gizmo-rotate90-main{border-radius:6px 0 0 6px;border-right:none;padding-right:6px}.build-page .gizmo-rotate90-main.active{border-right:none}.build-page .gizmo-rotate90-mini{display:flex;align-items:center;justify-content:center;box-sizing:border-box;min-width:32px;padding:4px 6px;margin:0;border:1px solid var(--bp-border);border-radius:0 6px 6px 0;border-left:1px solid var(--bp-border);background:var(--bp-surface2);color:var(--bp-text-dim);font-size:11px;font-weight:700;line-height:1;letter-spacing:-.02em;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.build-page .gizmo-rotate90-mini:not(.active):hover{background:var(--bp-surface);color:var(--bp-text)}.build-page .gizmo-rotate90-mini.active{background:var(--bp-accent);color:#fff;border-color:var(--bp-accent)}.build-page .gizmo-rotate90-mini.active:hover{background:var(--bp-accent-hover);color:#fff;border-color:var(--bp-accent-hover)}.build-page .gizmo-rotate90-main.active+.gizmo-rotate90-mini:not(.active){border-left-color:#ffffff1f}.build-page .gizmo-rotate90-main.active+.gizmo-rotate90-mini.active{border-left-color:#fff3}.build-page .gizmo-camera-bar{display:flex;align-items:center;gap:5px;flex-shrink:0;max-width:100%;min-height:var(--gizmo-bar-item-height)}.build-page .gizmo-camera-bar-select+.gizmo-camera-bar-label{margin-left:8px}.build-page .gizmo-camera-bar-label{display:inline-flex;align-items:center;height:var(--gizmo-bar-item-height);box-sizing:border-box;font-size:12px;line-height:1;font-weight:400;color:var(--bp-text-dim);white-space:nowrap;flex-shrink:0}.build-page .gizmo-camera-bar-select{width:62px;max-width:62px;height:var(--gizmo-bar-item-height);min-height:var(--gizmo-bar-item-height);padding:0 5px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--bp-text-dim);font-size:12px;line-height:1;font-weight:400;cursor:pointer;outline:none;transition:border-color .12s;box-sizing:border-box;vertical-align:middle}.build-page .gizmo-camera-bar-select:hover,.build-page .gizmo-camera-bar-select:focus{border-color:var(--border-strong)}.build-page .camera-field-input-wrap.camera-fov-bar{width:62px;max-width:62px;min-width:62px;flex:0 0 62px;height:var(--gizmo-bar-item-height);min-height:var(--gizmo-bar-item-height);max-height:var(--gizmo-bar-item-height);padding:0 5px;gap:3px;box-sizing:border-box;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);transition:border-color .12s}.build-page .camera-field-input-wrap.camera-fov-bar:hover{border-color:var(--border-strong)}.build-page .camera-fov-bar .camera-field-input{font-size:12px;line-height:1.2;font-weight:400;color:var(--bp-text-dim);min-width:0;min-height:0;align-self:center}.build-page .camera-fov-bar:focus-within .camera-field-input{color:var(--bp-text)}.build-page .camera-fov-bar .camera-field-unit{font-size:12px;line-height:1.2;color:var(--bp-text-dim)}.build-page .camera-field-input-wrap{display:flex;align-items:center;gap:4px;background:var(--surface-raised);border:1px solid var(--border-med);border-radius:var(--r-sm);padding:5px 8px;flex:1;transition:border-color .12s}.build-page .camera-field-input-wrap:focus-within{border-color:var(--border-strong)}.build-page .camera-field-input{border:none;background:transparent;color:var(--bp-text);font-size:11px;flex:1;min-width:0;text-align:right;outline:none}.build-page .camera-field-input::-webkit-inner-spin-button,.build-page .camera-field-input::-webkit-outer-spin-button{-webkit-appearance:none}.build-page .camera-field-unit{font-size:11px;color:var(--bp-text-dim);flex-shrink:0}.build-page .camera-fov-scrub-wrap{cursor:ew-resize;-webkit-user-select:none;user-select:none}.build-page .camera-fov-scrub-wrap:focus-within:not(.is-scrubbing){cursor:text}.build-page .camera-fov-scrub-wrap.is-scrubbing{cursor:ew-resize}.build-page .camera-fov-scrub-wrap .camera-field-input{cursor:inherit}.build-page .toolbar-room-tool-group{display:inline-flex;align-items:center;gap:4px}.build-page .room-height-group{display:inline-flex;align-items:center;gap:0}.build-page .camera-field-input-wrap.room-height-bar{width:72px;max-width:72px;min-width:72px;flex:0 0 72px;height:30px;min-height:30px;max-height:30px;padding:0 5px;gap:3px;box-sizing:border-box;border:1px solid var(--border-med);border-radius:var(--r-sm) 0 0 var(--r-sm);background:var(--surface-raised);transition:border-color .12s}.build-page .camera-field-input-wrap.room-height-bar:hover{border-color:var(--border-strong)}.build-page .room-height-bar .camera-field-input{font-size:12px;line-height:1.2;font-weight:400;color:var(--bp-text-dim);min-width:0;min-height:0;align-self:center}.build-page .room-height-bar:focus-within .camera-field-input{color:var(--bp-text)}.build-page .room-height-bar .camera-field-unit{font-size:12px;line-height:1.2;color:var(--bp-text-dim)}.build-page .toolbar-room-unit-btn{height:30px;min-height:30px;padding:0 7px;border:1px solid var(--border-med);border-left:none;border-radius:0 var(--r-sm) var(--r-sm) 0;background:var(--surface-raised);color:var(--bp-text-dim);font-size:11px;font-weight:400;cursor:pointer;outline:none;transition:background .12s,color .12s,border-color .12s;box-sizing:border-box;white-space:nowrap}.build-page .toolbar-room-unit-btn:hover{background:var(--bp-surface2);color:var(--bp-text);border-color:var(--border-strong)}.build-page .panel-3d-room-height{position:absolute;bottom:14px;left:14px;z-index:6;display:flex;align-items:center;gap:6px;pointer-events:auto;background:#1e1e1ed1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:4px 10px 4px 8px;border-radius:6px;box-shadow:0 2px 8px #00000040}.build-page .panel-3d-room-height-label{font-size:11px;color:#ffffffb8;white-space:nowrap;-webkit-user-select:none;user-select:none}.build-page .gizmo-export-wrap{position:relative;margin-left:auto;flex-shrink:0}.build-page .gizmo-export-icon-wrap{display:inline-flex;align-items:center;justify-content:center;line-height:0}.build-page .gizmo-export-btn svg{display:block}.build-page .gizmo-export-caret{margin-left:2px;opacity:.55;flex-shrink:0}.gizmo-export-menu{min-width:152px;padding:4px 0;border-radius:8px;background:var(--bp-surface, #1a1a20);border:1px solid var(--bp-border, rgba(255, 255, 255, .12));box-shadow:0 8px 24px #00000047;display:flex;flex-direction:column}.gizmo-export-menu-item{display:flex;align-items:center;width:100%;padding:7px 14px;border:none;background:transparent;color:var(--bp-text, rgba(255, 255, 255, .92));font-size:12px;cursor:pointer;white-space:nowrap;text-align:left;transition:background .12s}.gizmo-export-menu-item:hover{background:var(--bp-accent-subtle, rgba(99, 102, 241, .1))}.build-page .gizmo-lock-icon-wrap{display:inline-flex;align-items:center;justify-content:center;line-height:0}.build-page .gizmo-lock-svg{display:block}.build-page .gizmo-lock-btn.active{color:var(--bp-accent);border-color:var(--bp-accent-border);background:var(--bp-accent-subtle)}.build-page .shot-list{display:flex;align-items:center;gap:3px;flex:1;min-width:0;min-height:0;max-height:var(--gizmo-bar-item-height);overflow:hidden}.build-page .shot-list-track{display:flex;align-items:center;gap:3px;flex:1;min-width:0;min-height:0;max-height:var(--gizmo-bar-item-height);overflow-x:auto;overflow-y:hidden;overflow-y:clip;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;contain:paint}.build-page .shot-list-track::-webkit-scrollbar{display:none}.build-page .shot-chip-group{display:inline-flex;align-items:stretch;flex-shrink:0;border-radius:var(--r-xs);border:1px solid var(--bp-border);background:var(--bp-surface2);overflow:hidden;transition:border-color .15s,background .15s}.build-page .shot-chip-group:hover{border-color:var(--border-strong)}.build-page .shot-chip-group.active{border-color:var(--bp-accent);background:var(--bp-accent)}.build-page .shot-chip{display:flex;align-items:center;padding:4px 10px;border:none;border-radius:0;background:transparent;color:var(--bp-text-dim);font-size:11px;cursor:pointer;white-space:nowrap;transition:color .15s;flex-shrink:0}.build-page .shot-chip-group:hover .shot-chip{color:var(--bp-text)}.build-page .shot-chip-group.active .shot-chip{color:#fff}.build-page .shot-chip-remove{display:flex;align-items:center;justify-content:center;width:22px;flex-shrink:0;padding:0;border:none;border-left:1px solid rgba(255,255,255,.22);background:transparent;color:#ffffffd9;cursor:pointer;transition:background .12s,color .12s}.build-page .shot-chip-remove:hover{background:#0000001f;color:#fff}.build-page .shot-arrow{display:flex;align-items:center;justify-content:center;width:22px;height:24px;border:1px solid var(--bp-border);border-radius:var(--r-xs);background:transparent;color:var(--bp-text-dim);font-size:15px;cursor:pointer;flex-shrink:0;transition:all .15s;line-height:1}.build-page .shot-arrow:hover{background:var(--bp-surface2);color:var(--bp-text);border-color:var(--border-strong)}.build-page .toolbar-dropdown{position:relative}.build-page .toolbar-caret{font-size:10px;color:var(--bp-text-dim);margin-left:2px;transition:transform .15s}.build-page .toolbar-menu{position:absolute;top:calc(100% + 4px);left:0;z-index:100;min-width:120px;padding:4px;background:var(--surface-overlay);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:0 8px 24px #00000080}.build-page .toolbar-menu-item{display:flex;align-items:center;width:100%;padding:7px 10px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--bp-text-dim);font-size:12px;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.build-page .toolbar-menu-item:hover{background:var(--surface-raised);color:var(--bp-text)}.build-page .toolbar-menu-item.active{color:var(--bp-text);background:var(--bp-accent-subtle)}.build-page .floor-plan-svg{flex:1;width:100%;background:var(--bp-bg);cursor:crosshair;touch-action:none;outline:none}.build-page .floor-plan-svg:focus{outline:none}.build-page .grid-line{stroke:var(--bp-border);stroke-width:.5}.build-page .grid-line-major{stroke:var(--bp-border);stroke-width:.8;opacity:.7}.build-page .room-fill{fill:var(--bp-room-fill);stroke:none}.build-page .wall{fill:var(--bp-wall-color);stroke:none;cursor:pointer}.build-page .wall.selected{fill:var(--bp-wall-selected)}.build-page .corner-handle{fill:var(--bp-surface);stroke:var(--bp-accent);stroke-width:2;cursor:grab}.build-page .corner-handle:hover{r:8;fill:var(--bp-accent)}.build-page .dimension-label{fill:var(--bp-text-dim);font-size:11px;font-family:Inter,sans-serif;pointer-events:none;-webkit-user-select:none;user-select:none}.build-page .draw-preview-room{fill:#81a1c11a;stroke:var(--bp-accent);stroke-width:2;stroke-dasharray:6,4;pointer-events:none}.build-page .draw-preview-opening{fill:#88c0d01f;stroke:#88c0d0;stroke-width:2;stroke-dasharray:6,4;pointer-events:none}.build-page .draw-preview-bump{fill:#a3be8c1f;stroke:#a3be8c;stroke-width:2;stroke-dasharray:6,4;pointer-events:none}.build-page .draw-preview-stairs{fill:#81a1c114;stroke:var(--text-3);stroke-width:1.5;stroke-dasharray:4,3;pointer-events:none}.build-page .draw-preview-label{fill:var(--bp-accent);font-size:13px;font-weight:600;font-family:Inter,sans-serif;pointer-events:none;-webkit-user-select:none;user-select:none}.build-page .build-toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--r-sm, 8px);background:var(--surface-raised, #1c1c1f);border:1px solid var(--border-med, rgba(255, 255, 255, .11));color:var(--text-1, #f4f4f5);font-size:13px;line-height:1.4;white-space:nowrap;box-shadow:0 6px 20px #00000059;z-index:30000;pointer-events:none;animation:build-toast-in .22s ease-out}.build-page .build-toast svg{flex-shrink:0;color:var(--accent, #81a1c1)}@keyframes build-toast-in{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.fp-context-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999}.fp-context-menu{position:fixed;min-width:120px;background:var(--surface, #2b2d31);border:1px solid var(--border-med, #444);border-radius:6px;box-shadow:0 4px 16px #00000059;padding:4px 0;z-index:10000}.fp-context-menu-item{display:block;width:100%;padding:7px 16px;background:none;border:none;color:var(--text-1, #e0e0e0);font-size:13px;text-align:left;cursor:pointer;white-space:nowrap}.fp-context-menu-item:hover{background:var(--accent-subtle, rgba(100, 160, 255, .15))}.window-editor-root{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;background:var(--bp-bg);overflow:hidden}.window-editor-svg{max-width:100%;max-height:100%;display:block}.we-grid-line{stroke:var(--bp-border, #333);stroke-width:.5;opacity:.3}.we-outer{fill:#ffffff14;stroke:var(--bp-wall-color, #aaa);stroke-width:2;vector-effect:non-scaling-stroke}.we-frame-ring{fill:#ffffff1f;stroke:none;pointer-events:none}.we-mullion-line{stroke-linecap:square;pointer-events:none}.we-mullion-hit{pointer-events:stroke;cursor:grab}.we-mullion-hit:active{cursor:grabbing}.we-dim-label{fill:var(--bp-text-dim, #888);font-size:12px;font-variant-numeric:tabular-nums;-webkit-user-select:none;user-select:none}.build-page .we-toolbar-inline{display:flex;align-items:center;gap:2px;min-width:0;overflow:hidden}.we-toolbar-title{font-size:13px;font-weight:600;color:var(--bp-text, #e0e0e0);white-space:nowrap;margin:0 4px}.build-page .toolbar-separator{width:1px;height:20px;background:var(--bp-border, #444);margin:0 6px;flex-shrink:0}.we-toolbar-group{display:flex;align-items:center;gap:4px;margin-left:6px;flex-shrink:0}.we-toolbar-label,.we-toolbar-sub-label{font-size:11px;color:var(--bp-text-dim, #888);white-space:nowrap}.we-toolbar-range{width:80px;vertical-align:middle}.we-toolbar-range--short{width:60px}.we-toolbar-val{display:inline-block;min-width:3ch;text-align:end;font-size:11px;font-variant-numeric:tabular-nums;color:var(--bp-text, #e0e0e0)}.we-toolbar-count{width:3rem;padding:3px 6px;border-radius:4px;border:1px solid var(--bp-border, #444);background:var(--bp-surface, #2b2d31);color:var(--bp-text, #e0e0e0);font-size:12px;font-variant-numeric:tabular-nums}.we-toolbar-check{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--bp-text-dim, #888);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.engine3d-opening-contextmenu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10050;background:transparent}.engine3d-opening-contextmenu-panel{position:fixed;z-index:10051;min-width:8rem;padding:4px 0;border-radius:6px;border:1px solid var(--bp-border, #444);background:var(--bp-surface2, #32353b);box-shadow:0 6px 24px #00000073}.engine3d-opening-contextmenu-item{display:block;width:100%;padding:8px 14px;border:none;background:none;color:var(--bp-text, #e8e8e8);font-size:13px;text-align:left;cursor:pointer}.engine3d-opening-contextmenu-item:hover{background:var(--bp-accent-subtle, rgba(74, 158, 255, .15))}.build-page .carpet-decal-editor-panel{padding:12px 14px;max-width:100%}.build-page .carpet-decal-editor-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:12px;color:var(--bp-text, #e0e0e0)}.build-page .carpet-decal-editor-row input[type=range]{flex:1;min-width:0}.build-page .carpet-decal-editor-value{min-width:2.5rem;font-variant-numeric:tabular-nums;color:var(--bp-text-dim, #aaa)}.build-page .carpet-decal-editor-circle-btn{width:100%;padding:8px 10px;border-radius:4px;border:1px solid var(--bp-border, #444);background:var(--bp-surface, #2b2d31);color:var(--bp-text, #e8e8e8);font-size:12px;cursor:pointer}.build-page .carpet-decal-editor-circle-btn:hover:not(:disabled){background:var(--bp-accent-subtle, rgba(74, 158, 255, .12))}.build-page .carpet-decal-editor-circle-btn:disabled{opacity:.45;cursor:not-allowed}.build-page .carpet-decal-editor-hint{margin:0;font-size:11px;color:var(--bp-text-dim, #888)}.ci-row{display:flex;align-items:center;gap:6px;width:100%;padding:6px 12px;border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:12px;font-weight:500;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;-webkit-user-select:none;user-select:none}.ci-row:hover{background:var(--surface-raised);color:var(--text-1)}.ci-row.ci-selected{background:var(--accent-subtle);color:#88c0d0}.ci-row.ci-editing{background:var(--surface-raised)}.ci-arrow{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;border-radius:3px;color:var(--text-3);transition:transform .1s ease,color .1s}.ci-arrow:hover{color:var(--text-1);background:var(--surface-overlay)}.ci-arrow-open{transform:rotate(90deg)}.ci-arrow-placeholder{width:16px;height:16px;flex-shrink:0}.ci-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.ci-counts{flex-shrink:0;margin-left:auto;display:inline-flex;align-items:center;gap:3px;font-size:10px;font-weight:600;color:var(--text-3)}.ci-count-own{min-width:12px;text-align:center}.ci-count-total{opacity:.6;font-weight:500}.ci-row:hover .ci-counts{color:var(--text-2)}.ci-row.ci-selected .ci-counts{color:#88c0d0}.ci-row.ci-selected .ci-count-total{opacity:.7}.ci-rename-input{flex:1;min-width:0;padding:1px 4px;border:1px solid var(--accent-border);border-radius:3px;background:var(--surface-overlay);color:var(--text-1);font-size:12px;font-weight:500;font-family:inherit;outline:none;line-height:1.4}.ci-rename-input:focus{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-border)}.ci-row.ci-drag-before{box-shadow:0 -2px #88c0d0;border-radius:0}.ci-row.ci-drag-middle{background:#88c0d026;box-shadow:inset 0 0 0 1px #88c0d04d}.ci-row.ci-drag-after{box-shadow:0 2px #88c0d0;border-radius:0}.ci-row.ci-dragging{opacity:.3;pointer-events:none}.ci-children-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .1s ease}.ci-children-wrap.ci-expanded{grid-template-rows:1fr}.ci-children{position:relative;min-height:0;overflow:hidden}.ci-children:before{content:"";position:absolute;left:var(--ci-guide-left, 20px);top:0;bottom:6px;width:1px;background:var(--border-med, rgba(255, 255, 255, .08));pointer-events:none}.ccm-menu{position:fixed;z-index:1100;min-width:150px;padding:4px;background:var(--surface-overlay);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:0 8px 24px #00000080;animation:ccm-pop .1s ease}@keyframes ccm-pop{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.ccm-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:12px;font-weight:500;text-align:left;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.ccm-item:hover{background:var(--surface-raised);color:var(--text-1)}.ccm-item.ccm-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.ccm-item.ccm-delete{color:#d14b57}.ccm-item.ccm-delete:hover{background:#d14b571f;color:#e45562}.ccm-item svg{flex-shrink:0}.ccm-divider{height:1px;margin:3px 6px;background:var(--border)}.cd-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;background:#00000094;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:cd-fade-in .12s ease}@keyframes cd-fade-in{0%{opacity:0}to{opacity:1}}.cd-dialog{width:min(360px,calc(100vw - 32px));padding:18px;border:1px solid var(--border-strong);border-radius:var(--r-lg);background:var(--surface-overlay);box-shadow:0 18px 48px #00000073;animation:cd-slide-up .15s ease}@keyframes cd-slide-up{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.cd-title{margin:0 0 8px;font-size:15px;font-weight:600;color:var(--text-1)}.cd-message{margin:0;font-size:13px;color:var(--text-2);line-height:1.5}.cd-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.cd-cancel,.cd-confirm{min-width:76px;padding:7px 12px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer;transition:opacity .12s,background .12s}.cd-cancel{border:1px solid var(--border-med);background:var(--surface-raised);color:var(--text-2)}.cd-cancel:hover{background:var(--surface-overlay);color:var(--text-1)}.cd-confirm{border:0;background:var(--accent-grad);color:#fff}.cd-confirm:hover{opacity:.88}.cd-confirm.cd-danger{background:#d14b57}.cd-confirm.cd-danger:hover{background:#c0404b}.cd-cancel:disabled,.cd-confirm:disabled{opacity:.55;cursor:not-allowed}.mtc-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:center;justify-content:center;background:#00000094;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:mtc-fade .12s ease}@keyframes mtc-fade{0%{opacity:0}to{opacity:1}}.mtc-dialog{display:flex;flex-direction:column;width:min(380px,calc(100vw - 32px));max-height:min(520px,calc(100vh - 80px));border:1px solid var(--border-strong);border-radius:var(--r-lg);background:var(--surface-overlay);box-shadow:0 18px 48px #00000073;animation:mtc-slide .15s ease;overflow:hidden}@keyframes mtc-slide{0%{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.mtc-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;flex-shrink:0}.mtc-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mtc-close{display:grid;place-items:center;width:24px;height:24px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-3);cursor:pointer;flex-shrink:0;transition:background .1s,color .1s}.mtc-close:hover{background:var(--surface-raised);color:var(--text-1)}.mtc-search{position:relative;display:flex;align-items:center;padding:0 12px 8px;flex-shrink:0}.mtc-search-icon{position:absolute;left:20px;color:var(--text-3);pointer-events:none}.mtc-search-input{width:100%;padding:7px 28px 7px 30px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-1);font-size:12px;outline:none;transition:border-color .12s,background .12s}.mtc-search-input::placeholder{color:var(--text-3)}.mtc-search-input:focus{border-color:var(--accent-border);background:var(--surface-overlay)}.mtc-search-clear{position:absolute;right:18px;display:grid;place-items:center;width:18px;height:18px;border:0;border-radius:50%;background:transparent;color:var(--text-3);cursor:pointer;transition:color .12s,background .12s}.mtc-search-clear:hover{color:var(--text-1);background:var(--surface-overlay)}.mtc-tree{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 8px 8px;scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.mtc-node{display:flex;align-items:center;gap:6px;width:100%;padding:7px 12px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:12px;font-weight:500;text-align:left;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.mtc-node:hover{background:var(--surface-raised);color:var(--text-1)}.mtc-node.mtc-node-selected{background:var(--accent-subtle);color:#88c0d0}.mtc-node-root{margin-bottom:2px}.mtc-arrow{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;border-radius:3px;color:var(--text-3);transition:transform .15s,color .12s}.mtc-arrow:hover{color:var(--text-1);background:var(--surface-overlay)}.mtc-arrow-open{transform:rotate(90deg)}.mtc-arrow-placeholder{width:16px;height:16px;flex-shrink:0}.mtc-folder-icon{flex-shrink:0;color:var(--text-3)}.mtc-node.mtc-node-selected .mtc-folder-icon{color:#88c0d0}.mtc-node-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.mtc-empty{padding:20px 0;text-align:center;color:var(--text-3);font-size:12px}.mtc-footer{display:flex;justify-content:flex-end;gap:8px;padding:10px 16px 14px;border-top:1px solid var(--border);flex-shrink:0}.mtc-cancel,.mtc-confirm{min-width:76px;padding:7px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer;transition:opacity .12s,background .12s}.mtc-cancel{border:1px solid var(--border-med);background:var(--surface-raised);color:var(--text-2)}.mtc-cancel:hover{background:var(--surface-overlay);color:var(--text-1)}.mtc-confirm{border:0;background:var(--accent-grad);color:#fff}.mtc-confirm:hover{opacity:.88}.mtc-confirm:disabled{opacity:.45;cursor:not-allowed}.mtc-children-wrap{display:grid;grid-template-rows:0fr;transition:grid-template-rows .1s ease}.mtc-children-wrap.mtc-expanded{grid-template-rows:1fr}.mtc-children{position:relative;min-height:0;overflow:hidden}.mtc-children:before{content:"";position:absolute;left:var(--mtc-guide-left, 20px);top:0;bottom:6px;width:1px;background:var(--border-med, rgba(255, 255, 255, .08));pointer-events:none}.ct-root{display:flex;flex-direction:column;height:100%;overflow:hidden}.ct-search{position:relative;display:flex;align-items:center;padding:10px 10px 8px;flex-shrink:0}.ct-search-icon{position:absolute;left:18px;color:var(--text-3);pointer-events:none}.ct-search-input{width:100%;padding:7px 28px 7px 30px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-1);font-size:12px;outline:none;transition:border-color .12s,background .12s}.ct-search-input::placeholder{color:var(--text-3)}.ct-search-input:focus{border-color:var(--accent-border);background:var(--surface-overlay)}.ct-search-clear{position:absolute;right:16px;display:grid;place-items:center;width:18px;height:18px;border:0;border-radius:50%;background:transparent;color:var(--text-3);cursor:pointer;transition:color .12s,background .12s}.ct-search-clear:hover{color:var(--text-1);background:var(--surface-overlay)}.ct-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:0 6px 10px;scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.ct-item{display:flex;align-items:center;gap:6px;width:100%;padding:6px 12px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:12px;font-weight:500;text-align:left;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ct-item:hover{background:var(--surface-raised);color:var(--text-1)}.ct-item.ct-selected{background:var(--accent-subtle);color:#88c0d0}.ct-item-all{margin-bottom:4px;padding-left:12px}.ct-item-all svg{flex-shrink:0}.ct-arrow{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0;border-radius:3px;color:var(--text-3);transition:transform .15s,color .12s}.ct-arrow:hover{color:var(--text-1);background:var(--surface-overlay)}.ct-arrow-open{transform:rotate(90deg)}.ct-arrow-placeholder{width:16px;height:16px;flex-shrink:0}.ct-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mc-card{display:flex;flex-direction:column;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:border-color .12s,box-shadow .15s,transform .1s;overflow:hidden;user-select:none;-webkit-user-select:none}.mc-card:hover{border-color:var(--border-strong);box-shadow:0 4px 16px #0000004d;transform:translateY(-1px)}.mc-card.mc-selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-border)}.mc-card.mc-ref-drop{outline:2px dashed var(--accent, #6ea8ff);outline-offset:-2px;box-shadow:inset 0 0 0 1px #6ea8ff33}.mc-card.mc-ref-uploading{pointer-events:none;opacity:.88}.mc-thumb{position:relative;width:100%;aspect-ratio:1 / 1;background:var(--surface-raised);overflow:hidden}.mc-thumb img{width:100%;height:100%;object-fit:cover;display:block}.mc-no-thumb{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:36px;opacity:.35}.mc-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .15s;pointer-events:none}.mc-card:hover .mc-overlay{opacity:1;pointer-events:auto}.mc-overlay-actions{display:flex;align-items:center;justify-content:center;gap:10px}.mc-action-btn{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:#00000080;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:background .12s,border-color .12s;padding:0}.mc-action-btn:hover{background:#ffffff26;border-color:#fff6}.mc-ref-popover{position:fixed;z-index:10050;max-width:320px;max-height:280px;padding:6px;border-radius:var(--r-md, 8px);border:1px solid rgba(255,255,255,.2);background:#14161cfa;box-shadow:0 12px 40px #0000008c;pointer-events:auto}.mc-ref-popover img{display:block;max-width:100%;max-height:268px;width:auto;height:auto;object-fit:contain;border-radius:4px}.mc-format{position:absolute;top:6px;right:6px;padding:2px 6px;border-radius:4px;background:#000000a6;color:var(--text-2);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;pointer-events:none}.mc-info{display:flex;flex-direction:column;gap:2px;padding:8px 10px 10px}.mc-name{font-size:12px;font-weight:500;color:var(--text-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.mc-name-input{width:100%;font-size:12px;font-weight:500;color:var(--text-1);background:var(--surface-raised);border:1px solid var(--accent);border-radius:3px;padding:1px 5px;outline:none;line-height:1.4;box-sizing:border-box;user-select:text;-webkit-user-select:text}.mc-card.mc-editing{border-color:var(--accent)}.mc-meta{font-size:10px;color:var(--text-3);line-height:1}.mc-classify-btn.classifying{pointer-events:none;opacity:.85}.mc-classify-spinner{animation:mc-classify-spin .8s linear infinite}@keyframes mc-classify-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mc-classify-btn.done{border-color:#50dc8280;color:#50dc82}.mc-card.mc-skeleton{pointer-events:none;cursor:default}.mc-card.mc-skeleton .mc-thumb{background:var(--surface-raised)}.mc-shimmer{display:block;background:linear-gradient(90deg,var(--surface-raised, #2a2d35) 30%,rgba(255,255,255,.06) 50%,var(--surface-raised, #2a2d35) 70%);background-size:300% 100%;animation:mc-shimmer 1.5s ease-in-out infinite}.mc-card.mc-skeleton .mc-thumb .mc-shimmer{width:100%;height:100%}@keyframes mc-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.mg-stage{position:relative;min-height:100%}.mg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:10px;padding:2px}.mg-grid.mg-grid-marquee,.mg-grid.mg-grid-marquee *{user-select:none;-webkit-user-select:none}.mg-selection-box{position:absolute;z-index:20;border:1.5px solid rgba(100,160,255,.95);background:#5082ff1f;border-radius:4px;pointer-events:none;box-shadow:0 0 0 .5px #64a0ff4d}.mg-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:240px;gap:10px;color:var(--text-3)}.mg-empty svg{opacity:.4}.mg-empty p{margin:0;font-size:13px;font-weight:500}body.mg-marquee-selecting,body.mg-marquee-selecting *{user-select:none;-webkit-user-select:none}.tp-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1002;display:flex;align-items:center;justify-content:center;padding:24px;background:#00000073;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.tp-root{display:flex;flex-direction:column;width:min(400px,100%);max-height:min(560px,calc(100vh - 48px));border:1px solid var(--border-strong);border-radius:var(--r-lg);background:var(--surface-overlay);box-shadow:0 20px 50px #0000008c}.tp-title{margin:0;padding:14px 16px 0;font-size:14px;font-weight:600;color:var(--text-1)}.tp-search-row{display:flex;align-items:center;gap:8px;margin:10px 16px 0;padding:6px 10px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised)}.tp-search-icon{flex-shrink:0;color:var(--text-3)}.tp-search-input{flex:1;min-width:0;border:0;background:transparent;color:var(--text-1);font-size:12px;outline:none}.tp-search-input::placeholder{color:var(--text-3)}.tp-pin-placeholder{flex-shrink:0;display:grid;place-items:center;color:var(--text-3);opacity:.55}.tp-scroll{flex:1;min-height:0;overflow-y:auto;padding:10px 8px 8px;scrollbar-width:thin}.tp-section{margin-bottom:10px}.tp-section-head{padding:4px 8px 6px;font-size:11px;font-weight:600;color:var(--text-2);letter-spacing:.02em}.tp-muted{font-weight:500;color:var(--text-3)}.tp-list{margin:0;padding:0;list-style:none}.tp-row{display:grid;grid-template-columns:auto 16px 1fr auto;align-items:center;gap:8px;padding:7px 8px;border-radius:var(--r-sm);cursor:pointer;font-size:12px;color:var(--text-1);transition:background .1s}.tp-row:hover{background:var(--surface-raised)}.tp-row input{width:14px;height:14px;accent-color:var(--accent)}.tp-icon{width:14px;height:14px;border-radius:2px;border:1px solid var(--border-med);background:linear-gradient(145deg,var(--surface-overlay),var(--surface-raised))}.tp-icon-recent{position:relative}.tp-icon-recent:after{content:"";position:absolute;right:-2px;bottom:-2px;width:6px;height:6px;border-radius:50%;background:var(--text-3);border:1px solid var(--surface-overlay)}.tp-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tp-count{font-size:11px;color:var(--text-3)}.tp-empty{margin:12px 8px;font-size:12px;color:var(--text-3);line-height:1.45}.tp-footnote{margin:0 16px 8px;font-size:10px;color:var(--text-3);line-height:1.35;opacity:.85}.tp-footer{flex-shrink:0;display:flex;flex-direction:column;gap:10px;padding:0 12px 12px;border-top:1px solid var(--border)}.tp-hints{display:flex;flex-wrap:wrap;gap:10px 14px;padding-top:10px;font-size:10px;color:var(--text-3)}.tp-hints kbd{display:inline-block;margin:0 2px;padding:1px 5px;border:1px solid var(--border-med);border-radius:3px;background:var(--surface-raised);font-size:10px;font-family:inherit}.tp-actions{display:flex;justify-content:flex-end;gap:8px}.tp-btn-cancel,.tp-btn-apply{padding:7px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer}.tp-btn-cancel{border:1px solid var(--border-med);background:var(--surface-raised);color:var(--text-2)}.tp-btn-apply{border:0;background:var(--accent-grad);color:#fff}.tp-btn-cancel:hover{background:var(--surface-overlay)}.tp-btn-apply:hover{opacity:.92}.ml-tag-panel{width:280px;flex-shrink:0;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--surface);overflow:hidden}.ml-tag-panel-inner{display:flex;flex-direction:column;gap:12px;padding:14px 14px 16px;overflow-y:auto;min-height:0;flex:1}.ml-tag-model-name-block{display:flex;flex-direction:column;align-items:stretch;gap:6px;padding-bottom:2px;border-bottom:1px solid var(--border);margin-bottom:2px}.ml-tag-model-name-block.ml-tag-model-name-muted{border-bottom-color:transparent;margin-bottom:0;padding-bottom:0}.ml-tag-model-name-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.ml-tag-model-name-readonly{font-size:14px;font-weight:500;color:var(--text-1);line-height:1.35;word-break:break-word}.ml-tag-model-name-btn{display:block;width:100%;margin:0;padding:6px 8px;border:1px solid transparent;border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-1);font-size:14px;font-weight:500;text-align:left;line-height:1.35;word-break:break-word;cursor:pointer;transition:border-color .12s,background .12s}.ml-tag-model-name-btn:hover{border-color:var(--border-med);background:var(--surface-overlay)}.ml-tag-model-name-input{width:100%;margin:0;padding:6px 8px;border:1px solid var(--accent-border);border-radius:var(--r-sm);background:var(--surface-overlay);color:var(--text-1);font-size:14px;font-weight:500;line-height:1.35;outline:none;box-sizing:border-box}.ml-tag-model-name-muted{font-size:13px;color:var(--text-2)}.ml-tag-panel-heading{margin:0;font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.01em}.ml-tag-panel-empty,.ml-tag-panel-readonly{margin:0;font-size:12px;line-height:1.5;color:var(--text-3)}.ml-tag-panel-filter-hint{margin:0;font-size:11px;line-height:1.45;color:var(--text-3)}.ml-tag-add-big{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px 14px;border:0;border-radius:var(--r-md);background:var(--surface-raised);color:var(--text-2);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.ml-tag-add-big:hover{background:var(--surface-overlay);color:var(--text-1)}.ml-tag-add-big-icon{font-size:16px;font-weight:500;line-height:1;opacity:.85}.ml-tag-chips{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.ml-tag-chip{display:inline-flex;align-items:center;gap:2px;max-width:100%;padding:2px 2px 2px 8px;border-radius:999px;background:var(--surface-raised);border:1px solid var(--border-med);font-size:12px;color:var(--text-1)}.ml-tag-chip-readonly{padding:4px 10px}.ml-tag-chip-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border:0;background:transparent;color:inherit;font:inherit;text-align:left;cursor:pointer;padding:4px 0 4px 2px;border-radius:4px}.ml-tag-chip-label:hover{text-decoration:underline;text-underline-offset:2px}.ml-tag-chip-input{width:120px;max-width:60vw;padding:2px 6px;border:1px solid var(--accent-border);border-radius:4px;background:var(--surface-overlay);color:var(--text-1);font:inherit;font-size:12px;outline:none}.ml-tag-chip-remove{display:grid;place-items:center;width:22px;height:22px;margin-right:2px;border:0;border-radius:50%;background:transparent;color:var(--text-3);font-size:14px;line-height:1;cursor:pointer;transition:background .1s,color .1s}.ml-tag-chip-remove:hover{background:var(--surface-overlay);color:var(--text-1)}.ml-tag-add-small{display:grid;place-items:center;width:28px;height:28px;padding:0;border:1px dashed var(--border-med);border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:16px;line-height:1;cursor:pointer;transition:border-color .12s,color .12s,background .12s}.ml-tag-add-small:hover{border-color:var(--accent-border);color:var(--text-1);background:var(--surface-raised)}.ml-tag-chip-list{margin:0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:8px}.ml-page{display:flex;height:100%;overflow:hidden;animation:page-fade-in .2s ease}.ml-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface);overflow:hidden}.ml-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 14px 10px;flex-shrink:0;font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.01em;border-bottom:1px solid var(--border)}.ml-sidebar-header-title{display:flex;align-items:center;gap:8px;min-width:0}.ml-sidebar-header-title svg{color:var(--accent);flex-shrink:0}.ml-sidebar-header-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.ml-sidebar-upload-btn{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;padding:5px 8px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-2);font-size:11px;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.ml-sidebar-upload-btn:hover{background:var(--surface-overlay);color:var(--text-1);border-color:var(--accent-border)}.ml-content{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.ml-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--surface);gap:12px}.ml-toolbar-left{display:flex;align-items:center;gap:10px;min-width:0}.ml-breadcrumb{font-size:13px;font-weight:600;color:var(--text-1);letter-spacing:-.01em;white-space:nowrap}.ml-count{font-size:11px;color:var(--text-3);white-space:nowrap}.ml-toolbar-right{display:flex;align-items:center;gap:8px}.ml-search-wrap{position:relative;display:flex;align-items:center}.ml-search-icon{position:absolute;left:9px;color:var(--text-3);pointer-events:none}.ml-search-input{width:200px;padding:6px 28px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-1);font-size:12px;outline:none;transition:border-color .12s,background .12s,width .2s}.ml-search-input::placeholder{color:var(--text-3)}.ml-search-input:focus{width:260px;border-color:var(--accent-border);background:var(--surface-overlay)}.ml-search-clear{position:absolute;right:6px;display:grid;place-items:center;width:18px;height:18px;border:0;border-radius:50%;background:transparent;color:var(--text-3);cursor:pointer}.ml-search-clear:hover{color:var(--text-1);background:var(--surface-overlay)}.ml-sort-wrap{position:relative}.ml-sort-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 10px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:var(--surface-raised);color:var(--text-2);font-size:12px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .12s,color .12s,border-color .12s}.ml-sort-btn:hover{background:var(--surface-overlay);color:var(--text-1);border-color:var(--border-strong)}.ml-sort-dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:100;margin:0;padding:4px;list-style:none;min-width:120px;background:var(--surface-overlay);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:0 8px 24px #00000080}.ml-sort-option{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;border-radius:var(--r-sm);font-size:12px;color:var(--text-2);cursor:pointer;transition:background .1s,color .1s}.ml-sort-option:hover{background:var(--surface-raised);color:var(--text-1)}.ml-sort-active{color:var(--text-1)}.ml-sort-active svg{color:var(--accent)}.ml-drop-upload-hint{position:fixed;bottom:22px;left:50%;transform:translate(-50%);z-index:900;max-width:min(420px,calc(100vw - 32px));padding:10px 16px;border-radius:var(--r-md);border:1px solid var(--border-med);background:var(--surface-raised);box-shadow:0 8px 28px #0000002e;font-size:13px;font-weight:500;color:var(--text-1);pointer-events:none}.ml-grid-area{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 16px;scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.ml-dialog-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#00000094;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ml-dialog{width:min(380px,calc(100vw - 32px));padding:18px;border:1px solid var(--border-strong);border-radius:var(--r-lg);background:var(--surface-overlay);box-shadow:0 18px 48px #00000073}.ml-dialog h3{margin:0 0 8px;font-size:15px;color:var(--text-1)}.ml-dialog p{margin:0;font-size:13px;color:var(--text-2);line-height:1.5}.ml-dialog-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.ml-dialog-cancel,.ml-dialog-confirm{min-width:76px;padding:7px 12px;border-radius:var(--r-sm);font-size:12px;font-weight:600;cursor:pointer}.ml-dialog-cancel{border:1px solid var(--border-med);background:var(--surface-raised);color:var(--text-2)}.ml-dialog-confirm{border:0;background:#d14b57;color:#fff}.ml-dialog-cancel:disabled,.ml-dialog-confirm:disabled{opacity:.55;cursor:not-allowed}.ml-drop-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;display:flex;align-items:center;justify-content:center;background:#000000a6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;animation:ml-drop-fade-in .15s ease}.ml-drop-overlay-content{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px 64px;border:2px dashed rgba(255,255,255,.25);border-radius:20px;color:#ffffffd9;font-size:16px;font-weight:600;letter-spacing:.01em}.ml-drop-overlay-content svg{opacity:.7}.ml-drop-hint{font-size:12px;font-weight:400;opacity:.5}@keyframes ml-drop-fade-in{0%{opacity:0}to{opacity:1}}@media (max-width: 900px){.ml-sidebar{width:180px}.ml-search-input{width:140px}.ml-search-input:focus{width:180px}}@media (max-width: 640px){.ml-page{flex-direction:column}.ml-sidebar{width:100%;height:auto;max-height:200px;border-right:none;border-bottom:1px solid var(--border)}}.login-page{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:auto}.login-card{width:100%;max-width:400px;padding:40px 32px 32px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);display:flex;flex-direction:column;gap:20px}.login-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px}.login-logo{width:40px;height:40px;margin-bottom:4px}.login-title{font-size:22px;font-weight:700;margin:0;color:var(--text-1)}.login-subtitle{margin:0;font-size:13px;color:var(--text-2)}.login-google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--surface-raised);color:var(--text-1);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.login-google-btn:hover:not(:disabled){background:var(--surface-overlay);border-color:var(--border-strong)}.login-google-btn:disabled{opacity:.5;cursor:not-allowed}.login-divider{display:flex;align-items:center;gap:12px;color:var(--text-3);font-size:12px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border)}.login-form{display:flex;flex-direction:column;gap:12px}.login-input{width:100%;padding:10px 14px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--surface-raised);color:var(--text-1);font-size:14px;outline:none;transition:border-color .15s}.login-input::placeholder{color:var(--text-3)}.login-input:focus{border-color:var(--accent)}.login-error{margin:0;padding:8px 12px;font-size:12px;color:var(--danger);background:#ef444414;border-radius:var(--r-sm)}.login-success{text-align:center;color:var(--text-2);font-size:13px;display:flex;flex-direction:column;gap:12px;align-items:center}.login-submit-btn{width:100%;padding:10px 16px;border:none;border-radius:var(--r-md);background:var(--accent-grad);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .15s}.login-submit-btn:hover:not(:disabled){opacity:.9}.login-submit-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px}.login-footer-sep{color:var(--text-3)}.login-link-btn{background:none;border:none;padding:0;color:var(--accent);font-size:13px;cursor:pointer;text-decoration:none}.login-link-btn:hover{text-decoration:underline}.login-back-btn{background:none;border:none;padding:4px 0;color:var(--text-3);font-size:12px;cursor:pointer;text-align:center}.login-back-btn:hover{color:var(--text-2)}.projects-page{width:100%;height:100%;overflow:auto;padding:28px 36px 40px;display:flex;flex-direction:column;gap:20px}.projects-section-label{display:inline-flex;align-self:flex-start;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;color:var(--text-2);background:var(--surface-raised);border:1px solid var(--border-med)}.projects-body-row{display:flex;flex-direction:row;flex-wrap:wrap;align-items:flex-start;gap:20px;flex:1;min-height:0}.projects-create-card{flex-shrink:0;width:min(100%,280px);min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px;border:2px dashed var(--border-strong);border-radius:var(--r-lg);background:transparent;color:var(--text-2);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.projects-create-card:hover{border-color:var(--accent-border);color:var(--text-1);background:var(--accent-subtle)}.projects-create-plus{font-size:42px;font-weight:300;line-height:1;color:var(--text-3)}.projects-create-card:hover .projects-create-plus{color:var(--accent)}.projects-create-text{font-size:14px;font-weight:600}.projects-empty-hint{flex:1;min-height:200px;display:flex;align-items:center;justify-content:center;text-align:center;padding:24px}.projects-empty-hint p{margin:0;font-size:14px;color:var(--text-3);max-width:420px;line-height:1.6}.projects-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-3);font-size:14px}.projects-grid{flex:1;min-width:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.project-card{position:relative;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s}.project-card:hover{border-color:var(--accent-border);box-shadow:0 2px 12px #81a1c114}.project-card-thumb{width:100%;aspect-ratio:16/10;background:var(--surface-raised);overflow:hidden}.project-card-thumb img{width:100%;height:100%;object-fit:cover}.project-card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:12px}.project-card-info{padding:10px 14px;display:flex;flex-direction:column;gap:2px}.project-card-name{font-size:13px;font-weight:600;color:var(--text-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-card-meta{font-size:11px;color:var(--text-3)}.project-card-delete{position:absolute;top:8px;right:8px;width:24px;height:24px;border:none;border-radius:50%;background:#0009;color:#fff;font-size:16px;line-height:1;display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .12s}.project-card:hover .project-card-delete{opacity:1}.project-card-delete:hover{background:var(--danger)}.dev-gate-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:var(--bg, #0f0f12);padding:1.5rem}.dev-gate-card{width:100%;max-width:22rem;padding:1.75rem 1.5rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;box-shadow:0 16px 48px #00000059}.dev-gate-title{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:var(--text-1, #f4f4f5)}.dev-gate-hint{margin:0 0 1.25rem;font-size:.8125rem;line-height:1.5;color:var(--text-3, #a1a1aa)}.dev-gate-label{display:block;margin-bottom:.35rem;font-size:.75rem;color:var(--text-2, #d4d4d8)}.dev-gate-input{width:100%;box-sizing:border-box;padding:.55rem .65rem;margin-bottom:.75rem;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:#00000040;color:var(--text-1, #fafafa);font-size:.9375rem}.dev-gate-input:focus{outline:none;border-color:#60a5fa8c}.dev-gate-error{margin:-.35rem 0 .65rem;font-size:.75rem;color:#f87171}.dev-gate-submit{width:100%;padding:.55rem 1rem;border:none;border-radius:8px;background:#3b82f6;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer}.dev-gate-submit:hover{background:#2563eb}:root{--bg: #09090b;--surface: #111113;--surface-raised: #1c1c1f;--surface-overlay: #28282c;--border: rgba(255, 255, 255, .07);--border-med: rgba(255, 255, 255, .11);--border-strong: rgba(255, 255, 255, .16);--text-1: #f4f4f5;--text-2: #a1a1aa;--text-3: #52525b;--accent: #81a1c1;--accent-hover: #6d8fad;--accent-subtle: rgba(129, 161, 193, .1);--accent-border: rgba(129, 161, 193, .22);--accent-grad: linear-gradient(135deg, #5e81ac, #81a1c1 50%, #88c0d0);--danger: #ef4444;--r-xs: 5px;--r-sm: 8px;--r-md: 10px;--r-lg: 14px;--r-xl: 18px;--r-2xl: 22px}*{box-sizing:border-box}html,body,#app{width:100%;height:100vh;overflow:hidden;min-width:320px}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:13px;line-height:1.5;color:var(--text-1);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,textarea{font:inherit}button,label{cursor:pointer}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.app-body{flex:1;min-height:0;display:flex;flex-direction:row;overflow:hidden}.app-main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.create-route-stack{position:relative;flex:1;min-height:0;width:100%;display:flex;flex-direction:column}.create-route-layer{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.home-page{flex:1;display:flex;flex-direction:column;overflow:hidden;animation:page-fade-in .2s ease}.home-scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;background:var(--bg);scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.create-page{display:flex;flex-direction:column;height:100%;padding:10px 14px 14px;overflow:hidden}@keyframes page-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.topbar{display:flex;justify-content:space-between;align-items:center;gap:16px;height:44px;padding:0 0 10px;flex-shrink:0;border-bottom:1px solid var(--border);margin-bottom:10px;position:relative}.topbar-brand{display:flex;align-items:center;gap:10px}.brand-tag{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-1);background:var(--surface-raised);border:1px solid var(--border-med);padding:3px 8px;border-radius:var(--r-xs)}.topbar h1{font-size:13px;font-weight:400;margin:0;color:var(--text-2);letter-spacing:-.01em}.topbar-modes{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center}.topbar-actions{display:flex;gap:8px;align-items:center}.segmented-control{display:inline-flex;gap:2px;padding:3px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--surface)}.segmented-button{padding:5px 12px;border:0;border-radius:var(--r-sm);background:transparent;color:var(--text-3);font-size:12px;font-weight:500;transition:color .12s,background .12s}.segmented-button:hover{color:var(--text-2)}.segmented-button.active{background:var(--surface-overlay);color:var(--text-1);box-shadow:0 1px 4px #0006}.primary-button{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border:0;border-radius:var(--r-sm);background:var(--accent-grad);color:#fff;font-size:12px;font-weight:600;letter-spacing:-.01em;transition:opacity .15s,box-shadow .15s,transform .1s}.primary-button:hover:not(:disabled){opacity:.88;box-shadow:0 0 18px #81a1c138}.primary-button:active:not(:disabled){transform:scale(.98)}.primary-button:disabled{opacity:.35;cursor:not-allowed}.generate-btn-card{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:56px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--accent-grad);color:#fff;font-size:13px;font-weight:600;letter-spacing:-.01em;flex-shrink:0;transition:opacity .15s,box-shadow .15s,transform .1s}.generate-btn-card:hover:not(:disabled){opacity:.88;box-shadow:0 0 20px #81a1c140}.generate-btn-card:active:not(:disabled){transform:scale(.99)}.generate-btn-card:disabled{opacity:.35;cursor:not-allowed}.secondary-button{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:1px solid var(--border-med);border-radius:var(--r-sm);background:transparent;color:var(--text-2);font-size:12px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.secondary-button:hover{background:var(--surface-raised);color:var(--text-1);border-color:var(--border-strong)}.workspace{flex:1;min-height:0;display:grid;grid-template-columns:400px minmax(0,1fr);gap:10px;align-items:stretch}.panel{border:1px solid var(--border);border-radius:var(--r-2xl);background:var(--surface)}.input-panel{height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.output-panel,.output-panel .panel-body{height:100%;overflow:hidden}.panel-body{padding:14px;display:flex;flex-direction:column;gap:10px}.select-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.model-gen-row{margin-bottom:2px}.model-select-field .select-value{white-space:normal;line-height:1.25}.model-select-value-row{display:flex;align-items:center;gap:6px;min-width:0}.model-select-dropdown{max-height:min(70vh,320px);overflow-y:auto}.model-select-option{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;padding:8px 10px;border-radius:var(--r-sm);font-size:12px;color:var(--text-2);cursor:pointer;transition:background .1s,color .1s}.model-select-option:hover{background:var(--surface-raised);color:var(--text-1)}.model-select-option.selected{color:var(--text-1)}.model-select-option-main{display:flex;gap:10px;min-width:0;flex:1}.model-select-option-icon{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center}.model-select-option-text{display:flex;flex-direction:column;gap:3px;min-width:0}.model-select-option-title-row{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.model-select-option-title{font-weight:600;color:var(--text-1);font-size:12px}.model-select-option-desc{font-size:10px;line-height:1.35;color:var(--text-3)}.model-select-pro-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px 2px 5px;border-radius:999px;font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#f5e6a8;background:#00000073;border:1px solid rgba(212,175,55,.45)}.model-select-pro-badge svg{color:#e8c547}.select-field{position:relative}.select-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:9px 12px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--surface-raised);color:var(--text-1);text-align:left;transition:border-color .12s,background .12s}.select-trigger:hover,.select-field.open .select-trigger{border-color:var(--border-strong);background:var(--surface-overlay)}.select-trigger-inner{display:flex;flex-direction:column;gap:2px;min-width:0}.select-label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3);line-height:1}.select-value{font-size:12px;font-weight:500;color:var(--text-1);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-chevron{flex-shrink:0;color:var(--text-3);transition:transform .15s}.select-field.open .select-chevron{transform:rotate(180deg)}.select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;margin:0;padding:4px;list-style:none;background:var(--surface-overlay);border:1px solid var(--border-strong);border-radius:var(--r-md);box-shadow:0 8px 24px #00000080}.select-option{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;border-radius:var(--r-sm);font-size:12px;color:var(--text-2);cursor:pointer;transition:background .1s,color .1s}.select-option:hover{background:var(--surface-raised);color:var(--text-1)}.select-option.selected{color:var(--text-1)}.select-option.selected svg{color:var(--accent);flex-shrink:0}.upload-card{display:flex;flex-direction:column;gap:7px;padding:12px;border:1px solid var(--border);border-radius:var(--r-xl);background:transparent;transition:border-color .12s}.upload-card:hover{border-color:var(--border)}.upload-card-label{font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3)}.upload-card-title{font-size:13px;font-weight:600;color:var(--text-1);margin:0;letter-spacing:-.02em}.upload-card-meta{font-size:11px;color:var(--text-3);line-height:1.45}.upload-preview{width:100%;border-radius:var(--r-md);object-fit:contain;background:var(--surface-raised)}.upload-placeholder{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;aspect-ratio:16 / 9;border-radius:var(--r-md);border:1.5px dashed var(--border-med);background:var(--surface-raised);color:var(--text-3);font-size:12px;font-weight:500;overflow:hidden;transition:border-color .15s,color .15s,background .15s}.upload-icon-swap{position:relative;display:flex;align-items:center;justify-content:center;height:22px}.upload-ph-default{transition:opacity .18s}.upload-ph-hover{position:absolute;font-size:12px;font-weight:500;color:var(--text-1);opacity:0;transition:opacity .18s;pointer-events:none;white-space:nowrap}.upload-size-hint{font-size:10px;font-weight:400;color:var(--text-3);opacity:.7}.upload-card:hover .upload-placeholder{border-color:var(--border-strong)}.upload-card:hover .upload-ph-default{opacity:0}.upload-card:hover .upload-ph-hover{opacity:1}.upload-card-actions{display:flex;gap:6px;margin-top:4px}.prompt-field{display:flex;flex-direction:column;gap:6px}.prompt-field-label{font-size:11px;font-weight:600;color:var(--text-2);letter-spacing:-.01em}.prompt-input{width:100%;padding:10px 12px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--surface-raised);color:var(--text-1);font-size:12px;line-height:1.55;resize:vertical;min-height:60px;transition:border-color .12s,background .12s}.prompt-input::placeholder{color:var(--text-3)}.prompt-field-inline{padding:0 2px}.prompt-input:focus{outline:none;border-color:var(--accent-border);background:var(--surface-overlay)}.feature-button-group{display:flex;gap:8px}.feature-button{display:inline-flex;align-items:center;gap:8px;width:100%;height:56px;padding:0 14px;border:1px solid var(--border-med);border-radius:var(--r-md);background:var(--surface-raised);color:var(--text-2);font-size:13px;font-weight:600;letter-spacing:-.01em;transition:border-color .12s,background .12s}.feature-button:disabled{opacity:.55;cursor:not-allowed}.feature-button:not(:disabled):hover{background:var(--surface-overlay);border-color:var(--border-strong);color:var(--text-1)}.feature-badge{margin-left:auto;font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--accent-border);padding:2px 7px;border-radius:var(--r-xs)}.stack-card-disabled{opacity:.6}.stack-card-disabled .secondary-button{cursor:not-allowed}.stack-card{border:1px solid var(--border);border-radius:var(--r-xl);padding:12px}.stack-card-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}.section-kicker{margin:2px 0 0;font-size:10px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--text-3)}.panel h3,.empty-stage h3{margin:0;font-size:13px;font-weight:600;letter-spacing:-.02em}.reference-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.thumb-card{overflow:hidden;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-raised)}.thumb-card img{width:100%;aspect-ratio:1 / 1;object-fit:cover}.thumb-meta{display:flex;justify-content:space-between;align-items:center;gap:6px;padding:5px 8px;font-size:10px}.thumb-meta span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-2)}.thumb-meta button{border:0;border-radius:var(--r-xs);background:transparent;color:var(--text-3);font-size:10px;padding:2px 5px;flex-shrink:0;transition:background .12s,color .12s}.thumb-meta button:hover{background:var(--surface-overlay);color:var(--danger)}.empty-card{padding:12px;border-radius:var(--r-md);border:1px dashed var(--border);font-size:11px;color:var(--text-3);line-height:1.5;text-align:center}.result-grid{display:grid;gap:6px;flex:1;min-height:0}.result-card{position:relative;min-height:0;overflow:hidden;border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface-raised);cursor:pointer}.result-card img{width:100%;height:100%;object-fit:contain;display:block;background:var(--surface-raised)}.result-card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-end;justify-content:flex-end;gap:6px;padding:8px;background:linear-gradient(0deg,rgba(0,0,0,.45) 0%,transparent 50%);opacity:0;transition:opacity .18s}.result-card:hover .result-card-overlay{opacity:1}.overlay-btn{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#00000080;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .12s,border-color .12s}.overlay-btn:hover{background:#ffffff26;border-color:#fff6}.overlay-btn-text{display:inline-flex;align-items:center;gap:5px;height:32px;padding:0 10px;border-radius:16px;border:1px solid rgba(255,255,255,.2);background:#00000080;color:#fff;font-size:11px;font-weight:500;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);white-space:nowrap;transition:background .12s,border-color .12s}.overlay-btn-text:hover{background:#ffffff26;border-color:#fff6}.empty-stage{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;min-height:0;padding:32px;gap:6px;text-align:center}.empty-stage h3{font-size:15px;font-weight:600;color:var(--text-2);letter-spacing:-.02em}.empty-stage p{font-size:12px;color:var(--text-3);max-width:280px;line-height:1.55;margin:0}.empty-stage--canvas-hint{position:absolute;inset:auto 0 0 0;flex:0 0 auto;min-height:0;padding:14px 20px 18px;pointer-events:none;z-index:2;background:linear-gradient(to top,rgba(9,9,11,.85),transparent);justify-content:flex-end;gap:4px}.empty-stage--canvas-hint h3,.empty-stage--canvas-hint p{max-width:none}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse-fade{0%,to{opacity:.3}50%{opacity:1}}.loading-spinner{width:36px;height:36px;border-radius:50%;border:2.5px solid var(--border-med);border-top-color:var(--accent);animation:spin .8s linear infinite}.loading-label{font-size:12px;color:var(--text-3);margin:0;animation:pulse-fade 1.8s ease-in-out infinite}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;animation:lb-fade-in .18s ease}@keyframes lb-fade-in{0%{opacity:0}to{opacity:1}}.lightbox img{height:92vh;max-width:92vw;object-fit:contain;border-radius:var(--r-lg);cursor:default;animation:lb-scale-in .2s ease}@keyframes lb-scale-in{0%{transform:scale(.92);opacity:0}to{transform:scale(1);opacity:1}}.lightbox-close{position:absolute;top:20px;right:20px;width:36px;height:36px;display:grid;place-items:center;border:1px solid rgba(255,255,255,.15);border-radius:50%;background:#00000080;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:background .12s,border-color .12s}.lightbox-close:hover{background:#ffffff26;border-color:#ffffff4d}.detail-input-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.detail-input-grid+.prompt-field-inline{margin-top:10px}.detail-thumb{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border);background:var(--surface-raised)}.detail-thumb img{width:100%;aspect-ratio:1 / 1;object-fit:cover;display:block}.detail-thumb-label{position:absolute;bottom:3px;left:3px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;padding:0 4px;border-radius:4px;background:#000000b3;color:#fff;font-size:10px;font-weight:700;line-height:1;pointer-events:none}.detail-thumb-delete,.detail-thumb-crop{position:absolute;right:4px;width:22px;height:22px;display:grid;place-items:center;border:0;border-radius:50%;background:#0009;color:#fff;cursor:pointer;opacity:0;transition:opacity .15s,background .12s}.detail-thumb-delete{top:4px}.detail-thumb-crop{top:30px}.detail-thumb:hover .detail-thumb-delete,.detail-thumb:hover .detail-thumb-crop{opacity:1}.detail-thumb-delete:hover{background:var(--danger)}.detail-thumb-crop:hover{background:var(--accent)}.detail-input-slot{display:flex;align-items:center;justify-content:center;aspect-ratio:1 / 1;border-radius:var(--r-md);border:1.5px dashed var(--border-med);background:var(--surface-raised);color:var(--text-3);cursor:pointer;transition:border-color .15s,color .15s,background .15s}.detail-input-slot:hover{border-color:var(--border-strong);color:var(--text-2);background:var(--surface-overlay)}.crop-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;animation:lb-fade-in .18s ease}.crop-modal-inner{position:relative;display:flex;height:92vh;max-width:96vw;border-radius:var(--r-xl);overflow:hidden;background:var(--surface);border:1px solid var(--border-med);cursor:default;animation:lb-scale-in .2s ease}.crop-sidebar{width:250px;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--surface)}.crop-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:14px 14px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.crop-sidebar-title{font-size:13px;font-weight:600;color:var(--text-1)}.crop-sidebar-count{font-size:11px;font-weight:500;color:var(--text-3)}.crop-sidebar-list{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin;scrollbar-color:var(--surface-overlay) transparent}.crop-sidebar-empty{display:flex;align-items:center;justify-content:center;flex:1;font-size:12px;color:var(--text-3);text-align:center;padding:20px}.crop-thumb{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--border);flex-shrink:0}.crop-thumb img{width:100%;display:block}.crop-thumb-delete{position:absolute;top:4px;right:4px;width:22px;height:22px;display:grid;place-items:center;border:0;border-radius:50%;background:#0009;color:#fff;cursor:pointer;opacity:0;transition:opacity .15s,background .12s}.crop-thumb:hover .crop-thumb-delete{opacity:1}.crop-thumb-delete:hover{background:var(--danger)}.crop-sidebar-footer{padding:10px 14px 14px;border-top:1px solid var(--border);flex-shrink:0}.crop-canvas-area{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;position:relative;padding:20px;background:var(--bg)}.crop-canvas{display:block;border-radius:var(--r-md);cursor:crosshair;-webkit-user-select:none;user-select:none}.crop-limit-hint{position:absolute;top:12px;left:50%;transform:translate(-50%);font-size:12px;font-weight:500;color:var(--text-1);background:#000000b3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:5px 14px;border-radius:var(--r-sm);border:1px solid var(--border-med);white-space:nowrap;z-index:2}.hidden-input{display:none}@media (max-width: 1100px){.workspace{grid-template-columns:1fr;align-items:start;overflow-y:auto;height:auto}.input-panel{height:auto;overflow-y:visible}.output-panel{height:auto;aspect-ratio:16 / 9}.output-panel .panel-body{height:100%}.result-grid,.empty-stage{flex:none;height:100%}}@media (max-width: 720px){.app-shell{padding:10px}.reference-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.canvas-drag-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;cursor:grabbing}.canvas-drag-ghost{position:fixed;pointer-events:none;width:64px;height:64px;object-fit:cover;border-radius:6px;box-shadow:0 4px 16px #00000080;opacity:.85}.canvas-drop-highlight{outline:2px dashed #3b82f6!important;outline-offset:-2px;background:#3b82f614!important;transition:outline .1s,background .1s}
