.image-optimizer-tool{max-width:var(--tool-container-max-width, 1600px);margin:0 auto;padding:2rem}.image-optimizer-tool h1{text-align:center;margin-bottom:.5rem;color:#1a1a2e}.image-optimizer-tool .tool-description{text-align:center;color:#666;margin-bottom:2rem}.optimizer-layout{display:grid;grid-template-columns:var(--tool-controls-width, 420px) 1fr;gap:var(--tool-content-gap, 2rem)}.config-panel{display:flex;flex-direction:column;gap:1.5rem}.config-section{background:#f8f9fa;border-radius:12px;padding:1.5rem}.config-section h3{font-size:1.15rem;font-weight:700;color:var(--gray-900);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--primary);letter-spacing:.03em}.config-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.upload-zone{border:2px dashed #ddd;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;min-height:150px;display:flex;flex-direction:column;align-items:center;justify-content:center}.upload-zone:hover{border-color:#667eea;background:#f0f4ff}.upload-icon{font-size:3rem;color:#667eea;margin-bottom:.5rem}.upload-zone p{margin:0;color:#333;font-weight:500}.upload-zone small{color:#888}.upload-preview{max-width:100%}.upload-preview img{max-width:100%;max-height:120px;object-fit:contain;border-radius:8px}.upload-preview p{margin:.5rem 0 0;font-size:.875rem;color:#666;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.preset-btn{padding:.5rem;border:1px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:.75rem;transition:all .2s}.preset-btn:hover{border-color:#667eea;color:#667eea}.form-row{margin-bottom:1rem}.form-row label{display:block;font-weight:500;margin-bottom:.5rem;color:#333;font-size:.875rem}.form-row input[type=range]{width:100%}.quality-labels{display:flex;justify-content:space-between;font-size:.75rem;color:#888;margin-top:.25rem}.format-buttons,.mode-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.format-btn,.mode-btn{flex:1;padding:.5rem;border:2px solid #ddd;background:#fff;border-radius:6px;cursor:pointer;font-size:.7rem;font-weight:600;transition:all .2s;min-width:60px}.format-btn:hover,.mode-btn:hover{border-color:#667eea}.format-btn.active,.mode-btn.active{background:#667eea;border-color:#667eea;color:#fff}.dimensions-row{display:flex;align-items:flex-end;gap:.5rem;margin-bottom:1rem}.dimension-input{flex:1}.dimension-input label{display:block;font-size:.75rem;color:#666;margin-bottom:.25rem}.dimension-input input{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.875rem}.dimension-x{padding-bottom:.5rem;color:#888}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:1rem;cursor:pointer}.checkbox-label input{width:16px;height:16px}.action-buttons{display:flex;flex-direction:column;gap:.5rem}.primary-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:transform .2s,box-shadow .2s}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.secondary-btn{padding:.75rem 1.5rem;background:#fff;color:#667eea;border:2px solid #667eea;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.secondary-btn:hover{background:#667eea;color:#fff}.output-panel{display:flex;flex-direction:column;gap:1.5rem}.comparison-section{background:#f8f9fa;border-radius:12px;padding:1.5rem}.comparison-section h3{margin:0 0 1rem;color:#1a1a2e}.comparison-container{position:relative}.comparison-slider{position:relative;width:100%;height:400px;overflow:hidden;border-radius:8px;background:repeating-conic-gradient(#ddd,#ddd 25%,#fff 0%,#fff 50%) 50% / 20px 20px}.comparison-original,.comparison-optimized{position:absolute;top:0;left:0;width:100%;height:100%}.comparison-original img,.comparison-optimized img{width:100%;height:100%;object-fit:contain}.comparison-original{clip-path:inset(0 calc(100% - var(--position)) 0 0)}.comparison-optimized{clip-path:inset(0 0 0 var(--position))}.comparison-original .label,.comparison-optimized .label{position:absolute;bottom:10px;padding:.25rem .75rem;background:#000000b3;color:var(--gray-900);border-radius:4px;font-size:1rem}.comparison-original .label{left:10px}.comparison-optimized .label{right:10px}.comparison-handle{position:absolute;top:0;bottom:0;width:4px;background:#fff;transform:translate(-50%);cursor:ew-resize}.handle-line{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:#fff;border-radius:50%;box-shadow:0 2px 8px #0000004d;display:flex;align-items:center;justify-content:center}.handle-line:before{content:"< >";font-size:.75rem;color:#333}.comparison-range{width:100%;margin-top:1rem}.empty-comparison{height:300px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:8px;color:#888}.stats-section{background:#f8f9fa;border-radius:12px;padding:1.5rem}.stats-section h3{margin:0 0 1rem;color:#1a1a2e}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.stat-card{background:#fff;padding:1rem;border-radius:8px;text-align:center}.stat-card.savings{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.stat-label{display:block;font-size:.75rem;color:#666;margin-bottom:.25rem}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:#1a1a2e}.stat-sub{display:block;font-size:.75rem;color:#888;margin-top:.25rem}.savings-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.savings-progress{height:100%;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.history-section{background:#f8f9fa;border-radius:12px;padding:1.5rem}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.history-header h3{margin:0;color:#1a1a2e}.clear-btn{padding:.25rem .75rem;border:1px solid #dc2626;background:transparent;color:#dc2626;border-radius:4px;cursor:pointer;font-size:.75rem}.clear-btn:hover{background:#dc2626;color:#fff}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#fff;border-radius:8px}.history-info{display:flex;flex-direction:column}.history-name{font-size:.875rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.history-date{font-size:.75rem;color:#888}.history-stats{text-align:right;font-size:.75rem;color:#666}.history-savings{display:block;color:#10b981;font-weight:600}.tips-section{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:12px}.tips-section h3{margin:0 0 1rem;color:#1e40af}.tips-section ul{margin:0;padding-left:1.5rem}.tips-section li{margin-bottom:.5rem;color:#1e3a8a}.tips-section strong{color:#1e40af}@media (max-width: 1023px){.optimizer-layout,.stats-grid{grid-template-columns:1fr}.comparison-slider{height:300px}}@media (max-width: 640px){.image-optimizer-tool{padding:1rem}.format-buttons{flex-wrap:wrap}.format-btn{flex:1 1 45%}.comparison-slider{height:250px}}
