:root{color:#171717;background:#eef1f5;font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,sans-serif}*{box-sizing:border-box}body{margin:0;min-width:320px}button,input,select,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr}.app-topbar{height:78px;padding:16px clamp(18px,4vw,44px);display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:12px;background:#ffffffe0;border-bottom:1px solid rgba(20,24,31,.08);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);position:sticky;top:0;z-index:5}.app-topbar h1{margin:0;font-size:26px;line-height:1.1;letter-spacing:0}.app-topbar p{margin:4px 0 0;color:#6b7280;font-size:13px}.ghost-button{width:44px;height:44px;border:0;background:transparent;font-size:42px;line-height:1;cursor:pointer}.preview-button,.primary-action{border:0;border-radius:8px;background:#a4000b;color:#fff;font-weight:700;cursor:pointer}.preview-button{min-width:86px;height:44px;font-size:18px}.workspace{width:min(100%,1320px);margin:0 auto;padding:24px;display:grid;grid-template-columns:minmax(360px,1fr) minmax(380px,520px);gap:24px;align-items:start}.preview-stage{min-height:calc(100vh - 126px);display:grid;justify-items:center;align-content:center;gap:16px;border-radius:10px;background:linear-gradient(180deg,#ffffffb8,#ffffff5c),#dfe4ea;padding:24px}.canvas-frame{width:min(100%,430px);max-height:min(72vh,760px);overflow:hidden;background:#f2eddf;box-shadow:0 18px 50px #1f293733}.preview-canvas{display:block;width:100%;height:100%}.editor-panel{max-height:calc(100vh - 126px);overflow:auto;border-radius:14px;background:#f7f7fb;padding:22px;box-shadow:0 18px 48px #1f29371f}.text-editor{display:grid;gap:10px;margin-bottom:18px;font-weight:700}.text-editor textarea{width:100%;min-height:168px;resize:vertical;border:1px solid #d5d9e2;border-radius:8px;padding:12px;line-height:1.65;background:#fff}.setting-row,.slider-row{display:grid;grid-template-columns:112px minmax(0,1fr);align-items:center;gap:14px;margin:16px 0}.setting-row>span,.slider-row>span{font-size:17px}.font-button{border:0;background:transparent;color:#fe0617;font-size:20px;text-align:right;cursor:pointer}.font-button span{margin-left:8px;font-size:32px;vertical-align:-2px}.icon-group,.segmented{display:flex;gap:12px;flex-wrap:wrap}.icon-group button,.segmented button{min-width:48px;height:38px;border:1px solid transparent;border-radius:8px;background:transparent;font-weight:800;cursor:pointer}.icon-group button{font-size:24px}.segmented button{min-width:66px;background:#e6e8ed;font-size:15px}.icon-group button.active,.segmented button.active{background:#6f55b5;color:#fff}.setting-row.compact select,.setting-row.compact input[type=number],.duration-control input[type=number]{width:100%;min-height:38px;border:1px solid #d5d9e2;border-radius:8px;padding:6px 10px;background:#fff}.duration-control{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center}.duration-control span{color:#fe0617;font-weight:700;text-align:right}.slider-row{grid-template-columns:112px minmax(100px,1fr) 42px}.slider-row input[type=range]{width:100%;accent-color:#008cf8}.slider-row strong{color:#fe0617;text-align:right;font-size:20px}.swatches{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.swatches input[type=color]{width:42px;height:42px;padding:0;border:0;border-radius:999px;overflow:hidden;background:transparent}.swatches button{width:42px;height:42px;border:2px solid transparent;border-radius:999px;cursor:pointer}.swatches button.active{border-color:#111;outline:3px solid #fff}.export-controls{width:min(100%,430px);display:grid;grid-template-columns:.8fr 1.2fr;gap:12px}.export-controls button{min-height:44px;border-radius:8px;font-weight:700}.secondary-action{border:1px solid #cfd5df;background:#fff;color:#1f2937}.export-controls button:disabled,.preview-button:disabled{opacity:.55;cursor:not-allowed}.export-status,.validation-message{grid-column:1 / -1}.export-status{display:grid;gap:8px;color:#4b5563}.export-status progress{width:100%}.validation-message{margin:0;color:#b42318}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;display:grid;align-items:end;background:#000000ad}.font-modal{width:min(100%,920px);max-height:min(76vh,780px);margin:0 auto;overflow:hidden;border-radius:18px 18px 0 0;background:#fff;padding:28px clamp(20px,4vw,44px) 36px}.font-modal header{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-bottom:22px}.font-modal h2{grid-column:2;margin:0;font-size:28px}.font-modal header button{grid-column:3;justify-self:end;border:0;background:transparent;font-size:46px;line-height:1;cursor:pointer}.font-grid{max-height:calc(min(76vh,780px) - 114px);overflow:auto;display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:16px 22px;padding-right:4px}.font-grid button{position:relative;min-height:56px;border:2px solid transparent;border-radius:8px;background:#dedede;color:#111;font-size:23px;cursor:pointer}.font-grid button.selected{border-color:#ff0015;background:#fff}.font-grid button span{position:absolute;right:4px;top:4px;width:17px;height:17px;border-radius:50%;background:#111;color:#fff;font-size:13px;line-height:17px}@media(max-width:980px){.workspace{grid-template-columns:1fr;padding:0;gap:0}.preview-stage{min-height:calc(100vh - 78px);border-radius:0;padding:22px 18px 390px}.canvas-frame{width:min(70vw,420px);max-height:62vh}.editor-panel{position:fixed;left:0;right:0;bottom:0;z-index:10;max-height:48vh;border-radius:18px 18px 0 0;padding:22px 22px 30px}}@media(max-width:640px){.app-topbar{height:68px;grid-template-columns:38px 1fr auto;padding:10px 16px}.app-topbar h1{font-size:22px}.app-topbar p{display:none}.preview-button{min-width:70px;height:38px;font-size:16px}.preview-stage{min-height:calc(100vh - 68px);padding-bottom:420px}.canvas-frame{width:min(74vw,360px)}.editor-panel{max-height:52vh;padding:18px 18px 28px}.setting-row,.slider-row{grid-template-columns:104px minmax(0,1fr);gap:10px}.slider-row{grid-template-columns:104px minmax(80px,1fr) 36px}.setting-row>span,.slider-row>span{font-size:16px}.font-button{font-size:18px}.font-grid{grid-template-columns:repeat(2,minmax(120px,1fr));gap:12px}.font-grid button{font-size:20px}}
