:root{color-scheme:dark;--bg: #0a0a0b;--bg-elev: #111113;--surface: #161618;--surface-2: #1c1c1f;--surface-hover: #222226;--border: #232327;--border-strong: #2e2e34;--text: #ededee;--text-dim: #a5a5ad;--text-mute: #6c6c75;--accent: #c8ff36;--accent-ink: #0a1500;--accent-glow: rgba(200, 255, 54, .18);--danger: #ff5a5a;--shadow-1: 0 1px 0 rgba(255, 255, 255, .04) inset, 0 1px 2px rgba(0, 0, 0, .4);--shadow-2: 0 8px 32px rgba(0, 0, 0, .5);--radius: 8px;--radius-lg: 14px;--radius-xl: 20px;--ff-sans: "Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--ff-mono: "Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--ff-display: "Instrument Serif", "Times New Roman", serif}[data-theme=light]{color-scheme:light;--bg: #f4f2ec;--bg-elev: #ffffff;--surface: #ffffff;--surface-2: #f4f2ec;--surface-hover: #ebe9e2;--border: #e1ddd2;--border-strong: #c8c2b3;--text: #15151a;--text-dim: #5a5a63;--text-mute: #8c8c95;--accent: #5b8c00;--accent-ink: #ffffff;--accent-glow: rgba(91, 140, 0, .16);--shadow-1: 0 1px 0 rgba(255, 255, 255, .6) inset, 0 1px 2px rgba(0, 0, 0, .06);--shadow-2: 0 8px 32px rgba(0, 0, 0, .08)}*{box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{margin:0;padding:0;min-height:100%;background:var(--bg);color:var(--text);font-family:var(--ff-sans);font-size:14px;line-height:1.45;letter-spacing:-.005em;overflow-x:hidden;overflow-y:auto}#root{min-height:100vh}button{font-family:inherit;font-size:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}input,textarea,select{font-family:inherit;color:inherit;background:none;border:0;outline:0}::selection{background:var(--accent);color:var(--accent-ink)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.4)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .4s ease}@keyframes spin{to{transform:rotate(360deg)}}.app{min-height:100vh;padding-top:52px;background:var(--bg);color:var(--text)}.topbar{display:grid;grid-template-columns:280px 1fr 340px;align-items:center;border-bottom:1px solid var(--border);background:var(--bg-elev);height:52px;-webkit-user-select:none;user-select:none;position:fixed;top:0;left:0;right:0;z-index:30}.topbar.hero{grid-template-columns:1fr auto 1fr;padding:0 20px}.topbar .logo{display:flex;align-items:center;gap:10px;padding:0 16px;height:100%;border-right:1px solid var(--border)}.topbar.hero .logo{border-right:0;padding:0}.logo-mark{width:22px;height:22px;border-radius:6px;background:var(--accent);color:var(--accent-ink);display:grid;place-items:center;font-weight:700;font-size:12px;flex-shrink:0}.logo-name{font-weight:600;font-size:14px;letter-spacing:-.01em}.logo-name .dim{color:var(--text-mute);font-weight:400;margin-left:4px}.topbar .center-actions{display:flex;align-items:center;justify-content:center;gap:6px;height:100%}.pill-group{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:3px;gap:2px}.pill-group button{padding:4px 12px;border-radius:5px;color:var(--text-dim);font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:6px}.pill-group button:hover{color:var(--text)}.pill-group button.active{background:var(--surface-hover);color:var(--text)}.topbar .right-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:0 14px;height:100%;border-left:1px solid var(--border)}.topbar.hero .right-actions{border-left:0}.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#ff8a5b,#c44dff);display:grid;place-items:center;color:#fff;font-size:11px;font-weight:700;letter-spacing:.02em}.icon-btn{display:inline-grid;place-items:center;width:30px;height:30px;border-radius:7px;color:var(--text-dim)}.icon-btn:hover{background:var(--surface-hover);color:var(--text)}.hero-main{display:grid;place-items:center;min-height:calc(100vh - 52px);background:radial-gradient(ellipse 800px 500px at 50% 30%,var(--accent-glow),transparent 60%),var(--bg);position:relative;overflow-x:hidden;padding:30px 16px 40px}.hero-grid-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,var(--border) 1px,transparent 1px),linear-gradient(to bottom,var(--border) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(ellipse 700px 500px at 50% 50%,black 30%,transparent 75%);mask-image:radial-gradient(ellipse 700px 500px at 50% 50%,black 30%,transparent 75%);opacity:.35;pointer-events:none}.hero-inner{width:min(720px,90vw);text-align:center;position:relative;z-index:1}.hero-title{font-family:var(--ff-display);font-weight:400;font-size:clamp(40px,6vw,64px);line-height:1.02;letter-spacing:-.02em;margin:0 0 16px;text-wrap:balance}.hero-title em{font-style:italic;color:var(--accent);font-family:var(--ff-display)}.hero-sub{color:var(--text-dim);font-size:16px;max-width:480px;margin:0 auto 36px;text-wrap:pretty}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--radius-xl);background:linear-gradient(180deg,var(--surface),var(--bg-elev));padding:36px 24px;display:flex;flex-direction:column;align-items:center;gap:14px;transition:all .18s ease;cursor:pointer;margin-bottom:14px}.panel.left .dropzone{padding:18px 16px;gap:8px;margin-bottom:0;border-radius:var(--radius-lg)}.panel.left .dropzone-icon{width:36px;height:36px;border-radius:8px;font-size:16px}.panel.left .dropzone-text .primary{font-size:13px}.panel.left .dropzone-text .meta{font-size:11px}.dropzone:hover,.dropzone.dragging,.dropzone.active{border-color:var(--accent);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 6%,var(--surface)),var(--bg-elev));transform:translateY(-1px)}.dropzone-icon{width:48px;height:48px;border-radius:12px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-dim);font-size:22px}.dropzone.dragging .dropzone-icon,.dropzone.active .dropzone-icon{color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--surface-2));border-color:var(--accent)}.dropzone-text{text-align:center}.dropzone-text .primary{font-size:15px;font-weight:500;color:var(--text)}.dropzone-text .primary u{color:var(--accent);text-decoration:none;border-bottom:1px dashed var(--accent)}.dropzone-text .meta{font-size:12px;color:var(--text-mute);margin-top:4px}.dropzone p{font-size:14px;color:var(--text)}.dropzone p small{font-size:12px;color:var(--text-mute);display:block;margin-top:4px}.prompt-bar{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px 8px 8px 14px;box-shadow:var(--shadow-1);transition:border-color .15s ease;margin-bottom:12px}.prompt-bar:focus-within{border-color:var(--border-strong);box-shadow:var(--shadow-1),0 0 0 4px var(--accent-glow)}.prompt-bar input{flex:1;font-size:14.5px;padding:8px 0}.prompt-bar input::placeholder{color:var(--text-mute)}.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:9px;font-size:13px;font-weight:500;letter-spacing:-.005em;transition:all .12s ease;white-space:nowrap;height:34px;border:1px solid transparent}.btn.primary{background:var(--accent);color:var(--accent-ink);font-weight:600}.btn.primary:hover:not(:disabled){filter:brightness(1.06);transform:translateY(-.5px)}.btn.primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn.ghost{color:var(--text-dim);border-color:var(--border);background:var(--surface)}.btn.ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.btn.subtle{color:var(--text-dim)}.btn.subtle:hover{background:var(--surface-hover);color:var(--text)}.btn.icon-only{padding:0;width:30px;justify-content:center}.btn.sm{height:28px;font-size:12px;padding:0 10px;border-radius:7px}.btn.full{width:100%;justify-content:center}.btn.primary.full{height:38px;font-size:13.5px}.btn.primary.xl{height:52px;font-size:15px;letter-spacing:-.01em;font-weight:700}.btn.primary.xl:hover:not(:disabled){filter:brightness(1.08)}.hero-generate-cta{width:100%;height:52px;border-radius:var(--radius-lg);background:var(--accent);color:var(--accent-ink);font-size:15px;font-weight:700;letter-spacing:-.01em;display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;cursor:pointer;transition:all .12s ease;margin-bottom:12px}.hero-generate-cta:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 8px 24px #c8ff3640}.hero-generate-cta:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn.danger{color:var(--danger);border-color:var(--danger);background:transparent}.btn.danger:hover{background:color-mix(in srgb,var(--danger) 12%,transparent)}.quick-prompts{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:22px}.chip{padding:5px 11px;border:1px solid var(--border);background:var(--surface);border-radius:999px;font-size:12px;color:var(--text-dim);display:inline-flex;align-items:center;gap:6px;cursor:pointer;transition:all .12s ease}.chip:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-hover)}.chip.active{background:color-mix(in srgb,var(--accent) 14%,var(--surface));border-color:color-mix(in srgb,var(--accent) 50%,var(--border));color:var(--text)}.hero-examples{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin-top:28px;width:100%;max-width:720px;margin-bottom:40px}.hero-examples:empty{display:none}.hero-examples .ex{width:96px;height:96px;border-radius:10px;border:1.5px solid var(--border);background:var(--surface);overflow:hidden;flex-shrink:0;position:relative;cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.hero-examples .ex:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 6px 18px #0006,0 0 0 3px var(--accent-glow)}.hero-examples .ex img{width:100%;height:100%;object-fit:cover}.hero-examples-label{width:100%;text-align:center;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);font-weight:500;margin-bottom:8px}.hero-upload{display:flex;align-items:center;gap:10px;background:var(--surface);border:1.5px dashed var(--border-strong);border-radius:14px;padding:10px 12px;margin-bottom:10px;transition:all .15s ease;cursor:pointer}.hero-upload:hover,.hero-upload.dragging{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,var(--surface))}.hero-upload .icon{width:36px;height:36px;border-radius:9px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-dim);flex-shrink:0}.hero-upload.dragging .icon,.hero-upload.has-file .icon{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface-2));border-color:var(--accent)}.hero-upload .text{flex:1;display:flex;flex-direction:column;text-align:left;min-width:0}.hero-upload .text .primary{font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hero-upload .text .primary u{color:var(--accent);text-decoration:none;border-bottom:1px dashed var(--accent)}.hero-upload .text .meta{font-size:11.5px;color:var(--text-mute);font-family:var(--ff-mono)}.hero-upload .thumb{width:36px;height:36px;border-radius:7px;overflow:hidden;border:1px solid var(--border);flex-shrink:0}.hero-upload .thumb img{width:100%;height:100%;object-fit:cover}.hero-upload .clear{background:transparent;border:0;color:var(--text-mute);cursor:pointer;width:26px;height:26px;border-radius:6px;display:grid;place-items:center;font-size:18px}.hero-upload .clear:hover{background:var(--surface-hover);color:var(--text)}.type-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}.type-card{position:relative;text-align:left;border:1.5px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--surface),var(--bg-elev));padding:16px 14px 14px;display:flex;flex-direction:column;gap:8px;cursor:pointer;transition:all .15s ease;color:var(--text-dim)}.type-card:hover{border-color:var(--border-strong);color:var(--text);transform:translateY(-1px)}.type-card.active{border-color:var(--accent);color:var(--text);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 8%,var(--surface)),var(--bg-elev));box-shadow:0 0 0 3px var(--accent-glow)}.type-card .type-icon{width:32px;height:32px;border-radius:8px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-dim)}.type-card.active .type-icon{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface-2));border-color:var(--accent)}.type-card .type-title{font-size:14px;font-weight:600;color:var(--text)}.type-card .type-desc{font-size:11.5px;color:var(--text-mute);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:32px}.work{display:grid;grid-template-columns:280px 1fr 340px;height:calc(100vh - 52px);max-height:calc(100vh - 52px);overflow:hidden}.panel{background:var(--bg-elev);display:flex;flex-direction:column;min-height:0;overflow:hidden}.panel.left{border-right:1px solid var(--border)}.panel.right{border-left:1px solid var(--border)}.project-title-bar{flex-direction:row!important;align-items:center;gap:8px;padding:12px 14px!important}.project-title-display{flex:1;display:inline-flex;align-items:center;gap:6px;background:transparent;border:1px solid transparent;border-radius:8px;padding:6px 8px;text-align:left;font-size:13px;font-weight:600;color:var(--text);letter-spacing:-.005em;cursor:text;transition:background .12s ease,border-color .12s ease;min-width:0}.project-title-display:hover:not(:disabled){background:var(--surface);border-color:var(--border)}.project-title-display:disabled{cursor:default;color:var(--text-mute)}.project-title-display svg{flex-shrink:0;color:var(--text-mute);opacity:.7}.project-title-display:hover svg{color:var(--accent);opacity:1}.project-title-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-title-input{flex:1;height:32px;font-family:inherit;font-size:13px;font-weight:600;letter-spacing:-.005em;color:var(--text);background:var(--surface);border:1px solid var(--accent);border-radius:8px;padding:0 10px;box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 16%,transparent);min-width:0}.project-new-btn{width:32px!important;height:32px!important;border-radius:8px!important;padding:0!important;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.panel-section.projects-strip{display:flex;flex-direction:column;min-height:0}.projects-strip-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto;margin:0 -4px;padding:2px 4px;flex:1;min-height:0}.project-row{position:relative;display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px;border:1px solid transparent;background:transparent;cursor:pointer;transition:background .12s ease,border-color .12s ease;min-height:44px}.project-row:hover{background:var(--surface);border-color:var(--border)}.project-row.active{background:color-mix(in srgb,var(--accent) 10%,transparent);border-color:color-mix(in srgb,var(--accent) 35%,transparent)}.project-row.active .project-row-name{color:var(--text)}.project-row-thumb{width:36px;height:36px;border-radius:6px;background:var(--surface-2);border:1px solid var(--border);overflow:hidden;display:grid;place-items:center;color:var(--text-mute);flex-shrink:0}.project-row-thumb img{width:100%;height:100%;object-fit:cover;display:block}.project-row-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.project-row-name{font-size:12.5px;font-weight:500;color:var(--text-dim);letter-spacing:-.005em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-row-sub{font-size:10.5px;font-family:var(--ff-mono);color:var(--text-mute);letter-spacing:.02em}.project-row-delete{width:26px;height:26px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--text-mute);display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .12s ease,background .12s ease,color .12s ease,border-color .12s ease;flex-shrink:0}.project-row:hover .project-row-delete,.project-row.active .project-row-delete{opacity:1}.project-row-delete:hover{background:color-mix(in srgb,#ff4d4f 14%,transparent);border-color:color-mix(in srgb,#ff4d4f 50%,transparent);color:#ff4d4f}.project-row.var-loading{min-height:44px;border-radius:8px;flex-shrink:0}.panel-section{border-bottom:1px solid var(--border);padding:14px 16px;display:flex;flex-direction:column;gap:10px;flex-shrink:0}.panel-section.scroll{flex:1;min-height:0;overflow-y:auto}.panel-section:last-child{border-bottom:0}.section-header{display:flex;align-items:center;justify-content:space-between;color:var(--text-mute);font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase}.section-header .actions{display:flex;gap:2px}.source-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}.source-card .thumb{height:140px;background:repeating-conic-gradient(var(--surface-2) 0% 25%,var(--surface) 0% 50%) 0 0 / 16px 16px;display:grid;place-items:center;position:relative;overflow:hidden}.source-card .thumb.selected-thumb{height:auto;aspect-ratio:4 / 5;background:var(--surface-2)}.source-card .thumb.selected-thumb.checkerboard{background:repeating-conic-gradient(var(--surface-2) 0% 25%,var(--surface) 0% 50%) 0 0 / 18px 18px}.source-card .thumb.selected-thumb img{width:100%;height:100%;object-fit:contain}.source-card .thumb.selected-thumb .empty-pick{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--text-mute);font-size:11.5px;padding:24px;text-align:center}.source-card .thumb img{width:100%;height:100%;object-fit:cover}.source-card .meta{padding:9px 11px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);font-size:11.5px}.source-card .meta .name{color:var(--text);font-weight:500;font-family:var(--ff-mono);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.source-card .meta .dim{color:var(--text-mute);font-family:var(--ff-mono);font-size:10.5px}.history-list{display:grid;grid-template-columns:1fr 1fr;gap:8px}.history-item{position:relative;border-radius:8px;border:1px solid var(--border);overflow:hidden;cursor:pointer;aspect-ratio:1;transition:all .12s ease;background:var(--surface-2)}.history-item img{width:100%;height:100%;object-fit:cover}.history-item:hover{border-color:var(--border-strong);transform:translateY(-1px)}.history-item.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent),0 0 0 4px var(--accent-glow)}.history-item .tag{position:absolute;top:6px;left:6px;font-size:9.5px;padding:2px 5px;border-radius:4px;background:#0009;color:#fff;font-family:var(--ff-mono);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.proj-row{display:flex;align-items:center;gap:10px;padding:7px 8px;border-radius:7px;cursor:pointer;color:var(--text-dim);font-size:13px}.proj-row:hover,.proj-row.active{background:var(--surface-hover);color:var(--text)}.proj-row .dot{width:6px;height:6px;border-radius:50%;background:var(--text-mute);flex-shrink:0}.proj-row.active .dot{background:var(--accent)}.proj-row .count{margin-left:auto;font-size:11px;color:var(--text-mute);font-family:var(--ff-mono)}.canvas{display:grid;grid-template-rows:44px 1fr 120px;background:var(--bg);min-width:0}.canvas-toolbar{display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--border);background:var(--bg-elev);gap:10px}.canvas-toolbar .group{display:flex;align-items:center;gap:4px}.tab-row{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2px}.tab-row button{padding:4px 10px;border-radius:5px;font-size:12px;font-weight:500;color:var(--text-dim);display:inline-flex;gap:6px;align-items:center}.tab-row button.active{background:var(--surface-hover);color:var(--text)}.tab-row button.active .count{color:var(--accent)}.tab-row .count{color:var(--text-mute);font-family:var(--ff-mono);font-size:10px}.canvas-stage{position:relative;display:grid;place-items:center;padding:24px;background:radial-gradient(ellipse at 50% 50%,color-mix(in srgb,var(--accent-glow) 50%,transparent),transparent 70%),var(--bg);overflow:hidden}.stage-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,var(--border) 1px,transparent 1px),linear-gradient(to bottom,var(--border) 1px,transparent 1px);background-size:32px 32px;opacity:.25;-webkit-mask-image:linear-gradient(180deg,transparent,black 20%,black 80%,transparent);mask-image:linear-gradient(180deg,transparent,black 20%,black 80%,transparent);pointer-events:none}.hero-result{position:relative;aspect-ratio:1 / 1;max-height:100%;max-width:100%;width:min(560px,70vh);background:#fff;border-radius:var(--radius-lg);box-shadow:0 1px #ffffff0f inset,0 20px 60px #00000080,0 0 0 1px var(--border);overflow:hidden;z-index:1;display:grid;place-items:center}[data-theme=light] .hero-result{box-shadow:0 20px 60px #0000001f,0 0 0 1px var(--border)}.hero-result img{width:100%;height:100%;object-fit:contain;display:block}.hero-result.checkerboard{background:repeating-conic-gradient(#e8e8e6,#e8e8e6 25%,#f6f6f4 0%,#f6f6f4 50%) 0 0 / 24px 24px}.hero-result.empty{color:var(--text-mute);font-size:13px;background:var(--surface);border:1.5px dashed var(--border-strong);box-shadow:none}.hero-result.empty .empty-inner{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px;text-align:center}.hero-result.empty .empty-icon{width:56px;height:56px;border-radius:14px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-dim)}.corner-meta{position:absolute;top:10px;left:10px;display:flex;gap:6px;z-index:2}.corner-actions{position:absolute;top:10px;right:10px;display:flex;gap:4px;z-index:2;opacity:0;transition:opacity .15s ease}.hero-result:hover .corner-actions{opacity:1}.mini-tag{font-family:var(--ff-mono);font-size:10.5px;padding:3px 7px;border-radius:5px;background:#000000a6;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);letter-spacing:.02em}.mini-tag.accent{background:var(--accent);color:var(--accent-ink);font-weight:600}.corner-actions .icon-btn{background:#000000a6;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);width:28px;height:28px;border-radius:6px}.corner-actions .icon-btn:hover{background:#000000d9}.variations{display:flex;align-items:center;gap:10px;padding:0 14px;border-top:1px solid var(--border);background:var(--bg-elev);overflow-x:auto}.variations::-webkit-scrollbar{height:6px}.variations::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.var-item{position:relative;width:96px;height:96px;border-radius:10px;border:1.5px solid var(--border);overflow:hidden;cursor:pointer;flex-shrink:0;background:#fff;transition:all .15s ease}.var-item img{width:100%;height:100%;object-fit:cover}.var-item:hover{transform:translateY(-2px);border-color:var(--border-strong)}.var-item.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.var-item .num{position:absolute;bottom:5px;left:5px;font-family:var(--ff-mono);font-size:9.5px;color:#0009;background:#fffc;padding:1px 5px;border-radius:3px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.var-add{width:96px;height:96px;border-radius:10px;border:1.5px dashed var(--border-strong);display:grid;place-items:center;color:var(--text-mute);flex-shrink:0;background:transparent;transition:all .12s ease}.var-add:hover{color:var(--accent);border-color:var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent)}.var-loading{background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent),var(--surface-2);background-size:200% 100%;animation:shimmer 1.4s linear infinite;width:100%;height:100%}.hero-result.skeleton-card{background:var(--surface);box-shadow:0 0 0 1px var(--border),0 20px 60px #0006;overflow:hidden;position:relative;display:flex!important;flex-direction:column;padding:24px 18px}[data-theme=light] .hero-result.skeleton-card{background:var(--surface);box-shadow:0 0 0 1px var(--border),0 20px 60px #00000014}.hero-result.skeleton-card.edit-mode{box-shadow:0 0 0 1px color-mix(in srgb,var(--text-mute) 30%,transparent),0 20px 60px #00000059}.hero-result.skeleton-card.edit-mode .skeleton-shimmer{background:linear-gradient(115deg,transparent 40%,color-mix(in srgb,var(--text-mute) 12%,transparent) 50%,transparent 60%),linear-gradient(180deg,var(--surface-2),var(--surface))}.hero-result.skeleton-card.edit-mode .skeleton-spinner{color:var(--text);animation-duration:2.4s}.hero-result.skeleton-card.edit-mode .skeleton-bar{background:linear-gradient(90deg,transparent,var(--text-mute),transparent)}.skeleton-badge{position:absolute;top:14px;left:14px;font-size:10.5px;font-weight:600;font-family:var(--ff-mono);letter-spacing:.04em;text-transform:uppercase;padding:3px 8px;border-radius:999px;z-index:3}.skeleton-badge.create{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent);border:1px solid color-mix(in srgb,var(--accent) 40%,transparent)}.skeleton-badge.edit{background:color-mix(in srgb,var(--text-mute) 18%,transparent);color:var(--text-dim);border:1px solid color-mix(in srgb,var(--text-mute) 30%,transparent)}.skeleton-edit-row{display:inline-flex;align-items:center;gap:10px;align-self:center;font-size:12.5px;color:var(--text-dim);padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:999px}.skeleton-progress-strip{position:relative;z-index:2;margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:18px;border-top:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.skeleton-progress-strip .gen-loading-steps{gap:6px}.skeleton-progress-strip .skeleton-hint{text-align:center;margin:0}.skeleton-shimmer{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 35%,color-mix(in srgb,var(--accent) 14%,transparent) 50%,transparent 65%),linear-gradient(180deg,var(--surface-2),var(--surface));background-size:220% 100%,100% 100%;animation:shimmer 2.4s linear infinite}.skeleton-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:12px;text-align:center;flex:1;min-height:0}.skeleton-spinner{width:60px;height:60px;border-radius:50%;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;color:var(--accent);animation:skeleton-pulse 1.8s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--accent) 50%,transparent);transform:scale(1)}50%{box-shadow:0 0 0 16px color-mix(in srgb,var(--accent) 0%,transparent);transform:scale(1.04)}}.skeleton-label{font-size:13px;font-weight:500;color:var(--text);letter-spacing:-.005em;display:inline-flex;align-items:center}.skeleton-hint{font-size:11px;color:var(--text-mute);font-family:var(--ff-mono);letter-spacing:.02em}.skeleton-progress{width:180px;height:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;overflow:hidden}.skeleton-bar{width:35%;height:100%;background:linear-gradient(90deg,transparent,var(--accent),transparent);animation:skeleton-bar-slide 1.8s ease-in-out infinite}@keyframes skeleton-bar-slide{0%{transform:translate(-110%)}to{transform:translate(330%)}}.dot-pulse{display:inline-flex;gap:3px;margin-left:6px}.dot-pulse span{width:4px;height:4px;border-radius:50%;background:var(--accent);opacity:.3;animation:dot-pulse 1.2s ease-in-out infinite}.dot-pulse span:nth-child(2){animation-delay:.15s}.dot-pulse span:nth-child(3){animation-delay:.3s}@keyframes dot-pulse{0%,60%,to{opacity:.25;transform:scale(.8)}30%{opacity:1;transform:scale(1.2)}}.var-item.is-skeleton{cursor:default}.var-skeleton-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:var(--accent);z-index:2;animation:skeleton-pulse 1.6s ease-in-out infinite}.upload-progress{display:flex;flex-direction:column;gap:4px;width:100%;margin-top:8px}.upload-progress.done .upload-progress-fill{background:color-mix(in srgb,var(--accent) 80%,transparent)}.upload-progress.dropzone-bar{margin-top:12px}.upload-progress-track{width:100%;height:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;overflow:hidden}.upload-progress-fill{height:100%;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 55%,transparent),var(--accent));border-radius:999px;transition:width .2s ease;box-shadow:0 0 10px color-mix(in srgb,var(--accent) 35%,transparent)}.upload-progress-label{font-size:11px;font-family:var(--ff-mono);color:var(--text-mute);letter-spacing:.02em;display:inline-flex;align-items:center;gap:6px}.upload-progress.thumb-bar{position:absolute;left:4px;right:4px;bottom:4px;margin:0;gap:0;z-index:3}.upload-progress.thumb-bar .upload-progress-track{height:3px;background:#00000080;border:0}.thumb-uploading-veil{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:linear-gradient(180deg,#00000014,#0006);color:#fff;pointer-events:none;z-index:2}.thumb-uploading-pct{font-family:var(--ff-mono);font-size:11px;font-weight:600;padding:3px 9px;background:#0009;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.thumb.uploading img{opacity:.55;filter:saturate(.6) blur(.5px);transition:opacity .15s ease,filter .15s ease}.slot-preview{position:relative}.slot-upload-veil{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#0000006b;color:#fff;pointer-events:none;border-radius:inherit}.slot-upload-pct{font-family:var(--ff-mono);font-size:10.5px;font-weight:600;padding:2px 7px;background:#000000a6;border-radius:999px}.tabs-pill{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2px;gap:2px}.tabs-pill button{flex:1;padding:5px;border-radius:5px;font-size:11.5px;font-weight:500;color:var(--text-dim);letter-spacing:-.005em;text-align:center}.tabs-pill button.active{background:var(--surface-hover);color:var(--text)}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:11.5px;color:var(--text-dim);display:flex;justify-content:space-between;align-items:center}.field-label .value{font-family:var(--ff-mono);color:var(--text);font-size:11px}textarea.input,input.input,select.input{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:9px 11px;font-size:13px;color:var(--text);resize:vertical;font-family:var(--ff-sans);transition:border-color .12s ease}textarea.input{min-height:78px;line-height:1.4}textarea.input:focus,input.input:focus,select.input:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px var(--accent-glow)}textarea.input::placeholder,input.input::placeholder{color:var(--text-mute)}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:32px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23a5a5ad' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;resize:none}[data-theme=light] select.input{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a5a63' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>")}select.input option{background:var(--bg-elev);color:var(--text)}.slider{-webkit-appearance:none;width:100%;height:4px;background:var(--border);border-radius:2px;outline:none;margin:0}.slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--text);cursor:pointer;border:2px solid var(--bg-elev);box-shadow:0 1px 4px #0000004d}.slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--text);cursor:pointer;border:2px solid var(--bg-elev)}.option-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.option-tile{border:1px solid var(--border);background:var(--surface);border-radius:7px;padding:8px 6px;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;transition:all .12s ease;color:var(--text-dim)}.option-tile:hover{border-color:var(--border-strong);color:var(--text)}.option-tile.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--surface));color:var(--text)}.option-tile.active .ratio-box{border-color:var(--accent)}.option-tile .ratio-box{border:1.5px solid var(--text-dim);border-radius:2px}.option-tile .label{font-size:10.5px;font-family:var(--ff-mono)}.scene-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.scene-tile{position:relative;border-radius:8px;border:1.5px solid var(--border);aspect-ratio:1 / 1;overflow:hidden;cursor:pointer;transition:all .12s ease;background:var(--surface)}.scene-tile:hover{border-color:var(--border-strong);transform:translateY(-1px)}.scene-tile.active{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.scene-tile .label{position:absolute;bottom:5px;left:5px;right:5px;font-size:9.5px;color:#fff;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.6);text-align:center}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;font-size:13px}.toggle-row .label{color:var(--text-dim)}.switch{width:30px;height:18px;background:var(--border);border-radius:999px;position:relative;cursor:pointer;transition:background .15s ease;flex-shrink:0}.switch:before{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .15s ease}.switch.on{background:var(--accent)}.switch.on:before{transform:translate(12px);background:var(--accent-ink)}.segmented{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:7px;padding:2px;gap:2px}.segmented button{flex:1;padding:5px;font-size:11.5px;border-radius:4px;color:var(--text-dim);font-weight:500}.segmented button:hover{color:var(--text)}.segmented button.active{background:var(--surface-hover);color:var(--text)}.generate-footer{border-top:1px solid var(--border);padding:12px 16px 14px;display:flex;flex-direction:column;gap:8px;background:var(--bg-elev);flex-shrink:0}.generate-footer .row{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:var(--text-mute)}.generate-footer .row b{color:var(--text);font-family:var(--ff-mono);font-weight:500}.generate-footer .footer-prompt{width:100%;min-height:48px;resize:vertical;font-size:12.5px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--text)}.generate-footer .footer-prompt:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px var(--accent-glow)}.generate-footer .footer-prompt-row{position:relative;display:flex;flex-direction:column;gap:6px}.generate-footer .footer-improve-btn{align-self:flex-end;font-size:11.5px;padding:4px 10px;display:inline-flex;align-items:center;gap:5px}.generate-footer .footer-improve-btn:disabled{opacity:.45;cursor:not-allowed}.zone-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;display:flex;flex-direction:column;gap:10px}.zone-header{display:flex;align-items:center;gap:10px}.zone-icon{width:28px;height:28px;border-radius:7px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-dim);flex-shrink:0}.zone-icon svg{width:14px;height:14px}.zone-info{display:flex;flex-direction:column;line-height:1.2;min-width:0;flex:1}.zone-title{font-size:13px;font-weight:600;color:var(--text)}.zone-subtitle{font-size:11px;color:var(--text-mute);margin-top:1px}.zone-badge{display:inline-grid;place-items:center;min-width:20px;height:18px;padding:0 6px;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-size:10px;font-weight:700;font-family:var(--ff-mono)}.zone-slots{display:grid;gap:6px}.zone-slots-single{grid-template-columns:1fr}.zone-slots-double{grid-template-columns:repeat(2,1fr)}.zone-slots-triple{grid-template-columns:repeat(3,1fr)}.zone-control{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;display:flex;flex-direction:column;gap:6px}.zone-control-ai{cursor:pointer;transition:border-color .15s ease}.zone-control-ai:hover{border-color:var(--border-strong)}.zone-control-ai.ai-active{background:color-mix(in srgb,var(--accent) 10%,var(--surface-2));border-color:var(--accent)}.zone-control-ai.ai-disabled{opacity:.45;cursor:not-allowed}.zone-control-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.zone-control-ai-info{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text)}.zone-control-ai-info svg{color:var(--accent)}.zone-control-header{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text)}.zone-control-value{margin-left:auto;font-family:var(--ff-mono);font-size:11px;color:var(--accent)}.zone-control-hint,.zone-control-ai-disabled-hint{font-size:11px;color:var(--text-mute);line-height:1.4}.toggle-switch-mini,.toggle-switch{position:relative;display:inline-block;flex-shrink:0}.toggle-switch input,.toggle-switch-mini input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{display:inline-block;width:30px;height:18px;background:var(--border);border-radius:999px;position:relative;cursor:pointer;transition:background .15s ease}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .15s ease}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:after{transform:translate(12px);background:var(--accent-ink)}.toggle-slider-mini{display:inline-block;width:26px;height:16px;background:var(--border);border-radius:999px;position:relative;cursor:pointer;transition:background .15s ease}.toggle-slider-mini:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:#fff;transition:transform .15s ease}.toggle-switch-mini input:checked+.toggle-slider-mini{background:var(--accent)}.toggle-switch-mini input:checked+.toggle-slider-mini:after{transform:translate(10px);background:var(--accent-ink)}.toggle-switch-mini input:disabled+.toggle-slider-mini{opacity:.4;cursor:not-allowed}.garment-slot{display:flex;flex-direction:column;gap:4px;min-width:0}.slot-label{font-size:10px;color:var(--text-mute);text-align:center;letter-spacing:.02em;line-height:1.2;min-height:24px;display:flex;align-items:center;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.garment-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.garment-grid .slot-dropzone,.garment-grid .slot-preview{aspect-ratio:1}.garment-counter{font-family:var(--ff-mono);font-size:11px;color:var(--accent);text-transform:none;letter-spacing:0}.hero-multi-upload{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--surface),var(--bg-elev));padding:48px 32px;cursor:pointer;transition:all .15s ease;margin-bottom:10px;min-height:240px;text-align:center}.hero-multi-upload:hover,.hero-multi-upload.dragging{border-color:var(--accent);background:linear-gradient(180deg,color-mix(in srgb,var(--accent) 6%,var(--surface)),var(--bg-elev))}.hero-multi-upload .icon{width:44px;height:44px;border-radius:10px;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--text-dim);flex-shrink:0}.hero-multi-upload.dragging .icon,.hero-multi-upload.has-files .icon{color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface-2));border-color:var(--accent)}.hero-multi-upload .text{display:flex;flex-direction:column;gap:2px;min-width:0;align-items:center}.hero-multi-upload .text .primary{font-size:14px;font-weight:500;color:var(--text)}.hero-multi-upload .text .primary u{color:var(--accent);text-decoration:none;border-bottom:1px dashed var(--accent)}.hero-multi-upload .text .meta{font-size:12px;color:var(--text-mute)}.hero-multi-upload .thumb-strip{display:flex;flex-direction:row;gap:12px;flex-shrink:0;width:100%;overflow:visible;justify-content:center;flex-wrap:wrap}.hero-multi-upload .thumb{width:120px;height:120px;border-radius:8px;overflow:visible;border:1.5px solid var(--border);flex-shrink:0;background:var(--surface-2);position:relative}.hero-multi-upload .thumb img{width:100%;height:100%;object-fit:cover;border-radius:6px}.hero-multi-upload .thumb .remove-image{width:32px;height:32px;font-size:18px;top:6px;right:6px;background:#000c}.hero-multi-upload .thumb .remove-image:hover{background:var(--danger);transform:scale(1.15);box-shadow:0 2px 8px #ff5a5a4d}.hero-customize-row{display:flex;align-items:center;justify-content:stretch;gap:8px;margin:6px 0 10px}.hero-customize-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-dim);font-size:13px;font-weight:500;cursor:pointer;transition:all .12s ease}.hero-customize-toggle>span:nth-of-type(1){flex:1;text-align:left}.hero-customize-toggle:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-hover)}.hero-customize-toggle.open{border-color:color-mix(in srgb,var(--accent) 50%,var(--border));background:color-mix(in srgb,var(--accent) 10%,var(--surface));color:var(--text)}.hero-customize-toggle .chevron{transition:transform .15s ease;display:inline-flex}.hero-customize-toggle.open .chevron{transform:rotate(180deg)}.hero-customize-toggle .clear-btn{font-size:12px;color:var(--text-mute);padding:0 4px;border-left:1px solid var(--border);margin-left:4px;cursor:pointer}.hero-customize-toggle .clear-btn:hover{color:var(--danger)}.hero-customize-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;margin-bottom:12px;display:flex;flex-direction:column;gap:12px;text-align:left;animation:fadeIn .2s ease}.hero-customize-panel .section-header{color:var(--text-mute);font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;display:flex;justify-content:space-between;align-items:center}.hero-customize-panel .scene-grid{grid-template-columns:repeat(6,1fr)}@media (max-width: 720px){.hero-customize-panel .scene-grid{grid-template-columns:repeat(3,1fr)}}.hero-garment-header{display:flex;align-items:center;justify-content:space-between;margin:4px 4px 8px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute)}.hero-garment-header .counter{font-family:var(--ff-mono);color:var(--accent);letter-spacing:0;text-transform:none}.hero-garment-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:14px}.hero-garment-grid .slot-dropzone,.hero-garment-grid .slot-preview{aspect-ratio:1}.hero-garment-grid .slot-label{font-size:11px;min-height:22px}.hero-garment-grid .slot-icon{font-size:18px}.hero-garment-grid .slot-dropzone{border-radius:12px}.hero-garment-toggles{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}@media (max-width: 720px){.hero-garment-grid{grid-template-columns:repeat(4,1fr)}.hero-garment-toggles{grid-template-columns:1fr}}.slot-dropzone{position:relative;aspect-ratio:1;border:1.5px dashed var(--border-strong);border-radius:8px;background:var(--surface-2);display:grid;place-items:center;cursor:pointer;transition:all .15s ease}.slot-dropzone:hover,.slot-dropzone.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 5%,var(--surface-2))}.slot-icon{color:var(--text-mute);font-size:20px}.slot-preview{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--surface)}.slot-preview img{width:100%;height:100%;object-fit:cover}.slot-remove{position:absolute;top:3px;right:3px;width:18px;height:18px;border-radius:999px;background:#000000b3;color:#fff;border:0;cursor:pointer;font-size:12px;display:grid;place-items:center}.slot-remove:hover{background:var(--danger)}.tool-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.tool-option{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:1px solid var(--border);background:var(--surface);border-radius:8px;cursor:pointer;transition:all .12s ease;color:var(--text-dim);font-size:11.5px;font-weight:500}.tool-option svg{width:16px;height:16px}.tool-option span{font-size:10.5px}.tool-option:hover{border-color:var(--border-strong);color:var(--text)}.tool-option.active{border-color:var(--accent);color:var(--text);background:color-mix(in srgb,var(--accent) 8%,var(--surface))}.color-picker-container{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.color-picker{width:36px;height:36px;border:1px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;padding:0}.color-value{font-family:var(--ff-mono);font-size:12px;color:var(--text)}.closure-slider-wrapper{display:flex;flex-direction:column;gap:6px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.closure-slider{width:100%}.closure-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text-mute);font-family:var(--ff-mono)}.radio-group{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.radio-option{display:flex;align-items:center;justify-content:center;padding:9px;border:1px solid var(--border);background:var(--surface);border-radius:8px;cursor:pointer;font-size:12.5px;color:var(--text-dim);transition:all .12s ease}.radio-option input{display:none}.radio-option:hover{border-color:var(--border-strong);color:var(--text)}.radio-option.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));color:var(--text)}.batch-preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.batch-preview-item{aspect-ratio:1;border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--surface)}.batch-preview-item img{width:100%;height:100%;object-fit:cover}.batch-feature-info{display:flex;gap:10px;padding:10px;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-lg)}.batch-feature-info svg{color:var(--accent);flex-shrink:0;margin-top:2px}.batch-feature-text h4{font-size:12.5px;color:var(--text);margin:0 0 3px;font-weight:600}.batch-feature-text p{font-size:11.5px;color:var(--text-mute);margin:0;line-height:1.45}.batch-progress-container{padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.batch-progress-info{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text);margin-bottom:6px}.batch-progress-bar,.progress-bar-track{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.batch-progress-fill,.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s ease}.batch-progress-text{font-size:11px;color:var(--text-mute)}.multi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;padding:20px;width:100%;max-width:1080px;overflow-y:auto;max-height:100%}.multi-grid .grid-image-container{position:relative;border-radius:10px;overflow:hidden;background:#fff;border:1px solid var(--border);aspect-ratio:4 / 5;box-shadow:var(--shadow-1)}.multi-grid .grid-image-container img{width:100%;height:100%;object-fit:cover}.mini-edit-btn,.mini-bg-btn,.mini-download-btn{position:absolute;width:26px;height:26px;border-radius:6px;background:#000000b3;color:#fff;display:grid;place-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:0;cursor:pointer;transition:background .15s ease}.mini-edit-btn{top:6px;right:6px}.mini-bg-btn{top:6px;right:38px;background:#c8ff36d9;color:var(--accent-ink)}.mini-download-btn{bottom:6px;right:6px}.mini-edit-btn:hover,.mini-download-btn:hover{background:var(--accent);color:var(--accent-ink)}.mini-bg-btn:hover{background:var(--accent)}.edit-panel{position:absolute;bottom:16px;left:16px;right:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-2);z-index:5}.edit-panel.bg-replace-panel{border-color:var(--accent)}.edit-panel-header{display:flex;align-items:center;justify-content:space-between}.edit-panel-header h4{font-size:13px;color:var(--text);margin:0;font-weight:600}.edit-panel-close{width:24px;height:24px;border-radius:6px;background:transparent;border:0;color:var(--text-dim);font-size:16px;cursor:pointer}.edit-panel-close:hover{background:var(--surface-hover);color:var(--text)}.edit-instruction-textarea{width:100%;min-height:60px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-size:12.5px;color:var(--text);resize:vertical}.edit-instruction-textarea:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px var(--accent-glow)}.edit-panel-actions{display:flex;gap:6px}.edit-submit-btn{padding:8px 12px;background:var(--accent);color:var(--accent-ink);border:0;border-radius:7px;font-size:12px;font-weight:600;cursor:pointer}.edit-submit-btn:disabled{opacity:.4;cursor:not-allowed}.edit-cancel-btn{padding:8px 12px;background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border);border-radius:7px;font-size:12px;cursor:pointer}.edit-cancel-btn:hover{color:var(--text)}.error-message{padding:8px 10px;background:color-mix(in srgb,var(--danger) 14%,transparent);border:1px solid var(--danger);border-radius:7px;color:var(--danger);font-size:12px;line-height:1.4}.quality-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:5px;background:#000000a6;font-size:10.5px;font-family:var(--ff-mono);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.quality-good{color:var(--accent)}.quality-warning{color:#ffcc4a}.quality-error{color:var(--danger)}.gen-loading-steps{width:100%;display:flex;flex-direction:column;gap:6px}.gen-step{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-mute)}.gen-step-active{color:var(--text)}.gen-step-dot{position:relative;width:8px;height:8px;border-radius:50%;background:var(--border-strong);flex-shrink:0}.gen-step-active .gen-step-dot{background:var(--accent)}.gen-step-dot-pulse{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;border:2px solid var(--accent);animation:pulse 1.5s ease-out infinite}.gen-loading-settings{display:flex;flex-wrap:wrap;gap:5px;justify-content:center}.gen-tag{font-size:10.5px;padding:3px 8px;border-radius:999px;background:var(--surface-2);color:var(--text-dim);font-family:var(--ff-mono)}.gen-tag-ai{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}.export-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0bb3;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:250;display:grid;place-items:center;padding:20px;animation:fadeIn .15s ease}.export-modal{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;width:min(520px,100%);max-height:88vh;overflow-y:auto;position:relative;display:flex;flex-direction:column;gap:18px;box-shadow:var(--shadow-2)}.export-modal-close{position:absolute;top:14px;right:14px;width:30px;height:30px;border-radius:7px;background:var(--surface);color:var(--text-dim);border:1px solid var(--border);cursor:pointer;font-size:18px}.export-modal-close:hover{color:var(--text);background:var(--surface-hover)}.export-modal-title{font-size:16px;font-weight:600;color:var(--text);padding-right:36px;letter-spacing:-.01em;margin:0}.export-option-group{display:flex;flex-direction:column;gap:8px}.export-label{font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);font-weight:500}.export-options{display:flex;flex-wrap:wrap;gap:5px}.export-options.format-grid{display:grid;grid-template-columns:repeat(3,1fr)}.export-options.vertical{flex-direction:column}.export-options.scrollable{max-height:240px;overflow-y:auto}.export-option-btn{padding:7px 12px;background:var(--surface);border:1px solid var(--border);border-radius:7px;color:var(--text);font-size:12.5px;cursor:pointer;text-align:left;transition:all .12s ease}.export-option-btn:hover:not(.disabled):not(:disabled){border-color:var(--border-strong);background:var(--surface-hover)}.export-option-btn.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 12%,var(--surface));color:var(--text)}.export-option-btn:disabled,.export-option-btn.format-disabled{opacity:.4;cursor:not-allowed}.export-option-btn.disabled{opacity:.6}.dimension-category{display:flex;flex-direction:column;gap:4px;padding-top:4px}.dimension-category+.dimension-category{border-top:1px solid var(--border);padding-top:10px;margin-top:4px}.category-label{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);font-family:var(--ff-mono)}.dim-info{color:var(--text-mute);font-size:10.5px;margin-left:6px;font-family:var(--ff-mono)}.format-notice,.transparent-notice{font-size:11px;color:var(--text-mute);padding:7px 9px;background:var(--surface-2);border-radius:5px;margin-top:4px}.export-confirm-btn{padding:12px 18px;background:var(--accent);color:var(--accent-ink);border:0;border-radius:9px;font-size:13.5px;font-weight:600;cursor:pointer;transition:filter .15s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px}.export-confirm-btn:hover:not(:disabled){filter:brightness(1.06)}.export-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.export-spinner{width:12px;height:12px;border:2px solid rgba(10,21,0,.3);border-top-color:var(--accent-ink);border-radius:50%;animation:spin .8s linear infinite}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:300;display:grid;place-items:center;padding:28px;cursor:zoom-out;animation:fadeIn .15s ease}.lightbox-content{position:relative;max-width:95vw;max-height:90vh;cursor:default}.lightbox-content img{max-width:95vw;max-height:90vh;display:block;border-radius:var(--radius)}.lightbox-close{position:absolute;top:-40px;right:0;width:32px;height:32px;border-radius:8px;background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;font-size:18px;display:grid;place-items:center}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--text-mute);font-size:10.5px;background:var(--surface-2);padding:6px;text-align:center}.image-placeholder svg{width:18px;height:18px;opacity:.6}.uploaded-preview{position:relative;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);background:var(--surface)}.uploaded-preview img,.preview-image{width:100%;display:block;max-height:220px;object-fit:contain;background:var(--surface-2)}.remove-image,.remove-preview{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:6px;background:#000000bf;color:#fff;border:0;cursor:pointer;font-size:16px;font-weight:600;display:grid;place-items:center;transition:all .15s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.remove-image:hover,.remove-preview:hover{background:var(--danger);transform:scale(1.1);box-shadow:0 4px 12px #ff5a5a4d}.panel-section::-webkit-scrollbar,.canvas-stage::-webkit-scrollbar,.multi-grid::-webkit-scrollbar,.export-options::-webkit-scrollbar{width:8px}.panel-section::-webkit-scrollbar-thumb,.canvas-stage::-webkit-scrollbar-thumb,.multi-grid::-webkit-scrollbar-thumb,.export-options::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.panel-section::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}.edit-mode-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.edit-mode-title{font-family:var(--ff-display);font-style:italic;font-weight:400;font-size:17px;color:var(--text);line-height:1.1}.edit-mode-header .icon-btn{width:26px;height:26px;border-radius:6px}.projects-page{flex:1;padding:32px 36px 48px;overflow-y:auto}.projects-header{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-bottom:24px}.projects-title{font-family:var(--ff-display);font-weight:400;font-size:36px;line-height:1.05;letter-spacing:-.01em;color:var(--text);margin:0 0 4px}.projects-sub{color:var(--text-dim);font-size:13.5px;margin:0}.projects-actions{display:flex;gap:10px;align-items:center}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}.project-card{position:relative;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease;min-height:220px}.project-card:hover{border-color:var(--border-strong);transform:translateY(-2px);box-shadow:0 12px 28px #00000052}.project-cover{position:relative;aspect-ratio:4 / 5;background:var(--surface-2);overflow:hidden}.project-cover img{width:100%;height:100%;object-fit:cover;display:block}.project-cover-empty{width:100%;height:100%;display:grid;place-items:center;color:var(--text-mute);background:repeating-conic-gradient(var(--surface-2) 0% 25%,var(--surface) 0% 50%) 0 0 / 14px 14px}.project-module-tag{position:absolute;top:8px;left:8px;font-size:10.5px;font-family:var(--ff-mono);padding:3px 8px;border-radius:5px;background:var(--accent);color:var(--accent-ink);font-weight:600;letter-spacing:.02em}.project-count-tag{position:absolute;bottom:8px;right:8px;font-size:10.5px;font-family:var(--ff-mono);padding:3px 7px;border-radius:5px;background:#0009;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.project-meta{padding:11px 14px 13px;display:flex;flex-direction:column;gap:3px}.project-name{font-size:13.5px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-date{font-size:11.5px;color:var(--text-mute);font-family:var(--ff-mono)}.project-delete{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:7px;background:#0009;color:#fff;border:0;cursor:pointer;display:grid;place-items:center;opacity:0;transition:opacity .12s ease,background .12s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.project-card:hover .project-delete{opacity:1}.project-delete:hover{background:var(--danger)}.projects-empty{text-align:center;padding:64px 24px;background:var(--bg-elev);border:1.5px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--text-dim)}.projects-empty h3{font-family:var(--ff-display);font-weight:400;font-size:26px;margin:12px 0 6px;color:var(--text)}.projects-empty p{margin:0;font-size:13.5px}.projects-empty .result-placeholder-icon{color:var(--text-mute);margin-bottom:4px}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 0}.pagination-btn{padding:5px 10px;background:var(--surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:12px;cursor:pointer}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-info{font-size:11.5px;color:var(--text-mute)}.row-actions{display:flex;gap:6px}@media (max-width: 1180px){.work,.topbar{grid-template-columns:260px 1fr 320px}}@media (max-width: 980px){.work{grid-template-columns:240px 1fr 300px}.type-grid{grid-template-columns:repeat(2,1fr)}.hero-examples{display:none}}@media (max-width: 760px){.work{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.panel.left,.panel.right{border:0;border-top:1px solid var(--border);max-height:40vh}}
