*,*:before,*:after{box-sizing:border-box}:root{color-scheme:light dark;--bg: #0d1117;--surface: #161b22;--surface-elevated: #1e2733;--border: #2d3748;--text: #e2e8f0;--text-muted: #7a8799;--accent: #38bdf8;--accent-hover: #7dd3fc;--error: #f87171;--success: #4ade80;--font-sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "Cascadia Code", "SF Mono", Menlo, monospace}@media(prefers-color-scheme:light){:root{--bg: #f1f5f9;--surface: #ffffff;--surface-elevated: #f8fafc;--border: #cbd5e1;--text: #0f172a;--text-muted: #64748b;--accent: #0284c7;--accent-hover: #0369a1}}html,body{margin:0;height:100%;font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;overflow:hidden}#root{height:100%;overflow:hidden}button,select{font-family:inherit}.app{max-width:none;width:100%;margin:0 auto;height:100vh;overflow:hidden;padding:1.25rem;display:flex;flex-direction:column}.app-header{margin-bottom:1rem;flex-shrink:0}.app-header h1{margin:0 0 .3rem;font-size:1.55rem;font-weight:700;letter-spacing:-.02em}.subtitle{margin:0;color:var(--text-muted);font-size:.875rem}.app-body{display:flex;flex:1;min-height:0;overflow:hidden;gap:1.25rem;align-items:stretch}@media(max-width:800px){.app-body{display:grid;grid-template-columns:1fr;overflow:auto}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;min-height:16rem}.panel-input{flex:1 1 50%;min-width:18rem;resize:both;overflow:auto}.panel-output{flex:1 1 50%;min-width:22rem;max-width:100%;resize:both;overflow:auto}@media(max-width:800px){.panel-input,.panel-output{flex:1 1 auto;min-width:0;resize:none}}.panel-label{padding:.55rem 1rem;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-elevated);border-bottom:1px solid var(--border);flex-shrink:0}.panel-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--surface-elevated);flex-shrink:0}.panel-header .panel-label{border-bottom:none}.panel-fullscreen-btn{margin-right:.6rem}.panel-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;width:auto!important;max-width:none!important;min-width:0!important;min-height:0!important;border-radius:0;resize:none!important;overflow:hidden}.panel-hidden{display:none!important}.input-footer{display:flex;align-items:center;gap:.45rem;padding:.45rem .75rem;border-top:1px solid var(--border);background:var(--surface-elevated);flex-shrink:0}.controls{display:flex;flex-wrap:wrap;align-items:center;gap:1.25rem;padding:.6rem 1rem;border-top:1px solid var(--border);flex-shrink:0}.control-row{display:flex;align-items:center;gap:.5rem}.control-label{font-size:.8125rem;color:var(--text-muted);white-space:nowrap}.control-select{padding:.3rem .55rem;border-radius:5px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-size:.8125rem;cursor:pointer}.control-select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.control-check{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.8125rem;gap:.45rem}.control-check input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.action-row{display:flex;align-items:center;gap:.5rem;padding:.65rem .9rem;border-top:1px solid var(--border);background:var(--surface-elevated);flex-shrink:0}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.42rem .85rem;border-radius:6px;border:1px solid var(--border);background:var(--surface-elevated);color:var(--text);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap;line-height:1}.btn:hover:not(:disabled){background:color-mix(in srgb,var(--text) 8%,var(--surface-elevated));border-color:var(--text-muted)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:disabled{opacity:.38;cursor:not-allowed}.btn-sm{padding:.28rem .6rem;font-size:.775rem}.btn-xs{padding:.2rem .5rem;font-size:.74rem}.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){color:var(--text);background:var(--surface-elevated);border-color:var(--border)}.btn-process{background:var(--accent);border-color:transparent;color:#0d1117;font-weight:700;padding:.5rem 1.5rem;font-size:.875rem;letter-spacing:.01em}.btn-process:hover:not(:disabled){filter:brightness(1.08);background:var(--accent);border-color:transparent}.btn-group{display:flex;gap:.35rem}.output-resizable{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}@media(max-width:800px){.output-resizable{min-height:16rem}}.output-placeholder{flex:1;display:flex;align-items:center;justify-content:center;min-height:280px;padding:2rem 1.5rem;color:var(--text-muted);font-size:.875rem;text-align:center}.status-banner{display:flex;align-items:center;gap:.45rem;padding:.6rem 1rem;font-size:.875rem;font-weight:600;border-bottom:1px solid var(--border);flex-shrink:0}.status-valid{background:color-mix(in srgb,var(--success) 13%,var(--surface));color:var(--success)}.status-invalid{background:color-mix(in srgb,var(--error) 13%,var(--surface));color:var(--error)}.status-icon{font-size:1.05rem}.status-note{font-weight:400;opacity:.8}.validator-output{border-bottom:1px solid var(--border);flex-shrink:0}.validator-output-label{padding:.45rem 1rem;font-size:.7rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);background:var(--surface-elevated);border-bottom:1px solid var(--border)}.error-list{max-height:18rem;overflow-y:auto;overflow-x:hidden}.error-card{display:flex;flex-direction:column;gap:.35rem;width:100%;padding:.7rem 1rem;border:none;border-bottom:1px solid var(--border);border-left:3px solid transparent;background:none;cursor:pointer;text-align:left;transition:background .1s,border-left-color .1s;font-family:inherit}.error-card:last-child{border-bottom:none}.error-card:hover{background:color-mix(in srgb,var(--error) 6%,var(--surface));border-left-color:color-mix(in srgb,var(--error) 45%,transparent)}.error-card-active{background:color-mix(in srgb,var(--error) 11%,var(--surface))!important;border-left-color:var(--error)!important}.error-card-header{display:flex;align-items:center;gap:.55rem}.error-card-badge{font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#fff;background:var(--error);padding:.1rem .4rem;border-radius:3px;flex-shrink:0}.error-card-pos{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);font-weight:500}.error-card-msg{font-size:.82rem;color:var(--text);line-height:1.45}.error-card-source{position:relative;display:flex;align-items:flex-start;gap:0;margin-top:.15rem;font-family:var(--font-mono);font-size:.73rem;background:color-mix(in srgb,var(--error) 8%,var(--surface-elevated));border:1px solid color-mix(in srgb,var(--error) 20%,var(--border));border-radius:4px;overflow:hidden}.error-card-source-lnum{flex-shrink:0;padding:.22rem .5rem;background:color-mix(in srgb,var(--error) 16%,var(--surface-elevated));color:var(--error);font-weight:700;border-right:1px solid color-mix(in srgb,var(--error) 20%,var(--border));-webkit-user-select:none;user-select:none}.error-card-source-code{padding:.22rem .6rem;color:var(--text);white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word;flex:1}.error-card-caret{position:absolute;left:calc(2.5rem + calc(var(--col, 0) * 1ch));bottom:0;pointer-events:none}.error-card-caret:before{content:"▲";font-size:.45rem;color:var(--error);line-height:1}.output-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.45rem .75rem;border-bottom:1px solid var(--border);background:var(--surface-elevated);flex-shrink:0;gap:.5rem}.tree-wrap{flex:1;min-height:0;padding:.75rem 1rem 1rem;overflow:auto;max-height:none}@keyframes btn-spin{to{transform:rotate(360deg)}}.btn-spinner{display:inline-block;width:.9rem;height:.9rem;border-radius:50%;border:2px solid rgba(13,17,26,.25);border-top-color:#0d1117;animation:btn-spin .55s linear infinite;vertical-align:middle}.ev-root{--ev-gutter-width: 2.75rem;font-family:var(--font-mono);font-size:.78rem;line-height:1.65;flex:1;overflow-y:auto;overflow-x:hidden;max-height:none;min-height:80px;padding:.35rem 0}.ev-row{display:grid;grid-template-columns:var(--ev-gutter-width) 1fr;position:relative;align-items:flex-start}.ev-row:hover{background:color-mix(in srgb,var(--text) 3%,transparent)}.ev-row-error{background:color-mix(in srgb,var(--error) 8%,var(--surface));border-left:2px solid color-mix(in srgb,var(--error) 50%,transparent)}.ev-row-active{background:color-mix(in srgb,var(--error) 16%,var(--surface))!important;border-left:3px solid var(--error)!important}.ev-row-active .ev-gutter{color:var(--error);font-weight:700;opacity:1}.ev-gutter{display:flex;align-items:center;justify-content:flex-end;padding:0 .55rem 0 .4rem;color:var(--text-muted);font-size:.72rem;-webkit-user-select:none;user-select:none;opacity:.45;flex-shrink:0}.ev-row-error .ev-gutter{opacity:.8}.ev-code{display:block;padding-right:1rem;color:var(--text);white-space:pre-wrap;overflow-wrap:anywhere;word-break:break-word}.ev-col-pointer{position:absolute;left:calc(var(--ev-gutter-width) + calc(var(--col, 0) * 1ch));bottom:0;width:1ch;display:flex;justify-content:center;pointer-events:none}.ev-col-pointer:before{content:"▲";font-size:.5rem;color:var(--error);line-height:1}.jt-root{font-family:var(--font-mono);font-size:.8rem;line-height:1.75;color:var(--text)}.jt-line{display:flex;align-items:baseline;white-space:nowrap;min-height:1.4em}.jt-children{padding-left:1.4rem;border-left:1px solid var(--border);margin-left:.5rem}.jt-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:3px;padding-left:0;outline:none}.jt-toggle:hover{background:color-mix(in srgb,var(--text) 5%,transparent)}.jt-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.jt-caret{display:inline-flex;align-items:center;justify-content:center;width:1.1rem;flex-shrink:0;font-size:.5rem;color:var(--text-muted);transform:rotate(0);transition:transform .13s ease}.jt-caret-open{transform:rotate(90deg)}.jt-caret-placeholder{opacity:0}.jt-key{color:#7dd3fc}.jt-punct{color:#475569;margin:0 .05rem}.jt-bracket{color:#94a3b8;font-weight:500}.jt-string{color:#86efac;word-break:break-all;white-space:normal}.jt-number{color:#fdba74}.jt-boolean{color:#c084fc}.jt-null{color:#f87171}.jt-summary{color:#475569;font-size:.72rem;font-style:italic;padding:0 .35rem}@media(prefers-color-scheme:light){.jt-key{color:#0369a1}.jt-string{color:#15803d}.jt-number{color:#c2410c}.jt-boolean{color:#7c3aed}.jt-null{color:#dc2626}.jt-bracket{color:#64748b}.jt-punct{color:#94a3b8}.jt-children{border-left-color:#cbd5e1}}.le-root{--le-pad-top: .875rem;--le-font-size: .8125rem;--le-line-height: 1.65;--le-gutter-width: 2.75rem;position:relative;flex:1;min-height:8rem;background:var(--surface)}.le-gutter{position:absolute;top:0;left:0;bottom:0;width:var(--le-gutter-width);overflow-y:scroll;scrollbar-width:none;padding-top:var(--le-pad-top);background:var(--surface-elevated);border-right:1px solid var(--border);z-index:1}.le-gutter::-webkit-scrollbar{display:none}.le-num{display:block;padding-right:.45rem;font-family:var(--font-mono);font-size:var(--le-font-size);line-height:var(--le-line-height);text-align:right;color:var(--text-muted);opacity:.45;-webkit-user-select:none;user-select:none;white-space:nowrap}.le-editor{display:block;width:100%;height:100%;min-height:8rem;padding:var(--le-pad-top) 1rem var(--le-pad-top) calc(var(--le-gutter-width) + .5rem);border:none;background:transparent;color:var(--text);font-family:var(--font-mono);font-size:var(--le-font-size);line-height:var(--le-line-height);resize:none;outline:none;-moz-tab-size:2;tab-size:2;overflow-y:auto}.le-editor::placeholder{color:var(--text-muted);opacity:.5}.le-drag-over .le-editor{opacity:.25;pointer-events:none}.le-drag-over:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border:2px dashed var(--accent);border-radius:6px;pointer-events:none;z-index:3}.le-drop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:1.05rem;font-weight:600;pointer-events:none;z-index:4}
