.upload-area{border:3px dashed #b0bec5;border-radius:12px;padding:60px 20px;text-align:center;background:#fff;transition:all .3s ease;cursor:pointer}:global(body.dark-mode) .upload-area,:global(.dark-mode) .upload-area{border-color:#546e7a;background:#2d2d2d!important}.upload-area:hover,.upload-area.drag-active{border-color:#4dd0e1;background:#e0f7fa}:global(.dark-mode) .upload-area:hover,:global(.dark-mode) .upload-area.drag-active{border-color:#1976d2;background:#1e3a5f}.upload-content{display:flex;flex-direction:column;align-items:center;gap:15px}.upload-content svg{color:#4dd0e1;transition:color .3s ease}:global(.dark-mode) .upload-content svg{color:#64b5f6}.upload-content h3{color:#424242;font-size:1.3rem;margin:0;transition:color .3s ease}:global(.dark-mode) .upload-content h3{color:#e0e0e0}.upload-content p{color:#757575;margin:0;transition:color .3s ease}:global(.dark-mode) .upload-content p{color:#9e9e9e}.browse-button{margin-top:10px;padding:10px 24px;background:#4dd0e1;color:#006064;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}:global(.dark-mode) .browse-button{background:#1976d2;color:#e3f2fd}.browse-button:hover{background:#26c6da}:global(.dark-mode) .browse-button:hover{background:#1565c0}.crop-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.crop-modal{background:#fff;border-radius:12px;padding:20px;width:75vw;max-width:90vw;height:75vh;max-height:90vh;min-width:600px;min-height:400px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d}@media (max-width: 768px){.crop-modal{width:95vw;max-width:95vw;height:90vh;max-height:90vh;min-width:unset;min-height:unset}}body.dark-mode .crop-modal{background:#2d2d2d;box-shadow:0 8px 32px #00000080}.crop-controls-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px;background:#f5f5f5;border-radius:8px;gap:20px}body.dark-mode .crop-controls-bar{background:#1a1a1a}.crop-control-group{display:flex;align-items:center;gap:8px}.crop-control-label{font-size:.9rem;font-weight:600;color:#424242;margin-right:4px}body.dark-mode .crop-control-label{color:#e0e0e0}.crop-control-button{padding:6px 12px;border:1px solid #4dd0e1;background:#fff;color:#00838f;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:500}body.dark-mode .crop-control-button{background:#2d2d2d;border-color:#1976d2;color:#81d4fa}.crop-control-button:hover{background:#e0f7fa;border-color:#26c6da}body.dark-mode .crop-control-button:hover{background:#1e3a5f;border-color:#42a5f5}.crop-control-button.active{background:#4dd0e1;color:#fff;border-color:#4dd0e1}body.dark-mode .crop-control-button.active{background:#1976d2;color:#fff;border-color:#1976d2}.crop-color-button{min-width:60px}.crop-color-button.active{color:#fff;font-weight:600}.crop-color-button.active[style*="background-color: rgb(255, 255, 255)"]{color:#000}.crop-preview-container{position:relative;display:flex;justify-content:center;align-items:center;flex:1;min-height:0;overflow:hidden;border-radius:8px;background:#f5f5f5;width:100%;height:60vh;max-height:60vh}body.dark-mode .crop-preview-container{background:#1a1a1a}.crop-image-wrapper{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center;min-width:0;min-height:0;max-width:100%;max-height:100%}.crop-preview-image{width:100%;height:100%;object-fit:contain;display:block;-webkit-user-select:none;user-select:none;pointer-events:none}.crop-mask{position:absolute;background:transparent;pointer-events:none}.crop-overlay{position:absolute;border:3px solid;background:transparent;cursor:move;box-shadow:0 0 0 9999px #00000080;z-index:10;pointer-events:auto}.crop-handle{position:absolute;pointer-events:auto}.crop-handle-center{top:50%;left:50%;transform:translate(-50%,-50%);width:12px;height:12px;border:2px solid #ffffff;border-radius:50%;cursor:move}body.dark-mode .crop-handle-center{border-color:#e0e0e0}.crop-grid-line{position:absolute;pointer-events:none;opacity:.5}.crop-grid-line-vertical{top:0;bottom:0;width:1px;transform:translate(-50%)}.crop-grid-line-horizontal{left:0;right:0;height:1px;transform:translateY(-50%)}.crop-grid-line-main{opacity:.8}.crop-grid-line-vertical.crop-grid-line-main{width:2px}.crop-grid-line-horizontal.crop-grid-line-main{height:2px}.crop-handle-resize{bottom:-6px;right:-6px;width:24px;height:24px;background:#ff9800;border:2px solid #ffffff;border-radius:50%;cursor:nwse-resize;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 2px 4px #0000004d;pointer-events:auto}body.dark-mode .crop-handle-resize{background:#f57c00;border-color:#fff;box-shadow:0 2px 4px #00000080}.crop-handle-resize:hover{background:#fb8c00;transform:scale(1.1)}body.dark-mode .crop-handle-resize:hover{background:#ef6c00}.crop-handle-resize svg{width:12px;height:12px}.crop-instructions{margin-top:16px;text-align:center;color:#616161;font-size:.9rem;font-weight:500}body.dark-mode .crop-instructions{color:#b0b0b0}.crop-actions{margin-top:16px;display:flex;justify-content:flex-end;gap:12px}.crop-rotate-button,.crop-cancel-button,.crop-apply-button{padding:10px 20px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s}.crop-rotate-button{background:#ff9800;color:#fff;margin-right:auto}body.dark-mode .crop-rotate-button{background:#f57c00;color:#fff}.crop-rotate-button:hover{background:#fb8c00}body.dark-mode .crop-rotate-button:hover{background:#ef6c00}.crop-cancel-button{background:#e0e0e0;color:#212121}body.dark-mode .crop-cancel-button{background:#404040;color:#e0e0e0}.crop-cancel-button:hover{background:#d0d0d0}body.dark-mode .crop-cancel-button:hover{background:#505050}.crop-apply-button{background:#4dd0e1;color:#006064}body.dark-mode .crop-apply-button{background:#1976d2;color:#e3f2fd}.crop-apply-button:hover{background:#26c6da}body.dark-mode .crop-apply-button:hover{background:#1565c0}.crop-rotate-button{padding:8px 12px;background:#e0f7fa;color:#00838f;border:1px solid #4dd0e1;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}body.dark-mode .crop-rotate-button{background:#1e3a5f;color:#81d4fa;border-color:#1976d2}.crop-rotate-button:hover{background:#b2ebf2;border-color:#26c6da;transform:translateY(-1px)}body.dark-mode .crop-rotate-button:hover{background:#2c5282;border-color:#42a5f5}.pixelation-controls{background:#fff;padding:15px 20px;border-radius:8px;border:1px solid #e0e0e0;transition:background-color .3s ease,border-color .3s ease}body.dark-mode .pixelation-controls{background:#2d2d2d!important;border-color:#404040}.controls-header{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #e0e0e0;transition:border-color .3s ease}body.dark-mode .controls-header{border-bottom-color:#404040}.header-row{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;align-items:center}.header-left{display:flex;align-items:center;gap:15px;flex-wrap:wrap}.header-right{display:flex;align-items:center;gap:15px;justify-content:flex-start}.crop-crunch-buttons{display:flex;align-items:center;gap:8px;flex-shrink:0}.crop-button-container,.crunch-button-container{position:relative}.crop-button,.crunch-button{padding:8px 16px;background:#4dd0e1;color:#006064;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}body.dark-mode .crop-button,body.dark-mode .crunch-button{background:#1976d2;color:#e3f2fd}.crop-button:hover,.crunch-button:hover{background:#26c6da}body.dark-mode .crop-button:hover,body.dark-mode .crunch-button:hover{background:#1565c0}.crop-button:disabled,.crunch-button:disabled{opacity:.5;cursor:not-allowed}.crop-menu{position:absolute;top:100%;left:0;margin-top:0;padding-top:4px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:150px;display:flex;flex-direction:column;overflow:hidden}body.dark-mode .crop-menu{background:#2d2d2d;border-color:#404040;box-shadow:0 4px 12px #0000004d}.crop-menu button{padding:10px 16px;border:none;background:transparent;color:#212121;text-align:left;cursor:pointer;font-size:.9rem;transition:background .2s,color .2s}body.dark-mode .crop-menu button{color:#e0e0e0}.crop-menu button:hover{background:#f5f5f5;color:#006064}body.dark-mode .crop-menu button:hover{background:#404040;color:#e3f2fd}.crop-menu button:not(:last-child),.crunch-menu button:not(:last-child){border-bottom:1px solid #e0e0e0}body.dark-mode .crop-menu button:not(:last-child),body.dark-mode .crunch-menu button:not(:last-child){border-bottom-color:#404040}.crop-menu button:disabled,.crunch-menu button:disabled{opacity:.5;cursor:not-allowed}.crop-menu button:disabled:hover,.crunch-menu button:disabled:hover{background:transparent;color:inherit}body.dark-mode .crop-menu button:disabled:hover,body.dark-mode .crunch-menu button:disabled:hover{background:transparent;color:inherit}.menu-separator{height:1px;background:#e0e0e0;margin:4px 0}body.dark-mode .menu-separator{background:#404040}.crunch-menu{position:absolute;top:100%;left:0;margin-top:0;padding-top:4px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:150px;display:flex;flex-direction:column;overflow:hidden}body.dark-mode .crunch-menu{background:#2d2d2d;border-color:#404040;box-shadow:0 4px 12px #0000004d}.crunch-menu button{padding:10px 16px;border:none;background:transparent;color:#212121;text-align:left;cursor:pointer;font-size:.9rem;transition:background .2s,color .2s}body.dark-mode .crunch-menu button{color:#e0e0e0}.crunch-menu button:hover:not(:disabled){background:#f5f5f5;color:#006064}body.dark-mode .crunch-menu button:hover:not(:disabled){background:#404040;color:#e3f2fd}.header-method-select{display:flex;align-items:center}.method-select-header{padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:.9rem;background:#fff;color:#212121;transition:border-color .2s,background-color .3s ease,color .3s ease;width:auto;min-width:200px;max-width:600px}body.dark-mode .method-select-header{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.method-select-header:focus{outline:none;border-color:#4dd0e1}body.dark-mode .method-select-header:focus{border-color:#1976d2}.header-px2-input{display:flex;align-items:center}.px2-input-container-header{display:flex;align-items:center;gap:6px}.px2-input-header{width:100px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:1.1rem;font-weight:600;background:#fff;color:#212121;transition:border-color .2s,background-color .3s ease,color .3s ease;text-align:center}body.dark-mode .px2-input-header{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.px2-input-header:focus{outline:none;border-color:#4dd0e1}body.dark-mode .px2-input-header:focus{border-color:#1976d2}.px2-label-header{font-size:1.1rem;color:#616161;font-weight:600;transition:color .3s ease}body.dark-mode .px2-label-header{color:#b0b0b0}.download-button{padding:8px 16px;background:#4dd0e1;color:#006064;border:none;border-radius:6px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap;min-width:44px;display:flex;align-items:center;justify-content:center}body.dark-mode .download-button{background:#1976d2;color:#e3f2fd}.download-button:hover{background:#26c6da}body.dark-mode .download-button:hover{background:#1565c0}.process-button-image{padding:8px 16px;background:#4dd0e1;color:#006064;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}body.dark-mode .process-button-image{background:#1976d2;color:#e3f2fd}.process-button-image:hover{background:#26c6da}body.dark-mode .process-button-image:hover{background:#1565c0}.toggle-label{display:flex;align-items:center;gap:10px;font-weight:600;color:#424242;cursor:pointer;transition:color .3s ease;margin-left:auto}body.dark-mode .toggle-label{color:#e0e0e0}.toggle-label input[type=checkbox].toggle-switch{width:44px;height:24px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ccc;border-radius:12px;position:relative;transition:background .3s ease}.toggle-label input[type=checkbox].toggle-switch:checked{background:#4dd0e1}body.dark-mode .toggle-label input[type=checkbox].toggle-switch{background:#555}body.dark-mode .toggle-label input[type=checkbox].toggle-switch:checked{background:#1976d2}.toggle-label input[type=checkbox].toggle-switch:before{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:2px;left:2px;transition:transform .3s ease,background .3s ease}body.dark-mode .toggle-label input[type=checkbox].toggle-switch:before{background:#b0b0b0}.toggle-label input[type=checkbox].toggle-switch:checked:before{transform:translate(20px)}.controls-content{margin-top:10px;transition:border-color .3s ease}.input-group{margin-bottom:12px}.input-group label{display:block;margin-bottom:5px;color:#616161;font-weight:500;transition:color .3s ease}body.dark-mode .input-group label{color:#b0b0b0}.input-group input[type=number],.input-group select{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:1rem;background:#fff;color:#212121;transition:border-color .2s,background-color .3s ease,color .3s ease}body.dark-mode .input-group input[type=number],body.dark-mode .input-group select{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.input-group input[type=number]:focus,.input-group select:focus{outline:none;border-color:#4dd0e1}body.dark-mode .input-group input[type=number]:focus,body.dark-mode .input-group select:focus{border-color:#1976d2}.zoom-buttons{display:flex;justify-content:center;gap:8px;margin-bottom:12px}.zoom-button{padding:6px 12px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#616161;font-size:.75rem;font-weight:500;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}body.dark-mode .zoom-button{background:#2d2d2d;border-color:#404040;color:#b0b0b0}.zoom-button:hover{background:#f5f5f5;border-color:#4dd0e1;color:#006064}body.dark-mode .zoom-button:hover{background:#2d2d2d;border-color:#1976d2;color:#e3f2fd}.zoom-button.active{background:#4dd0e1;border-color:#4dd0e1;color:#006064;font-weight:600}body.dark-mode .zoom-button.active{background:#1976d2;border-color:#1976d2;color:#e3f2fd}.slider-container{display:flex;align-items:center;gap:15px;margin:20px 0;padding:10px 0}.slider-label{font-size:.85rem;color:#757575;min-width:35px;transition:color .3s ease}body.dark-mode .slider-label{color:#9e9e9e}.pixelation-slider{flex:1;height:16px;border-radius:8px;background:#e0e0e0;outline:none;-webkit-appearance:none;transition:background .3s ease;background-image:linear-gradient(to right,transparent 0%,transparent -.3%,rgba(158,158,158,.15) 0%,rgba(158,158,158,.15) .3%,transparent .3%),linear-gradient(to right,transparent calc(16.67% - .4%),rgba(158,158,158,.18) 16.67%,rgba(158,158,158,.18) 17.07%,transparent 17.07%),linear-gradient(to right,transparent 44.04%,rgba(158,158,158,.18) 44.44%,rgba(158,158,158,.18) calc(44.44% + .4%),transparent calc(44.44% + .4%)),linear-gradient(to right,transparent 71.82%,rgba(158,158,158,.18) 72.22%,rgba(158,158,158,.18) 72.62%,transparent 72.62%),linear-gradient(to right,transparent 99.7%,rgba(158,158,158,.15) 100%,rgba(158,158,158,.15) 100%),linear-gradient(to right,transparent calc(5.56% - .15%),rgba(158,158,158,.08) 5.56%,rgba(158,158,158,.08) 5.71%,transparent 5.71%),linear-gradient(to right,transparent calc(11.11% - .15%),rgba(158,158,158,.08) 11.11%,rgba(158,158,158,.08) 11.26%,transparent 11.26%),linear-gradient(to right,transparent 22.07%,rgba(158,158,158,.08) 22.22%,rgba(158,158,158,.08) calc(22.22% + .15%),transparent calc(22.22% + .15%)),linear-gradient(to right,transparent calc(27.78% - .15%),rgba(158,158,158,.08) 27.78%,rgba(158,158,158,.08) 27.93%,transparent 27.93%),linear-gradient(to right,transparent 33.18%,rgba(158,158,158,.08) 33.33%,rgba(158,158,158,.08) 33.48%,transparent 33.48%),linear-gradient(to right,transparent 38.74%,rgba(158,158,158,.08) 38.89%,rgba(158,158,158,.08) 39.04%,transparent 39.04%),linear-gradient(to right,transparent calc(55.56% - .15%),rgba(158,158,158,.08) 55.56%,rgba(158,158,158,.08) 55.71%,transparent 55.71%),linear-gradient(to right,transparent 60.96%,rgba(158,158,158,.08) 61.11%,rgba(158,158,158,.08) 61.26%,transparent 61.26%),linear-gradient(to right,transparent 66.52%,rgba(158,158,158,.08) 66.67%,rgba(158,158,158,.08) calc(66.67% + .15%),transparent calc(66.67% + .15%)),linear-gradient(to right,transparent 77.63%,rgba(158,158,158,.08) 77.78%,rgba(158,158,158,.08) 77.93%,transparent 77.93%),linear-gradient(to right,transparent calc(83.33% - .15%),rgba(158,158,158,.08) 83.33%,rgba(158,158,158,.08) 83.48%,transparent 83.48%),linear-gradient(to right,transparent 88.74%,rgba(158,158,158,.08) 88.89%,rgba(158,158,158,.08) 89.04%,transparent 89.04%),linear-gradient(to right,transparent calc(94.44% - .15%),rgba(158,158,158,.08) 94.44%,rgba(158,158,158,.08) 94.59%,transparent 94.59%);background-size:100% 100%;background-repeat:no-repeat}body.dark-mode .pixelation-slider{background:#404040;background-image:linear-gradient(to right,transparent 0%,transparent -.3%,rgba(117,117,117,.12) 0%,rgba(117,117,117,.12) .3%,transparent .3%),linear-gradient(to right,transparent calc(16.67% - .4%),rgba(117,117,117,.15) 16.67%,rgba(117,117,117,.15) 17.07%,transparent 17.07%),linear-gradient(to right,transparent 44.04%,rgba(117,117,117,.15) 44.44%,rgba(117,117,117,.15) calc(44.44% + .4%),transparent calc(44.44% + .4%)),linear-gradient(to right,transparent 71.82%,rgba(117,117,117,.15) 72.22%,rgba(117,117,117,.15) 72.62%,transparent 72.62%),linear-gradient(to right,transparent 99.7%,rgba(117,117,117,.12) 100%,rgba(117,117,117,.12) 100%),linear-gradient(to right,transparent calc(5.56% - .15%),rgba(117,117,117,.06) 5.56%,rgba(117,117,117,.06) 5.71%,transparent 5.71%),linear-gradient(to right,transparent calc(11.11% - .15%),rgba(117,117,117,.06) 11.11%,rgba(117,117,117,.06) 11.26%,transparent 11.26%),linear-gradient(to right,transparent 22.07%,rgba(117,117,117,.06) 22.22%,rgba(117,117,117,.06) calc(22.22% + .15%),transparent calc(22.22% + .15%)),linear-gradient(to right,transparent calc(27.78% - .15%),rgba(117,117,117,.06) 27.78%,rgba(117,117,117,.06) 27.93%,transparent 27.93%),linear-gradient(to right,transparent 33.18%,rgba(117,117,117,.06) 33.33%,rgba(117,117,117,.06) 33.48%,transparent 33.48%),linear-gradient(to right,transparent 38.74%,rgba(117,117,117,.06) 38.89%,rgba(117,117,117,.06) 39.04%,transparent 39.04%),linear-gradient(to right,transparent calc(55.56% - .15%),rgba(117,117,117,.06) 55.56%,rgba(117,117,117,.06) 55.71%,transparent 55.71%),linear-gradient(to right,transparent 60.96%,rgba(117,117,117,.06) 61.11%,rgba(117,117,117,.06) 61.26%,transparent 61.26%),linear-gradient(to right,transparent 66.52%,rgba(117,117,117,.06) 66.67%,rgba(117,117,117,.06) calc(66.67% + .15%),transparent calc(66.67% + .15%)),linear-gradient(to right,transparent 77.63%,rgba(117,117,117,.06) 77.78%,rgba(117,117,117,.06) 77.93%,transparent 77.93%),linear-gradient(to right,transparent calc(83.33% - .15%),rgba(117,117,117,.06) 83.33%,rgba(117,117,117,.06) 83.48%,transparent 83.48%),linear-gradient(to right,transparent 88.74%,rgba(117,117,117,.06) 88.89%,rgba(117,117,117,.06) 89.04%,transparent 89.04%),linear-gradient(to right,transparent calc(94.44% - .15%),rgba(117,117,117,.06) 94.44%,rgba(117,117,117,.06) 94.59%,transparent 94.59%);background-size:100% 100%;background-repeat:no-repeat}.pixelation-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:36px;height:36px;border-radius:50%;background:#4dd0e1;cursor:pointer;transition:background .3s ease,transform .2s ease;box-shadow:0 2px 6px #0003}body.dark-mode .pixelation-slider::-webkit-slider-thumb{background:#1976d2;box-shadow:0 2px 6px #0006}.pixelation-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.pixelation-slider::-moz-range-thumb{width:36px;height:36px;border-radius:50%;background:#4dd0e1;cursor:pointer;border:none;transition:background .3s ease,transform .2s ease;box-shadow:0 2px 6px #0003}body.dark-mode .pixelation-slider::-moz-range-thumb{background:#1976d2;box-shadow:0 2px 6px #0006}.pixelation-slider::-moz-range-thumb:hover{transform:scale(1.1)}.slider-labels-bottom{display:flex;justify-content:space-between;font-size:.75rem;color:#9e9e9e;margin-top:5px;transition:color .3s ease}body.dark-mode .slider-labels-bottom{color:#757575}.info-text{margin-top:10px;padding:10px;background:#e0f7fa;border-radius:6px;color:#00838f;transition:background-color .3s ease,color .3s ease;position:relative}.info-text-nav-buttons{position:absolute;bottom:8px;left:8px;display:flex;align-items:center;gap:6px}body.dark-mode .info-text{background:#1e3a5f;color:#81d4fa}.info-text small{font-size:.85rem;text-align:center;display:block}.info-text-buttons{position:absolute;bottom:8px;right:8px;display:flex;align-items:center;gap:8px}.info-text-buttons .download-button-info,.theme-toggle-info{background:#ffffff4d;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:4px 8px;font-size:1rem;cursor:pointer;transition:all .3s ease}body.dark-mode .info-text-buttons .download-button-info,body.dark-mode .theme-toggle-info{background:#0000004d;border-color:#ffffff1a}.info-text-buttons .download-button-info:hover,.theme-toggle-info:hover{background:#ffffff80;transform:scale(1.1)}body.dark-mode .info-text-buttons .download-button-info:hover,body.dark-mode .theme-toggle-info:hover{background:#00000080}.precision-button{width:28px;height:28px;padding:0;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#616161;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,border-color .2s ease,color .2s ease,transform .1s ease;flex-shrink:0}body.dark-mode .precision-button{background:#2d2d2d;border-color:#404040;color:#b0b0b0}.precision-button:hover{background:#f5f5f5;border-color:#4dd0e1;color:#006064;transform:scale(1.05)}body.dark-mode .precision-button:hover{background:#2d2d2d;border-color:#1976d2;color:#e3f2fd}.precision-button:active{transform:scale(.95)}.pixel-size-input-container{display:flex;align-items:center;gap:8px;margin-top:5px}.pixel-size-input{width:80px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:1rem;background:#fff;color:#212121;transition:border-color .2s,background-color .3s ease,color .3s ease;text-align:center}body.dark-mode .pixel-size-input{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.pixel-size-input:focus{outline:none;border-color:#4dd0e1}body.dark-mode .pixel-size-input:focus{border-color:#1976d2}.pixel-size-label{font-size:.9rem;color:#616161;font-weight:500;transition:color .3s ease}body.dark-mode .pixel-size-label{color:#b0b0b0}.px2-input-container{display:flex;align-items:center;gap:6px;margin-bottom:12px;justify-content:center}.px2-input{width:100px;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:1.1rem;font-weight:600;background:#fff;color:#212121;transition:border-color .2s,background-color .3s ease,color .3s ease;text-align:center}body.dark-mode .px2-input{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.px2-input:focus{outline:none;border-color:#4dd0e1}body.dark-mode .px2-input:focus{border-color:#1976d2}.px2-label{font-size:1.1rem;color:#616161;font-weight:600;transition:color .3s ease}body.dark-mode .px2-label{color:#b0b0b0}.image-preview{margin:0}.preview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.preview-item h3{margin-bottom:10px;color:#424242;font-size:1rem;font-weight:600;transition:color .3s ease}body.dark-mode .preview-item h3{color:#e0e0e0}.image-container{position:relative;background:#fff;border-radius:8px;padding:8px;border:1px solid #e0e0e0;transition:background-color .3s ease,border-color .3s ease;min-height:250px;max-height:350px;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.image-container img{position:relative;z-index:1}body.dark-mode .image-container{background:#3d3d3d!important;border-color:#404040}.image-container img{width:100%;height:auto;border-radius:6px;display:block;max-height:400px;object-fit:contain}.original-image-container{position:relative}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000;display:flex;align-items:center;justify-content:center;border-radius:8px;opacity:0;transition:opacity .3s ease,background .3s ease;pointer-events:none;z-index:10}.original-image-container:hover .image-overlay{opacity:1;background:#00000080;pointer-events:all}.change-image-button{width:48px;height:48px;border-radius:50%;background:#ffffffe6;border:2px solid rgba(0,0,0,.2);color:#424242;font-size:32px;font-weight:300;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;margin:0;z-index:11;position:relative}.change-image-button:hover{background:#fff;transform:scale(1.1);border-color:#0000004d}body.dark-mode .change-image-button{background:#2d2d2de6;border-color:#fff3;color:#e0e0e0}body.dark-mode .change-image-button:hover{background:#2d2d2d;border-color:#ffffff4d}.placeholder{background:#fff;border:2px dashed #b0bec5;border-radius:8px;padding:60px 20px;text-align:center;color:#9e9e9e;transition:background-color .3s ease,border-color .3s ease,color .3s ease}body.dark-mode .placeholder{background:#3d3d3d!important;border-color:#546e7a;color:#757575}@media (max-width: 768px){.preview-grid{grid-template-columns:1fr}}.info-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease}.info-modal{position:relative;background:#fff;border-radius:12px;width:min(90vw,900px);max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;animation:slideUp .2s ease}body.dark-mode .info-modal{background:#2d2d2d;box-shadow:0 8px 32px #00000080}.info-modal-close{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:#0009;border:2px solid rgba(255,255,255,.8);color:#fff;font-size:24px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;padding:0;line-height:1}body.dark-mode .info-modal-close{background:#fff3;border-color:#fff9;color:#fff}.info-modal-close:hover{background:#000c;transform:scale(1.1)}body.dark-mode .info-modal-close:hover{background:#ffffff4d}.info-modal-content{padding:40px;overflow-y:auto;max-height:calc(90vh - 80px);color:#212121;line-height:1.6}body.dark-mode .info-modal-content{color:#e0e0e0}.info-modal-content h1{font-size:2rem;font-weight:700;margin:0 0 1.5rem;color:#00838f;border-bottom:2px solid #4dd0e1;padding-bottom:.5rem}body.dark-mode .info-modal-content h1{color:#81d4fa;border-bottom-color:#1976d2}.info-modal-content h2{font-size:1.5rem;font-weight:600;margin:2rem 0 1rem;color:#00838f}body.dark-mode .info-modal-content h2{color:#81d4fa}.info-modal-content h3{font-size:1.25rem;font-weight:600;margin:1.5rem 0 .75rem;color:#006064}body.dark-mode .info-modal-content h3{color:#90caf9}.info-modal-content h4{font-size:1.1rem;font-weight:600;margin:1.25rem 0 .5rem;color:#006064}body.dark-mode .info-modal-content h4{color:#90caf9}.info-modal-content p{margin:.75rem 0}.info-modal-content ul{margin:.75rem 0;padding-left:2rem}.info-modal-content li{margin:.5rem 0}.info-modal-content strong{font-weight:600;color:#00838f}body.dark-mode .info-modal-content strong{color:#81d4fa}.info-hr{border:none;border-top:1px solid #e0e0e0;margin:2rem 0}body.dark-mode .info-hr{border-top-color:#404040}.info-code-block{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:4px;padding:1rem;margin:1rem 0;overflow-x:auto;font-family:Courier New,monospace;font-size:.9rem}body.dark-mode .info-code-block{background:#1a1a1a;border-color:#404040;color:#e0e0e0}.info-code-block code{color:#212121}body.dark-mode .info-code-block code{color:#e0e0e0}.info-modal-content::-webkit-scrollbar{width:8px}.info-modal-content::-webkit-scrollbar-track{background:#f5f5f5;border-radius:4px}body.dark-mode .info-modal-content::-webkit-scrollbar-track{background:#1a1a1a}.info-modal-content::-webkit-scrollbar-thumb{background:#9e9e9e;border-radius:4px}.info-modal-content::-webkit-scrollbar-thumb:hover{background:#757575}body.dark-mode .info-modal-content::-webkit-scrollbar-thumb{background:#616161}body.dark-mode .info-modal-content::-webkit-scrollbar-thumb:hover{background:#757575}.info-toc{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin:2rem 0}body.dark-mode .info-toc{background:#1a1a1a;border-color:#404040}.info-toc-title{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:#00838f}body.dark-mode .info-toc-title{color:#81d4fa}.info-toc-list{list-style:none;padding:0;margin:0}.info-toc-item{margin:.25rem 0;line-height:1.5}.info-toc-level-2{padding-left:0;font-weight:500}.info-toc-level-3{padding-left:1.5rem;font-size:.95rem}.info-toc-expandable-wrapper{display:flex;align-items:center;gap:.5rem}.info-toc-expand-button{background:none;border:none;padding:0;margin:0;cursor:pointer;display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;transition:transform .2s ease}.info-toc-expand-button:hover{transform:scale(1.1)}.info-toc-expand-icon{display:inline-block;width:12px;font-size:.8rem;color:#00838f;transition:transform .2s ease;-webkit-user-select:none;user-select:none}body.dark-mode .info-toc-expand-icon{color:#64b5f6}.info-toc-sublist{list-style:none;padding:0 0 0 1.5rem;margin:0;border-left:2px solid #e0e0e0}body.dark-mode .info-toc-sublist{border-left-color:#404040}.info-toc-sublist-nested{padding-left:1.5rem;margin-top:.25rem;margin-bottom:.25rem}.info-toc-link{color:#00838f;text-decoration:none;transition:color .2s ease;display:block}body.dark-mode .info-toc-link{color:#64b5f6}.info-toc-link:hover{color:#006064;text-decoration:underline}body.dark-mode .info-toc-link:hover{color:#90caf9}.info-toc-link:active{color:#004d40}body.dark-mode .info-toc-link:active{color:#b3e5fc}.info-modal-content{scroll-behavior:smooth}.info-modal-content h1[id],.info-modal-content h2[id],.info-modal-content h3[id],.info-modal-content h4[id]{scroll-margin-top:20px}.app{background:#fff;height:100vh;display:flex;flex-direction:column;overflow-y:auto;transition:background-color .3s ease}.app.dark-mode{background:#2d2d2d}.app-content{padding:15px 20px;background:#fafafa;transition:background-color .3s ease;display:flex;flex-direction:column;flex:1;overflow-y:auto;min-height:0}.app.dark-mode .app-content{background:#252525}.upload-section{margin-bottom:15px;flex-shrink:0}.error-message{background:#ffebee;color:#c62828;padding:12px;border-radius:6px;margin-top:15px;border:1px solid #ffcdd2;transition:background-color .3s ease,border-color .3s ease}.app.dark-mode .error-message{background:#4a1f1f;color:#ef5350;border-color:#6a2f2f}.controls-section{margin-bottom:30px}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:25px}.control-group{background:#fff;padding:20px;border-radius:8px;border:1px solid #e0e0e0;transition:background-color .3s ease,border-color .3s ease}.app.dark-mode .control-group{background:#2d2d2d;border-color:#404040}.control-group h3{margin-bottom:15px;color:#424242;font-size:1.1rem;transition:color .3s ease}.app.dark-mode .control-group h3{color:#e0e0e0}.control-group label{display:block;margin-bottom:10px;color:#616161;cursor:pointer;transition:color .3s ease}.app.dark-mode .control-group label{color:#b0b0b0}.control-group input[type=number],.control-group input[type=range]{width:100%;margin:10px 0}.control-group input[type=radio]{margin-right:8px;cursor:pointer}.control-group input[type=radio]:checked{accent-color:#4dd0e1}.app.dark-mode .control-group input[type=radio]:checked{accent-color:#1976d2}.radio-group{display:flex;flex-direction:column;gap:10px}.process-button{width:100%;padding:12px;background:linear-gradient(135deg,#4dd0e1,#26c6da);color:#006064;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,background .3s ease;margin-top:10px}.app.dark-mode .process-button{background:linear-gradient(135deg,#1976d2,#1565c0);color:#e3f2fd}.process-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #4dd0e166}.app.dark-mode .process-button:hover:not(:disabled){box-shadow:0 5px 15px #1976d266}.process-button:disabled{opacity:.6;cursor:not-allowed}.preview-section{margin-top:30px}.image-display-section{margin-bottom:15px;flex-shrink:0}.controls-section{margin-bottom:10px;flex-shrink:0}.app.dark-mode .app-footer{background:#2d2d2d;border-top-color:#404040}.app.dark-mode .footer-link{color:#64b5f6}.app.dark-mode .footer-link:hover{color:#90caf9}.app.dark-mode .footer-separator{color:#616161}.app.dark-mode .footer-info-button{color:#64b5f6}.app.dark-mode .footer-info-button:hover{color:#90caf9}@media (max-width: 768px){.controls-grid{grid-template-columns:1fr}}.batch-thumbnails-grid{margin-bottom:20px;width:100%}.thumbnails-label{font-size:.9rem;font-weight:600;color:#424242;margin-bottom:10px;transition:color .3s ease}body.dark-mode .thumbnails-label{color:#e0e0e0}.thumbnails-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:15px}.thumbnail-item{position:relative;background:#fff;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;transition:background-color .3s ease,border-color .3s ease}body.dark-mode .thumbnail-item{background:#2d2d2d;border-color:#404040}.thumbnail-image{width:100%;height:120px;object-fit:contain;display:block;background:#fafafa;transition:opacity .2s ease}body.dark-mode .thumbnail-image{background:#252525}.thumbnail-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#0000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;transition:opacity .3s ease,background .3s ease;pointer-events:none}.thumbnail-item:hover .thumbnail-overlay{opacity:1;background:#00000080}.remove-thumbnail-button{width:32px;height:32px;border-radius:50%;background:#ffffffe6;border:1px solid rgba(0,0,0,.2);color:#c62828;font-size:20px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;line-height:1;pointer-events:auto}body.dark-mode .remove-thumbnail-button{background:#2d2d2de6;border-color:#fff3;color:#ef5350}.remove-thumbnail-button:hover:not(:disabled){background:#fff;transform:scale(1.1)}body.dark-mode .remove-thumbnail-button:hover:not(:disabled){background:#2d2d2d}.remove-thumbnail-button:disabled{opacity:.5;cursor:not-allowed}.target-thumbnail{border:2px solid #4dd0e1;background:#fff;position:relative}.target-thumbnail .thumbnail-image{transition:opacity .2s ease,transform .2s ease}body.dark-mode .target-thumbnail{border-color:#1976d2;background:#2d2d2d}.target-thumbnail:hover .thumbnail-overlay{opacity:1;background:#00000080}.upload-placeholder-button{width:100%;height:120px;background:#fff;border:2px dashed #4dd0e1;border-radius:6px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:0;gap:8px}body.dark-mode .upload-placeholder-button{background:#2d2d2d;border-color:#1976d2}.upload-placeholder-button:hover:not(:disabled){background:#e0f7fa;border-color:#26c6da;transform:scale(1.02)}body.dark-mode .upload-placeholder-button:hover:not(:disabled){background:#1e3a5f;border-color:#42a5f5}.upload-placeholder-button:disabled{opacity:.5;cursor:not-allowed}.upload-placeholder-icon{font-size:2rem}.upload-placeholder-text{font-size:.75rem;color:#00838f;font-weight:600}body.dark-mode .upload-placeholder-text{color:#81d4fa}.thumbnail-processed{transform:scale(1.12);z-index:1;box-shadow:0 2px 8px #00000026}body.dark-mode .thumbnail-processed{box-shadow:0 2px 8px #0000004d}.thumbnail-progress-overlay{position:absolute;bottom:0;left:0;right:0;height:4px;background:#0003;overflow:hidden}.thumbnail-progress-bar{height:100%;background:#4dd0e1;transition:width .3s ease}body.dark-mode .thumbnail-progress-bar{background:#1976d2}body.dark-mode .thumbnail-progress-overlay{background:#fff3}.batch-info-box{position:fixed;bottom:60px;left:50%;transform:translate(-50%);width:calc(100% - 40px);max-width:1200px;margin-top:10px;padding:10px;background:#e0f7fa;border-radius:6px;color:#00838f;transition:background-color .3s ease,color .3s ease;z-index:100}body.dark-mode .batch-info-box{background:#1e3a5f;color:#81d4fa}.batch-info-box small{font-size:.85rem;text-align:center;display:block}.batch-info-controls{position:absolute;bottom:8px;left:8px;right:8px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.batch-info-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.batch-info-right{display:flex;align-items:center;gap:8px;margin-left:auto}.info-text-nav-buttons{display:flex;align-items:center;gap:6px}.info-text-buttons{display:flex;align-items:center;gap:8px}.upload-button-info,.download-button-info,.theme-toggle-info,.batch-crop-button-info,.batch-crunch-button-info,.process-all-button-info,.clear-button-info{background:#ffffff4d;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:4px 10px;font-size:.85rem;font-weight:600;color:#00838f;cursor:pointer;transition:all .3s ease;white-space:nowrap;display:inline-flex;align-items:center;flex-shrink:0}body.dark-mode .batch-crop-button-info,body.dark-mode .batch-crunch-button-info,body.dark-mode .process-all-button-info,body.dark-mode .clear-button-info{background:#0000004d;border-color:#ffffff1a;color:#81d4fa}.batch-crop-button-info:hover,.batch-crunch-button-info:hover,.process-all-button-info:hover,.clear-button-info:hover{background:#ffffff80;transform:scale(1.05);color:#006064}body.dark-mode .batch-crop-button-info:hover,body.dark-mode .batch-crunch-button-info:hover,body.dark-mode .process-all-button-info:hover,body.dark-mode .clear-button-info:hover{background:#00000080;color:#90caf9}body.dark-mode .upload-button-info,body.dark-mode .download-button-info,body.dark-mode .theme-toggle-info{background:#0000004d;border-color:#ffffff1a}.upload-button-info:hover,.download-button-info:hover:not(.disabled),.theme-toggle-info:hover{background:#ffffff80;transform:scale(1.1)}body.dark-mode .upload-button-info:hover,body.dark-mode .download-button-info:hover:not(.disabled),body.dark-mode .theme-toggle-info:hover{background:#00000080}.download-button-info.disabled{opacity:.4;cursor:not-allowed}.nav-mode-button{background:#ffffff4d;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:4px 10px;font-size:.85rem;font-weight:600;color:#00838f;text-decoration:none;cursor:pointer;transition:all .3s ease;display:inline-block}body.dark-mode .nav-mode-button{background:#0000004d;border-color:#ffffff1a;color:#81d4fa}.nav-mode-button:hover{background:#ffffff80;transform:scale(1.05);color:#006064}body.dark-mode .nav-mode-button:hover{background:#00000080;color:#90caf9}.nav-mode-button.active{background:#fff9;color:#006064;font-weight:700}body.dark-mode .nav-mode-button.active{background:#00000080;color:#90caf9}.batch-preview-info-card{position:relative;width:calc(100% - 40px);max-width:1200px;margin:20px auto 0;margin-bottom:15px!important;padding:10px;background:#e0f7fa;border-radius:6px;color:#00838f;transition:background-color .3s ease,color .3s ease;grid-column:1 / -1}body.dark-mode .batch-preview-info-card{background:#1e3a5f;color:#81d4fa}.batch-preview-info-card small{font-size:.85rem;text-align:center;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batch-preview-info-card small strong{font-weight:600}.preview-info-buttons{position:absolute;bottom:8px;right:8px;display:flex;align-items:center;gap:8px}.download-all-button,.clear-results-button{background:#ffffff4d;border:1px solid rgba(0,0,0,.1);border-radius:6px;padding:4px 10px;font-size:.85rem;font-weight:600;color:#00838f;cursor:pointer;transition:all .3s ease;white-space:nowrap}body.dark-mode .download-all-button,body.dark-mode .clear-results-button{background:#0000004d;border-color:#ffffff1a;color:#81d4fa}.download-all-button:hover:not(:disabled),.clear-results-button:hover{background:#ffffff80;transform:scale(1.05);color:#006064}body.dark-mode .download-all-button:hover:not(:disabled),body.dark-mode .clear-results-button:hover{background:#00000080;color:#90caf9}.download-all-button:disabled{opacity:.6;cursor:not-allowed}.batch-image-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.batch-image-preview-modal{position:relative;background:#fff;border-radius:12px;width:min(90vmin,800px);height:min(90vmin,800px);padding:80px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}body.dark-mode .batch-image-preview-modal{background:#2d2d2d;box-shadow:0 8px 32px #00000080}.batch-image-preview-close{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:50%;background:#0009;border:2px solid rgba(255,255,255,.8);color:#fff;font-size:24px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;padding:0;line-height:1}body.dark-mode .batch-image-preview-close{background:#fff3;border-color:#fff9;color:#fff}.batch-image-preview-close:hover{background:#000c;transform:scale(1.1)}body.dark-mode .batch-image-preview-close:hover{background:#ffffff4d}.batch-image-preview-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#0009;border:2px solid rgba(255,255,255,.8);color:#fff;font-size:32px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;padding:0;line-height:1}body.dark-mode .batch-image-preview-nav{background:#fff3;border-color:#fff9;color:#fff}.batch-image-preview-nav:hover:not(:disabled){background:#000c;transform:translateY(-50%) scale(1.1)}body.dark-mode .batch-image-preview-nav:hover:not(:disabled){background:#ffffff4d}.batch-image-preview-nav:disabled{opacity:.3;cursor:not-allowed}.batch-image-preview-nav-prev{left:20px}.batch-image-preview-nav-next{right:20px}.batch-image-preview-controls{display:flex;gap:12px;margin-bottom:15px;justify-content:center;align-items:center;flex-wrap:wrap}.batch-image-preview-toggle{display:flex;gap:8px;justify-content:center;align-items:center}.batch-image-preview-toggle-button{padding:8px 16px;border:1px solid #4dd0e1;background:#fff;color:#00838f;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}body.dark-mode .batch-image-preview-toggle-button{background:#2d2d2d;border-color:#1976d2;color:#81d4fa}.batch-image-preview-toggle-button:hover{background:#e0f7fa;border-color:#26c6da;transform:translateY(-1px)}body.dark-mode .batch-image-preview-toggle-button:hover{background:#1e3a5f;border-color:#42a5f5}.batch-image-preview-toggle-button.active{background:#4dd0e1;color:#fff;border-color:#4dd0e1}body.dark-mode .batch-image-preview-toggle-button.active{background:#1976d2;color:#fff;border-color:#1976d2}.batch-image-preview-toggle-button.active:hover{background:#26c6da;border-color:#26c6da}body.dark-mode .batch-image-preview-toggle-button.active:hover{background:#1565c0;border-color:#1565c0}.batch-image-preview-download{padding:8px 16px;border:1px solid #4dd0e1;background:#fff;color:#00838f;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:500}body.dark-mode .batch-image-preview-download{background:#2d2d2d;border-color:#1976d2;color:#81d4fa}.batch-image-preview-download:hover{background:#e0f7fa;border-color:#26c6da;transform:translateY(-1px)}body.dark-mode .batch-image-preview-download:hover{background:#1e3a5f;border-color:#42a5f5}.batch-image-preview-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100%;overflow:hidden;border-radius:8px;background:#f5f5f5;flex:1}body.dark-mode .batch-image-preview-container{background:#1a1a1a}.batch-image-preview-image{width:100%;height:100%;display:block;object-fit:contain;-webkit-user-select:none;user-select:none}.batch-image-preview-info{margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0;width:100%;text-align:center}body.dark-mode .batch-image-preview-info{border-top-color:#404040}.batch-image-preview-header{position:relative;display:flex;justify-content:center;align-items:center;width:100%;margin-bottom:5px}.batch-image-preview-filename-wrapper{width:100%;display:flex;justify-content:center;align-items:center}.batch-image-preview-filename{font-size:.9rem;font-weight:600;color:#212121;word-break:break-word;text-align:center}body.dark-mode .batch-image-preview-filename{color:#e0e0e0}.batch-image-preview-dimensions{font-size:.85rem;color:#757575;text-align:center}body.dark-mode .batch-image-preview-dimensions{color:#9e9e9e}.batch-image-preview-pixellation-size{font-size:.85rem;color:#757575;margin-top:4px;text-align:center}body.dark-mode .batch-image-preview-pixellation-size{color:#9e9e9e}.batch-image-preview-info .batch-image-preview-download{position:absolute;right:0;top:50%;transform:translateY(-50%);padding:4px 8px;font-size:1rem;border:1px solid #4dd0e1;background:#fff;color:#00838f;border-radius:4px;cursor:pointer;transition:all .2s ease}body.dark-mode .batch-image-preview-info .batch-image-preview-download{background:#2d2d2d;border-color:#1976d2;color:#81d4fa}.batch-image-preview-info .batch-image-preview-download:hover{background:#e0f7fa;border-color:#26c6da;transform:translateY(calc(-50% - 1px))}body.dark-mode .batch-image-preview-info .batch-image-preview-download:hover{background:#1e3a5f;border-color:#42a5f5}.batch-crop-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.batch-crop-modal{background:#fff;border-radius:12px;padding:24px;width:80vw;max-width:90vw;height:80vh;max-height:90vh;min-width:700px;min-height:500px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;position:relative;overflow:hidden}body.dark-mode .batch-crop-modal{background:#2d2d2d;box-shadow:0 8px 32px #00000080}.batch-crop-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:32px;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;z-index:100}.batch-crop-close:hover{background:#0000001a;color:#333}body.dark-mode .batch-crop-close{color:#aaa}body.dark-mode .batch-crop-close:hover{background:#ffffff1a;color:#fff}.batch-crop-title{font-size:1.5rem;font-weight:600;color:#333;margin:0 0 16px;flex-shrink:0}body.dark-mode .batch-crop-title{color:#e0e0e0}.batch-crop-controls-bar{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:center;margin-bottom:16px;padding:8px 12px;background:#f5f5f5;border-radius:8px;gap:12px;overflow-x:auto;overflow-y:hidden;flex-shrink:0}body.dark-mode .batch-crop-controls-bar{background:#1a1a1a}.batch-crop-control-group{display:flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap}.batch-crop-control-label{font-size:.9rem;font-weight:600;color:#424242;margin-right:4px}body.dark-mode .batch-crop-control-label{color:#e0e0e0}.batch-crop-control-button{padding:5px 10px;border:1px solid #4dd0e1;background:#fff;color:#00838f;border-radius:4px;cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:500;white-space:nowrap;flex-shrink:0}body.dark-mode .batch-crop-control-button{background:#2d2d2d;border-color:#1976d2;color:#81d4fa}.batch-crop-control-button:hover{background:#e0f7fa;border-color:#26c6da}body.dark-mode .batch-crop-control-button:hover{background:#1a1a1a;border-color:#42a5f5}.batch-crop-control-button.active{background:#4dd0e1;color:#fff;border-color:#4dd0e1}body.dark-mode .batch-crop-control-button.active{background:#1976d2;color:#fff;border-color:#1976d2}.batch-crop-color-button.active{font-weight:700}.batch-crop-move-button{padding:5px 12px;border:1px solid #4dd0e1;background:#fff;color:#00838f;border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:.85rem;font-weight:600;white-space:nowrap;flex-shrink:0}.batch-crop-move-button:hover{background:#4dd0e1;color:#fff}body.dark-mode .batch-crop-move-button{background:#2d2d2d;border-color:#1976d2;color:#81d4fa}body.dark-mode .batch-crop-move-button:hover{background:#1976d2;color:#fff}.batch-crop-content-area{display:flex;flex:1;gap:16px;min-height:0;margin-bottom:16px;overflow:hidden}.batch-crop-image-list-sidebar{width:200px;flex-shrink:0;overflow-y:auto;background:#f5f5f5;border-radius:8px;padding:12px;display:flex;flex-direction:column}body.dark-mode .batch-crop-image-list-sidebar{background:#1a1a1a}.batch-crop-image-list-sidebar .batch-crop-image-list-title{font-size:.9rem;font-weight:600;color:#424242;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #ddd}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-list-title{color:#e0e0e0;border-bottom-color:#444}.batch-crop-image-list-sidebar .batch-crop-image-list-items{display:flex;flex-direction:column;gap:4px;overflow-y:auto;flex:1}.batch-crop-image-list-sidebar .batch-crop-image-item{display:flex;align-items:flex-start;gap:8px;cursor:pointer;padding:6px 8px;border-radius:4px;transition:background .2s ease}.batch-crop-image-list-sidebar .batch-crop-image-item:hover{background:#4dd0e126}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-item:hover{background:#1976d233}.batch-crop-image-list-sidebar .batch-crop-image-check{display:inline-block;width:18px;height:18px;flex-shrink:0;text-align:center;line-height:18px;font-size:14px;font-weight:700;color:#888;margin-right:4px}.batch-crop-image-list-sidebar .batch-crop-image-item.included .batch-crop-image-check{color:#4caf50}.batch-crop-image-list-sidebar .batch-crop-image-item:hover .batch-crop-image-check{color:#4dd0e1}.batch-crop-image-list-sidebar .batch-crop-image-item.included:hover .batch-crop-image-check{color:#66bb6a}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-check{color:#666}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-item.included .batch-crop-image-check{color:#66bb6a}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-item:hover .batch-crop-image-check{color:#81d4fa}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-item.included:hover .batch-crop-image-check{color:#81c784}.batch-crop-image-list-sidebar .batch-crop-image-name{font-size:.8rem;color:#555;word-break:break-word;line-height:1.3}body.dark-mode .batch-crop-image-list-sidebar .batch-crop-image-name{color:#bbb}.batch-crop-preview-container{flex:1;position:relative;background:#f9f9f9;border-radius:8px;overflow:hidden;min-height:300px;max-height:100%}body.dark-mode .batch-crop-preview-container{background:#1a1a1a}.batch-crop-stack-wrapper{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.batch-crop-stack-layer{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.batch-crop-stack-image{display:block;position:absolute}.batch-crop-bounds-box{position:absolute;border:2px dashed #888;background:transparent;pointer-events:none;z-index:50;box-sizing:border-box}body.dark-mode .batch-crop-bounds-box{border-color:#aaa}.batch-crop-mask{position:absolute;pointer-events:none;z-index:1000}.batch-crop-overlay{position:absolute;border:3px solid #4dd0e1;box-shadow:0 0 0 9999px #00000080;cursor:move;pointer-events:all;transition:border-color .2s ease}.batch-crop-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:20px;height:20px;background:#4dd0e1;border:2px solid #ffffff;border-radius:50%;cursor:move;box-shadow:0 2px 4px #0003}.crop-grid-line{position:absolute;background:#4dd0e1;opacity:.8;pointer-events:none}.crop-grid-line-vertical{width:2px;height:100%;top:0}.crop-grid-line-horizontal{height:2px;width:100%;left:0}.crop-grid-line-main{opacity:1;width:3px}.crop-grid-line-horizontal.crop-grid-line-main{height:3px;width:100%}.batch-crop-alignment-controls{display:flex;align-items:center;gap:8px}.batch-crop-alignment-controls .batch-crop-control-label{font-size:.9rem;font-weight:600;color:#424242;margin-right:4px}body.dark-mode .batch-crop-alignment-controls .batch-crop-control-label{color:#e0e0e0}.batch-crop-instructions{text-align:center;font-size:.85rem;color:#666;margin-bottom:12px;flex-shrink:0}body.dark-mode .batch-crop-instructions{color:#aaa}.batch-crop-actions{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #e0e0e0;flex-shrink:0}body.dark-mode .batch-crop-actions{border-top-color:#424242}.batch-crop-action-buttons{display:flex;gap:12px}.batch-crop-cancel-button,.batch-crop-apply-button{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.batch-crop-cancel-button{background:#f5f5f5;color:#666}.batch-crop-cancel-button:hover{background:#e0e0e0}body.dark-mode .batch-crop-cancel-button{background:#424242;color:#aaa}body.dark-mode .batch-crop-cancel-button:hover{background:#555}.batch-crop-apply-button{background:#4dd0e1;color:#fff}.batch-crop-apply-button:hover{background:#26c6da}.batch-crop-apply-button:disabled{background:#ccc;color:#999;cursor:not-allowed}body.dark-mode .batch-crop-apply-button{background:#1976d2}body.dark-mode .batch-crop-apply-button:hover{background:#1565c0}body.dark-mode .batch-crop-apply-button:disabled{background:#424242;color:#666}@media (max-width: 768px){.batch-crop-modal{width:95vw;max-width:95vw;height:90vh;max-height:90vh;min-width:unset;min-height:unset;padding:16px}.batch-crop-controls-bar{flex-direction:column;align-items:flex-start;gap:12px}.batch-crop-title{font-size:1.2rem}.batch-crop-content-area{flex-direction:column}.batch-crop-image-list-sidebar{width:100%;max-height:120px;flex-shrink:0}}.batch-crunch-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.batch-crunch-modal{background:#fff;border-radius:12px;padding:32px;width:600px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000004d;position:relative;overflow-y:auto}body.dark-mode .batch-crunch-modal{background:#2d2d2d;box-shadow:0 8px 32px #00000080}.batch-crunch-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:32px;color:#666;cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;z-index:100}.batch-crunch-close:hover{background:#0000001a;color:#333}body.dark-mode .batch-crunch-close{color:#aaa}body.dark-mode .batch-crunch-close:hover{background:#ffffff1a;color:#fff}.batch-crunch-title{font-size:1.75rem;font-weight:600;color:#333;margin:0 0 24px}body.dark-mode .batch-crunch-title{color:#e0e0e0}.batch-crunch-content{flex:1;display:flex;flex-direction:column;gap:20px}.batch-crunch-description{font-size:1rem;color:#666;margin:0;line-height:1.5}body.dark-mode .batch-crunch-description{color:#aaa}.batch-crunch-loading{text-align:center;padding:40px 20px;font-size:1.1rem;color:#666}body.dark-mode .batch-crunch-loading{color:#aaa}.batch-crunch-warning{display:flex;gap:16px;padding:20px;background:#fff3cd;border:2px solid #ffc107;border-radius:8px;align-items:flex-start}body.dark-mode .batch-crunch-warning{background:#3d3114;border-color:#ff9800}.batch-crunch-warning-icon{font-size:28px;flex-shrink:0}.batch-crunch-warning-content{flex:1}.batch-crunch-warning-content strong{display:block;font-size:1.1rem;color:#856404;margin-bottom:8px}body.dark-mode .batch-crunch-warning-content strong{color:#ffb74d}.batch-crunch-sizes{font-size:.9rem;color:#856404;margin-bottom:8px}body.dark-mode .batch-crunch-sizes{color:#ffb74d}.batch-crunch-suggestion{font-size:.95rem;color:#856404;font-weight:600}body.dark-mode .batch-crunch-suggestion{color:#ffcc80}.batch-crunch-info{display:flex;gap:16px;padding:20px;background:#d4edda;border:2px solid #28a745;border-radius:8px;align-items:center}body.dark-mode .batch-crunch-info{background:#1b3624;border-color:#4caf50}.batch-crunch-info-icon{font-size:28px;color:#28a745;flex-shrink:0}body.dark-mode .batch-crunch-info-icon{color:#4caf50}.batch-crunch-info-content{flex:1;font-size:1rem;color:#155724;font-weight:600}body.dark-mode .batch-crunch-info-content{color:#81c784}.batch-crunch-options{display:flex;flex-direction:column;gap:16px;margin-top:8px}.batch-crunch-option-group{padding:20px;background:#f8f9fa;border-radius:8px;border:2px solid #e0e0e0}body.dark-mode .batch-crunch-option-group{background:#1a1a1a;border-color:#424242}.batch-crunch-option-group h3{margin:0 0 8px;font-size:1.1rem;color:#333}body.dark-mode .batch-crunch-option-group h3{color:#e0e0e0}.batch-crunch-option-group p{margin:0 0 12px;font-size:.9rem;color:#666}body.dark-mode .batch-crunch-option-group p{color:#aaa}.batch-crunch-button{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.batch-crunch-button-primary{background:#4dd0e1;color:#fff;width:100%}.batch-crunch-button-primary:hover{background:#26c6da}body.dark-mode .batch-crunch-button-primary{background:#1976d2}body.dark-mode .batch-crunch-button-primary:hover{background:#1565c0}.batch-crunch-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e0e0e0}body.dark-mode .batch-crunch-actions{border-top-color:#424242}.batch-crunch-cancel-button,.batch-crunch-crop-button{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all .2s ease}.batch-crunch-cancel-button{background:#f5f5f5;color:#666}.batch-crunch-cancel-button:hover{background:#e0e0e0}body.dark-mode .batch-crunch-cancel-button{background:#424242;color:#aaa}body.dark-mode .batch-crunch-cancel-button:hover{background:#555}.batch-crunch-crop-button{background:#ffc107;color:#000}.batch-crunch-crop-button:hover{background:#ffb300}body.dark-mode .batch-crunch-crop-button{background:#ff9800;color:#000}body.dark-mode .batch-crunch-crop-button:hover{background:#fb8c00}@media (max-width: 768px){.batch-crunch-modal{width:95vw;padding:24px}.batch-crunch-title{font-size:1.4rem}.batch-crunch-options{gap:12px}.batch-crunch-option-group{padding:16px}}.pxl-batch{background:#fafafa;min-height:100vh;height:100vh;overflow:hidden;display:flex;flex-direction:column;transition:background-color .3s ease}.pxl-batch.dark-mode{background:#252525}.batch-content{padding:20px 20px 180px;width:100%;margin:0 auto;position:relative;flex:1;overflow-y:auto;overflow-x:hidden}.batch-actions{display:flex;gap:15px;margin-top:20px;margin-bottom:20px}.process-all-button{padding:12px 24px;background:linear-gradient(135deg,#4dd0e1,#26c6da);color:#006064;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s,background .3s ease}.pxl-batch.dark-mode .process-all-button{background:linear-gradient(135deg,#1976d2,#1565c0);color:#e3f2fd}.process-all-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #4dd0e166}.pxl-batch.dark-mode .process-all-button:hover:not(:disabled){box-shadow:0 5px 15px #1976d266}.process-all-button:disabled{opacity:.6;cursor:not-allowed}.clear-button{padding:12px 24px;background:#fff;color:#616161;border:1px solid #e0e0e0;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s,color .2s}.pxl-batch.dark-mode .clear-button{background:#2d2d2d;border-color:#404040;color:#b0b0b0}.clear-button:hover{background:#f5f5f5;border-color:#4dd0e1;color:#006064}.pxl-batch.dark-mode .clear-button:hover{background:#404040;border-color:#1976d2;color:#e3f2fd}.pxl-batch .app-footer{position:fixed;bottom:0;left:0;right:0;padding:10px 20px;text-align:center;background:#fff;border-top:1px solid #e0e0e0;font-size:.85rem;transition:background-color .3s ease,border-color .3s ease;z-index:50}.pxl-batch.dark-mode .app-footer{background:#2d2d2d;border-top-color:#404040}.pxl-batch .footer-link{color:#00838f;text-decoration:none;transition:color .3s ease}.pxl-batch.dark-mode .footer-link{color:#64b5f6}.pxl-batch .footer-link:hover{color:#006064;text-decoration:underline}.pxl-batch.dark-mode .footer-link:hover{color:#90caf9}.pxl-batch .footer-separator{margin:0 10px;color:#9e9e9e}.pxl-batch.dark-mode .footer-separator{color:#616161}.pxl-batch .footer-info-button{background:none;border:none;color:#00838f;font-size:1.1rem;cursor:pointer;padding:0;margin:0;transition:color .3s ease,transform .2s ease;line-height:1;vertical-align:middle}.pxl-batch.dark-mode .footer-info-button{color:#64b5f6}.pxl-batch .footer-info-button:hover{color:#006064;transform:scale(1.1)}.pxl-batch.dark-mode .footer-info-button:hover{color:#90caf9}.pxl-batch .footer-info-button:active{transform:scale(.95)}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.page-content{flex:1}.app-footer{padding:10px 20px;text-align:center;background:#fff;border-top:1px solid #e0e0e0;font-size:.85rem;transition:background-color .3s ease,border-color .3s ease;flex-shrink:0}body.dark-mode .app-footer{background:#2d2d2d;border-top-color:#404040}.footer-link{color:#00838f;text-decoration:none;transition:color .3s ease}body.dark-mode .footer-link{color:#64b5f6}.footer-link:hover{color:#006064;text-decoration:underline}body.dark-mode .footer-link:hover{color:#90caf9}.footer-separator{margin:0 10px;color:#9e9e9e}body.dark-mode .footer-separator{color:#616161}.footer-info-button{background:none;border:none;color:#00838f;font-size:1.1rem;cursor:pointer;padding:0;margin:0;transition:color .3s ease,transform .2s ease;line-height:1;vertical-align:middle}body.dark-mode .footer-info-button{color:#64b5f6}.footer-info-button:hover{color:#006064;transform:scale(1.1)}body.dark-mode .footer-info-button:hover{color:#90caf9}.footer-info-button:active{transform:scale(.95)}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5;margin:0;padding:0;transition:background-color .3s ease}body.dark-mode{background:#121212}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{height:100%;width:100%;display:flex;flex-direction:column}
