*,*:before,*:after{box-sizing:border-box}:root{--color-bg: #f8f9fa;--color-surface: #ffffff;--color-border: #dee2e6;--color-text: #212529;--color-text-muted: #6c757d;--color-primary: #0d6efd;--color-primary-hover: #0b5ed7;--color-secondary: #6c757d;--color-secondary-hover: #565e64;--color-success-bg: #d1e7dd;--color-success-text: #0f5132;--color-warning-bg: #fff3cd;--color-warning-text: #664d03;--color-error-bg: #f8d7da;--color-error-text: #842029;--font-sans: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "Cascadia Code", "Fira Code", "Consolas", "Menlo", monospace;--radius: 6px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--gap: 1rem;--header-height: 72px}html,body{margin:0;padding:0;height:100%;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);font-size:14px;line-height:1.5}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{padding:.75rem 1.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;display:flex;align-items:baseline;gap:1rem}.app-title{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.02em;color:var(--color-primary)}.app-subtitle{margin:0;font-size:.875rem;color:var(--color-text-muted)}.app-disclaimer{margin:0 0 0 auto;font-size:.8125rem;color:var(--color-warning-text);background:var(--color-warning-bg);padding:.25rem .625rem;border-radius:var(--radius);white-space:nowrap}.app-main{display:grid;grid-template-columns:1fr 1fr;gap:0;flex:1;overflow:hidden;min-height:0}.panel{display:flex;flex-direction:column;overflow:hidden;background:var(--color-surface);min-height:0}.panel-editor{border-right:1px solid var(--color-border)}.panel-results{display:flex;flex-direction:column;overflow:hidden}.panel-heading{display:flex;align-items:flex-end;gap:1rem;padding:.5rem 1rem 0;min-height:2.5rem;border-bottom:1px solid var(--color-border);flex-shrink:0;background:var(--color-bg)}.panel-editor .panel-heading{align-items:center;padding-bottom:.5rem}.panel-title{margin:0;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);flex:1}.editor-hint{margin:0;padding:.5rem 1rem;font-size:.8125rem;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);flex-shrink:0}.editor-container{flex:1;overflow:hidden;min-height:0;font-family:var(--font-mono);font-size:13px}.editor-container .cm-editor{height:100%}.editor-container .cm-scroller{overflow:auto;height:100%}.editor-actions{padding:.75rem 1rem;border-top:1px solid var(--color-border);flex-shrink:0;display:flex;justify-content:center;gap:.5rem}.editor-actions .btn-primary{width:40%;justify-content:center}.btn{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .875rem;font-size:.875rem;font-weight:500;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:background-color .15s ease,border-color .15s ease;line-height:1.5;white-space:nowrap}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary);padding:.5rem 1.5rem;font-size:1rem}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-secondary);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-bg);color:var(--color-secondary-hover)}.results-tabs{display:flex;gap:0}.results-tab{padding:.375rem .875rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);background:none;border:1px solid color-mix(in srgb,var(--color-border) 50%,transparent);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0;cursor:pointer;transition:color .15s,background-color .15s,border-color .15s}.results-tab:hover{color:var(--color-text)}.results-tab.active{color:var(--color-primary);background:var(--color-surface);border-color:var(--color-border)}.results-pane{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.results-pane[hidden]{display:none}.findings-container{padding:.75rem 1rem;font-size:.875rem;flex:1;overflow:auto;min-height:0}.placeholder-text{margin:0;color:var(--color-text-muted);font-style:italic}.findings-clean{display:flex;align-items:center;gap:.5rem;color:var(--color-success-text);background:var(--color-success-bg);border-radius:var(--radius);padding:.5rem .75rem}.findings-error{color:var(--color-error-text);background:var(--color-error-bg);border-radius:var(--radius);padding:.5rem .75rem;font-family:var(--font-mono);font-size:.8125rem;white-space:pre-wrap;word-break:break-word}.finding-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.finding-item{border-radius:var(--radius);padding:.5rem .75rem;background:var(--color-warning-bg);border-left:3px solid #ffc107}.finding-type{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-warning-text);margin-bottom:.2rem}.finding-message{color:var(--color-warning-text);margin:0}.finding-states{font-family:var(--font-mono);font-size:.75rem;margin-top:.25rem;color:var(--color-warning-text);opacity:.8}.toggle-label{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;margin-left:auto;padding-bottom:.375rem}.toggle-label[hidden]{display:none}.toggle-input{cursor:pointer}.diagram-container{padding:.75rem 1rem;flex:1;overflow:auto;min-height:0}.diagram-container svg{max-width:100%;max-height:100%}.diagram-error{color:var(--color-error-text);background:var(--color-error-bg);border-radius:var(--radius);padding:.5rem .75rem;font-size:.8125rem}.diagram-actions{padding:.5rem 1rem .75rem;display:flex;gap:.5rem;flex-shrink:0}@media(max-width:900px){.app{height:auto;min-height:100vh;overflow:auto}.app-main{grid-template-columns:1fr;overflow:visible}.panel{height:auto;overflow:visible}.panel-editor{border-right:none;border-bottom:1px solid var(--color-border)}.editor-container{height:300px;flex:none}.editor-container .cm-editor,.editor-container .cm-scroller{height:300px}}
