:root{--bg:#0d1117;--panel:#151b23;--panel2:#1f2937;--text:#e6edf3;--muted:#9aa4b2;--accent:#7dd3fc;--accent2:#a78bfa;--good:#34d399;--bad:#fb7185;--warn:#fbbf24;--border:#303846}*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,#1e293b,#0d1117 45%);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}h1,h2,h3{margin-top:0}p{line-height:1.55}.hero{display:grid;grid-template-columns:1fr 280px;gap:24px;padding:42px 48px 26px;border-bottom:1px solid var(--border)}.eyebrow{text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-size:12px}.hero h1{font-size:38px;line-height:1.08;max-width:980px}.lead{font-size:18px;color:var(--muted);max-width:900px}.hero-card,.panel,.sidebar{background:rgba(21,27,35,.86);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 50px rgba(0,0,0,.25)}.hero-card{padding:22px;align-self:center}.status-dot{display:inline-block;width:10px;height:10px;border-radius:99px;background:var(--good);box-shadow:0 0 18px var(--good);margin-right:8px}.layout{display:grid;grid-template-columns:310px 1fr;gap:24px;padding:24px 48px 48px}.sidebar{padding:18px;position:sticky;top:16px;height:calc(100vh - 32px);overflow:auto}.task-list{display:flex;flex-direction:column;gap:10px}.task-btn{border:1px solid var(--border);background:#0f172a;color:var(--text);text-align:left;border-radius:14px;padding:12px;cursor:pointer}.task-btn:hover,.task-btn.active{border-color:var(--accent);background:#122033}.task-btn small{display:block;color:var(--muted);margin-top:4px}.content{display:flex;flex-direction:column;gap:20px}.panel{padding:22px}.grid{display:grid;gap:20px}.grid.two{grid-template-columns:1fr 1fr}.task-meta{display:flex;gap:12px;align-items:center}.badge{display:inline-flex;padding:5px 10px;border-radius:999px;background:rgba(125,211,252,.14);border:1px solid rgba(125,211,252,.35);color:var(--accent)}.muted{color:var(--muted)}label{display:block;margin:14px 0 6px;color:var(--muted)}input[type=range]{width:100%;accent-color:var(--accent)}.robot-scene{position:relative;height:140px;background:linear-gradient(90deg,#111827,#0f172a);border:1px solid var(--border);border-radius:16px;margin-top:18px;overflow:hidden}.robot{position:absolute;bottom:28px;left:24px;font-size:44px;transition:left .25s}.obstacle{position:absolute;right:30px;bottom:20px;width:35px;height:80px;background:linear-gradient(#f97316,#ef4444);border-radius:10px}.state{margin-top:12px;padding:12px;border-radius:14px;background:var(--panel2);font-weight:700}.state.good{color:var(--good)}.state.bad{color:var(--bad)}.metric{display:flex;justify-content:space-between;gap:20px;border-bottom:1px solid var(--border);padding:10px 0}.metric span{color:var(--muted)}button{border:0;border-radius:12px;padding:11px 14px;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#08111f;font-weight:800;cursor:pointer;margin-top:14px}pre{white-space:pre-wrap;background:#0b1220;border:1px solid var(--border);padding:14px;border-radius:14px;min-height:105px}.journal-form{display:flex;gap:10px}.journal-form input{flex:1;border:1px solid var(--border);background:#0b1220;color:var(--text);border-radius:12px;padding:12px}.theory{border-color:rgba(167,139,250,.4)}@media(max-width:900px){.hero,.layout,.grid.two{grid-template-columns:1fr}.hero{padding:28px 20px}.layout{padding:20px}.sidebar{position:static;height:auto}.hero h1{font-size:30px}}
select{width:100%;border:1px solid var(--border);background:#0b1220;color:var(--text);border-radius:12px;padding:11px}.controller-info{margin:8px 0 14px;padding:12px;border:1px solid var(--border);border-radius:14px;background:#0b1220;color:var(--muted)}.controller-info strong{color:var(--accent)}.controller-info span{font-size:13px}.iot-flow{display:flex;align-items:stretch;gap:10px;flex-wrap:wrap}.flow-card{min-width:145px;flex:1;background:#0b1220;border:1px solid var(--border);border-radius:16px;padding:14px}.flow-card b{display:block;color:var(--accent);margin-bottom:6px}.flow-card span{color:var(--muted);font-size:13px}.arrow{display:flex;align-items:center;color:var(--accent);font-size:24px}.stream{display:flex;flex-direction:column;gap:6px;max-height:140px;overflow:auto}.stream-row{background:#0b1220;border:1px solid var(--border);border-radius:10px;padding:8px;color:var(--muted);font-size:13px}.state.warn{color:var(--warn)}.future{border-color:rgba(52,211,153,.35)}.iot-map{border-color:rgba(125,211,252,.35)}
.wiring-lab{border-color:rgba(251,191,36,.38)}.code-lab{border-color:rgba(167,139,250,.45)}.logic-chain{display:flex;flex-direction:column;gap:10px}.logic-step{background:#0b1220;border:1px solid var(--border);border-radius:14px;padding:12px}.logic-step b{color:var(--accent)}.logic-step small{display:block;color:var(--muted);margin-top:4px}.check-result,.code-report{margin-top:12px;display:flex;flex-direction:column;gap:8px}.check-item{padding:10px;border-radius:12px;border:1px solid var(--border);background:#0b1220}.check-item.ok{border-color:rgba(52,211,153,.5);color:var(--good)}.check-item.warn{border-color:rgba(251,191,36,.55);color:var(--warn)}.check-item.bad{border-color:rgba(251,113,133,.55);color:var(--bad)}textarea#codeEditor{width:100%;min-height:280px;background:#050b16;color:#dbeafe;border:1px solid var(--border);border-radius:16px;padding:14px;font:14px/1.45 ui-monospace,SFMono-Regular,Consolas,monospace;tab-size:2}.code-actions{display:flex;gap:10px;flex-wrap:wrap}
.pinout-wrap{margin:14px 0 18px}.pinout-board{background:#07111f;border:1px solid var(--border);border-radius:18px;padding:14px;overflow:auto}.board-svg text{font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:11px;fill:#cbd5e1}.board-body{fill:#123b5d;stroke:#60a5fa;stroke-width:2}.board-chip{fill:#111827;stroke:#64748b}.pin-dot{fill:#1f2937;stroke:#64748b;stroke-width:1}.pin-dot.active{fill:#fbbf24;stroke:#fde68a;stroke-width:2}.pin-label.active{fill:#fbbf24;font-weight:700}.pin-legend{fill:#94a3b8;font-size:12px}.pin-wire{stroke:#fbbf24;stroke-width:2;stroke-dasharray:4 3}.pin-role{fill:#fde68a;font-size:12px;font-weight:700}
.sensor-chooser{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px;margin-top:10px}.sensor-card{display:block;border:1px solid var(--border);background:#0b1220;border-radius:14px;padding:12px;cursor:pointer}.sensor-card input{margin-right:8px}.sensor-card b{display:block;color:var(--text);margin-bottom:4px}.sensor-card small{display:block;color:var(--muted);line-height:1.35}.sensor-card.selected{border-color:var(--accent);background:#102033}.sensor-card.disabled{opacity:.45;cursor:not-allowed}.iot-flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));align-items:stretch}.arrow{display:none}.flow-card{min-height:86px}.flow-card span{word-break:break-word}
.source-note{border-left:3px solid var(--accent);padding:8px 12px;background:#0b1220;border-radius:10px;text-indent:0}.source-note strong{color:var(--accent)}
.story-box{border:1px solid rgba(167,139,250,.35);background:#111827;border-radius:16px;padding:14px;margin:14px 0}.story-box h3,.map-box h3{margin-bottom:8px}.story-box p{text-indent:0;margin:0}.map-box{margin:14px 0}.task-map{background:#07111f;border:1px solid var(--border);border-radius:18px;padding:12px;overflow:auto}.task-map svg{max-width:100%;height:auto}.map-bg{fill:#0f172a;stroke:#334155;stroke-width:2}.map-zone{fill:#1e293b;stroke:#64748b;stroke-width:2}.map-good{fill:#064e3b;stroke:#34d399}.map-warn{fill:#78350f;stroke:#fbbf24}.map-bad{fill:#7f1d1d;stroke:#fb7185}.map-path{fill:none;stroke:#7dd3fc;stroke-width:4;stroke-dasharray:8 6}.map-label{font:13px Inter,system-ui,sans-serif;fill:#e6edf3}.map-small{font:11px Inter,system-ui,sans-serif;fill:#94a3b8}.map-pin{fill:#fbbf24;stroke:#fde68a;stroke-width:2}.map-robot{font-size:24px}.map-arrow{stroke:#a78bfa;stroke-width:3;marker-end:url(#arrow)}
