:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#f5f7ff;--bg:#050813;--bg-2:#0a1228;--line:#ffffff14;--line-strong:#ffffff29;--muted:#8a9bcf;--muted-2:#6c7eb0;--text:#eef2ff;--code-bg:#07101f;--tok-kw:#ff8ab8;--tok-type:#4ad6a8;--tok-string:#ffd479;--tok-num:#ffb14a;--tok-comment:#5a6a91;--tok-cap:#7dd1ff;--tok-punct:#cbd3f3;--tok-op:#c5a8ff;background:#050813;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:radial-gradient(1200px 800px at 80% -10%,#6282ff2e,#0000 60%),radial-gradient(900px 600px at 0 110%,#4ad6a824,#0000 60%),radial-gradient(circle,#0c1832 0%,#050813 60%,#02040b 100%);min-height:100vh;line-height:1.6}main{width:min(1320px,100%);padding:48px 28px 96px;padding-left:max(28px, env(safe-area-inset-left));padding-right:max(28px, env(safe-area-inset-right));margin:0 auto}.hero{text-align:center;place-items:center;margin-bottom:56px;display:grid}.hero__content{max-width:820px}.eyebrow{color:#7c95d1;text-transform:uppercase;letter-spacing:.18em;margin:0 0 14px;font-size:.78rem;font-weight:600}h1{background:linear-gradient(135deg,#fff 0%,#a6bcff 60%,#4ac0ff 100%);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;margin:0;font-size:clamp(2.5rem,4.5vw,4.5rem);line-height:1.05}p{color:#cbd3f3;max-width:44rem;margin:16px auto 0}.hero__hint{border:1px solid var(--line);color:#a6bcff;background:#0d163099;border-radius:999px;align-items:center;gap:10px;margin-top:22px;padding:8px 14px;font-size:.85rem;display:inline-flex}.hero__hint:before{content:"";background:#4ac0ff;border-radius:50%;width:8px;height:8px;box-shadow:0 0 12px #4ac0ff}.course-shell{gap:24px;display:grid}.course-header{border:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0b1329b3;border-radius:22px;justify-content:space-between;align-items:center;gap:20px;padding:22px 26px;display:flex}.course-header__main{display:grid}.course-header__title{letter-spacing:-.01em;margin:6px 0 0;font-size:1.4rem;font-weight:600}.course-header__lessons-btn{border:1px solid var(--line-strong);color:var(--text);font:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff0f;border-radius:14px;align-items:center;gap:10px;padding:10px 14px;font-size:.9rem;font-weight:600;display:none}.course-header__lessons-icon{font-size:1.05rem;line-height:1}.course-header__lessons-count{color:var(--muted);background:#ffffff0f;border-radius:999px;padding:2px 8px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.78rem}.progress-meter{flex-direction:column;align-items:flex-end;gap:8px;min-width:240px;display:flex}.progress-meter__bar{background:#ffffff14;border-radius:999px;width:240px;height:6px;overflow:hidden}.progress-meter__fill{border-radius:999px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.progress-meter__label{color:var(--muted);font-size:.82rem}.course-panel{grid-template-columns:minmax(300px,360px) minmax(0,1fr);align-items:start;gap:24px;display:grid}.lesson-list{scrollbar-width:thin;scrollbar-color:#ffffff26 transparent;gap:22px;max-height:calc(100vh - 48px);padding-right:6px;display:grid;position:sticky;top:24px;overflow-y:auto}.lesson-list::-webkit-scrollbar{width:6px}.lesson-list::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:999px}.track-group{gap:8px;display:grid}.track-group__head{border-bottom:1px solid var(--line);gap:2px;padding:4px 4px 6px;display:grid}.track-group__label{letter-spacing:.22em;text-transform:uppercase;color:#c8d4ff;font-size:.74rem;font-weight:700}.track-group__tag{color:var(--muted-2);font-size:.78rem}.track-group__lessons{grid-template-columns:minmax(0,1fr);gap:8px;display:grid}.lesson-card{border:1px solid var(--line);text-align:left;color:inherit;cursor:pointer;font:inherit;background:#0f18329e;border-radius:14px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;width:100%;padding:12px 14px;transition:transform .22s,border-color .22s,background .22s;display:grid}.lesson-card:hover{background:#142040c7;transform:translateY(-1px)}.lesson-card.active{background:#14244cd9;box-shadow:0 18px 40px -20px #6282ff80}.lesson-card__num{letter-spacing:.05em;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;font-weight:600}.lesson-card__body{gap:2px;min-width:0;display:grid}.lesson-card__title{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.94rem;font-weight:600;overflow:hidden}.lesson-card__focus{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:.78rem;overflow:hidden}.lesson-card__check{border:1px solid var(--line);width:22px;height:22px;color:var(--muted);background:#ffffff0d;border-radius:50%;flex-shrink:0;place-items:center;font-size:.72rem;display:grid}.lesson-card__check.is-done{color:#042a1f;background:linear-gradient(135deg,#4ad6a8 0%,#4ac0ff 100%);border-color:#0000;font-weight:700}.stage-panel{border:1px solid var(--line);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#ffffff2e transparent;background:linear-gradient(#0d1630cc 0%,#070c1af5 100%);border-radius:28px;max-height:calc(100vh - 48px);position:relative;overflow:hidden auto}.stage-panel::-webkit-scrollbar{width:6px}.stage-panel::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:999px}.lesson-scene{z-index:0;height:360px;position:sticky;top:0}.lesson-scene canvas{display:block;width:100%!important;height:100%!important}.stage-overlay{pointer-events:none;z-index:1;background:radial-gradient(60% 80% at 100% 0,#ffffff12,#0000 60%),linear-gradient(#0000 60%,#050813eb 100%);height:360px;position:absolute;top:0;left:0;right:0}.stage-content{z-index:2;grid-template-columns:minmax(0,1fr);align-content:start;gap:28px;min-width:0;margin-top:-88px;padding:0 36px 40px;display:grid;position:relative}.stage-heading{gap:8px;max-width:720px;display:grid}.stage-heading__eyebrow{text-transform:uppercase;letter-spacing:.2em;margin:0;font-size:.74rem;font-weight:700}.stage-heading__track{text-transform:capitalize;color:var(--muted);letter-spacing:.12em;font-weight:500}.stage-heading__title{letter-spacing:-.01em;margin:0;font-size:clamp(1.8rem,2.6vw,2.6rem);line-height:1.1}.stage-heading__desc{color:#cbd3f3;max-width:640px;margin:4px 0 0;font-size:1.02rem}.stage-section__label{text-transform:uppercase;letter-spacing:.2em;color:var(--muted);margin:0 0 12px;font-size:.72rem;font-weight:700}.stage-body{gap:14px;max-width:720px;display:grid}.stage-body__p{color:#d6deff;max-width:720px;margin:0;font-size:1rem;line-height:1.7}.stage-body__p:first-letter{color:var(--muted)}.stage-keypoints{max-width:720px}.stage-keypoints__list{gap:10px;margin:0;padding:0;list-style:none;display:grid}.stage-keypoints__list li{color:#d6deff;border:1px solid var(--line);background:#081022a6;border-radius:14px;align-items:flex-start;gap:12px;padding:10px 14px;font-size:.95rem;display:flex}.stage-keypoints__dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:8px;box-shadow:0 0 10px}.js-compare{gap:12px;max-width:980px;display:grid}.js-compare__caption{color:var(--muted);letter-spacing:.04em;margin:0;font-size:.85rem}.js-compare__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.js-compare__panel{border:1px solid var(--line);background:#070d1cb8;border-radius:18px;gap:8px;padding:14px;display:grid}.js-compare__panel--js{border-color:#ffc74047}.js-compare__panel--ts{border-color:#4ac0ff47}.js-compare__tab{align-items:center;gap:10px;padding-bottom:4px;display:flex}.js-compare__chip{letter-spacing:.1em;border-radius:6px;place-items:center;padding:3px 8px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.7rem;font-weight:700;display:inline-grid}.js-compare__chip--js{color:#ffd479;background:#ffc7402e;border:1px solid #ffc74059}.js-compare__chip--ts{color:#7dd1ff;background:#4ac0ff2e;border:1px solid #4ac0ff59}.js-compare__title{color:var(--muted);font-size:.88rem}.js-compare .code-block{box-shadow:none}.js-compare .code-block__pre{padding:14px 14px 18px;font-size:.8rem}.code-block{background:var(--code-bg);border:1px solid #ffffff0f;border-radius:18px;max-width:820px;overflow:hidden;box-shadow:0 30px 80px -40px #0009}.code-block__chrome{border-bottom:1px solid var(--line);background:#ffffff08;align-items:center;gap:8px;padding:10px 14px;display:flex}.code-dot{border-radius:50%;width:10px;height:10px;display:inline-block}.code-dot--r{background:#ff5f57}.code-dot--y{background:#febc2e}.code-dot--g{background:#28c840}.code-block__file{color:var(--muted);margin-left:8px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem}.code-block__pre{white-space:pre;margin:0;padding:18px 18px 22px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.84rem;line-height:1.65;display:block;overflow-x:auto}.code-line{white-space:pre;grid-template-columns:28px 1fr;align-items:baseline;gap:12px;display:grid}.code-line__num{color:#8a9bcf8c;-webkit-user-select:none;user-select:none;text-align:right;font-size:.74rem}.code-line__text{white-space:pre}.tok-kw{color:var(--tok-kw);font-weight:600}.tok-type{color:var(--tok-type)}.tok-string{color:var(--tok-string)}.tok-num{color:var(--tok-num)}.tok-comment{color:var(--tok-comment);font-style:italic}.tok-cap{color:var(--tok-cap)}.tok-punct{color:var(--tok-punct)}.tok-op{color:var(--tok-op)}.quiz{border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0b1329c7;border-radius:20px;gap:14px;max-width:720px;padding:22px 24px;transition:box-shadow .22s;display:grid;position:relative}.quiz__label{text-transform:uppercase;letter-spacing:.2em;color:var(--muted);margin:0;font-size:.72rem;font-weight:700}.quiz__question{letter-spacing:-.01em;margin:0;font-size:1.1rem}.quiz__options{gap:8px;display:grid}.quiz-option{border:1px solid var(--line);color:inherit;font:inherit;cursor:pointer;text-align:left;background:#ffffff08;border-radius:14px;grid-template-columns:28px 1fr;align-items:center;gap:12px;padding:12px 14px;transition:transform .18s,background .18s,border-color .18s;display:grid}.quiz-option:hover:not(:disabled){background:#ffffff12;transform:translate(2px)}.quiz-option:disabled{cursor:not-allowed;opacity:.55}.quiz-option__bullet{background:#ffffff0f;border-radius:8px;place-items:center;width:26px;height:26px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.78rem;font-weight:600;display:grid}.quiz-option--selected{background:#6282ff29;border-color:#6282ff8c}.quiz-option--correct{background:#4ad6a82e;border-color:#4ad6a899}.quiz-option--wrong{background:#ff607a29;border-color:#ff607a8c}.quiz__feedback{align-items:center;gap:12px;padding-top:4px;font-size:.92rem;display:flex}.quiz__feedback.is-correct{color:#95edca}.quiz__feedback.is-wrong{color:#ffb1bf}.quiz__retry{color:inherit;font:inherit;cursor:pointer;background:0 0;border:1px solid #ffb1bf66;border-radius:999px;padding:6px 12px}.quiz__retry:hover{background:#ffb1bf14}.quiz__reset{color:#05101f;font:inherit;cursor:pointer;background:linear-gradient(135deg,#4ad6a8,#4ac0ff);border:0;border-radius:999px;padding:8px 14px;font-weight:700;transition:transform .18s,box-shadow .18s}.quiz__reset:hover{transform:translateY(-1px);box-shadow:0 14px 28px -14px #4ad6a8b3}.controls{border:1px solid var(--line);background:#0b13299e;border-radius:22px;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;display:flex}.controls__counter{color:var(--muted);letter-spacing:.1em;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem}.controls__divider{opacity:.5}.control-button{cursor:pointer;color:#fff;background:linear-gradient(135deg,#6b81ff 0%,#4ac0ff 100%);border:0;border-radius:999px;padding:12px 22px;font-size:.95rem;font-weight:600;transition:transform .18s,box-shadow .18s,opacity .18s}.control-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 35px -10px #4ac0ff73}.control-button:disabled{opacity:.4;cursor:not-allowed}.control-button--ghost{color:var(--text);background:#ffffff0f}.control-button--ghost:hover:not(:disabled){box-shadow:none;background:#ffffff1a}.bottom-dock{z-index:50;padding:10px 14px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--line);-webkit-backdrop-filter:blur(14px);background:#080e1eeb;align-items:center;gap:10px;display:none;position:fixed;bottom:0;left:0;right:0}.bottom-dock__button{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff14;border:0;border-radius:14px;flex-shrink:0;place-items:center;width:48px;height:48px;font-size:1.2rem;transition:opacity .18s,transform .12s;display:grid}.bottom-dock__button:disabled{opacity:.35;cursor:not-allowed}.bottom-dock__button:active:not(:disabled){transform:scale(.95)}.bottom-dock__button--ghost{background:#ffffff14}.bottom-dock__button--accent{color:#fff;box-shadow:0 8px 24px -10px #4ac0ff73}.bottom-dock__center{border:1px solid var(--line);color:inherit;font:inherit;text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff0a;border-radius:14px;flex:1;gap:2px;min-width:0;padding:8px 12px;display:grid}.bottom-dock__num{letter-spacing:.12em;color:var(--muted);font-family:JetBrains Mono,ui-monospace,monospace;font-size:.7rem}.bottom-dock__title{white-space:nowrap;text-overflow:ellipsis;font-size:.9rem;font-weight:600;overflow:hidden}.drawer{z-index:60;position:fixed;inset:0}.drawer__backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#02050fa6;position:absolute;inset:0}.drawer__panel{border-right:1px solid var(--line);width:min(380px,92vw);padding:22px 18px calc(22px + env(safe-area-inset-bottom));padding-left:max(18px, env(safe-area-inset-left));background:linear-gradient(#0c1832 0%,#060c1f 100%);grid-template-rows:auto auto 1fr;gap:14px;display:grid;position:absolute;top:0;bottom:0;left:0;box-shadow:30px 0 80px -20px #000000b3}.drawer__head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.drawer__title{margin:6px 0 0;font-size:1.4rem;font-weight:600}.drawer__close{border:1px solid var(--line);width:40px;height:40px;color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff0a;border-radius:12px;font-size:1rem}.drawer__progress{gap:6px;display:grid}.drawer__progress .progress-meter__bar{width:100%}.drawer__progress .progress-meter__label{color:var(--muted);font-size:.78rem}.drawer__list{-webkit-overflow-scrolling:touch;gap:22px;padding:4px 4px 12px 0;display:grid;overflow-y:auto}.tryit{border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0b1329c7;border-radius:20px;gap:14px;max-width:820px;padding:22px 24px;transition:box-shadow .22s;display:grid;position:relative}.tryit__head{gap:4px;display:grid}.tryit__label{text-transform:uppercase;letter-spacing:.2em;color:var(--muted);margin:0;font-size:.72rem;font-weight:700}.tryit__prompt{color:var(--text);max-width:none;margin:0;font-size:1rem;line-height:1.55}.tryit__editor-wrap{background:var(--code-bg);border:1px solid #ffffff0f;border-radius:14px;overflow:hidden}.tryit__chrome{border-bottom:1px solid var(--line);background:#ffffff08;align-items:center;gap:8px;padding:10px 14px;display:flex}.tryit__filename{color:var(--muted);margin-left:8px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.76rem}.tryit__editor{color:#eef2ff;resize:vertical;tab-size:2;white-space:pre;caret-color:#4ac0ff;background:0 0;border:0;outline:none;width:100%;min-height:110px;padding:14px 16px;font-family:JetBrains Mono,ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.86rem;line-height:1.65;display:block;overflow-x:auto}.tryit__editor:focus{background:#4ac0ff0a}.tryit__editor::placeholder{color:var(--muted-2)}.tryit__editor::selection{background:#4ac0ff47}.tryit__actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.tryit__compile{color:#042a1f;cursor:pointer;font-weight:700;font:inherit;letter-spacing:.02em;-webkit-tap-highlight-color:transparent;background:linear-gradient(135deg,#4ad6a8 0%,#4ac0ff 100%);border:0;border-radius:999px;padding:10px 18px;font-size:.9rem;transition:transform .16s,box-shadow .16s}.tryit__compile:hover{transform:translateY(-1px);box-shadow:0 16px 32px -14px #4ad6a88c}.tryit__compile:active{transform:translateY(0)}.tryit__btn{border:1px solid var(--line);color:var(--text);font:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#ffffff0a;border-radius:999px;padding:9px 16px;font-size:.86rem;transition:background .16s,border-color .16s}.tryit__btn:hover{background:#ffffff14}.tryit__btn--ghost{color:#ffb1bf;border-color:#ffb1bf59}.tryit__btn--ghost:hover{background:#ffb1bf14}.tryit__shortcut{border:1px solid var(--line);color:var(--muted);background:#ffffff0a;border-radius:8px;margin-left:auto;padding:4px 10px;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.75rem}.tryit__hint{color:#ffd479;background:#ffc74014;border:1px solid #ffc74040;border-radius:12px;gap:10px;padding:10px 14px;font-size:.92rem;line-height:1.55;display:flex}.tryit__hint-icon{flex-shrink:0}.tryit__output{border:1px solid var(--line);border-radius:14px;padding:14px 16px;font-size:.94rem}.tryit__output.is-ok{color:#95edca;background:#4ad6a81a;border-color:#4ad6a866}.tryit__output.is-error{color:#ffb1bf;background:#ff607a14;border-color:#ff607a66}.tryit__output-title{letter-spacing:.02em;margin:0 0 6px;font-family:JetBrains Mono,ui-monospace,monospace;font-weight:700}.tryit__output-text{color:inherit;max-width:none;margin:0;font-size:.92rem;line-height:1.55}.tryit__output-list{gap:4px;margin:4px 0 0;padding:0;font-size:.86rem;list-style:none;display:grid}.tryit__check{width:14px;font-weight:700;display:inline-block}.tryit__output-progress{opacity:.85;margin:8px 0 0;font-family:JetBrains Mono,ui-monospace,monospace;font-size:.84rem}@media (max-width:1100px){.js-compare__grid{grid-template-columns:1fr}}@media (max-width:980px){.course-panel{grid-template-columns:minmax(0,1fr)}.lesson-list--desktop,.controls--desktop{display:none}.bottom-dock{display:flex}.course-header__lessons-btn{display:inline-flex}.hero__hint{display:none}.stage-panel{max-height:none}.stage-content{margin-top:-72px;padding:0 24px 32px}.lesson-scene{height:280px;position:relative}.stage-overlay{height:280px}.course-header{flex-wrap:wrap;gap:14px 16px}.course-header__main{flex:1;min-width:0}.progress-meter{flex-basis:100%;align-items:stretch;width:100%}.progress-meter__bar{width:100%}.progress-meter{align-items:flex-start}main{padding-bottom:calc(120px + env(safe-area-inset-bottom))}}@media (max-width:600px){main{padding:32px 18px 0;padding-bottom:calc(110px + env(safe-area-inset-bottom))}.hero{margin-bottom:36px}h1{font-size:clamp(2rem,8vw,3rem)}.hero p{font-size:.95rem}.course-header{border-radius:18px;padding:16px 18px}.course-header__title{font-size:1.2rem}.stage-panel{border-radius:22px}.stage-content{gap:22px;margin-top:-56px;padding:0 16px 24px}.stage-heading__title{font-size:1.6rem}.stage-heading__desc{font-size:.94rem}.stage-body__p{font-size:.95rem;line-height:1.65}.lesson-scene,.stage-overlay{height:220px}.code-block{border-radius:14px}.code-block__chrome{padding:8px 12px}.code-block__pre{padding:14px 12px 16px;font-size:.78rem;line-height:1.55}.code-line{grid-template-columns:22px 1fr;gap:10px}.code-line__num{font-size:.68rem}.js-compare__panel{border-radius:14px;padding:12px}.quiz{border-radius:16px;padding:18px}.quiz__question{font-size:1rem}.quiz-option{padding:12px}.tryit{border-radius:16px;padding:18px}.tryit__editor{min-height:90px;padding:12px;font-size:.78rem}.tryit__chrome{padding:8px 12px}.tryit__compile{padding:10px 16px;font-size:.86rem}.tryit__btn{padding:8px 14px;font-size:.82rem}.tryit__shortcut{display:none}.stage-keypoints__list li{padding:10px 12px;font-size:.92rem}.bottom-dock__center{padding:6px 10px}.bottom-dock__title{font-size:.85rem}}@media (max-width:380px){.course-header__lessons-count{display:none}.bottom-dock__button{width:44px;height:44px}}
