:root{--bg: #0f1419;--surface: #1a2332;--surface2: #243447;--text: #e6edf3;--muted: #8b949e;--accent: #58a6ff;--accent-dim: #388bfd66;--success: #3fb950;--error: #f85149;--radius: 8px;--font-sans: "IBM Plex Sans", "Segoe UI", system-ui, sans-serif;--font-mono: "IBM Plex Mono", "JetBrains Mono", "Fira Code", monospace}*{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;background:var(--surface2);color:var(--text);padding:.4em .75em;border-radius:var(--radius);transition:background .15s}button:hover{background:#2d3d52}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea,select{font-family:var(--font-mono);font-size:.95rem;background:var(--surface);color:var(--text);border:1px solid var(--surface2);border-radius:var(--radius);padding:.5em .65em}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim)}textarea{resize:vertical;min-height:120px}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}code,.mono{font-family:var(--font-mono);font-size:.9em;background:var(--surface2);padding:.15em .4em;border-radius:4px}.pre-wrap{white-space:pre-wrap;word-break:break-word}.error-msg{color:var(--error);font-size:.9rem}.success-msg{color:var(--success)}.symbol-bank{display:flex;flex-wrap:wrap;gap:.75rem 1rem;align-items:flex-start}.sb-section{display:flex;flex-direction:column;gap:.35rem}.sb-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:.35rem}.sb-toggle{padding:0 .25em;font-size:.9em;opacity:.7}.sb-tokens{display:flex;flex-wrap:wrap;gap:.35rem}.sb-btn{font-family:var(--font-mono);font-size:1rem;padding:.35em .5em;min-width:2em}.sb-btn.sb-var{background:var(--surface);color:var(--accent)}.sb-btn.sb-pred{font-size:.9rem}.sb-templates .sb-token-list{display:flex;flex-wrap:wrap;gap:.4rem}.sb-tpl{font-size:.85rem;padding:.3em .5em;white-space:nowrap}.sb-tpl code{font-size:inherit;padding:0;background:transparent}.logic-editor{display:flex;flex-direction:column;gap:.5rem}.le-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.le-presets{min-width:180px}.le-actions{display:flex;gap:.35rem}.le-input{width:100%;font-size:.95rem;line-height:1.5;font-family:var(--font-mono)}.le-input-error{border-color:#f8514980}.le-error{padding:.75rem;background:#f851491a;border:1px solid rgba(248,81,73,.3);border-radius:var(--radius);font-size:.85rem;margin-top:.5rem}.le-error-snippet{margin:.5rem 0;padding:.5rem;background:var(--surface1);border-radius:var(--radius);border:1px solid var(--surface2)}.le-error-code{font-family:var(--font-mono);font-size:.9rem;white-space:pre-wrap;word-break:break-all;display:block;line-height:1.6}.le-error-highlight{background:#f851494d;border-bottom:2px solid #f85149;padding:0 2px;font-weight:600}.le-error-location{margin-bottom:.5rem;color:var(--text)}.le-error-char{color:var(--muted);font-size:.9em}.le-error-message,.le-error-expected{margin-bottom:.5rem;color:var(--text)}.le-error-expected code{background:var(--surface2);padding:.2rem .4rem;border-radius:3px;font-family:var(--font-mono);font-size:.9em}.le-error-got{color:var(--text)}.le-error-got code{background:#f8514933;padding:.2rem .4rem;border-radius:3px;font-family:var(--font-mono);font-size:.9em;color:#f85149}.step-explanation{margin-bottom:1.5rem;border:1px solid var(--surface2);border-radius:var(--radius);background:var(--bg)}.step-explanation-header{padding:.75rem 1rem;border-bottom:1px solid var(--surface2);background:var(--surface1)}.step-explanation-title{font-size:.9rem;font-weight:600;color:var(--text)}.step-explanation-content{padding:1rem}.step-item{display:flex;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--surface2)}.step-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.step-number{flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;background:var(--surface2);border-radius:50%;font-weight:600;font-size:.85rem;color:var(--text)}.step-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.step-formula{font-family:var(--font-mono);font-size:.9rem;background:var(--surface1);padding:.5rem .75rem;border-radius:var(--radius);border:1px solid var(--surface2);color:var(--text);display:block;overflow-x:auto}.step-text{margin:0;font-size:.9rem;line-height:1.6;color:var(--text)}.english-renderer{display:flex;flex-direction:column;gap:1rem}.er-section{flex:1;display:flex;flex-direction:column;min-height:0;background:var(--surface);border-radius:var(--radius);border:1px solid var(--surface2);overflow:hidden}.er-section .panel-header{padding:.5rem .75rem;font-size:.85rem;font-weight:600;color:var(--muted);background:var(--surface2);border-bottom:1px solid var(--surface2)}.er-section .panel-body{padding:.75rem;overflow:auto}.er-output{margin:0;font-size:1rem;line-height:1.6}.er-tree{margin:0;font-size:.85rem;line-height:1.5;color:var(--muted)}.muted{color:var(--muted);margin:0;font-style:italic}.logic-traps{margin-bottom:1.5rem;border:1px solid var(--surface2);border-radius:var(--radius);background:var(--bg)}.logic-traps-header{padding:.75rem 1rem;border-bottom:1px solid var(--surface2);background:var(--surface1)}.logic-traps-title{font-size:.9rem;font-weight:600;color:var(--text)}.logic-traps-content{padding:.75rem 1rem}.logic-trap-item{margin-bottom:1rem;padding:.75rem;border-radius:var(--radius);border-left:3px solid}.logic-trap-item:last-child{margin-bottom:0}.logic-trap-info{background:#2196f31a;border-left-color:#2196f3}.logic-trap-warning{background:#ff98001a;border-left-color:#ff9800}.logic-trap-title{font-size:.85rem;font-weight:600;color:var(--text);margin-bottom:.4rem}.logic-trap-message{font-size:.8rem;color:var(--muted);line-height:1.5}.composer{display:flex;flex-direction:column;gap:.75rem}.composer-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.composer-title{font-weight:600;font-size:.95rem}.composer-header-actions{display:flex;gap:.4rem;flex-wrap:wrap}.composer-scope-summary{border-radius:var(--radius);border:1px dashed var(--surface2);padding:.4rem .75rem;font-size:.8rem;background:var(--surface)}.composer-scope-row{display:flex;gap:.5rem;align-items:baseline}.composer-scope-vars{font-family:var(--font-mono)}.composer-errors{margin:.35rem 0 0;padding-left:1.2rem;color:var(--danger)}.composer-builder{display:flex;flex-direction:column;gap:.5rem}.composer-output{background:var(--surface);border:1px solid var(--surface2);border-radius:var(--radius);overflow:hidden}.composer-output-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1.2fr);gap:.75rem;margin-top:.5rem}@media(max-width:900px){.composer-output-grid{grid-template-columns:1fr}}.composer-output .panel-header{padding:.5rem .75rem;font-size:.85rem;color:var(--muted);background:var(--surface2)}.composer-logic{margin:0;padding:.75rem;font-family:var(--font-mono);font-size:.9rem;overflow-x:auto}.composer-english{margin:0;padding:.75rem;font-size:.9rem}.composer-tree{margin:0;padding:.75rem;font-family:var(--font-mono);font-size:.85rem}.composer-copy-btn{margin-left:auto;font-size:.8rem}.builder-form{border:1px solid var(--surface2);border-radius:var(--radius);padding:.5rem .75rem;background:var(--surface)}.builder-form.empty{padding:.75rem}.bf-label,.bf-sublabel{font-size:.8rem;color:var(--muted);margin-right:.5rem}.bf-sublabel{display:block;margin-bottom:.25rem}.bf-actions{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.35rem}.bf-actions button{font-size:.85rem}.bf-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.5rem}.bf-row:last-child{margin-bottom:0}.bf-remove{margin-left:auto;padding:.2em .4em;font-size:.9rem;opacity:.7}.bf-nested{margin-top:.5rem;padding-left:.5rem;border-left:2px solid var(--surface2)}.bf-sides{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.5rem}.bf-side{padding:.5rem;background:var(--bg);border-radius:var(--radius);border:1px solid var(--surface2)}.bf-arg{display:inline-flex;align-items:center;gap:.25rem}.bf-arg .bf-sublabel{display:inline;margin:0}.bf-inline{display:inline-flex;flex-direction:column;gap:.1rem}.bf-error{margin-top:.25rem;font-size:.8rem;color:var(--danger)}.bf-hint{margin-top:.25rem;font-size:.8rem;color:var(--muted)}.bf-body-chooser{margin-top:.25rem}.term-editor{display:flex;flex-direction:column;gap:.2rem}.term-row{display:flex;align-items:center;gap:.3rem}.supported-structures{margin-top:1rem;border:1px solid var(--surface2);border-radius:var(--radius);background:var(--bg)}.supported-structures-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:transparent;border:none;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text);transition:background-color .2s}.supported-structures-header:hover{background:var(--surface1)}.supported-structures-title{flex:1;text-align:left}.supported-structures-toggle{font-size:.8rem;color:var(--muted);margin-left:.5rem}.supported-structures-content{padding:1rem;border-top:1px solid var(--surface2)}.supported-structures-section{margin-bottom:1.5rem}.supported-structures-section:last-child{margin-bottom:0}.supported-structures-category{font-size:.85rem;font-weight:600;color:var(--muted);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.5px}.supported-structures-list{list-style:none;padding:0;margin:0}.supported-structures-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--surface2)}.supported-structures-item:last-child{border-bottom:none}.supported-structures-example{flex:1;font-family:var(--font-mono);font-size:.85rem;color:var(--text);background:var(--surface1);padding:.4rem .6rem;border-radius:var(--radius);word-break:break-word}.supported-structures-copy{flex-shrink:0;padding:.35rem .75rem;font-size:.8rem;background:var(--surface2);border:1px solid var(--surface3);border-radius:var(--radius);color:var(--text);cursor:pointer;transition:background-color .2s,border-color .2s}.supported-structures-copy:hover{background:var(--surface3);border-color:var(--surface4)}.supported-structures-copy:active{background:var(--surface4)}.etl-section{margin-bottom:1.5rem}.etl-divider{padding-top:1.5rem;border-top:1px solid var(--surface2)}.etl-subheader{font-size:.85rem;font-weight:600;color:var(--muted);margin-bottom:.5rem}.etl-phrase-note{font-size:.8rem;color:var(--muted);margin-bottom:.5rem}.etl-phrase-note code{font-family:var(--font-mono);font-size:.85em}.etl-phrase-input{display:flex;flex-direction:column;gap:.5rem}.etl-textarea{min-height:80px;font-family:var(--font-sans)}.etl-phrase-actions{display:flex;align-items:center;gap:.5rem}.etl-hint{font-size:.8rem;color:var(--muted)}.etl-error{padding:.4rem .5rem;background:#f851491a;border-radius:var(--radius)}.etl-output{display:flex;flex-direction:column;gap:.5rem}.etl-logic{margin:0;padding:.75rem;background:var(--bg);border:1px solid var(--surface2);border-radius:var(--radius);font-family:var(--font-mono);font-size:.95rem;line-height:1.5;overflow-x:auto}.etl-copy{align-self:flex-start}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{padding:.75rem 1.25rem;background:var(--surface);border-bottom:1px solid var(--surface2);display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.app-header h1{margin:0;font-size:1.25rem;font-weight:600}.tabs{display:flex;gap:.25rem}.tabs button{padding:.5rem 1rem;background:transparent;color:var(--muted)}.tabs button:hover{color:var(--text);background:var(--surface2)}.tabs button.active{background:var(--surface2);color:var(--accent);font-weight:500}.app-main{flex:1;display:flex;flex-direction:column;min-height:0;padding:1rem}.panels{display:grid;grid-template-columns:1fr 1fr;gap:1rem;flex:1;min-height:0}@media(max-width:900px){.panels{grid-template-columns:1fr}}.panel{display:flex;flex-direction:column;background:var(--surface);border-radius:var(--radius);border:1px solid var(--surface2);overflow:hidden}.panel-header{padding:.5rem .75rem;font-size:.85rem;font-weight:600;color:var(--muted);background:var(--surface2);border-bottom:1px solid var(--surface2)}.panel-body{flex:1;padding:.75rem;overflow:auto;min-height:0}.output-split{display:flex;gap:1rem;min-height:0}.output-left{flex:0 1 50%;min-width:0;display:flex;flex-direction:column;gap:1rem;overflow:auto}.output-right{flex:1 1 50%;min-width:0;display:flex;flex-direction:column;overflow:auto}.output-right .english-renderer--only{flex:1;display:flex;flex-direction:column;min-height:0}.output-right .english-renderer--only .er-section{flex:1;min-height:0;display:flex;flex-direction:column}.output-right .english-renderer--only .er-section .panel-body{flex:1;overflow:auto}.symbol-bank-wrap{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--surface2)}.symbol-bank-wrap .panel-header{margin:-.75rem -.75rem .75rem;padding:.5rem .75rem}
