:root{--bg: #0a0e1a;--bg2: #111827;--bg3: #1a2235;--panel: #141c2e;--border: rgba(99,130,255,.12);--border2: rgba(99,130,255,.22);--accent: #6382ff;--accent2: #a78bfa;--teal: #2dd4bf;--amber: #fbbf24;--coral: #f87171;--green: #4ade80;--text: #e8eaf6;--text2: #8b95b8;--text3: #5a6480;--ph1: #6382ff;--ph2: #2dd4bf;--phc: #fbbf24;--font-display: "Fraunces", serif;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--radius: 10px;--radius-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:14px;line-height:1.6;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.topnav{display:flex;align-items:center;gap:0;padding:0 20px;height:52px;background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;z-index:100}.logo{font-family:var(--font-display);font-weight:600;font-size:18px;color:var(--text);letter-spacing:-.3px;margin-right:28px;white-space:nowrap}.logo span{color:var(--accent)}.course-tabs{display:flex;gap:2px;background:var(--bg3);border-radius:8px;padding:3px}.course-tab{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .18s;border:none;background:transparent;color:var(--text2);font-family:var(--font-body);display:flex;flex-direction:column;align-items:flex-start;gap:1px}.course-tab-label{line-height:1.2}.course-tab-coming{font-size:8px;font-weight:600;letter-spacing:.04em;background:#fbbf242e;color:#fbbf24;border:1px solid rgba(251,191,36,.35);border-radius:4px;padding:1px 5px;text-transform:uppercase}.course-tab-sub{font-size:9px;font-weight:400;opacity:.65;letter-spacing:.01em;line-height:1.2;white-space:nowrap}.course-tab.active-ph1{background:#6382ff33;color:var(--ph1)}.course-tab.active-ph2{background:#2dd4bf33;color:var(--ph2)}.course-tab.active-phc{background:#fbbf2433;color:var(--phc)}.course-tab:hover:not(.active-ph1):not(.active-ph2):not(.active-phc){background:var(--bg2);color:var(--text)}.nav-search{margin-left:auto;display:flex;align-items:center;gap:8px}.search-input{background:var(--bg3);border:1px solid var(--border);border-radius:7px;padding:6px 12px;color:var(--text);font-family:var(--font-body);font-size:13px;width:200px;outline:none;transition:border-color .15s}.search-input:focus{border-color:var(--border2)}.search-input::placeholder{color:var(--text3)}.calc-toggle{display:flex;align-items:center;gap:7px;padding:5px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:7px;font-size:12px;color:var(--text2);cursor:pointer;transition:all .15s;font-family:var(--font-mono);-webkit-user-select:none;user-select:none}.calc-toggle.on{border-color:#fbbf2466;color:var(--amber);background:#fbbf2412}.calc-toggle .dot{width:7px;height:7px;border-radius:50%;background:var(--text3);transition:background .15s}.calc-toggle.on .dot{background:var(--amber)}.main-layout{display:flex;flex:1;overflow:hidden}.sidebar{width:240px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border2) transparent}.sidebar-section{padding:14px 14px 6px}.sidebar-section-label{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);padding:0 6px 6px}.topic-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .13s;margin-bottom:1px}.topic-item:hover{background:var(--bg3)}.topic-item.active{background:#6382ff1f}.topic-item.active .topic-name{color:var(--accent)}.topic-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--border2);transition:background .13s}.topic-item.active .topic-dot{background:var(--accent)}.topic-name{font-size:13px;color:var(--text2);flex:1;transition:color .13s}.topic-badge{font-size:9px;font-family:var(--font-mono);padding:1px 5px;border-radius:4px;background:#6382ff1f;color:var(--accent);letter-spacing:.02em}.topic-badge.calc{background:#fbbf241f;color:var(--amber)}.topic-badge.em{background:#2dd4bf1f;color:var(--teal)}.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.topic-header{padding:18px 24px 14px;border-bottom:1px solid var(--border);flex-shrink:0;display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.topic-course-tag{font-size:11px;font-family:var(--font-mono);color:var(--ph1);margin-bottom:4px;letter-spacing:.04em}.topic-title{font-family:var(--font-display);font-weight:600;font-size:22px;color:var(--text);letter-spacing:-.3px;line-height:1.2}.topic-subtitle{font-size:13px;color:var(--text2);margin-top:3px}.topic-actions{display:flex;gap:8px;flex-shrink:0}.btn{padding:7px 14px;border-radius:7px;font-size:12px;font-family:var(--font-body);font-weight:500;cursor:pointer;transition:all .15s;border:1px solid var(--border2);background:transparent;color:var(--text2)}.btn:hover{background:var(--bg3);color:var(--text)}.btn.primary{background:#6382ff26;border-color:#6382ff59;color:var(--accent)}.btn.primary:hover{background:#6382ff40}.quiz-banner{display:none;background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--amber);margin:0 16px;flex-shrink:0;line-height:1.5}.quiz-banner.visible{display:block}.sim-panel-row{display:flex;flex:1;overflow:hidden}.sim-wrapper{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:16px;gap:12px;min-width:0}.canvas-container{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;position:relative;min-height:0}.canvas-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(99,130,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(99,130,255,.04) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}canvas{display:block;width:100%;height:100%;position:relative;z-index:1}.sim-controls-bar{display:flex;align-items:center;gap:6px;flex-shrink:0}.ctrl-btn{min-width:32px;height:32px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .13s;flex-shrink:0}.ctrl-btn.ctrl-label{padding:0 10px;font-size:11px;font-family:var(--font-body);font-weight:500}.ctrl-btn:hover{background:var(--bg2);border-color:var(--border2);color:var(--text)}.ctrl-btn.active{background:#6382ff26;border-color:#6382ff59;color:var(--accent)}.ctrl-divider{width:1px;height:20px;background:var(--border);margin:0 2px}.speed-label{font-size:11px;font-family:var(--font-mono);color:var(--text3);margin-left:auto}.speed-select{background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text2);font-family:var(--font-mono);font-size:11px;padding:4px 8px;outline:none;cursor:pointer}.graph-container{width:100%;height:100px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;overflow:hidden;position:relative;flex-shrink:0}.param-explainer{background:var(--bg2);border:1px solid rgba(99,130,255,.25);border-radius:var(--radius);padding:12px 16px;display:flex;flex-direction:column;gap:6px;flex-shrink:0;animation:pe-in .25s ease;transition:opacity .6s ease}.param-explainer.fading{opacity:0}@keyframes pe-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.pe-sentence{font-size:12.5px;color:var(--text2);line-height:1.6}.pe-sentence strong{color:var(--text)}.pe-sentence em{color:var(--accent2);font-style:normal}.pe-equation{font-family:var(--font-mono);font-size:12px;color:var(--accent2);background:var(--bg3);border-radius:6px;padding:5px 10px}.pe-equation .hi{color:var(--amber);font-style:normal;text-decoration:underline;text-underline-offset:2px}.pe-result{font-family:var(--font-mono);font-size:11px;color:var(--green);padding-top:2px}.concept-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;flex-shrink:0}.concept-title{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:8px}.concept-text{font-size:13px;color:var(--text2);line-height:1.7}.concept-text strong{color:var(--text);font-weight:500}.concept-text em{color:var(--accent2);font-style:normal}.concept-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}.concept-tag{font-size:10px;font-family:var(--font-mono);padding:3px 8px;border-radius:5px;background:#6382ff14;color:var(--accent);border:1px solid rgba(99,130,255,.18)}.right-panel{width:270px;flex-shrink:0;background:var(--panel);border-left:1px solid var(--border);overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border2) transparent;display:flex;flex-direction:column}.panel-section{padding:16px;border-bottom:1px solid var(--border)}.panel-section-title{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text3);margin-bottom:12px}.slider-row{display:flex;flex-direction:column;gap:3px;margin-bottom:14px}.slider-label-row{display:flex;justify-content:space-between;align-items:baseline;gap:6px}.slider-lbl{font-size:12px;color:var(--text2);line-height:1.4;flex:1}.slider-val{font-size:12px;font-family:var(--font-mono);color:var(--accent);white-space:nowrap}input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer;height:4px}.readout-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.readout-card{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 10px}.readout-lbl{font-size:10px;color:var(--text3);margin-bottom:3px;font-family:var(--font-mono)}.readout-val{font-size:15px;font-weight:500;color:var(--text);font-family:var(--font-mono)}.readout-unit{font-size:10px;color:var(--text3)}.preset-row{display:flex;flex-wrap:wrap;gap:6px}.preset-btn{padding:5px 10px;border-radius:6px;font-size:11px;font-family:var(--font-body);background:var(--bg3);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .13s}.preset-btn:hover{border-color:var(--border2);color:var(--text)}.preset-btn.active{background:#6382ff1f;border-color:#6382ff59;color:var(--accent)}.choice-btn-row{display:flex;gap:8px;margin-top:6px}.choice-btn{flex:1;padding:6px 10px;border-radius:6px;border:1px solid rgba(139,149,184,.25);background:#8b95b814;color:var(--text2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.choice-btn:hover{background:#8b95b82e;color:var(--text1)}.choice-btn.active{background:#6366f140;border-color:#6366f199;color:#a5b4fc}.formula-box{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-family:var(--font-mono);font-size:12px;color:var(--accent2);line-height:1.9;white-space:pre-wrap}.formula-box .eq-name{color:var(--text3);font-size:10px}.toggle-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.toggle-lbl{font-size:12px;color:var(--text2)}.toggle-switch{width:32px;height:18px;background:var(--bg3);border:1px solid var(--border2);border-radius:9px;cursor:pointer;position:relative;transition:background .15s;flex-shrink:0}.toggle-switch.on{background:#6382ff4d;border-color:#6382ff80}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;border-radius:50%;background:var(--text3);transition:all .15s}.toggle-switch.on:after{left:16px;background:var(--accent)}.ap-tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-family:var(--font-mono);padding:2px 7px;border-radius:4px;margin-right:4px}.ap-tag.ph1{background:#6382ff1a;color:var(--ph1)}.ap-tag.ph2{background:#2dd4bf1a;color:var(--ph2)}.ap-tag.phc{background:#fbbf241a;color:var(--phc)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
