body{margin:0}:root{--bg:#f7fbff;--paper:#fff;--paper-2:#f1f7f5;--ink:#17212b;--muted:#677381;--line:#dfe8ec;--teal:#0c9488;--teal-dark:#08756c;--coral:#e2574c;--yellow:#f2c94c;--blue:#3c7dd9;--shadow:0 16px 48px #24374621;color:var(--ink);background:var(--bg);font-synthesis:none;letter-spacing:0;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:linear-gradient(#0c94880f 1px, transparent 1px), linear-gradient(90deg, #0c94880f 1px, transparent 1px), var(--bg);background-size:28px 28px;min-width:320px;min-height:100svh;margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.52}#root{min-height:100svh}.app-shell{grid-template-rows:auto minmax(0,1fr);grid-template-columns:minmax(300px,340px) minmax(460px,1fr) minmax(300px,360px);gap:14px;min-height:100svh;padding:14px;display:grid}.side-panel,.workspace,.top-strip,.mode-tabs{border:1px solid var(--line);box-shadow:var(--shadow);background:#fffffff0}.mode-tabs{border-radius:8px;grid-column:1/-1;justify-content:space-between;align-items:center;gap:14px;min-width:0;padding:10px;display:flex}.mode-tabs-title{color:var(--teal-dark);flex:none;align-items:center;gap:8px;font-size:14px;display:inline-flex}.mode-tabs-list{grid-template-columns:repeat(6,minmax(0,1fr));gap:8px;width:min(980px,100%);display:grid}.mode-tab{border:1px solid var(--line);min-width:0;min-height:42px;color:var(--ink);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:7px;padding:0 10px;font-size:13px;font-weight:900;display:inline-flex}.mode-tab span{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.mode-tab:hover{background:#f2faf8;border-color:#9fc9c5}.mode-tab.active{border-color:var(--teal);color:var(--teal-dark);background:#dff3ef}.side-panel{border-radius:8px;flex-direction:column;gap:14px;max-height:calc(100svh - 28px);padding:16px;display:flex;overflow:auto}.panel-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.panel-head h1,.panel-head h2{color:var(--ink);letter-spacing:0;margin:0;line-height:1.05}.panel-head h1{font-size:25px}.panel-head h2{font-size:22px}.panel-head.compact{align-items:center}.eyebrow{color:var(--teal-dark);text-transform:uppercase;margin:0 0 5px;font-size:12px;font-weight:800}.status-pill{min-height:30px;color:var(--teal-dark);white-space:nowrap;background:#e8f6f3;border:1px solid #0c94883d;border-radius:8px;align-items:center;padding:5px 9px;font-size:13px;font-weight:800;display:inline-flex}.upload-zone{text-align:center;background:#f5fbfa;border:2px dashed #bfd6d5;border-radius:8px;place-items:center;gap:8px;min-height:174px;padding:14px;transition:border-color .2s,background .2s;display:grid;position:relative}.upload-zone:hover{border-color:var(--teal);background:#ecf8f5}.upload-zone input,.secondary-button input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.upload-zone img{object-fit:contain;background:#fff;border-radius:6px;max-width:100%;max-height:124px}.upload-zone strong{color:var(--ink);font-size:15px}.upload-zone span{color:var(--muted);font-size:12px}.upload-empty{width:64px;height:64px;color:var(--teal);box-shadow:inset 0 0 0 1px var(--line);background:#fff;border-radius:8px;place-items:center;display:grid}.inline-error{color:#a53a32;background:#fff1ef;border:1px solid #e2574c47;border-radius:8px;padding:10px 12px;font-size:13px;font-weight:700}.button-row{gap:8px;display:flex}.primary-button,.secondary-button,.export-button,.tool-button,.preset,.segmented button{border:1px solid var(--line);color:var(--ink);background:#fff;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:800;line-height:1;display:inline-flex}.primary-button{border-color:var(--teal);background:var(--teal);color:#fff;width:100%;min-height:48px}.primary-button:hover{background:var(--teal-dark)}.primary-button.attention{background:var(--yellow);color:#2e2500;border-color:#d99a12}.secondary-button{flex:1;min-height:40px;padding:0 10px;font-size:13px;position:relative}.secondary-button:hover,.export-button:hover,.tool-button:hover,.preset:hover,.segmented button:hover{background:#f2faf8;border-color:#9fc9c5}.icon-only{flex:0 0 42px}.control-section{border:1px solid var(--line);background:#ffffffb8;border-radius:8px;gap:10px;padding:12px;display:grid}.control-section h2,.control-section h3{color:var(--ink);letter-spacing:0;margin:0;font-size:15px}.preset-grid{grid-template-columns:repeat(4,1fr);gap:7px;display:grid}.preset{min-height:36px;padding:0 8px;font-size:12px}.preset.active,.segmented button.active,.tool-button.active{border-color:var(--teal);color:var(--teal-dark);background:#dff3ef}.two-columns{grid-template-columns:1fr 1fr;gap:8px;display:grid}.field,.range-field{color:var(--muted);gap:6px;font-size:12px;font-weight:800;display:grid}.field input[type=number],.field input[type=color]{border:1px solid var(--line);width:100%;min-height:38px;color:var(--ink);background:#fff;border-radius:8px;padding:0 10px}.field input[type=color]{padding:4px}.range-field span{justify-content:space-between;gap:8px;display:flex}.range-field strong{color:var(--ink)}.range-field input{width:100%;accent-color:var(--teal)}.toggle-line{min-height:34px;color:var(--ink);align-items:center;gap:9px;font-size:13px;font-weight:800;display:flex}.toggle-line input{width:18px;height:18px;accent-color:var(--teal)}.segmented{grid-template-columns:repeat(auto-fit,minmax(74px,1fr));gap:7px;display:grid}.segmented button{min-height:36px;padding:0 6px;font-size:12px}.center-column{grid-template-rows:auto minmax(520px,1fr);gap:14px;min-width:0;display:grid}.top-strip{border-radius:8px;justify-content:space-between;align-items:center;gap:12px;min-height:64px;padding:12px 14px;display:flex}.top-strip div{gap:3px;min-width:0;display:grid}.top-strip strong{color:var(--ink);font-size:15px}.top-strip span{color:var(--muted);font-size:12px}.top-strip .secondary-button{flex:none}.workspace{border-radius:8px;grid-template-rows:auto 1fr;min-width:0;display:grid;overflow:hidden}.workspace-toolbar{border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex}.tool-group{gap:6px;display:flex}.tool-button{width:40px;height:40px;padding:0}.canvas-shell{touch-action:none;background:#f8fbff;min-height:0;position:relative;overflow:hidden}.canvas-shell canvas{display:block}.tool-brush canvas,.tool-eraser canvas{cursor:crosshair}.tool-picker canvas{cursor:copy}.tool-pan canvas{cursor:grab}.zoom-readout{border:1px solid var(--line);min-width:58px;color:var(--muted);text-align:center;background:#ffffffeb;border-radius:8px;padding:7px 9px;font-size:12px;font-weight:900;position:absolute;bottom:12px;right:12px}.palette-section{gap:9px}.mode-guide-section p{color:var(--muted);margin:0;font-size:13px;font-weight:650;line-height:1.5}.active-palette,.full-palette{grid-template-columns:repeat(6,minmax(0,1fr));gap:7px;display:grid}.color-swatch{background:#fff;border:2px solid #0000;border-radius:8px;place-items:center;height:42px;display:grid;position:relative}.color-swatch span{border-radius:7px;position:absolute;inset:5px;box-shadow:inset 0 0 0 1px #11182733}.color-swatch strong{z-index:1;color:#111827;background:#ffffffd1;border-radius:50%;place-items:center;width:22px;height:22px;font-size:11px;display:grid;position:relative}.color-swatch.active,.mini-swatch.active{border-color:var(--coral);box-shadow:0 0 0 2px #e2574c2e}.mini-swatch{color:#111827cc;text-shadow:0 1px #fff6;border:2px solid #0000;border-radius:8px;height:32px;font-size:10px;font-weight:900}.stats-section{min-height:0}.stats-head{justify-content:space-between;align-items:center;display:flex}.stats-head strong{color:var(--teal-dark)}.materials-list{gap:6px;max-height:240px;padding-right:2px;display:grid;overflow:auto}.material-row{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:18px 1fr 24px auto;align-items:center;gap:8px;min-height:34px;padding:6px 8px;display:grid}.material-chip{border-radius:50%;width:18px;height:18px;box-shadow:inset 0 0 0 1px #11182738}.material-row span{min-width:0;color:var(--ink);font-size:13px;font-weight:800}.material-row small{color:var(--muted);font-weight:900}.material-row strong{color:var(--ink);font-size:13px}.empty-note{border:1px dashed var(--line);min-height:70px;color:var(--muted);border-radius:8px;place-items:center;font-size:13px;font-weight:800;display:grid}.export-section{grid-template-columns:1fr 1fr}.export-section h3{grid-column:1/-1}.export-button{min-height:42px;padding:0 10px;font-size:13px}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=1180px){.app-shell{grid-template-columns:320px minmax(0,1fr)}.mode-tabs{flex-direction:column;align-items:stretch}.mode-tabs-title{justify-content:center}.right-panel{grid-column:1/-1;max-height:none}.right-panel .control-section{align-content:start}.right-panel{grid-template-columns:repeat(3,1fr);display:grid}.right-panel .panel-head{grid-column:1/-1}}@media (width<=820px){.app-shell{grid-template-columns:1fr;padding:10px}.mode-tabs-list{grid-template-columns:repeat(2,minmax(0,1fr))}.side-panel{max-height:none}.center-column{grid-template-rows:auto minmax(480px,70svh)}.workspace-toolbar{flex-wrap:wrap}.right-panel{display:flex}.top-strip{flex-direction:column;align-items:stretch}.top-strip .secondary-button{width:100%}}
