#root{width:100%;height:100%}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-w: 252px;--sidebar-bg: #101318;--sidebar-surface: rgba(255, 255, 255, .04);--sidebar-surface-hover: rgba(255, 255, 255, .07);--sidebar-surface-active: rgba(245, 158, 11, .12);--sidebar-text: #6b7280;--sidebar-text-hover: #d1d5db;--sidebar-text-active: #fbbf24;--sidebar-border: rgba(255, 255, 255, .06);--accent: #f59e0b;--accent-hover: #d97706;--accent-subtle: #fffbeb;--accent-glow: rgba(245, 158, 11, .15);--bg: #f8f9fb;--surface: #ffffff;--surface-raised: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: #e5e7eb;--border-light: #f3f4f6;--success: #059669;--danger: #dc2626;--shadow-xs: 0 1px 2px rgba(0,0,0,.03);--shadow-sm: 0 1px 3px rgba(0,0,0,.04), 0 1px 2px rgba(0,0,0,.02);--shadow-md: 0 4px 12px rgba(0,0,0,.05);--shadow-lg: 0 12px 40px rgba(0,0,0,.08);--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--font: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace}body{font-family:var(--font);background:var(--bg);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}.app-container{display:flex;height:100vh;overflow:hidden}.app-body{display:flex;flex:1;overflow:hidden}.app-header{display:none}.hamburger-menu{background:none;border:none;cursor:pointer;padding:8px;color:var(--text-secondary);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:all .15s}.hamburger-menu:hover{background:var(--border-light);color:var(--text-primary)}.header-title{font-size:.9375rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative;z-index:10;transition:transform .3s cubic-bezier(.25,.46,.45,.94)}.sidebar:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.015'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.sidebar>*{position:relative;z-index:1}.sidebar-brand{padding:1.25rem 1rem 1rem;display:flex;align-items:center;gap:.625rem;border-bottom:1px solid var(--sidebar-border)}.sidebar-brand-mark{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#d97706);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px #f59e0b40}.sidebar-brand-mark svg{width:16px;height:16px;color:#fff}.sidebar-brand-text{flex:1;display:flex;align-items:baseline;gap:.375rem;min-width:0}.sidebar-brand-name{font-size:.875rem;font-weight:700;color:#f9fafb;letter-spacing:-.02em;white-space:nowrap}.sidebar-brand-tag{font-family:var(--font-mono);font-size:.625rem;font-weight:500;color:var(--sidebar-text);background:var(--sidebar-surface);padding:1px 5px;border-radius:4px;letter-spacing:.02em}.sidebar-close{display:none;background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:4px;border-radius:4px;margin-left:auto;transition:color .15s}.sidebar-close:hover{color:#f9fafb}.sidebar-nav{flex:1;overflow-y:auto;padding:.5rem 0}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:3px}.sidebar-group{padding:.5rem .75rem .25rem}.sidebar-group-label{font-size:.6125rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#fff3;padding:0 .5rem;margin-bottom:.25rem;-webkit-user-select:none;user-select:none}.sidebar-item{width:100%;display:flex;align-items:center;gap:.5rem;padding:.4375rem .5rem;margin-bottom:1px;background:transparent;border:1px solid transparent;border-radius:var(--r-sm);color:var(--sidebar-text);font-family:var(--font);font-size:.8125rem;font-weight:500;cursor:pointer;text-align:left;transition:all .12s ease;position:relative;outline:none}.sidebar-item:hover:not(.disabled){background:var(--sidebar-surface-hover);color:var(--sidebar-text-hover)}.sidebar-item.active{background:var(--sidebar-surface-active);border-color:#f59e0b14;color:var(--sidebar-text-active)}.sidebar-item.disabled{opacity:.4;cursor:default}.sidebar-item-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-item-icon svg{width:16px;height:16px}.sidebar-item.active .sidebar-item-icon{color:var(--accent)}.sidebar-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-item-badge{font-family:var(--font-mono);font-size:.5625rem;font-weight:500;padding:1px 5px;background:var(--sidebar-surface);border-radius:3px;color:var(--sidebar-text);letter-spacing:.02em;text-transform:uppercase;flex-shrink:0}.sidebar-item-kbd{font-family:var(--font-mono);font-size:.625rem;font-weight:500;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;background:var(--sidebar-surface);border:1px solid var(--sidebar-border);border-radius:3px;color:var(--sidebar-text);flex-shrink:0}.sidebar-item.active .sidebar-item-kbd{background:#f59e0b1a;border-color:#f59e0b26;color:var(--accent)}.sidebar-footer{padding:.75rem;border-top:1px solid var(--sidebar-border)}.sidebar-footer-pill{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:var(--sidebar-surface);border-radius:999px;font-size:.6875rem;font-weight:500;color:var(--sidebar-text)}.sidebar-footer-pill svg{flex-shrink:0;opacity:.6}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:199;animation:overlayIn .2s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.main-content{flex:1;overflow-y:auto;background:var(--bg);padding:2.5rem 3rem;display:flex;flex-direction:column;align-items:center}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px}.tool-container{max-width:880px;width:100%;margin:0 auto;animation:contentIn .35s cubic-bezier(.25,.46,.45,.94)}@keyframes contentIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tool-header{margin-bottom:2rem}.tool-header h2{font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin-bottom:.375rem;color:var(--text-primary)}.tool-header p{color:var(--text-secondary);font-size:.9375rem;line-height:1.5}.upload-zone{margin-bottom:1.75rem}.upload-zone-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3.5rem 2rem;border:2px dashed var(--border);border-radius:var(--r-lg);cursor:pointer;transition:all .2s ease;background:var(--surface);text-align:center}.upload-zone-label:hover{border-color:var(--accent);background:var(--accent-subtle)}.upload-zone.dragover .upload-zone-label{border-color:var(--accent);background:var(--accent-subtle);border-style:solid;box-shadow:0 0 0 4px var(--accent-glow);transform:scale(1.005)}.upload-zone-label svg{margin-bottom:1rem;color:var(--accent);opacity:.7;width:44px;height:44px}.upload-zone-label h3{font-size:1.0625rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.upload-zone-label p{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem}.upload-hint{display:inline-block;padding:.25rem .75rem;background:var(--bg);border-radius:999px;font-size:.75rem;color:var(--text-muted);font-weight:500}.settings-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.25rem 1.5rem;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem;box-shadow:var(--shadow-xs)}.setting-group{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.setting-label{font-weight:600;font-size:.8125rem;color:var(--text-primary);white-space:nowrap;min-width:140px}.preset-selector{padding:.4375rem .75rem;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-primary);font-family:var(--font);font-size:.8125rem;cursor:pointer;min-width:260px;transition:border-color .15s}.preset-selector:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.checkbox-group{display:flex;flex-wrap:wrap;gap:.75rem}.checkbox-label{display:flex;align-items:center;gap:.375rem;cursor:pointer;font-size:.8125rem;color:var(--text-primary);-webkit-user-select:none;user-select:none;font-weight:500}.checkbox-label input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--accent)}.checkbox-label:hover span{color:var(--accent-hover)}.slider-group{display:flex;align-items:center;gap:.75rem}.slider-group input[type=range]{width:180px;accent-color:var(--accent)}.slider-group span{min-width:40px;color:var(--text-secondary);font-family:var(--font-mono);font-size:.8125rem;font-weight:500;font-variant-numeric:tabular-nums}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem;margin-bottom:1.5rem}.image-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:.875rem;position:relative;transition:all .2s ease;box-shadow:var(--shadow-xs)}.image-card:hover{border-color:var(--accent);box-shadow:var(--shadow-md)}.image-card.processing{opacity:.7;pointer-events:none}.image-card.processed{border-color:var(--success)}.image-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.625rem}.image-card-title{font-size:.8125rem;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.image-card-remove{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s}.image-card-remove:hover{background:#dc26260f;color:var(--danger)}.image-card-preview{position:relative;width:100%;aspect-ratio:4/3;background:var(--bg);border-radius:var(--r-sm);overflow:hidden;margin-bottom:.625rem}.image-card-preview img{width:100%;height:100%;object-fit:cover}.image-card-overlay{position:absolute;inset:0;background:#ffffffeb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5}.image-card-spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:.5rem}@keyframes spin{to{transform:rotate(360deg)}}.image-card-status{font-size:.8125rem;color:var(--text-secondary);font-weight:500}.image-card-actions{display:flex;gap:.375rem}.image-card-actions .btn{flex:1;padding:.4375rem .75rem;font-size:.8125rem}.image-card-badge{position:absolute;top:.625rem;right:.625rem;padding:.1875rem .5rem;background:var(--success);color:#fff;font-size:.6875rem;font-weight:600;border-radius:4px;display:flex;align-items:center;gap:.25rem}.actions-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:.875rem 1.25rem;margin-bottom:1.75rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;box-shadow:var(--shadow-xs)}.actions-left,.actions-right{display:flex;gap:.5rem;flex-wrap:wrap}.actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn{padding:.5rem 1rem;border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;gap:.375rem;line-height:1.4}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#1a1a1a}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 8px #f59e0b4d}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg);border-color:var(--text-muted)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#047857;box-shadow:0 2px 8px #05966940}.btn-outline{background:var(--surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){background:var(--bg);color:var(--text-primary);border-color:var(--text-muted)}.btn-outline-danger{background:var(--surface);color:var(--danger);border:1px solid var(--border)}.btn-outline-danger:hover:not(:disabled){background:#dc26260a;border-color:#dc262640}.btn svg{flex-shrink:0}.info-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.5rem;margin-top:1.75rem;box-shadow:var(--shadow-xs)}.info-section h3{font-size:.9375rem;font-weight:700;margin-bottom:1rem;color:var(--text-primary);letter-spacing:-.01em}.info-section h4{font-size:.8125rem;font-weight:600;margin-top:1.25rem;margin-bottom:.5rem;color:var(--text-primary)}.info-section ul{list-style:none;padding-left:0}.info-section li{padding:.375rem 0 .375rem 1.25rem;position:relative;font-size:.8125rem;color:var(--text-secondary);line-height:1.6}.info-section li:before{content:"";position:absolute;left:0;top:.75rem;width:5px;height:5px;background:var(--accent);border-radius:50%}footer{width:100%;max-width:880px;margin-top:auto;padding-top:2.5rem;padding-bottom:1rem;text-align:center;color:var(--text-muted);font-size:.75rem}footer p{margin-bottom:.25rem}footer a{color:var(--text-secondary);text-decoration:none;font-weight:500;transition:color .15s}footer a:hover{color:var(--accent)}.mode-toggle{display:inline-flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;margin-bottom:1rem;gap:2px}.mode-btn{padding:.4375rem 1rem;border:none;border-radius:var(--r-sm);background:transparent;color:var(--text-secondary);font-family:var(--font);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s}.mode-btn:hover{color:var(--text-primary)}.mode-btn.active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs)}.tool-options{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.75rem 1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:1rem;box-shadow:var(--shadow-xs)}.option-label{font-size:.8125rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.option-group{display:flex;align-items:center;gap:.5rem}.option-select{padding:.375rem .625rem;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-primary);font-family:var(--font);font-size:.8125rem;cursor:pointer;transition:border-color .15s}.option-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.textarea{width:100%;padding:.875rem 1rem;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text-primary);font-family:var(--font);font-size:.875rem;line-height:1.6;resize:vertical;transition:border-color .15s}.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.textarea::placeholder{color:var(--text-muted)}.textarea-code{font-family:var(--font-mono);font-size:.8125rem;line-height:1.7;tab-size:2}.input-area,.output-area{margin-bottom:1rem}.area-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;gap:.5rem}.area-label{font-size:.8125rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.area-actions{display:flex;gap:.375rem;align-items:center}.btn-clear{background:none;border:none;color:var(--text-muted);font-family:var(--font);font-size:.75rem;font-weight:500;cursor:pointer;padding:.25rem .5rem;border-radius:var(--r-sm);transition:all .15s}.btn-clear:hover{color:var(--danger);background:#dc26260f}.btn-sm{padding:.3125rem .625rem;font-size:.75rem}.swap-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:50%;background:var(--surface);color:var(--text-secondary);cursor:pointer;transition:all .15s;margin:0 auto 1rem;flex-shrink:0}.swap-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-sm)}.codec-layout{display:flex;flex-direction:column;gap:0;align-items:center}.file-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:var(--accent-subtle);border:1px solid rgba(245,158,11,.2);border-radius:999px;font-size:.75rem;font-weight:500;color:var(--accent-hover);margin-top:.5rem}.file-drop-zone{display:flex;align-items:center;justify-content:center;padding:2rem;border:2px dashed var(--border);border-radius:var(--r-md);cursor:pointer;transition:all .15s;background:var(--surface);min-height:80px}.file-drop-zone:hover{border-color:var(--accent);background:var(--accent-subtle)}.file-drop-zone p{color:var(--text-muted);font-size:.875rem}.error-banner{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:#dc26260a;border:1px solid rgba(220,38,38,.15);border-radius:var(--r-md);margin-bottom:1rem;color:var(--danger);font-size:.8125rem;font-family:var(--font-mono);line-height:1.5}.error-banner svg{flex-shrink:0;margin-top:1px}.error-location{color:var(--text-muted);font-weight:500}.json-output{background:#1e1e2e;color:#cdd6f4;padding:1.25rem;border-radius:var(--r-md);font-family:var(--font-mono);font-size:.8125rem;line-height:1.7;overflow-x:auto;white-space:pre;tab-size:2;max-height:500px;overflow-y:auto;border:1px solid #313244}.json-output::-webkit-scrollbar{width:6px;height:6px}.json-output::-webkit-scrollbar-track{background:transparent}.json-output::-webkit-scrollbar-thumb{background:#45475a;border-radius:6px}.json-key{color:#89b4fa}.json-string{color:#a6e3a1}.json-number{color:#fab387}.json-boolean{color:#cba6f7}.json-null{color:#f38ba8}.output-stats{font-weight:400;font-size:.75rem;color:var(--text-muted);font-family:var(--font-mono);margin-left:.5rem}.stat-good{color:var(--success)}.indent-options{display:inline-flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);padding:2px;gap:1px}.indent-btn{padding:.25rem .5rem;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);font-family:var(--font);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s}.indent-btn.active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs)}.hash-results{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.hash-result-item{background:var(--surface);border:1px solid var(--border);border-left:3px solid;border-radius:var(--r-md);padding:.875rem 1rem;box-shadow:var(--shadow-xs)}.hash-result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.375rem}.hash-algo-label{font-family:var(--font-mono);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.hash-value{display:block;font-family:var(--font-mono);font-size:.75rem;line-height:1.6;color:var(--text-secondary);word-break:break-all;background:var(--bg);padding:.5rem .625rem;border-radius:var(--r-sm);-webkit-user-select:all;user-select:all}.hash-loading{display:flex;align-items:center;gap:.75rem;padding:1rem;color:var(--text-secondary);font-size:.875rem}.preset-tabs{display:flex;gap:.25rem;margin-bottom:1.25rem;padding:3px;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-md)}.preset-tab{flex:1;padding:.5rem .75rem;border:none;border-radius:var(--r-sm);background:transparent;color:var(--text-secondary);font-family:var(--font);font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.preset-tab:hover{color:var(--text-primary)}.preset-tab.active{background:var(--surface);color:var(--text-primary);box-shadow:var(--shadow-xs)}.qr-layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1rem}.qr-input-side{display:flex;flex-direction:column;gap:1rem}.qr-options{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-xs)}.form-fields{display:flex;flex-direction:column;gap:.75rem}.form-field{display:flex;flex-direction:column;gap:.375rem}.form-field label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.form-input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface);color:var(--text-primary);font-family:var(--font);font-size:.875rem;transition:border-color .15s}.form-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.qr-slider{width:100%;accent-color:var(--accent)}.color-picker-group{display:flex;gap:1rem}.color-picker-item{flex:1;display:flex;flex-direction:column;gap:.375rem}.color-picker-item label{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.color-input-wrap{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border:1px solid var(--border);border-radius:var(--r-sm);background:var(--surface)}.color-input-wrap input[type=color]{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;padding:0;background:none}.color-input-wrap input[type=color]::-webkit-color-swatch-wrapper{padding:0}.color-input-wrap input[type=color]::-webkit-color-swatch{border:1px solid var(--border);border-radius:4px}.color-hex{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase}.qr-preview-side{display:flex;flex-direction:column;align-items:center;gap:1rem}.qr-preview{display:flex;align-items:center;justify-content:center;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:1.5rem;min-height:280px;width:100%;box-shadow:var(--shadow-xs)}.qr-preview img{max-width:100%;height:auto;image-rendering:pixelated}.qr-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:var(--text-muted);text-align:center}.qr-placeholder svg{opacity:.3}.qr-placeholder p{font-size:.875rem}.qr-download-actions{display:flex;gap:.5rem;width:100%}.qr-download-actions .btn{flex:1;justify-content:center}@media(max-width:768px){.setting-group{flex-direction:column;align-items:flex-start}.setting-label{min-width:auto}.preset-selector{width:100%;min-width:auto}.checkbox-group{width:100%}}@media(max-width:768px){.app-container{flex-direction:column}.app-header{display:flex;align-items:center;gap:.75rem;padding:0 1rem;height:52px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;z-index:100}.hamburger-menu{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;transform:translate(-100%);z-index:200;box-shadow:4px 0 24px #00000040}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.sidebar-close{display:flex}.main-content{padding:1.25rem 1rem}.tool-header h2{font-size:1.375rem}.upload-zone-label{padding:2.5rem 1.25rem}.upload-zone-label svg{width:40px;height:40px}.upload-zone-label h3{font-size:1rem}.image-grid{grid-template-columns:1fr}.actions-bar{flex-direction:column;align-items:stretch}.actions-left,.actions-right{flex-direction:column}.actions-left .btn,.actions-right .btn,.btn{width:100%;justify-content:center}.settings-bar{padding:1rem}.slider-group input[type=range],.mode-toggle{width:100%}.mode-btn{flex:1;text-align:center}.tool-options{flex-direction:column;align-items:flex-start}.option-group{width:100%;flex-wrap:wrap}.option-select{width:100%}.codec-layout{gap:0}.qr-layout{grid-template-columns:1fr}.qr-preview{min-height:200px}.preset-tabs{flex-wrap:wrap}.preset-tab{flex:0 0 auto;padding:.4375rem .625rem;font-size:.75rem}.color-picker-group{flex-direction:column}.hash-value{font-size:.6875rem}.indent-options{width:100%}.indent-btn{flex:1;text-align:center}}.model-selector{margin-bottom:1rem}.model-selector-label{display:block;font-size:.8125rem;font-weight:600;color:var(--color-text-secondary, #6b7280);margin-bottom:.5rem}.model-selector-options{display:flex;gap:.5rem;flex-wrap:wrap}.model-option{display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.625rem 1rem;border-radius:.5rem;border:2px solid var(--border, #e5e7eb);background:var(--surface, #fff);cursor:pointer;transition:border-color .15s,background .15s;min-width:100px}.model-option:hover:not(:disabled){border-color:var(--accent, #f59e0b)}.model-option.active{border-color:var(--accent, #f59e0b);background:#fffbeb}.model-option:disabled{opacity:.5;cursor:not-allowed}.model-option-name{font-size:.875rem;font-weight:700;color:var(--color-text, #111827)}.model-option-meta{font-size:.6875rem;color:var(--color-text-secondary, #6b7280)}.model-option-accuracy{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--accent, #f59e0b)}.model-option-badge{font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:.1rem .35rem;border-radius:3px;background:var(--bg-tertiary, #374151);color:var(--text-secondary, #9ca3af)}.model-option-badge.webgpu{background:#10b98126;color:#10b981}.model-option.unavailable{opacity:.45;cursor:not-allowed;border-style:dashed}.model-selector-desc{display:block;margin-top:.375rem;font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.model-status{background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:.75rem;padding:1rem 1.25rem;margin-bottom:1.5rem}.model-status-idle{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.model-status-idle .btn{display:flex;align-items:center;gap:.5rem}.model-status-hint{font-size:.8125rem;color:var(--color-text-secondary, #6b7280)}.model-status-loading{display:flex;flex-direction:column;gap:.5rem}.model-progress-bar{width:100%;height:8px;background:var(--border, #e5e7eb);border-radius:4px;overflow:hidden}.model-progress-fill{height:100%;background:var(--accent, #f59e0b);border-radius:4px;transition:width .3s ease}.model-progress-info{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.model-status-ready{display:flex;align-items:center;gap:.75rem}.model-cached-badge{display:inline-flex;align-items:center;gap:.375rem;font-size:.8125rem;font-weight:600;color:#16a34a}.model-device-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;border-radius:9999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#f3f4f6;color:#6b7280}.model-status-error{display:flex;align-items:center;gap:.75rem}.model-status-error .error-text{color:#dc2626;font-size:.8125rem;flex:1}.privacy-footer{display:flex;align-items:center;gap:.375rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border, #e5e7eb);font-size:.75rem;color:#16a34a;font-weight:500}.ai-input-section{margin-bottom:1.5rem}.ai-input-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.ai-toggle{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--color-text-secondary, #6b7280);cursor:pointer}.ai-toggle input[type=checkbox]{accent-color:var(--accent, #f59e0b)}.ai-actions{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}.btn-sm{padding:.25rem .625rem;font-size:.75rem}.ai-results{background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:.75rem;padding:1.25rem;margin-bottom:1.5rem}.ai-results-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.ai-results-header h3{margin:0;font-size:1rem;font-weight:600}.confidence-bar-wrapper{flex:1;height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden;min-width:60px}.confidence-bar{height:100%;border-radius:4px;background:var(--accent, #f59e0b);transition:width .3s ease}.confidence-bar.positive{background:#22c55e}.confidence-bar.negative{background:#ef4444}.confidence-value{font-size:.75rem;font-weight:600;color:var(--color-text-secondary, #6b7280);min-width:3.5rem;text-align:right}.sentiment-result{padding:.75rem 0;border-bottom:1px solid var(--border, #e5e7eb)}.sentiment-result:last-child{border-bottom:none}.sentiment-text{font-size:.875rem;color:var(--color-text, #111827);margin-bottom:.5rem;line-height:1.5}.sentiment-output{display:flex;align-items:center;gap:.75rem}.sentiment-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;min-width:5.5rem}.sentiment-breakdown{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem}.sentiment-bar-row{display:flex;align-items:center;gap:.5rem}.sentiment-bar-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;min-width:4.5rem;text-align:right}.lang-result{padding:.75rem 0;border-bottom:1px solid var(--border, #e5e7eb)}.lang-result:last-child{border-bottom:none}.lang-text{font-size:.875rem;color:var(--color-text, #111827);margin-bottom:.5rem;line-height:1.5;font-style:italic}.lang-predictions{display:flex;flex-direction:column;gap:.375rem}.lang-prediction{display:flex;align-items:center;gap:.75rem}.lang-name{font-size:.8125rem;font-weight:600;color:var(--color-text, #111827);min-width:6rem}.ner-legend{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1rem;padding:.5rem 0}.ner-legend-item{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--color-text-secondary, #6b7280)}.ner-legend-dot{width:10px;height:10px;border-radius:50%}.ner-highlighted-text{font-size:.9375rem;line-height:2;padding:1rem;background:#f9fafb;border-radius:.5rem;border:1px solid var(--border, #e5e7eb)}.entity-highlight{padding:.125rem .25rem;border-radius:3px;position:relative;cursor:help}.entity-tag{font-size:.5625rem;font-weight:700;margin-left:2px;vertical-align:super}.ner-table-wrapper{overflow-x:auto}.ner-table{width:100%;border-collapse:collapse;font-size:.8125rem}.ner-table th,.ner-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--border, #e5e7eb)}.ner-table th{font-weight:600;color:var(--color-text-secondary, #6b7280);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em}.entity-type-badge{display:inline-block;padding:.125rem .5rem;border-radius:4px;font-size:.6875rem;font-weight:700}.bg-remove-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.bg-remove-card{background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:.75rem;overflow:hidden}.bg-remove-before-after{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border, #e5e7eb)}.bg-remove-img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden;background:#f9fafb}.bg-remove-img-wrap img{width:100%;height:100%;object-fit:contain}.bg-remove-img-wrap.checkerboard{background-image:linear-gradient(45deg,#e5e7eb 25%,transparent 25%),linear-gradient(-45deg,#e5e7eb 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e5e7eb 75%),linear-gradient(-45deg,transparent 75%,#e5e7eb 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0px}.bg-remove-label{position:absolute;top:.375rem;left:.375rem;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;border-radius:3px;background:#0009;color:#fff;z-index:1}.bg-remove-processing{display:flex;align-items:center;justify-content:center;height:100%;font-size:.8125rem;color:var(--color-text-secondary, #6b7280)}.bg-remove-actions{display:flex;gap:.5rem;padding:.75rem}.classify-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.classify-card{background:var(--surface, #fff);border:1px solid var(--border, #e5e7eb);border-radius:.75rem;overflow:hidden;padding:.75rem}.classify-img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:.5rem;background:#f9fafb;margin-bottom:.75rem}.classify-img-wrap img{width:100%;height:100%;object-fit:contain}.classify-remove-btn{position:absolute;top:.375rem;right:.375rem;width:24px;height:24px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.classify-processing{text-align:center;padding:.5rem;font-size:.8125rem;color:var(--color-text-secondary, #6b7280)}.prediction-list{display:flex;flex-direction:column;gap:.375rem;margin-top:.5rem}.prediction-item{display:flex;align-items:center;gap:.5rem}.prediction-label{font-size:.75rem;color:var(--color-text, #111827);min-width:8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summarizer-settings{display:flex;gap:1.5rem;flex-wrap:wrap}.summarizer-settings label{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--color-text-secondary, #6b7280)}.summarizer-settings input[type=range]{width:100px;accent-color:var(--accent, #f59e0b)}.word-count-badge{font-size:.75rem;font-weight:600;color:var(--color-text-secondary, #6b7280);padding:.125rem .5rem;background:#f3f4f6;border-radius:9999px}.compression-badge{font-size:.75rem;font-weight:600;color:#16a34a;padding:.125rem .5rem;background:#dcfce7;border-radius:9999px}.audio-preview{margin-top:1rem;padding:1rem;background:#f9fafb;border-radius:.5rem;border:1px solid var(--border, #e5e7eb)}.recording-btn{animation:recording-pulse 1.5s ease-in-out infinite}.recording-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#ef4444;margin-right:.375rem}@keyframes recording-pulse{0%,to{opacity:1}50%{opacity:.7}}.translator-lang-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.translator-select{flex:1;padding:.5rem .75rem;border-radius:.5rem;border:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);font-size:.875rem;color:var(--color-text, #111827)}.translator-swap-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1px solid var(--border, #e5e7eb);background:var(--surface, #fff);cursor:pointer;color:var(--color-text-secondary, #6b7280);transition:background .15s,color .15s}.translator-swap-btn:hover{background:var(--accent, #f59e0b);color:#fff;border-color:var(--accent, #f59e0b)}.translator-quick-pairs{display:flex;gap:.375rem;flex-wrap:wrap;margin-bottom:.75rem}.translator-panels{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.translator-panel .textarea{width:100%;min-height:120px}@media(max-width:768px){.bg-remove-grid,.classify-grid,.translator-panels{grid-template-columns:1fr}.translator-lang-bar{flex-wrap:wrap}.translator-select{min-width:0}.summarizer-settings{flex-direction:column;gap:.75rem}.sentiment-output{flex-wrap:wrap}.prediction-label{min-width:5rem}}
