:root,[data-theme=light]{--color-paper: #FAF6F1;--color-paper-light: #FFFFFF;--color-paper-dark: #F0EBE4;--color-paper-warm: #F5EDE3;--color-ink: #2B2420;--color-ink-light: #7A6E63;--color-ink-faint: #DDD5CA;--color-ink-muted: #B5A99D;--color-accent: #D4582A;--color-accent-dark: #B94A1F;--color-accent-light: #E8854E;--color-accent-rgb: 212, 88, 42;--color-accent-glow: rgba(212, 88, 42, .12);--color-success: #3D8B4E;--color-success-rgb: 61, 139, 78;--color-error: #C44133;--doodle-opacity: .08;--surface-card: #FFFFFF;--surface-raised: #FFFFFF;--surface-sunken: #F0EBE4;--surface-overlay: rgba(43, 36, 32, .04);--shadow-xs: 0 1px 2px rgba(43, 36, 32, .06);--shadow-sm: 0 2px 4px rgba(43, 36, 32, .06), 0 1px 2px rgba(43, 36, 32, .04);--shadow-md: 0 4px 12px rgba(43, 36, 32, .08), 0 2px 4px rgba(43, 36, 32, .04);--shadow-lg: 0 8px 24px rgba(43, 36, 32, .1), 0 4px 8px rgba(43, 36, 32, .04);--shadow-xl: 0 16px 48px rgba(43, 36, 32, .12), 0 8px 16px rgba(43, 36, 32, .06);--shadow-accent: 0 4px 16px rgba(212, 88, 42, .25);--shadow-accent-lg: 0 8px 32px rgba(212, 88, 42, .3);--shadow-success: 0 4px 16px rgba(61, 139, 78, .25);--shadow-inset: inset 0 2px 4px rgba(43, 36, 32, .06);--font-family: "Instrument Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--font-size-2xs: 10px;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-md: 15px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-2xl: 32px;--font-size-3xl: 42px;--space-2xs: 2px;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-xs: 4px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--duration-instant: .08s;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--border-subtle: 1px solid rgba(43, 36, 32, .08);--border-default: 1px solid var(--color-ink-faint);--border-strong: 1px solid var(--color-ink-muted)}[data-theme=dark]{--color-paper: #1A1614;--color-paper-light: #242019;--color-paper-dark: #12100E;--color-paper-warm: #1E1A16;--color-ink: #EDE8E2;--color-ink-light: #BDB2A6;--color-ink-faint: #3A332D;--color-ink-muted: #635A50;--color-accent: #E8854E;--color-accent-dark: #D4582A;--color-accent-light: #F0A06B;--color-accent-rgb: 232, 133, 78;--color-accent-glow: rgba(232, 133, 78, .15);--color-success: #5AAF6B;--color-success-rgb: 90, 175, 107;--color-error: #E05A4C;--doodle-opacity: .05;--surface-card: #242019;--surface-raised: #2A2520;--surface-sunken: #12100E;--surface-overlay: rgba(0, 0, 0, .2);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2), 0 1px 2px rgba(0, 0, 0, .15);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25), 0 2px 4px rgba(0, 0, 0, .15);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3), 0 4px 8px rgba(0, 0, 0, .2);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .4), 0 8px 16px rgba(0, 0, 0, .25);--shadow-accent: 0 4px 16px rgba(232, 133, 78, .2);--shadow-accent-lg: 0 8px 32px rgba(232, 133, 78, .25);--shadow-success: 0 4px 16px rgba(90, 175, 107, .2);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .2);--border-subtle: 1px solid rgba(255, 255, 255, .06);--border-default: 1px solid var(--color-ink-faint);--border-strong: 1px solid var(--color-ink-muted)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-family);background:var(--color-paper);color:var(--color-ink);line-height:1.5;min-height:100vh;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none}input[type=range]{cursor:pointer}img{max-width:100%;height:auto}::selection{background:rgba(var(--color-accent-rgb),.2);color:var(--color-ink)}:focus{outline:none}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.92)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes progressPulse{0%,to{box-shadow:0 0 rgba(var(--color-accent-rgb),.4)}50%{box-shadow:0 0 0 6px rgba(var(--color-accent-rgb),0)}}@keyframes checkmark{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}@keyframes confetti{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(-100px) rotate(720deg);opacity:0}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.animate-fade-in{animation:fadeIn .3s var(--ease-out) forwards}.animate-fade-out{animation:fadeOut .3s ease-out forwards}.animate-slide-up{animation:slideUp .4s var(--ease-out) forwards}.animate-slide-down{animation:slideDown .4s var(--ease-out) forwards}.animate-scale-in{animation:scaleIn .3s var(--ease-out) forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-bounce{animation:bounce .5s var(--ease-spring)}.state-entering{animation:scaleIn .3s var(--ease-out) forwards}.state-exiting{animation:scaleOut .2s ease-out forwards}.skeleton{background:linear-gradient(90deg,var(--surface-sunken) 25%,var(--surface-card) 50%,var(--surface-sunken) 75%);background-size:200% 100%;animation:shimmer 1s infinite;border-radius:var(--radius-sm)}.progress-bar{position:relative;height:4px;background:var(--color-ink-faint);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-accent);border-radius:var(--radius-full);transition:width .3s var(--ease-out)}.progress-bar-indeterminate .progress-bar-fill{width:30%;animation:indeterminate 1.5s ease-in-out infinite}@keyframes indeterminate{0%{transform:translate(-100%)}to{transform:translate(400%)}}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.spinner-large{width:40px;height:40px;border-width:3px}.spinner-accent{border-color:rgba(var(--color-accent-rgb),.2);border-top-color:var(--color-accent)}.success-checkmark{width:24px;height:24px}.success-checkmark circle{fill:var(--color-success);animation:scaleIn .3s var(--ease-out) forwards}.success-checkmark path{stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:24;stroke-dashoffset:24;animation:checkmark .4s .2s ease-out forwards}.stagger-item{opacity:0;animation:slideUp .4s var(--ease-out) forwards}.stagger-item.animated{opacity:1;animation:none}.stagger-item:nth-child(1){animation-delay:0ms}.stagger-item:nth-child(2){animation-delay:40ms}.stagger-item:nth-child(3){animation-delay:80ms}.stagger-item:nth-child(4){animation-delay:.12s}.stagger-item:nth-child(5){animation-delay:.16s}.stagger-item:nth-child(6){animation-delay:.2s}.stagger-item:nth-child(7){animation-delay:.24s}.stagger-item:nth-child(8){animation-delay:.28s}.stagger-item.animated:nth-child(n){animation-delay:0ms}.hover-lift{transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) ease}.hover-lift:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.press-effect{transition:transform var(--duration-instant) ease}.press-effect:active{transform:scale(.97)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(100px);padding:10px 24px;background:var(--color-ink);color:var(--color-paper);border-radius:var(--radius-full);box-shadow:var(--shadow-lg);z-index:1000;opacity:0;transition:transform .3s var(--ease-out),opacity .3s ease;font-size:var(--font-size-sm);font-weight:600}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.toast-success{background:var(--color-success)}.toast-error{background:var(--color-error)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.animate-spin{animation:none}.progress-bar-indeterminate .progress-bar-fill{animation:none;width:50%}}.app:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:var(--doodle-opacity);background-image:radial-gradient(circle,currentColor .5px,transparent .5px);background-size:24px 24px;color:var(--color-ink)}.app{min-height:100vh;display:flex;flex-direction:column;padding:var(--space-lg);padding-top:80px;position:relative;background:var(--color-paper);transition:background-color var(--duration-normal) ease}.app:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;background:radial-gradient(ellipse 80% 50% at 20% 0%,rgba(var(--color-accent-rgb),.04) 0%,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 100%,rgba(var(--color-accent-rgb),.03) 0%,transparent 50%)}.main-area{position:relative;z-index:1;width:100%;max-width:480px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);flex:1;justify-content:center;padding-bottom:var(--space-xl)}.top-nav-left{position:fixed;top:var(--space-md);left:var(--space-lg);z-index:100}.logo{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none;transition:opacity var(--duration-fast) ease}.logo:hover{opacity:.75}.logo img{width:36px;height:36px;object-fit:contain}.logo-text{font-size:var(--font-size-md);font-weight:700;color:var(--color-ink);letter-spacing:-.3px}.top-nav{position:fixed;top:var(--space-md);right:var(--space-lg);display:flex;align-items:center;gap:var(--space-xs);z-index:100}.nav-link{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--surface-card);border:var(--border-default);border-radius:var(--radius-full);color:var(--color-ink-light);text-decoration:none;font-size:var(--font-size-sm);font-weight:600;transition:all var(--duration-fast) ease;box-shadow:var(--shadow-xs)}.nav-link:hover{border-color:var(--color-accent);color:var(--color-accent);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.nav-link:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.theme-toggle{width:38px;height:38px;border-radius:50%;background:var(--surface-card);border:var(--border-default);display:flex;align-items:center;justify-content:center;color:var(--color-ink);transition:all var(--duration-normal) var(--ease-spring);box-shadow:var(--shadow-xs)}.theme-toggle:hover{border-color:var(--color-accent);color:var(--color-accent);transform:scale(1.08) rotate(12deg);box-shadow:var(--shadow-accent)}.theme-toggle:active{transform:scale(.92)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.theme-toggle svg{transition:transform var(--duration-normal) var(--ease-spring);width:16px;height:16px}.theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:none}[data-theme=dark] .theme-toggle .icon-moon{display:block}.brand{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.brand-icon{width:64px;height:64px;object-fit:contain}.brand-text{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-ink);letter-spacing:-1px}.drop-zone-subtitle{font-size:var(--font-size-md);color:var(--color-ink-light);text-align:center;margin-bottom:var(--space-md);font-weight:500;letter-spacing:-.2px}.drop-zone{width:100%;aspect-ratio:4/3;border:1.5px solid var(--color-ink-faint);border-radius:var(--radius-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);background:var(--surface-card);position:relative;overflow:hidden}.drop-zone:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(135deg,rgba(var(--color-accent-rgb),.06) 0%,transparent 60%);opacity:0;transition:opacity var(--duration-normal) ease;pointer-events:none}.drop-zone:hover:before{opacity:1}.drop-zone:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.drop-zone.drag-over{border-color:var(--color-accent);border-width:3px;transform:scale(1.01) translateY(-2px);box-shadow:var(--shadow-accent-lg)}.drop-zone.drag-over:before{opacity:1}.drop-zone-icon{width:64px;height:64px;color:var(--color-accent);opacity:.5;transition:all var(--duration-normal) var(--ease-out)}.drop-zone:hover .drop-zone-icon{opacity:.9;transform:scale(1.06)}.drop-zone.drag-over .drop-zone-icon{opacity:1;transform:scale(1.12);color:var(--color-accent)}.drop-zone-text{text-align:center}.drop-zone-primary{font-size:var(--font-size-lg);font-weight:600;color:var(--color-ink);margin-bottom:var(--space-xs);letter-spacing:-.3px}.drop-zone-secondary{font-size:var(--font-size-sm);color:var(--color-ink-muted)}.drop-zone:hover .drop-zone-primary{color:var(--color-accent)}.drop-zone:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px}.keyboard-hint{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-ink-muted)}.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 var(--space-xs);background:var(--surface-sunken);border:var(--border-default);border-radius:5px;font-family:var(--font-mono);font-size:10px;font-weight:600;box-shadow:var(--shadow-xs),inset 0 -1px #0000000f}.smoosh-card{width:100%;background:var(--surface-card);border:var(--border-default);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md);transition:box-shadow var(--duration-normal) ease}.smoosh-card-preview{width:100%;min-height:280px;max-height:400px;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--surface-sunken);border-bottom:var(--border-default);position:relative;overflow:hidden}.smoosh-card-preview img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.loading{color:var(--color-ink-light);font-size:var(--font-size-sm)}.comparison-container{position:absolute;inset:0;cursor:ew-resize;user-select:none}.comparison-before,.comparison-after{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.comparison-before{z-index:2}.comparison-after{z-index:1}.comparison-before img,.comparison-after img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none}.comparison-label{position:absolute;top:var(--space-sm);padding:var(--space-2xs) var(--space-sm);background:#000000c7;backdrop-filter:blur(8px);color:#fff;font-size:var(--font-size-2xs);font-weight:700;letter-spacing:.3px;border-radius:var(--radius-full);z-index:5}.comparison-label-before{left:var(--space-sm)}.comparison-label-after{right:var(--space-sm)}.comparison-size{position:absolute;bottom:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:#000000c7;backdrop-filter:blur(8px);color:#fff;font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full);z-index:5}.comparison-size-before{left:var(--space-sm)}.comparison-size-after{right:var(--space-sm)}.comparison-slider{position:absolute;top:0;bottom:0;width:3px;background:#fff;z-index:10;transform:translate(-50%);box-shadow:0 0 12px #0000004d}.comparison-slider-handle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:34px;height:34px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #00000040,0 0 0 2px #ffffff80;transition:transform var(--duration-fast) var(--ease-spring)}.comparison-slider-handle:hover{transform:translate(-50%,-50%) scale(1.12)}.comparison-slider-handle svg{color:var(--color-ink);opacity:.7}.comparison-enlarge-btn{position:absolute;top:var(--space-sm);right:var(--space-sm);width:30px;height:30px;display:flex;align-items:center;justify-content:center;padding:0;background:#0009;backdrop-filter:blur(8px);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;z-index:10;opacity:0;transition:opacity var(--duration-fast),background var(--duration-fast),transform var(--duration-fast)}.comparison-container:hover .comparison-enlarge-btn{opacity:1}.comparison-enlarge-btn:hover{background:#000000d9;transform:scale(1.05)}.comparison-enlarged-backdrop{position:fixed;inset:0;background:#000000d9;backdrop-filter:blur(8px);z-index:999;cursor:pointer}.comparison-container.enlarged{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90vw;height:85vh;max-width:1400px;max-height:900px;z-index:1000;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);background:var(--color-paper-dark)}.comparison-container.enlarged .comparison-enlarge-btn{opacity:1;top:var(--space-md);right:var(--space-md);width:40px;height:40px}.comparison-container.enlarged .comparison-label{font-size:var(--font-size-sm);padding:5px 14px}.comparison-container.enlarged .comparison-size{font-size:var(--font-size-md);padding:5px 14px}.preview-single{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.preview-single img{max-width:100%;max-height:100%;object-fit:contain}.preview-single.crop-mode{cursor:crosshair}.crop-overlay{position:absolute;inset:0;background:#00000080;z-index:20}.crop-selection{position:absolute;border:2px solid white;background:transparent;box-shadow:0 0 0 9999px #00000080;cursor:move}.crop-handle{position:absolute;width:12px;height:12px;background:#fff;border:2px solid var(--color-accent);border-radius:2px;z-index:25}.crop-handle-nw{top:-6px;left:-6px;cursor:nwse-resize}.crop-handle-ne{top:-6px;right:-6px;cursor:nesw-resize}.crop-handle-sw{bottom:-6px;left:-6px;cursor:nesw-resize}.crop-handle-se{bottom:-6px;right:-6px;cursor:nwse-resize}.crop-handle-n{top:-6px;left:50%;transform:translate(-50%);cursor:ns-resize}.crop-handle-s{bottom:-6px;left:50%;transform:translate(-50%);cursor:ns-resize}.crop-handle-e{right:-6px;top:50%;transform:translateY(-50%);cursor:ew-resize}.crop-handle-w{left:-6px;top:50%;transform:translateY(-50%);cursor:ew-resize}.crop-actions{position:absolute;bottom:var(--space-md);left:50%;transform:translate(-50%);display:flex;gap:var(--space-sm);z-index:30}.crop-action-btn{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--duration-fast)}.crop-apply{background:var(--color-accent);border:2px solid var(--color-accent);color:#fff}.crop-apply:hover{background:var(--color-accent-dark)}.crop-apply:focus-visible,.crop-cancel:focus-visible{outline:2px solid white;outline-offset:2px}.crop-cancel{background:var(--color-paper);border:2px solid var(--color-ink-faint);color:var(--color-ink)}.crop-cancel:hover{background:var(--color-paper-dark);border-color:var(--color-ink)}.crop-toolbar{position:absolute;top:var(--space-sm);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-sm);background:#000000d1;border-radius:var(--radius-md);z-index:35;backdrop-filter:blur(12px)}.crop-toolbar-presets{display:flex}.crop-preset-select{padding:var(--space-xs) var(--space-sm);padding-right:var(--space-lg);background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);color:#fff;font-size:var(--font-size-xs);font-family:inherit;font-weight:500;cursor:pointer;min-width:110px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.crop-preset-select:focus{outline:none;border-color:var(--color-accent)}.crop-preset-select option,.crop-preset-select optgroup{background:var(--color-paper-dark);color:var(--color-ink)}.crop-toolbar-toggles{display:flex;gap:var(--space-2xs);padding-left:var(--space-xs);border-left:1px solid rgba(255,255,255,.12)}.crop-toolbar-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:#ffffffb3;cursor:pointer;transition:all var(--duration-fast)}.crop-toolbar-btn:hover{background:#ffffff1a;color:#fff}.crop-toolbar-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.crop-toolbar-dimensions{display:flex;align-items:center;gap:var(--space-xs);padding-left:var(--space-sm);border-left:1px solid rgba(255,255,255,.12);color:#fff;font-family:var(--font-mono);font-size:var(--font-size-2xs)}.crop-dim-size{font-weight:600}.crop-dim-ratio{opacity:.5}.crop-grid{position:absolute;inset:0;pointer-events:none}.crop-grid-line{position:absolute;background:#ffffff59}.crop-grid-v1{left:33.333%;top:0;bottom:0;width:1px}.crop-grid-v2{left:66.666%;top:0;bottom:0;width:1px}.crop-grid-h1{top:33.333%;left:0;right:0;height:1px}.crop-grid-h2{top:66.666%;left:0;right:0;height:1px}.transform-row{display:flex;gap:var(--space-xs)}.transform-btn{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-paper);border:var(--border-default);border-radius:var(--radius-sm);color:var(--color-ink);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-fast)}.transform-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.smoosh-card-info{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--surface-card);border-bottom:var(--border-default)}.smoosh-card-filename{font-weight:600;font-size:var(--font-size-sm);color:var(--color-ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%;letter-spacing:-.2px}.smoosh-card-size{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-ink-light);font-weight:500}.smoosh-result{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md);background:linear-gradient(135deg,rgba(var(--color-success-rgb),.12),rgba(var(--color-success-rgb),.06));border-bottom:var(--border-subtle);animation:resultReveal var(--duration-slow) var(--ease-out)}@keyframes resultReveal{0%{opacity:0;transform:scaleY(.8)}50%{transform:scaleY(1.02)}to{opacity:1;transform:scaleY(1)}}.smoosh-result-stats{display:flex;align-items:baseline;gap:var(--space-sm)}.smoosh-result-savings{font-family:var(--font-mono);font-size:var(--font-size-xl);font-weight:800;color:var(--color-success);letter-spacing:-1px}.smoosh-result-text{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-success);opacity:.75}.smoosh-controls{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.format-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xs)}.format-btn{padding:var(--space-xs) var(--space-sm);border:var(--border-default);border-radius:var(--radius-md);background:var(--color-paper);font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink-light);transition:all var(--duration-fast) ease;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:var(--space-xs);position:relative}.format-btn .format-name{letter-spacing:.2px;font-size:var(--font-size-xs);font-weight:700}.format-btn .format-estimate{font-family:var(--font-mono);font-size:var(--font-size-2xs);font-weight:500;opacity:.6}.format-btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-glow);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.format-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;box-shadow:var(--shadow-accent);transform:translateY(-1px)}.format-btn.active .format-estimate{opacity:.85}.format-btn:disabled{opacity:.35;cursor:not-allowed}.format-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.format-btn.recommended{border-color:var(--color-accent)}.format-rec{position:absolute;top:-4px;right:-4px;font-size:10px;color:var(--color-accent)}.quality-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;padding-top:var(--space-md);border-top:var(--border-subtle);min-height:44px}.quality-row.disabled{opacity:.35;pointer-events:none}.quality-row.disabled .quality-label:after{content:" (lossless)";font-weight:400}.quality-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink-light);min-width:50px}.quality-slider{flex:1;-webkit-appearance:none;appearance:none;height:6px;border-radius:var(--radius-full);background:var(--surface-sunken);border:var(--border-subtle)}.quality-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--color-accent);border:3px solid var(--surface-card);box-shadow:var(--shadow-sm),0 0 0 1px rgba(var(--color-accent-rgb),.2);cursor:grab;transition:transform var(--duration-fast) var(--ease-spring),box-shadow var(--duration-fast)}.quality-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:var(--shadow-accent)}.quality-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.05)}.quality-slider:focus-visible{outline:2px solid var(--color-accent);outline-offset:4px}.quality-slider::-moz-range-track{height:6px;border-radius:var(--radius-full);background:var(--surface-sunken);border:var(--border-subtle)}.quality-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--color-accent);border:3px solid var(--surface-card);box-shadow:var(--shadow-sm),0 0 0 1px rgba(var(--color-accent-rgb),.2);cursor:grab}.quality-slider::-moz-range-thumb:hover{box-shadow:var(--shadow-accent)}.quality-slider::-moz-range-thumb:active{cursor:grabbing}.quality-slider::-webkit-slider-runnable-track{height:6px;border-radius:var(--radius-full);background:linear-gradient(to right,var(--color-accent) 0%,var(--color-accent) var(--slider-progress, 75%),var(--surface-sunken) var(--slider-progress, 75%),var(--surface-sunken) 100%);border:var(--border-subtle)}.quality-slider::-moz-range-progress{height:6px;border-radius:var(--radius-full) 0 0 var(--radius-full);background:var(--color-accent)}.quality-value{font-family:var(--font-mono);font-size:var(--font-size-md);font-weight:700;color:var(--color-ink);min-width:45px;text-align:right;letter-spacing:-.5px}.quality-estimate{font-family:var(--font-mono);font-size:var(--font-size-2xs);color:var(--color-ink-light);background:var(--surface-sunken);padding:var(--space-2xs) var(--space-sm);border-radius:var(--radius-full);min-width:60px;text-align:center}.advanced-toggle{display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm);background:none;border:none;color:var(--color-ink-muted);font-size:var(--font-size-xs);font-weight:600;cursor:pointer;transition:color var(--duration-fast);width:100%}.advanced-toggle:hover{color:var(--color-accent)}.advanced-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.advanced-toggle svg{transition:transform var(--duration-normal) var(--ease-out)}.advanced-toggle.open svg{transform:rotate(180deg)}.advanced-options{display:none;flex-direction:column;gap:var(--space-md);padding-top:var(--space-sm);border-top:var(--border-subtle);margin-top:var(--space-sm)}.advanced-options.open{display:flex}.option-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-ink-muted);margin-bottom:var(--space-xs)}.resize-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-xs)}.resize-btn{padding:var(--space-sm) var(--space-xs);border:var(--border-default);border-radius:var(--radius-sm);background:var(--color-paper);font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:500;color:var(--color-ink-light);transition:all var(--duration-fast)}.resize-btn:hover{border-color:var(--color-accent);color:var(--color-accent);transform:translateY(-1px)}.resize-btn.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;box-shadow:var(--shadow-accent)}.resize-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.smoosh-btn-big{width:100%;margin-top:var(--space-xs);padding:var(--space-md) var(--space-lg);background:var(--color-accent);border:none;border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:800;color:#fff;letter-spacing:.3px;box-shadow:var(--shadow-accent);transition:all var(--duration-fast) var(--ease-out);position:relative;overflow:hidden}.smoosh-btn-big:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .35s ease}.smoosh-btn-big:hover:not(:disabled):before{left:100%}.smoosh-btn-big:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-accent-lg);background:var(--color-accent-dark)}.smoosh-btn-big:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.smoosh-btn-big:disabled{opacity:.5;cursor:not-allowed}.smoosh-btn-big:focus-visible{outline:2px solid white;outline-offset:2px}.smoosh-btn-big.processing{background:var(--color-ink-light);box-shadow:var(--shadow-sm);letter-spacing:1px;animation:processingPulse 2s ease-in-out infinite}@keyframes processingPulse{0%,to{box-shadow:var(--shadow-sm)}50%{box-shadow:var(--shadow-md),0 0 0 4px rgba(var(--color-accent-rgb),.1)}}.smoosh-spinner{display:inline-block;width:16px;height:16px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;margin-right:var(--space-xs);vertical-align:middle}.download-btn{width:100%;padding:var(--space-md);background:var(--color-success);border:none;border-radius:var(--radius-md);font-size:var(--font-size-md);font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:all var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-success);position:relative;overflow:hidden;letter-spacing:.3px}.download-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.15),transparent);transition:left .35s ease}.download-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(var(--color-success-rgb),.35)}.download-btn:hover:before{left:100%}.download-btn:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.download-btn:focus-visible{outline:2px solid white;outline-offset:2px}.download-btn svg{transition:transform var(--duration-fast) var(--ease-spring)}.download-btn:hover svg{transform:translateY(2px)}.actions-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xs)}.action-btn{padding:var(--space-sm);border:var(--border-default);border-radius:var(--radius-sm);background:var(--color-paper);font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink-light);transition:all var(--duration-fast)}.action-btn:hover{border-color:var(--color-ink-muted);color:var(--color-ink);background:var(--surface-sunken);transform:translateY(-1px);box-shadow:var(--shadow-xs)}.action-btn:active{transform:translateY(0)}.action-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.progress-text{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-ink-light);text-align:center;margin-top:var(--space-xs)}.batch-container{width:100%;max-width:600px;background:var(--surface-card);border:var(--border-default);border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-md)}.batch-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);background:var(--surface-sunken);border-bottom:var(--border-default)}.batch-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-ink);margin:0;letter-spacing:-.3px}.batch-count{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-ink-light);font-weight:500}.batch-settings{padding:var(--space-md);border-bottom:var(--border-subtle);display:flex;flex-direction:column;gap:var(--space-md)}.batch-list{max-height:400px;overflow-y:auto;padding:var(--space-sm) var(--space-md)}.batch-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--color-paper);border:var(--border-default);border-radius:var(--radius-md);margin-bottom:var(--space-xs);transition:all var(--duration-fast) ease}.batch-item:last-child{margin-bottom:0}.batch-item:hover{border-color:var(--color-ink-muted);box-shadow:var(--shadow-xs)}.batch-item.processing{border-color:var(--color-accent);background:var(--color-accent-glow);animation:batchItemPulse 1.5s ease-in-out infinite}@keyframes batchItemPulse{0%,to{border-color:var(--color-accent)}50%{border-color:var(--color-accent-light);box-shadow:0 0 0 2px rgba(var(--color-accent-rgb),.08)}}.batch-item.complete{border-color:var(--color-success);background:rgba(var(--color-success-rgb),.06);animation:batchItemComplete .3s var(--ease-out)}@keyframes batchItemComplete{0%{background:rgba(var(--color-success-rgb),.15)}to{background:rgba(var(--color-success-rgb),.06)}}.batch-item.error{border-color:var(--color-error);background:#c441330f}.batch-item-preview{width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--surface-sunken)}.batch-item-preview img{width:100%;height:100%;object-fit:cover}.batch-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-2xs)}.batch-item-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batch-item-size{font-family:var(--font-mono);font-size:var(--font-size-xs);color:var(--color-ink-light)}.batch-item-savings{font-family:var(--font-mono);font-size:var(--font-size-xs);font-weight:700;color:var(--color-success)}.batch-item-error{font-size:var(--font-size-xs);font-weight:500;color:var(--color-error)}.batch-item .progress-bar{margin-top:var(--space-xs);height:3px}.batch-item-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.batch-download-btn,.batch-remove-btn{width:32px;height:32px;border-radius:var(--radius-sm);border:var(--border-default);background:var(--color-paper);display:flex;align-items:center;justify-content:center;color:var(--color-ink-light);transition:all var(--duration-fast) ease}.batch-download-btn:hover{border-color:var(--color-success);color:var(--color-success);background:rgba(var(--color-success-rgb),.08)}.batch-remove-btn:hover{border-color:var(--color-error);color:var(--color-error);background:#c4413314}.batch-download-btn:focus-visible,.batch-remove-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.batch-summary{padding:var(--space-md);background:linear-gradient(135deg,rgba(var(--color-success-rgb),.1),rgba(var(--color-success-rgb),.05));text-align:center;font-family:var(--font-mono);font-size:var(--font-size-sm);font-weight:700;color:var(--color-success)}.batch-actions{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);border-top:var(--border-subtle)}.site-footer{width:100%;background:var(--surface-sunken);border-top:var(--border-default);padding:var(--space-2xl) var(--space-lg);margin-top:auto}.footer-content{display:flex;justify-content:center;gap:var(--space-3xl);max-width:800px;margin:0 auto}.footer-section{display:flex;flex-direction:column;gap:var(--space-xs)}.footer-section h4{font-size:var(--font-size-sm);font-weight:700;color:var(--color-ink);margin-bottom:var(--space-xs)}.footer-section a{font-size:var(--font-size-2xs);color:var(--color-ink-light);text-decoration:none;transition:color var(--duration-fast)}.footer-section a:hover{color:var(--color-accent)}@media(max-width:600px){.footer-content{flex-direction:column;gap:var(--space-lg);align-items:center;text-align:center}}@media(max-width:768px){.app{padding:var(--space-md)}.main-area{max-width:100%}.drop-zone{aspect-ratio:4/3}.drop-zone-icon{width:56px;height:56px}.brand-text{font-size:var(--font-size-xl)}.format-row,.resize-row{grid-template-columns:repeat(4,1fr)}.top-nav-left{left:var(--space-md)}.top-nav{right:var(--space-md)}}@media(max-width:480px){.app{padding:var(--space-sm);padding-bottom:60px}.main-area{gap:var(--space-md)}.brand-text{font-size:var(--font-size-lg)}.brand-icon{width:48px;height:48px}.drop-zone-subtitle{font-size:var(--font-size-sm)}.drop-zone{aspect-ratio:1/1;padding:var(--space-md);border-radius:var(--radius-lg)}.drop-zone-icon{width:48px;height:48px}.drop-zone-primary{font-size:var(--font-size-md)}.keyboard-hint{display:none}.smoosh-card{border-radius:var(--radius-lg)}.smoosh-card-preview{aspect-ratio:4/3;min-height:200px;max-height:300px}.smoosh-card-info{padding:var(--space-xs) var(--space-sm)}.smoosh-card-filename{font-size:var(--font-size-xs);max-width:55%}.smoosh-controls{padding:var(--space-sm);gap:var(--space-sm)}.format-row{grid-template-columns:repeat(2,1fr)}.format-btn{padding:var(--space-xs);font-size:var(--font-size-xs)}.format-btn .format-estimate{font-size:8px}.quality-row{flex-wrap:wrap;gap:var(--space-sm)}.quality-label{min-width:auto;width:100%}.quality-slider{flex:1;min-width:100px}.quality-estimate{display:none}.resize-row{grid-template-columns:repeat(2,1fr)}.resize-btn{font-size:10px}.smoosh-btn-big{padding:var(--space-md);font-size:var(--font-size-md);letter-spacing:.2px}.smoosh-result{padding:var(--space-sm)}.smoosh-result-savings{font-size:var(--font-size-xl)}.actions-row{gap:var(--space-xs)}.action-btn{padding:var(--space-xs);font-size:var(--font-size-xs)}.comparison-label{font-size:9px;padding:var(--space-2xs) var(--space-xs)}.comparison-size{font-size:var(--font-size-xs);padding:var(--space-2xs) var(--space-xs)}.comparison-slider-handle{width:28px;height:28px}.crop-toolbar{flex-wrap:wrap;max-width:95%;gap:var(--space-xs);padding:var(--space-xs)}.crop-preset-select{min-width:90px;font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-lg) var(--space-xs) var(--space-sm)}.crop-toolbar-btn{width:32px;height:32px}.crop-toolbar-dimensions{font-size:10px;padding-left:var(--space-xs)}.crop-handle{width:16px;height:16px}.crop-handle-nw{top:-8px;left:-8px}.crop-handle-ne{top:-8px;right:-8px}.crop-handle-sw{bottom:-8px;left:-8px}.crop-handle-se{bottom:-8px;right:-8px}.crop-actions{gap:var(--space-xs)}.crop-action-btn{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}.theme-toggle{width:34px;height:34px}.theme-toggle svg{width:14px;height:14px}.nav-link{font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm)}.top-nav-left{left:var(--space-sm)}.top-nav{right:var(--space-sm)}.logo img{width:28px;height:28px}.logo-text{font-size:var(--font-size-sm)}.download-btn{padding:var(--space-sm);font-size:var(--font-size-sm)}.batch-container{border-radius:var(--radius-lg)}}@media(max-width:360px){.brand-text{font-size:var(--font-size-md)}.format-row,.resize-row{grid-template-columns:repeat(2,1fr);gap:4px}.smoosh-btn-big{font-size:var(--font-size-sm)}}@media(hover:none)and (pointer:coarse){.format-btn,.resize-btn,.action-btn{min-height:44px}.quality-slider::-webkit-slider-thumb{width:28px;height:28px}.format-btn:hover,.resize-btn:hover,.action-btn:hover,.smoosh-btn-big:hover{transform:none}.comparison-slider-handle:hover{transform:translate(-50%,-50%)!important}.drop-zone:hover{transform:none;box-shadow:none}.nav-link:hover{transform:none}}@media(max-height:500px)and (orientation:landscape){.app{padding:var(--space-sm)}.drop-zone,.smoosh-card-preview{aspect-ratio:16/9}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.smoosh-card{border-width:1px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.smoosh-spinner{animation:none;border:2px solid white}}@media print{.theme-toggle,.smoosh-controls,.actions-row,.top-nav,.top-nav-left{display:none}.smoosh-card{box-shadow:none;border:1px solid #ccc}}
