:root,[data-theme=dark]{--bg: #0a0a0c;--surface: #141518;--surface-2: #1a1c20;--surface-3: #23262b;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .15);--text: #e6e7ea;--text-dim: #8b8f98;--text-faint: #5f636c;--accent: #7c83f0;--accent-soft: rgba(124, 131, 240, .14);--on-accent: #ffffff;--ok: #4ec98a;--warn: #e6b450;--danger: #f06c6c;--stage: #0d0e11;--stage-2: #101216}[data-theme=light]{--bg: #f4f5f7;--surface: #ffffff;--surface-2: #f2f3f5;--surface-3: #e8eaee;--border: rgba(0, 0, 0, .1);--border-strong: rgba(0, 0, 0, .18);--text: #1b1d22;--text-dim: #5a5f6a;--text-faint: #8b909b;--accent: #5b63d8;--accent-soft: rgba(91, 99, 216, .12);--on-accent: #ffffff;--ok: #2e9e5b;--warn: #b07d12;--danger: #d64545;--stage: #e9ebef;--stage-2: #eef0f3}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:PingFang SC,Microsoft YaHei,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:14px;-webkit-font-smoothing:antialiased;accent-color:var(--accent)}.app{display:flex;height:100vh;overflow:hidden}.preview-area{flex:1;display:flex;flex-direction:column;min-width:0;padding:20px 24px;gap:16px}.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.app-header h1{margin:0;font-size:18px;font-weight:600;letter-spacing:.2px}.app-header p{margin:4px 0 0;color:var(--text-dim);font-size:12.5px}.preview-stage{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:14px;background:var(--stage);background-image:linear-gradient(0deg,var(--stage-2),var(--stage));border:1px solid var(--border)}.canvas-frame{position:relative;border-radius:10px;overflow:hidden;box-shadow:0 12px 40px #0006;outline:1px solid var(--border)}.preview-canvas{display:block}.frame-indicator{position:absolute;left:8px;bottom:8px;padding:3px 9px;font-size:11px;font-variant-numeric:tabular-nums;font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;color:#fff;background:#080a10a8;border:1px solid rgba(255,255,255,.1);border-radius:6px;backdrop-filter:blur(4px);pointer-events:none}.pivot-overlay{position:absolute;inset:0;cursor:crosshair}.pivot-marker{position:absolute;width:16px;height:16px;margin:-8px 0 0 -8px;border-radius:50%;border:2px solid #fff;background:#7c83f080;box-shadow:0 0 0 2px #00000080,0 0 12px #7c83f0e6;pointer-events:none}.pivot-marker:after{content:"";position:absolute;inset:5px;border-radius:50%;background:#fff}.toolbar{display:flex;flex-direction:column;gap:10px}.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}.status-bar{font-size:12.5px;color:var(--text-dim);padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:8px;min-height:34px;display:flex;align-items:center}.status-working{color:var(--accent)}.status-ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 35%,transparent)}.status-error{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,transparent)}.btn{font:inherit;font-size:13px;font-weight:500;padding:9px 16px;border-radius:8px;border:1px solid var(--border-strong);cursor:pointer;transition:all .15s ease;color:var(--text);background:var(--surface-2)}.btn:hover{border-color:var(--accent)}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent);border-color:transparent;color:var(--on-accent)}.btn-primary:hover:not(:disabled){filter:brightness(1.08)}.btn-primary:disabled{background:var(--surface-3);color:var(--text-faint)}.btn-ghost{background:transparent;border-color:var(--border-strong);color:var(--text-dim)}.btn-ghost.is-active{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.btn-soft{background:var(--surface-3)}.btn-soft.is-active{border-color:var(--accent);color:var(--accent)}.btn.full{width:100%;display:block}.btn.big{padding:12px;font-size:14px;margin-top:8px}.btn.danger:hover{border-color:var(--danger);color:var(--danger)}.link-btn{background:none;border:none;color:var(--text-dim);font:inherit;font-size:12px;cursor:pointer;padding:2px 4px;border-radius:5px}.link-btn:hover{color:var(--accent)}.settings{width:400px;flex-shrink:0;display:flex;flex-direction:column;background:var(--surface);border-left:1px solid var(--border)}.tabs{display:flex;padding:6px 8px 0;gap:2px;border-bottom:1px solid var(--border)}.tab-btn{flex:1;font:inherit;font-size:12.5px;font-weight:500;color:var(--text-dim);background:transparent;border:none;border-bottom:2px solid transparent;padding:10px 2px 11px;cursor:pointer;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--text)}.tab-btn.is-active{color:var(--accent);border-bottom-color:var(--accent)}.tab-content{flex:1;overflow-y:auto;padding:18px}.tab-content::-webkit-scrollbar{width:9px}.tab-content::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:6px}.panel{display:flex;flex-direction:column;gap:4px;animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.group-title{font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--text-faint);margin:16px 0 8px}.group-title:first-child{margin-top:2px}.section-head{display:flex;align-items:center;justify-content:space-between}.section-head .group-title{margin:16px 0 8px}.section-actions{display:flex;gap:8px}.help-text{font-size:11.5px;line-height:1.6;color:var(--text-faint);margin:8px 0 4px}.help-text b{color:var(--text-dim)}.warn-text{font-size:11.5px;line-height:1.55;color:var(--warn);background:color-mix(in srgb,var(--warn) 12%,transparent);border:1px solid color-mix(in srgb,var(--warn) 32%,transparent);border-radius:7px;padding:7px 9px;margin:4px 0 2px}.readonly-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-dim);padding:7px 10px;background:var(--surface-2);border:1px dashed var(--border-strong);border-radius:7px;margin-top:6px}.readonly-row b{color:var(--accent);font-variant-numeric:tabular-nums}.field-row{display:flex;align-items:center;gap:10px;padding:5px 0}.field-label{width:76px;flex-shrink:0;font-size:12.5px;color:var(--text-dim)}.field-row input[type=range]{flex:1;height:4px;min-width:0}.field-value{width:50px;text-align:right;font-size:12.5px;font-variant-numeric:tabular-nums;color:var(--text)}.field-value.is-warn{color:var(--warn);font-weight:600}.text-input,.select-input{flex:1;min-width:0;font:inherit;font-size:13px;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:7px;padding:7px 10px;transition:border-color .15s}.text-input:focus,.select-input:focus{outline:none;border-color:var(--accent)}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:3px;gap:2px}.seg-btn{font:inherit;font-size:12px;font-weight:500;color:var(--text-dim);background:transparent;border:none;border-radius:6px;padding:5px 13px;cursor:pointer;transition:all .15s}.seg-btn:hover{color:var(--text)}.seg-btn.is-active{background:var(--accent);color:var(--on-accent)}.switch{width:40px;height:22px;border-radius:12px;border:1px solid var(--border-strong);background:var(--surface-3);position:relative;cursor:pointer;transition:background .15s,border-color .15s}.switch.on{background:var(--accent);border-color:transparent}.switch-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s;box-shadow:0 1px 3px #0000004d}.switch.on .switch-knob{transform:translate(18px)}.collapsible{margin-top:14px;border:1px solid var(--border);border-radius:8px;overflow:hidden}.collapsible-header{width:100%;display:flex;justify-content:space-between;align-items:center;font:inherit;font-size:12.5px;font-weight:500;color:var(--text-dim);background:var(--surface-2);border:none;padding:11px 13px;cursor:pointer}.collapsible-header .chev{transition:transform .2s}.collapsible.open .collapsible-header .chev{transform:rotate(180deg)}.collapsible-body{padding:8px 13px 13px;border-top:1px solid var(--border)}.swatch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.bg-swatch{position:relative;height:50px;border-radius:8px;border:2px solid transparent;cursor:pointer;overflow:hidden;transition:transform .15s,box-shadow .15s}.bg-swatch:hover{transform:translateY(-2px)}.bg-swatch.is-active{border-color:#fff;box-shadow:0 0 0 2px var(--accent)}.bg-swatch span{position:absolute;left:0;right:0;bottom:0;font-size:11px;font-weight:500;color:#fff;text-align:center;padding:3px 0;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent)}.inline-upload{margin-top:8px}.bg-gradient-preview{height:90px;border-radius:8px;border:1px solid var(--border-strong);margin:14px 0 10px}.bg-control{padding:6px 0}.bg-control-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}.bg-control-head span{font-size:12.5px;color:var(--text-dim)}.bg-control-head b{font-size:12px;color:var(--text);font-variant-numeric:tabular-nums}.bg-hue-wrap{position:relative;height:18px}.bg-hue-rainbow{position:absolute;inset:2px 0;border-radius:7px;background:linear-gradient(to right,#ee2b2b,#eeee2b,#2bee2b,#2beeee,#2b2bee,#ee2bee,#ee2b2b);pointer-events:none}.bg-hue-wrap input{position:absolute;inset:0;width:100%;height:18px;margin:0;cursor:pointer;background:transparent;appearance:none;-webkit-appearance:none}.bg-hue-wrap input::-webkit-slider-thumb,.bg-lightness-range::-webkit-slider-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--text);box-shadow:0 1px 4px #00000059;appearance:none;-webkit-appearance:none}.bg-hue-wrap input::-moz-range-thumb,.bg-lightness-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;border:2px solid var(--text);box-shadow:0 1px 4px #00000059}.bg-lightness-range{width:100%;height:5px;margin:0;cursor:pointer;appearance:none;-webkit-appearance:none;border-radius:8px;background:linear-gradient(to right,#5f636c 0 15%,var(--ok) 15% 69%,var(--warn) 69% 85%,var(--danger) 85% 100%)}.risk-bar{position:relative;display:grid;grid-template-columns:15fr 54fr 16fr 15fr;gap:2px;height:4px;margin-top:8px}.risk-bar span{border-radius:6px;opacity:.65}.risk-weak{background:var(--text-faint)}.risk-safe{background:var(--ok)}.risk-strong{background:var(--warn)}.risk-danger{background:var(--danger)}.risk-bar i{position:absolute;top:50%;width:6px;height:10px;border-radius:3px;background:var(--text);transform:translate(-50%,-50%)}.risk-label{margin-top:5px;font-size:11.5px;color:var(--text-dim)}.risk-label.is-safe{color:var(--ok)}.risk-label.is-strong{color:var(--warn)}.risk-label.is-danger{color:var(--danger)}.hue-preset-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.hue-preset{height:32px;border:1px solid var(--border-strong);border-radius:6px;cursor:pointer;padding:0;transition:transform .12s,box-shadow .12s}.hue-preset:hover{transform:translateY(-2px)}.hue-preset.is-active{box-shadow:0 0 0 2px var(--accent);border-color:transparent}.direction-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:5px}.direction-btn{min-height:32px;border:1px solid var(--border-strong);border-radius:7px;background:transparent;color:var(--text-dim);font:inherit;font-size:11.5px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.direction-btn:hover{color:var(--text);border-color:var(--accent)}.direction-btn.is-active{background:var(--accent);color:var(--on-accent);border-color:transparent}.bg-mid-display{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin:8px 0 4px}.bg-mid-cell{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:7px;min-width:0}.bg-mid-cell span{display:block;font-size:10.5px;color:var(--text-faint);margin-bottom:5px}.bg-mid-cell i{display:block;height:24px;border-radius:5px;border:1px solid var(--border-strong);margin-bottom:5px}.bg-mid-cell b{display:block;font-family:ui-monospace,Menlo,monospace;font-size:10.5px;color:var(--text-dim);font-weight:400;overflow:hidden;text-overflow:ellipsis}.mono-input{font-family:ui-monospace,Menlo,monospace}.angle-row{display:flex;align-items:center;gap:14px;margin:12px 0 2px}.angle-dial{position:relative;width:86px;height:86px;border-radius:50%;border:1px solid var(--border-strong);background:radial-gradient(circle,var(--surface-2),var(--surface));cursor:pointer;padding:0;flex-shrink:0}.angle-dial:before{content:"";position:absolute;inset:10px;border-radius:50%;border:1px dashed var(--border-strong)}.angle-hand{position:absolute;left:50%;bottom:50%;width:2px;height:34px;background:var(--accent);transform-origin:50% 100%;border-radius:2px}.angle-knob{position:absolute;width:12px;height:12px;margin:-6px 0 0 -6px;border-radius:50%;background:#fff;border:2px solid var(--accent);box-shadow:0 1px 4px #00000059}.angle-value{display:flex;flex-direction:column;gap:5px}.angle-value span{font-size:12px;color:var(--text-dim)}.angle-value b{font-size:18px;font-variant-numeric:tabular-nums}.color-pop-row{position:relative;display:flex;align-items:center;gap:10px;padding:5px 0}.color-pop-swatch{width:34px;height:28px;flex-shrink:0;border:1px solid var(--border-strong);border-radius:7px;cursor:pointer;padding:0}.color-pop-panel{position:absolute;z-index:20;top:38px;left:86px;width:220px;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:0 12px 28px #00000059}.color-pop-panel .react-colorful{width:100%;height:160px}.color-pop-panel .react-colorful__saturation{border-radius:7px 7px 0 0}.color-pop-panel .react-colorful__hue{height:14px;margin-top:7px;border-radius:7px}.text-color-editor{display:flex;flex-direction:column;gap:8px}.text-color-presets{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.text-color-preset{height:28px;border-radius:6px;border:1px solid var(--border-strong);cursor:pointer;padding:0}.text-color-preset:hover{transform:translateY(-1px);border-color:var(--accent)}.fill-editor{display:flex;flex-direction:column;gap:10px;margin-top:8px}.fill-stops{display:flex;gap:8px}.stop-chip{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-size:12px;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:7px;padding:7px;cursor:pointer}.stop-chip.is-active{border-color:var(--accent);color:var(--text)}.stop-dot{width:14px;height:14px;border-radius:4px;border:1px solid var(--border-strong)}.picker-wrap .react-colorful{width:100%;height:150px}.picker-wrap .react-colorful__saturation{border-radius:8px 8px 0 0}.picker-wrap .react-colorful__hue{height:16px;margin-top:6px;border-radius:6px}.picker-wrap .react-colorful__saturation-pointer,.picker-wrap .react-colorful__hue-pointer{width:16px;height:16px}.fill-row{display:flex;align-items:center;gap:10px}.hex-input{flex:1;min-width:0;font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:7px;padding:7px 10px}.hex-input:focus{outline:none;border-color:var(--accent)}.swatch-row{display:grid;grid-template-columns:repeat(9,1fr);gap:5px}.mini-swatch{aspect-ratio:1;border-radius:5px;border:1px solid var(--border-strong);cursor:pointer;padding:0}.mini-swatch:hover{transform:scale(1.12)}.gradient-preview{height:30px;border-radius:7px;border:1px solid var(--border-strong)}.css-readout{font-family:ui-monospace,Menlo,monospace;font-size:11px;line-height:1.5;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border);border-radius:7px;padding:8px 10px;word-break:break-all}.column-cards{display:flex;flex-direction:column;gap:12px;margin-top:8px}.column-card{background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:12px 14px}.column-card-title{font-size:12.5px;font-weight:600;color:var(--accent);margin-bottom:6px}.posters-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:6px}.fill-indicator{flex:1;font-size:12.5px;font-weight:500}.fill-indicator.is-ok{color:var(--ok)}.fill-indicator.is-warn{color:var(--text-dim)}.fill-indicator em{color:var(--danger);font-style:normal;font-weight:600}.poster-columns{display:flex;flex-direction:column;gap:16px;margin-top:10px}.poster-col-title{font-size:12px;font-weight:600;color:var(--text-dim);margin-bottom:8px}.poster-col-title span{color:var(--text-faint);font-weight:400}.poster-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,80px);gap:8px}.poster-slot{position:relative;width:80px;height:120px;border-radius:8px;overflow:hidden;cursor:pointer;transition:transform .12s,border-color .12s}.poster-slot.is-empty{border:1.5px dashed var(--border-strong);background:var(--surface-2);display:flex;align-items:center;justify-content:center}.poster-slot.is-empty:hover{border-color:var(--accent);background:var(--accent-soft)}.poster-slot.is-filled{border:1.5px solid var(--border)}.poster-slot.is-filled:hover{border-color:var(--accent)}.poster-slot.is-drop{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.poster-slot img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none}.slot-empty-hint{display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-faint);font-size:12px;font-variant-numeric:tabular-nums}.slot-empty-hint em{font-size:22px;font-style:normal;line-height:1;color:var(--text-dim)}.slot-delete{position:absolute;top:4px;right:4px;width:20px;height:20px;border-radius:50%;border:none;background:#080a10b3;color:#fff;font-size:15px;line-height:1;cursor:pointer;opacity:0;transition:opacity .12s ease,background .12s ease}.poster-slot:hover .slot-delete{opacity:1}.slot-delete:hover{background:var(--danger)}@media (max-width: 900px){.app{flex-direction:column;height:auto;min-height:100vh}.settings{width:100%;border-left:none;border-top:1px solid var(--border)}.preview-stage{min-height:240px}}.num-box{width:64px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:flex-end;gap:2px}.num-input{width:46px;font:inherit;font-size:12px;text-align:right;color:var(--text);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:6px;padding:3px 5px;font-variant-numeric:tabular-nums}.num-input:focus{outline:none;border-color:var(--accent)}.num-input::-webkit-outer-spin-button,.num-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.num-box em{font-style:normal;font-size:11px;color:var(--text-faint)}.color-input{width:40px;height:26px;padding:0;border:1px solid var(--border-strong);border-radius:6px;background:var(--surface-2);cursor:pointer;flex-shrink:0}.color-input:disabled{opacity:.5;cursor:not-allowed}.color-input::-webkit-color-swatch-wrapper{padding:2px}.color-input::-webkit-color-swatch{border:none;border-radius:4px}.color-hex{flex:1;text-align:right;font-family:ui-monospace,Menlo,monospace;font-size:11.5px;color:var(--text-dim);font-variant-numeric:tabular-nums}.title-drag-overlay{position:absolute;inset:0;cursor:move;touch-action:none}
