*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{width:100%;min-height:100vh}.b64-main{flex-direction:column;flex:1;gap:10px;padding:12px 16px 0;display:flex;overflow:hidden}.b64-toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;display:flex}.b64-mode-switcher{border:1px solid var(--border);background:var(--bg);border-radius:6px;align-items:center;gap:2px;margin-right:4px;padding:2px;display:inline-flex}.b64-mode-btn{all:unset;cursor:pointer;color:var(--text-muted);white-space:nowrap;border-radius:4px;padding:4px 16px;font-size:12px;font-weight:600;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{flex:1;grid-template-columns:1fr 1fr;gap:12px;min-height:0;display:grid;overflow:hidden}.b64-editor-area.layout-side{grid-template-rows:1fr;grid-template-columns:1fr 1fr}.b64-editor-area.layout-stack{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.b64-editor-area.layout-focus{grid-template-rows:1fr;grid-template-columns:1fr}.b64-output-area{flex-direction:column;flex:1;min-height:0;display:flex;overflow:auto}.b64-output-text{color:var(--text);white-space:pre-wrap;word-break:break-all;background:var(--surface);flex:1;margin:0;padding:12px 14px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.6}.b64-error{color:var(--error);background:var(--error-bg);flex:1;padding:12px 14px;font-size:13px}.b64-empty{min-height:200px;color:var(--text-muted);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:24px;display:flex}.b64-empty-icon{color:var(--empty-icon);letter-spacing:-1px;font-family:monospace;font-size:32px;font-weight:700;line-height:1}.b64-empty p{max-width:220px;font-size:14px}.b64-error-row{flex-wrap:wrap;align-items:baseline;gap:8px;display:flex}.b64-error-pos{color:var(--error);white-space:nowrap;background:#cf222e1f;border-radius:4px;flex-shrink:0;padding:1px 7px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:11px;font-weight:700}.b64-error-msg{flex:1;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.b64-error-hint{opacity:.8;border-top:1px solid #cf222e26;margin-top:6px;padding-top:6px;font-size:12px}.b64-content-card{flex-direction:column;flex:1;gap:10px;padding:24px 20px;font-size:13px;display:flex}.b64-content-card--binary{color:var(--fg,var(--text,inherit));background:#3b82f614;border-left:3px solid #3b82f6}html[data-theme=dark] .b64-content-card--binary{background:#60a5fa1a;border-left-color:#60a5fa}.b64-content-card--encrypted{color:var(--fg,var(--text,inherit));background:#f59e0b14;border-left:3px solid #f59e0b}html[data-theme=dark] .b64-content-card--encrypted{background:#fbbf241a;border-left-color:#fbbf24}.b64-content-card-label{letter-spacing:.08em;text-transform:uppercase;opacity:.55;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:10px;font-weight:700}.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{opacity:.8;max-width:520px;margin:0;font-size:13px;line-height:1.6}.b64-content-card-cta{align-self:flex-start;margin-top:4px}.b64-char-count{color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:11px;font-weight:500}.b64-auto-btn{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{background:var(--brand-light);border:1px solid var(--brand);border-radius:var(--radius);color:var(--brand-dark);flex-shrink:0;justify-content:space-between;align-items:center;gap:10px;padding:7px 12px;font-size:13px;display:flex}html[data-theme=dark] .b64-suggestion{color:var(--brand)}.b64-suggestion-msg{flex:1;font-weight:500}.b64-suggestion-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.b64-suggestion-accept{all:unset;cursor:pointer;background:var(--brand);color:#fff;white-space:nowrap;border-radius:5px;padding:3px 12px;font-size:12px;font-weight:600;transition:background .15s}.b64-suggestion-accept:hover{background:var(--brand-dark)}.b64-suggestion-dismiss{all:unset;cursor:pointer;width:22px;height:22px;color:var(--brand);opacity:.7;border-radius:4px;justify-content:center;align-items:center;font-size:14px;transition:opacity .15s,background .15s;display:inline-flex}.b64-suggestion-dismiss:hover{opacity:1;background:#0000000f}.b64-norm-banner{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);color:var(--fg);flex-shrink:0;align-items:flex-start;gap:10px;padding:8px 12px;font-size:13px;display:flex}.b64-norm-banner-icon{color:var(--success,#16a34a);flex-shrink:0;margin-top:1px;font-size:14px;font-weight:700}.b64-norm-banner-body{flex:1;min-width:0}.b64-norm-banner-title{color:var(--success,#16a34a);margin-bottom:3px;font-weight:600;display:block}.b64-norm-banner-list{opacity:.85;margin:0;padding-left:16px}.b64-norm-banner-list li{line-height:1.5}.b64-norm-banner-dismiss{all:unset;cursor:pointer;opacity:.6;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-top:-1px;font-size:14px;transition:opacity .15s,background .15s;display:inline-flex}.b64-norm-banner-dismiss:hover{opacity:1;background:#0000000f}.b64-view-switcher{border:1px solid var(--border);background:var(--bg);border-radius:6px;gap:2px;padding:2px;display:inline-flex}.b64-view-btn{all:unset;cursor:pointer;color:var(--text-muted);border-radius:4px;padding:4px 16px;font-size:12px;font-weight:600;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{background:var(--border);flex-shrink:0;width:1px;height:20px}.b64-file-toolbar-meta{color:var(--text);white-space:nowrap;text-overflow:ellipsis;align-items:baseline;gap:8px;max-width:340px;font-size:13px;font-weight:600;display:flex;overflow:hidden}.b64-file-toolbar-size{color:var(--text-muted);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:11px;font-weight:400}.b64-file-drop-pane{flex-direction:column;display:flex;overflow:hidden}.b64-file-drop-pane--active{border-color:var(--brand);background:var(--brand-light)}.b64-file-reselect{all:unset;cursor:pointer;color:var(--brand);font-size:11px;font-weight:600;transition:opacity .15s}.b64-file-reselect:hover{opacity:.75}.b64-dropzone-full{cursor:pointer;text-align:center;color:var(--text-muted);border:2px dashed #0000;border-radius:6px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;margin:8px;padding:32px 24px;transition:border-color .15s,background .15s,color .15s;display:flex}.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{opacity:.65;font-size:12px}.b64-file-loading{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;padding:32px 24px;display:flex}.b64-file-loading-name{color:var(--text);word-break:break-all;font-size:13px;font-weight:600}.b64-progress-bar{background:var(--border);border-radius:99px;width:100%;max-width:260px;height:6px;overflow:hidden}.b64-progress-bar--large{max-width:100%;height:8px}.b64-progress-fill{background:var(--brand);border-radius:99px;height:100%;transition:width .1s linear}.b64-file-loading-pct{font-variant-numeric:tabular-nums;color:var(--brand);font-size:22px;font-weight:700}.b64-file-error-full{text-align:center;color:var(--error);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:32px 24px;display:flex}.b64-file-error-full svg{opacity:.7}.b64-file-error-msg{color:var(--error);font-size:13px;font-weight:500}.b64-file-error-name{color:var(--text-muted);word-break:break-all;margin-bottom:6px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}.b64-file-info-full{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:32px 24px;display:flex}.b64-file-icon-wrap{font-size:40px;line-height:1}.b64-file-done-name{color:var(--text);word-break:break-all;max-width:100%;font-size:14px;font-weight:600}.b64-file-dl{flex-direction:column;gap:6px;width:100%;max-width:280px;margin-top:4px;display:flex}.b64-file-dl>div{background:var(--bg);border-radius:5px;justify-content:space-between;align-items:baseline;gap:8px;padding:5px 10px;font-size:12px;display:flex}.b64-file-dl dt{color:var(--text-muted);white-space:nowrap;font-weight:500}.b64-file-dl dd{font-variant-numeric:tabular-nums;color:var(--text);text-align:right;word-break:break-all;font-weight:600}.b64-preview-area,.b64-decode-preview{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.b64-preview-pdf{border:none;flex:1;width:100%;min-height:0;display:block}.b64-preview-media-wrap{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:24px;display:flex}.b64-preview-audio{width:100%;max-width:420px}.b64-preview-video{border-radius:6px;width:100%;max-width:100%;max-height:100%;box-shadow:0 2px 16px #00000024}.b64-preview-image-wrap{background:repeating-conic-gradient(#0000000a 0% 25%,#0000 0% 50%) 0 0/16px 16px;flex:1;justify-content:center;align-items:center;padding:16px;display:flex;overflow:auto}.b64-preview-image{object-fit:contain;border-radius:4px;max-width:100%;max-height:100%;box-shadow:0 2px 12px #0000001f}.b64-preview-text{flex:1;min-height:0;overflow:auto}.b64-preview-binary{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:10px;padding:32px 24px;display:flex}.b64-preview-binary-hint{color:var(--text-muted);margin-top:4px;font-size:12px}.b64-download-bar{border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.b64-decode-meta{flex-flow:wrap;gap:4px;max-width:none;margin:0}.b64-decode-meta>div{padding:3px 8px;font-size:11px}.b64-download-btn{white-space:nowrap;flex-shrink:0;padding:7px 18px;font-size:13px;font-weight:600;text-decoration:none}@keyframes b64-indeterminate{0%{width:60%;transform:translate(-100%)}50%{width:40%}to{width:60%;transform:translate(260%)}}.jwt-wrapper{flex-direction:column;flex:1;gap:10px;padding:12px 16px 0;display:flex;overflow:hidden}.jwt-toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;display:flex}.jwt-tool{flex:1;gap:0;min-height:0;display:flex;overflow:hidden}.jwt-tool.layout-side{flex-direction:row}.jwt-tool.layout-side .jwt-input-pane{border-right:1px solid var(--border);border-bottom:none;width:42%;min-width:260px}.jwt-tool.layout-stack{flex-direction:column}.jwt-tool.layout-stack .jwt-input-pane{width:100%;min-width:unset;border-right:none;border-bottom:1px solid var(--border);height:40%}.jwt-tool.layout-stack .jwt-segments-pane{flex:unset;height:60%}.jwt-tool.layout-focus{flex-direction:row}.jwt-tool.layout-focus .jwt-input-pane{border-right:none;width:100%;min-width:0}.jwt-tool.layout-focus .jwt-segments-pane{flex:1;width:100%;min-width:0}.jwt-pane--hidden{display:none!important}.jwt-input-pane{flex-direction:column;display:flex;overflow:hidden}.jwt-segments-pane{flex-direction:column;flex:1;display:flex;overflow:hidden}.jwt-pane-header{border-bottom:1px solid var(--border);background:var(--surface);flex-shrink:0;align-items:center;gap:8px;padding:8px 14px;display:flex}.jwt-pane-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;flex:1;font-size:12px;font-weight:600}.jwt-pane-actions{align-items:center;gap:6px;display:flex}.jwt-textarea-wrap{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.jwt-textarea{resize:none;background:var(--surface);width:100%;height:100%;color:var(--text);caret-color:var(--text);word-break:break-all;white-space:pre-wrap;border:none;outline:none;flex:1;padding:14px;font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:12.5px;line-height:1.65}.jwt-textarea-wrap.has-overlay .jwt-textarea{color:#0000}.jwt-textarea::placeholder{color:var(--text-muted);opacity:.65;font-style:italic}.jwt-colored-token{word-break:break-all;white-space:pre-wrap;pointer-events:none;padding:14px;font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:12.5px;line-height:1.65;position:absolute;inset:0;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{background:var(--error-bg);color:var(--error);border-top:1px solid var(--error);flex-shrink:0;align-items:center;gap:7px;padding:8px 14px;font-size:12px;font-weight:500;display:flex}.jwt-error-bar-icon{flex-shrink:0}.jwt-segments{flex-direction:column;flex:1;gap:0;display:flex;overflow-y:auto}.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{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 14px 8px;display:flex}.jwt-seg-dot{background:var(--seg-accent);border-radius:50%;flex-shrink:0;width:10px;height:10px}.jwt-seg-label{color:var(--text);font-size:13px;font-weight:700}.jwt-seg-desc{color:var(--text-muted);margin-left:2px;font-size:11px}.jwt-seg-body{background:var(--bg);flex-direction:column;gap:10px;padding:12px 14px;display:flex}.jwt-seg-section{flex-direction:column;gap:4px;display:flex}.jwt-seg-section-header{justify-content:space-between;align-items:center;gap:6px;min-height:18px;display:flex}.jwt-seg-section-title{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:10px;font-weight:600}.jwt-copy-btn{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:4px;flex-shrink:0;align-items:center;gap:4px;padding:2px 7px;font-size:10px;font-weight:500;line-height:1.5;transition:color .1s,border-color .1s,background .1s;display:inline-flex}.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{color:var(--seg-accent);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius,6px);word-break:break-all;white-space:pre-wrap;margin:0;padding:8px 10px;font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:11.5px;line-height:1.6}.jwt-seg-decode-placeholder{color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius,6px);align-items:center;gap:6px;padding:8px 10px;font-size:12px;font-style:italic;display:flex}.jwt-seg-empty{color:var(--text-muted);padding:2px 0;font-size:12px;font-style:italic}.jwt-seg-decoded{color:var(--text);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius,6px);word-break:break-all;white-space:pre-wrap;margin:0;padding:8px 10px;font-family:Menlo,Cascadia Code,Consolas,Monaco,monospace;font-size:12px;line-height:1.65}.jwt-seg-decode-error{background:var(--error-bg);color:var(--error);border-radius:var(--radius,6px);border:1px solid var(--error);word-break:break-word;align-items:flex-start;gap:7px;padding:8px 10px;font-size:12px;font-weight:500;display:flex}.jwt-seg-decode-error svg{flex-shrink:0;margin-top:1px}.jwt-seg-sig-note{color:var(--text-muted);padding:2px 0;font-size:12px;font-style:italic;line-height:1.55}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--radius:8px;--brand:#1a7f4b;--brand-dark:#155f38;--brand-light:#e9f7f0;--bg:#f0f2f5;--surface:#fff;--border:#d0d7de;--text:#24292f;--text-muted:#6e7781;--error:#cf222e;--error-bg:#fff0ee;--shadow:0 1px 4px #00000014;--header-bg:linear-gradient(135deg, #1a7f4b 0%, #155f38 100%);--header-border:transparent;--header-shadow:0 2px 8px #0000002e;--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;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}html[data-theme=dark]{--brand:#1db887;--brand-dark:#17976e;--brand-light:#1db88726;--bg:#13151e;--surface:#1a1e2d;--border:#252a3d;--text:#e2e8f0;--text-muted:#7f8ea3;--error:#f85149;--error-bg:#f851491f;--shadow:0 1px 6px #0006;--header-bg:#0d1017;--header-border:#252a3d;--header-shadow:0 2px 12px #00000080;--node-hover:#ffffff0d;--empty-icon:#2e3650;--collapsed-hint-bg:#ffffff0f;--json-string:#3fb950;--json-number:#58a6ff;--json-bool:#e3b341;--json-null:#c397d8;--json-key:#79c0ff;--json-index:#c397d8;--badge-valid-bg:#1db88726;--badge-valid-fg:#1db887;--badge-lenient-bg:#e3b34126;--badge-lenient-fg:#e3b341;--lenient-bar-bg:#e3b3411a;--lenient-bar-fg:#e3b341;--lenient-bar-border:#e3b34140;--type-str-bg:#3fb95026;--type-str-fg:#3fb950;--type-num-bg:#58a6ff26;--type-num-fg:#58a6ff;--type-bool-bg:#e3b34126;--type-bool-fg:#e3b341;--type-obj-bg:#ffffff14;--type-obj-fg:#7f8ea3;--type-null-bg:#c397d826;--type-null-fg:#c397d8;--flash-bg:#1db8874d;--pulse-bg:#1db88733}html,body{background:var(--bg);height:100%;color:var(--text);overflow:hidden}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.tool-region{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.tool-region--hidden{display:none}.tool-nav{background:#0000001f;border:1px solid #fff3;border-radius:8px;gap:2px;padding:2px;display:inline-flex}.tool-nav-btn{all:unset;cursor:pointer;color:#ffffffb3;white-space:nowrap;border-radius:6px;padding:5px 16px;font-size:13px;font-weight:600;transition:background .15s,color .15s}.tool-nav-btn:hover:not(.tool-nav-btn--active){color:#fffffff2;background:#ffffff1f}.tool-nav-btn--active{color:#fff;background:#ffffff38;font-weight:700}.app-header{background:var(--header-bg);color:#fff;border-bottom:1px solid var(--header-border);box-shadow:var(--header-shadow);flex-shrink:0;align-items:center;gap:20px;padding:12px 20px;display:flex}.app-header-inner{flex:1;align-items:center;gap:16px;display:flex}.app-logo{align-items:center;gap:10px;display:flex}.logo-icon{object-fit:contain;border-radius:8px;flex-shrink:0;width:36px;height:36px}.logo-text{letter-spacing:-.5px;font-size:20px;font-weight:700}.app-tagline{opacity:.8;font-size:13px}.theme-toggle{all:unset;cursor:pointer;color:#fff;background:#ffffff26;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;margin-left:auto;transition:background .2s,transform .2s;display:inline-flex}.theme-toggle:hover{background:#ffffff40;transform:rotate(15deg)}.app-main{flex-direction:column;flex:1;gap:10px;padding:12px 16px 10px;display:flex;overflow:hidden}.toolbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;padding:8px 12px;display:flex}.btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;line-height:1.4;transition:all .15s}.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{flex:1;grid-template-rows:1fr;grid-template-columns:1fr 1fr;gap:12px;min-height:0;display:grid;overflow:hidden}.editor-area.layout-side{grid-template-rows:1fr;grid-template-columns:1fr 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-rows:1fr 1fr;grid-template-columns: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-rows:1fr;grid-template-columns:1fr}.editor-area.layout-focus.has-nav{grid-template-rows:1fr;grid-template-columns:210px 1fr}.editor-area.layout-focus.has-nav-collapsed{grid-template-rows:1fr;grid-template-columns:36px 1fr}.focus-switcher{border:1px solid var(--border);background:var(--surface);border-radius:6px;align-items:center;gap:2px;padding:2px;display:inline-flex}.focus-tab{all:unset;cursor:pointer;color:var(--text-muted);white-space:nowrap;border-radius:4px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;transition:background .12s,color .12s;display:flex}.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{border:1px solid var(--border);background:var(--surface);border-radius:6px;align-items:center;gap:2px;margin-left:auto;padding:2px;display:inline-flex}.layout-btn{all:unset;cursor:pointer;width:30px;height:26px;color:var(--text-muted);border-radius:4px;justify-content:center;align-items:center;transition:background .12s,color .12s;display:flex}.layout-btn:hover{background:var(--bg);color:var(--text)}.layout-btn.active{background:var(--brand-light);color:var(--brand)}.nav-panel{flex-direction:column;min-height:0;display:flex;overflow:hidden}.pane{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;min-height:0;display:flex;overflow:hidden}.pane-header{border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.pane-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:700}.status-badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.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{color:#2675c8;background:#58a6ff26}html[data-theme=dark] .status-badge.extracted{color:#58a6ff;background:#58a6ff26}.extracted-bar{color:#2675c8;background:#58a6ff14;border-top:1px solid #58a6ff40;flex-shrink:0;padding:6px 14px;font-size:12px}html[data-theme=dark] .extracted-bar{color:#58a6ff}.json-textarea{resize:none;background:var(--surface);width:100%;color:var(--text);border:none;outline:none;flex:1;padding:12px 14px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.6;overflow:auto}.json-textarea::placeholder{color:var(--text-muted)}.lenient-bar{background:var(--lenient-bar-bg);color:var(--lenient-bar-fg);border-top:1px solid var(--lenient-bar-border);flex-shrink:0;padding:6px 14px;font-size:12px}.error-bar{background:var(--error-bg);border-top:1px solid #cf222e33;flex-shrink:0}html[data-theme=dark] .error-bar{border-top-color:#f8514940}.error-bar-header{color:var(--error);align-items:center;gap:8px;padding:8px 14px;font-size:12px;display:flex}.error-bar-icon{flex-shrink:0}.error-bar-msg{flex:1;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.error-bar-loc{white-space:nowrap;color:var(--error);background:#cf222e1a;border-radius:4px;padding:1px 6px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:11px;font-weight:700}.error-jump-btn{all:unset;cursor:pointer;color:var(--error);border:1px solid var(--error);opacity:.75;white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600;transition:opacity .15s,background .15s}.error-jump-btn:hover{opacity:1;background:var(--error-bg)}.err-code-block--bar{border-top:1px solid #cf222e26;max-height:180px;padding:6px 0 8px;overflow:auto}.tabs{gap:4px;display:flex}.tab-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:20px;padding:4px 14px;font-size:12px;font-weight:500;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;min-height:0;overflow:auto}.empty-state{height:100%;min-height:300px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.empty-icon{color:var(--empty-icon);font-family:monospace;font-size:48px;font-weight:700;line-height:1}.empty-state p{max-width:220px;font-size:14px}.output-error-panel{background:var(--error-bg);flex-direction:column;height:100%;display:flex;overflow-y:auto}.output-error-header{color:var(--error);align-items:center;gap:10px;padding:14px 16px 10px;display:flex}.output-error-title{font-size:15px;font-weight:700}.output-error-msg{color:var(--error);word-break:break-word;padding:0 16px 10px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px}.output-error-loc{align-items:center;gap:10px;padding:0 16px 12px;display:flex}.output-error-loc-badge{color:var(--error);background:#cf222e1f;border-radius:4px;padding:2px 8px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px;font-weight:700}.output-error-snippet{background:#0000000f;border-radius:6px;flex:1;min-height:0;margin:0 16px 12px;overflow:auto}html[data-theme=dark] .output-error-snippet{background:#0000004d}.output-error-snippet-label{text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);padding:6px 10px 4px;font-size:10px;font-weight:700}.output-error-snippet-code{padding:4px 10px 8px;overflow-x:auto}.err-code-block{white-space:pre;padding:6px 0 8px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12.5px;line-height:1.65;overflow-x:auto}.err-line{padding:0 14px;display:block}.err-line--active{border-left:2px solid var(--error);background:#cf222e14;padding-left:12px}html[data-theme=dark] .err-line--active{background:#f851491a}.err-line-num{color:var(--text-muted);opacity:.5;-webkit-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;user-select:none}.err-line--active .err-line-sep{color:var(--error);opacity:.4}.err-line-text{color:var(--text)}.err-line--active .err-line-text{color:var(--error)}.err-caret-row{color:var(--error);opacity:.9;padding:0 14px;font-weight:700;display:block}.output-error-hint{color:var(--text-muted);border-top:1px solid #cf222e1f;padding:10px 16px 14px;font-size:12px}.json-formatted{white-space:pre;tab-size:2;color:var(--text);padding:14px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:13px;line-height:1.6}.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{white-space:nowrap;border-radius:4px;align-items:baseline;gap:2px;padding:0 4px;display:flex}.json-node-line:hover{background:var(--node-hover)}.json-children{border-left:2px solid var(--border);margin-left:9px;padding-left:20px}.toggle-btn{all:unset;cursor:pointer;width:16px;height:16px;color:var(--text-muted);flex-shrink:0;justify-content:center;align-items:center;margin-right:2px;font-size:9px;display:inline-flex}.toggle-btn:hover{color:var(--brand)}.toggle-placeholder{flex-shrink:0;width:16px;margin-right:2px;display:inline-block}.json-key{color:var(--json-key)}.json-index{color:var(--json-index);font-style:italic}.json-colon{color:var(--text-muted)}.json-bracket{color:var(--text-muted);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);text-underline-offset:2px;text-decoration:underline;color:var(--brand)!important}@keyframes key-flash{0%{background:var(--flash-bg)}60%{background:var(--flash-bg)}to{background:0 0}}.json-node-flash{border-radius:4px;animation:1.2s forwards key-flash}@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:0 0}}.json-node-target{border-radius:4px;animation:1.6s forwards target-pulse}.key-navigator{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;min-height:0;display:flex;overflow:hidden}.nav-header{border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.nav-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:700}.nav-count{background:var(--brand-light);color:var(--brand);border-radius:10px;padding:1px 6px;font-size:10px;font-weight:700}.nav-collapse-btn{all:unset;cursor:pointer;width:20px;height:20px;color:var(--text-muted);border-radius:4px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.nav-collapse-btn:hover{background:var(--brand-light);color:var(--brand)}.key-navigator--collapsed{cursor:default;align-items:center;gap:10px;padding:10px 0}.nav-expand-btn{all:unset;cursor:pointer;width:22px;height:22px;color:var(--text-muted);border-radius:4px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.nav-expand-btn:hover{background:var(--brand-light);color:var(--brand)}.nav-title-vertical{writing-mode:vertical-rl;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:700}.nav-search-wrap{border-bottom:1px solid var(--border);flex-shrink:0;padding:6px 8px}.nav-search{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:12px}.nav-search:focus{border-color:var(--brand);background:var(--surface)}.nav-list{flex:1;padding:4px 0;overflow-y:auto}.nav-item{all:unset;cursor:pointer;width:100%;color:var(--text);white-space:nowrap;text-overflow:ellipsis;box-sizing:border-box;align-items:center;gap:6px;padding:4px 8px 4px 10px;font-size:12px;transition:background .1s;display:flex;overflow:hidden}.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{text-align:center;letter-spacing:-.3px;border-radius:3px;flex-shrink:0;min-width:26px;padding:1px 3px;font-family:monospace;font-size:9px;font-weight:700}.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-object,.type-array{background:var(--type-obj-bg);color:var(--type-obj-fg)}.type-null{background:var(--type-null-bg);color:var(--type-null-fg)}.nav-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.nav-empty{text-align:center;color:var(--text-muted);padding:20px 8px;font-size:12px}.json-collapsed-hint{color:var(--text-muted);cursor:pointer;background:var(--collapsed-hint-bg);border-radius:4px;margin:0 4px;padding:0 6px;font-size:11px;font-style:italic}.json-collapsed-hint:hover{background:var(--brand-light);color:var(--brand)}.app-footer{color:var(--text-muted);border-top:1px solid var(--border);background:var(--surface);flex-shrink:0;justify-content:center;align-items:center;gap:10px;padding:6px 16px;font-size:11px;display:flex}.app-footer-text{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;display:flex;overflow:hidden}.app-footer-version{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;border-radius:4px;flex-shrink:0;padding:1px 6px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:10px;font-weight:600}.app-footer-dismiss{all:unset;cursor:pointer;width:18px;height:18px;color:var(--text-muted);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;font-size:10px;transition:background .12s,color .12s;display:flex}.app-footer-dismiss:hover{background:var(--bg);color:var(--text)}@media (width<=768px){.editor-area,.editor-area.has-nav{grid-template-columns:1fr}.app-main{padding:8px}html,body{overflow:auto}.app{height:auto;min-height:100vh}}
