#root{width:100%;height:100%}.invoice-generator{display:flex;flex-direction:column;gap:16px}.invoice-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.invoice-actions-right{display:flex;gap:8px;margin-left:auto}.invoice-body{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}.invoice-mobile-tabs{display:none}.inv-error{padding:10px 14px;background:#ee44441a;border:1px solid rgba(238,68,68,.3);border-radius:var(--r-md);color:#dc2626;font-size:13px}.invoice-form{display:flex;flex-direction:column;gap:10px}.inv-form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.inv-form-section[open]{border-color:var(--border-focus, var(--border))}.inv-form-section-title{padding:10px 14px;font-size:13px;font-weight:600;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none;display:flex;align-items:center;gap:6px}.inv-form-section-title::-webkit-details-marker{display:none}.inv-form-section-title:before{content:"▶";font-size:9px;color:var(--text-secondary);transition:transform .15s}.inv-form-section[open]>.inv-form-section-title:before{transform:rotate(90deg)}.inv-form-fields{padding:6px 14px 14px;display:flex;flex-direction:column;gap:10px}.inv-form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.inv-logo-upload{display:flex;gap:8px;align-items:center}.inv-logo-upload .form-input{flex:1;min-width:0}.inv-items-header{display:grid;grid-template-columns:1fr 60px 80px 80px 32px;gap:6px;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;padding-bottom:4px}.inv-item-row{display:grid;grid-template-columns:1fr 60px 80px 80px 32px;gap:6px;align-items:center}.inv-item-desc{min-width:0}.inv-item-num{text-align:right}.inv-item-amount{font-size:12px;text-align:right;color:var(--text-primary);font-weight:500;padding-right:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.inv-item-remove{padding:4px!important;min-width:0!important;display:flex;align-items:center;justify-content:center}.inv-item-remove:disabled{opacity:.3;cursor:not-allowed}.inv-tax-section{display:flex;flex-direction:column;gap:10px}.inv-tax-hint{font-size:11px;color:var(--text-secondary);background:var(--accent-subtle, rgba(99, 102, 241, .08));padding:6px 10px;border-radius:var(--r-sm)}.inv-discount-toggle{display:flex;gap:4px}.inv-form-totals{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;display:flex;flex-direction:column;gap:6px}.inv-form-totals-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-secondary)}.inv-form-total-final{font-weight:700;font-size:15px;color:var(--text-primary);padding-top:6px;border-top:1px solid var(--border);margin-top:2px}.inv-saved-dropdown{position:relative}.inv-saved-list{position:absolute;top:100%;left:0;z-index:20;min-width:240px;max-height:280px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);margin-top:4px;padding:4px}.inv-saved-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;font-size:12px;border-radius:var(--r-sm);cursor:pointer;border:none;background:none;width:100%;text-align:left;color:var(--text-primary);font-family:inherit}.inv-saved-item:hover{background:var(--accent-subtle)}.inv-saved-item-label{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-saved-item-date{font-size:10px;color:var(--text-secondary);white-space:nowrap}.inv-saved-delete{padding:2px 4px;background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:14px;line-height:1;border-radius:3px}.inv-saved-delete:hover{color:#e44;background:#ee44441a}.inv-saved-empty{padding:16px;text-align:center;font-size:12px;color:var(--text-secondary)}.invoice-preview-wrapper{position:sticky;top:20px}.invoice-paper{aspect-ratio:210 / 297;background:#fff;border-radius:var(--r-md);box-shadow:0 1px 4px #00000014,0 4px 16px #0000000a;padding:32px 28px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;color:#222;font-size:11px;line-height:1.5;overflow:hidden;display:flex;flex-direction:column}.inv-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px}.inv-header-left{display:flex;gap:10px;align-items:flex-start;flex:1;min-width:0}.inv-logo{width:48px;height:48px;object-fit:contain;border-radius:4px;flex-shrink:0}.inv-company-info{min-width:0}.inv-company-name{font-size:13px;font-weight:700;color:#111;margin-bottom:2px}.inv-header-right{text-align:right;flex-shrink:0}.inv-title{font-size:18px;font-weight:700;color:#3358a9;letter-spacing:.02em;margin-bottom:6px}.inv-meta{font-size:9px;color:#555;line-height:1.7}.inv-meta strong{color:#333}.inv-separator{border:none;border-top:1px solid #e0e0e0;margin:10px 0}.inv-bill-to{margin-bottom:12px}.inv-section-label{font-size:9px;font-weight:700;color:#3358a9;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.inv-client-name{font-size:12px;font-weight:600;color:#111;margin-bottom:2px}.inv-detail-text{font-size:9px;color:#666;line-height:1.6}.inv-table{width:100%;border-collapse:collapse;margin-bottom:12px;font-size:9px}.inv-table thead th{font-size:8px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#777;padding:4px 4px 6px;border-bottom:1px solid #ddd}.inv-table tbody td{padding:5px 4px;border-bottom:1px solid #eee;vertical-align:top}.inv-summary{display:flex;flex-direction:column;align-items:flex-end;gap:3px;margin-bottom:14px}.inv-summary-row{display:flex;justify-content:space-between;gap:24px;font-size:9.5px;color:#555;min-width:160px}.inv-summary-divider{width:160px;border-top:1px solid #ddd;margin:3px 0}.inv-total{font-weight:700;font-size:12px;color:#111}.inv-footer-section{margin-top:8px}.inv-tabs{display:flex;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:3px}.inv-tab{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;color:var(--text-secondary);font-family:inherit;transition:all .15s}.inv-tab.active{background:var(--accent);color:#fff}.inv-tab:hover:not(.active){background:var(--accent-subtle)}.inv-tab-count{font-size:11px;font-weight:400;opacity:.8;margin-left:4px}.inv-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.inv-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;display:flex;flex-direction:column;gap:4px;text-align:center}.inv-stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.inv-stat-label{font-size:11px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.inv-filters{display:flex;gap:8px;flex-wrap:wrap}.inv-filter-search{flex:1;min-width:180px}.inv-filter-select{min-width:120px}.inv-filter-date{min-width:130px}.inv-list{display:flex;flex-direction:column;gap:14px}.inv-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-md)}.inv-list-table{width:100%;border-collapse:collapse;font-size:13px}.inv-list-table thead th{padding:10px 12px;text-align:left;font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;background:var(--surface);border-bottom:1px solid var(--border);white-space:nowrap}.inv-list-table tbody td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-primary);vertical-align:middle}.inv-list-table tbody tr:last-child td{border-bottom:none}.inv-list-table tbody tr:hover{background:var(--accent-subtle)}.inv-list-number{font-weight:600;white-space:nowrap}.inv-list-client{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.inv-list-date{white-space:nowrap;color:var(--text-secondary);font-size:12px}.inv-list-amount{font-weight:600;white-space:nowrap;text-align:right}.inv-list-actions{display:flex;gap:4px;flex-wrap:nowrap}.inv-list-empty{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md)}.inv-status-badge{display:inline-block;padding:3px 8px;border-radius:10px;font-size:11px;font-weight:600;white-space:nowrap}.inv-status-draft{background:#6b72801f;color:var(--text-secondary)}.inv-status-published{background:#22c55e1f;color:#16a34a}.btn-sm{padding:4px 8px!important;font-size:11px!important;min-width:0!important}.btn-danger{color:#dc2626!important;border-color:#dc26264d!important}.btn-danger:hover,.btn-confirm{background:#dc26261a!important;color:#dc2626!important}.inv-settings{max-width:480px}.inv-settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px}.inv-settings-title{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 16px}.inv-settings-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}.inv-settings-field{display:flex;flex-direction:column;gap:4px}.inv-settings-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.inv-settings-preview{font-size:13px;color:var(--text-secondary);padding:10px 12px;background:var(--accent-subtle, rgba(99, 102, 241, .08));border-radius:var(--r-sm)}.inv-settings-preview strong{color:var(--text-primary)}@media(max-width:768px){.invoice-body{grid-template-columns:1fr}.invoice-mobile-tabs{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:4px}.invoice-mobile-tab{flex:1;padding:8px;border:none;background:transparent;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;color:var(--text-secondary);font-family:inherit;transition:all .15s}.invoice-mobile-tab.active{background:var(--accent);color:#fff}.invoice-body-panel{display:none}.invoice-body-panel.active{display:block}.invoice-preview-wrapper{position:static}.inv-items-header,.inv-item-row{grid-template-columns:1fr 50px 70px 70px 28px;gap:4px}.inv-form-row{grid-template-columns:1fr}.invoice-actions{flex-direction:column;align-items:stretch}.invoice-actions-right{margin-left:0}.inv-stats-bar{grid-template-columns:repeat(2,1fr)}.inv-filters{flex-direction:column}.inv-filter-search,.inv-filter-select,.inv-filter-date{min-width:0;width:100%}.inv-list-actions{flex-wrap:wrap}.inv-settings-fields{grid-template-columns:1fr}}.webcam-video-wrapper{position:relative;background:#000;border-radius:var(--r-lg);overflow:hidden;margin-bottom:16px;aspect-ratio:16 / 9}.webcam-video{width:100%;height:100%;object-fit:contain;display:block}.webcam-video.mirrored{transform:scaleX(-1)}.webcam-stats-overlay{position:absolute;top:12px;left:12px;display:flex;gap:8px}.webcam-stat-badge{background:#0009;color:#fff;font-size:12px;font-weight:600;padding:4px 10px;border-radius:99px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-variant-numeric:tabular-nums}.webcam-recording-overlay{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;background:#dc2626d9;color:#fff;font-size:12px;font-weight:700;padding:4px 12px;border-radius:99px;letter-spacing:.04em}.webcam-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.webcam-tabs::-webkit-scrollbar{display:none}.webcam-tab{padding:10px 16px;font-size:13px;font-weight:600;color:var(--text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:color .15s,border-color .15s;font-family:inherit}.webcam-tab:hover{color:var(--text-primary)}.webcam-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.webcam-tab-content{display:flex;flex-direction:column;gap:16px}.webcam-controls-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.webcam-select{padding:8px 12px;border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface);color:var(--text-primary);font-size:13px;font-family:inherit;min-width:140px}.webcam-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);cursor:pointer}.webcam-toggle input[type=checkbox]{accent-color:var(--accent)}.webcam-stop-btn{margin-left:auto}.webcam-error-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:48px 24px;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg)}.webcam-error-state h3{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.webcam-error-state p{font-size:13.5px;color:var(--text-secondary);line-height:1.6;max-width:440px;margin:0}.webcam-error-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--accent-subtle);color:var(--accent);margin-bottom:4px}.webcam-error-icon svg{width:28px;height:28px}.webcam-camera-icon{background:var(--accent-subtle);color:var(--accent)}.webcam-denied-icon{background:#dc26261a;color:#dc2626}.webcam-privacy-notice{font-size:12.5px!important;color:var(--text-tertiary)!important;max-width:360px!important}.webcam-start-btn{display:inline-flex;align-items:center;gap:8px;margin-top:8px;padding:12px 28px;font-size:15px}.webcam-help-steps{text-align:left;font-size:13px;color:var(--text-secondary);line-height:1.7;background:var(--bg);border-radius:var(--r-md);padding:16px 20px;margin:4px 0}.webcam-help-steps ol,.webcam-help-steps ul{margin:4px 0 0;padding-left:20px}.webcam-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:webcam-spin .8s linear infinite}@keyframes webcam-spin{to{transform:rotate(360deg)}}.webcam-info-grid{display:grid;gap:1px;background:var(--border);border-radius:var(--r-md);overflow:hidden}.webcam-info-row{display:grid;grid-template-columns:140px 1fr;background:var(--surface);font-size:13px}.webcam-info-label{padding:10px 14px;font-weight:600;color:var(--text-secondary);background:var(--bg)}.webcam-info-value{padding:10px 14px;color:var(--text-primary);word-break:break-all;font-variant-numeric:tabular-nums}.webcam-capabilities{margin-top:12px}.webcam-capabilities h4{font-size:13px;font-weight:700;color:var(--text-secondary);margin:0 0 8px}.webcam-photo-preview{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:#000}.webcam-photo-preview img{width:100%;display:block;max-height:400px;object-fit:contain}.webcam-photo-actions{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface);border-top:1px solid var(--border)}.webcam-photo-name{font-size:12px;color:var(--text-tertiary)}.webcam-quality-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);white-space:nowrap}.webcam-quality-slider{width:100px;accent-color:var(--accent)}.webcam-gallery h4{font-size:13px;font-weight:700;color:var(--text-secondary);margin:0 0 8px}.webcam-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.webcam-gallery-item{position:relative;aspect-ratio:4 / 3;border-radius:var(--r-sm, 6px);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color .15s}.webcam-gallery-item.active{border-color:var(--accent)}.webcam-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.webcam-gallery-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.webcam-gallery-item:hover .webcam-gallery-remove{opacity:1}.webcam-record-dot{width:10px;height:10px;background:#dc2626;border-radius:50%;display:inline-block}.webcam-recording-indicator{width:10px;height:10px;background:#fff;border-radius:50%;display:inline-block;animation:webcam-pulse 1s ease-in-out infinite}@keyframes webcam-pulse{0%,to{opacity:1}50%{opacity:.3}}.webcam-record-btn,.webcam-stop-record-btn{display:inline-flex;align-items:center;gap:8px}.webcam-recording-preview{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.webcam-playback{width:100%;display:block;max-height:400px;background:#000}.webcam-diag-live{font-size:12px;font-weight:700;color:#16a34a;background:#16a34a1a;padding:4px 10px;border-radius:99px;animation:webcam-pulse 1.5s ease-in-out infinite}.webcam-diag-results{display:flex;flex-direction:column;gap:14px}.webcam-diag-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px}.webcam-diag-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.webcam-diag-card-title{font-size:13px;font-weight:700;color:var(--text-primary)}.webcam-diag-card-value{font-size:13px;font-weight:600;color:var(--accent)}.webcam-diag-detail{font-size:12px;color:var(--text-tertiary);margin-top:8px;display:block}.webcam-brightness-bar{display:flex;flex-direction:column;gap:4px}.webcam-brightness-zones{display:flex;font-size:10px;font-weight:600;color:var(--text-tertiary)}.webcam-brightness-zones .zone{flex:1;text-align:center}.webcam-brightness-track{position:relative;height:12px;border-radius:99px;background:linear-gradient(to right,#1e1b4b,#3730a3,#16a34a 40%,#facc15,#ef4444);overflow:visible}.webcam-brightness-fill{display:none}.webcam-brightness-marker{position:absolute;top:-2px;width:4px;height:16px;background:#fff;border:1px solid rgba(0,0,0,.3);border-radius:2px;transform:translate(-50%);transition:left .3s ease;box-shadow:0 1px 3px #0000004d}.webcam-saturation-bar{height:12px;border-radius:99px;background:var(--border);overflow:hidden}.webcam-saturation-fill{height:100%;border-radius:99px;background:linear-gradient(to right,#9ca3af,var(--accent));transition:width .3s ease}@media(max-width:600px){.webcam-video-wrapper{border-radius:var(--r-md)}.webcam-tabs{gap:0}.webcam-tab{padding:10px 12px;font-size:12px}.webcam-info-row{grid-template-columns:110px 1fr}.webcam-info-label,.webcam-info-value{padding:8px 10px;font-size:12px}.webcam-controls-row{gap:8px}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--sidebar-w: 252px;--sidebar-bg: #0A1628;--sidebar-surface: rgba(144, 224, 239, .04);--sidebar-surface-hover: rgba(144, 224, 239, .1);--sidebar-surface-active: rgba(0, 71, 171, .18);--sidebar-text: #94A3B8;--sidebar-text-hover: #E2E8F0;--sidebar-text-active: #48BBDB;--sidebar-border: rgba(144, 224, 239, .08);--accent: #0047AB;--accent-hover: #003A8C;--accent-subtle: #EBF4FF;--accent-glow: rgba(0, 71, 171, .15);--bg: #F7F9FC;--bg-gradient: linear-gradient(175deg, #ffffff 0%, #f7fafe 25%, #f0f6fb 50%, #eaf3f9 75%, #e4f0f7 100%);--surface: #ffffff;--surface-raised: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--border: #DDE4EF;--border-light: #EDF1F7;--success: #059669;--danger: #dc2626;--shadow-xs: 0 1px 2px rgba(0,30,80,.04);--shadow-sm: 0 1px 3px rgba(0,30,80,.05), 0 1px 2px rgba(0,30,80,.02);--shadow-md: 0 4px 12px rgba(0,30,80,.06);--shadow-lg: 0 12px 40px rgba(0,30,80,.1);--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;position:relative}.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),margin-left .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;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-brand-mark img{width:100%;height:100%;object-fit:contain}.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-collapse-btn{background:none;border:none;color:var(--sidebar-text);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s;flex-shrink:0;opacity:0;transition:opacity .15s,color .15s,background .15s}.sidebar-brand:hover .sidebar-collapse-btn{opacity:1}.sidebar-collapse-btn:hover{color:#f9fafb;background:var(--sidebar-surface-hover)}.sidebar.collapsed{margin-left:calc(-1 * var(--sidebar-w))}.sidebar-expand-btn{display:none;position:absolute;top:12px;left:12px;z-index:5;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:6px;cursor:pointer;color:var(--text-secondary);box-shadow:var(--shadow-sm);transition:color .15s,box-shadow .15s}.sidebar-expand-btn:hover{color:var(--accent);box-shadow:var(--shadow-md)}@media(min-width:769px){.sidebar-expand-btn{display:flex;align-items:center;justify-content:center}}.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:#ffffff61;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:#0047ab1f;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:#0047ab1a;border-color:#0047ab26;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-gradient);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:100%;width:100%;margin:0 auto;animation:contentIn .35s cubic-bezier(.25,.46,.45,.94)}.json-split-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;min-height:70vh}.json-split-panel{display:flex;flex-direction:column;min-height:0;min-width:0;margin-bottom:0}.json-split-panel .textarea,.json-split-panel .json-output{flex:1;min-height:0;max-height:none;resize:none}.json-split-placeholder{flex:1;display:flex;align-items:center;justify-content:center;border:1px dashed var(--border);border-radius:var(--r-md);background:var(--surface);min-height:0}.json-split-placeholder-text{color:var(--text-muted);font-size:.875rem}.json-split-placeholder .error-banner{margin:1rem}.json-split-panel .area-header{flex-wrap:wrap}@media(max-width:768px){.json-split-layout{grid-template-columns:1fr;min-height:auto}.json-split-panel .textarea{min-height:200px;resize:vertical}}@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:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 8px #0047ab59}.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;align-self:center}.swap-btn:hover{border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-sm)}.codec-layout{display:grid;grid-template-columns:1fr auto 1fr;gap:0 .75rem;align-items:stretch;min-height:60vh}.codec-layout .input-area,.codec-layout .output-area{display:flex;flex-direction:column;min-height:0;margin-bottom:0}.codec-layout .input-area{grid-column:1}.codec-layout .output-area{grid-column:3}.codec-layout .textarea{flex:1;min-height:0;resize:none}.codec-layout .json-output{flex:1;min-height:0;max-height:none}.codec-layout .swap-btn{align-self:center;grid-column:2;margin:0}.codec-layout .area-header{flex-wrap:wrap}.file-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:var(--accent-subtle);border:1px solid rgba(0,71,171,.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-output-foldable{padding:.5rem 0}.json-line{display:flex;align-items:baseline;padding:0 .75rem 0 0}.json-line:hover{background:#ffffff08}.json-line-num{width:3ch;min-width:3ch;text-align:right;color:#585b70;-webkit-user-select:none;user-select:none;padding-right:.5rem;flex-shrink:0}.json-fold-toggle{width:1.25rem;min-width:1.25rem;text-align:center;color:#6c7086;font-size:.625rem;-webkit-user-select:none;user-select:none;flex-shrink:0}.json-fold-toggle-active{cursor:pointer}.json-fold-toggle-active:hover{color:#cdd6f4}.json-line-content{flex:1;white-space:pre}.json-collapsed-indicator{font-style:italic;color:#6c7086;cursor:pointer;margin-left:.25rem}.json-collapsed-indicator:hover,.json-key{color:#89b4fa}.json-string{color:#a6e3a1}.json-number{color:#fab387}.json-boolean{color:#cba6f7}.json-null{color:#f38ba8}.css-selector{color:#89b4fa}.css-property{color:#89dceb}.css-at-rule{color:#cba6f7}.css-number{color:#fab387}.css-color-token{color:#f5c2e7}.css-string{color:#a6e3a1}.css-important{color:#f38ba8;font-style:italic}.sql-keyword{color:#cba6f7}.sql-string{color:#a6e3a1}.sql-number{color:#fab387}.sql-comment{color:#6c7086;font-style:italic}.sql-function,.xml-tag{color:#89b4fa}.xml-attr-name{color:#89dceb}.xml-attr-value{color:#a6e3a1}.xml-comment{color:#6c7086;font-style:italic}.xml-cdata{color:#fab387}.xml-pi{color:#cba6f7}.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}.sidebar-collapse-btn{display:none}.sidebar-expand-btn{display:none!important}.sidebar.collapsed{margin-left:0}.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{grid-template-columns:1fr;min-height:auto}.codec-layout .input-area,.codec-layout .output-area,.codec-layout .swap-btn{grid-column:1}.codec-layout .textarea{min-height:200px;resize:vertical}.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, #0047AB)}.model-option.active{border-color:var(--accent, #0047AB);background:#ebf4ff}.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, #0047AB)}.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, #0047AB);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, #0047AB)}.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, #0047AB);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, #0047AB)}.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, #0047AB);color:#fff;border-color:var(--accent, #0047AB)}.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}}.pm-sidebar::-webkit-scrollbar{width:4px}.pm-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
