:root{color:#18212f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}button{font:inherit;border:0}h1,h2,p{overflow-wrap:anywhere}h1{margin:0;font-size:34px;line-height:1.15}.app-shell{grid-template-columns:320px minmax(0,1fr);min-height:100vh;display:grid}.workspace{min-width:0;padding:32px}.sidebar{background:#fff;border-right:1px solid #dce3ed;flex-direction:column;gap:24px;padding:24px;display:flex}.brand{grid-template-columns:48px minmax(0,1fr);align-items:center;gap:12px;display:grid}.brand-mark{color:#fff;background:#133f5c;border-radius:8px;place-items:center;width:48px;height:48px;display:grid}.brand p{margin:0;font-size:17px;font-weight:800}.brand span{color:#667085;margin-top:4px;font-size:13px;line-height:1.4;display:block}.progress-block{border:1px solid #dce3ed;border-radius:8px;padding:16px}.progress-row{color:#475467;justify-content:space-between;gap:12px;font-size:14px;display:flex}.progress-row strong{color:#18212f}.progress-track{background:#edf1f6;border-radius:999px;height:8px;margin:12px 0 10px;overflow:hidden}.progress-track div{border-radius:inherit;background:#1b7f79;height:100%;transition:width .18s}.progress-block p{color:#667085;margin:0;font-size:13px}.lesson-list{gap:8px;display:grid}.mobile-lesson-picker{display:none}.lesson-item{color:#344054;cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:10px;width:100%;min-height:74px;padding:12px;display:grid}.lesson-item.completed{grid-template-columns:36px minmax(0,1fr) 22px}.lesson-item:hover{background:#f5f7fb}.lesson-item.active{color:#153f3c;background:#edf8f7;border-color:#96c9c5}.lesson-number{color:#475467;background:#eef2f6;border-radius:8px;place-items:center;width:36px;height:36px;font-size:13px;font-weight:800;display:grid}.lesson-item.active .lesson-number{color:#fff;background:#1b7f79}.lesson-copy{gap:4px;min-width:0;display:grid}.lesson-copy strong,.lesson-copy small{overflow-wrap:anywhere;display:block}.lesson-copy strong{color:inherit;font-size:14px;line-height:1.3}.lesson-copy small{color:#667085;font-size:12px;line-height:1.35}.done-icon{color:#1b7f79;justify-self:end}@media (width>=921px){.sidebar{max-height:100vh;position:sticky;top:0}.lesson-list{overscroll-behavior:contain;scrollbar-color:#66708573 transparent;scrollbar-gutter:stable;scrollbar-width:thin;flex:1;min-height:0;margin-right:-14px;padding-right:14px;overflow-y:auto}.lesson-list::-webkit-scrollbar{width:8px}.lesson-list::-webkit-scrollbar-track{background:0 0}.lesson-list::-webkit-scrollbar-thumb{background:#6670856b;border:2px solid #fff;border-radius:999px}.lesson-list::-webkit-scrollbar-thumb:hover{background:#66708594}}.hero-panel{border-bottom:1px solid #dce3ed;justify-content:space-between;align-items:flex-start;gap:24px;padding-bottom:24px;display:flex}.eyebrow{color:#1b7f79;margin-bottom:10px;font-size:13px;font-weight:800;display:inline-flex}.hero-panel p{color:#475467;max-width:760px;margin:12px 0 0;font-size:17px;line-height:1.65}.button-row{flex-wrap:wrap;gap:10px;display:flex}.primary,.secondary{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;padding:9px 13px;font-weight:800;display:inline-flex}.secondary{color:#344054;background:#fff;border:1px solid #cfd8e3}.primary{color:#fff;background:#1b7f79}.primary.done-action{color:#667085;background:#eef2f6}.tabs{flex-wrap:wrap;gap:8px;margin:24px 0;display:flex}.tab{color:#475467;cursor:pointer;background:#fff;border:1px solid #cfd8e3;border-radius:8px;min-width:84px;min-height:40px;font-weight:800}.tab.active{color:#fff;background:#133f5c;border-color:#133f5c}.content-grid{grid-template-columns:repeat(1,minmax(0,1fr));gap:18px;display:grid}.panel{background:#fff;border:1px solid #dce3ed;border-radius:8px;min-width:0;padding:22px}.panel.wide{grid-column:1/-1}.panel.compact{padding:18px}.panel-title{color:#133f5c;align-items:center;gap:10px;margin-bottom:16px;display:flex}.panel-title h2{color:#18212f;margin:0;font-size:18px;line-height:1.3}.concept-list,.checklist{gap:12px;margin:0;padding:0;list-style:none;display:grid}.concept-list li{color:#344054;border-left:4px solid #1b7f79;padding-left:12px;line-height:1.65}.checklist{margin-bottom:18px}.checklist li{color:#344054;align-items:flex-start;gap:10px;line-height:1.55;display:flex}.checklist svg{color:#1b7f79;flex:none;margin-top:3px}.compare-label{color:#b9472f;margin-bottom:8px;font-size:13px;font-weight:900;display:inline-block}.panel p,.lead{color:#475467;line-height:1.7}.lead{margin-top:0}.code-block{-webkit-overflow-scrolling:touch;color:#edf4ff;background:#101828;border:1px solid #263344;border-radius:8px;max-width:100%;padding:16px;font-size:14px;line-height:1.65;overflow:auto}.code-block code{white-space:pre;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace}.code-block.success{background:#0f2f24;border-color:#1f7a4d}.code-block.danger{background:#321915;border-color:#9d3b28}.editor-wrap{gap:8px;margin-bottom:14px;display:grid}.editor-wrap>span{color:#344054;font-size:13px;font-weight:900}.code-editor-frame{-webkit-overflow-scrolling:touch;resize:vertical;color:#edf4ff;background:#101828;border:1px solid #263344;border-radius:8px;outline:none;width:100%;max-width:100%;min-height:260px;display:grid;position:relative;overflow:auto}.code-editor-frame:focus-within{border-color:#51b7b0;box-shadow:0 0 0 3px #1b7f792e}.code-editor-frame.danger{border-color:#9d3b28}.code-editor,.code-editor-highlight{tab-size:2;white-space:pre;grid-area:1/1;min-width:max-content;min-height:260px;margin:0;padding:16px;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:14px;line-height:1.65}.code-editor{z-index:1;color:#0000;caret-color:#edf4ff;outline:none}.code-editor::selection{background:#51b7b04d}.code-editor-highlight{pointer-events:none}.code-editor-highlight code{font:inherit}.syntax-comment{color:#8fa1b8;font-style:italic}.syntax-function{color:#7dd3fc}.syntax-keyword{color:#f0abfc;font-weight:700}.syntax-number{color:#fdba74}.syntax-punctuation{color:#b7c5d8}.syntax-string{color:#a7f3d0}.syntax-type{color:#fde68a}.result-note{color:#153f3c;background:#edf8f7;border-left:4px solid #1b7f79;margin:12px 0 0;padding:10px 12px;font-weight:700}.answer-panel{border-color:#a9d7c1}@media (width<=920px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:10;border-bottom:1px solid #dce3ed;border-right:0;gap:16px;position:sticky;top:0}.lesson-list{scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;margin:0 -24px;padding:0 24px 4px;scroll-padding:24px;display:flex;overflow-x:auto}.lesson-item{scroll-snap-align:start;flex:0 0 260px}.workspace{padding:24px}.hero-panel{flex-direction:column}}@media (width<=680px){body{font-size:17px}.sidebar,.workspace{padding:16px}.sidebar{gap:12px;position:static}.brand{grid-template-columns:44px minmax(0,1fr)}.brand-mark{width:44px;height:44px}.brand p{font-size:19px}.brand span{font-size:14px}.progress-block{padding:14px}.progress-row{font-size:15px}.progress-block p{font-size:14px}.mobile-lesson-picker{gap:8px;display:grid}.mobile-lesson-picker span{color:#344054;font-size:14px;font-weight:900}.mobile-lesson-picker select{color:#153f3c;width:100%;min-height:48px;font:inherit;background:#edf8f7;border:1px solid #96c9c5;border-radius:8px;padding:0 12px;font-weight:800}.lesson-list{display:none}.workspace{padding-top:20px}.content-grid{grid-template-columns:1fr;gap:16px}.hero-panel{gap:18px;padding-bottom:20px}h1{font-size:31px;line-height:1.12}.hero-panel p{margin-top:10px;font-size:17px;line-height:1.62}.eyebrow{font-size:14px}.tabs{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin:20px 0;display:grid}.tab{min-width:0;min-height:48px;padding:0 6px;font-size:16px}.panel,.panel.compact{padding:18px}.panel-title{margin-bottom:12px}.panel-title h2{font-size:20px}.concept-list,.checklist{gap:14px}.concept-list li,.checklist li,.panel p,.lead{font-size:17px;line-height:1.7}.code-block,.code-editor,.code-editor-highlight{padding:14px;font-size:14px;line-height:1.6}.editor-wrap>span{font-size:15px}.code-editor-frame,.code-editor,.code-editor-highlight{min-height:320px}.primary,.secondary{width:100%;min-height:48px;font-size:16px}}
