*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,ui-sans-serif,system-ui,PingFang SC,Microsoft YaHei,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{color-scheme:light;--bg: #f4f5f7;--panel: #ffffff;--panel-2: #f9fafb;--line: #e5e7eb;--line-strong: #d1d5db;--text: #111827;--muted: #6b7280;--soft: #9ca3af;--primary: #4f46e5;--primary-2: #4338ca;--primary-soft: #eef2ff;--danger: #dc2626;--shadow: 0 16px 40px rgba(17, 24, 39, .1);font-family:Inter,ui-sans-serif,system-ui,PingFang SC,Microsoft YaHei,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0;color:var(--text);background:var(--bg);overflow:hidden}button,input,select{font:inherit}button{border:0}.app-shell{height:100%;display:flex;flex-direction:column;position:relative}.topbar{height:64px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 22px;background:#ffffffeb;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:20}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:38px;height:38px;display:grid;place-items:center;color:#fff;background:linear-gradient(135deg,#111827,#4f46e5);border-radius:10px;box-shadow:0 10px 22px #4f46e538}.brand strong,.brand h1{display:block;font-size:16px;letter-spacing:0}.brand span{display:block;margin-top:2px;font-size:12px;color:var(--muted)}.topbar-actions{display:flex;align-items:center;gap:10px}select,input[type=text],input:not([type]){height:36px;border:1px solid var(--line);background:#fff;color:var(--text);border-radius:8px;padding:0 10px;outline:none}select:focus,input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.primary-button,.secondary-button,.icon-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:36px;border-radius:9px;cursor:pointer;transition:.16s ease;white-space:nowrap}.primary-button{padding:0 15px;color:#fff;background:var(--primary);font-weight:650}.primary-button:hover{background:var(--primary-2);transform:translateY(-1px)}.primary-button:disabled{opacity:.7;cursor:wait}.secondary-button{padding:0 12px;background:#fff;color:var(--text);border:1px solid var(--line)}.secondary-button:hover,.icon-button:hover{border-color:var(--line-strong);background:var(--panel-2)}.secondary-button.full{width:100%}.icon-button{width:32px;height:32px;flex:0 0 auto;background:#fff;color:var(--muted);border:1px solid var(--line)}.workspace{min-height:0;flex:1;display:grid;grid-template-columns:360px minmax(0,1fr)}.sidebar{min-height:0;overflow:auto;padding:16px;background:#fff;border-right:1px solid var(--line)}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:#d1d5db;border:2px solid #fff;border-radius:99px}.panel{padding:15px;margin-bottom:12px;border:1px solid var(--line);border-radius:12px;background:var(--panel)}.panel-title{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:var(--text);font-size:14px;font-weight:700}.panel-title svg{color:var(--primary)}.upload-dropzone{position:relative;height:92px;display:grid;place-items:center;gap:6px;border:1px dashed #c7d2fe;border-radius:12px;color:var(--primary);background:linear-gradient(180deg,#f8faff,#fff);cursor:pointer}.upload-dropzone span{font-size:13px;color:var(--muted)}.upload-dropzone input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.asset-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.asset-thumb{position:relative;aspect-ratio:1;padding:0;overflow:hidden;border-radius:9px;background:#f3f4f6;border:1px solid var(--line);cursor:pointer}.asset-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.asset-thumb span{position:absolute;left:5px;bottom:5px;padding:2px 5px;color:#fff;background:#111827b8;border-radius:5px;font-size:10px}.asset-thumb i{position:absolute;right:4px;top:4px;width:20px;height:20px;display:grid;place-items:center;color:#fff;background:#111827b8;border-radius:99px;font-style:normal}.asset-thumb.is-used{border-color:#a5b4fc;box-shadow:0 0 0 2px var(--primary-soft)}.preset-group+.preset-group{margin-top:12px}.mini-label{margin:8px 0 7px;color:var(--muted);font-size:12px;font-weight:650}.ratio-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.ratio-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(54px,1fr));gap:8px}.ratio-tile{height:70px;display:grid;place-items:center;align-content:center;gap:3px;color:#6b7280;background:#fff;border:1px solid #d1d5db;border-radius:10px;cursor:pointer}.ratio-tile svg{width:28px;height:28px;color:#64748b}.ratio-tile span{font-size:11px;font-weight:650}.ratio-tile.active{color:var(--primary);border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 2px #4f46e51a}.ratio-card{display:grid;gap:2px;min-height:76px;padding:10px;text-align:left;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:10px;cursor:pointer}.ratio-card strong{font-size:18px;line-height:1}.ratio-card span{font-size:12px;font-weight:650}.ratio-card small{color:var(--muted);font-size:11px}.ratio-card.active,.template-card.active{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 2px #4f46e514}.template-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.template-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr))}.template-card{padding:7px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;color:var(--text)}.template-card svg{width:100%;display:block;margin-bottom:6px}.template-card span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.panel-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px;color:var(--muted);font-size:12px}.panel-toolbar button{color:var(--primary);background:transparent;cursor:pointer;font-size:12px;font-weight:650}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;padding:24px;background:#1118276b}.template-modal{width:min(760px,96vw);max-height:min(760px,88vh);overflow:auto;padding:18px;background:#fff;border-radius:16px;box-shadow:0 24px 70px #11182747}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-bottom:12px;border-bottom:1px solid var(--line)}.modal-header strong,.modal-header span{display:block}.modal-header span{margin-top:3px;color:var(--muted);font-size:12px}.modal-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.segmented{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;padding:3px;gap:3px;margin-bottom:10px;background:#f3f4f6;border-radius:10px}.segmented button{height:30px;border-radius:8px;color:var(--muted);background:transparent;cursor:pointer}.segmented button.active{color:var(--text);background:#fff;box-shadow:0 1px 4px #11182714;font-weight:650}.color-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:8px 0}.color-row label{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:38px;padding:0 10px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:9px;font-size:12px}.select-row{display:grid;gap:6px;margin:9px 0;color:var(--muted);font-size:12px}.select-row select,.row-between select{width:100%}.watermark-select{padding-top:2px}input[type=color]{width:30px;height:26px;padding:0;border:0;background:transparent}.range-row{display:grid;grid-template-columns:58px minmax(0,1fr) 52px;align-items:center;gap:8px;margin-top:10px;color:var(--muted);font-size:12px}.range-row input{width:100%;accent-color:var(--primary)}.range-row strong{color:var(--text);font-size:12px;text-align:right}.swatches{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:12px}.swatches button{display:flex;align-items:center;gap:7px;height:34px;padding:0 8px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:9px;cursor:pointer;font-size:12px}.swatches i{width:18px;height:18px;flex:0 0 auto;border-radius:99px}.empty-note{padding:12px;color:var(--muted);background:#f9fafb;border:1px dashed var(--line);border-radius:10px;font-size:12px;line-height:1.55}.watermark-editor{margin-top:10px;padding:10px;border:1px solid var(--line);border-radius:10px;background:#f9fafb}.row-between{display:flex;align-items:center;gap:8px}.row-between input{width:100%}.watermark-textarea{width:100%;min-height:74px;resize:vertical;padding:8px 10px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:9px;outline:none;line-height:1.45}.watermark-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.watermark-text-options{display:grid;gap:4px;margin-top:9px}.watermark-text-options>label{display:grid;gap:6px;color:var(--muted);font-size:12px}.watermark-text-options select{width:100%}.position-grid{display:grid;grid-template-columns:repeat(3,22px);gap:5px;margin:10px 0}.position-grid button{width:22px;height:22px;border:1px solid var(--line-strong);border-radius:5px;background:#fff;cursor:pointer}.position-grid button.active{border-color:var(--primary);background:var(--primary)}.checkbox-label{justify-content:flex-start!important}.checkbox-label input{accent-color:var(--primary)}.preset-list{display:grid;gap:7px;margin-top:9px}.preset-item{display:grid;grid-template-columns:minmax(0,1fr) 32px;gap:7px}.preset-item>button:first-child{display:flex;align-items:center;gap:7px;height:32px;min-width:0;padding:0 9px;color:var(--text);background:#fff;border:1px solid var(--line);border-radius:8px;cursor:pointer;text-align:left}.canvas-area{min-width:0;min-height:0;position:relative;display:flex;flex-direction:column;background:linear-gradient(180deg,#ffffff9e,#fff0),radial-gradient(circle at 1px 1px,#d7dbe3 1px,transparent 0);background-size:auto,22px 22px}.canvas-meta{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;color:var(--muted);border-bottom:1px solid rgba(229,231,235,.78)}.canvas-meta strong{display:block;color:var(--text);font-size:14px}.canvas-meta span{display:block;margin-top:3px;font-size:12px}.canvas-meta small{font-size:12px}.stage-wrap{min-height:0;flex:1;display:grid;place-items:center;padding:32px;overflow:auto}.stage-card{position:relative;overflow:hidden;background:#fff;box-shadow:var(--shadow);transform-origin:top left}.stage-zoom-frame{display:block;flex:0 0 auto}.stage-card canvas{display:block}.selection-box{position:absolute;border:2px solid var(--primary);border-radius:2px;box-shadow:0 0 0 1px #ffffffbf inset;pointer-events:none}.image-float-toolbar{position:absolute;width:352px;padding:10px 12px 12px;color:#fff;background:#1f2937f0;border:1px solid rgba(255,255,255,.12);border-radius:12px;box-shadow:0 16px 36px #11182747;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:5}.canvas-zoom-control{position:absolute;right:22px;bottom:18px;z-index:12;min-width:238px;height:42px;display:grid;grid-template-columns:auto minmax(90px,1fr) 44px;align-items:center;gap:10px;padding:6px 12px;color:#111;border-radius:999px;background:#ffffffbd;box-shadow:inset 0 0 0 1px #00000014,inset 0 1px #ffffffc2,0 12px 28px #0000001f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.canvas-zoom-control span{color:#666;font-size:12px;font-weight:720}.canvas-zoom-control strong{font-size:12px;text-align:right}.canvas-zoom-control input[type=range]{width:100%;height:18px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer}.canvas-zoom-control input[type=range]::-webkit-slider-runnable-track{height:12px;border-radius:999px;background:#00000014;box-shadow:inset 0 1px 2px #00000014}.canvas-zoom-control input[type=range]::-webkit-slider-thumb{width:16px;height:16px;margin-top:-2px;border:0;border-radius:999px;background:#111;box-shadow:0 2px 6px #0000003d;-moz-appearance:none;appearance:none;-webkit-appearance:none}.canvas-zoom-control input[type=range]::-moz-range-track{height:12px;border:0;border-radius:999px;background:#00000014;box-shadow:inset 0 1px 2px #00000014}.canvas-zoom-control input[type=range]::-moz-range-thumb{width:16px;height:16px;border:0;border-radius:999px;background:#111;box-shadow:0 2px 6px #0000003d}.toolbar-head{display:flex;align-items:center;gap:7px;margin-bottom:8px;font-size:12px}.toolbar-head span{flex:1;font-weight:650}.mini-segmented{display:flex;padding:2px;gap:2px;background:#ffffff1f;border-radius:8px}.mini-segmented button{height:24px;padding:0 8px;color:#ffffffb8;background:transparent;border-radius:6px;cursor:pointer;font-size:11px}.mini-segmented button.active{color:#111827;background:#fff}.float-range{display:grid;grid-template-columns:40px minmax(0,1fr) 48px;align-items:center;gap:8px;margin-top:7px;font-size:11px}.float-range input{width:100%;accent-color:#a5b4fc}.float-range strong{text-align:right}.watermark-add-button{margin-top:8px}.watermark-upload{position:relative;min-height:48px;width:100%;display:flex;align-items:center;gap:9px;padding:8px;color:var(--muted);background:#fff;border:1px dashed #c7d2fe;border-radius:9px;overflow:hidden}.watermark-upload img{width:34px;height:34px;-o-object-fit:cover;object-fit:cover;border-radius:7px}.watermark-upload span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.watermark-upload input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}@media(max-width:980px){body{overflow:auto}#root{min-height:100%;height:auto}.app-shell{min-height:100vh;height:auto}.topbar{position:sticky;top:0}.workspace{display:flex;flex-direction:column-reverse}.sidebar{border-right:0;border-top:1px solid var(--line);max-height:none;overflow:visible}.canvas-area{min-height:72vh}.canvas-meta{padding:0 16px}.canvas-meta small{display:none}}@media(max-width:560px){.topbar{height:auto;align-items:flex-start;gap:12px;padding:12px;flex-direction:column}.topbar-actions{width:100%}.topbar-actions select,.topbar-actions button{flex:1}.export-canvas-info{width:100%;min-width:0}.sidebar{padding:10px}.ratio-grid,.template-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.stage-wrap{padding:18px}}:root{--bg: #d9d9d9;--panel: rgba(244, 244, 244, .92);--panel-2: #e8e8e8;--line: rgba(0, 0, 0, .08);--line-strong: rgba(0, 0, 0, .16);--text: #111111;--muted: #6f6f6f;--soft: #9a9a9a;--primary: #111111;--primary-2: #000000;--primary-soft: rgba(17, 17, 17, .08);--shadow: 0 24px 70px rgba(0, 0, 0, .16)}body{background:var(--bg)}.topbar{height:56px;position:absolute;inset:0 0 auto 0;padding:6px 7px;background:transparent;border-bottom:0;box-shadow:none;pointer-events:none}.topbar .brand,.topbar .topbar-actions{pointer-events:auto}.brand{width:304px;flex:0 0 304px;min-height:44px;padding:6px 12px 6px 8px;gap:9px;background:linear-gradient(135deg,#ffffffd1,#ffffff8f),radial-gradient(circle at 0% 0%,rgba(94,78,255,.18),transparent 46%);border-radius:18px;box-shadow:inset 0 0 0 1px #ffffffb8,0 10px 24px #1d233014;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand-mark{width:32px;height:32px;color:#fff;background:radial-gradient(circle at 32% 20%,rgba(255,255,255,.3),transparent 28%),linear-gradient(135deg,#111,#5046e6 52%,#1ab6ff);border-radius:10px;box-shadow:0 8px 18px #0000002e}.brand strong,.brand h1{font-size:15px;line-height:1.05;margin:0}.brand span{margin-top:1px;font-size:11px}.topbar-actions{min-height:44px;padding:4px;gap:6px;background:linear-gradient(135deg,#ffffffdb,#ffffff8f),radial-gradient(circle at 100% 0%,rgba(26,182,255,.16),transparent 42%);border-radius:18px;box-shadow:inset 0 0 0 1px #ffffffc7,0 12px 28px #1d233017;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.export-canvas-info{min-width:190px;height:34px;display:grid;align-content:center;padding:0 12px;border-radius:13px;background:#ffffffbd;box-shadow:inset 0 0 0 1px #0000000f,inset 0 1px #ffffffd1}.export-canvas-info strong,.export-canvas-info span{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-canvas-info strong{color:#111;font-size:12px;font-weight:820;line-height:1.1}.export-canvas-info span{margin-top:2px;color:#62666f;font-size:10px;font-weight:650;line-height:1.1}.topbar-actions select{height:34px;border:0;border-radius:12px;background:#ffffffeb;box-shadow:inset 0 0 0 1px #00000014}.primary-button{height:34px;padding:0 14px;color:#fff;background:radial-gradient(circle at 30% 10%,rgba(255,255,255,.22),transparent 30%),linear-gradient(135deg,#111,#1d1d23 58%,#34314b);border-radius:12px;box-shadow:0 8px 20px #00000029}.primary-button:hover{background:#000}.workspace{grid-template-columns:304px minmax(0,1fr);background:#d9d9d9}.sidebar{margin:0 0 7px 7px;padding:64px 8px 8px;background:#eeeeeef0;border:0;border-radius:18px;box-shadow:inset 0 0 0 1px #ffffff9e,0 14px 36px #0000000f}.sidebar::-webkit-scrollbar{width:0;height:0;display:none}.sidebar{scrollbar-width:none;-ms-overflow-style:none}.panel{padding:8px;margin-bottom:10px;border:0;border-radius:15px;background:transparent}.panel-title{gap:7px;margin:2px 2px 9px;color:#626262;font-size:11px;font-weight:750;letter-spacing:.04em;text-transform:uppercase}.panel-title svg{width:14px;height:14px;color:#111}.upload-dropzone{height:90px;gap:7px;color:#111;border:0;border-radius:12px;background:#ffffff8f;box-shadow:inset 0 0 0 1px #0000000f,inset 0 1px #ffffffb8}.upload-dropzone svg{width:18px;height:18px}.upload-dropzone span{font-size:12px;color:#777}.asset-grid{grid-template-columns:repeat(4,1fr);gap:7px}.asset-thumb{border:0;border-radius:10px;background:#ddd;box-shadow:inset 0 0 0 1px #00000014}.asset-thumb[draggable=true]{cursor:grab}.asset-thumb[draggable=true]:active{cursor:grabbing}.asset-thumb.is-dragging{opacity:.42;transform:scale(.94) rotate(-2deg)}.asset-drag-preview{position:fixed;left:-9999px;top:-9999px;width:86px;height:86px;padding:0;overflow:hidden;border:0;border-radius:14px;background:#ddd;box-shadow:0 18px 42px #0000004d,0 0 0 3px #ffffffdb;transform:rotate(-4deg) scale(1.06);pointer-events:none}.asset-drag-preview img{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover}.asset-thumb.is-used{box-shadow:inset 0 0 0 2px #111,0 6px 14px #0000001a}.asset-thumb span{left:4px;bottom:4px;background:#0000009e;border-radius:6px}.asset-thumb i{right:4px;top:4px;background:#0000009e}.ratio-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.ratio-tile{height:68px;color:#404040;background:#ffffff9e;border:0;border-radius:13px;box-shadow:inset 0 0 0 1px #0000001a,inset 0 1px #ffffff9e}.ratio-tile svg{color:#2b2b2b}.ratio-tile.active{color:#fff;background:#111;box-shadow:inset 0 0 0 1px #ffffff29,0 10px 22px #0000002e}.ratio-tile.active svg{color:#fff}.panel-toolbar{margin:0 2px 9px;font-size:11px}.panel-toolbar button{color:#111;background:#ffffff94;border-radius:999px;padding:4px 8px}.template-grid,.template-grid.compact{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px}.template-card{padding:5px;border:0;border-radius:0;background:#ffffff94;box-shadow:inset 0 0 0 1px #00000017,inset 0 1px #ffffffb3}.template-card svg{margin-bottom:4px;overflow:visible;filter:none}.template-card span{font-size:11px;color:#202020}.template-card.active{background:#fff;box-shadow:inset 0 0 0 2px #111111d9,0 10px 24px #0000001f}.segmented{height:40px;padding:4px;background:#0000000e;border-radius:999px}.segmented button{height:32px;border-radius:999px}.segmented button.active{color:#111;background:#ffffffd6}.secondary-button{height:36px;color:#111;background:#ffffffa8;border:0;border-radius:12px;box-shadow:inset 0 0 0 1px #00000014,inset 0 1px #ffffffc2}.icon-button{color:#111;background:#ffffffb3;border:0;border-radius:999px;box-shadow:inset 0 0 0 1px #00000014}.secondary-button:hover,.icon-button:hover{background:#fff;transform:translateY(-1px)}.color-row{gap:8px}.color-row label,.select-row select,.row-between select,.watermark-textarea,select,input[type=text],input:not([type]){border:0;border-radius:12px;background:#ffffffad;box-shadow:inset 0 0 0 1px #00000014,inset 0 1px #ffffffb8}.color-row label{min-height:36px;padding:0 9px}.range-row{grid-template-columns:54px minmax(0,1fr) 46px;margin-top:9px;color:#666}.range-row input,.float-range input{accent-color:#111}.range-row input[type=range],.float-range input[type=range]{height:18px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer}.range-row input[type=range]::-webkit-slider-runnable-track,.float-range input[type=range]::-webkit-slider-runnable-track{height:14px;border-radius:999px;background:#ffffffe0;box-shadow:inset 0 0 0 1px #0000000d,inset 0 1px #ffffffd1}.range-row input[type=range]::-webkit-slider-thumb,.float-range input[type=range]::-webkit-slider-thumb{width:16px;height:16px;margin-top:-1px;border:0;border-radius:999px;background:#111;box-shadow:0 2px 5px #0000003d;-moz-appearance:none;appearance:none;-webkit-appearance:none}.range-row input[type=range]::-moz-range-track,.float-range input[type=range]::-moz-range-track{height:14px;border:0;border-radius:999px;background:#ffffffe0;box-shadow:inset 0 0 0 1px #0000000d,inset 0 1px #ffffffd1}.range-row input[type=range]::-moz-range-thumb,.float-range input[type=range]::-moz-range-thumb{width:16px;height:16px;border:0;border-radius:999px;background:#111;box-shadow:0 2px 5px #0000003d}.swatches{grid-template-columns:repeat(2,1fr);gap:7px}.swatches button{height:34px;border:0;border-radius:12px;background:#ffffff9e;box-shadow:inset 0 0 0 1px #00000014}.empty-note{color:#757575;background:#ffffff6b;border:0;border-radius:12px;box-shadow:inset 0 0 0 1px #0000000f}.watermark-editor{padding:9px;border:0;border-radius:14px;background:#ffffff5c;box-shadow:inset 0 0 0 1px #0000000f}.watermark-upload{background:#ffffffad;border:0;border-radius:12px;box-shadow:inset 0 0 0 1px #00000014}.position-grid{grid-template-columns:repeat(3,24px)}.position-grid button{width:24px;height:24px;border:0;border-radius:7px;background:#ffffffad;box-shadow:inset 0 0 0 1px #0000001a}.position-grid button.active{background:#111;box-shadow:none}.preset-item>button:first-child{height:34px;border:0;border-radius:12px;background:#ffffff9e;box-shadow:inset 0 0 0 1px #00000014}.canvas-area{background:radial-gradient(circle at 50% 46%,#ffffffdb 0,#ffffffdb 22%,#e9e9e994 52%,#cacacab8),linear-gradient(rgba(0,0,0,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.018) 1px,transparent 1px),#d7d7d7;background-size:auto,36px 36px,36px 36px,auto}.canvas-meta{height:56px;justify-content:flex-end;padding:0 28px;border-bottom:0}.canvas-meta strong{display:none;font-size:13px}.canvas-meta span{display:none}.canvas-meta small{color:#6e6e6e;font-size:11px}.stage-wrap{padding:28px 34px 40px;background:transparent}.stage-card{border-radius:0;box-shadow:var(--shadow)}.selection-box{border:2px solid #111;box-shadow:0 0 0 1px #ffffffe0 inset}.image-float-toolbar{background:#121212eb;border:0;border-radius:14px}.template-modal{background:#f4f4f4f5;border-radius:22px;box-shadow:0 28px 90px #00000057;scrollbar-width:none;-ms-overflow-style:none}.template-modal::-webkit-scrollbar{width:0;height:0;display:none}.template-modal .modal-header{padding-bottom:10px}.template-modal .preset-group+.preset-group{margin-top:14px}.template-modal .mini-label{margin:7px 0 8px;font-size:12px;font-weight:760}.template-grid.modal-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.template-grid.modal-grid .template-card{padding:5px;border-radius:0}.template-grid.modal-grid .template-card svg{margin-bottom:5px}.template-grid.modal-grid .template-card span{font-size:12px;font-weight:650}.background-presets{display:grid;gap:11px}.background-section-title{margin:0 0 6px;color:#111;font-size:13px;font-weight:720}.background-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.background-swatch{position:relative;aspect-ratio:1.38;padding:0;border:0;border-radius:10px;background:#ffffff5c;cursor:pointer;box-shadow:inset 0 0 0 1px #00000017,inset 0 1px #fff9;overflow:hidden}.background-swatch>span{position:absolute;top:2px;right:2px;bottom:2px;left:2px;display:grid;place-items:center;color:#fff;border-radius:8px;background-position:center;background-size:cover;box-shadow:inset 0 0 0 1px #00000014,0 6px 14px #0000001a}.background-more>span{background:linear-gradient(135deg,#ffffff1f,#00000057),#34383e}.background-more svg{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.background-tools{position:relative;display:grid;grid-template-columns:repeat(2,1fr);gap:7px;margin:11px 0 2px}.background-tools>button{height:38px;display:inline-flex;align-items:center;justify-content:center;gap:7px;color:#111;border-radius:12px;background:#ffffffa3;box-shadow:inset 0 0 0 1px #00000014,inset 0 1px #ffffffc2;cursor:pointer;font-size:12px;font-weight:720}.background-tools>button.active{color:#fff;background:#111}.background-side-popover{position:fixed;left:318px;top:272px;z-index:60;width:260px;padding:14px;border-radius:18px;background:#f4f4f4fa;box-shadow:inset 0 0 0 1px #ffffffb3,0 24px 60px #00000038}.popover-title{margin-bottom:12px;color:#111;font-size:18px;font-weight:760}.background-upload-drop{position:relative;min-height:164px;display:grid;place-items:center;align-content:center;gap:7px;color:#111;border:1px dashed rgba(0,0,0,.32);border-radius:12px;background:#ffffff57;cursor:pointer;overflow:hidden}.background-upload-drop strong{font-size:16px}.background-upload-drop span{color:#777;font-size:12px}.background-upload-drop input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.unsplash-popover{top:234px;width:292px}.unsplash-search{height:38px;display:grid;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:7px;padding:0 10px;color:#7b7b7b;border-radius:11px;background:#ffffff9e}.unsplash-search input{width:100%;height:100%;padding:0;border:0;background:transparent;box-shadow:none;font-size:14px}.unsplash-chips{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin:16px 0 13px}.unsplash-chips button{height:32px;padding:0 12px;color:#111;border-radius:999px;background:#ffffff8f;cursor:pointer;font-size:13px}.unsplash-result-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-height:250px;overflow:auto;scrollbar-width:none;-ms-overflow-style:none}.unsplash-result-grid::-webkit-scrollbar{width:0;height:0;display:none}.unsplash-result-grid button{aspect-ratio:1.15;padding:0;border-radius:10px;background:#ddd;overflow:hidden;cursor:pointer;box-shadow:inset 0 0 0 1px #00000014}.unsplash-result-grid img{width:100%;height:100%;display:block;-o-object-fit:cover;object-fit:cover}.unsplash-loading{margin-top:10px;color:#777;font-size:12px;text-align:center}.canvas-preset-trigger{position:relative;width:100%;min-height:50px;display:grid;grid-template-columns:36px minmax(0,1fr) 20px;align-items:center;gap:10px;padding:8px 10px;color:#111;text-align:left;border-radius:14px;background:#ffffffa8;box-shadow:inset 0 0 0 1px #00000012,inset 0 1px #ffffffbd;cursor:pointer}.canvas-preset-trigger:hover{background:#ffffffd1}.canvas-preset-chip{width:36px;height:30px;border-radius:9px;background:linear-gradient(135deg,#ffffff6b,#00000014),#d7dde5;box-shadow:inset 0 0 0 1px #0000001a,0 6px 14px #0000001a}.canvas-preset-copy{min-width:0;display:grid;gap:2px}.canvas-preset-copy strong,.canvas-preset-copy small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.canvas-preset-copy strong{color:#111;font-size:13px;font-weight:760}.canvas-preset-copy small{color:#777;font-size:11px;font-weight:650}.canvas-preset-popover{position:relative;z-index:10;margin-top:8px;max-height:520px;overflow:auto;padding:9px;border-radius:16px;background:#f7f7f7fa;box-shadow:inset 0 0 0 1px #ffffffb8,0 18px 45px #00000029;scrollbar-width:none;-ms-overflow-style:none}.canvas-preset-popover::-webkit-scrollbar{width:0;height:0;display:none}.canvas-size-row{display:grid;grid-template-columns:repeat(2,1fr);gap:7px;margin-bottom:10px}.canvas-size-row>div{min-height:42px;display:grid;align-content:center;gap:2px;padding:7px 10px;border-radius:12px;background:#fff;box-shadow:inset 0 0 0 1px #00000012}.canvas-size-row span{color:#8a8a8a;font-size:10px;font-weight:800;line-height:1}.canvas-size-row strong{color:#111;font-size:13px;line-height:1.1}.canvas-preset-section+.canvas-preset-section{margin-top:11px}.canvas-preset-section-title{display:flex;align-items:center;gap:6px;margin:0 0 7px;color:#5d5d5d;font-size:11px;font-weight:820}.canvas-preset-section-title span{width:16px;height:16px;display:inline-grid;place-items:center;border-radius:999px;background:#fff;font-size:10px;box-shadow:inset 0 0 0 1px #00000012}.canvas-preset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.canvas-ratio-option{min-width:0;min-height:78px;display:grid;grid-template-rows:26px auto auto;justify-items:center;gap:3px;padding:8px 6px;color:#222;border-radius:13px;background:#fff;box-shadow:inset 0 0 0 1px #00000012,0 5px 12px #0000000a;cursor:pointer}.canvas-ratio-option:hover{transform:translateY(-1px);box-shadow:inset 0 0 0 1px #0000001a,0 9px 18px #00000014}.canvas-ratio-option.active{color:#fff;background:#111;box-shadow:0 12px 22px #0000002e}.canvas-ratio-option svg{width:26px;height:26px}.canvas-ratio-option span,.canvas-ratio-option small{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.canvas-ratio-option span{font-size:11px;font-weight:780}.canvas-ratio-option small{color:inherit;opacity:.62;font-size:10px;font-weight:760}@media(max-width:980px){body{overflow:auto}#root{min-height:100%;height:auto}.app-shell{min-height:100vh;height:auto}.topbar{position:sticky;top:0;z-index:30}.workspace{display:flex;flex-direction:column-reverse}.sidebar{margin:0 7px 7px;border-radius:18px;max-height:none;overflow:visible}.canvas-area{min-height:72vh}.canvas-meta{padding:0 16px}.canvas-meta small{display:none}}@media(max-width:560px){.topbar{height:auto;align-items:flex-start;gap:10px;padding:8px;flex-direction:column}.brand,.topbar-actions{width:100%;flex:initial}.topbar-actions select,.topbar-actions button{flex:1}.sidebar{padding:8px}.ratio-strip,.template-grid,.template-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr))}.stage-wrap{padding:18px}}
