:root{color:#122116;background:#eff3ec;font-family:Segoe UI,Helvetica Neue,sans-serif}*{box-sizing:border-box}body{margin:0}#root{min-height:100vh}.app-shell{background:linear-gradient(#f6f9f4 0%,#e7efe2 100%);grid-template-columns:95px 1fr 320px;min-height:100vh;display:grid}.app-shell>*{min-width:0}.left-toolbar{text-align:center;background:#f2f7ee;border-right:1px solid #c7d5c2;flex-direction:column;gap:16px;padding:16px 10px;display:flex}.toolbar-group-bottom{margin-top:auto}.help-button{text-align:center;padding:6px 0;font-size:1.1rem}.toolbar-group{flex-direction:column;gap:8px;display:flex}.tool-button{color:#17301d;text-align:center;cursor:pointer;background:#fff;border:1px solid #9cb195;border-radius:8px;padding:8px 10px;font-size:.8rem}.tool-button.active{background:#dcebd8;border-color:#60885b;font-weight:600}.tool-button:disabled{opacity:.55;cursor:default}.editor-area{min-height:100%;position:relative}.canvas-region{background:repeating-linear-gradient(-45deg,#ebf5e5cc,#ebf5e5cc 14px,#e4f0ddcc 14px 28px);flex-direction:column;flex:1;gap:12px;min-height:100%;padding:16px;display:flex}.canvas-region p{margin:0}.canvas-surface{isolation:isolate;background:#f8fcf6e0;border:1px solid #c4d5bf;border-radius:12px;flex:1;min-height:0;position:relative;overflow:hidden}.canvas-viewport{transform-origin:0 0;position:absolute;top:0;bottom:0;left:0;right:0}.canvas-sheet{background:#f8fcf7;border:1px solid #d3e2ce;border-radius:12px;position:relative;overflow:hidden;box-shadow:0 18px 30px #243a2814}.canvas-surface.stamp-mode-surface{cursor:copy}.canvas-surface.background-mode-surface{cursor:move}.canvas-surface.pan-mode-surface{cursor:grab}.canvas-surface.pan-mode-surface.panning{cursor:grabbing}.canvas-background-image{pointer-events:none;max-width:none;max-height:none;display:block;position:absolute}.canvas-empty-state{text-align:center;color:#3f5f46;pointer-events:none;justify-content:center;align-items:center;width:100%;max-width:none;height:100%;margin:0;padding:20px;display:flex;position:absolute;top:0;bottom:0;left:0;right:0}.canvas-hint{z-index:4;color:#28452e;pointer-events:none;background:#ffffffe6;border:1px solid #c4d4c0;border-radius:10px;max-width:min(420px,100% - 24px);margin:0;padding:10px 12px;font-size:.85rem;position:absolute;top:12px;right:12px}.canvas-zoom-indicator{z-index:4;color:#2d4f35;pointer-events:none;opacity:0;background:#ffffffe0;border:1px solid #c4d4c0;border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:700;transition:opacity .2s;position:absolute;bottom:12px;right:12px}.canvas-zoom-indicator.visible{opacity:1}.stamp-layer{z-index:2;position:absolute;top:0;bottom:0;left:0;right:0}.stamp-layer-disabled{pointer-events:none}.stamp-item{cursor:grab;touch-action:none;background:0 0;border:0;outline:none;padding:0;position:absolute}.stamp-item .stamp-shape{pointer-events:none}.stamp-item:focus{outline:none}.stamp-item:focus-visible{outline:none}.stamp-item.dragging{cursor:grabbing}.stamp-item.selected:after{content:"";border:2px solid var(--stamp-outline-color,#2f6140);pointer-events:none;border-radius:12px;position:absolute;top:-2px;bottom:-2px;left:-2px;right:-2px}.shape-asset{width:100%;height:100%;color:var(--shape-color,#4c8a47);isolation:isolate;pointer-events:none;-webkit-user-drag:none;-webkit-user-select:none;user-select:none;display:inline-flex;position:relative}.shape-asset .shape-svg,.shape-asset svg,.shape-asset .shape-img{width:100%;height:100%;display:block}.shape-asset .shape-tint{background:var(--shape-color,#4c8a47);mix-blend-mode:color;opacity:var(--shape-tint-strength,1);pointer-events:none;-webkit-mask-image:var(--shape-mask);-webkit-mask-position:50%;-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-image:var(--shape-mask);-webkit-mask-image:var(--shape-mask);mask-image:var(--shape-mask);-webkit-mask-source-type:alpha;position:absolute;top:0;bottom:0;left:0;right:0;-webkit-mask-position:50%;mask-position:50%;-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-source-type:alpha;mask-mode:alpha}.stamp-shape,.element-preview .shape-asset{width:100%;height:100%}.canvas-summary{background:#ffffffe6;border:1px solid #c7d8c2;border-radius:10px;flex-wrap:wrap;gap:10px 16px;margin:0;padding:10px 12px;display:flex}.canvas-summary-item{align-items:baseline;gap:6px;font-size:.85rem;display:flex}.canvas-summary-label{text-transform:uppercase;letter-spacing:.04em;color:#3b5a43;font-size:.7rem;font-weight:700}.canvas-summary-value{color:#1f3f27;font-weight:600}.right-panel{overscroll-behavior:contain;background:#f7faf5;border-left:1px solid #c7d5c2;align-content:start;gap:16px;min-height:0;max-height:100vh;padding:16px 16px 16px 20px;display:grid;overflow:hidden auto}.region-title{letter-spacing:.04em;text-transform:uppercase;color:#2e4b33;margin:0;font-size:.9rem}.section-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.plan-actions-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.plan-actions-grid .full-width{grid-column:1/-1}.panel-section.plan-section .plan-actions-grid{margin-top:auto}.panel-section.plan-section{flex-direction:column;gap:10px;display:flex}.plan-save-indicator{color:#35533c;align-items:center;gap:8px;font-size:.82rem;display:flex}.plan-save-emoji{transition:opacity .2s,transform .2s}.plan-save-texts{display:grid}.plan-save-text{grid-area:1/1;transition:opacity .2s}.plan-save-indicator.saving .plan-save-emoji{opacity:0;transform:scale(.9)}.plan-save-indicator.saved .plan-save-emoji{opacity:1;transform:scale(1)}.plan-save-indicator.saving .plan-save-text.saved{opacity:0}.plan-save-indicator.saving .plan-save-text.saving,.plan-save-indicator.saved .plan-save-text.saved{opacity:1}.plan-save-indicator.saved .plan-save-text.saving{opacity:0}.file-field{grid-template-columns:repeat(2,minmax(0,1fr));align-items:stretch;gap:8px;display:grid;position:relative}.panel-section .file-input{clip:rect(0,0,0,0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.file-label{color:#2e4b33;cursor:pointer;text-transform:none;font-size:.85rem;font-weight:600;display:block}.file-field .tool-button{width:100%}.plan-name-row{grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:8px;display:grid}.plan-delete-button{justify-content:center;align-items:center;min-width:40px;padding:0;font-size:1rem;display:flex}.panel-section{background:#fff;border:1px solid #c8d7c4;border-radius:12px;gap:10px;padding:12px;display:grid}.field-label{text-transform:uppercase;color:#35533c;letter-spacing:.03em;font-size:.75rem;font-weight:600}.panel-section input,.panel-section select{border:1px solid #9fb498;border-radius:8px;width:100%;min-width:0;padding:8px;font-size:.9rem}.color-swatch-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.color-swatch-button{color:#17301d;text-align:left;cursor:pointer;background:#fff;border:1px solid #9fb498;border-radius:10px;align-items:center;gap:10px;padding:8px 10px;font-size:.8rem;display:flex}.color-swatch-button.selected{background:#dcebd8;border-color:#60885b;font-weight:600}.color-swatch-chip{background:var(--swatch-color);border:1px solid #14241a33;border-radius:8px;flex:0 0 30px;width:30px;height:30px;box-shadow:inset 0 0 0 1px #ffffff59}.color-swatch-label{line-height:1.1}.panel-action{text-align:center}.element-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.element-list-item{position:relative}.element-list-item.dragging{opacity:.6}.element-list-item.drop-before:before,.element-list-item.drop-after:after{content:"";background:#5f8759;border-radius:999px;height:2px;position:absolute;left:12px;right:12px}.element-list-item.drop-before:before{top:-6px}.element-list-item.drop-after:after{bottom:-6px}.element-list-button{text-align:left;cursor:pointer;color:#17301d;background:#fff;border:1px solid #c8d7c4;border-radius:10px;grid-template-columns:auto 1fr;align-items:center;gap:10px;width:100%;padding:10px;display:grid}.element-list-button[aria-grabbed=true]{cursor:grabbing}.element-list-button.selected{background:#edf6e9;border-color:#60885b}.element-preview{background:#f5faf2;border:1px solid #c7d8c2;border-radius:10px;justify-content:center;align-items:center;width:38px;height:38px;padding:4px;display:inline-flex}.element-preview svg{width:100%;height:100%;display:block}.element-list-text{gap:4px;display:grid}.element-name{margin-bottom:4px;font-size:.9rem;font-weight:700}.element-meta{color:#35533c;margin:0;font-size:.85rem}.shape-picker-row{grid-template-columns:auto 1fr;align-items:center;gap:8px;display:grid}.panel-note{color:#4d6653;margin:0;font-size:.85rem}.form-grid{gap:10px;display:grid}.danger-button{color:#7a2d2d;border-color:#b46a6a}.error-note{color:#8b3131;margin:0;font-size:.85rem}.resize-handle-layer{position:absolute;top:0;bottom:0;left:0;right:0}.resize-handle{background:#fff;border:1px solid #1f3d22;border-radius:999px;width:8px;height:8px;position:absolute}.resize-handle.handle-top{cursor:ns-resize;top:-5px;left:50%;transform:translate(-50%)}.resize-handle.handle-right{cursor:ew-resize;top:50%;right:-5px;transform:translateY(-50%)}.resize-handle.handle-bottom{cursor:ns-resize;bottom:-5px;left:50%;transform:translate(-50%)}.resize-handle.handle-left{cursor:ew-resize;top:50%;left:-5px;transform:translateY(-50%)}.background-selection{pointer-events:none;border:2px dashed #5b6f60;border-radius:12px;position:absolute;box-shadow:inset 0 0 0 1px #ffffffb3}.background-handle{pointer-events:auto;background:#fff;border:1px solid #1f3d22;border-radius:6px;width:14px;height:14px;position:absolute;box-shadow:0 2px 6px #1624182e}.background-handle.handle-top-left{cursor:nwse-resize;top:-8px;left:-8px}.background-handle.handle-top-right{cursor:nesw-resize;top:-8px;right:-8px}.background-handle.handle-bottom-right{cursor:nwse-resize;bottom:-8px;right:-8px}.background-handle.handle-bottom-left{cursor:nesw-resize;bottom:-8px;left:-8px}.modal-backdrop{z-index:10;background:#10201473;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.shape-modal{background:#f7fbf6;border:1px solid #8ba085;border-radius:14px;gap:12px;width:max(440px,40vw);padding:16px;display:grid}.load-plan-modal{background:#f7fbf6;border:1px solid #8ba085;border-radius:14px;gap:12px;width:min(520px,100%);padding:16px;display:grid}.confirm-modal{background:#f7fbf6;border:1px solid #8ba085;border-radius:14px;gap:12px;width:min(420px,100%);padding:16px;display:grid}.help-modal{background:#f7fbf6;border:1px solid #8ba085;border-radius:14px;gap:12px;width:min(560px,100%);padding:16px;display:grid}.saved-plan-list{gap:8px;max-height:min(320px,60vh);display:grid;overflow-y:auto}.saved-plan-button{text-align:left;flex-direction:column;align-items:flex-start;gap:4px;display:flex}.saved-plan-button.selected{background:#dcebd8;border-color:#60885b;font-weight:600}.saved-plan-name{font-size:.9rem}.saved-plan-meta{color:#4d6150;font-size:.75rem}.modal-actions{justify-content:flex-end;gap:8px;display:flex}.hotkey-table{border-collapse:collapse;width:100%;font-size:.85rem}.hotkey-table th,.hotkey-table td{text-align:left;border-bottom:1px solid #d8e3d4;padding:8px 6px}.hotkey-table th{text-transform:uppercase;letter-spacing:.04em;color:#35533c;font-size:.75rem}.help-notes{color:#3c5142;gap:6px;font-size:.85rem;display:grid}.help-notes p{margin:0}.shape-modal h2,.load-plan-modal h2,.confirm-modal h2,.help-modal h2{margin:0;font-size:1rem}.shape-option-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;max-height:max(420px,70vh);padding-right:4px;display:grid;overflow-y:auto}.shape-option{text-align:center;text-transform:none;justify-content:center;align-items:center;min-height:110px;padding:10px;display:flex}.shape-option .shape-asset,.shape-option-preview{width:72px;height:72px}.active-shape{background:#dcebd8;border-color:#60885b;font-weight:700}.plan-toast{z-index:12;border:1px solid #0000;border-radius:10px;max-width:min(340px,100% - 32px);padding:10px 12px;font-size:.85rem;position:fixed;bottom:16px;right:16px;box-shadow:0 10px 24px #12211626}.plan-toast.success{color:#22412a;background:#eef8ea;border-color:#8db085}.plan-toast.error{color:#702a2a;background:#fff1f1;border-color:#c98989}@media (max-width:900px){.app-shell{grid-template-rows:auto 1fr auto;grid-template-columns:1fr}.left-toolbar{border-bottom:1px solid #c7d5c2;border-right:0;flex-direction:row;align-items:flex-start;overflow-x:auto}.toolbar-group{min-width:150px}.plan-actions-grid{grid-template-columns:1fr}.right-panel{border-top:1px solid #c7d5c2;border-left:0}.canvas-region{min-height:360px;padding:12px}.canvas-surface{min-height:320px}.canvas-summary{width:100%}.canvas-hint{max-width:calc(100% - 24px)}}