:root{--ds-black: #171717;--ds-gray-600: #4d4d4d;--ds-gray-500: #666666;--ds-gray-400: #808080;--ds-gray-100: #ebebeb;--ds-gray-50: #fafafa;--ds-white: #ffffff;--ds-blue: #0a72ef;--ds-pink: #de1d8d;--ds-red: #ff5b4f;--ds-focus: hsla(212, 100%, 48%, 1);--ds-ring: rgb(235 235 235) 0 0 0 1px;--ds-border: rgb(0 0 0 / 8%) 0 0 0 1px;--ds-card: rgb(0 0 0 / 8%) 0 0 0 1px, rgb(0 0 0 / 4%) 0 2px 2px, rgb(0 0 0 / 4%) 0 8px 8px -8px, #fafafa 0 0 0 1px;color:var(--ds-black);background:var(--ds-white);font-family:Geist,Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;font-feature-settings:"liga";font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;min-width:320px;overflow:hidden;background:var(--ds-white)}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:wait}.app-shell{height:100vh;min-height:0;display:flex;flex-direction:column;background:var(--ds-white)}.top-bar{height:64px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:32px;padding:0 24px;background:#ffffffeb;box-shadow:var(--ds-ring);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:2}.brand-block{min-width:0;display:flex;align-items:center;gap:12px}.brand-mark{width:34px;height:34px;display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;border-radius:7px;background:var(--ds-black);color:var(--ds-white);font-size:18px;font-weight:600;line-height:1;box-shadow:var(--ds-border)}.wordmark{min-width:0;display:inline-flex;align-items:center;gap:6px;margin:0;color:var(--ds-black);font-size:17px;font-weight:600;line-height:1.2;letter-spacing:0;white-space:nowrap}.wordmark-link{min-width:28px;height:19px;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;background:#ebf5ff;color:#0068d6;font-size:11px;font-weight:500;line-height:1}.top-bar p{margin:4px 0 0;overflow:hidden;color:var(--ds-gray-500);font-size:12px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.top-actions{display:flex;flex:0 0 auto;align-items:center;gap:8px}.icon-button,.text-button,.inline-action,.ai-prompt-actions button,.selected-decoration-heading button,.segmented-grid button,.option-grid button,.mode-row button,.size-row button,.align-row button,.template-card{border:0;outline:none;box-shadow:var(--ds-ring);transition:background-color .16s ease,color .16s ease,box-shadow .16s ease}.icon-button:hover,.text-button:hover,.inline-action:hover,.ai-prompt-actions button:hover,.selected-decoration-heading button:hover,.segmented-grid button:hover,.option-grid button:hover,.mode-row button:hover,.size-row button:hover,.align-row button:hover,.template-card:hover{background:var(--ds-gray-50);box-shadow:var(--ds-border),#0000000a 0 2px 2px}.icon-button:focus-visible,.text-button:focus-visible,.inline-action:focus-visible,.ai-prompt-actions button:focus-visible,.selected-decoration-heading button:focus-visible,.segmented-grid button:focus-visible,.option-grid button:focus-visible,.mode-row button:focus-visible,.size-row button:focus-visible,.align-row button:focus-visible,.template-card:focus-visible,textarea:focus-visible,input:focus-visible{outline:2px solid var(--ds-focus);outline-offset:2px}.icon-button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:6px;padding:0 14px;background:var(--ds-white);color:var(--ds-black);font-size:14px;font-weight:500;white-space:nowrap}.icon-button.primary{background:var(--ds-black);color:var(--ds-white);box-shadow:var(--ds-border)}.icon-button.primary:hover,.icon-button.primary:focus-visible{background:#000}.icon-button.ghost{width:38px;padding:0}.workspace{flex:1;height:calc(100vh - 64px);min-height:0;display:grid;grid-template-columns:344px minmax(380px,1fr) 316px;background:var(--ds-white)}.panel{height:100%;min-height:0;overflow:auto;overscroll-behavior:contain;background:var(--ds-white)}.controls-panel{padding:18px;box-shadow:#ebebeb -1px 0 inset}.template-panel{padding:18px;box-shadow:#ebebeb 1px 0 inset}.control-section{border-radius:8px}.control-section+.control-section{margin-top:18px;padding-top:18px;box-shadow:#ebebeb 0 -1px}.section-title,.panel-heading,.subsection-title{display:flex;align-items:center}.section-title{gap:8px;margin-bottom:12px;color:var(--ds-blue)}.panel-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.section-title h2,.panel-heading h2{margin:0;color:var(--ds-black);font-size:14px;font-weight:600;line-height:1.2;letter-spacing:0}.collapse-section{display:grid}.collapse-summary{margin-bottom:0;list-style:none;cursor:pointer;-webkit-user-select:none;user-select:none}.collapse-summary::-webkit-details-marker{display:none}.collapse-summary:after{content:"";width:8px;height:8px;margin-left:auto;border-right:1.5px solid var(--ds-gray-400);border-bottom:1.5px solid var(--ds-gray-400);transform:rotate(45deg) translateY(-2px);transition:transform .16s ease}.collapse-section[open] .collapse-summary:after{transform:rotate(225deg) translateY(-2px)}.collapse-body{margin-top:12px}.subsection-title{gap:7px;color:var(--ds-pink)}.subsection-title h3{margin:0;color:var(--ds-black);font-size:13px;font-weight:600;line-height:1.2}label{display:grid;gap:7px;color:var(--ds-gray-600);font-size:13px;font-weight:500}label+label{margin-top:10px}.field-label{display:flex;align-items:center;justify-content:space-between;gap:12px;color:var(--ds-gray-600);font-size:13px;font-weight:500}.field-label small{color:var(--ds-gray-400);font-size:11px;font-weight:500;white-space:nowrap}textarea,input{width:100%;border:0;border-radius:6px;background:var(--ds-white);color:var(--ds-black);padding:9px 11px;outline:none;box-shadow:var(--ds-ring);transition:background-color .16s ease,box-shadow .16s ease}textarea::placeholder,input::placeholder{color:var(--ds-gray-400);font-size:12px;line-height:1.5}textarea:hover,input:hover{background:var(--ds-gray-50)}textarea{height:112px;min-height:112px;resize:none;line-height:1.58}.segmented-grid,.option-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.segmented-grid button{min-height:54px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;border-radius:8px;background:var(--ds-white);padding:9px 10px;color:var(--ds-black);text-align:left}.segmented-grid span{font-size:13px;font-weight:500}.segmented-grid small{color:var(--ds-gray-500);font-size:11px;white-space:nowrap}.segmented-grid button.selected,.option-grid button.selected,.mode-row button.selected,.size-row button.selected,.align-row button.selected{background:#ebf5ff;color:#0068d6;box-shadow:#93c5fd 0 0 0 1px,#0a72ef14 0 2px 2px}.dimension-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.combo-group{display:grid;gap:8px}.combo-group+.combo-group{margin-top:14px}.option-grid button{width:100%;min-height:36px;border-radius:6px;background:var(--ds-white);color:var(--ds-black);padding:8px 10px;font-size:12px;font-weight:500;text-align:left}.option-item{position:relative;min-width:0;display:block}.option-item .option-delete{position:absolute;top:-6px;right:-6px;width:22px;height:22px;min-height:0;display:inline-flex;align-items:center;justify-content:center;border-radius:9999px;background:var(--ds-white);color:var(--ds-gray-500);padding:0;box-shadow:var(--ds-card)}.inline-action,.text-button{min-height:28px;display:inline-flex;align-items:center;gap:5px;border-radius:9999px;background:#ebf5ff;color:#0068d6;padding:0 10px;font-size:12px;font-weight:500}.ai-prompt-box,.selected-decoration{display:grid;gap:8px;border-radius:8px;background:var(--ds-white);padding:10px;box-shadow:var(--ds-card)}.ai-prompt-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ai-prompt-actions button{height:32px;border-radius:6px;background:var(--ds-white);color:var(--ds-black);font-size:12px;font-weight:500}.ai-prompt-actions button:last-child{background:var(--ds-black);color:var(--ds-white)}.ai-prompt-actions button:disabled{opacity:.68}.selected-decoration-list{display:grid;gap:10px;margin-top:10px}.selected-decoration-heading{display:flex;align-items:center;justify-content:space-between;gap:10px}.selected-decoration-heading strong{color:var(--ds-black);font-size:13px;font-weight:600}.selected-decoration-heading button{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:6px;background:var(--ds-white);color:var(--ds-gray-500)}.range-field{display:grid;gap:6px;color:var(--ds-gray-600);font-size:12px}.range-field span{display:flex;align-items:center;justify-content:space-between;gap:10px}.range-field small{color:var(--ds-gray-400);font-size:11px;font-weight:500}.range-field input{padding:0;box-shadow:none;accent-color:var(--ds-blue)}.size-row,.align-row,.mode-row{display:grid;gap:8px}.size-row{grid-template-columns:repeat(3,1fr)}.align-row{grid-template-columns:repeat(3,1fr);margin-top:12px}.mode-row{grid-template-columns:repeat(2,1fr)}.size-row button,.align-row button,.mode-row button{height:34px;border-radius:6px;background:var(--ds-white);color:var(--ds-black);font-size:12px;font-weight:500}.align-row button{display:flex;align-items:center;justify-content:center}.current-color{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;border-radius:8px;background:var(--ds-white);padding:8px 10px;color:var(--ds-gray-600);font-size:12px;box-shadow:var(--ds-ring)}.current-color span{width:24px;height:24px;border:2px solid var(--ds-white);border-radius:9999px;box-shadow:var(--ds-border)}.current-color strong{overflow:hidden;color:var(--ds-black);font-weight:500;text-overflow:ellipsis;white-space:nowrap}.color-row{display:grid;grid-template-columns:repeat(8,1fr);gap:7px}.color-dot{width:100%;aspect-ratio:1;min-width:0;border:2px solid var(--ds-white);border-radius:6px;box-shadow:var(--ds-ring);transition:box-shadow .16s ease}.color-dot:hover,.color-dot:focus-visible{outline:2px solid var(--ds-focus);outline-offset:2px}.color-dot.selected{box-shadow:var(--ds-black) 0 0 0 2px,#00000014 0 2px 2px}.field-hint{margin:8px 0 0;color:var(--ds-gray-500);font-size:12px;line-height:1.45}.error-text{color:#c92f36}.highlight-controls{display:grid;gap:8px;margin-top:12px}.preview-panel{position:relative;min-width:0;min-height:0;height:100%;display:flex;align-items:center;justify-content:center;padding:54px 34px 34px;background:linear-gradient(90deg,rgb(0 0 0 / 3%) 1px,transparent 1px),linear-gradient(0deg,rgb(0 0 0 / 3%) 1px,transparent 1px),var(--ds-gray-50);background-size:32px 32px;box-shadow:#ebebeb 1px 0 inset,#ebebeb -1px 0 inset}.preview-meta{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;gap:8px;border-radius:9999px;background:#ffffffdb;padding:7px 10px;color:var(--ds-gray-600);font-size:12px;box-shadow:var(--ds-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.preview-meta span{color:var(--ds-blue);font-weight:600}.preview-meta strong{color:var(--ds-black);font-weight:500}.canvas-stage{width:min(100%,780px);height:100%;display:flex;align-items:center;justify-content:center}.canvas-stage canvas{max-width:100%;max-height:100%;width:auto;height:auto;display:block;border-radius:8px;box-shadow:#00000029 0 20px 56px,var(--ds-border)}.template-list{display:grid;gap:10px}.template-card{display:grid;grid-template-columns:82px 1fr;align-items:center;gap:12px;border-radius:8px;background:var(--ds-white);padding:8px;text-align:left}.template-card.selected{background:#ebf5ff;box-shadow:#93c5fd 0 0 0 1px,#0a72ef14 0 2px 2px}.template-card canvas{width:82px;height:110px;border-radius:7px;background:var(--ds-gray-50);object-fit:cover;box-shadow:var(--ds-ring)}.template-card span{min-width:0;display:grid;gap:7px}.template-card strong{overflow-wrap:anywhere;color:var(--ds-black);font-size:13px;font-weight:600;line-height:1.3}.template-card small{width:fit-content;border-radius:9999px;background:var(--ds-gray-50);color:var(--ds-gray-600);padding:4px 8px;font-size:11px;font-weight:500;line-height:1;box-shadow:var(--ds-ring)}.template-card.selected small{background:var(--ds-white);color:#0068d6}.app-loading{position:fixed;inset:0;z-index:40;display:grid;place-items:center;background:var(--ds-white);cursor:progress}.app-loading-card{width:168px;display:grid;justify-items:center;gap:16px}.app-loading-mark{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:7px;background:var(--ds-black);color:var(--ds-white);font-size:19px;font-weight:600;line-height:1;box-shadow:var(--ds-border)}.app-loading-bar{position:relative;width:100%;height:2px;overflow:hidden;border-radius:9999px;background:var(--ds-gray-100)}.app-loading-bar:after{content:"";position:absolute;inset:0;width:42%;border-radius:inherit;background:var(--ds-black);animation:app-loading-progress .9s ease-in-out infinite}.wechat-entry{position:relative;width:38px;height:38px;flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:50%;background:var(--ds-white);padding:3px;outline:none;box-shadow:var(--ds-card);transition:background-color .16s ease,box-shadow .16s ease}.wechat-entry:after{content:"";position:absolute;inset:-6px;border-radius:inherit;box-shadow:#93c5fd 0 0 0 1px;animation:wechat-pulse 2.4s ease-out infinite}.wechat-entry:hover,.wechat-entry:focus-visible,.wechat-entry.is-active{background:var(--ds-gray-50);box-shadow:var(--ds-border),#00000014 0 8px 18px -10px}.wechat-entry:focus-visible{outline:2px solid var(--ds-focus);outline-offset:3px}.wechat-entry img{width:100%;height:100%;display:block;border-radius:50%;object-fit:cover}.wechat-modal-layer{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:24px;background:#fafafab8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:wechat-layer-in .26s ease both}.wechat-modal-layer.is-closing{animation:wechat-layer-out .26s ease both}.wechat-modal{position:relative;width:min(100%,368px);display:grid;justify-items:center;border-radius:8px;background:var(--ds-white);padding:28px 28px 24px;text-align:center;box-shadow:var(--ds-card),#00000014 0 24px 72px -28px;transform-origin:calc(100% - 22px) -72px;animation:wechat-modal-in .3s cubic-bezier(.2,.8,.2,1) both}.wechat-modal.is-closing{animation:wechat-modal-out .26s cubic-bezier(.4,0,.2,1) both}.wechat-close{position:absolute;top:10px;right:10px;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:6px;background:var(--ds-white);color:var(--ds-gray-500);box-shadow:var(--ds-ring)}.wechat-close:hover,.wechat-close:focus-visible{background:var(--ds-gray-50)}.wechat-close:focus-visible{outline:2px solid var(--ds-focus);outline-offset:2px}.wechat-avatar{width:54px;height:54px;display:block;border-radius:50%;object-fit:cover;box-shadow:var(--ds-ring)}.wechat-modal h2{max-width:100%;margin:16px 0 0;color:var(--ds-black);font-size:22px;font-weight:600;line-height:1.25;letter-spacing:0}.wechat-modal p{width:100%;max-width:292px;margin:10px 0 18px;color:var(--ds-gray-600);font-size:14px;line-height:1.7;overflow-wrap:anywhere;word-break:break-word}.wechat-qrcode{width:198px;height:198px;display:block;border-radius:8px;object-fit:cover;box-shadow:var(--ds-ring)}.wechat-confirm{width:100%;min-height:40px;margin-top:20px;border:0;border-radius:6px;background:var(--ds-black);color:var(--ds-white);font-size:14px;font-weight:500;outline:none;box-shadow:var(--ds-border)}.wechat-confirm:hover,.wechat-confirm:focus-visible{background:#000}.wechat-confirm:focus-visible{outline:2px solid var(--ds-focus);outline-offset:2px}@keyframes wechat-pulse{0%{opacity:.72;transform:scale(.88)}70%,to{opacity:0;transform:scale(1.22)}}@keyframes app-loading-progress{0%{transform:translate(-120%)}to{transform:translate(260%)}}@keyframes wechat-layer-in{0%{background:#fafafa00;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{background:#fafafab8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}}@keyframes wechat-layer-out{0%{background:#fafafab8;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}to{background:#fafafa00;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}@keyframes wechat-modal-in{0%{opacity:0;transform:translate(132px,-148px) scale(.18)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes wechat-modal-out{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(132px,-148px) scale(.18)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important}}@media(max-width:1180px){.workspace{grid-template-columns:320px minmax(330px,1fr)}.template-panel{display:none}}@media(max-width:760px){html,body,#root{height:auto}body{min-height:100vh;overflow-x:hidden;overflow-y:auto}.app-shell{height:auto;min-height:100vh;overflow-x:hidden}.top-bar{height:auto;flex-direction:column;align-items:stretch;gap:12px;padding:14px}.top-actions{display:grid;grid-template-columns:38px 1fr 38px}.workspace{display:flex;flex-direction:column;height:auto;min-height:0;overflow-x:hidden}.panel{height:auto;overflow:visible}.preview-panel{order:-1;height:auto;min-height:430px;padding:56px 16px 18px}.preview-meta{top:12px;left:14px;right:14px;justify-content:space-between}.canvas-stage{height:356px}.controls-panel{padding:18px;box-shadow:#ebebeb 0 -1px}.template-panel{display:block;overflow:hidden;padding:18px;box-shadow:#ebebeb 0 -1px}.template-list{display:flex;gap:10px;margin:0 -18px;overflow-x:auto;padding:0 18px 6px;scroll-snap-type:x proximity;scrollbar-width:none;-webkit-overflow-scrolling:touch}.template-list::-webkit-scrollbar{display:none}.template-card{width:168px;flex:0 0 168px;grid-template-columns:1fr;scroll-snap-align:start}.template-card canvas{width:100%;height:126px}.color-row{grid-template-columns:repeat(8,minmax(28px,1fr))}.wechat-modal-layer{padding:16px}.wechat-modal{padding:26px 20px 22px}}.lab-shell{height:100vh;min-height:0;display:flex;flex-direction:column;background:var(--ds-white)}.lab-header{height:64px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:0 24px;background:var(--ds-white);box-shadow:var(--ds-ring)}.lab-header h1{margin:0;font-size:18px;line-height:1.2}.lab-header p{margin:4px 0 0;color:var(--ds-gray-500);font-size:12px}.lab-link{min-height:36px;display:inline-flex;align-items:center;border-radius:6px;padding:0 12px;background:var(--ds-white);color:var(--ds-black);font-size:13px;font-weight:500;text-decoration:none;box-shadow:var(--ds-ring)}.lab-workspace{flex:1;min-height:0;display:grid;grid-template-columns:minmax(420px,520px) minmax(0,1fr)}.lab-editor{min-height:0;overflow:auto;padding:18px;background:var(--ds-white);box-shadow:#ebebeb -1px 0 inset}.lab-prompt-input{min-height:390px;font-family:Geist Mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;line-height:1.55}.lab-terms-input{min-height:190px;margin-top:10px;font-size:13px;line-height:1.45}.lab-actions{display:flex;align-items:end;gap:10px;margin-top:14px}.lab-actions label{width:72px;gap:5px}.lab-actions select{min-height:38px;border:0;border-radius:6px;background:var(--ds-white);padding:0 8px;box-shadow:var(--ds-ring)}.lab-results{min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(auto-fill,362px);align-content:start;align-items:start;justify-content:start;gap:14px;padding:18px;background:var(--ds-gray-50)}.lab-empty{grid-column:1 / -1;min-height:180px;display:grid;place-items:center;border-radius:8px;color:var(--ds-gray-500);background:var(--ds-white);font-size:13px;box-shadow:var(--ds-ring)}.lab-card{width:362px;min-width:362px;border-radius:8px;background:var(--ds-white);overflow:visible;box-shadow:var(--ds-card)}.lab-card.error{box-shadow:#ff5b4f70 0 0 0 1px}.lab-card-header{min-height:56px;display:flex;align-items:center;justify-content:space-between;gap:10px;width:360px;padding:10px 12px;box-shadow:#ebebeb 0 -1px inset}.lab-card-header h2{margin:0;font-size:14px;line-height:1.25}.lab-card-header p{margin:4px 0 0;color:var(--ds-gray-500);font-size:11px}.lab-canvas-wrap{position:relative;width:360px;height:360px;min-width:360px;min-height:360px;display:grid;place-items:center;overflow:visible;background:linear-gradient(var(--ds-gray-100) 1px,transparent 1px),linear-gradient(90deg,var(--ds-gray-100) 1px,transparent 1px),var(--ds-white);background-size:24px 24px}.lab-canvas-wrap canvas{width:360px!important;height:360px!important;max-width:none;max-height:none;display:block;flex:0 0 auto}.lab-canvas-wrap span{position:absolute;inset:auto 12px 12px;border-radius:8px;padding:8px;background:#ffffffe0;color:var(--ds-gray-600);font-size:12px;text-align:center;box-shadow:var(--ds-ring)}.lab-meta{display:flex;justify-content:space-between;gap:10px;width:360px;padding:9px 12px;color:var(--ds-gray-500);font-size:12px;box-shadow:#ebebeb 0 1px inset}.lab-json{width:360px;box-shadow:#ebebeb 0 1px inset}.lab-json summary{cursor:pointer;padding:9px 12px;color:var(--ds-black);font-size:12px;font-weight:500}.lab-json pre{max-height:260px;margin:0;overflow:auto;padding:12px;background:var(--ds-black);color:var(--ds-gray-50);font-size:11px;line-height:1.45}@media(max-width:900px){html,body,#root{height:auto}body{overflow-y:auto}.lab-shell{height:auto;min-height:100vh}.lab-workspace{display:flex;flex-direction:column;height:auto}.lab-editor{max-height:none;overflow:visible;box-shadow:#ebebeb 0 -1px inset}.lab-results{min-height:0;overflow:visible;grid-template-columns:362px;justify-content:center}}
