*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#fafafa;color:#333;height:100vh;display:flex;overflow:hidden}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.canvas-container{flex:1;position:relative;overflow:hidden;background:#fff}.canvas-container.dragover{background:#f0f7ff}.svg-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.svg-wrapper svg{max-width:100%;max-height:100%}.selection-box{position:absolute;border:2px dashed #2196F3;background:#2196f31a;pointer-events:none;display:none}.drop-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#999;pointer-events:none}.drop-hint.hidden{display:none}.status-bar{padding:8px 16px;background:#fff;font-size:13px;color:#666;border-top:1px solid #eee}.sidebar{width:300px;background:#fff;border-left:1px solid #ddd;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-section{padding:16px;border-bottom:1px solid #eee}.sidebar-section h3{font-size:12px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.sidebar button{width:100%;padding:10px 14px;border:1px solid #e0e0e0;background:linear-gradient(to bottom,#fff,#fafafa);border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:8px;position:relative}.sidebar button:last-child{margin-bottom:0}.sidebar button:hover{background:linear-gradient(to bottom,#fafafa,#f0f0f0);border-color:#ccc;box-shadow:0 1px 3px #00000014}.sidebar button:active{background:#f0f0f0;box-shadow:inset 0 1px 2px #0000001a}.sidebar button.primary,.sidebar button.contrast{background:linear-gradient(to bottom,#2196f3,#1e88e5);border-color:#1976d2;color:#fff}.sidebar button.primary:hover,.sidebar button.contrast:hover{background:linear-gradient(to bottom,#1e88e5,#1976d2);border-color:#1565c0;box-shadow:0 2px 4px #2196f34d}.sidebar button.primary:active,.sidebar button.contrast:active{background:#1976d2}.sidebar button.danger{background:linear-gradient(to bottom,#f44336,#e53935);border-color:#d32f2f;color:#fff}.sidebar button.danger:hover{background:linear-gradient(to bottom,#e53935,#d32f2f);border-color:#c62828;box-shadow:0 2px 4px #f443364d}.sidebar button.danger:active{background:#d32f2f}.kbd{display:inline-flex;align-items:center;justify-content:center;padding:2px 6px;font-size:10px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Monaco,monospace;font-weight:500;background:#0000000f;border:1px solid rgba(0,0,0,.1);border-radius:4px;color:#666;margin-left:auto;white-space:nowrap}.sidebar button.primary .kbd,.sidebar button.contrast .kbd,.sidebar button.danger .kbd{background:#fff3;border-color:#ffffff4d;color:#ffffffe6}.btn-text{flex:1;text-align:left;white-space:nowrap}.threshold-control{display:flex;flex-direction:column;gap:8px}.threshold-control label{font-size:13px;color:#666;display:flex;justify-content:space-between}.threshold-control input[type=range]{width:100%;cursor:pointer;height:6px;border-radius:3px;-webkit-appearance:none;background:#e0e0e0}.threshold-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#2196f3;cursor:pointer;box-shadow:0 1px 3px #0003}.threshold-control input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#2196f3;cursor:pointer;border:none;box-shadow:0 1px 3px #0003}.threshold-value{font-weight:600;color:#2196f3}#file-input{display:none}.preview-section{flex:1;display:flex;flex-direction:column;min-height:0}.preview-container{flex:1;min-height:120px;margin-bottom:12px;border:1px solid #ddd;border-radius:6px;overflow:hidden;position:relative}.checkerboard{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(45deg,#e0e0e0 25%,transparent 25%),linear-gradient(-45deg,#e0e0e0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e0e0e0 75%),linear-gradient(-45deg,transparent 75%,#e0e0e0 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px;background-color:#fff}.preview-svg-wrapper{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;padding:8px}.preview-svg-wrapper svg{max-width:100%;max-height:100%;pointer-events:none}.preview-svg-wrapper[draggable=true]{cursor:grab;user-select:none;-webkit-user-select:none}.preview-svg-wrapper[draggable=true]:active{cursor:grabbing}.preview-svg-wrapper.dragging{opacity:.7;cursor:grabbing}.preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#999;font-size:12px}.export-buttons{display:flex;gap:8px}.export-buttons button{flex:1;margin-bottom:0;white-space:nowrap;overflow:hidden;padding:8px 10px}.export-buttons .btn-text{overflow:hidden;text-overflow:ellipsis}.export-buttons .kbd{padding:2px 4px;font-size:9px;flex-shrink:0}@media(max-width:768px){body{flex-direction:column}.sidebar{width:100%;border-left:none;border-top:1px solid #ddd;max-height:40vh}.preview-container{min-height:100px}.kbd{display:none}}.color-replace-row{display:flex;align-items:center;gap:6px;margin-bottom:12px}.color-box{width:32px;height:32px;border:2px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;flex-shrink:0;transition:all .2s ease;box-shadow:inset 0 1px 3px #0000001a}.color-box:hover{border-color:#2196f3;transform:scale(1.05)}.color-picker-hidden{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.eyedropper-btn{width:32px!important;height:32px;padding:6px!important;margin:0!important;display:flex!important;align-items:center;justify-content:center;flex-shrink:0;border-radius:6px!important}.eyedropper-btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:2}.eyedropper-btn.active{background:linear-gradient(to bottom,#2196f3,#1e88e5)!important;border-color:#1976d2!important;color:#fff;box-shadow:0 2px 4px #2196f34d}.eyedropper-btn.active svg{stroke:#fff}.arrow-icon{color:#999;font-size:18px;flex-shrink:0;font-weight:700}#replace-color-btn{flex:1;margin:0!important;min-width:50px;height:32px;padding:0 12px!important}.eyedropper-mode,.eyedropper-mode *{cursor:crosshair!important}.btn-icon{width:16px;height:16px;flex-shrink:0}
