:root{color-scheme:light dark;--bg: #eceee9;--bg-soft: #f4f5f1;--panel: #ffffff;--panel-2: #fbfcfa;--ink: #17202a;--muted: #5c6670;--faint: #8b939a;--line: #dcdfd8;--line-soft: #e7e9e3;--accent: #176f63;--accent-strong: #0f5c52;--accent-soft: #e7f1ed;--on-accent: #ffffff;--gold: #d7951e;--danger: #b23a26;--danger-soft: #f6e7e3;--radius: 16px;--radius-sm: 10px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(23, 32, 42, .06), 0 2px 8px rgba(23, 32, 42, .05);--shadow: 0 12px 32px rgba(23, 32, 42, .12);--shadow-lg: 0 24px 60px rgba(23, 32, 42, .22);--appbar-h: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif}@media (prefers-color-scheme: dark){:root:not([data-theme=light]){--bg: #11161b;--bg-soft: #161c22;--panel: #1b232b;--panel-2: #202a33;--ink: #e9edf0;--muted: #9aa6b0;--faint: #6f7d88;--line: #2c3742;--line-soft: #25303a;--accent: #2f9e8c;--accent-strong: #38b3a0;--accent-soft: #1c2e2c;--on-accent: #04110e;--danger: #e07a63;--danger-soft: #2e201c;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 12px 32px rgba(0, 0, 0, .5);--shadow-lg: 0 24px 60px rgba(0, 0, 0, .6)}}:root[data-theme=dark]{color-scheme:dark;--bg: #11161b;--bg-soft: #161c22;--panel: #1b232b;--panel-2: #202a33;--ink: #e9edf0;--muted: #9aa6b0;--faint: #6f7d88;--line: #2c3742;--line-soft: #25303a;--accent: #2f9e8c;--accent-strong: #38b3a0;--accent-soft: #1c2e2c;--on-accent: #04110e;--danger: #e07a63;--danger-soft: #2e201c;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);--shadow: 0 12px 32px rgba(0, 0, 0, .5);--shadow-lg: 0 24px 60px rgba(0, 0, 0, .6)}:root[data-theme=light]{color-scheme:light}*{box-sizing:border-box}[hidden]{display:none!important}html,body{margin:0;height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer}h2{margin:0;font-size:17px;font-weight:700}.app{display:flex;flex-direction:column;min-height:100dvh}.appbar{position:sticky;top:0;z-index:30;height:var(--appbar-h);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 clamp(12px,4vw,28px);padding-top:env(safe-area-inset-top,0px);border-bottom:1px solid var(--line);background:color-mix(in srgb,var(--panel) 86%,transparent);-webkit-backdrop-filter:saturate(160%) blur(14px);backdrop-filter:saturate(160%) blur(14px)}.brand{display:flex;align-items:center;gap:10px;min-width:0}.brand-mark{display:grid;place-items:center;width:30px;height:30px;border-radius:9px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:var(--on-accent);font-size:16px;flex:0 0 auto}.brand-name{font-weight:800;font-size:16px;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appbar-actions{display:flex;align-items:center;gap:8px}.workspace{flex:1;display:grid;grid-template-columns:1fr;grid-template-areas:"stage" "history" "composer";gap:12px;padding:12px clamp(12px,4vw,28px);min-height:0}.stage{grid-area:stage}.history{grid-area:history}.composer{grid-area:composer}.stage,.history,.composer{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.stage{display:flex;flex-direction:column;overflow:hidden;min-height:46vh}.stage-canvas{flex:1;display:grid;place-items:center;padding:16px;min-height:0;background:radial-gradient(circle at 1px 1px,color-mix(in srgb,var(--ink) 7%,transparent) 1px,transparent 0);background-size:22px 22px}.stage-canvas img{max-width:100%;max-height:min(64vh,720px);border-radius:var(--radius-sm);object-fit:contain;box-shadow:var(--shadow);background:var(--panel-2)}.stage-empty{display:grid;justify-items:center;gap:10px;text-align:center;padding:24px;color:var(--muted)}.stage-empty-art{width:min(40vw,180px);aspect-ratio:1;border-radius:18px;border:2px dashed var(--line);background:linear-gradient(135deg,color-mix(in srgb,var(--gold) 22%,transparent),transparent 50%),linear-gradient(315deg,color-mix(in srgb,var(--accent) 22%,transparent),transparent 52%)}.stage-empty-title{margin:4px 0 0;font-weight:700;color:var(--ink)}.stage-empty-hint{margin:0;font-size:13px;color:var(--faint)}.stage-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-top:1px solid var(--line-soft);background:var(--panel-2)}.stage-meta{min-width:0;font-size:13px;color:var(--muted);overflow-wrap:anywhere}.stage.is-busy .stage-canvas{position:relative}.stage.is-busy .stage-canvas:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(100deg,transparent 30%,color-mix(in srgb,var(--accent) 14%,transparent) 50%,transparent 70%);background-size:200% 100%;animation:shimmer 1.2s linear infinite;pointer-events:none}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.download-split{position:relative;display:inline-flex;flex:0 0 auto}.download-main,.download-arrow{min-height:40px;border:1px solid var(--accent-strong);background:var(--accent);color:var(--on-accent);font-weight:700}.download-main{min-width:96px;padding:0 14px;border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.download-split.single .download-main{border-radius:var(--radius-sm)}.download-arrow{width:40px;padding:0;border-left-color:color-mix(in srgb,var(--on-accent) 28%,transparent);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.download-main:hover,.download-arrow:hover{background:var(--accent-strong)}.download-main:disabled,.download-arrow:disabled{opacity:.6;cursor:wait}.download-menu{position:absolute;right:0;bottom:calc(100% + 6px);z-index:12}.download-menu.menu-down{top:calc(100% + 6px);bottom:auto}.download-menu{min-width:160px;padding:6px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel);box-shadow:var(--shadow)}.download-menu button{width:100%;min-height:40px;padding:0 12px;border:0;border-radius:8px;background:transparent;text-align:left}.download-menu button:hover{background:var(--accent-soft)}.history{padding:14px;display:flex;flex-direction:column;min-height:0}.history-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.history-grid{display:grid;grid-auto-flow:column;grid-auto-columns:104px;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.thumb{width:104px;height:104px;border:1px solid var(--line);border-radius:var(--radius-sm);padding:0;background:var(--panel-2);overflow:hidden;position:relative;transition:transform .12s ease,border-color .12s ease}.thumb:hover,.thumb:focus-visible{border-color:var(--accent);transform:translateY(-2px);outline:none}.thumb img{width:100%;height:100%;object-fit:cover;display:block}.thumb time{position:absolute;left:5px;right:5px;bottom:5px;padding:3px 4px;border-radius:6px;background:#0a1016bd;color:#fff;font-size:10px;text-align:center;letter-spacing:.2px}.empty-history{display:flex;align-items:center;min-height:96px;padding:0 4px;color:var(--faint);font-size:14px}.composer{display:flex;flex-direction:column;gap:10px;padding:12px;position:sticky;bottom:0;z-index:20;padding-bottom:calc(12px + var(--safe-bottom));box-shadow:0 -8px 24px #17202a0f}.composer.is-drop{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.composer-input textarea{width:100%;min-height:56px;max-height:34vh;resize:none;padding:12px 14px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel-2);line-height:1.5;outline:none}.composer-input textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.orientation-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.orientation-status{display:inline-flex;align-items:center;gap:8px;min-width:0;padding:6px 12px;border-radius:var(--radius-pill);background:var(--accent-soft);color:var(--accent-strong);font-size:13px;font-weight:700;white-space:nowrap}.orientation-icon{display:inline-block;border:2px solid currentColor;border-radius:3px;flex:0 0 auto}.orientation-status[data-orientation=landscape] .orientation-icon{width:20px;height:13px}.orientation-status[data-orientation=portrait] .orientation-icon{width:13px;height:20px}.orientation-status[data-orientation=square] .orientation-icon{width:16px;height:16px}.orientation-toggle{min-height:38px;padding:0 12px;font-size:13px;flex:0 0 auto}.orientation-toggle [aria-hidden=true]{font-size:16px}.composer-actions{display:flex;align-items:center;gap:10px}.composer-tools{display:flex;align-items:center;gap:8px;flex:1;min-width:0}input[type=file]{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.ref-list{display:flex;flex-wrap:wrap;gap:8px}.ref-list:empty{display:none}.ref-chip{display:inline-flex;align-items:center;gap:8px;max-width:100%;min-height:30px;padding:0 10px;border-radius:var(--radius-pill);background:var(--accent-soft);color:var(--accent-strong);font-size:12px;font-weight:600}.ref-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ref-chip small{color:color-mix(in srgb,var(--accent-strong) 70%,transparent)}.icon-button{display:inline-grid;place-items:center;width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--panel-2);color:var(--ink);font-size:20px;transition:background .12s ease,border-color .12s ease}.icon-button:hover{border-color:var(--accent);background:var(--accent-soft)}.icon-button.small{width:36px;height:36px;font-size:22px}.theme-button{font-weight:800;line-height:1}.file-button,.ghost-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:44px;padding:0 14px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--panel-2);color:var(--ink);font-weight:600;white-space:nowrap}.file-button:hover,.ghost-button:hover{border-color:var(--accent);background:var(--accent-soft)}.ghost-button.danger{color:var(--danger)}.ghost-button.danger:hover{border-color:var(--danger);background:var(--danger-soft)}.file-icon{font-size:16px}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;padding:0 20px;border-radius:var(--radius-sm);border:1px solid var(--accent-strong);background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:var(--on-accent);font-weight:800;letter-spacing:.3px;box-shadow:0 6px 16px color-mix(in srgb,var(--accent) 28%,transparent);transition:transform .08s ease,filter .12s ease}.primary-button:hover{filter:brightness(1.05)}.primary-button:active{transform:translateY(1px)}.primary-button:disabled{filter:grayscale(.3);opacity:.7;cursor:wait;box-shadow:none}.primary-button.compact{min-height:44px}.button-icon{color:color-mix(in srgb,var(--gold) 80%,white)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100dvh;max-width:100vw;max-height:100dvh;margin:0;border:0;padding:16px;background:transparent;color:var(--ink);display:flex;align-items:center;justify-content:center;box-sizing:border-box}.modal::backdrop{background:#080c1080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sheet{width:min(620px,100%);max-height:calc(100dvh - 32px);display:flex;flex-direction:column;overflow:auto;padding:18px;padding-bottom:calc(18px + var(--safe-bottom));background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lg)}.sheet.wide{width:min(1080px,100%)}.sheet-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;position:sticky;top:-18px;margin-top:-18px;padding:18px 0 12px;background:var(--panel);z-index:2}.sheet-head-actions{display:flex;align-items:center;gap:10px}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.field{display:flex;flex-direction:column;gap:6px;min-width:0}.field.span-2{grid-column:1 / -1}.field-label{color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.2px}.field input,.field select{width:100%;height:46px;padding:0 12px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel-2);outline:none}.field input:focus,.field select:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.toggle-row{flex-direction:row;align-items:center;gap:10px;align-self:end;min-height:46px;font-weight:700}.toggle-row input{width:20px;height:20px;accent-color:var(--accent)}.sheet-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:20px}.sheet-actions-right{display:flex;gap:10px}.history-detail{display:grid;grid-template-columns:1fr;gap:16px}.detail-image-wrap{display:grid;place-items:center;min-height:240px;border-radius:var(--radius-sm);background:var(--panel-2);border:1px solid var(--line);overflow:hidden}.detail-image-wrap img{max-width:100%;max-height:60vh;object-fit:contain}.detail-side{display:flex;flex-direction:column;gap:8px;min-width:0}.detail-kv{display:grid;grid-template-columns:64px 1fr;gap:8px;min-height:34px;align-items:center;border-bottom:1px solid var(--line-soft);font-size:14px}.detail-kv span{color:var(--muted)}.detail-kv strong{min-width:0;overflow-wrap:anywhere}.prompt-readonly{min-height:72px;max-height:200px;overflow:auto;padding:12px;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--panel-2);line-height:1.55;white-space:pre-wrap;overflow-wrap:anywhere}.detail-refs{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px}.detail-refs img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--line);background:var(--panel-2)}.toast{position:fixed;left:50%;bottom:calc(20px + var(--safe-bottom));transform:translate(-50%);z-index:60;max-width:min(440px,calc(100vw - 32px));padding:12px 16px;border-radius:var(--radius-sm);color:#fff;background:var(--danger);box-shadow:var(--shadow);font-weight:600;animation:toast-in .18s ease}.toast.toast-ok{background:var(--accent)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,8px)}}@media (min-width: 880px){:root{--appbar-h: 64px}.brand-name{font-size:17px}.workspace{grid-template-columns:minmax(320px,380px) minmax(0,1fr);grid-template-rows:minmax(0,1fr) auto;grid-template-areas:"composer stage" "composer history";gap:16px;padding:16px clamp(16px,3vw,36px);height:calc(100dvh - var(--appbar-h))}.composer{position:static;bottom:auto;padding:16px;box-shadow:var(--shadow-sm);overflow:auto}.composer-input{flex:1;display:flex}.composer-input textarea{flex:1;min-height:220px;max-height:none;resize:vertical}.composer-actions{flex-direction:column;align-items:stretch}.composer-tools{flex:0 0 auto}.primary-button{width:100%;min-height:52px}.stage{min-height:0}.history{overflow:hidden}.history-detail{grid-template-columns:minmax(0,1fr) minmax(280px,380px)}.detail-image-wrap img{max-height:72vh}}@media (min-width: 1280px){.workspace{grid-template-columns:420px minmax(0,1fr)}}@media (prefers-reduced-motion: reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}.login-page{min-height:100dvh;display:grid;place-items:center;padding:20px;background:radial-gradient(120% 80% at 50% 0%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 60%),var(--bg)}.login-card{width:min(400px,100%);padding:28px 24px;border:1px solid var(--line);border-radius:18px;background:var(--panel);box-shadow:var(--shadow-lg)}.mark{display:grid;place-items:center;width:44px;height:44px;margin-bottom:16px;border-radius:13px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;font-size:22px}.login-card h1{margin:0 0 4px;font-size:22px;font-weight:800}.sub{margin:0 0 22px;color:var(--muted);font-size:14px}.login-card label{display:block;margin-bottom:8px;color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.2px}.login-card input[type=password]{width:100%;height:48px;padding:0 14px;border:1px solid var(--line);border-radius:10px;background:var(--panel-2);color:inherit;outline:none;font:inherit}.login-card input[type=password]:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}.login-card button[type=submit]{width:100%;height:50px;margin-top:16px;border:1px solid var(--accent-strong);border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;font:inherit;font-weight:800;letter-spacing:.3px}.login-card button[type=submit]:hover{filter:brightness(1.05)}.login-card button[type=submit]:disabled{opacity:.7;cursor:wait}.login-error{min-height:20px;margin-top:12px;color:var(--danger);font-size:13px;font-weight:700}
