:root{color:#171717;background:#f6f2ee;font-family:Noto Sans SC,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}.lab-shell{height:100vh;min-height:0;display:flex;flex-direction:column;background:#f6f2ee}.lab-header{height:64px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:0 24px;border-bottom:1px solid #e3ddd5;background:#ffffffe0}.lab-header h1{margin:0;font-size:18px;line-height:1.2}.lab-header p{margin:4px 0 0;color:#6b625c;font-size:12px}.lab-link{min-height:36px;display:inline-flex;align-items:center;border:1px solid #d9d0c7;border-radius:8px;padding:0 12px;background:#fff;color:#171717;font-size:13px;font-weight:760;text-decoration:none}.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;border-right:1px solid #e3ddd5;background:#fffdfa}.lab-prompt-input{min-height:390px;font-family:SFMono-Regular,Consolas,Liberation Mono,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:1px solid #d9d0c7;border-radius:8px;background:#fff;padding:0 8px}.lab-results{min-height:0;overflow:auto;display:grid;grid-template-columns:repeat(auto-fill,360px);align-content:start;justify-content:start;gap:14px;padding:18px}.lab-empty{grid-column:1 / -1;min-height:180px;display:grid;place-items:center;border:1px dashed #d9d0c7;border-radius:8px;color:#7b716a;background:#fffdfa;font-size:13px}.lab-card{width:360px;border:1px solid #e3ddd5;border-radius:8px;background:#fffdfa;overflow:hidden}.lab-card.error{border-color:#e5484d6b}.lab-card-header{min-height:56px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border-bottom:1px solid #eee8e2}.lab-card-header h2{margin:0;font-size:14px;line-height:1.25}.lab-card-header p{margin:4px 0 0;color:#7b716a;font-size:11px}.lab-canvas-wrap{position:relative;width:360px;height:360px;display:grid;place-items:center;background:linear-gradient(#eee8e2 1px,transparent 1px),linear-gradient(90deg,#eee8e2 1px,transparent 1px),#fffdf9;background-size:24px 24px}.lab-canvas-wrap canvas{width:360px;height:360px}.lab-canvas-wrap span{position:absolute;inset:auto 12px 12px;border-radius:8px;padding:8px;background:#ffffffe0;color:#5c554f;font-size:12px;text-align:center}.lab-meta{display:flex;justify-content:space-between;gap:10px;padding:9px 12px;border-top:1px solid #eee8e2;color:#6b625c;font-size:12px}.lab-json{border-top:1px solid #eee8e2}.lab-json summary{cursor:pointer;padding:9px 12px;color:#2c2926;font-size:12px;font-weight:760}.lab-json pre{max-height:260px;margin:0;overflow:auto;padding:12px;background:#171717;color:#f8f4ee;font-size:11px;line-height:1.45}@media(max-width:900px){.lab-workspace{grid-template-columns:1fr}.lab-editor{max-height:52vh;border-right:0;border-bottom:1px solid #e3ddd5}.lab-results{grid-template-columns:360px;justify-content:center}}*{box-sizing:border-box}html,body{height:100%}body{margin:0;min-width:320px;overflow:hidden}#root{height:100%}button,input,textarea{font:inherit}button{cursor:pointer}.app-shell{height:100vh;min-height:0;display:flex;flex-direction:column;background:linear-gradient(180deg,#fffc,#f6f2eee0),#f6f2ee}.top-bar{height:64px;flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:0 24px;border-bottom:1px solid #e3ddd5;background:#ffffffdb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.brand-block{min-width:0;display:flex;align-items:center;gap:12px}.brand-mark{width:36px;height:36px;display:inline-flex;flex:0 0 auto;align-items:center;justify-content:center;border:1px solid #171717;border-radius:8px;background:#171717;color:#fff;font-size:19px;font-weight:850;line-height:1}.top-bar h1{margin:0;color:#171717;font-size:17px;font-weight:820;line-height:1.2}.wordmark{display:inline-flex;align-items:center;gap:7px;min-width:0;white-space:nowrap}.wordmark>span:not(.wordmark-link){letter-spacing:0}.wordmark-link{min-width:30px;height:20px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgb(229 72 77 / 28%);border-radius:999px;background:#fff1ef;color:#e5484d;font-size:11px;font-weight:820;line-height:1}.top-bar p{margin:5px 0 0;overflow:hidden;color:#6b625c;font-size:12px;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.top-actions{display:flex;flex:0 0 auto;align-items:center;gap:8px}.icon-button{min-height:38px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #d9d0c7;border-radius:8px;padding:0 14px;color:#171717;font-weight:720;white-space:nowrap;transition:border-color .18s ease,background-color .18s ease,color .18s ease,box-shadow .18s ease}.icon-button:hover,.icon-button:focus-visible,.text-button:hover,.text-button:focus-visible,.segmented-grid button:hover,.segmented-grid button:focus-visible,.option-grid button:hover,.option-grid button:focus-visible,.inline-action:hover,.inline-action:focus-visible,.selected-decoration-heading button:hover,.selected-decoration-heading button:focus-visible,.size-row button:hover,.size-row button:focus-visible,.align-row button:hover,.align-row button:focus-visible,.template-card:hover,.template-card:focus-visible{border-color:#e5484d;outline:none;box-shadow:0 0 0 3px #e5484d1f}.icon-button.primary{border-color:#e5484d;background:#e5484d;color:#fff;box-shadow:0 10px 22px #e5484d38}.icon-button.primary:hover,.icon-button.primary:focus-visible{border-color:#c92f36;background:#c92f36}.icon-button.secondary,.icon-button.ghost{background:#fff}.icon-button.ghost{width:40px;padding:0}.workspace{flex:1;height:calc(100vh - 64px);min-height:0;display:grid;grid-template-columns:340px minmax(380px,1fr) 310px}.panel{height:100%;min-height:0;overflow:auto;overscroll-behavior:contain;background:#fffdfa}.controls-panel{border-right:1px solid #e3ddd5;padding:18px}.template-panel{border-left:1px solid #e3ddd5;padding:18px}.control-section+.control-section{margin-top:20px;padding-top:18px;border-top:1px solid #eee8e2}.section-title,.panel-heading{display:flex;align-items:center}.section-title{gap:8px;margin-bottom:12px;color:#e5484d}.panel-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.section-title h2,.panel-heading h2{margin:0;color:#171717;font-size:14px;font-weight:820;line-height:1.2}.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:2px solid #9a8f86;border-bottom:2px solid #9a8f86;transform:rotate(45deg) translateY(-2px);transition:transform .18s ease}.collapse-section[open] .collapse-summary:after{transform:rotate(225deg) translateY(-2px)}.collapse-body{margin-top:12px}.subsection-title{display:flex;align-items:center;gap:7px;color:#e5484d}.subsection-title h3{margin:0;color:#2c2926;font-size:13px;font-weight:800;line-height:1.2}label{display:grid;gap:7px;color:#5c554f;font-size:13px;font-weight:720}label+label{margin-top:10px}.field-label{display:flex;align-items:center;justify-content:space-between;gap:12px}.field-label small{color:#9a8f86;font-size:11px;font-weight:720;white-space:nowrap}textarea,input{width:100%;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#171717;padding:9px 11px;outline:none;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}textarea::placeholder,input::placeholder{color:#aaa098;font-size:12px;line-height:1.5}textarea:hover,input:hover{border-color:#bfb4aa}textarea:focus,input:focus{border-color:#e5484d;box-shadow:0 0 0 3px #e5484d1f}textarea{height:108px;min-height:108px;resize:none;line-height:1.58}.segmented-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.segmented-grid button{min-height:54px;flex-direction:column;align-items:flex-start;justify-content:center;display:flex;gap:4px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;padding:9px 10px;color:#171717;text-align:left;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.segmented-grid button.selected,.option-grid button.selected,.size-row button.selected,.align-row button.selected{border-color:#e5484d;background:#fff1ef;box-shadow:inset 0 0 0 1px #e5484d33}.segmented-grid span{font-weight:760}.segmented-grid small{color:#7b716a;font-size:11px;white-space:nowrap}.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{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.option-grid button{width:100%;min-height:36px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#171717;padding:8px 10px;font-size:12px;font-weight:760;text-align:left;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.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-color:#e8ded5;border-radius:999px;background:#fff;color:#8a8077;padding:0;box-shadow:0 2px 8px #1717171f}.inline-action{min-height:26px;display:inline-flex;align-items:center;gap:4px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#e5484d;padding:0 8px;font-size:12px;font-weight:780;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.ai-prompt-box{display:grid;gap:8px;border:1px solid #eee8e2;border-radius:8px;background:#fff8f6;padding:10px}.ai-prompt-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.ai-prompt-actions button{height:32px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#171717;font-size:12px;font-weight:760}.ai-prompt-actions button:last-child{border-color:#e5484d;background:#e5484d;color:#fff}.ai-prompt-actions button:disabled{cursor:wait;opacity:.68}.selected-decoration-list{display:grid;gap:10px;margin-top:10px}.selected-decoration{display:grid;gap:10px;border:1px solid #eee8e2;border-radius:8px;background:#fff;padding:10px}.selected-decoration-heading{display:flex;align-items:center;justify-content:space-between;gap:10px}.selected-decoration-heading strong{color:#171717;font-size:13px;font-weight:820}.selected-decoration-heading button{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#7b716a;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.range-field{display:grid;gap:6px;color:#5c554f;font-size:12px}.range-field span{display:flex;align-items:center;justify-content:space-between;gap:10px}.range-field small{color:#9a8f86;font-size:11px;font-weight:760}.range-field input{padding:0;accent-color:#e5484d}.size-row{display:grid;grid-template-columns:repeat(3,1fr);gap:7px}.size-row button{height:32px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#171717;font-size:12px;font-weight:760;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.current-color{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;border:1px solid #eee8e2;border-radius:8px;background:#fff;padding:8px 10px;color:#5c554f;font-size:12px}.current-color span{width:24px;height:24px;border:2px solid #ffffff;border-radius:999px;box-shadow:0 0 0 1px #cfc5bb}.current-color strong{overflow:hidden;color:#171717;font-weight:760;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 #ffffff;border-radius:8px;box-shadow:0 0 0 1px #cfc5bb;transition:box-shadow .18s ease,transform .18s ease}.color-dot:hover,.color-dot:focus-visible{outline:none;box-shadow:0 0 0 1px #e5484d,0 0 0 4px #e5484d1f}.color-dot.selected{box-shadow:0 0 0 2px #171717,0 0 0 5px #1717171a}.field-hint{margin:8px 0 0;color:#7b716a;font-size:12px;line-height:1.45}.error-text{color:#c92f36}.align-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.highlight-controls{display:grid;gap:8px;margin-top:12px}.mode-row{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.mode-row button{height:36px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#171717;font-weight:760;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.mode-row button:hover,.mode-row button:focus-visible{border-color:#e5484d;outline:none;box-shadow:0 0 0 3px #e5484d1f}.mode-row button.selected{border-color:#e5484d;background:#fff1ef;box-shadow:inset 0 0 0 1px #e5484d33}.align-row button{height:38px;display:flex;align-items:center;justify-content:center;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#171717;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.preview-panel{position:relative;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center;height:100%;padding:54px 34px 34px;background:linear-gradient(90deg,rgb(23 23 23 / 4%) 1px,transparent 1px),linear-gradient(0deg,rgb(23 23 23 / 4%) 1px,transparent 1px),radial-gradient(circle at 50% 0%,rgb(229 72 77 / 10%),transparent 36%),#f2ede7;background-size:28px 28px,28px 28px,auto,auto}.preview-meta{position:absolute;top:18px;left:18px;display:inline-flex;align-items:center;gap:8px;border:1px solid rgb(217 208 199 / 80%);border-radius:8px;background:#fffdfadb;padding:8px 10px;color:#5c554f;font-size:12px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.preview-meta span{color:#e5484d;font-weight:820}.preview-meta strong{color:#171717;font-weight:760}.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:10px;box-shadow:0 22px 60px #17171733,0 0 0 1px #17171714}.text-button{min-height:32px;display:inline-flex;align-items:center;gap:6px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;color:#e5484d;padding:0 10px;font-size:12px;font-weight:780;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.template-list{display:grid;gap:10px}.template-card{display:grid;grid-template-columns:82px 1fr;align-items:center;gap:12px;border:1px solid #d9d0c7;border-radius:8px;background:#fff;padding:8px;text-align:left;transition:border-color .18s ease,background-color .18s ease,box-shadow .18s ease}.template-card.selected{border-color:#e5484d;background:#fff8f6;box-shadow:inset 0 0 0 1px #e5484d2e,0 10px 24px #e5484d1a}.template-card canvas{width:82px;height:110px;border-radius:7px;background:#f2ede7;object-fit:cover;box-shadow:0 0 0 1px #17171714}.template-card span{min-width:0;display:grid;gap:7px}.template-card strong{overflow-wrap:anywhere;color:#171717;font-size:13px;font-weight:820;line-height:1.3}.template-card small{width:fit-content;border-radius:999px;background:#f2ede7;color:#6b625c;padding:4px 8px;font-size:11px;font-weight:760;line-height:1}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:1ms!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;padding:14px}.top-actions{display:grid;grid-template-columns:40px 1fr}.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{border-top:1px solid #e3ddd5;border-right:0;padding:18px}.template-panel{display:block;border-top:1px solid #e3ddd5;border-left:0;overflow:hidden;padding:18px}.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))}}.lab-shell .lab-results{grid-template-columns:repeat(auto-fill,362px);align-content:start;align-items:start}.lab-shell .lab-card{width:362px;min-width:362px;overflow:visible}.lab-shell .lab-card-header,.lab-shell .lab-meta,.lab-shell .lab-json{width:360px}.lab-shell .lab-canvas-wrap{width:360px;height:360px;min-width:360px;min-height:360px;overflow:visible}.lab-shell .lab-canvas-wrap canvas{width:360px!important;height:360px!important;max-width:none;max-height:none;display:block;flex:0 0 auto}@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}.lab-results{min-height:0;overflow:visible;grid-template-columns:362px;justify-content:center}}
