body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--radius:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;--brand:#1a7f4b;--brand-dark:#155f38;--brand-light:#e9f7f0;--bg:#f0f2f5;--surface:#ffffff;--border:#d0d7de;--text:#24292f;--text-muted:#6e7781;--error:#cf222e;--error-bg:#fff0ee;--shadow:0 1px 4px rgba(0,0,0,0.08);--header-bg:linear-gradient(135deg,#1a7f4b,#155f38);--header-border:transparent;--header-shadow:0 2px 8px rgba(0,0,0,0.18);--node-hover:#f3f4f6;--empty-icon:#d0d7de;--collapsed-hint-bg:#f1f1f1;--json-string:#22863a;--json-number:#005cc5;--json-bool:#e36209;--json-null:#6f42c1;--json-key:#24292e;--json-index:#8250df;--badge-valid-bg:#dafbe1;--badge-valid-fg:#116329;--badge-lenient-bg:#fff8c5;--badge-lenient-fg:#7d4e00;--lenient-bar-bg:#fff8c5;--lenient-bar-fg:#7d4e00;--lenient-bar-border:#e3c84a;--type-str-bg:#d4edda;--type-str-fg:#155724;--type-num-bg:#cce5ff;--type-num-fg:#004085;--type-bool-bg:#fff3cd;--type-bool-fg:#856404;--type-obj-bg:#e2e3e5;--type-obj-fg:#383d41;--type-null-bg:#ede4f5;--type-null-fg:#6f42c1;--flash-bg:#b7f0d0;--pulse-bg:#b7f0d0}.json-node-copy-btn{all:unset;cursor:pointer;display:none;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;margin-left:auto;border-radius:5px;color:var(--text-muted);opacity:0;transition:opacity .15s,background .15s,color .15s}.json-node-line:hover .json-node-copy-btn{opacity:1}.json-node-copy-btn:hover{background:var(--brand-light);color:var(--brand)}@media (pointer:coarse){.json-node-copy-btn{display:inline-flex;opacity:1;width:36px;height:36px;color:var(--text-muted)}.json-sheet-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9998;animation:sheet-fade-in .2s ease}.json-bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--surface);border-radius:18px 18px 0 0;padding-bottom:env(safe-area-inset-bottom,12px);box-shadow:0 -4px 32px rgba(0,0,0,.18);animation:sheet-slide-up .26s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}.json-sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--border);margin:10px auto 4px;flex-shrink:0}.json-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:8px 20px 6px;flex-shrink:0}.json-sheet-title{font-size:13px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.json-sheet-close{all:unset;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg);color:var(--text-muted);font-size:13px;font-weight:600}.json-sheet-items{display:flex;flex-direction:column;gap:2px;padding:4px 12px 16px;overflow-y:auto}.json-sheet-items .ctx-item{padding:14px 12px;font-size:15px;border-radius:10px;min-height:52px}.json-sheet-items .ctx-label{font-size:15px}.json-sheet-items .ctx-hint{font-size:12px}}@media (pointer:coarse){@keyframes sheet-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheet-fade-in{0%{opacity:0}to{opacity:1}}}html[data-theme=dark]{--brand:#1db887;--brand-dark:#17976e;--brand-light:rgba(29,184,135,0.15);--bg:#13151e;--surface:#1a1e2d;--border:#252a3d;--text:#e2e8f0;--text-muted:#7f8ea3;--error:#f85149;--error-bg:rgba(248,81,73,0.12);--shadow:0 1px 6px rgba(0,0,0,0.4);--header-bg:#0d1017;--header-border:#252a3d;--header-shadow:0 2px 12px rgba(0,0,0,0.5);--node-hover:rgba(255,255,255,0.05);--empty-icon:#2e3650;--collapsed-hint-bg:rgba(255,255,255,0.06);--json-string:#3fb950;--json-number:#58a6ff;--json-bool:#e3b341;--json-null:#c397d8;--json-key:#79c0ff;--json-index:#c397d8;--badge-valid-bg:rgba(29,184,135,0.15);--badge-valid-fg:#1db887;--badge-lenient-bg:rgba(227,179,65,0.15);--badge-lenient-fg:#e3b341;--lenient-bar-bg:rgba(227,179,65,0.1);--lenient-bar-fg:#e3b341;--lenient-bar-border:rgba(227,179,65,0.25);--type-str-bg:rgba(63,185,80,0.15);--type-str-fg:#3fb950;--type-num-bg:rgba(88,166,255,0.15);--type-num-fg:#58a6ff;--type-bool-bg:rgba(227,179,65,0.15);--type-bool-fg:#e3b341;--type-obj-bg:rgba(255,255,255,0.08);--type-obj-fg:#7f8ea3;--type-null-bg:rgba(195,151,216,0.15);--type-null-fg:#c397d8;--flash-bg:rgba(29,184,135,0.3);--pulse-bg:rgba(29,184,135,0.2)}body,html{height:100%;overflow:hidden;background:var(--bg);color:var(--text)}.app{flex-direction:column;height:100vh}.app,.tool-region{display:flex;overflow:hidden}.tool-region{flex:1 1;flex-direction:column;min-height:0}.tool-region--hidden{display:none}.tool-nav{display:inline-flex;gap:2px;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:2px;background:rgba(0,0,0,.12)}.tool-nav-btn{all:unset;cursor:pointer;padding:5px 16px;font-size:13px;font-weight:600;border-radius:6px;color:rgba(255,255,255,.7);white-space:nowrap;transition:background .15s,color .15s}.tool-nav-btn:hover:not(.tool-nav-btn--active){background:rgba(255,255,255,.12);color:rgba(255,255,255,.95)}.tool-nav-btn--active{background:rgba(255,255,255,.22);color:#fff;font-weight:700}.app-header{background:var(--header-bg);color:#fff;padding:12px 20px;border-bottom:1px solid var(--header-border);box-shadow:var(--header-shadow);flex-shrink:0;gap:20px}.app-header,.app-header-inner{display:flex;align-items:center}.app-header-inner{gap:16px;flex:1 1}.app-logo{display:flex;align-items:center;gap:10px}.logo-icon{width:36px;height:36px;border-radius:8px;object-fit:contain;flex-shrink:0}.logo-text{font-size:20px;font-weight:700;letter-spacing:-.5px}.app-tagline{font-size:13px;opacity:.8}.theme-toggle{all:unset;cursor:pointer;width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(255,255,255,.15);color:#fff;transition:background .2s,transform .2s;flex-shrink:0;margin-left:auto}.theme-toggle:hover{background:rgba(255,255,255,.25);transform:rotate(15deg)}.app-main{flex:1 1;display:flex;flex-direction:column;overflow:hidden;padding:12px 16px 10px;gap:10px}.toolbar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-shrink:0;align-items:center}.btn,.toolbar{background:var(--surface)}.btn{padding:6px 14px;font-size:13px;font-weight:500;border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;transition:all .15s;line-height:1.4}.btn:hover:not(:disabled){background:var(--bg);border-color:var(--brand);color:var(--brand)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn.btn-primary:hover:not(:disabled){background:var(--brand-dark);border-color:var(--brand-dark);color:#fff}.btn.btn-sample{color:var(--brand);border-color:var(--brand)}.btn.btn-sample:hover:not(:disabled){background:var(--brand-light)}.editor-area{display:grid;grid-gap:12px;gap:12px;flex:1 1;overflow:hidden;min-height:0}.editor-area,.editor-area.layout-side{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.editor-area.layout-side.has-nav{grid-template-columns:210px 1fr 1fr}.editor-area.layout-side.has-nav-collapsed{grid-template-columns:36px 1fr 1fr}.editor-area.layout-stack{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.editor-area.layout-stack.has-nav{grid-template-columns:210px 1fr}.editor-area.layout-stack.has-nav-collapsed{grid-template-columns:36px 1fr}.editor-area.layout-stack .nav-panel{grid-row:1/-1}.editor-area.layout-focus{grid-template-columns:1fr;grid-template-rows:1fr}.editor-area.layout-focus.has-nav{grid-template-columns:210px 1fr;grid-template-rows:1fr}.editor-area.layout-focus.has-nav-collapsed{grid-template-columns:36px 1fr;grid-template-rows:1fr}.focus-switcher{display:inline-flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:6px;padding:2px;background:var(--surface)}.focus-tab{all:unset;cursor:pointer;display:flex;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;border-radius:4px;color:var(--text-muted);white-space:nowrap;transition:background .12s,color .12s}.focus-tab:hover{background:var(--bg);color:var(--text)}.focus-tab--active{background:var(--brand);color:#fff}.focus-tab--active:hover{background:var(--brand-dark)}.pane.pane--hidden{display:none}.layout-picker{display:inline-flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:6px;padding:2px;background:var(--surface);margin-left:auto}.layout-btn{all:unset;cursor:pointer;display:flex;align-items:center;justify-content:center;width:30px;height:26px;border-radius:4px;color:var(--text-muted);transition:background .12s,color .12s}.layout-btn:hover{background:var(--bg);color:var(--text)}.layout-btn.active{background:var(--brand-light);color:var(--brand)}.nav-panel,.pane{display:flex;flex-direction:column;overflow:hidden;min-height:0}.pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.pane-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.pane-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.status-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px}.status-badge.valid{background:var(--badge-valid-bg);color:var(--badge-valid-fg)}.status-badge.lenient{background:var(--badge-lenient-bg);color:var(--badge-lenient-fg)}.status-badge.invalid{background:var(--error-bg);color:var(--error)}.status-badge.extracted{background:rgba(88,166,255,.15);color:#2675c8}html[data-theme=dark] .status-badge.extracted{background:rgba(88,166,255,.15);color:#58a6ff}.extracted-bar{background:rgba(88,166,255,.08);color:#2675c8;padding:6px 14px;font-size:12px;border-top:1px solid rgba(88,166,255,.25);flex-shrink:0}html[data-theme=dark] .extracted-bar{color:#58a6ff}.json-textarea{flex:1 1;width:100%;padding:12px 14px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.6;border:none;outline:none;resize:none;background:var(--surface);color:var(--text);overflow:auto}.json-textarea::placeholder{color:var(--text-muted)}.lenient-bar{background:var(--lenient-bar-bg);color:var(--lenient-bar-fg);padding:6px 14px;font-size:12px;border-top:1px solid var(--lenient-bar-border);flex-shrink:0}.error-bar{background:var(--error-bg);border-top:1px solid rgba(207,34,46,.2);flex-shrink:0}html[data-theme=dark] .error-bar{border-top-color:rgba(248,81,73,.25)}.error-bar-header{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:12px;color:var(--error)}.error-bar-icon{flex-shrink:0}.error-bar-msg{flex:1 1;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.error-bar-loc{font-size:11px;font-weight:700;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;background:rgba(207,34,46,.1);padding:1px 6px;border-radius:4px;white-space:nowrap;color:var(--error)}.error-jump-btn{all:unset;cursor:pointer;font-size:11px;font-weight:600;color:var(--error);padding:2px 8px;border:1px solid var(--error);border-radius:4px;opacity:.75;white-space:nowrap;transition:opacity .15s,background .15s}.error-jump-btn:hover{opacity:1;background:var(--error-bg)}.err-code-block--bar{border-top:1px solid rgba(207,34,46,.15);padding:6px 0 8px;max-height:180px;overflow-y:auto;overflow-x:auto}.tabs{display:flex;gap:4px}.tab-btn{padding:4px 14px;font-size:12px;font-weight:500;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s}.tab-btn:hover{color:var(--brand);border-color:var(--brand)}.tab-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}.output-content{flex:1 1;overflow:auto;min-height:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:300px;gap:12px;color:var(--text-muted);text-align:center}.empty-icon{font-size:48px;font-family:monospace;font-weight:700;color:var(--empty-icon);line-height:1}.empty-state p{font-size:14px;max-width:220px}.output-error-panel{display:flex;flex-direction:column;height:100%;overflow-y:auto;background:var(--error-bg)}.output-error-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px;color:var(--error)}.output-error-title{font-size:15px;font-weight:700}.output-error-msg{padding:0 16px 10px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;color:var(--error);word-break:break-word}.output-error-loc{display:flex;align-items:center;gap:10px;padding:0 16px 12px}.output-error-loc-badge{font-size:12px;font-weight:700;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;background:rgba(207,34,46,.12);color:var(--error);padding:2px 8px;border-radius:4px}.output-error-snippet{flex:1 1;margin:0 16px 12px;border-radius:6px;background:rgba(0,0,0,.06);overflow:auto;min-height:0}html[data-theme=dark] .output-error-snippet{background:rgba(0,0,0,.3)}.output-error-snippet-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);padding:6px 10px 4px}.output-error-snippet-code{padding:4px 10px 8px;overflow-x:auto}.err-code-block{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12.5px;line-height:1.65;overflow-x:auto;white-space:pre;padding:6px 0 8px}.err-line{display:block;padding:0 14px}.err-line--active{background:rgba(207,34,46,.08);border-left:2px solid var(--error);padding-left:12px}html[data-theme=dark] .err-line--active{background:rgba(248,81,73,.1)}.err-line-num{color:var(--text-muted);opacity:.5;-webkit-user-select:none;-moz-user-select:none;user-select:none}.err-line--active .err-line-num{opacity:.8;color:var(--error)}.err-line-sep{color:var(--border);-webkit-user-select:none;-moz-user-select:none;user-select:none}.err-line--active .err-line-sep{color:var(--error);opacity:.4}.err-line-text{color:var(--text)}.err-caret-row,.err-line--active .err-line-text{color:var(--error)}.err-caret-row{display:block;padding:0 14px;font-weight:700;opacity:.9}.output-error-hint{padding:10px 16px 14px;font-size:12px;color:var(--text-muted);border-top:1px solid rgba(207,34,46,.12)}.json-formatted{padding:14px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.6;white-space:pre;-moz-tab-size:2;tab-size:2;color:var(--text)}.tree-wrapper{padding:12px 8px}.json-tree{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.8}.json-node{position:relative}.json-node-line{display:flex;align-items:baseline;gap:2px;padding:0 4px;border-radius:4px;white-space:nowrap}.json-node-line:hover{background:var(--node-hover)}.json-children{padding-left:20px;border-left:2px solid var(--border);margin-left:9px}.toggle-btn{all:unset;cursor:pointer;font-size:9px;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0;margin-right:2px}.toggle-btn:hover{color:var(--brand)}.toggle-placeholder{display:inline-block;width:16px;flex-shrink:0;margin-right:2px}.json-key{color:var(--json-key)}.json-index{color:var(--json-index);font-style:italic}.json-bracket,.json-colon{color:var(--text-muted)}.json-bracket{font-weight:600}.json-comma{color:var(--text-muted)}.json-key-label{cursor:pointer;border-radius:3px;padding:0 1px;transition:background .1s,color .1s}.json-key-label:hover{background:var(--brand-light);color:var(--brand)!important;text-decoration:underline;text-underline-offset:2px}@keyframes key-flash{0%{background:var(--flash-bg)}60%{background:var(--flash-bg)}to{background:transparent}}.json-node-flash{animation:key-flash 1.2s ease forwards;border-radius:4px}@keyframes target-pulse{0%{box-shadow:inset 3px 0 0 var(--brand);background:var(--pulse-bg)}65%{box-shadow:inset 3px 0 0 var(--brand);background:var(--pulse-bg)}to{box-shadow:none;background:transparent}}.json-node-target{animation:target-pulse 1.6s ease forwards;border-radius:4px}.json-context-menu{position:fixed;z-index:9999;min-width:200px;max-width:280px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 20px rgba(0,0,0,.14),0 1px 5px rgba(0,0,0,.08);padding:4px;display:flex;flex-direction:column;gap:1px;-webkit-user-select:none;-moz-user-select:none;user-select:none;outline:none}html[data-theme=dark] .json-context-menu{box-shadow:0 4px 24px rgba(0,0,0,.5),0 1px 6px rgba(0,0,0,.4)}.ctx-section-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);padding:4px 10px 3px}.ctx-item{all:unset;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 10px;border-radius:5px;cursor:pointer;font-size:12.5px;color:var(--text);transition:background .1s,color .1s;width:100%;box-sizing:border-box}.ctx-item:hover{background:var(--node-hover)}.ctx-item--copied{color:var(--brand)}.ctx-label{font-weight:500;white-space:nowrap;flex-shrink:0}.ctx-hint{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;text-align:right}.key-navigator{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;min-height:0}.nav-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0}.nav-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px}.nav-count{font-size:10px;font-weight:700;background:var(--brand-light);color:var(--brand);padding:1px 6px;border-radius:10px}.nav-collapse-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:4px;color:var(--text-muted);transition:background .15s,color .15s}.nav-collapse-btn:hover{background:var(--brand-light);color:var(--brand)}.key-navigator--collapsed{align-items:center;padding:10px 0;gap:10px;cursor:default}.nav-expand-btn{all:unset;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;color:var(--text-muted);transition:background .15s,color .15s}.nav-expand-btn:hover{background:var(--brand-light);color:var(--brand)}.nav-title-vertical{writing-mode:vertical-rl;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.nav-search-wrap{padding:6px 8px;border-bottom:1px solid var(--border);flex-shrink:0}.nav-search{width:100%;padding:5px 8px;font-size:12px;border:1px solid var(--border);border-radius:6px;outline:none;background:var(--bg);color:var(--text);font-family:inherit}.nav-search:focus{border-color:var(--brand);background:var(--surface)}.nav-list{flex:1 1;overflow-y:auto;padding:4px 0}.nav-item{all:unset;display:flex;align-items:center;gap:6px;width:100%;padding:4px 8px 4px 10px;font-size:12px;cursor:pointer;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background .1s;box-sizing:border-box}.nav-item:hover{background:var(--bg);color:var(--brand)}.nav-item.active{background:var(--brand-light);color:var(--brand);font-weight:600}.nav-type-badge{font-family:monospace;font-size:9px;font-weight:700;padding:1px 3px;border-radius:3px;flex-shrink:0;min-width:26px;text-align:center;letter-spacing:-.3px}.type-string{background:var(--type-str-bg);color:var(--type-str-fg)}.type-number{background:var(--type-num-bg);color:var(--type-num-fg)}.type-bool{background:var(--type-bool-bg);color:var(--type-bool-fg)}.type-array,.type-object{background:var(--type-obj-bg);color:var(--type-obj-fg)}.type-null{background:var(--type-null-bg);color:var(--type-null-fg)}.nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1}.nav-empty{text-align:center;padding:20px 8px;color:var(--text-muted);font-size:12px}.json-collapsed-hint{color:var(--text-muted);font-style:italic;font-size:11px;cursor:pointer;padding:0 6px;background:var(--collapsed-hint-bg);border-radius:4px;margin:0 4px}.json-collapsed-hint:hover{background:var(--brand-light);color:var(--brand)}.app-footer{justify-content:center;gap:10px;padding:6px 16px;font-size:11px;color:var(--text-muted);border-top:1px solid var(--border);background:var(--surface);flex-shrink:0}.app-footer,.app-footer-text{display:flex;align-items:center}.app-footer-text{gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-footer-version{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:10px;font-weight:600;padding:1px 6px;border-radius:4px;background:var(--bg);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;flex-shrink:0}.app-footer-dismiss{all:unset;cursor:pointer;display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;font-size:10px;color:var(--text-muted);flex-shrink:0;margin-left:auto;transition:background .12s,color .12s}.app-footer-dismiss:hover{background:var(--bg);color:var(--text)}@media (max-width:768px){body,html{overflow:auto}.app{height:auto;min-height:100vh}.tool-region{overflow:visible;flex:unset}.app-header{padding:8px 12px}.app-header-inner{gap:8px}.app-tagline{display:none}.logo-text{font-size:17px}.logo-icon{width:28px;height:28px}.tool-nav-btn{padding:5px 12px;font-size:12px}.app-main{padding:8px;overflow:visible}.toolbar{padding:6px 8px;gap:4px}.btn{padding:5px 10px;font-size:12px}.layout-picker{margin-left:0}.editor-area,.editor-area.has-nav,.editor-area.has-nav-collapsed,.editor-area.layout-focus,.editor-area.layout-focus.has-nav,.editor-area.layout-focus.has-nav-collapsed,.editor-area.layout-side,.editor-area.layout-side.has-nav,.editor-area.layout-side.has-nav-collapsed,.editor-area.layout-stack,.editor-area.layout-stack.has-nav,.editor-area.layout-stack.has-nav-collapsed{grid-template-columns:1fr;grid-template-rows:auto;overflow:visible;flex:unset}.nav-panel{display:none}.input-pane{min-height:280px}.output-pane{min-height:340px}.json-textarea{min-height:210px}.empty-state,.output-content{min-height:220px}.pane.pane--hidden{display:flex!important}}.b64-main{flex:1 1;display:flex;flex-direction:column;overflow:hidden;padding:12px 16px 0;gap:10px}.b64-toolbar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-shrink:0;align-items:center}.b64-mode-switcher{display:inline-flex;align-items:center;gap:2px;border:1px solid var(--border);border-radius:6px;padding:2px;background:var(--bg);margin-right:4px}.b64-mode-btn{all:unset;cursor:pointer;padding:4px 16px;font-size:12px;font-weight:600;border-radius:4px;color:var(--text-muted);white-space:nowrap;transition:background .12s,color .12s}.b64-mode-btn:hover:not(.b64-mode-btn--active){background:var(--bg);color:var(--text)}.b64-mode-btn--active{background:var(--brand);color:#fff}.b64-mode-btn--active:hover{background:var(--brand-dark)}.b64-editor-area{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px;flex:1 1;overflow:hidden;min-height:0}.b64-editor-area.layout-side{grid-template-columns:1fr 1fr;grid-template-rows:1fr}.b64-editor-area.layout-stack{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.b64-editor-area.layout-focus{grid-template-columns:1fr;grid-template-rows:1fr}.b64-output-area{flex:1 1;overflow:auto;min-height:0;display:flex;flex-direction:column}.b64-output-text{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-all;margin:0;background:var(--surface)}.b64-error,.b64-output-text{flex:1 1;padding:12px 14px;font-size:13px}.b64-error{color:var(--error);background:var(--error-bg)}.b64-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1 1;min-height:200px;gap:10px;color:var(--text-muted);text-align:center;padding:24px}.b64-empty-icon{font-size:32px;font-family:monospace;font-weight:700;color:var(--empty-icon);line-height:1;letter-spacing:-1px}.b64-empty p{font-size:14px;max-width:220px}.b64-error-row{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.b64-error-pos{flex-shrink:0;font-size:11px;font-weight:700;background:rgba(207,34,46,.12);color:var(--error);padding:1px 7px;border-radius:4px;white-space:nowrap}.b64-error-msg,.b64-error-pos{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.b64-error-msg{flex:1 1}.b64-error-hint{margin-top:6px;font-size:12px;opacity:.8;padding-top:6px;border-top:1px solid rgba(207,34,46,.15)}.b64-content-card{flex:1 1;display:flex;flex-direction:column;gap:10px;padding:24px 20px;font-size:13px}.b64-content-card--binary{background:color-mix(in srgb,#3b82f6 8%,transparent);border-left:3px solid #3b82f6;color:var(--fg,var(--text,inherit))}html[data-theme=dark] .b64-content-card--binary{background:color-mix(in srgb,#60a5fa 10%,transparent);border-left-color:#60a5fa}.b64-content-card--encrypted{background:color-mix(in srgb,#f59e0b 8%,transparent);border-left:3px solid #f59e0b;color:var(--fg,var(--text,inherit))}html[data-theme=dark] .b64-content-card--encrypted{background:color-mix(in srgb,#fbbf24 10%,transparent);border-left-color:#fbbf24}.b64-content-card-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.55;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.b64-content-card--binary .b64-content-card-label{color:#2563eb}.b64-content-card--encrypted .b64-content-card-label{color:#d97706}html[data-theme=dark] .b64-content-card--binary .b64-content-card-label{color:#93c5fd}html[data-theme=dark] .b64-content-card--encrypted .b64-content-card-label{color:#fcd34d}.b64-content-card-title{margin:0;font-size:15px;font-weight:600;line-height:1.35}.b64-content-card-desc{margin:0;font-size:13px;line-height:1.6;opacity:.8;max-width:520px}.b64-content-card-cta{align-self:flex-start;margin-top:4px}.b64-char-count{font-size:11px;font-weight:500;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.b64-auto-btn,.b64-char-count{color:var(--text-muted)}.btn.b64-auto-btn--on{background:var(--brand-light);color:var(--brand);border-color:var(--brand)}.btn.b64-auto-btn--on:hover:not(:disabled){background:var(--brand-light);color:var(--brand-dark);border-color:var(--brand-dark)}.b64-suggestion{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:7px 12px;background:var(--brand-light);border:1px solid var(--brand);border-radius:var(--radius);font-size:13px;color:var(--brand-dark);flex-shrink:0}html[data-theme=dark] .b64-suggestion{color:var(--brand)}.b64-suggestion-msg{flex:1 1;font-weight:500}.b64-suggestion-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.b64-suggestion-accept{all:unset;cursor:pointer;padding:3px 12px;font-size:12px;font-weight:600;border-radius:5px;background:var(--brand);color:#fff;transition:background .15s;white-space:nowrap}.b64-suggestion-accept:hover{background:var(--brand-dark)}.b64-suggestion-dismiss{all:unset;cursor:pointer;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;font-size:14px;color:var(--brand);opacity:.7;transition:opacity .15s,background .15s}.b64-suggestion-dismiss:hover{opacity:1;background:rgba(0,0,0,.06)}.b64-norm-banner{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;background:color-mix(in srgb,var(--success,#22c55e) 10%,transparent);border:1px solid color-mix(in srgb,var(--success,#22c55e) 40%,transparent);border-radius:var(--radius);font-size:13px;color:var(--fg);flex-shrink:0}.b64-norm-banner-icon{flex-shrink:0;font-size:14px;color:var(--success,#16a34a);font-weight:700;margin-top:1px}.b64-norm-banner-body{flex:1 1;min-width:0}.b64-norm-banner-title{font-weight:600;display:block;margin-bottom:3px;color:var(--success,#16a34a)}.b64-norm-banner-list{margin:0;padding-left:16px;opacity:.85}.b64-norm-banner-list li{line-height:1.5}.b64-norm-banner-dismiss{all:unset;cursor:pointer;flex-shrink:0;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;font-size:14px;opacity:.6;transition:opacity .15s,background .15s;margin-top:-1px}.b64-norm-banner-dismiss:hover{opacity:1;background:rgba(0,0,0,.06)}.b64-view-switcher{display:inline-flex;gap:2px;border:1px solid var(--border);border-radius:6px;padding:2px;background:var(--bg)}.b64-view-btn{all:unset;cursor:pointer;padding:4px 16px;font-size:12px;font-weight:600;border-radius:4px;color:var(--text-muted);transition:background .12s,color .12s}.b64-view-btn:hover:not(.b64-view-btn--active){background:var(--bg);color:var(--text)}.b64-view-btn--active{background:var(--brand);color:#fff}.b64-toolbar-divider{width:1px;height:20px;background:var(--border);flex-shrink:0}.b64-file-toolbar-meta{display:flex;align-items:baseline;gap:8px;font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:340px}.b64-file-toolbar-size{font-size:11px;font-weight:400;color:var(--text-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;flex-shrink:0}.b64-file-drop-pane{display:flex;flex-direction:column;overflow:hidden}.b64-file-drop-pane--active{border-color:var(--brand);background:var(--brand-light)}.b64-file-reselect{all:unset;cursor:pointer;font-size:11px;font-weight:600;color:var(--brand);transition:opacity .15s}.b64-file-reselect:hover{opacity:.75}.b64-dropzone-full{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;padding:32px 24px;text-align:center;color:var(--text-muted);border:2px dashed transparent;border-radius:6px;margin:8px;transition:border-color .15s,background .15s,color .15s}.b64-dropzone-full:hover,.b64-file-drop-pane--active .b64-dropzone-full{border-color:var(--brand);background:var(--brand-light);color:var(--brand)}.b64-dropzone-full svg{opacity:.45;transition:opacity .15s}.b64-dropzone-full:hover svg,.b64-file-drop-pane--active .b64-dropzone-full svg{opacity:.8}.b64-dropzone-full-label{font-size:15px;font-weight:500;line-height:1.5}.b64-dropzone-link{color:var(--brand);font-weight:600}.b64-dropzone-hint{font-size:12px;opacity:.65}.b64-file-loading{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:32px 24px;text-align:center}.b64-file-loading-name{font-size:13px;font-weight:600;color:var(--text);word-break:break-all}.b64-progress-bar{width:100%;max-width:260px;height:6px;background:var(--border);border-radius:99px;overflow:hidden}.b64-progress-bar--large{max-width:100%;height:8px}.b64-progress-fill{height:100%;background:var(--brand);border-radius:99px;transition:width .1s linear}.b64-file-loading-pct{font-size:22px;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--brand)}.b64-file-error-full{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 24px;text-align:center;color:var(--error)}.b64-file-error-full svg{opacity:.7}.b64-file-error-msg{font-size:13px;font-weight:500;color:var(--error)}.b64-file-error-name{font-size:12px;color:var(--text-muted);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;margin-bottom:6px;word-break:break-all}.b64-file-info-full{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 24px;text-align:center}.b64-file-icon-wrap{font-size:40px;line-height:1}.b64-file-done-name{font-size:14px;font-weight:600;color:var(--text);word-break:break-all;max-width:100%}.b64-file-dl{display:flex;flex-direction:column;gap:6px;width:100%;max-width:280px;margin-top:4px}.b64-file-dl>div{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:5px 10px;background:var(--bg);border-radius:5px;font-size:12px}.b64-file-dl dt{font-weight:500;color:var(--text-muted);white-space:nowrap}.b64-file-dl dd{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--text);font-weight:600;text-align:right;word-break:break-all}.b64-decode-preview,.b64-preview-area{flex:1 1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.b64-preview-pdf{flex:1 1;width:100%;min-height:0;border:none;display:block}.b64-preview-media-wrap{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;gap:16px}.b64-preview-audio{width:100%;max-width:420px}.b64-preview-video{width:100%;max-width:100%;max-height:100%;border-radius:6px;box-shadow:0 2px 16px rgba(0,0,0,.14)}.b64-preview-image-wrap{flex:1 1;display:flex;align-items:center;justify-content:center;overflow:auto;padding:16px;background:repeating-conic-gradient(rgba(0,0,0,.04) 0 25%,transparent 0 50%) 0 0 /16px 16px}.b64-preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px;box-shadow:0 2px 12px rgba(0,0,0,.12)}.b64-preview-text{flex:1 1;overflow:auto;min-height:0}.b64-preview-binary{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 24px;text-align:center}.b64-preview-binary-hint{font-size:12px;color:var(--text-muted);margin-top:4px}.b64-download-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap}.b64-decode-meta{flex-direction:row;flex-wrap:wrap;gap:4px;margin:0;max-width:none}.b64-decode-meta>div{padding:3px 8px;font-size:11px}.b64-download-btn{flex-shrink:0;white-space:nowrap;font-size:13px;font-weight:600;text-decoration:none;padding:7px 18px}@keyframes b64-indeterminate{0%{transform:translateX(-100%);width:60%}50%{width:40%}to{transform:translateX(260%);width:60%}}@media (max-width:768px){.b64-main{padding:8px;overflow:visible;flex:unset}.b64-toolbar{padding:6px 8px;gap:4px}.b64-editor-area,.b64-editor-area.layout-focus,.b64-editor-area.layout-side,.b64-editor-area.layout-stack{grid-template-columns:1fr;grid-template-rows:auto;overflow:visible;flex:unset}.b64-editor-area .pane{min-height:280px}.b64-output-area,.b64-output-text{min-height:180px}.b64-file-drop-pane{min-height:220px}.pane.pane--hidden{display:flex!important}}.jwt-wrapper{flex:1 1;display:flex;flex-direction:column;overflow:hidden;padding:12px 16px 0;gap:10px}.jwt-toolbar{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-shrink:0;align-items:center}.jwt-tool{display:flex;flex:1 1;overflow:hidden;gap:0;min-height:0}.jwt-tool.layout-side{flex-direction:row}.jwt-tool.layout-side .jwt-input-pane{width:42%;min-width:260px;border-right:1px solid var(--border);border-bottom:none}.jwt-tool.layout-stack{flex-direction:column}.jwt-tool.layout-stack .jwt-input-pane{width:100%;min-width:unset;height:40%;border-right:none;border-bottom:1px solid var(--border)}.jwt-tool.layout-stack .jwt-segments-pane{height:60%;flex:unset}.jwt-tool.layout-focus{flex-direction:row}.jwt-tool.layout-focus .jwt-input-pane{width:100%;min-width:0;border-right:none}.jwt-tool.layout-focus .jwt-segments-pane{flex:1 1;width:100%;min-width:0}.jwt-pane--hidden{display:none!important}.jwt-input-pane,.jwt-segments-pane{display:flex;flex-direction:column;overflow:hidden}.jwt-segments-pane{flex:1 1}.jwt-pane-header{display:flex;align-items:center;gap:8px;padding:8px 14px;border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0}.jwt-pane-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;flex:1 1}.jwt-pane-actions{display:flex;gap:6px;align-items:center}.jwt-textarea-wrap{position:relative;flex:1 1;overflow:hidden;display:flex;flex-direction:column}.jwt-textarea{flex:1 1;width:100%;height:100%;resize:none;padding:14px;font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:12.5px;line-height:1.65;background:var(--surface);color:var(--text);border:none;outline:none;caret-color:var(--text);word-break:break-all;white-space:pre-wrap}.jwt-textarea-wrap.has-overlay .jwt-textarea{color:transparent}.jwt-textarea::placeholder{color:var(--text-muted);opacity:.65;font-style:italic}.jwt-colored-token{position:absolute;inset:0;padding:14px;font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:12.5px;line-height:1.65;word-break:break-all;white-space:pre-wrap;pointer-events:none;overflow:hidden}.jwt-ct-header{color:#e06c75}.jwt-ct-payload{color:#c678dd}.jwt-ct-signature{color:#56b6c2}.jwt-ct-dot{color:var(--text-muted)}html[data-theme=dark] .jwt-ct-header{color:#f28b82}html[data-theme=dark] .jwt-ct-payload{color:#d7a5ec}html[data-theme=dark] .jwt-ct-signature{color:#7ee0eb}.jwt-error-bar{display:flex;align-items:center;gap:7px;padding:8px 14px;background:var(--error-bg);color:var(--error);font-size:12px;font-weight:500;border-top:1px solid var(--error);flex-shrink:0}.jwt-error-bar-icon{flex-shrink:0}.jwt-segments{display:flex;flex-direction:column;overflow-y:auto;flex:1 1;gap:0}.jwt-seg{border-bottom:1px solid var(--border);flex-shrink:0}.jwt-seg:last-child{border-bottom:none}.jwt-seg--header{--seg-accent:#e06c75}.jwt-seg--payload{--seg-accent:#c678dd}.jwt-seg--signature{--seg-accent:#56b6c2}html[data-theme=dark] .jwt-seg--header{--seg-accent:#f28b82}html[data-theme=dark] .jwt-seg--payload{--seg-accent:#d7a5ec}html[data-theme=dark] .jwt-seg--signature{--seg-accent:#7ee0eb}.jwt-seg-header{display:flex;align-items:center;gap:8px;padding:10px 14px 8px;background:var(--surface);border-bottom:1px solid var(--border)}.jwt-seg-dot{width:10px;height:10px;border-radius:50%;background:var(--seg-accent);flex-shrink:0}.jwt-seg-label{font-size:13px;font-weight:700;color:var(--text)}.jwt-seg-desc{font-size:11px;color:var(--text-muted);margin-left:2px}.jwt-seg-body{padding:12px 14px;background:var(--bg);gap:10px}.jwt-seg-body,.jwt-seg-section{display:flex;flex-direction:column}.jwt-seg-section{gap:4px}.jwt-seg-section-header{display:flex;align-items:center;justify-content:space-between;gap:6px;min-height:18px}.jwt-seg-section-title{font-weight:600;text-transform:uppercase;letter-spacing:.07em}.jwt-copy-btn,.jwt-seg-section-title{font-size:10px;color:var(--text-muted)}.jwt-copy-btn{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;font-weight:500;border-radius:4px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:color .1s,border-color .1s,background .1s;flex-shrink:0;line-height:1.5}.jwt-copy-btn:hover{color:var(--text);border-color:var(--text-muted);background:var(--bg)}.jwt-copy-btn--done{color:var(--brand,#22c55e);border-color:var(--brand,#22c55e);background:var(--surface)}.jwt-seg-raw{font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:11.5px;line-height:1.6;color:var(--seg-accent);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius,6px);padding:8px 10px;word-break:break-all;white-space:pre-wrap;margin:0}.jwt-seg-decode-placeholder{display:flex;align-items:center;gap:6px;padding:8px 10px;border:1px dashed var(--border);border-radius:var(--radius,6px)}.jwt-seg-decode-placeholder,.jwt-seg-empty{font-size:12px;color:var(--text-muted);font-style:italic}.jwt-seg-empty{padding:2px 0}.jwt-seg-decoded{font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;line-height:1.65;color:var(--text);background:var(--surface);border:1px solid var(--border);word-break:break-all;white-space:pre-wrap;margin:0}.jwt-seg-decode-error,.jwt-seg-decoded{font-size:12px;border-radius:var(--radius,6px);padding:8px 10px}.jwt-seg-decode-error{display:flex;align-items:flex-start;gap:7px;background:var(--error-bg);color:var(--error);font-weight:500;border:1px solid var(--error);word-break:break-word}.jwt-seg-decode-error svg{flex-shrink:0;margin-top:1px}.jwt-seg-sig-note{font-size:12px;color:var(--text-muted);font-style:italic;line-height:1.55;padding:2px 0}@media (max-width:768px){.jwt-wrapper{padding:8px;overflow:visible;flex:unset}.jwt-toolbar{padding:6px 8px;gap:4px}.jwt-tool,.jwt-tool.layout-focus,.jwt-tool.layout-side,.jwt-tool.layout-stack{flex-direction:column;overflow:visible;flex:unset;min-height:0}.jwt-input-pane,.jwt-tool.layout-focus .jwt-input-pane,.jwt-tool.layout-side .jwt-input-pane{width:100%;min-width:0;height:auto;min-height:240px;border-right:none;border-bottom:1px solid var(--border)}.jwt-tool.layout-stack .jwt-input-pane{height:auto;min-height:200px}.jwt-tool.layout-stack .jwt-segments-pane{height:auto;flex:unset;min-height:380px}.jwt-segments-pane{flex:unset;min-height:380px}.jwt-pane--hidden{display:flex!important}}