: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}*{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,.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}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: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,.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}.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}.align-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.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:auto}.app-shell{height:auto;min-height:100vh}.top-bar{height:auto;flex-direction:column;align-items:stretch;padding:14px}.top-actions{display:grid;grid-template-columns:40px 1fr 1fr}.workspace{display:flex;flex-direction:column;height:auto;min-height:0}.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;padding:18px}.template-list{display:flex;gap:10px;margin:0 -18px;overflow-x:auto;padding:0 18px 6px;scroll-snap-type:x proximity}.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))}}
