:root{--bg: #0d1117;--card: #161b22;--card-border: rgba(255, 255, 255, .06);--text: #e6edf3;--muted: #8b949e;--accent: #58a6ff;--green: #3fb950;--red: #f85149;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .25)}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.55;font-size:15px}.app{max-width:1280px;margin:0 auto;padding:1.5rem 1.75rem;min-height:100vh}.app-header,header{margin-bottom:1.75rem;padding-bottom:1.25rem;border-bottom:1px solid var(--card-border)}.app-header-top{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.app-header h1,header h1{margin:0;font-size:1.6rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.header-badges{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.status-pill{font-size:.75rem;font-weight:600;padding:.25rem .6rem;border-radius:999px;text-transform:capitalize}.status-pill.status-running{background:#3fb95033;color:var(--green);animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{50%{opacity:.85}}.status-pill.status-mode{background:#ffffff14;color:var(--muted)}.status-pill.status-mode[data-mode=following]{background:#3fb95026;color:var(--green)}.status-pill.status-mode[data-mode=no_lead]{background:#58a6ff26;color:var(--accent)}.status-pill.status-mode[data-mode=standby]{background:#d2992226;color:#d29922}.status-pill.status-mode[data-mode=off]{background:#8b949e26;color:var(--muted)}.subtitle{margin:.5rem 0 0;color:var(--muted);font-size:.9rem;max-width:56rem}.subtitle-link{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;text-align:left}.subtitle-link:hover{color:var(--accent);text-decoration:underline}.control-diagram-card{margin-bottom:1rem}.control-diagram-card h2{margin-bottom:.25rem}.control-diagram-card>.muted.small{margin-bottom:.75rem}.inputs-card{grid-column:span 1}.outputs-card{display:flex;flex-direction:column;gap:.75rem}.outputs-card .mode-badge-btn{align-self:flex-start}.control-diagram-wrap{overflow:auto;padding:.75rem 0}.control-diagram-svg{width:100%;min-width:320px;max-width:900px;height:auto;display:block;margin:0 auto}.diagram-section-bg{fill:#ffffff08;stroke:none}.diagram-section-label{font-size:10px;font-weight:600;fill:var(--muted);letter-spacing:.05em}.diagram-feedback-label{font-size:10px;fill:var(--accent)}.control-diagram-hint{margin:.5rem 0 0;text-align:center}.control-diagram-wrap .block-group{outline:none}.control-diagram-wrap .block-group .block{fill:var(--card);stroke:var(--muted);stroke-width:1.5;transition:fill .15s ease,stroke .15s ease,filter .15s ease}.control-diagram-wrap .block-group:hover .block,.control-diagram-wrap .block-group:focus .block{filter:brightness(1.15)}.control-diagram-wrap .block-group.ref .block{fill:#1a2d3d;stroke:var(--accent)}.control-diagram-wrap .block-group.measurement .block{fill:#2a2235;stroke:#9b59b6}.control-diagram-wrap .block-group.fusion .block{fill:#1e2a35;stroke:#3498db}.control-diagram-wrap .block-group.controller .block{fill:#1a2e22;stroke:var(--green)}.control-diagram-wrap .block-group.actuating .block{fill:#2d2a1a;stroke:#f39c12}.control-diagram-wrap .block-group.plant .block{fill:#2d201a;stroke:#e74c3c}.control-diagram-wrap .block-title{font-size:12px;font-weight:600;fill:var(--text);pointer-events:none}.control-diagram-wrap .block-sub{font-size:10px;fill:var(--muted);pointer-events:none}.control-diagram-wrap .block-caption{font-size:11px;fill:var(--muted);font-weight:500}.control-diagram-wrap .arrow-label{font-size:10px;fill:var(--muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card);border-radius:12px;max-width:440px;width:100%;max-height:85vh;overflow:auto;box-shadow:0 8px 32px #0006;border:1px solid var(--muted);animation:modalSlideIn .25s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .5rem;border-bottom:1px solid #2d3748}.modal-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--accent)}.modal-close{background:none;border:none;color:var(--muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:0 .25rem;border-radius:4px}.modal-close:hover{color:var(--text);background:#2d3748}.modal-description{margin:0;padding:1.25rem 1.25rem 1.5rem;font-size:.95rem;line-height:1.6;color:var(--text)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.25rem}.card{background:var(--card);border-radius:var(--radius);padding:1.25rem 1.5rem;border:1px solid var(--card-border);box-shadow:var(--shadow)}.card:focus-within{border-color:#58a6ff40}.card h2{margin:0 0 .5rem;font-size:1.05rem;font-weight:600;color:var(--accent);letter-spacing:.01em}.card h3{margin:.75rem 0 .5rem;font-size:.85rem;color:var(--muted)}.card h3[title]{cursor:help}.slider-row{margin-bottom:.75rem}.slider-row label{display:flex;justify-content:space-between;font-size:.85rem}.slider-label{color:var(--muted)}.slider-label[title]{cursor:help}.slider-label-btn{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;text-align:left}.slider-label-btn:hover .slider-label.clickable{color:var(--accent);text-decoration:underline}.slider-label.clickable{cursor:pointer}.input-output-hint{margin-top:-.25rem;margin-bottom:.5rem}.slider-value{color:var(--text)}.slider-row input[type=range]{width:100%;margin-top:.25rem;accent-color:var(--accent)}.toggle-row{margin-bottom:.75rem}.toggle-row label{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer}.controller-type-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;flex-wrap:wrap}.controller-type-label{font-size:.9rem;font-weight:600;color:var(--text)}.controller-type-toggle{display:flex;border:1px solid var(--card-border);border-radius:var(--radius);overflow:hidden;background:#ffffff08}.controller-option{display:flex;align-items:center;padding:.4rem .9rem;font-size:.9rem;cursor:pointer;margin:0;border:none;background:transparent;color:var(--muted)}.controller-option input{position:absolute;opacity:0;pointer-events:none}.controller-option.selected{background:var(--accent);color:var(--bg);font-weight:600}.controller-option:not(.selected):hover{background:#ffffff0f;color:var(--text)}.pid-card .pid-internals{margin-top:.5rem}.pid-card .pid-row{display:flex;justify-content:space-between;font-size:.9rem;margin-bottom:.35rem}.pid-card .pid-row span:first-child{color:var(--muted)}.pid-chart-title{font-size:1rem;font-weight:600;margin:1.25rem 0 .35rem;color:var(--text)}.pid-chart-wrap{margin-top:.5rem;max-width:100%}.pid-chart-svg{display:block;width:100%;max-width:420px;height:auto}.pid-chart-tick,.pid-chart-label{font-size:.75rem;fill:var(--muted)}.acc-toggle{margin-bottom:.5rem}.acc-switch-label{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;cursor:help}.acc-switch{width:1.1rem;height:1.1rem;accent-color:var(--accent);cursor:pointer}.acc-switch-text{font-weight:600;color:var(--text)}.acc-switch-hint{font-size:.8rem;color:var(--muted);width:100%;margin-left:1.6rem}.acc-switch-text-btn{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;text-align:left;display:inline-flex;flex-wrap:wrap;align-items:center;gap:.35rem}.acc-switch-text-btn:hover .acc-switch-text{color:var(--accent);text-decoration:underline}.card h2 .heading-link,.card h3 .heading-link,.card h3 .heading-btn{background:none;border:none;padding:0;margin:0;font:inherit;cursor:pointer;text-decoration:none}.card h2 .heading-link{color:var(--accent)}.card h3 .heading-link,.card h3 .heading-btn{color:var(--muted)}.card h2 .heading-link:hover,.card h3 .heading-link:hover,.card h3 .heading-btn:hover{color:var(--accent);text-decoration:underline}.app-header h1 .heading-link{background:none;border:none;padding:0;margin:0;font:inherit;color:inherit;cursor:pointer;text-decoration:none}.app-header h1 .heading-link:hover{text-decoration:underline;opacity:.9}.sim-controls{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.sim-btn{padding:.4rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:6px;cursor:pointer}.sim-play{background:var(--green);color:#0d1f0d}.sim-play:hover{filter:brightness(1.1)}.sim-pause{background:#e67e22;color:#1a0f00}.sim-pause:hover{filter:brightness(1.1)}.reset-btn{margin-bottom:0;padding:.4rem .75rem;font-size:.85rem;color:var(--accent);background:transparent;border:1px solid var(--accent);border-radius:6px;cursor:pointer}.reset-btn:hover{background:#58a6ff26}.inputs-subsection{font-size:.9rem;font-weight:600;margin:1.25rem 0 .5rem;padding-top:1rem;color:var(--muted);border-top:1px solid var(--card-border)}.inputs-subsection:first-of-type{margin-top:.5rem;padding-top:0;border-top:none}.dynamic-value-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem;font-size:.85rem}.dynamic-value-label{color:var(--muted);min-width:8rem}.dynamic-value-label-btn{background:none;border:none;padding:0;font:inherit;color:inherit;cursor:pointer;text-align:left;min-width:8rem}.dynamic-value-label-btn:hover .dynamic-value-label{color:var(--accent);text-decoration:underline}.dynamic-value-value{color:var(--text);font-weight:500;font-variant-numeric:tabular-nums}.dynamic-value-badge{font-size:.7rem;padding:.15rem .4rem;background:#58a6ff33;color:var(--accent);border-radius:4px;margin-left:auto}.no-rules-hint{margin-top:.25rem}.hint-text{font-size:.9rem;color:var(--text);margin:.5rem 0 .25rem}.hint-text strong{color:var(--accent)}.muted.small{font-size:.8rem;margin-top:.5rem}.membership-functions-card,.output-mf-card,.output-surface-card,.rules-card{grid-column:1 / -1}.membership-functions-card h2,.output-mf-card h2,.output-surface-card h2{margin-bottom:.5rem}.membership-functions-card h2{margin-bottom:.25rem}.membership-functions-card>.muted.small{margin-bottom:1rem}.membership-chart{margin-bottom:1.5rem;padding:.75rem 0;border-bottom:1px solid #2d3748}.membership-chart:last-child{border-bottom:none;margin-bottom:0}.membership-chart-title{font-size:.95rem;margin:0 0 .5rem;color:var(--text)}.membership-chart-current{font-weight:400;color:var(--muted);font-size:.85rem}.membership-chart-svg{width:100%;max-width:320px;height:auto;display:block}.membership-chart-legend{display:flex;flex-wrap:wrap;gap:.75rem 1rem;margin-top:.5rem;font-size:.8rem;color:var(--muted)}.membership-chart-legend-item{display:inline-flex;align-items:center;gap:.35rem}.membership-chart-legend-item[title]{cursor:help}.membership-chart-legend-dot{width:8px;height:8px;border-radius:50%}.output-mf-card{grid-column:1 / -1}.output-mf-card h2{margin-bottom:.25rem}.output-mf-card>.muted.small{margin-bottom:1rem}.output-surface-card{grid-column:1 / -1}.output-surface-card h2{margin-bottom:.25rem}.output-surface{margin-top:.5rem}.output-surface-caption{margin-bottom:.75rem;max-width:56rem}.output-surface-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.25rem}.output-surface-map{background:#1a2332;border-radius:var(--radius);padding:1rem;border:1px solid rgba(255,255,255,.06)}.output-surface-title{font-size:.95rem;margin:0 0 .75rem;color:var(--accent);font-weight:600}.output-surface-svg{width:100%;max-width:420px;height:auto;display:block}.output-surface-marker{pointer-events:none}.mode-badge{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;margin-bottom:1rem}.mode-badge[data-mode=off]{background:#333;color:var(--muted)}.mode-badge[data-mode=standby]{background:#3d2e1f;color:#f0c674}.mode-badge[data-mode=no_lead]{background:#1e2d3a;color:var(--accent)}.mode-badge[data-mode=following]{background:#1e3329;color:var(--green)}.mode-badge[title]{cursor:help}.mode-badge-btn{display:inline-block;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;margin-bottom:1rem;background:none;border:1px solid transparent;font:inherit;color:inherit;cursor:pointer;text-align:left;transition:border-color .15s,filter .15s}.mode-badge-btn:hover{filter:brightness(1.15);border-color:#fff3}.mode-badge-btn[data-mode=off]{background:#333;color:var(--muted)}.mode-badge-btn[data-mode=standby]{background:#3d2e1f;color:#f0c674}.mode-badge-btn[data-mode=no_lead]{background:#1e2d3a;color:var(--accent)}.mode-badge-btn[data-mode=following]{background:#1e3329;color:var(--green)}.gauge{margin-bottom:1rem}.outputs-card .gauge:last-child{margin-bottom:0}.gauge-label{font-size:.85rem;color:var(--muted);margin-bottom:.25rem}.gauge-label[title]{cursor:help}.gauge-label-btn{background:none;border:none;padding:0;margin:0;font:inherit;cursor:pointer;text-align:left;width:100%}.gauge-label-btn:hover .gauge-label.clickable{color:var(--accent);text-decoration:underline}.gauge-label.clickable{cursor:pointer}.gauge-bar-wrap{height:12px;background:#2d3748;border-radius:6px;overflow:hidden}.gauge-bar{height:100%;border-radius:6px;transition:width .15s ease}.gauge-value{font-size:.8rem;color:var(--muted);margin-left:.5rem}.fusion-card h2{margin-bottom:.75rem}.fusion-bars{margin-top:.25rem}.fusion-bars .fusion-bar{display:grid;grid-template-columns:72px 1fr 44px;align-items:center;gap:.6rem;margin-bottom:.6rem;font-size:.9rem}.bar-wrap{height:10px;background:#2d3748;border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px;transition:width .15s ease}.bar-fill.lidar{background:#3498db}.bar-fill.radar{background:#9b59b6}.bar-fill.camera{background:#e67e22}.rules-card h2{margin-bottom:.5rem}.rules-card>.muted.small{margin-bottom:.75rem}.rules-subtitle{font-size:.9rem;font-weight:600;margin:1.25rem 0 .5rem;color:var(--muted)}.rules-subtitle:first-of-type{margin-top:.75rem}.fuzzy-rules-list{margin:0 0 .5rem;padding-left:1.25rem;font-size:.82rem;line-height:1.5;color:var(--text);max-height:14rem;overflow-y:auto}.fuzzy-rule-item{margin-bottom:.4rem}.fuzzy-rule-item strong{color:var(--accent);margin-right:.25rem}.rule-list{margin:0;padding-left:1.25rem;font-size:.85rem}.rule-item{margin-bottom:.35rem}.muted{color:var(--muted);font-size:.85rem;margin:0}.membership-section{margin-bottom:1rem}.membership-section h3{margin-bottom:.5rem}.mb-row{display:grid;grid-template-columns:90px 1fr 40px;align-items:center;gap:.5rem;margin-bottom:.4rem;font-size:.8rem}.mb-bar-wrap{height:8px;background:#2d3748;border-radius:4px;overflow:hidden}.mb-bar{height:100%;background:var(--accent);border-radius:4px;transition:width .15s ease}
