*{box-sizing:border-box;margin:0;padding:0;font-family:sans-serif}body{background-color:#f4f4f9}header{padding:15px 30px;background-color:#333;color:#fff;display:flex;justify-content:space-between;align-items:center}header a{color:#4caf50;text-decoration:none}header a:hover{text-decoration:underline}#app-container{display:flex;max-width:1400px;margin:20px auto;background-color:#fff;box-shadow:0 4px 8px #0000001a;min-height:80vh}#roadmap-nav{flex:0 0 250px;padding:20px;border-right:1px solid #ddd;background-color:#fafafa}#content-area{flex-grow:1;padding:30px;line-height:1.6}#playground-layout{display:flex;height:calc(100vh - 70px)}#threejs-container{flex-grow:1;border:1px solid #ccc;background-color:#ddd}#ui-panel{flex:0 0 350px;padding:20px;background-color:#2c3e50;color:#fff;overflow-y:auto}#controls-area{margin-top:15px;padding:10px;border:1px solid #4CAF50;border-radius:5px}#servo-angle{width:100%}#app-container{display:flex;max-width:1400px;margin:20px auto;background-color:#fff;box-shadow:0 4px 12px #0000001a;min-height:80vh;border-radius:8px;overflow:hidden}#roadmap-nav{flex:0 0 280px;padding:20px 0;border-right:1px solid #e0e0e0;background-color:#f8f9fa;overflow-y:auto;position:sticky;top:0;height:calc(100vh - 70px)}#roadmap-nav h2{padding:0 20px 10px;color:#34495e;border-bottom:2px solid #34495e;margin-bottom:15px}#roadmap-nav ul{list-style:none;padding:0}.roadmap-title h3{font-size:1.1em;padding:10px 20px;color:#2c3e50;margin-top:15px}.chapter-title h4{font-size:1em;font-weight:700;color:#3b8186;padding:8px 20px 5px;margin-top:10px}.subchapter-item a{display:block;padding:8px 20px 8px 30px;text-decoration:none;color:#34495e;font-size:.95em;border-left:3px solid transparent;transition:background-color .2s,border-left-color .2s}.subchapter-item a:hover{background-color:#ecf0f1}.subchapter-item a.active{background-color:#e8f7f0;border-left-color:#4caf50;font-weight:700;color:#2c3e50}#content-area{flex-grow:1;padding:30px;line-height:1.65}#course-layout{display:flex;height:100vh;overflow:hidden}#roadmap-list{width:250px;flex-shrink:0;overflow-y:auto;background-color:#f8f9fa;border-right:1px solid #ddd}#content-area{flex-grow:1;padding:30px;overflow-y:auto;max-width:800px}#right-sidebar{position:sticky;top:72px;max-height:calc(100vh - 72px);overflow-y:auto}#content-area h2{color:#362adb;margin-bottom:20px;border-bottom:2px solid #ddd;padding-bottom:10px}#content-area h3{color:#3498db;margin:25px 0 10px}pre{background-color:#2d2d2d;color:#f8f8f2;padding:15px;border-radius:5px;overflow-x:auto;font-family:Consolas,Monaco,monospace;font-size:.9em;margin:20px 0}#content-area img{max-width:100%;height:auto;display:block;margin:20px auto;border:1px solid #ccc;border-radius:4px}.failure-modes{border:2px solid #e74c3c;background-color:#fdf5f5;padding:20px;border-radius:6px;margin:30px 0}.failure-modes h3{color:#c0392b;border-bottom:1px dashed #e74c3c;padding-bottom:10px;margin-top:0}.failure-modes ul{list-style-type:none;padding-left:0}.failure-modes li{margin-bottom:10px;padding-left:25px;position:relative;color:#333}.failure-modes li:before{content:"⚠️";position:absolute;left:0;font-size:1.1em}.playground-link{margin:30px 0;padding:15px;background-color:#d1e7dd;border-left:5px solid #4CAF50;border-radius:4px;font-weight:700}.playground-link a{color:#4caf50;text-decoration:underline}#peer-support-box{position:fixed;bottom:15px;right:15px;width:260px;background:#fff;border:2px solid #ccc;border-radius:8px;box-shadow:0 0 10px #0000004d;font-family:sans-serif;z-index:9999}#peer-support-header{background:#2e7d32;color:#fff;padding:8px;font-weight:700;border-top-left-radius:6px;border-top-right-radius:6px}#peer-support-messages{height:200px;overflow-y:auto;padding:8px;font-size:.9em}.peer-msg{background:#e8f5e9;padding:6px;border-radius:6px;margin:5px 0}.user-msg{background:#e3f2fd;padding:6px;border-radius:6px;margin:5px 0;text-align:right}#peer-support-input-area{display:flex;padding:8px;gap:5px}#peer-support-input{flex:1;padding:5px;border:1px solid #aaa;border-radius:4px}#peer-support-send{padding:6px 10px;background:#2e7d32;color:#fff;border:none;border-radius:4px;cursor:pointer}#ai-assistant-container{display:flex;flex-direction:column;height:100%;background:#1e1e1e;color:#eaeaea;border-radius:8px;overflow:hidden;font-size:.9rem}#ai-assistant-container h4{margin:0;padding:10px 14px;background:#252526;border-bottom:1px solid #333;font-size:.85rem;letter-spacing:.3px;color:#9cdcfe}#chat-messages{flex:1;padding:12px;overflow-y:auto;background:#1e1e1e;display:flex;flex-direction:column;gap:10px}.msg-ai,.msg-user{max-width:90%;padding:8px 10px;border-radius:6px;line-height:1.4;word-wrap:break-word}.msg-ai{align-self:flex-start;background:#2d2d30;border-left:3px solid #4fc3f7}.msg-user{align-self:flex-end;background:#0e639c;color:#fff}.chat-controls{display:flex;gap:6px;padding:10px;border-top:1px solid #333;background:#252526}#chat-input{flex:1;background:#1e1e1e;border:1px solid #3c3c3c;color:#fff;padding:6px 8px;border-radius:4px;outline:none}#chat-input:focus{border-color:#4fc3f7}#chat-send{background:#0e639c;border:none;color:#fff;padding:6px 12px;border-radius:4px;cursor:pointer}#chat-send:hover{background:#17b}#right-sidebar{width:340px;min-width:340px;height:calc(100vh - 64px);padding:16px;overflow-y:auto;background:#0f1115;border-left:1px solid #1f2430;display:flex;flex-direction:column;gap:16px}#right-sidebar h3{font-size:1.1rem;font-weight:600;color:#e6e9ef;margin-bottom:4px}.tool-section{background:#151922;border:1px solid #22283a;border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.tool-section h4{font-size:.9rem;font-weight:600;color:#cdd6f4;margin-bottom:4px}.tool-section ul{list-style:none;padding-left:0;margin:0}.tool-section li{font-size:.85rem;line-height:1.4;color:#aab1c3;margin-bottom:6px}.tool-section a{color:#89b4fa;text-decoration:none}.tool-section a:hover{text-decoration:underline}.playground-link{display:inline-block;margin-top:6px;padding:8px 10px;background:#1b2030;border:1px solid #2a3150;border-radius:6px;font-size:.85rem;font-weight:500;text-align:center}.playground-link:hover{background:#22274a}.ai-panel{margin-top:auto}.ai-chat-box{height:180px;overflow-y:auto;background:#0b0d13;border:1px solid #22283a;border-radius:6px;padding:8px;font-size:.8rem;color:#cdd6f4}.msg-ai{color:#a6e3a1;margin-bottom:6px}.msg-user{color:#f9e2af;margin-bottom:6px}.ai-input-row{display:flex;gap:6px}.ai-input-row input{flex:1;padding:6px 8px;background:#0b0d13;border:1px solid #22283a;border-radius:6px;color:#e6e9ef;font-size:.8rem}.ai-input-row button{padding:6px 10px;background:#313244;border:1px solid #45475a;border-radius:6px;color:#e6e9ef;font-size:.8rem;cursor:pointer}.ai-input-row button:hover{background:#45475a}.sidebar-section{background:#111827;border-radius:12px;margin-bottom:14px;overflow:hidden;border:1px solid #1f2937}.section-header{all:unset;cursor:pointer;display:flex;justify-content:space-between;align-items:center;width:100%;padding:12px 14px;font-weight:600;color:#e5e7eb}.section-header:hover{background:#1f2937}.section-body{padding:10px 14px 14px}.sidebar-section.collapsed .section-body{display:none}.chevron{transition:transform .2s ease}.sidebar-section.collapsed .chevron{transform:rotate(-90deg)}#right-sidebar a:hover{text-decoration:underline}#right-sidebar{position:sticky;top:72px;max-height:calc(100vh - 72px);overflow-y:auto;background:#0f1117;color:#e6e6eb;padding:1rem;border-left:1px solid #1e2230}#right-sidebar h3{font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:#fff}#right-sidebar section{background:#151826;border-radius:10px;padding:.9rem;margin-bottom:1rem;box-shadow:0 4px 14px #00000040}#right-sidebar h4{font-size:.9rem;margin-bottom:.6rem;color:#cfd6ff;display:flex;align-items:center;gap:.4rem}#right-sidebar ul{list-style:none;padding-left:0;margin:0}#right-sidebar li{font-size:.85rem;line-height:1.4;margin-bottom:.4rem;color:#d0d3dc}#right-sidebar a{color:#8ab4ff;text-decoration:none}#right-sidebar{position:fixed;right:0;top:auto;max-height:60vh;border-left:none;border-top:1px solid #1e2230;border-radius:16px 16px 0 0;z-index:2}.lesson-debugging{border-left:4px solid #4da3ff}.lesson-failure{border-left:4px solid #f5b942;background:#1b1a12}.lesson-failure li{color:#f0d9a6}.lesson-playground{background:linear-gradient(135deg,#1d4ed8,#2563eb);text-align:center}.lesson-playground a{display:inline-block;color:#fff;font-weight:600;padding:.6rem .9rem;border-radius:6px;background:#ffffff1f}.lesson-playground a:hover{background:#fff3}#ai-assistant-container{background:#0b0d14;border:1px solid #1f2433}.chat-box{max-height:240px;overflow-y:auto;background:#0f1117;padding:.5rem;border-radius:6px;margin-bottom:.5rem;font-size:.85rem}.msg-ai{color:#b6f2c2;margin-bottom:.4rem}.msg-user{color:#8ab4ff;margin-bottom:.4rem}.chat-controls{display:flex;gap:.4rem}#chat-input{flex:1;background:#0f1117;border:1px solid #1f2433;color:#fff;padding:.4rem;border-radius:4px}#chat-input:focus{outline:none;border-color:#4da3ff}#chat-send{background:#2563eb;border:none;color:#fff;padding:.4rem .7rem;border-radius:4px;cursor:pointer}#chat-send:hover{background:#1d4ed8}@media(max-width:1024px){#course-layout{display:flex;flex-direction:column}#roadmap-list{display:none}#right-sidebar{position:fixed;bottom:0;margin-left:auto;top:auto;max-height:60vh;border-left:none;border-top:1px solid #1e2230;border-radius:16px 16px 0 0;z-index:100}#content-area{padding-bottom:60vh}}.roadmap-module{margin-bottom:.6rem}.roadmap-module-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:.35rem .5rem;border-radius:6px;background:#151826;font-size:.85rem}.roadmap-module-header:hover{background:#1f2433}.roadmap-module .chevron{transition:transform .2s ease}.roadmap-module .roadmap-lessons{display:none;margin-top:.3rem}.roadmap-module.open .roadmap-lessons{display:block}.roadmap-module.open .chevron{transform:rotate(90deg)}#roadmap-toggle{display:none;font-size:1.3rem;background:none;border:none;color:inherit;cursor:pointer}@media(max-width:900px){#roadmap-toggle{display:block}#roadmap-list{position:fixed;top:0;left:0;height:100vh;width:260px;background:#0f1220;z-index:1000;transform:translate(-100%);transition:transform .25s ease;overflow-y:auto;padding-top:3.5rem}#roadmap-list.open{transform:translate(0)}#roadmap-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:999}#roadmap-backdrop.show{display:block}#course-layout{grid-template-columns:1fr}}#peer-support-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;background:linear-gradient(135deg,#00c853,#64dd17);border-radius:50%;display:grid;place-items:center;font-size:24px;cursor:pointer;z-index:9999;box-shadow:0 10px 30px #0000004d}#peer-support-dm{position:fixed;bottom:96px;right:24px;width:360px;height:480px;background:#0f1117;color:#fff;border-radius:14px;box-shadow:0 20px 60px #00000080;display:none;flex-direction:column;z-index:9999}#peer-support-dm.open{display:flex}.dm-header{padding:12px 16px;font-weight:700;display:flex;justify-content:space-between;background:#161b22;border-bottom:1px solid #222}.dm-body{flex:1;padding:16px;font-size:14px;opacity:.7}.dm-footer{padding:12px;border-top:1px solid #222}.dm-footer input{width:100%;padding:8px;background:#1c2128;border:none;color:#fff;border-radius:6px}#peer-support-panel{position:fixed;bottom:90px;right:20px;width:360px;height:480px;background:#0e0f14;border-radius:14px;display:none;flex-direction:column;box-shadow:0 20px 40px #0006;z-index:9999}.ps-header{padding:12px 16px;display:flex;justify-content:space-between;border-bottom:1px solid #222}.ps-contacts{width:40%;border-right:1px solid #222;overflow-y:auto}.ps-contact{padding:12px;cursor:pointer}.ps-contact.active{background:#1b1d29}.ps-empty{margin:auto;color:#777;text-align:center}.ps-body{display:flex;height:100%}.ps-contacts{width:38%;border-right:1px solid #222;overflow-y:auto}#peer-support-panel{position:fixed;bottom:80px;right:20px;width:360px;height:480px;background:#0b0e14;border-radius:12px;box-shadow:0 20px 60px #00000080;display:none;flex-direction:column;z-index:9999}#peer-support-panel.open{display:flex}.ps-header{padding:12px 14px;font-weight:600;border-bottom:1px solid #222;display:flex;justify-content:space-between;align-items:center}.ps-body{flex:1;display:flex;overflow:hidden}.ps-contacts{width:120px;border-right:1px solid #222;overflow-y:auto}.ps-contact{padding:10px;cursor:pointer}.ps-contact:hover{background:#151a25}.ps-chat{flex:1;display:flex;flex-direction:column}.ps-empty{margin:auto;opacity:.6}.ps-messages{flex:1;padding:12px;overflow-y:auto}.ps-input{display:flex;gap:6px;padding:10px;border-top:1px solid #222}.ps-input input{flex:1;background:#111;border:1px solid #333;color:#fff;padding:6px 8px;border-radius:6px}#peer-support-dm{position:fixed;bottom:90px;right:24px;width:360px;height:480px;background:linear-gradient(180deg,#0f1115,#0a0c10);border-radius:16px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;opacity:0;transform:translateY(20px) scale(.98);pointer-events:none;transition:all .25s ease;z-index:9999}.dm-main{display:grid;grid-template-columns:120px 1fr;height:100%}.dm-contacts{border-right:1px solid rgba(255,255,255,.08);padding:8px}.dm-contact{padding:10px;border-radius:10px;cursor:pointer;margin-bottom:4px}.dm-contact:hover{background:#ffffff0f}.dm-contact .name{font-size:14px;font-weight:600}.dm-contact .meta{font-size:11px;opacity:.7}.dm-chat{display:flex;flex-direction:column;height:100%}.dm-empty{margin:auto;opacity:.5;font-size:14px}#hardware-snapshot{position:fixed;inset:0;z-index:9999}.hs-backdrop{position:absolute;inset:0;background:#0009}.hs-panel{position:absolute;right:20px;bottom:80px;width:320px;max-height:80vh;overflow-y:auto;background:#fff;border-radius:12px;padding:16px;box-shadow:0 20px 40px #0000004d}.hs-panel section{margin-bottom:12px}.hs-warning{background:#ffeaea;color:#b00020;padding:8px;border-radius:6px;font-weight:700}.hs-actions{display:flex;justify-content:space-between;margin-top:12px}.hs-panel{animation:snapIn .25s ease-out}@keyframes snapIn{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.dm-input button{cursor:pointer;transition:transform .1s ease,background .2s ease}.dm-input button:hover{transform:scale(1.1)}.dm-input button:active{transform:scale(.95)}#peer-support-fab{position:fixed;bottom:18px;right:18px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#00c853,#64dd17);display:flex;align-items:center;justify-content:center;font-size:26px;cursor:pointer;box-shadow:0 12px 30px #00c85359;transition:transform .2s ease,box-shadow .2s ease;z-index:9998}#peer-support-fab:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 18px 40px #00c85373}#peer-support-fab:active{transform:scale(.95)}#peer-support-dm{position:fixed;bottom:90px;right:18px;width:380px;height:520px;background:#111;border-radius:14px;box-shadow:0 30px 80px #0009;display:flex;flex-direction:column;opacity:0;transform:translateY(20px) scale(.97);pointer-events:none;transition:all .25s ease;z-index:9999}.dm-contacts{width:140px;background:#0b0b0b;border-right:1px solid #222;overflow-y:auto}.dm-contact{padding:12px;cursor:pointer;transition:background .2s ease}.dm-contact:hover{background:#1a1a1a}.dm-contact .name{font-weight:600;color:#fff;font-size:.95em}.dm-contact .meta{font-size:.75em;color:#8bc34a}.dm-empty{color:#666;font-size:.9em;text-align:center;margin:auto;opacity:.7}.msg{max-width:80%;padding:10px 12px;margin-bottom:8px;border-radius:12px;font-size:.9em;line-height:1.4}.msg.other{background:#1e1e1e;color:#fff;align-self:flex-start}.msg.self{background:linear-gradient(135deg,#00c853,#64dd17);color:#000;align-self:flex-end}.dm-input{display:flex;align-items:center;gap:6px;padding:10px;border-top:1px solid #222;background:#0f0f0f}.dm-input input{flex:1;min-width:0;background:#1a1a1a;border:none;color:#fff;padding:8px 10px;border-radius:8px;outline:none}.dm-input button{background:#1f1f1f;border:none;color:#fff;padding:6px 8px;border-radius:8px;cursor:pointer}.dm-input button:hover{background:#2a2a2a}.msg.snapshot{background:linear-gradient(135deg,#00e676,#1de9b6);color:#030;font-size:.85em;border-radius:12px;padding:10px 12px;max-width:75%;align-self:flex-end;box-shadow:0 8px 20px #00e67640}.msg.snapshot strong{display:block;font-weight:600;margin-bottom:4px}.snapshot-mini{font-size:.8em;opacity:.9}.dm-messages{display:flex;flex-direction:column;gap:8px}.dm-chat{display:flex;flex-direction:column;background:#111}#peer-support-dm{position:fixed!important;inset:auto 24px 90px auto;width:360px;height:480px;background:linear-gradient(180deg,#111,#0a0a0a);border-radius:14px;box-shadow:0 30px 80px #000000bf;display:flex;flex-direction:column;z-index:2147483647;opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;transition:opacity .25s ease,transform .25s ease}#peer-support-dm.open{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}#peer-support-fab{position:fixed!important;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:#1db954;color:#000;display:grid;place-items:center;font-size:22px;cursor:pointer;z-index:2}#peer-support-dm{position:fixed;inset:auto 24px 24px auto;z-index:10}#peer-support-dm{position:fixed;bottom:90px;right:24px;width:360px;height:480px;display:flex;flex-direction:column;background:#0b0f14;border-radius:12px;overflow:hidden}.dm-main{display:flex;flex:1;min-height:0}.dm-chat{display:flex;flex-direction:column;flex:1;min-width:0;min-height:0}.dm-messages{flex:1;padding:12px;overflow-y:auto}.dm-input{display:flex;gap:8px;padding:10px;border-top:1px solid rgba(255,255,255,.08)}#profile-btn{position:fixed;top:12px;right:16px;z-index:9999;background:#111;color:#fff;border-radius:50%;width:42px;height:42px;border:none;cursor:pointer}#profile-panel{position:fixed;top:64px;right:16px;width:260px;background:#0f172a;color:#fff;border-radius:12px;padding:16px;z-index:9999;box-shadow:0 10px 40px #0006}#profile-panel.hidden{display:none}.profile-header{display:flex;justify-content:space-between;align-items:center}.profile-stats .stat{display:flex;justify-content:space-between;margin:10px 0;opacity:.9}#profile-panel{position:fixed;top:80px;right:20px;width:280px;background:#111;color:#eee;border-radius:12px;padding:12px;box-shadow:0 10px 30px #0006;font-size:12px;z-index:999}.profile-header{margin-bottom:10px;font-size:14px}.heatmap-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.heatmap-cell{width:14px;height:14px;border-radius:3px;background:#222}.heatmap-cell[data-level="0"]{background:#222}.heatmap-cell[data-level="1"]{background:#1e3a2f}.heatmap-cell[data-level="2"]{background:#2e7d32}.heatmap-cell[data-level="3"]{background:#66bb6a}.heatmap-cell[data-level="4"]{background:#b9f6ca}
