:root{--color-ink: #15171c;--color-muted: #6b7280;--color-subtle: #9ca3af;--color-canvas: #f6f5f2;--color-surface: rgba(255, 255, 255, .88);--color-surface-solid: #ffffff;--color-sidebar: rgba(244, 243, 239, .9);--color-border: rgba(31, 41, 55, .1);--color-border-strong: rgba(31, 41, 55, .16);--color-accent: #334155;--color-accent-soft: #eef2ff;--radius-card: 26px;--radius-control: 18px;--radius-pill: 999px;--shadow-card: 0 18px 50px rgba(15, 23, 42, .08);--shadow-floating: 0 24px 70px rgba(15, 23, 42, .14);--shadow-composer: 0 20px 60px rgba(15, 23, 42, .16);font-family:Avenir Next,SF Pro Text,PingFang SC,Microsoft YaHei,sans-serif;color:var(--color-ink);background:var(--color-canvas);line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;min-height:100%;overflow:hidden}body{margin:0;min-width:320px;background:radial-gradient(circle at 12% 8%,rgba(148,163,184,.2),transparent 28rem),radial-gradient(circle at 90% 86%,rgba(203,213,225,.28),transparent 30rem),linear-gradient(135deg,#f8f7f4,#f3f4f6 52%,#f8fafc);color:var(--color-ink)}body:before{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.36;background-image:linear-gradient(rgba(15,23,42,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(15,23,42,.035) 1px,transparent 1px);background-size:36px 36px;-webkit-mask-image:radial-gradient(circle at 50% 18%,#000 0,transparent 68%);mask-image:radial-gradient(circle at 50% 18%,#000 0,transparent 68%)}button,input,select,textarea{font:inherit}button{border:none;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.6}input,select,textarea{width:100%;border:1px solid var(--color-border-strong);border-radius:var(--radius-control);background:var(--color-surface-solid);color:var(--color-ink);padding:.95rem 1rem;outline:none;transition:border-color .18s ease,box-shadow .18s ease}input:focus,select:focus,textarea:focus{border-color:#33415561;box-shadow:0 0 0 4px #3341551a}textarea{resize:vertical}.chatgpt-shell{display:flex;height:100dvh;min-height:0;width:100%;overflow:hidden}.app-sidebar{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:16px;padding:18px 14px;border-right:1px solid var(--color-border);min-height:0;overflow:hidden;background:var(--color-sidebar);-webkit-backdrop-filter:blur(24px) saturate(1.08);backdrop-filter:blur(24px) saturate(1.08)}.sidebar-branding{display:flex;align-items:center;gap:12px}.brand-mark{width:38px;height:38px;border-radius:13px;background:linear-gradient(135deg,#111827,#334155);color:#fff;font-weight:700;box-shadow:0 12px 30px #0f172a2e}.sidebar-branding strong,.sidebar-branding small{display:block}.sidebar-branding small{margin-top:2px;color:#6b7280}.new-chat-button,.settings-entry,.sidebar-link{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:46px;padding:0 14px;border-radius:16px;background:#ffffffbd;color:var(--color-ink);border:1px solid var(--color-border);transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.new-chat-button{justify-content:flex-start;font-weight:600;background:#15171c;color:#fff;border-color:#15171c;box-shadow:0 16px 40px #0f172a24}.new-chat-button:hover,.settings-entry:hover,.sidebar-link:hover{transform:translateY(-1px);box-shadow:0 12px 32px #0f172a14}.sidebar-section{flex:1;display:flex;flex-direction:column;min-height:0}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;color:#6b7280;font-size:.94rem}.sidebar-search{display:grid;gap:8px;margin-bottom:12px}.sidebar-search span{color:#6b7280;font-size:.88rem}.sidebar-search input{min-height:40px;border-radius:14px;padding:.8rem .92rem}.history-toolbar{display:grid;grid-template-columns:minmax(240px,1fr) auto;align-items:end;gap:14px;margin-bottom:20px;padding:12px;border:1px solid var(--color-border);border-radius:22px;background:#ffffffb8;box-shadow:0 12px 34px #0f172a0a}.history-search{display:grid;gap:8px}.history-search span{color:var(--color-muted);font-size:.88rem}.history-search input{min-height:42px;border-radius:16px}.history-filter-chips{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 14px;border-radius:999px;background:#f8fafceb;color:#4b5563;border:1px solid var(--color-border);transition:transform .16s ease,background .16s ease,border-color .16s ease}.filter-chip:hover{transform:translateY(-1px);background:#fff}.filter-chip span{color:#6b7280;font-size:.86rem}.filter-chip.active{background:#111827;color:#fff;border-color:#111827}.filter-chip.active span{color:#fffc}.sidebar-link{width:auto;min-height:34px;padding:0 12px;font-size:.88rem}.session-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;min-height:0;padding-right:4px}.history-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 12px;border-radius:15px;background:transparent;color:var(--color-ink);border:1px solid transparent;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease}.history-actions{display:flex;flex-wrap:nowrap;justify-content:flex-end;gap:3px;flex-shrink:0;width:0;max-width:0;padding:0;border-radius:999px;border:0 solid rgba(31,41,55,.08);background:transparent;box-shadow:none;overflow:hidden;opacity:0;pointer-events:none;transition:width .16s ease,max-width .16s ease,opacity .14s ease}.history-item:hover .history-actions,.history-item:focus-within .history-actions{width:108px;max-width:108px;opacity:1;pointer-events:auto}.history-item.active,.history-item.pinned,.settings-entry.active,.sidebar-link.active{background:#ffffffeb;border-color:var(--color-border-strong);box-shadow:0 10px 28px #0f172a0f}.history-item.pinned{border-color:#6366f147}.history-open-button{flex:1;min-width:0;min-height:48px;padding:0;background:transparent;color:inherit;text-align:left}.history-copy{min-width:0}.history-copy strong,.history-copy small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-copy small{margin-top:4px;color:#6b7280}.pin-marker{display:inline-flex;align-items:center;margin-right:6px;padding:.12rem .42rem;border-radius:999px;background:#eef2ff;color:#4338ca;font-size:.72rem;vertical-align:middle}.history-delete{min-height:32px;padding:0 10px;border-radius:999px;background:transparent;color:#9ca3af;font-size:.86rem}.history-action{flex:0 0 34px;min-width:34px;min-height:28px;padding:0 6px;border-radius:999px;background:transparent;color:#4b5563;font-size:.76rem;border:1px solid transparent;white-space:nowrap}.history-action:hover{background:#f8fafc;border-color:var(--color-border)}.history-action.danger{color:#b91c1c}.history-action.active{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.history-delete:hover{color:#ef4444}.sidebar-empty{padding:14px 10px;color:#6b7280;font-size:.94rem}.sidebar-footer{padding-top:8px}.app-main{flex:1;min-width:0;min-height:0;height:100%;padding:18px;display:flex;flex-direction:column;overflow-x:hidden;overflow-y:auto;scrollbar-gutter:stable}.app-main.chat-mode-main{padding:0;background:#ffffffb3;overflow:hidden}.panel,.workspace-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.panel{padding:30px;width:100%}.form-card{display:grid;gap:16px;padding:18px;border:1px solid var(--color-border);border-radius:22px;background:#ffffffc7;box-shadow:0 12px 34px #0f172a0d}.settings-form{display:grid;gap:24px}.panel-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}.panel-header h2{margin:0;font-size:clamp(1.55rem,2vw,2rem);letter-spacing:-.03em}.panel-header p{margin:.45rem 0 0;max-width:680px;color:#6b7280}.panel-actions{display:flex;flex-wrap:wrap;gap:12px}.panel-actions button,.secondary-button,.ghost-button,.top-link,.mode-chip{min-height:42px;padding:0 16px;border-radius:999px;background:#15171c;color:#fff;transition:transform .16s ease,background .16s ease,border-color .16s ease,box-shadow .16s ease}.secondary-button,.ghost-button,.top-link,.mode-chip{background:#fff;color:var(--color-ink);border:1px solid var(--color-border)}.mode-chip.active,.top-link:hover,.secondary-button:hover,.ghost-button:hover{background:#f3f4f6}.settings-grid,.capability-grid,.workspace-gallery{display:grid;gap:16px}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-grid label{display:grid;gap:10px}.settings-grid span{font-size:.95rem;color:#374151}.capability-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.capability-card{display:grid;gap:10px;padding:18px;border-radius:22px;border:1px solid var(--color-border);background:#ffffffb8;box-shadow:0 12px 32px #0f172a0a}.capability-card header{display:flex;align-items:center;justify-content:space-between;gap:12px}.capability-card p{margin:0;color:#4b5563}.settings-hint-card{display:grid;gap:10px;padding:18px 20px;border-radius:22px;border:1px solid var(--color-border);background:linear-gradient(135deg,#ffffffe6,#f8fafce6),radial-gradient(circle at top right,rgba(51,65,85,.1),transparent 18rem);box-shadow:0 14px 38px #0f172a0d}.settings-hint-card strong{font-size:1rem}.settings-hint-card ul{margin:0;padding-left:1.2rem;color:#4b5563}.settings-hint-card li+li{margin-top:.35rem}.capability-description{color:#6b7280!important;font-size:.9rem}.badge{padding:.35rem .7rem;border-radius:999px;background:#f3f4f6;font-size:.8rem}.is-available{border-color:#22c55e47;background:#f0fdf4e6}.is-warning{border-color:#f59e0b4d;background:#fffbebf2}.is-danger,.is-unsupported{border-color:#ef444440;background:#fef2f2f5}.status-tip,.warning-text,.muted-text{margin:0;font-size:.94rem}.status-tip{color:#4f46e5}.warning-text{color:#b45309}.muted-text{color:#6b7280}.boot-banner{display:flex;justify-content:space-between;gap:12px;align-items:center;margin:0 0 16px;padding:14px 16px;border-radius:18px;border:1px solid rgba(245,158,11,.24);background:#fff7ed}.loading-screen{display:grid;place-items:center;flex:1;border:1px dashed #d1d5db;border-radius:28px;background:#fff;color:#6b7280}.workspace-panel{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.workspace-panel.chat-layout{border:none;box-shadow:none;background:transparent;height:100%;border-radius:0}.workspace-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 28px 18px;border-bottom:1px solid #efeff4}.workspace-header.chat-layout{width:min(980px,100%);margin:0 auto;padding:16px 0 10px;border-bottom:none}.workspace-eyebrow{margin:0 0 .35rem;font-size:.86rem;color:#6b7280}.workspace-header h1{margin:0;font-size:1.85rem}.workspace-content{flex:1;min-height:0;overflow-y:auto;padding:26px 28px 18px;overscroll-behavior:contain;scrollbar-gutter:stable}.workspace-content.is-chat{padding:28px 28px 20px;display:flex;justify-content:center}.chat-thread,.mode-content{min-height:0}.chat-thread{flex:1;display:flex;flex-direction:column;width:min(860px,100%);margin:0 auto;padding-bottom:10px}.chat-thread.empty,.mode-content{display:flex;flex-direction:column}.chat-thread.empty{justify-content:center}.workspace-empty{margin:auto;max-width:720px;text-align:center}.workspace-empty h2{margin:0;font-size:clamp(2rem,3vw,3.4rem);font-weight:600}.workspace-empty p{margin:14px auto 0;max-width:560px;color:#6b7280}.thread-message{display:flex;gap:12px;align-items:flex-start;width:100%;margin:0 0 28px}.thread-message.user{justify-content:flex-end}.thread-avatar{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:#111827;color:#fff;font-size:.9rem;flex-shrink:0}.thread-bubble{width:100%;max-width:100%;padding:0;border-radius:20px;background:transparent}.thread-message.user .thread-bubble{width:auto;max-width:min(460px,74%);padding:13px 17px;background:#f1f5f9;border:1px solid rgba(148,163,184,.18);border-radius:24px 24px 7px}.thread-bubble p{margin:0;white-space:pre-wrap;word-break:break-word}.thread-message.assistant .thread-bubble{max-width:min(760px,100%)}.message-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:10px;opacity:0;transform:translateY(2px);transition:opacity .16s ease,transform .16s ease}.thread-message:hover .message-actions,.thread-message:focus-within .message-actions{opacity:1;transform:translateY(0)}.message-actions .ghost-button{min-height:32px;padding:0 12px;font-size:.84rem}.thread-message.assistant .thread-bubble p{font-size:1.02rem;line-height:1.85;color:#111827}.chat-attachment-grid,.chat-draft-attachments{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.chat-attachment-thumb,.chat-draft-thumb{position:relative;width:92px;height:92px;padding:0;overflow:hidden;border-radius:18px;border:1px solid rgba(148,163,184,.38);background:#f8fafc}.chat-attachment-thumb img,.chat-draft-thumb img{display:block;width:100%;height:100%;object-fit:cover}.chat-draft-attachments{width:min(820px,100%);margin:0 auto 10px}.chat-draft-thumb span{position:absolute;top:6px;right:6px;display:grid;place-items:center;width:22px;height:22px;border-radius:999px;background:#0f172ac7;color:#fff;font-size:1rem;line-height:1}.attachment-size-hint{align-self:center;color:#6b7280;font-size:.9rem}.markdown-message{color:#111827;font-size:1.02rem;line-height:1.85;word-break:break-word}.markdown-message>:first-child{margin-top:0}.markdown-message>:last-child{margin-bottom:0}.markdown-message p,.markdown-message ul,.markdown-message ol,.markdown-message blockquote,.markdown-message pre,.markdown-message table{margin:.75rem 0}.markdown-message ul,.markdown-message ol{padding-left:1.45rem}.markdown-message li+li{margin-top:.25rem}.markdown-message strong{font-weight:750}.markdown-message a{color:#4f46e5;text-decoration:none;border-bottom:1px solid rgba(79,70,229,.28)}.markdown-message a:hover{color:#3730a3;border-bottom-color:currentColor}.markdown-message blockquote{padding:.15rem 0 .15rem 1rem;border-left:3px solid #c7d2fe;color:#4b5563}.markdown-message code{padding:.16rem .36rem;border-radius:8px;background:#f1f5f9;color:#be123c;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:.92em}.markdown-code-block{overflow:hidden;margin:1rem 0;border:1px solid #e5e7eb;border-radius:18px;background:#0f172a;box-shadow:0 16px 42px #0f172a1f}.markdown-code-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:42px;padding:0 12px 0 16px;background:#ffffff0f;color:#cbd5e1;font-size:.84rem}.markdown-code-toolbar button{min-height:30px;padding:0 10px;border-radius:999px;background:#ffffff1f;color:#fff}.markdown-message .markdown-code-block pre{margin:0;max-height:420px;overflow:auto;padding:16px;background:transparent;color:#e5e7eb}.markdown-message .markdown-code-block code{padding:0;border-radius:0;background:transparent;color:inherit;font-size:.92rem;line-height:1.7}.markdown-message table{display:block;width:100%;overflow-x:auto;border-collapse:collapse}.markdown-message th,.markdown-message td{padding:.55rem .7rem;border:1px solid #e5e7eb}.markdown-message th{background:#f8fafc;font-weight:700}.thread-message.is-waiting{align-items:center}.thread-message.is-waiting .thread-bubble{width:auto;padding:14px 18px;background:#f5f5f7;border-radius:24px}.typing-indicator{display:inline-flex;align-items:center;gap:8px;min-height:20px}.typing-indicator span{width:8px;height:8px;border-radius:999px;background:#9ca3af;animation:typing-bounce 1.2s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,80%,to{transform:translateY(0);opacity:.45}40%{transform:translateY(-5px);opacity:1}}.workspace-gallery{grid-template-columns:repeat(auto-fill,minmax(220px,280px));align-content:start;justify-content:start}.workspace-gallery.compare{grid-template-columns:repeat(auto-fill,minmax(320px,460px))}.workspace-gallery.image-history-grid{grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:20px;width:100%}@media(min-width:1500px){.workspace-gallery.image-history-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}.workspace-image-card{position:relative;overflow:hidden;border:1px solid rgba(31,41,55,.1);border-radius:26px;background:#ffffffe6;box-shadow:0 18px 48px #0f172a13;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.workspace-image-card:hover{transform:translateY(-3px);border-color:#33415533;box-shadow:var(--shadow-floating)}.image-preview-button{display:block;width:100%;padding:0;overflow:hidden;background:linear-gradient(135deg,#f8fafc,#eef2f7);color:inherit;text-align:left}.reference-thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}.reference-thumb-grid .image-preview-button{border-radius:14px;border:1px solid #e5e7eb}.workspace-image-card img,.workspace-inline-preview img{display:block;width:100%;aspect-ratio:4 / 3;object-fit:cover;transition:transform .2s ease}.image-history-grid>.workspace-image-card>.image-preview-button img{height:clamp(158px,22vh,238px);aspect-ratio:auto;object-fit:contain;background:radial-gradient(circle at 50% 38%,#fff,#eef2f7)}.image-preview-button:hover img{transform:scale(1.035)}.image-group-preview-button{position:relative;display:block;width:100%;min-height:clamp(158px,22vh,238px);overflow:hidden;background:radial-gradient(circle at 50% 38%,#fff,#eef2f7);color:inherit}.image-group-preview-button img{width:100%;height:clamp(158px,22vh,238px);aspect-ratio:auto;object-fit:contain}.image-group-overlay{position:absolute;right:12px;bottom:12px;padding:.45rem .7rem;border-radius:999px;background:#0f172ac7;color:#fff;font-size:.86rem;font-weight:700;box-shadow:0 12px 30px #0f172a38}.workspace-image-meta{display:grid;gap:9px;padding:15px}.image-mode-badge{width:fit-content;padding:.28rem .62rem;border-radius:999px;background:var(--color-accent-soft);color:#4338ca;font-size:.78rem;font-weight:700}.image-meta-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.image-status-badge{width:fit-content;padding:.28rem .62rem;border-radius:999px;background:#f3f4f6;color:#4b5563;font-size:.78rem;font-weight:700}.image-ratio-badge{width:fit-content;padding:.28rem .62rem;border-radius:999px;background:#f8fafcf5;color:#475569;border:1px solid var(--color-border);font-size:.78rem;font-weight:700}.image-status-badge.is-completed{background:#f0fdf4f2;color:#15803d}.image-status-badge.is-pending{background:#eff6fff2;color:#1d4ed8}.image-status-badge.is-error{background:#fef2f2f2;color:#b91c1c}.image-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px;opacity:.64;transition:opacity .16s ease}.workspace-image-card:hover .image-actions,.workspace-image-card:focus-within .image-actions{opacity:1}.image-actions .ghost-button{min-height:36px;padding:0 12px;background:#f8fafce6;border-color:var(--color-border)}.image-actions .image-edit-action{background:#15171c;color:#fff;border-color:#15171c;box-shadow:0 10px 24px #0f172a24}.image-actions .image-edit-action:hover{background:#020617}.load-more-row{display:flex;justify-content:center;margin:22px 0 6px}.small-button{min-height:34px;padding:0 12px;font-size:.9rem}.workspace-history-error{display:grid;gap:6px}.workspace-history-error>summary{list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none}.workspace-history-error>summary::-webkit-details-marker{display:none}.workspace-history-error-detail{margin:0;color:#92400e;font-size:.9rem;line-height:1.5;white-space:pre-wrap;word-break:break-word}.workspace-image-meta strong{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.image-placeholder{display:grid;place-items:center;min-height:150px;color:var(--color-muted);background:linear-gradient(135deg,#f8fafceb,#f1f5f9eb),repeating-linear-gradient(45deg,transparent 0 10px,rgba(15,23,42,.035) 10px 20px)}.image-compare-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:14px}.image-history-grid .image-compare-grid img{height:clamp(92px,14vh,150px);aspect-ratio:auto;object-fit:contain;background:#f8fafc}.image-history-grid .reference-thumb-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr))}.image-history-grid .reference-thumb-grid img{height:76px}.image-history-grid .linked-output-grid{max-height:150px;overflow-y:auto;padding-right:2px}.image-history-grid .batch-output-grid{grid-template-columns:repeat(2,minmax(0,1fr));max-height:238px;overflow-y:auto;padding:14px}.image-history-grid .batch-output-grid img{height:104px;aspect-ratio:auto;object-fit:contain;background:#f8fafc}.image-history-grid .linked-output-grid .image-placeholder{min-height:76px;border-radius:14px;font-size:.86rem}.image-compare-grid small{display:inline-block;margin-bottom:6px;color:#6b7280}.workspace-composer-shell{padding:12px 24px 14px;border-top:1px solid rgba(31,41,55,.06);flex-shrink:0;background:linear-gradient(180deg,#ffffff9e,#ffffffeb 34%);-webkit-backdrop-filter:blur(20px) saturate(1.1);backdrop-filter:blur(20px) saturate(1.1)}.workspace-composer-shell.chat-layout{padding:8px 0 12px;border-top:none;background:linear-gradient(180deg,transparent,rgba(255,255,255,.92) 34%)}.upload-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;width:min(920px,100%);margin:0 auto 8px}.upload-chip,.file-chip{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 14px;border-radius:999px;background:#fff;border:1px solid #e5e7eb}.upload-chip{cursor:pointer}.aspect-ratio-picker{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 8px 0 12px;border-radius:999px;background:#ffffffe0;border:1px solid #e5e7eb}.aspect-ratio-picker span{color:var(--color-muted);font-size:.86rem;white-space:nowrap}.aspect-ratio-picker select{width:auto;min-width:118px;min-height:28px;padding:0 26px 0 8px;border:none;border-radius:999px;background:#f8fafc;color:var(--color-ink);font-size:.86rem}.aspect-ratio-picker select:focus{box-shadow:0 0 0 3px #33415514}.clear-reference-button{min-height:38px;padding:0 14px}.file-name-chip{max-width:min(260px,100%);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#4b5563;font-size:.9rem}.workspace-inline-preview{width:min(180px,100%);margin:0 auto 8px;overflow:hidden;border-radius:22px;border:1px solid #e5e7eb}.workspace-inline-preview.multi{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;width:min(520px,100%);max-height:112px;padding:6px;overflow-y:auto;background:#ffffffc7}.inline-preview-button{display:block;width:100%;padding:0;overflow:hidden;border-radius:16px;background:#f8fafc}.inline-preview-item{position:relative;min-width:0}.inline-preview-remove{position:absolute;top:5px;right:5px;z-index:2;display:grid;place-items:center;width:24px;height:24px;padding:0;border-radius:999px;background:#111827d1;color:#fff;font-size:18px;line-height:1;box-shadow:0 8px 18px #0f172a47;opacity:.92;transition:transform .16s ease,opacity .16s ease,background .16s ease}.inline-preview-remove:hover{background:#b91c1cf0;opacity:1;transform:scale(1.06)}.inline-preview-button img{aspect-ratio:1 / 1}.workspace-composer{display:flex;align-items:flex-end;gap:12px;width:min(860px,calc(100% - 28px));margin:0 auto;padding:11px 12px 11px 18px;border-radius:31px;border:1px solid rgba(31,41,55,.14);background:#fffffff5;box-shadow:var(--shadow-composer);transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.workspace-composer:focus-within{border-color:#33415557;box-shadow:0 24px 70px #0f172a2e}.workspace-input{border:none;box-shadow:none;background:transparent;resize:none;min-height:28px;max-height:180px;padding:8px 0}.workspace-input:focus{border:none;box-shadow:none}.send-button{flex-shrink:0;min-width:94px;height:44px;border-radius:999px;background:#15171c;color:#fff;padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;box-shadow:0 12px 28px #0f172a38;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.send-button:not(:disabled):hover{transform:translateY(-1px);background:#020617;box-shadow:0 16px 36px #0f172a42}.cancel-button{flex-shrink:0;height:44px;min-height:44px}.button-spinner{width:15px;height:15px;border-radius:999px;border:2px solid rgba(255,255,255,.42);border-top-color:#fff;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.workspace-footer-meta{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;width:min(860px,calc(100% - 28px));margin:8px auto 0}.workspace-footer-copy{display:grid;gap:4px;min-width:0;padding-top:2px}.workspace-footer-meta p{width:auto;margin:0}.workspace-footer-meta .muted-text,.workspace-footer-meta .warning-text{font-size:.86rem;line-height:1.45}.image-lightbox{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:24px;overflow:hidden;background:#0f172abd;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.image-group-dialog{position:fixed;inset:0;z-index:45;display:grid;place-items:center;padding:24px;overflow:hidden;background:#0f172a99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.image-group-card{position:relative;display:grid;gap:18px;width:min(1080px,100%);max-height:calc(100dvh - 48px);padding:22px;overflow:hidden;border-radius:30px;background:#fffffff5;box-shadow:0 28px 90px #0000003d}.edit-selection-card{width:min(1160px,100%)}.edit-selection-meta{display:flex;align-items:baseline;justify-content:space-between;gap:12px;color:#64748b}.edit-selection-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.edit-selection-item{position:relative;display:grid;gap:8px;padding:10px;border:1px solid rgba(148,163,184,.24);border-radius:20px;background:#f8fafc;color:#0f172a;text-align:left;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.edit-selection-item img,.edit-selection-item .image-placeholder{width:100%;height:180px;border-radius:16px;object-fit:contain;background:#fff}.edit-selection-item.selected{border-color:#2563eba6;box-shadow:0 18px 36px #2563eb24;transform:translateY(-1px)}.edit-selection-index,.edit-selection-check{position:absolute;top:16px;display:grid;place-items:center;min-width:30px;height:30px;padding:0 8px;border-radius:999px;color:#fff;font-size:.8rem;font-weight:800;box-shadow:0 10px 24px #0f172a2e}.edit-selection-index{left:16px;background:#0f172abf}.edit-selection-check{right:16px;background:#2563ebe6}.edit-selection-label{display:-webkit-box;overflow:hidden;color:#475569;font-size:.92rem;line-height:1.45;-webkit-box-orient:vertical;-webkit-line-clamp:2}.edit-selection-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.image-group-header h3{margin:0;font-size:1.25rem}.image-group-header p{margin:6px 48px 0 0;color:#64748b;line-height:1.5}.image-group-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;min-height:0;overflow-y:auto;padding-right:4px}.image-group-item-card{display:grid;gap:10px}.image-group-item{position:relative;min-height:150px;overflow:hidden;border:1px solid rgba(148,163,184,.28);border-radius:20px;background:#f8fafc}.image-group-item:not(:disabled):hover img{transform:scale(1.035)}.image-group-item:disabled{cursor:default}.image-group-item img{width:100%;height:180px;object-fit:contain;background:#f8fafc}.image-group-item>span:last-child{position:absolute;left:10px;top:10px;display:grid;place-items:center;min-width:28px;height:28px;padding:0 8px;border-radius:999px;background:#0f172abd;color:#fff;font-size:.78rem;font-weight:800}.image-group-download{min-height:36px;padding:0 12px}.image-lightbox-card{position:relative;display:grid;gap:14px;width:min(980px,100%);max-height:calc(100dvh - 48px);padding:16px;overflow:hidden;border-radius:28px;background:#fffffff5;box-shadow:0 28px 90px #0000003d}.lightbox-nav{position:absolute;top:50%;z-index:1;width:48px;height:48px;border-radius:999px;background:#0f172ac7;color:#fff;font-size:2rem;line-height:1;transform:translateY(-50%)}.lightbox-nav.previous{left:18px}.lightbox-nav.next{right:18px}.image-lightbox-card img{display:block;max-width:100%;max-height:calc(100dvh - 180px);margin:0 auto;border-radius:20px;object-fit:contain;background:#0f172a}.lightbox-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:999px;background:#0f172ac7;color:#fff;font-size:1.4rem;line-height:1}.lightbox-footer{display:flex;align-items:center;justify-content:space-between;gap:14px;min-width:0}.lightbox-footer strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mode-switcher{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:0;margin-left:auto}.toast-host{position:fixed;right:22px;top:22px;z-index:80;display:grid;gap:10px;width:min(360px,calc(100vw - 44px));pointer-events:none}.toast-item{pointer-events:auto;padding:12px 14px;border-radius:16px;border:1px solid rgba(148,163,184,.28);background:#fffffff0;color:#111827;box-shadow:0 18px 50px #0f172a24;text-align:left}.toast-success{border-color:#22c55e57}.toast-warning{border-color:#f59e0b6b}.toast-error{border-color:#ef444461}@media(max-width:1120px){.app-sidebar{width:260px}.capability-grid,.settings-grid,.workspace-gallery.compare,.history-toolbar{grid-template-columns:1fr}}@media(max-width:860px){.chatgpt-shell{flex-direction:column}.app-sidebar{width:100%;max-height:32dvh;flex-shrink:0;border-right:none;border-bottom:1px solid var(--color-border)}.app-main{flex:1;min-height:0;padding:12px}.workspace-panel{min-height:0;height:100%}.panel,.workspace-header,.workspace-content,.workspace-composer-shell{padding-left:18px;padding-right:18px}.panel-header,.boot-banner{flex-direction:column;align-items:stretch}.workspace-gallery{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.workspace-gallery.image-history-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.workspace-footer-meta{flex-direction:column;align-items:stretch}.history-item:hover .history-actions,.history-item:focus-within .history-actions{opacity:1;pointer-events:auto}}@media(max-width:640px){.app-sidebar{padding:12px;gap:10px}.sidebar-branding small{display:none}.image-compare-grid{grid-template-columns:1fr}.image-history-grid .image-compare-grid img{height:140px}.workspace-composer{gap:8px;padding:8px;width:calc(100% - 18px)}.send-button{min-width:78px;padding:0 12px}.history-toolbar{padding:10px}.history-filter-chips{gap:6px}.filter-chip{flex:1 1 calc(50% - 6px);justify-content:center;min-width:0;padding:0 10px}.workspace-composer-shell{padding-bottom:12px}.mode-switcher{gap:8px;margin-left:0;justify-content:flex-start}.workspace-footer-meta .muted-text,.workspace-footer-meta .warning-text{font-size:.84rem}.mode-chip{flex:1 1 0;min-width:0;padding:0 10px}.thread-message.user .thread-bubble{max-width:88%}.markdown-message{font-size:.98rem}.lightbox-footer{align-items:stretch;flex-direction:column}.lightbox-footer strong{white-space:normal}.image-group-card,.edit-selection-card,.image-lightbox-card{max-height:calc(100dvh - 28px);padding:16px;border-radius:24px}.image-group-dialog,.image-lightbox{padding:14px}.edit-selection-meta,.edit-selection-actions{flex-direction:column;align-items:stretch}.edit-selection-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.edit-selection-item img,.edit-selection-item .image-placeholder{height:140px}}.tool-entry{justify-content:flex-start;margin-top:8px}.quick-tools-section{border-top:1px solid var(--color-border);flex:initial;padding-top:14px}.ecommerce-panel{max-width:1440px;margin:0 auto;min-height:min-content}.ecommerce-hero{align-items:flex-start}.eyebrow{color:var(--color-accent);font-size:.78rem;font-weight:800;letter-spacing:.12em;margin:0 0 8px;text-transform:uppercase}.ecommerce-warning{margin:0 0 14px}.primary-generate-button{background:#111827;color:#fff;box-shadow:0 18px 42px #11182729}.primary-generate-button:not(:disabled):hover{background:#020617;transform:translateY(-1px)}.workflow-steps{display:grid;gap:12px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:18px}.workflow-step{align-items:flex-start;display:flex;gap:12px;padding:16px 18px;border:1px solid var(--color-border);border-radius:20px;background:#ffffffc7;box-shadow:0 10px 26px #0f172a0a}.workflow-step span{align-items:center;background:#111827;border-radius:999px;color:#fff;display:inline-flex;flex-shrink:0;font-size:.82rem;font-weight:700;height:28px;justify-content:center;width:28px}.workflow-step strong{display:block;margin-top:1px}.workflow-step p{color:var(--color-muted);margin:4px 0 0}.workflow-step.complete{border-color:#1118272e;box-shadow:0 14px 30px #0f172a0f}.workflow-step.complete span{background:linear-gradient(135deg,#0f766e,#1d4ed8)}.ecommerce-layout{display:grid;gap:18px;grid-template-columns:minmax(220px,280px) minmax(0,1fr)}.ecommerce-projects{align-self:start;position:sticky;top:24px}.section-title-row{align-items:flex-start;display:flex;gap:14px;justify-content:space-between;margin-bottom:14px}.section-title-row p{margin:4px 0 0}.listing-project-list,.ecommerce-main-flow,.image-plan-list{display:grid;gap:12px}.listing-project-card{background:#ffffffb8;border:1px solid var(--color-border);border-radius:16px;color:var(--color-ink);display:grid;gap:4px;padding:14px;text-align:left}.listing-project-card.active,.listing-project-card:hover{border-color:#3341556b;box-shadow:var(--shadow-card)}.compact-empty{padding:24px 12px}.ecommerce-form{display:grid;gap:16px}.ecommerce-form>label,.ecommerce-assets-card>label{display:grid;gap:10px}.ecommerce-input-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.platform-template-card{background:linear-gradient(135deg,#eef2ffeb,#f1f5f9eb);border:1px solid var(--color-border);border-radius:18px;padding:16px}.platform-template-card p,.platform-template-card small{color:var(--color-muted);display:block;margin:8px 0 0}.asset-upload-grid,.listing-output-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.asset-upload-box{border:1px dashed var(--color-border-strong);border-radius:18px;padding:16px}.listing-upload-stage{display:grid;gap:16px;padding:18px;border:1px solid rgba(51,65,85,.12);border-radius:24px;background:linear-gradient(135deg,#fffffff0,#f8fafce6),radial-gradient(circle at 12% 10%,rgba(51,65,85,.1),transparent 20rem)}.style-preset-panel{display:grid;gap:14px;padding:18px;border:1px solid var(--color-border);border-radius:24px;background:#ffffffb8}.style-preset-grid{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}.style-preset-card{display:grid;gap:6px;min-height:104px;padding:16px;border:1px solid var(--color-border);border-radius:18px;background:#fff;color:var(--color-ink);text-align:left;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.style-preset-card span{color:var(--color-muted);font-size:.92rem}.style-preset-card:hover,.style-preset-card.active{border-color:#1118276b;box-shadow:0 16px 34px #0f172a14;transform:translateY(-1px)}.style-preset-card.active{background:linear-gradient(135deg,#111827,#334155);color:#fff}.style-preset-card.active span{color:#ffffffc7}.upload-stage-copy{align-items:flex-start;display:flex;gap:12px}.upload-stage-copy p{color:var(--color-muted);margin:4px 0 0}.step-pill{border:1px solid rgba(51,65,85,.16);border-radius:var(--radius-pill);color:var(--color-accent);flex-shrink:0;font-size:.78rem;font-weight:800;letter-spacing:.04em;padding:5px 10px;text-transform:uppercase}.prominent-upload-grid{gap:14px}.prominent-upload-box{align-items:center;background:#fff;border:1.5px dashed rgba(51,65,85,.32);cursor:pointer;display:grid;gap:8px;min-height:156px;place-items:center;text-align:center;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.prominent-upload-box:hover{border-color:#1118279e;box-shadow:var(--shadow-card);transform:translateY(-2px)}.prominent-upload-box.dragover{border-color:#111827cc;box-shadow:0 18px 48px #0f172a24;transform:translateY(-2px) scale(1.01)}.competitor-upload-box{background:#fbfbf8}.upload-icon{display:grid;font-size:2rem;height:52px;place-items:center;width:52px;border-radius:18px;background:#f1f5f9}.prominent-upload-box small,.upload-empty-hint{color:var(--color-muted)}.upload-count{color:var(--color-accent);font-weight:700}.pending-preview-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.pending-preview-card{align-items:center;display:grid;gap:10px;grid-template-columns:64px minmax(0,1fr) auto;padding:10px;border:1px solid var(--color-border);border-radius:18px;background:#ffffffc7}.pending-preview-card img{width:64px;height:64px;border-radius:14px;object-fit:cover;background:#f3f4f6}.pending-preview-card small{color:var(--color-muted);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-chip-list{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}.asset-chip{align-items:center;background:#f8fafce6;border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-muted);display:inline-flex;gap:8px;padding:6px 10px}.asset-chip button{border-radius:var(--radius-pill);min-height:0;padding:0 7px}.listing-output-grid section,.image-plan-card,.result-section{background:#f8fafccc;border:1px solid var(--color-border);border-radius:18px;padding:16px}.listing-output-grid h3{margin:8px 0}.result-section{margin-top:14px}.run-state-card{display:grid;gap:10px;margin-top:12px;padding:16px;border-radius:18px;border:1px solid var(--color-border)}.run-state-card p,.run-state-card ul{color:var(--color-muted);margin:0}.run-state-card ul{padding-left:1.2rem}.run-state-card.is-pending{background:#f8fafc}.run-state-card.is-error{background:#fff7ed;border-color:#f59e0b4d}.run-state-card.is-error strong{color:#9a3412}.result-section ul{margin:12px 0 0;padding-left:20px}.parameter-grid{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}.parameter-grid span{background:#ffffffb8;border-radius:12px;color:var(--color-muted);display:grid;gap:4px;padding:10px}.image-plan-card{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.image-plan-card p{color:var(--color-muted);margin:8px 0 0}.ecommerce-assets-card>button,.ecommerce-form>.section-title-row button{justify-self:flex-start}@media(max-width:980px){.ecommerce-layout,.workflow-steps,.ecommerce-input-grid,.asset-upload-grid,.listing-output-grid,.parameter-grid,.style-preset-grid{grid-template-columns:1fr}.ecommerce-projects{position:static}}@media(max-width:760px){html,body,#app{overflow:hidden}.chatgpt-shell{flex-direction:column}.app-sidebar{width:100%;max-height:none;overflow:visible;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;border-right:none;border-bottom:1px solid var(--color-border)}.sidebar-branding{grid-column:1;gap:10px}.brand-mark{width:34px;height:34px;border-radius:12px}.sidebar-branding small,.sidebar-search,.sidebar-empty,.app-sidebar>.sidebar-section:not(.quick-tools-section){display:none}.new-chat-button,.settings-entry,.tool-entry{min-height:40px;border-radius:14px;justify-content:center;padding-left:10px;padding-right:10px}.new-chat-button{grid-column:2}.sidebar-section{flex:initial}.sidebar-section-header{margin-bottom:8px}.session-list{max-height:74px;overflow-y:auto}.quick-tools-section{grid-column:1;border-top:none;padding-top:8px}.quick-tools-section .sidebar-section-header{display:none}.sidebar-footer{grid-column:2;padding-top:0}.quick-tools-section .tool-entry,.sidebar-footer .settings-entry{width:100%}.app-main{flex:1;min-height:0;padding:8px}.panel{padding:14px;border-radius:22px}.panel-header,.section-title-row,.boot-banner{flex-direction:column;align-items:stretch}.panel-header h2{font-size:clamp(1.45rem,7vw,2rem)}.panel-actions,.panel-actions button,.section-title-row button,.primary-generate-button{width:100%}.ecommerce-layout{display:flex;flex-direction:column}.ecommerce-main-flow{order:1}.ecommerce-projects{order:2}.workflow-steps{gap:8px;margin-bottom:12px}.workflow-step,.listing-upload-stage,.style-preset-panel,.form-card,.result-section,.run-state-card{border-radius:18px;padding:12px}.workflow-step p,.upload-stage-copy p,.platform-template-card p,.platform-template-card small{font-size:.9rem}.prominent-upload-box{min-height:132px;padding:14px}.style-preset-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.style-preset-card{min-height:92px;padding:12px}.pending-preview-grid{grid-template-columns:1fr}.pending-preview-card{grid-template-columns:56px minmax(0,1fr)}.pending-preview-card img{width:56px;height:56px}.pending-preview-card .small-button{grid-column:1 / -1;justify-self:stretch}.image-plan-card{flex-direction:column}.image-plan-card button{width:100%}}@media(max-width:430px){.app-sidebar{max-height:none;gap:6px;padding:8px}.sidebar-section-header span,.history-copy small{font-size:.8rem}.history-item{padding:8px 10px}.panel{padding:12px}.style-preset-grid{grid-template-columns:1fr}.listing-project-card,.platform-template-card,.listing-output-grid section{border-radius:16px;padding:12px}}
