:root{font-family:Inter,Microsoft YaHei,PingFang SC,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#1f2933;background:#efebe2;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}.shell{min-height:100vh;padding:18px}.busyOverlay{position:fixed;z-index:50;inset:0;display:grid;place-items:center;background:#1f29337a;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.busyDialog{display:grid;place-items:center;gap:10px;width:min(360px,calc(100vw - 36px));padding:28px 24px;color:#1f2933;background:#fffdf8;border:1px solid #d8d1c3;border-radius:8px;box-shadow:0 24px 70px #1118274d;text-align:center}.busyDialog svg{color:#245d63}.busyDialog strong{font-size:18px}.busyDialog span{color:#6b6258;font-size:13px;line-height:1.5}.busyProgress{width:100%;height:8px;overflow:hidden;background:#e7e1d6;border-radius:999px}.busyProgress div{height:100%;background:#245d63;border-radius:inherit;transition:width .18s ease}.workspace{display:grid;grid-template-columns:320px minmax(0,1fr) 320px;gap:14px;min-height:calc(100vh - 36px)}.panel{background:#fffdf8;border:1px solid #d8d1c3;border-radius:8px;box-shadow:0 14px 34px #41342214}.controls{display:flex;flex-direction:column;gap:14px;max-height:calc(100vh - 36px);overflow:auto;padding:18px}.brand{display:grid;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:12px}.brandMark{display:grid;place-items:center;width:44px;height:44px;color:#fff;background:#245d63;border-radius:8px}.brand h1{margin:0;font-size:21px;line-height:1.2}.brand p{margin:5px 0 0;overflow:hidden;color:#6b6258;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.upload{position:relative;display:flex;align-items:center;justify-content:center;gap:9px;min-height:48px;color:#fff;background:#b54132;border-radius:8px;cursor:pointer;font-weight:700}.blankCreate{display:flex;align-items:center;justify-content:center;gap:8px;min-height:44px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:8px;cursor:pointer;font-weight:800}.upload input{position:absolute;inset:0;opacity:0;cursor:pointer}.projectName{display:grid;gap:6px;color:#6b6258;font-size:13px}.projectName input{min-height:38px;padding:0 10px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:7px}.projectActions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.projectActions button{display:flex;align-items:center;justify-content:center;gap:6px;min-height:38px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:8px;cursor:pointer;font-size:13px;font-weight:800}.projectActions button:disabled{cursor:not-allowed;opacity:.45}.projectActions input{display:none}.saveStatus{margin-top:-8px;color:#7a7166;font-size:12px}.controlGroup{display:grid;gap:7px}.labelRow,.stats div{display:flex;align-items:center;justify-content:space-between;gap:12px}.labelRow span,.stats span{color:#6b6258;font-size:13px}input[type=range]{width:100%;accent-color:#245d63}.rangeStepper{display:grid;grid-template-columns:34px minmax(0,1fr) 34px;align-items:center;gap:8px}.rangeStepper button{min-height:32px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:7px;cursor:pointer;font-size:18px;font-weight:800;line-height:1}.mobileDock,.drawerBackdrop,.drawerClose,.landscapeTip{display:none}.sectionTitle,.panelTitle.compact{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#245d63;font-size:13px;font-weight:800}.sectionTitle{justify-content:flex-start;margin-top:2px}.segmented{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;padding:4px;background:#f3f0e8;border:1px solid #d8d1c3;border-radius:8px}.segmented.four{grid-template-columns:repeat(4,minmax(0,1fr))}.segmented button{min-height:34px;color:#403a34;background:transparent;border:0;border-radius:6px;cursor:pointer;font-weight:700}.segmented button.active{color:#fff;background:#245d63}.inlineFields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.inlineFields label{display:grid;gap:6px;color:#6b6258;font-size:13px}.inlineFields input,.inlineFields select,.paletteSelect{width:100%;min-height:36px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:7px}.inlineFields input[type=color]{padding:3px}.switches{display:grid;gap:10px}.switches label{display:flex;align-items:center;gap:10px;min-height:38px;padding:0 10px;background:#f3f0e8;border:1px solid #d8d1c3;border-radius:8px;color:#403a34;font-size:14px}.switches input{width:17px;height:17px;accent-color:#245d63}.stats{display:grid;gap:8px;padding:12px;background:#f3f0e8;border:1px solid #d8d1c3;border-radius:8px}.stats strong{font-size:15px}.actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.primaryActions{padding:10px;background:#f3f0e8;border:1px solid #d8d1c3;border-radius:8px}.actions button{display:flex;align-items:center;justify-content:center;gap:6px;min-width:0;min-height:42px;padding:0 8px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:8px;cursor:pointer;font-weight:700;font-size:13px}.actions button:disabled{cursor:not-allowed;opacity:.48}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.previewArea{position:relative;display:grid;min-width:0;overflow:hidden;background:#d7d0c3;border:1px solid #bfb6a6;border-radius:8px}.canvasWrap{position:relative;display:flex;align-items:center;justify-content:center;min-height:100%;overflow:auto;padding:22px}.canvasWrap canvas{max-width:100%;height:auto;background:#f7f5ef;border:1px solid #9f9688;border-radius:6px;box-shadow:0 18px 38px #2e251924;cursor:crosshair;touch-action:none}.canvasWrap.zooming{overflow:hidden;touch-action:none}.canvasWrap.zooming canvas{cursor:grab}.canvasWrap.zooming canvas:active{cursor:grabbing}.transformedCanvas{transform-origin:center center;will-change:transform}.magnifierToggle{position:absolute;z-index:3;top:14px;right:14px;display:grid;place-items:center;width:42px;height:42px;color:#1f2933;background:#fffdf8f0;border:1px solid #bfb6a6;border-radius:8px;cursor:pointer;box-shadow:0 10px 26px #2e251924}.magnifierToggle.active{color:#fff;background:#245d63;border-color:#245d63}.zoomModeHint{position:absolute;z-index:3;top:14px;left:14px;display:flex;align-items:center;gap:8px;padding:8px 10px;color:#1f2933;background:#fffdf8f2;border:1px solid #bfb6a6;border-radius:8px;box-shadow:0 10px 26px #2e251924;font-size:13px;font-weight:800}.zoomModeHint button{min-height:28px;padding:0 10px;color:#fff;background:#245d63;border:0;border-radius:6px;cursor:pointer;font-weight:800}.zoomModeHint button:disabled{color:#8a8177;background:#e7e1d6;cursor:default}.magnifierPanel{position:absolute;z-index:5;right:14px;bottom:14px;display:grid;gap:8px;max-width:min(560px,calc(100% - 28px));max-height:min(620px,calc(100% - 86px));padding:10px;overflow:auto;background:#fffdf8f7;border:1px solid #bfb6a6;border-radius:8px;box-shadow:0 20px 52px #2e251938}.magnifierPanel.pinned{border-color:#245d63}.magnifierHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;color:#57534e;font-size:12px;font-weight:800;cursor:move;-webkit-user-select:none;user-select:none}.magnifierHeader button{min-height:28px;padding:0 10px;color:#1f2933;background:#fff;border:1px solid #d8d1c3;border-radius:6px;cursor:pointer;font-weight:800}.magnifierPanel canvas{display:block;max-width:none;background:#f7f5ef;border:1px solid #9f9688;border-radius:6px;cursor:crosshair;touch-action:none}.magnifierFrame{position:absolute;z-index:2;pointer-events:none;border:2px solid #b54132;background:#b5413214;box-shadow:0 0 0 1px #ffffffe6,0 8px 18px #2e251929}.cropCanvas{width:100%;max-width:260px;height:auto;justify-self:center;background:#f7f5ef;border:1px solid #bfb6a6;border-radius:8px;cursor:move;touch-action:none}.error,.notice{position:absolute;z-index:2;top:14px;left:14px;right:14px;padding:10px 12px;border-radius:8px}.error{color:#7f1d1d;background:#fee2e2;border:1px solid #fecaca}.notice{color:#713f12;background:#fef3c7;border:1px solid #facc15}.error+.notice{top:62px}.draftOverlay{position:absolute;z-index:4;top:14px;left:50%;transform:translate(-50%);display:grid;gap:10px;width:min(430px,calc(100% - 28px));padding:10px;background:#fffdf8f0;border:1px solid #bfb6a6;border-radius:8px;box-shadow:0 16px 38px #2e25192e;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.draftThumb{display:grid;gap:6px}.draftThumb span{color:#57534e;font-size:12px;font-weight:800}.draftThumb canvas{width:100%;height:auto;max-height:170px;object-fit:contain;background:#f7f5ef;border:1px solid #d8d1c3;border-radius:6px}.draftControls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.draftControls button{min-height:34px;border:1px solid #bfb6a6;border-radius:7px;cursor:pointer;font-weight:800}.draftControls button:first-child{color:#fff;background:#245d63;border-color:#245d63}.draftControls button:nth-child(2),.draftControls button:nth-child(3){color:#1f2933;background:#fff}.palettePanel{display:flex;flex-direction:column;min-width:0;max-height:calc(100vh - 36px);overflow:auto;padding:16px}.panelTitle{display:flex;align-items:center;gap:8px;margin-bottom:12px;color:#245d63}.panelTitle.compact{margin:14px 0 8px}.panelTitle.compact small{color:#7a7166;font-size:12px;font-weight:700}.panelTitle h2{margin:0;color:#1f2933;font-size:17px}.paletteSelect{margin-bottom:12px;padding:0 10px}.editorPanel{display:grid;gap:10px;margin-bottom:12px;padding:10px;background:#f3f0e8;border:1px solid #d8d1c3;border-radius:8px}.currentColor{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:9px}.currentColor strong,.currentColor small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.currentColor strong{font-size:14px}.currentColor small{margin-top:2px;color:#6b6258;font-size:12px}.swatch.large{width:36px;height:36px}.toolBar{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:7px}.toolBar button,.replaceRow button,.inventoryToggle{display:grid;place-items:center;min-height:36px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:7px;cursor:pointer;font-weight:800}.toolBar button.active{color:#fff;background:#245d63;border-color:#245d63}.toolBar button:disabled,.replaceRow button:disabled,.inventoryToggle:disabled{cursor:not-allowed;opacity:.45}.replaceRow{display:grid;grid-template-columns:minmax(0,1fr) 18px minmax(0,1fr) 58px;align-items:center;gap:7px}.replaceRow select{min-width:0;min-height:36px;border:1px solid #bfb6a6;border-radius:7px}.usedList{display:grid;gap:7px;min-height:0;max-height:min(55vh,520px);overflow:auto;padding-right:2px}.colorRow{display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:9px;min-height:34px;padding:5px 8px;background:#f8f6f1;border:1px solid #ded8cd;border-radius:7px}.colorButton{width:100%;color:#1f2933;cursor:pointer;text-align:left}.colorRow.warn{border-color:#d97706}.swatch,.paletteDot{border:1px solid rgba(20,20,20,.28)}.swatch{width:22px;height:22px;border-radius:5px}.colorName{overflow:hidden;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.colorName small{margin-left:6px;color:#7a7166}.colorRow strong{font-size:13px}.paletteGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(32px,1fr));gap:7px;margin-top:16px}.paletteDot{display:grid;place-items:center;aspect-ratio:1;padding:0;border-radius:7px;color:#111827;font-size:11px;font-weight:800;text-shadow:0 1px 1px rgba(255,255,255,.75),0 -1px 1px rgba(255,255,255,.5)}button.paletteDot{cursor:pointer}.paletteDot.disabled{filter:grayscale(1);opacity:.38;text-decoration:line-through}.paletteDot.selected{outline:3px solid #245d63;outline-offset:2px}.inventoryToggle{margin-top:9px;width:100%}.disabledList{display:grid;gap:7px}.disabledColorRow{display:grid;grid-template-columns:24px minmax(0,1fr) auto;align-items:center;gap:8px;min-height:38px;padding:6px 8px;color:#1f2933;background:#fff;border:1px solid #d8d1c3;border-radius:7px;cursor:pointer;text-align:left}.disabledColorRow span:not(.swatch){display:grid;min-width:0;font-weight:800}.disabledColorRow small{overflow:hidden;color:#6b6258;font-size:11px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.disabledColorRow strong{color:#245d63;font-size:12px}.boardList{display:grid;gap:7px;margin-top:4px}.boardRow{display:flex;align-items:center;justify-content:space-between;min-height:30px;padding:0 8px;background:#f8f6f1;border:1px solid #ded8cd;border-radius:7px;color:#403a34;font-size:13px}.moreRows{color:#7a7166;font-size:12px;text-align:center}.note{display:grid;grid-template-columns:18px minmax(0,1fr);gap:9px;margin-top:auto;padding-top:18px;color:#6b6258;font-size:12px;line-height:1.55}@media(max-width:1180px){.workspace{grid-template-columns:280px minmax(0,1fr)}.palettePanel{grid-column:1 / -1;min-height:240px}.usedList{max-height:260px}}@media(max-width:760px){.shell{padding:10px 10px 68px}.workspace{grid-template-columns:1fr;min-height:auto}.previewArea{min-height:calc(100vh - 92px);order:-1}.canvasWrap{padding:12px;justify-content:flex-start}.magnifierToggle{top:10px;right:10px}.magnifierPanel{left:auto;right:10px;bottom:10px;width:min(46vw,180px);max-width:180px;max-height:24vh;padding:8px}.magnifierPanel canvas{width:100%;height:auto}.magnifierHeader{min-height:34px}.zoomModeHint{top:10px;left:10px;padding:7px 8px;font-size:12px}.zoomModeHint button{min-height:30px;padding:0 9px}.controls,.palettePanel{position:fixed;z-index:30;left:10px;right:10px;bottom:76px;display:flex;max-height:min(78vh,720px);overflow:auto;transform:translateY(calc(100% + 92px));transition:transform .2s ease}.controls.drawerOpen,.palettePanel.drawerOpen{transform:translateY(0)}.drawerClose{display:block;min-height:36px;color:#1f2933;background:#fff;border:1px solid #bfb6a6;border-radius:7px;cursor:pointer;font-weight:800}.actions{grid-template-columns:repeat(2,minmax(0,1fr))}.primaryActions{box-shadow:0 10px 26px #4134221f}.mobileDock{position:fixed;z-index:40;left:10px;right:10px;bottom:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:8px;background:#fffdf8f5;border:1px solid #d8d1c3;border-radius:8px;box-shadow:0 14px 38px #2e251933}.mobileDock button{min-height:42px;color:#fff;background:#245d63;border:0;border-radius:7px;cursor:pointer;font-weight:800}.mobileDock button:disabled{opacity:.45}.drawerBackdrop{position:fixed;z-index:20;inset:0;display:block;background:#1f293347;border:0}.landscapeTip{position:fixed;z-index:60;left:16px;right:16px;top:74px;display:grid;gap:10px;padding:14px;color:#1f2933;background:#fffdf8f7;border:1px solid #d8d1c3;border-radius:8px;box-shadow:0 16px 42px #2e251938}.landscapeTip strong{font-size:16px}.landscapeTip span{color:#6b6258;font-size:13px;line-height:1.5}.landscapeTip div{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.landscapeTip button{min-height:38px;border-radius:7px;cursor:pointer;font-weight:800}.landscapeTip button:first-child{color:#fff;background:#245d63;border:0}.landscapeTip button:last-child{color:#1f2933;background:#fff;border:1px solid #bfb6a6}.projectActions{grid-template-columns:1fr}.segmented.four{grid-template-columns:repeat(2,minmax(0,1fr))}.draftOverlay{top:10px}.draftControls{grid-template-columns:1fr}.rangeStepper{grid-template-columns:38px minmax(0,1fr) 38px}.rangeStepper button{min-height:36px}}@media(max-width:1180px)and (orientation:landscape){.shell{padding:10px}.workspace{display:grid;grid-template-columns:minmax(230px,26vw) minmax(0,1fr) minmax(230px,26vw);gap:10px;min-height:calc(100vh - 20px)}.controls,.palettePanel{position:static;grid-column:auto;display:flex;max-height:calc(100vh - 20px);min-height:0;overflow:auto;transform:none}.previewArea{min-height:calc(100vh - 20px);order:initial}.mobileDock,.drawerBackdrop,.drawerClose,.landscapeTip{display:none}.magnifierPanel{width:min(36vw,300px);max-height:58vh}}
