:root{--bg:#f7f4ef;--panel:#fffdf8;--ink:#241f1a;--muted:#766c61;--line:#ded4c7;--accent:#2c7a7b;--accent-strong:#1f5f60;--warm:#f4a261;--danger:#b5462f;--shadow:0 18px 40px rgba(58,42,24,.08)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-family:Inter,PingFang SC,Microsoft YaHei,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.app-shell{min-height:100vh;padding:28px}.workspace{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr) minmax(280px,340px);grid-gap:18px;gap:18px;max-width:1580px;margin:0 auto}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow)}.main-panel,.side-panel{padding:18px}.main-panel{min-height:calc(100vh - 56px)}.brand-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:18px}.brand-row h1{margin:0;font-size:24px;line-height:1.1}.brand-row span{color:var(--muted);font-size:13px}.section{border-top:1px solid var(--line);padding-top:16px;margin-top:16px}.section:first-child{border-top:0;padding-top:0;margin-top:0}.section h2{margin:0 0 12px;font-size:15px}.upload-zone{display:grid;place-items:center;min-height:160px;padding:18px;border:1px dashed #b9a998;border-radius:8px;background:#fff8ef;text-align:center;color:var(--muted)}.upload-zone strong{display:block;color:var(--ink);margin-bottom:6px}.project-import{display:block;padding:9px 10px;border:1px solid var(--line);border-radius:7px;background:#fff}.processed-import,.project-import{margin-top:10px;color:var(--ink);text-align:center;font-size:13px;font-weight:700;cursor:pointer}.processed-import{display:grid;grid-gap:4px;gap:4px;padding:10px;border:1px dashed #d8c4a8;border-radius:8px;background:#fffaf1}.processed-import span{color:var(--muted);font-size:12px;font-weight:500}.source-switcher{display:grid;grid-gap:8px;gap:8px;margin-top:10px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.source-switcher p{margin:0;color:var(--muted);font-size:12px;font-weight:700}.source-switch-buttons{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.source-switch-buttons button{border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff;color:var(--ink);font-size:12px;font-weight:700}.source-switch-buttons button.active{border-color:var(--accent);background:#edfafa;color:var(--accent)}.generation-mode-panel{display:grid;grid-gap:8px;gap:8px;margin-top:12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.generation-mode-panel>span{color:var(--muted);font-size:12px;font-weight:800}.generation-mode-panel p{margin:0;color:var(--muted);font-size:12px}.generation-mode-buttons{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.generation-mode-buttons button{display:grid;grid-gap:4px;gap:4px;min-height:74px;border:1px solid var(--line);border-radius:8px;padding:10px;background:#fffaf3;color:var(--ink);text-align:left}.generation-mode-buttons button.active{border-color:var(--accent);background:#edfafa;box-shadow:inset 0 0 0 1px rgba(44,122,123,.18)}.generation-mode-buttons strong{font-size:13px}.generation-mode-buttons small{color:var(--muted);font-size:11px;line-height:1.35}.source-preview{margin-top:12px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:8px}.source-preview-frame{position:relative;overflow:hidden;width:-moz-fit-content;width:fit-content;max-width:100%;margin:0 auto}.source-preview-frame img{display:block;max-width:100%;max-height:260px;width:auto;height:auto}.crop-overlay{position:absolute;z-index:1;border:2px solid #2c7a7b;box-shadow:0 0 0 999px rgba(36,31,26,.34);background:linear-gradient(rgba(44,122,123,.16),rgba(44,122,123,.16)),repeating-linear-gradient(90deg,hsla(0,0%,100%,.28) 0 1px,transparent 1px 33.33%),repeating-linear-gradient(0deg,hsla(0,0%,100%,.28) 0 1px,transparent 1px 33.33%);pointer-events:none}.source-focus-preview{display:grid;grid-gap:8px;gap:8px;margin-top:12px;padding:10px;border:1px solid #c9e3e0;border-radius:8px;background:#f5fbfa}.source-focus-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.source-focus-head strong{font-size:13px}.source-focus-head span{color:var(--muted);font-size:11px}.source-focus-frame{display:grid;place-items:center;overflow:hidden;height:160px;border:1px solid var(--line);border-radius:7px;background:#fff}.source-focus-frame img{width:100%;height:100%;object-fit:contain;transition:transform .16s ease,object-position .16s ease}.control-hint{margin:0 0 10px;color:var(--muted);font-size:12px;line-height:1.45}.file-input{display:none}.control-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:10px;gap:10px}.ai-preprocess-grid{display:grid;grid-gap:12px;gap:12px;margin-bottom:12px}.ai-preprocess-grid>div{display:grid;grid-gap:8px;gap:8px}.ai-preprocess-grid strong{color:var(--muted);font-size:12px}.segmented-control{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:8px;gap:8px}.ai-style-list button,.segmented-control button{border:1px solid var(--line);border-radius:7px;padding:8px;background:#fff;color:var(--ink);text-align:left}.segmented-control button{display:grid;grid-gap:2px;gap:2px;text-align:center;font-weight:800}.ai-style-list small,.segmented-control span{color:var(--muted);font-size:11px;font-weight:500}.ai-style-list button.active,.segmented-control button.active{border-color:var(--accent);background:#edfafa}.ai-style-list{display:grid;grid-gap:8px;gap:8px}.ai-style-list button{display:grid;grid-gap:3px;gap:3px}.ai-style-list span{font-size:13px;font-weight:800}.field{display:grid;grid-gap:6px;gap:6px;margin-bottom:12px}.field label,.toggle-label{color:var(--muted);font-size:12px}.field input,.field select{width:100%;border:1px solid var(--line);border-radius:6px;padding:9px 10px;background:#fff;color:var(--ink)}.range-field input{padding:0;accent-color:var(--accent)}.compact-section{padding-top:12px;margin-top:12px}.crop-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px 10px;gap:8px 10px}.mini-button{width:100%;border:1px solid var(--line);border-radius:6px;padding:8px 10px;background:#fff;color:var(--muted);font-size:12px}.advanced-toggle{width:100%;margin:12px 0;border:1px solid var(--line);border-radius:7px;padding:9px 10px;background:#fff;color:var(--accent);font-size:13px;font-weight:700}.compact-toggle{margin:8px 0 10px;padding:8px 10px;font-size:12px}.compact-tools{display:grid;grid-gap:8px;gap:8px}.toggle-label{display:flex;align-items:center;gap:8px}.preset-list{display:grid;grid-gap:8px;gap:8px}.preset-button{display:grid;grid-template-columns:1fr auto;grid-gap:6px 10px;gap:6px 10px;width:100%;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);text-align:left}.preset-button.active{border-color:var(--accent);background:#edfafa}.preset-button strong{font-size:13px}.preset-button span{color:var(--muted);font-size:12px}.q-size-panel{display:grid;grid-gap:8px;gap:8px;margin-top:10px;padding:10px;border:1px solid #d7ebe8;border-radius:8px;background:#f5fbfa}.q-size-panel p{margin:0;color:var(--muted);font-size:12px;font-weight:700}.q-size-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:8px;gap:8px}.q-size-buttons button{display:grid;grid-gap:3px;gap:3px;min-height:54px;border:1px solid var(--line);border-radius:7px;padding:8px;background:#fff;color:var(--ink);text-align:left}.q-size-buttons strong{font-size:12px}.q-size-buttons span{color:var(--muted);font-size:11px}.q-style-roadmap{display:grid;grid-gap:4px;gap:4px;margin-top:10px;padding:10px;border:1px dashed #d8c4a8;border-radius:8px;background:#fffaf1}.q-style-roadmap strong{color:var(--ink);font-size:13px}.q-style-roadmap span{color:var(--muted);font-size:12px;line-height:1.5}.primary-button,.secondary-button{width:100%;border-radius:7px;padding:11px 12px;font-weight:700}.primary-button{background:var(--accent);color:#fff}.primary-button:hover{background:var(--accent-strong)}.secondary-button{border:1px solid var(--line);background:#fff;color:var(--ink)}.button-stack{display:grid;grid-gap:10px;gap:10px}.package-button{box-shadow:0 8px 20px rgba(162,83,35,.18)}.package-summary{display:grid;grid-gap:8px;gap:8px;margin-bottom:12px}.package-summary div{display:grid;grid-template-columns:86px 1fr;grid-gap:8px;gap:8px;align-items:center;padding:9px 10px;border:1px solid var(--line);border-radius:7px;background:#fff}.package-summary strong{font-size:13px}.package-summary span{color:var(--muted);font-size:12px}.preview-stage{display:flex;min-height:600px;align-items:center;justify-content:center;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:16px;background:linear-gradient(#ece6dc 1px,transparent 0),linear-gradient(90deg,#ece6dc 1px,transparent 0),#fffefa;background-size:20px 20px}.preview-stage.editing{display:block;align-items:flex-start;justify-content:flex-start;min-height:0;height:clamp(420px,58vh,640px);overflow:scroll;cursor:-webkit-grab;cursor:grab;position:relative;scrollbar-color:#b7a897 #fff7e8;scrollbar-width:auto}.preview-stage.panning,.preview-stage.panning .preview-canvas.editable{cursor:-webkit-grabbing;cursor:grabbing}.mini-map{position:-webkit-sticky;position:sticky;top:10px;left:calc(100% - 166px);z-index:6;width:156px;height:156px;margin:0 0 -156px auto;padding:4px;border:1px solid rgba(36,31,26,.18);border-radius:8px;background:rgba(255,253,248,.92);box-shadow:0 10px 24px rgba(36,31,26,.14);cursor:pointer}.mini-map canvas{display:block;width:148px;height:148px}.mini-map-viewport{position:absolute;box-sizing:border-box;border:2px solid #e76f51;border-radius:4px;box-shadow:0 0 0 1px hsla(0,0%,100%,.9);pointer-events:none}.preview-tabs{display:inline-grid;grid-template-columns:repeat(5,1fr);gap:4px;margin:0 0 12px;padding:4px;border:1px solid var(--line);border-radius:8px;background:#fff}.section-nav{display:inline-flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0 0 12px 10px;color:var(--muted);font-size:13px}.section-nav button{border:1px solid var(--line);border-radius:6px;padding:7px 10px;background:#fff;color:var(--ink);font-weight:700}.section-nav strong{color:var(--ink)}.zoom-toolbar{display:inline-flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0 0 12px}.zoom-toolbar span{color:var(--muted);font-size:13px}.zoom-toolbar button{border:1px solid var(--line);border-radius:6px;padding:6px 9px;background:#fff;color:var(--ink);font-weight:700}.zoom-toolbar button.active{background:var(--ink);color:#fff}.zoom-toolbar .edit-toggle{border-color:var(--accent);color:var(--accent)}.zoom-toolbar .edit-toggle.active{background:var(--accent);color:#fff}.point-editor{display:grid;grid-template-columns:auto auto auto 72px 72px auto minmax(220px,1fr) auto;grid-gap:10px;gap:10px;align-items:end;margin:0 0 12px;padding:10px;border:1px solid #c9e3e0;border-radius:8px;background:#f5fbfa}.point-editor .edit-hint{grid-column:1/-1;margin:0;color:var(--muted);font-size:12px;line-height:1.4}.batch-suggestions>div,.edit-tool-group,.popover-tools{display:inline-flex;gap:6px;align-items:center;flex-wrap:wrap}.batch-suggestions button,.edit-tool-group button,.popover-tools button{border:1px solid var(--line);border-radius:6px;padding:7px 9px;background:#fff;color:var(--ink);font-size:12px;font-weight:800}.edit-tool-group button.active,.popover-tools button.active{border-color:var(--accent);background:#edfafa;color:var(--accent)}.batch-suggestions,.edit-history-panel{display:grid;grid-gap:6px;gap:6px;align-self:stretch}.batch-suggestions>span,.edit-history-panel>span{color:var(--muted);font-size:12px}.batch-suggestions button:disabled{opacity:.45}.edit-history-panel{grid-column:1/-1;padding-top:2px}.edit-history-panel ol{display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none}.edit-history-panel li{max-width:260px;overflow:hidden;border:1px solid var(--line);border-radius:6px;padding:5px 7px;background:#fff;color:var(--muted);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.point-editor div,.point-editor label{display:grid;grid-gap:4px;gap:4px}.point-editor span{color:var(--muted);font-size:12px}.point-editor strong{min-height:22px;color:var(--ink);font-size:14px}.point-editor input,.point-editor select{width:100%;min-width:0;border:1px solid var(--line);border-radius:6px;padding:8px 10px;background:#fff;color:var(--ink)}.point-editor .primary-button{width:auto;min-width:116px;padding:9px 12px}.point-editor .secondary-button{width:auto;min-width:72px;padding:9px 12px}.preview-tabs button{min-width:92px;border-radius:6px;padding:7px 10px;background:transparent;color:var(--muted);font-size:13px;font-weight:700}.preview-tabs button.active{background:var(--accent);color:#fff}.preview-canvas{flex:0 0 auto;max-width:none;height:auto;background:#fff;border:1px solid #d2c6b9}.preview-canvas.editable{cursor:crosshair;border-color:var(--accent);box-shadow:0 0 0 3px rgba(44,122,123,.12)}.cell-edit-popover{position:absolute;z-index:5;display:grid;grid-gap:8px;gap:8px;width:min(280px,calc(100% - 32px));padding:10px;border:1px solid #c9e3e0;border-radius:8px;background:rgba(255,253,248,.96);box-shadow:0 12px 30px rgba(36,31,26,.16)}.cell-edit-popover-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.cell-edit-popover-head span,.neighbor-colors>span{color:var(--muted);font-size:12px}.neighbor-colors{display:grid;grid-gap:6px;gap:6px}.neighbor-colors>div{display:flex;flex-wrap:wrap;gap:6px}.neighbor-colors button{display:inline-flex;align-items:center;gap:5px;padding:5px 7px;font-size:12px;font-weight:800}.cell-edit-popover select,.neighbor-colors button{border:1px solid var(--line);border-radius:6px;background:#fff;color:var(--ink)}.cell-edit-popover select{width:100%;padding:8px 10px}.cell-edit-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.cell-edit-actions .primary-button,.cell-edit-actions .secondary-button{width:100%;padding:8px 10px}.empty-state{max-width:360px;text-align:center;color:var(--muted)}.empty-state strong{display:block;margin-bottom:8px;color:var(--ink);font-size:18px}.stats-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.stat{padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.stat span{display:block;color:var(--muted);font-size:12px}.stat strong{display:block;margin-top:4px;font-size:18px}.legend-tools{display:grid;grid-template-columns:minmax(0,1fr) auto auto;grid-gap:8px;gap:8px;align-items:center;margin-bottom:10px}.legend-tools input{width:100%;min-width:0;border:1px solid var(--line);border-radius:7px;padding:8px 10px;background:#fff;font:inherit}.legend-tools .mini-button{width:auto;white-space:nowrap}.legend-tools .mini-button:disabled{opacity:.45;cursor:not-allowed}.legend-tools span{grid-column:1/-1;color:var(--muted);font-size:12px}.legend-list{display:grid;grid-gap:8px;gap:8px;max-height:380px;overflow:auto}.legend-row{display:grid;grid-template-columns:22px 44px 1fr auto;align-items:center;grid-gap:8px;gap:8px;padding:8px;border:1px solid var(--line);border-radius:7px;background:#fff;font-size:12px}.legend-edit{grid-column:1/-1}.legend-edit summary{width:-moz-fit-content;width:fit-content;color:var(--accent);font-size:12px;font-weight:700;cursor:pointer}.legend-edit[open]{display:grid;grid-gap:8px;gap:8px;padding-top:2px}.legend-edit select{grid-column:1/-1;width:100%;border:1px solid var(--line);border-radius:6px;padding:7px 8px;background:#fff;color:var(--ink);font-size:12px}.swatch{width:22px;height:22px;border:1px solid rgba(0,0,0,.18);border-radius:4px}.code-pill{display:inline-grid;place-items:center;min-width:36px;height:22px;border-radius:5px;background:#efe7dc;font-weight:800}.shopping-note{color:var(--muted);font-size:13px;line-height:1.55}.export-status{margin:10px 0 0}.reset-settings-button{margin-top:10px}.tip-list{display:grid;grid-gap:8px;gap:8px;margin:0;padding-left:18px;color:var(--muted);font-size:13px;line-height:1.45}.compact-tip-list{margin-top:10px}.make-summary-card{display:grid;grid-gap:10px;gap:10px}.make-summary-main{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.make-summary-main div{padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff7e8}.make-summary-main span,.make-summary-main strong{display:block}.make-summary-main span{color:var(--muted);font-size:12px}.make-summary-main strong{margin-top:4px;color:var(--ink);font-size:17px}.make-summary{display:grid;grid-template-columns:1fr auto;grid-gap:8px 12px;gap:8px 12px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:13px}.make-summary span{color:var(--muted)}.make-summary strong{color:var(--ink)}.make-checklist{display:grid;grid-gap:6px;gap:6px;padding:10px;border:1px solid var(--line);border-radius:8px;background:#fff}.make-checklist p{margin:0;color:var(--muted);font-size:13px;line-height:1.45}@media (max-width:1180px){.workspace{grid-template-columns:320px minmax(0,1fr)}.right-panel{grid-column:1/-1}}@media (max-width:760px){.app-shell{padding:12px}.workspace{grid-template-columns:1fr}.main-panel{min-height:520px}.preview-stage{min-height:420px}.legend-tools{grid-template-columns:1fr}.legend-tools .mini-button{width:100%}.generation-mode-buttons,.point-editor{grid-template-columns:1fr}.point-editor .primary-button{width:100%}.q-size-buttons,.segmented-control{grid-template-columns:1fr}}