*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{color:#333;background:#f0f2f5;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px}.app-layout{height:100vh;display:flex;overflow:hidden}.control-panel{background:#fff;border-right:1px solid #e0e0e0;flex-direction:column;gap:4px;width:280px;min-width:280px;padding:20px 16px;display:flex;overflow-y:auto}.panel-title{color:#1a1a1a;border-bottom:2px solid #409eff;margin-bottom:12px;padding-bottom:12px;font-size:18px;font-weight:700}.control-group{border-bottom:1px solid #f0f0f0;padding:10px 0}.control-label{color:#555;margin-bottom:8px;font-size:13px;font-weight:600;display:block}.control-select{cursor:pointer;background:#fff;border:1px solid #d0d0d0;border-radius:6px;outline:none;width:100%;padding:8px 10px;font-size:14px;transition:border-color .2s}.control-select:focus{border-color:#409eff}.control-input{border:1px solid #d0d0d0;border-radius:6px;outline:none;width:80px;padding:8px 10px;font-size:14px;transition:border-color .2s}.control-input:focus{border-color:#409eff}.modal-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:10px;flex-direction:column;width:90vw;height:85vh;display:flex;overflow:hidden;box-shadow:0 8px 32px #00000040}.modal-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:12px 16px;font-size:15px;font-weight:600;display:flex}.modal-close{cursor:pointer;color:#999;background:0 0;border:none;font-size:22px;line-height:1}.modal-close:hover{color:#333}.modal-body{flex-direction:column;flex:1;padding:16px;display:flex;overflow:hidden}.modal-image-wrap{cursor:crosshair;background:#f5f5f5;border-radius:6px;flex:1;justify-content:center;align-items:center;margin-bottom:12px;display:flex;position:relative;overflow:hidden}.modal-image{object-fit:contain;-webkit-user-select:none;user-select:none;pointer-events:none;max-width:100%;max-height:100%}.selection-overlay{pointer-events:none;background:#409eff26;position:absolute}.sel-border{pointer-events:none;background:#409eff;position:absolute}.sel-left,.sel-right{width:2px}.sel-top,.sel-bottom{height:2px}.loupe-canvas{pointer-events:none;z-index:10;image-rendering:pixelated;position:absolute;box-shadow:0 4px 16px #00000059}.cursor-cross{pointer-events:none;z-index:5;width:20px;height:20px;position:absolute;transform:translate(-50%,-50%)}.cursor-cross:before,.cursor-cross:after{content:"";background:#409eff;position:absolute}.cursor-cross:before{width:2px;height:100%;top:0;left:50%;transform:translate(-50%)}.cursor-cross:after{width:100%;height:2px;top:50%;left:0;transform:translateY(-50%)}.region-info{color:#666;text-align:center;margin-bottom:10px;font-size:12px}.pattern-row{flex-direction:column;align-items:center;gap:4px;margin-bottom:12px;display:flex}.pattern-row label{color:#666;font-size:13px}.modal-actions{border-top:1px solid #eee;justify-content:flex-end;gap:10px;padding:12px 16px;display:flex}.btn{cursor:pointer;border:1px solid #0000;border-radius:6px;padding:8px 24px;font-size:14px;font-weight:600;transition:all .2s}.btn-primary{color:#fff;background:#409eff;border-color:#409eff}.btn-primary:hover{background:#337ecc}.btn-primary:disabled{cursor:not-allowed;background:#b3d8ff;border-color:#b3d8ff}.btn-secondary{color:#666;background:#fff;border-color:#d0d0d0}.btn-secondary:hover{color:#409eff;border-color:#409eff}.pattern-counts{align-items:center;gap:4px;margin-top:4px;display:flex}.count-input{width:58px}.count-sep{color:#999;font-weight:600}.input-with-unit{align-items:center;gap:6px;display:flex}.unit{color:#999;font-size:13px}.hint{color:#999;margin-top:6px;font-size:12px;line-height:1.5}.custom-size{flex-direction:column;gap:8px;margin-top:10px;display:flex}.size-row{align-items:center;gap:6px;display:flex}.size-label{color:#666;text-align:right;width:20px;font-size:13px}.size-input,.small-input{width:70px}.upload-zone{text-align:center;cursor:pointer;border:2px dashed #d0d0d0;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:80px;padding:16px;transition:border-color .2s,background .2s;display:flex}.upload-zone:hover,.upload-zone.dragover{background:#ecf5ff;border-color:#409eff}.upload-icon{color:#409eff;font-size:28px;line-height:1}.upload-text{color:#555;font-size:13px}.upload-formats{color:#aaa;font-size:11px}.image-preview-small{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.image-preview-small img{object-fit:contain;border-radius:4px;max-width:100%;max-height:120px}.image-actions{gap:8px;display:flex}.btn-reselect,.btn-remove{cursor:pointer;background:#fff;border-radius:4px;padding:4px 12px;font-size:12px;transition:background .2s}.btn-reselect{color:#409eff;border:1px solid #409eff}.btn-reselect:hover{background:#ecf5ff}.btn-remove{color:#f56c6c;border:1px solid #f56c6c}.btn-remove:hover{background:#fef0f0}.calibrate-section{text-align:center;background:#f8f9fa;border-radius:6px;padding:12px}.calibrate-controls{justify-content:center;align-items:center;gap:12px;margin-bottom:8px;display:flex}.cal-btn{cursor:pointer;background:#fff;border:1px solid #d0d0d0;border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;font-weight:600;transition:all .15s;display:flex}.cal-btn:hover{color:#409eff;background:#ecf5ff;border-color:#409eff}.cal-val{color:#409eff;text-align:center;min-width:56px;font-size:18px;font-weight:700}.print-section{margin-top:auto;padding-top:16px;border-bottom:none!important}.btn-download{color:#409eff;cursor:pointer;background:#fff;border:1px solid #409eff;border-radius:8px;width:100%;margin-bottom:8px;padding:10px 0;font-size:14px;font-weight:600;transition:all .2s}.btn-download:hover{background:#ecf5ff}.btn-print{color:#fff;cursor:pointer;background:#409eff;border:none;border-radius:8px;width:100%;padding:12px 0;font-size:16px;font-weight:600;transition:background .2s}.btn-print:hover{background:#337ecc}.btn-print:active{background:#2a6cb0}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.preview-area{-webkit-user-select:none;user-select:none;cursor:grab;background:#e8eaed;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:20px;display:flex;position:relative;overflow:hidden}.preview-area:active{cursor:grabbing}.preview-viewport{will-change:transform;justify-content:center;align-items:center;display:flex;overflow:visible}.preview-canvas{image-rendering:auto;pointer-events:none;width:100%;height:100%;box-shadow:0 2px 12px #00000026}.drag-hint{color:#909399;background:#ffffffd9;border-radius:20px;padding:4px 14px;font-size:12px;line-height:1.5}.viewport-overlay{pointer-events:none;z-index:10;flex-direction:column;align-items:center;gap:6px;display:flex;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.viewport-overlay>*{pointer-events:auto}.viewport-controls{background:#ffffffe6;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;display:flex;box-shadow:0 1px 4px #0000001a}.vz-btn{color:#555;cursor:pointer;background:#fff;border:1px solid #d0d0d0;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;font-weight:600;line-height:1;transition:all .15s;display:flex}.vz-btn:hover{color:#409eff;background:#f0f0f0;border-color:#409eff}.vz-reset{border-radius:14px;width:auto;padding:0 10px;font-size:12px}.vz-input{text-align:center;color:#333;-moz-appearance:textfield;border:1px solid #d0d0d0;border-radius:4px;outline:none;width:50px;padding:4px;font-size:13px;font-weight:600}.vz-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.vz-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.vz-input:focus{border-color:#409eff}.vz-unit{color:#888;font-size:12px;font-weight:600}
