:root{--page: #eef2f7;--surface: #f7f9fc;--surface-2: #fbfcfe;--panel: #f4f7fb;--line: #cfd9e7;--line-strong: #9eb2ca;--text: #1f2a38;--muted: #4a5d73;--primary: #2877c7;--primary-soft: #dbe9f8;--shadow-sm: 0 1px 2px rgba(32, 55, 87, .03), 0 2px 6px rgba(32, 55, 87, .02);--radius-xl: 18px;--radius-lg: 14px;--radius-md: 10px;--ui-font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", "Noto Sans SC", "Microsoft YaHei", sans-serif;--ui-control-font: -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", "Noto Sans SC", "Microsoft YaHei", sans-serif;--upload-bg: #dceaf9;--switch-track-bg: #d7e1ee;--switch-track-border: #b9cadd;--switch-thumb-bg: #fff;--slider-visited: #bfd0e4;--badge-bg: #d9e9fa;--btn-tonal-bg: #dce8f6;--btn-tonal-color: #1d4f84;--btn-filled-bg: #8fb0d5;--card-bg: rgba(251, 252, 254, .82);--input-bg: #fdfefe;--sidebar-gradient-start: #eff3f8;--sidebar-gradient-end: #ebf0f6;--preview-gradient-start: #eef2f7;--preview-gradient-end: #e9eef5;--preview-stage-bg: #f3f6fa;--status-done: #43b768;--status-error: #eb5b56}html,body{margin:0;min-height:100%;background:var(--page);color:var(--text);font-family:var(--ui-font);-webkit-font-smoothing:antialiased;transition:background-color .22s ease,border-color .22s ease,color .22s ease}html{--theme-burst-x: calc(100% - 30px) ;--theme-burst-y: 28px}*{box-sizing:border-box}button,input,select{font:inherit;font-family:var(--ui-font)}body{overflow:hidden;position:relative;transition:background-color .24s ease,color .24s ease}body:after{content:"";position:fixed;top:-18vmax;right:-18vmax;bottom:-18vmax;left:-18vmax;pointer-events:none;opacity:0;background:radial-gradient(circle at var(--theme-burst-x) var(--theme-burst-y),color-mix(in srgb,var(--primary) 16%,transparent) 0,color-mix(in srgb,var(--primary) 10%,transparent) 9%,transparent 34%);transform:scale(.82);z-index:999}html.theme-switching body:after{animation:theme-burst .48s cubic-bezier(.22,.8,.24,1)}@keyframes theme-burst{0%{opacity:0;transform:scale(.82)}35%{opacity:.6}to{opacity:0;transform:scale(1.08)}}.app{display:grid;grid-template-columns:332px minmax(0,1fr);height:100dvh}.sidebar{padding:10px 10px 16px;background:linear-gradient(180deg,var(--sidebar-gradient-start) 0%,var(--sidebar-gradient-end) 100%);border-right:1px solid var(--line);overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:7px;transition:background .24s ease,border-color .24s ease}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:#6c829e47;border-radius:999px}.sidebar-head{min-height:34px;display:flex;align-items:center;justify-content:space-between}.brand-wrap{display:flex;align-items:center;gap:6px}.brand-mark{display:flex;align-items:center}.dot{width:9px;height:9px;border-radius:50%}.dot+.dot{margin-left:-2px}.dot-a{background:#3d8bff}.dot-b{background:#47b96d}.dot-c{background:#eb5b56}.brand{font-size:17px;font-weight:600;letter-spacing:-.03em}.icon-btn{width:44px;height:44px;border:0;border-radius:50%;background:transparent;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .18s ease,color .18s ease,transform .28s cubic-bezier(.22,.8,.24,1)}.icon-btn:hover{background:#2877c714;color:var(--text)}.icon-btn svg{width:16px;height:16px;transform-origin:center;transition:transform .28s cubic-bezier(.22,.8,.24,1),opacity .2s ease}html.theme-switching .icon-btn{transform:rotate(18deg) scale(.96)}html.theme-switching .icon-btn svg{transform:rotate(90deg) scale(.82)}[data-ui-theme=light] .icon-moon,[data-ui-theme=dark] .icon-sun{display:none}.upload-card,.panel-card,.text-preview-card,.preview-stage{contain:content;border:1px solid var(--line);background:var(--card-bg);box-shadow:var(--shadow-sm);transition:background-color .24s ease,border-color .24s ease,box-shadow .24s ease,color .24s ease}.upload-card{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:14px;cursor:pointer;text-decoration:none}.upload-card:hover{border-color:var(--line-strong);background:#f8fbff}.upload-ico{width:36px;height:36px;border-radius:11px;background:var(--upload-bg);color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.upload-ico svg{width:22px;height:22px}.upload-copy{min-width:0}.upload-title{font-size:13px;font-weight:500;margin-bottom:2px}.upload-sub{font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-card{border-radius:14px;padding:10px 11px}.panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.panel-head-inline{align-items:center}.panel-title{font-size:13px;font-weight:500}.inline-switches{display:flex;align-items:center;gap:8px}.mini-switch{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--muted);cursor:pointer}.mini-switch input{position:absolute;opacity:0}.mini-track{position:relative;width:44px;height:26px;border-radius:999px;background:var(--switch-track-bg, #d7e1ee);border:1px solid var(--switch-track-border, #b9cadd)}.mini-track:after{content:"";position:absolute;top:1px;left:1px;width:22px;height:22px;border-radius:50%;background:var(--switch-thumb-bg, #fff);box-shadow:0 1px 2px #00000014;transition:transform .18s ease}.mini-switch input:checked+.mini-track{background:var(--primary);border-color:var(--primary)}.mini-switch input:checked+.mini-track:after{transform:translate(18px)}.field-grid.two-col{display:grid;grid-template-columns:1fr 1fr;gap:8px}.compact-gap{margin-bottom:6px}.field{display:flex;flex-direction:column;gap:5px}.field-label{font-size:10px;font-weight:500;color:var(--muted)}.field-label-top{margin-top:2px;margin-bottom:8px}.field input,.field select{width:100%;height:34px;border:1px solid var(--line-strong);border-radius:10px;background:var(--input-bg);padding:0 10px;color:var(--text);outline:none;font-family:var(--ui-control-font);font-size:16px;font-weight:500;letter-spacing:-.01em;line-height:1;-webkit-font-smoothing:antialiased}.field input:focus,.field select:focus{border-color:var(--primary)}.field input::placeholder{font-weight:500;color:color-mix(in srgb,var(--muted) 78%,transparent)}.field select option{font-family:var(--ui-control-font);font-size:16px;font-weight:500}.field-select{position:relative}.select-wrap{position:relative;display:block}.field select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding-right:32px;font-family:var(--ui-control-font);text-rendering:geometricPrecision}.select-arrow{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:12px;height:8px;color:var(--muted);pointer-events:none}.slider-row{display:block;margin-top:8px}.slider-header{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px;font-size:12px;font-weight:500}.slider-header span:first-child{color:var(--text)}.slider-header span:last-child{color:var(--primary);background:var(--badge-bg);border-radius:999px;padding:2px 9px;min-width:48px;text-align:center}input[type=range]{width:100%;height:4px;border-radius:999px;background:var(--slider-visited, #bfd0e4);-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;padding:10px 0;margin:-10px 0}input[type=range]{touch-action:none}input[type=range]::-webkit-slider-thumb{width:24px;height:24px;border-radius:50%;border:2px solid #dbe8f6;background:var(--primary);-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}input[type=range]::-moz-range-thumb{width:24px;height:24px;border:2px solid #dbe8f6;border-radius:50%;background:var(--primary);cursor:pointer}.theme-swatches{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}.swatch{height:36px;border-radius:10px;border:2px solid transparent;box-shadow:inset 0 0 0 1px #ffffffb3;cursor:pointer}.swatch.is-active{border-color:#283d5d47}.auto{background:linear-gradient(135deg,#d7dee8,#e9ddd6)}.soft-rose{background:#e7d6d9}.mist-blue{background:#d5dbe6}.soft-apricot{background:#ead5c0}.soft-sand{background:#ddd9d2}.chip-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:8px}.color-chip-card{display:flex;align-items:center;gap:8px;min-width:0;padding:8px 10px;border-radius:14px;border:1px solid var(--line);background:#f8fbff}.color-chip{width:32px;height:32px;border-radius:10px;background:#d0d0d0;border:1px solid rgba(120,132,150,.25);flex-shrink:0}.chip-copy{min-width:0}.color-chip-card{animation:chip-reveal .42s cubic-bezier(.22,.8,.24,1) both}.color-chip-card:nth-child(2){animation-delay:.08s}@keyframes chip-reveal{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.chip-copy span{display:block;font-size:10px;color:var(--muted);margin-bottom:2px}.chip-copy strong{display:block;font-size:12px;line-height:1.2;word-break:break-all}.side-meta{margin-top:auto;display:flex;flex-direction:column;gap:8px}.text-preview-card{border-radius:14px;padding:7px 9px;display:flex;align-items:center;gap:10px}.meta-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px #2877c71f;flex-shrink:0}.text-preview-copy span{display:block;font-size:10px;color:var(--muted);margin-bottom:2px}.text-preview-copy strong{display:block;font-size:13px}.action-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.btn{height:40px;border:0;border-radius:999px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .22s ease,color .22s ease,transform .14s ease}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-tonal{background:var(--btn-tonal-bg);color:var(--btn-tonal-color)}.btn-filled{background:var(--btn-filled-bg);color:#fff}.btn-filled:not(:disabled){background:var(--primary)}.size-readout{font-size:11px;color:var(--muted);font-weight:500;white-space:nowrap}.preview-panel{min-width:0;padding:12px 12px 12px 10px;background:linear-gradient(180deg,var(--preview-gradient-start) 0%,var(--preview-gradient-end) 100%);display:flex;flex-direction:column;gap:10px}.preview-head{min-height:26px;display:flex;align-items:center;justify-content:space-between;gap:12px}.preview-title-wrap{display:flex;align-items:center;gap:9px}.preview-title{font-size:13px;font-weight:500}.preview-meta{font-size:11px;font-weight:500;color:var(--muted)}.preview-stage{position:relative;flex:1;min-height:0;border-radius:0;background:var(--preview-stage-bg);padding:10px;display:flex;align-items:center;justify-content:center;overflow:auto;transition:box-shadow .2s ease,background-color .2s ease}.preview-stage.drag-over{box-shadow:inset 0 0 0 3px var(--primary);background:color-mix(in srgb,var(--primary) 6%,var(--preview-stage-bg))}.preview-stage .drop-hint{display:none;position:absolute;top:0;right:0;bottom:0;left:0;align-items:center;justify-content:center;background:color-mix(in srgb,var(--primary) 8%,transparent);z-index:10;pointer-events:none}.preview-stage.drag-over .drop-hint{display:flex}.drop-hint-text{font-size:16px;font-weight:500;color:var(--primary);background:var(--surface);padding:14px 28px;border-radius:16px;box-shadow:0 4px 24px #0000001a}#previewCanvas{display:block;max-width:100%;max-height:calc(100dvh - 56px);width:auto;height:auto;border-radius:0}.placeholder{position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:0;color:#7f8ea2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.placeholder.is-hidden{display:none}.placeholder-icon{width:52px;height:52px}.placeholder-icon svg{width:100%;height:100%}.placeholder-text{font-size:12px;font-weight:500}[data-ui-theme=dark]{--page: #151a20;--surface: #1e252d;--surface-2: #222b35;--panel: #202932;--line: #334150;--line-strong: #50657b;--text: #edf2f8;--muted: #a9b7c8;--primary: #6aa9ea;--primary-soft: rgba(106, 169, 234, .18);--shadow-sm: none;--upload-bg: #273747;--switch-track-bg: #334150;--switch-track-border: #50657b;--switch-thumb-bg: #e0e6ef;--slider-visited: #334150;--badge-bg: rgba(106, 169, 234, .18);--btn-tonal-bg: #273747;--btn-tonal-color: #dce9f8;--btn-filled-bg: #507fb2;--card-bg: rgba(31, 39, 48, .96);--input-bg: #1a222b;--sidebar-gradient-start: #171d24;--sidebar-gradient-end: #171d24;--preview-gradient-start: #171d24;--preview-gradient-end: #171d24;--preview-stage-bg: #202932;--status-done: #5fd478;--status-error: #f87171}[data-ui-theme=dark] .sidebar,[data-ui-theme=dark] .preview-panel{background:linear-gradient(180deg,var(--sidebar-gradient-start) 0%,var(--sidebar-gradient-end) 100%)}[data-ui-theme=dark] .field input,[data-ui-theme=dark] .field select{color:var(--text)}[data-ui-theme=dark] .select-arrow{color:var(--muted)}@media(max-height:860px)and (min-width:981px){body{overflow:auto}.app{height:auto;min-height:100dvh}.sidebar{overflow-y:auto}}@media(min-width:981px)and (max-width:1200px){.app{grid-template-columns:310px minmax(0,1fr)}.sidebar{padding:8px 8px 6px}}@media(max-width:980px){body{overflow:auto}.app{grid-template-columns:1fr;height:auto}.sidebar{height:auto;overflow:visible;border-right:0;border-bottom:1px solid var(--line)}.preview-panel{min-height:60vh;padding-top:14px}#previewCanvas{max-height:calc(100dvh - 140px)}}@media(max-width:640px){.field-grid.two-col,.chip-grid,.theme-swatches{grid-template-columns:1fr}.action-row{grid-template-columns:1fr 1fr}.inline-switches{flex-wrap:wrap;justify-content:flex-end}}.preset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-bottom:8px}.preset-btn{height:36px;border:1px solid var(--line-strong);border-radius:8px;background:var(--surface-2);color:var(--muted);font-size:11px;font-weight:500;cursor:pointer;transition:background-color .18s ease,border-color .18s ease,color .18s ease}.preset-btn:hover,.preset-btn.is-active{background:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.preset-thumb{display:block;width:100%;height:14px;border-radius:3px;background:#fff;margin-bottom:3px;box-shadow:0 0 0 1px #00000014}.preset-thumb.th-none{box-shadow:none;background:transparent;border:1px dashed rgba(0,0,0,.12)}.preset-thumb.th-minimal{box-shadow:inset 0 0 0 1px #000000b3}.preset-thumb.th-classic{box-shadow:inset 0 0 0 2px #000000b3;padding:3px}.preset-thumb.th-polaroid{box-shadow:inset 0 0 #000000b3;padding:4px;box-shadow:0 2px 8px #0000001a}.preset-thumb.th-film{box-shadow:inset 0 0 0 3px #000000b3}.preset-thumb.th-shadow{box-shadow:0 3px 12px #00000024}[data-ui-theme=dark] .preset-btn{background:var(--panel)}.text-btn{display:inline-flex;align-items:center;height:24px;padding:0 8px;border:0;border-radius:6px;background:transparent;color:var(--primary);font-size:11px;font-weight:500;cursor:pointer;transition:background-color .18s ease}.text-btn:hover{background:var(--primary-soft)}.btn-sm{height:28px;font-size:11px;padding:0 12px;border-radius:8px}.btn-xs{height:26px;font-size:10px;padding:0 10px;border-radius:7px}.btn-full{width:100%;justify-content:center}.dropdown{position:relative;display:inline-block}.dropdown-menu{position:absolute;top:calc(100% + 4px);right:0;min-width:180px;background:var(--surface);border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 32px #0000001f;padding:6px;z-index:100;animation:dropdown-in .16s ease}.dropdown-item{display:block;width:100%;height:34px;border:0;border-radius:8px;background:transparent;color:var(--text);font-size:12px;font-weight:500;text-align:left;padding:0 10px;cursor:pointer;transition:background .12s ease}.dropdown-item:hover{background:var(--primary-soft);color:var(--primary)}.dropdown-divider{height:1px;background:var(--line);margin:4px 6px}.dropdown-label{font-size:10px;font-weight:600;color:var(--muted);padding:4px 10px 2px}@keyframes dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}[data-ui-theme=dark] .dropdown-menu{background:var(--panel);box-shadow:0 8px 32px #00000059}.batch-toggle{display:inline-flex;align-items:center;justify-content:center;text-align:center;cursor:pointer;border-radius:999px;font-size:11px;font-weight:500}.batch-controls{display:flex;align-items:center;gap:6px;margin-bottom:6px}.batch-list{display:flex;flex-direction:column;gap:4px;max-height:140px;overflow-y:auto}.batch-list::-webkit-scrollbar{width:4px}.batch-list::-webkit-scrollbar-thumb{background:#6c829e47;border-radius:999px}.batch-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;background:var(--surface-2);font-size:11px}.batch-thumb,.batch-thumb-placeholder{width:36px;height:36px;border-radius:6px;flex-shrink:0;object-fit:cover;background:var(--line)}.batch-thumb-placeholder{display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px}.batch-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.batch-retry-btn{width:36px;height:28px;border:1px solid var(--line-strong);border-radius:6px;background:var(--surface);color:var(--primary);font-size:11px;font-weight:500;cursor:pointer;flex-shrink:0;transition:background .15s ease}.batch-retry-btn:hover{background:var(--primary-soft)}.batch-item.done{background:color-mix(in srgb,var(--status-done) 8%,transparent)}.batch-item.error{background:color-mix(in srgb,var(--status-error) 8%,transparent)}.batch-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500}.batch-status{font-size:10px;color:var(--muted);flex-shrink:0}.batch-item.done .batch-status{color:var(--status-done)}.batch-item.error .batch-status{color:var(--status-error)}.batch-progress{width:100%;height:3px;border-radius:999px;background:var(--line);overflow:hidden}.batch-progress-bar{height:100%;background:var(--primary);border-radius:999px;transition:width .2s ease}.template-save{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.template-save-actions{display:flex;gap:6px}.field-input{width:100%;height:32px;border:1px solid var(--line-strong);border-radius:10px;background:var(--surface-2);padding:0 10px;color:var(--text);font-size:13px;font-weight:500;outline:none;font-family:var(--ui-control-font)}.field-input:focus{border-color:var(--primary)}.template-list{display:flex;flex-direction:column;gap:4px;max-height:120px;overflow-y:auto}.template-list::-webkit-scrollbar{width:4px}.template-list::-webkit-scrollbar-thumb{background:#6c829e47;border-radius:999px}.template-item{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-radius:8px;border:1px solid var(--line);background:var(--surface-2);transition:border-color .18s ease}.template-item:hover{border-color:var(--line-strong)}.template-item.is-active{border-color:var(--primary);background:var(--primary-soft)}.template-item-info{min-width:0;flex:1}.template-item-info strong{display:block;font-size:12px;line-height:1.2;margin-bottom:1px}.template-item-info span{display:block;font-size:10px;color:var(--muted)}.template-item-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.icon-btn-sm{width:36px;height:36px;border:0;border-radius:6px;background:transparent;color:var(--muted);font-size:11px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .18s ease,color .18s ease}.icon-btn-sm:hover{background:#2877c71a;color:var(--text)}.template-empty{padding:8px;text-align:center}.muted-text{font-size:11px;color:var(--muted)}.image-error{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#eb5b56;font-size:13px;font-weight:500;padding:8px 12px;background:#eb5b5614;border:1px solid rgba(235,91,86,.2);border-radius:10px;margin-top:4px}.image-error .text-btn{color:#eb5b56;flex-shrink:0}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,var(--line) 0%,color-mix(in srgb,var(--line) 60%,var(--surface)) 40%,var(--line) 80%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite;border-radius:8px}.skeleton-canvas{width:100%;height:100%;min-height:200px;border-radius:0;position:absolute;top:10px;right:10px;bottom:10px;left:10px}.demo-btn{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 16px;border:1px dashed var(--line-strong);border-radius:999px;background:var(--surface);color:var(--muted);font-size:12px;font-weight:500;cursor:pointer;transition:border-color .18s ease,color .18s ease,background .18s ease}.demo-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}.demo-btn svg{width:16px;height:16px}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:12px;font-size:13px;font-weight:500;box-shadow:0 4px 20px #0000001f;pointer-events:auto;animation:toast-in .28s cubic-bezier(.22,.8,.24,1);transition:opacity .22s ease,transform .22s ease;max-width:360px}.toast.toast-out{opacity:0;transform:translate(40px) scale(.96)}.toast-success{background:#e8f5ec;color:#1e6e3a;border:1px solid #b8dfc4}.toast-error{background:#fdecea;color:#b3322c;border:1px solid #f5c6c2}.toast-info{background:var(--primary-soft);color:var(--primary);border:1px solid color-mix(in srgb,var(--primary) 30%,transparent)}.toast-icon{width:18px;height:18px;flex-shrink:0}.toast-close{width:24px;height:24px;border:0;border-radius:6px;background:transparent;color:inherit;opacity:.6;cursor:pointer;font-size:14px;display:inline-flex;align-items:center;justify-content:center;margin-left:auto;flex-shrink:0;transition:opacity .15s ease}.toast-close:hover{opacity:1}[data-ui-theme=dark] .toast-success{background:#5fd47824;color:#5fd478;border-color:#5fd47838}[data-ui-theme=dark] .toast-error{background:#f8717124;color:#f87171;border-color:#f8717138}[data-ui-theme=dark] .toast-info{background:#6aa9ea2e;color:#6aa9ea;border-color:#6aa9ea38}@keyframes toast-in{0%{opacity:0;transform:translate(40px) scale(.96)}to{opacity:1;transform:translate(0) scale(1)}}.icon-btn:focus-visible,.icon-btn-sm:focus-visible,.preset-btn:focus-visible,.swatch:focus-visible,.text-btn:focus-visible,.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:inherit}input[type=range]:focus-visible{outline:2px solid var(--primary);outline-offset:4px;border-radius:999px}[data-ui-theme=dark] .field-input{background:var(--panel);color:var(--text)}[data-ui-theme=dark] .batch-item,[data-ui-theme=dark] .template-item{background:var(--panel)}:root{--page: #fbfbf8;--surface: #fffffc;--surface-2: #fbfbf8;--panel: #fffffc;--line: #d8d2c7;--line-strong: #171514;--text: #171514;--muted: #706b66;--primary: #9d2f45;--primary-soft: rgba(157, 47, 69, .08);--shadow-sm: none;--radius-xl: 0;--radius-lg: 0;--radius-md: 0;--serif-font: "Gloock", Georgia, serif;--cn-serif-font: "Noto Serif SC", "Songti SC", "STSong", serif;--ui-font: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Noto Sans SC", sans-serif;--ui-control-font: "Inter", "Helvetica Neue", Arial, "PingFang SC", "Noto Sans SC", sans-serif;--ui-label-size: 12px;--ui-label-tracking: .2em;--ui-value-size: 13px;--ui-value-tracking: .055em;--field-height: 50px;--field-pad-x: 26px;--upload-bg: transparent;--switch-track-bg: #ede9e1;--switch-track-border: #d8d2c7;--switch-thumb-bg: #fffffc;--slider-visited: #c8c0b5;--badge-bg: transparent;--btn-tonal-bg: transparent;--btn-tonal-color: #171514;--btn-filled-bg: #171514;--card-bg: transparent;--input-bg: #fbfbf8;--sidebar-gradient-start: #fffffc;--sidebar-gradient-end: #fffffc;--preview-gradient-start: #fbfbf8;--preview-gradient-end: #fbfbf8;--preview-stage-bg: #fbfbf8;--status-done: #657a55;--status-error: #b64b45;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-soft: cubic-bezier(.25, .46, .45, .94)}html,body{background:var(--page);color:var(--text);font-family:var(--ui-font)}button,input,select{font-family:var(--ui-control-font)}.app{grid-template-columns:minmax(0,1fr) 460px;height:100dvh;overflow:hidden;background:var(--page)}.preview-panel{grid-column:1;grid-row:1;position:relative;min-width:0;min-height:0;padding:0;gap:0;background:linear-gradient(90deg,rgba(23,21,20,.045) 1px,transparent 1px),linear-gradient(rgba(23,21,20,.04) 1px,transparent 1px),var(--preview-stage-bg);background-size:64px 64px;border-right:1px solid rgba(23,21,20,.1);animation:pc-reveal-up .82s 80ms var(--ease-out) both}.sidebar{grid-column:2;grid-row:1;padding:36px 40px 34px;gap:0;background:var(--panel);border-right:0;border-left:1px solid rgba(23,21,20,.1);scrollbar-gutter:stable;animation:pc-reveal-left .78s 90ms var(--ease-out) both}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#1715142e;border:3px solid var(--panel);border-radius:999px}.sidebar-head{min-height:auto;padding-bottom:30px;border-bottom:1px solid var(--line)}.brand-wrap{gap:10px}.brand-mark{display:none}.brand{font-family:var(--serif-font);font-size:clamp(32px,2.2vw,42px);font-weight:400;line-height:1;letter-spacing:0}.icon-btn{width:42px;height:42px;border:1px solid var(--text);border-radius:999px;color:var(--text);transition:transform .52s var(--ease-out),background-color .42s var(--ease-soft),color .42s var(--ease-soft)}.icon-btn:hover{transform:translateY(-1px);background:var(--text);color:var(--page)}.upload-card{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:0;min-height:var(--field-height);margin-top:28px;padding:0;border:1px solid var(--text);border-radius:0;background:transparent;box-shadow:none;overflow:hidden;transform:translateZ(0);transition:border-color .42s var(--ease-soft),box-shadow .52s var(--ease-soft),transform .52s var(--ease-out)}.upload-card:hover{border-color:var(--primary);background:transparent;box-shadow:0 0 0 3px #9d2f4514;transform:translateY(-2px)}.upload-card:active{transform:translateY(0) scale(.997)}.upload-card.is-loading{border-color:var(--primary);box-shadow:0 0 0 3px #9d2f4514}.upload-ico{display:none}.upload-copy{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;width:100%;min-height:var(--field-height)}.upload-title{min-width:0;padding:0 18px 0 var(--field-pad-x);margin:0;color:var(--text);font-family:var(--ui-control-font);font-size:var(--ui-value-size);font-weight:500;letter-spacing:var(--ui-value-tracking);text-transform:uppercase;white-space:nowrap;transition:color .42s var(--ease-soft),transform .52s var(--ease-out)}.upload-card.is-loading .upload-title{color:var(--primary)}.upload-sub{align-self:stretch;display:inline-flex;align-items:center;padding:0 20px;color:#fff;background:var(--text);border-left:1px solid var(--text);font-size:0;white-space:nowrap;overflow:visible;transition:background-color .42s var(--ease-soft),color .42s var(--ease-soft),transform .52s var(--ease-out)}.upload-sub:before{content:"Replace";font-family:var(--ui-control-font);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.upload-card.is-loading .upload-sub:before{content:"Loading"}.upload-card.is-loading .upload-sub{background:linear-gradient(90deg,var(--text),var(--primary),var(--text)) 0 0 / 220% 100%;animation:pc-upload-scan 1.15s var(--ease-soft) infinite}.upload-card:hover .upload-title{color:var(--primary);transform:translate(2px)}.upload-card:hover .upload-sub{background:var(--primary);transform:translate(-1px)}.panel-card,.text-preview-card{contain:none;border:0;border-bottom:1px solid var(--line);border-radius:0;padding:30px 0 31px;background:transparent;box-shadow:none;animation:pc-reveal-up .72s var(--ease-out) both}.panel-card:nth-of-type(1){animation-delay:.15s}.panel-card:nth-of-type(2){animation-delay:.2s}.panel-card:nth-of-type(3){animation-delay:.25s}.panel-card:nth-of-type(4){animation-delay:.3s}.panel-card:nth-of-type(5){animation-delay:.35s}.panel-card:nth-of-type(6){animation-delay:.4s}.panel-head{display:grid;grid-template-columns:max-content max-content;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px}.panel-title{color:var(--text);font-family:var(--ui-control-font);font-size:14px;font-weight:700;letter-spacing:.18em;text-transform:uppercase}.inline-switches{gap:14px}.mini-switch{gap:8px;color:var(--muted);font-family:var(--ui-control-font);font-size:var(--ui-label-size);font-weight:500;letter-spacing:.08em;transition:color .42s var(--ease-soft),transform .52s var(--ease-out)}.mini-switch:hover{color:var(--text)}.mini-track{width:42px;height:22px;border-radius:999px;background:transparent;border:1px solid var(--line);box-shadow:inset 0 0 0 1px #fffffc80;transition:background-color .46s var(--ease-soft),border-color .46s var(--ease-soft),box-shadow .46s var(--ease-soft)}.mini-track:after{top:3px;left:3px;width:14px;height:14px;background:#fffffc;box-shadow:0 1px 3px #19161229;transition:transform .52s var(--ease-out),background-color .46s var(--ease-soft),box-shadow .46s var(--ease-soft)}.mini-switch input:checked+.mini-track{background:var(--primary);border-color:var(--primary);box-shadow:inset 0 0 0 1px #fffffc24}.mini-switch input:checked+.mini-track:after{transform:translate(20px)}.mini-switch input:focus-visible+.mini-track{outline:2px solid var(--primary);outline-offset:3px}.mini-switch:active .mini-track:after{transform:scale(.92)}.mini-switch:active input:checked+.mini-track:after{transform:translate(20px) scale(.92)}.field-grid.two-col,.field-grid.two-col.compact-gap{grid-template-columns:1fr;gap:16px}.field{gap:10px}.field-label,.field-label-top,.slider-header,.chip-copy span,.text-preview-copy span,.dropdown-label,.batch-status,.template-item-info span,.muted-text{color:#69645e;font-family:var(--ui-control-font);font-size:var(--ui-label-size);font-weight:500;letter-spacing:.04em;line-height:1.2}.field-label-top{margin:14px 0 10px}.field input,.field select,.field-input{height:var(--field-height);border:1px solid var(--line);border-radius:0;background:var(--input-bg);color:#2a2825;padding:0 18px 0 var(--field-pad-x);font-family:var(--ui-control-font);font-size:var(--ui-value-size);font-weight:500;letter-spacing:var(--ui-value-tracking);text-transform:uppercase;line-height:1;transition:border-color .42s var(--ease-soft),background-color .42s var(--ease-soft),box-shadow .52s var(--ease-soft),transform .52s var(--ease-out)}.field input:hover,.field select:hover,.field-input:hover{border-color:#17151457;background:#fffffc}.field input:focus,.field select:focus,.field-input:focus{border-color:var(--primary);background:#fffffc;box-shadow:0 0 0 3px #9d2f4514;transform:translateY(-1px)}.field input::placeholder{color:#706b669e;font-weight:500}.field select option{font-family:var(--ui-control-font);font-size:var(--ui-value-size);font-weight:500}.select-arrow{right:18px;width:12px;height:8px;color:var(--text)}.slider-row{margin-top:16px}.slider-header{margin-bottom:10px}.slider-header span:first-child{color:#69645e}.slider-header span:last-child{min-width:auto;padding:0;color:var(--muted);background:transparent;border-radius:0;text-align:right}input[type=range]{--range-track: #c8c0b5;--range-fill: var(--primary);height:22px;padding:0;margin:-1px 0 0;border-radius:0;border:0;box-shadow:none;background:linear-gradient(var(--range-fill),var(--range-fill)) 0 50% / var(--range-fill-percent, 0%) 2px no-repeat,linear-gradient(var(--range-track),var(--range-track)) 0 50% / 100% 2px no-repeat;transition:filter .42s var(--ease-soft)}input[type=range]::-webkit-slider-runnable-track{height:22px;border:0;background:transparent}input[type=range]:hover{filter:saturate(1.1)}input[type=range]::-webkit-slider-thumb{width:8px;height:28px;margin-top:-3px;border:0;border-radius:0;background:var(--primary);box-shadow:0 0 0 4px var(--panel);transition:transform .42s var(--ease-out)}input[type=range]::-webkit-slider-thumb:hover{transform:scaleY(1.12)}input[type=range]:active::-webkit-slider-thumb{transform:scaleY(.92)}input[type=range]::-moz-range-thumb{width:8px;height:28px;border:0;border-radius:0;background:var(--primary);box-shadow:0 0 0 4px var(--panel)}input[type=range]::-moz-range-track{height:2px;background:var(--range-track)}input[type=range]::-moz-range-progress{height:2px;background:var(--range-fill)}.slider-row:hover .slider-header span:first-child,.slider-row:hover .slider-header span:last-child{color:var(--text)}.theme-swatches{grid-template-columns:repeat(5,1fr);gap:12px}.swatch{height:58px;border:1px solid rgba(23,21,20,.16);border-radius:0;box-shadow:none;transition:transform .56s var(--ease-out),box-shadow .52s var(--ease-soft),border-color .42s var(--ease-soft)}.swatch:hover{transform:translateY(-3px);border-color:#1715145c;box-shadow:0 12px 28px #1916121f}.swatch.is-active{border-color:#17151475;box-shadow:inset 0 0 0 8px var(--panel),inset 0 0 0 9px var(--text)}.chip-grid{grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.color-chip-card,.template-item,.batch-item{border-radius:0;border:1px solid var(--line);background:var(--surface-2)}.color-chip-card{padding:12px var(--field-pad-x)}.color-chip{border-radius:0}.chip-copy strong,.text-preview-copy strong,.template-item-info strong,.batch-name{font-family:var(--ui-control-font);font-size:var(--ui-label-size);font-weight:600;letter-spacing:.08em;text-transform:uppercase}.side-meta{margin-top:20px}.btn,.text-btn,.demo-btn,.dropdown-item,.batch-toggle,.batch-retry-btn,.icon-btn-sm{border-radius:0;font-family:var(--ui-control-font);letter-spacing:.08em;text-transform:uppercase;transition:transform .52s var(--ease-out),background-color .42s var(--ease-soft),color .42s var(--ease-soft),border-color .42s var(--ease-soft)}.btn{height:var(--field-height);border:1px solid var(--text);font-size:12px;font-weight:700;background:transparent;color:var(--text)}.btn:hover:not(:disabled),.demo-btn:hover{transform:translateY(-2px);background:var(--text);color:var(--page)}.btn-tonal{background:transparent;color:var(--text)}.btn-filled,.btn-filled:not(:disabled){background:var(--text);color:var(--page)}.btn-filled:hover:not(:disabled){background:var(--primary);border-color:var(--primary)}.btn-sm{height:34px;border-radius:0}.btn-xs{height:30px;border-radius:0}.text-btn{height:28px;padding:0;color:var(--muted);background:transparent;font-size:11px;font-weight:600}.text-btn:hover{color:var(--primary);background:transparent}.preview-head{min-height:72px;flex:0 0 auto;padding:0 34px;border-bottom:1px solid rgba(23,21,20,.1);position:relative;z-index:2000;isolation:isolate;background:#fbfbf8;-webkit-backdrop-filter:none;backdrop-filter:none}.preview-head-left,.preview-head-right{display:flex;align-items:center;gap:12px;position:relative;z-index:30}.preview-title,.preview-text-inline,.size-readout{color:var(--muted);font-family:var(--ui-control-font);font-size:var(--ui-label-size);font-weight:500;letter-spacing:.14em;text-transform:uppercase}.meta-dot{width:7px;height:7px;background:var(--primary);box-shadow:none}.preview-stage{contain:none;position:relative;z-index:0;flex:1;margin:0;padding:42px;border:0;background:transparent;display:grid;place-items:center;overflow:auto}.preview-stage:before{content:"";position:absolute;top:9%;right:9%;bottom:9%;left:9%;border:1px solid rgba(23,21,20,.08);pointer-events:none}.preview-stage.drag-over{box-shadow:inset 0 0 0 3px var(--primary);background:#9d2f450d}#previewCanvas{max-width:min(88%,88vh);max-height:calc(100dvh - 112px);filter:drop-shadow(0 28px 80px rgba(25,22,18,.14));animation:pc-float-in .9s .13s var(--ease-out) both;transition:opacity .36s var(--ease-soft),transform .8s var(--ease-out),filter .8s var(--ease-out)}#previewCanvas:hover{transform:translateY(-4px) scale(1.012);filter:drop-shadow(0 34px 94px rgba(25,22,18,.17))}#previewCanvas.is-transitioning{opacity:.72;transform:translateY(6px) scale(.986);filter:drop-shadow(0 18px 52px rgba(25,22,18,.1))}.preview-loading{position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;display:grid;place-items:center;pointer-events:none;background:linear-gradient(90deg,transparent 0%,rgba(255,255,252,.68) 48%,transparent 100%) -120% 0 / 220% 100% no-repeat;animation:pc-preview-wash 1.18s var(--ease-soft) infinite}.preview-loading-bar{position:absolute;top:50%;left:50%;width:min(420px,42vw);height:2px;overflow:hidden;transform:translate(-50%,-50%);background:#17151429}.preview-loading-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;width:38%;background:var(--primary);animation:pc-loading-line .94s var(--ease-out) infinite}.preview-loading-copy{position:absolute;left:clamp(24px,3vw,56px);bottom:clamp(24px,3vw,48px);display:grid;gap:6px;color:var(--muted);font-family:var(--ui-control-font);letter-spacing:.08em;text-transform:uppercase}.preview-loading-copy span{font-size:11px;font-weight:700}.preview-loading-copy strong{max-width:min(360px,42vw);overflow:hidden;color:var(--text);font-size:13px;font-weight:600;letter-spacing:.12em;text-overflow:ellipsis;white-space:nowrap}.placeholder{top:42px;right:42px;bottom:42px;left:42px;gap:14px;color:var(--muted);border:1px solid rgba(23,21,20,.1);background:#fffffc61}.placeholder-text{font-family:var(--ui-control-font);font-size:var(--ui-label-size);font-weight:500;letter-spacing:.08em;text-transform:uppercase}.demo-btn{height:40px;border:1px solid var(--text);background:transparent;color:var(--text)}.dropdown{z-index:2100}.dropdown-menu{top:calc(100% + 10px);right:0;min-width:230px;padding:10px 0;border-radius:0;background:#fffffc;border:1px solid var(--line-strong);box-shadow:0 18px 44px #19161224;animation:pc-dropdown-in .26s var(--ease-out);z-index:1000;pointer-events:auto;opacity:1;overflow:hidden}.dropdown-item{height:46px;padding:0 28px;border-radius:0;background:#fffffc;color:var(--text);font-size:13px;font-weight:700;letter-spacing:.1em;pointer-events:auto;transition:transform .42s var(--ease-out),background-color .32s var(--ease-soft),color .32s var(--ease-soft)}.dropdown-item:hover{transform:translate(3px);background:#f3eee7;color:var(--primary)}.dropdown-divider{margin:8px 24px}.dropdown-label{padding:6px 28px 4px}.preview-head-right .btn{min-width:118px;height:58px;padding:0 24px;border:2px solid var(--text);background:var(--surface);color:var(--text);opacity:1;pointer-events:auto;font-size:13px;letter-spacing:.08em}.preview-head-right .btn-tonal:not(:disabled){background:var(--surface);color:var(--text)}.preview-head-right .btn-filled:not(:disabled){background:var(--primary);border-color:var(--primary);color:#fff}.preview-head-right .btn:hover:not(:disabled){transform:translateY(-2px);background:var(--text);border-color:var(--text);color:var(--page)}.preview-head-right .btn-filled:hover:not(:disabled){background:#7d2437;border-color:#7d2437;color:#fff}.preview-head-right .btn:disabled{opacity:.36;color:var(--muted);border-color:var(--line);background:transparent;pointer-events:none}.dropdown.is-open .btn-filled:not(:disabled){background:#7d2437;border-color:#7d2437;color:#fff}.template-save{gap:10px}.template-list,.batch-list{gap:8px}.template-item,.batch-item{padding:10px 12px}.icon-btn-sm{border:1px solid transparent}.icon-btn-sm:hover{background:transparent;border-color:var(--line);color:var(--text)}.image-error,.toast{border-radius:0}.toast{box-shadow:0 18px 44px #19161224}@keyframes pc-reveal-up{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes pc-reveal-left{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}@keyframes pc-upload-scan{0%{background-position:100% 0}to{background-position:-120% 0}}@keyframes pc-preview-wash{0%{background-position:-120% 0}to{background-position:120% 0}}@keyframes pc-loading-line{0%{transform:translate(-120%)}to{transform:translate(280%)}}@keyframes pc-float-in{0%{opacity:0;transform:translateY(28px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pc-dropdown-in{0%{transform:translateY(-6px)}to{transform:translateY(0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}}@media(max-height:860px)and (min-width:981px){body{overflow:hidden}.app{height:100dvh;min-height:0}}@media(min-width:981px)and (max-width:1280px){.app{grid-template-columns:minmax(0,1fr) 420px}.sidebar{padding:30px 32px}#previewCanvas{max-width:min(84%,80vh)}}@media(max-width:980px){body{overflow:auto}.app{display:flex;flex-direction:column-reverse;height:auto;min-height:100dvh;overflow:visible}.sidebar{width:100%;border-left:0;border-bottom:1px solid var(--line);padding:30px 22px 42px}.preview-panel{min-height:64vh;border-right:0}.preview-head{min-height:auto;padding:16px 18px;flex-wrap:wrap}.preview-stage{min-height:58vh;padding:26px 18px}#previewCanvas{max-width:min(88vw,460px);max-height:calc(100dvh - 180px)}}@media(max-width:640px){.brand{font-size:30px}.panel-head,.panel-head.panel-head-inline{grid-template-columns:1fr;align-items:start}.inline-switches{justify-content:start}.chip-grid,.theme-swatches{grid-template-columns:1fr 1fr}}[data-ui-theme=dark]{--page: #151311;--surface: #1e1b18;--surface-2: #201d1a;--panel: #181614;--line: #3c3630;--line-strong: #e7dfd4;--text: #f7f1e8;--muted: #b9afa4;--primary: #d26b82;--primary-soft: rgba(210, 107, 130, .16);--input-bg: #181614;--preview-stage-bg: #151311}[data-ui-theme=dark] .sidebar,[data-ui-theme=dark] .preview-panel{background:var(--panel)}[data-ui-theme=dark] .preview-head{background:#151311d6}[data-ui-theme=dark] .field input,[data-ui-theme=dark] .field select,[data-ui-theme=dark] .field-input{color:var(--text)}.app *,.app *:before,.app *:after,.toast,.toast *{border-radius:0!important}.app .icon-btn,.app .icon-btn-sm,.app .btn,.app .text-btn,.app .demo-btn,.app .batch-toggle,.app .batch-retry-btn,.app .dropdown-menu,.app .dropdown-item,.app .upload-card,.app .mini-track,.app .mini-track:after,.app .swatch,.app .color-chip,.app .color-chip-card,.app .template-item,.app .batch-item,.app .field input,.app .field select,.app .field-input{border-radius:0!important}.app input[type=range]{--range-track: #c8c0b5;--range-fill: var(--primary);display:block;width:100%;height:30px!important;padding:0!important;margin:-4px 0 0!important;border:0!important;border-radius:0!important;box-shadow:none!important;background:linear-gradient(var(--range-fill),var(--range-fill)) 0 50% / var(--range-fill-percent, 0%) 2px no-repeat,linear-gradient(var(--range-track),var(--range-track)) 0 50% / 100% 2px no-repeat!important;-moz-appearance:none!important;appearance:none!important;-webkit-appearance:none!important}.app input[type=range]::-webkit-slider-runnable-track{width:100%;height:30px!important;border:0!important;border-radius:0!important;background:transparent!important;box-shadow:none!important}.app input[type=range]::-webkit-slider-thumb{width:8px!important;height:28px!important;margin-top:1px!important;border:0!important;border-radius:0!important;background:var(--primary)!important;box-shadow:none!important;cursor:pointer;-moz-appearance:none!important;appearance:none!important;-webkit-appearance:none!important;transition:transform .42s var(--ease-out)}.app input[type=range]::-webkit-slider-thumb:hover{transform:scaleY(1.12)}.app input[type=range]:active::-webkit-slider-thumb{transform:scaleY(.92)}.app input[type=range]::-moz-range-track{height:2px!important;border:0!important;border-radius:0!important;background:var(--range-track)!important}.app input[type=range]::-moz-range-progress{height:2px!important;border-radius:0!important;background:var(--range-fill)!important}.app input[type=range]::-moz-range-thumb{width:8px!important;height:28px!important;border:0!important;border-radius:0!important;background:var(--primary)!important;box-shadow:none!important;cursor:pointer}
