@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_5901b7c6-module__ec5Qua__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_5901b7c6-module__ec5Qua__variable{--font-inter:"Inter", "Inter Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.0s19wthhh_6~m.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.0dza.stei.9v7.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.03nf~dfjdkf~..woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.0gfhww.tctz1o.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.09q3q1i5159bl.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.1409xf.ylxg8g.woff2?dpl=dpl_8o32Pi5LGUqkRLGdvECypsfaYZR5)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_d5591ac2-module__D88TVW__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_d5591ac2-module__D88TVW__variable{--font-mono:"JetBrains Mono", "JetBrains Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.fixed{position:fixed}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.italic{font-style:italic}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}.course-page{color:#222;background:#fff;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.top-bar{z-index:240;pointer-events:none;background:#fff;border-bottom:1px solid #eee;height:56px;transition:transform .3s,opacity .3s;position:fixed;top:0;left:0;right:0}.top-bar.visible,.top-bar-title.visible,.home-btn.visible,.menu-btn.visible{opacity:1;transform:translateY(0)}.top-bar.hidden,.top-bar-title.hidden,.home-btn.hidden,.menu-btn.hidden{opacity:0;transform:translateY(-100%)}.top-bar-title{z-index:241;color:#2563eb;text-transform:uppercase;letter-spacing:1px;pointer-events:none;justify-content:center;align-items:center;height:56px;font-size:18px;font-weight:600;transition:transform .3s,opacity .3s;display:flex;position:fixed;top:0;left:0;right:0}.home-btn{z-index:250;color:#999;cursor:pointer;justify-content:center;align-items:center;width:34px;height:56px;text-decoration:none;transition:transform .3s,opacity .3s,color .2s;display:flex;position:fixed;top:0;left:12px}.home-btn:hover{color:#333}.menu-btn{z-index:250;color:#999;cursor:pointer;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;width:44px;height:56px;transition:transform .3s,opacity .3s,color .2s;display:flex;position:fixed;top:0;left:42px}.menu-btn:hover{color:#333}.menu-icon{flex-direction:column;justify-content:space-between;width:22px;height:16px;display:flex;position:relative}.menu-line{transform-origin:50%;background:currentColor;border-radius:1px;width:100%;height:2px;transition:transform .25s,opacity .25s;display:block}.menu-btn.is-open .menu-line-1{transform:translateY(7px)rotate(45deg)}.menu-btn.is-open .menu-line-2{opacity:0}.menu-btn.is-open .menu-line-3{transform:translateY(-7px)rotate(-45deg)}.course-main{margin-left:0;padding-top:56px;transition:margin-left .2s}.course-content{max-width:720px;margin:0 auto;padding:48px 24px}.step-header-section{margin-bottom:36px}.step-label{text-transform:uppercase;letter-spacing:.5px;color:#2563eb;margin-bottom:10px;font-size:14px;font-weight:600;display:inline-block}.step-header-section h1{color:#222;margin:0;font-size:32px;font-weight:600;line-height:1.2}.step-body{line-height:1.7}.step-footer{border-top:1px solid #eee;align-items:center;margin-top:56px;padding-top:28px;display:flex}.footer-spacer{flex:1}.footer-btn{color:#444;cursor:pointer;background:0 0;border:1px solid #ddd;border-radius:6px;padding:12px 24px;font-size:15px;font-weight:500;transition:all .15s}.footer-btn:hover{color:#2563eb;border-color:#2563eb}.footer-btn.next{color:#fff;background:#2563eb;border-color:#2563eb}.footer-btn.next:hover{background:#1d4ed8}@media (max-width:640px){.course-content{padding:32px 16px}.step-header-section h1{font-size:26px}.nav-arrow{width:32px;height:32px}}.step-loader{padding:20px 0}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%) 0 0/200% 100%;border-radius:6px;animation:1.5s infinite skeleton-shimmer}.skeleton-title{width:40%;height:24px;margin-bottom:24px}.skeleton-text{width:100%;height:18px;margin-bottom:12px}.skeleton-text.short{width:70%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes spin{to{transform:rotate(360deg)}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:#222;-webkit-font-smoothing:antialiased;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:18px;line-height:1.7}h1,h2,h3,h4,h5,h6{color:#222;font-weight:600;line-height:1.3}h1{font-size:32px}h2{color:#222;margin-bottom:14px;font-size:24px}h3{margin-bottom:12px;font-size:20px}p{color:#444;margin-bottom:16px;font-size:18px}strong{color:#222;font-weight:600}code{color:#d63384;background:#f5f5f5;border-radius:4px;padding:2px 6px;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:.9em}pre{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin:16px 0;padding:16px;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6;overflow-x:auto}pre code{color:#374151;background:0 0;padding:0}ul,ol{margin:16px 0;padding-left:0;list-style:none}li{color:#444;margin:8px 0;padding-left:0;font-size:18px}.content-section{margin-bottom:36px}.content-section h2{color:#222;margin-bottom:14px;font-size:22px;font-weight:600}.content-section p:last-child{margin-bottom:0}.task-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.task-section h2{color:#2563eb}.math-formula{text-align:center;color:#222;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin:28px 0;padding:24px;font-family:Times New Roman,Georgia,serif;font-size:20px}.math-label{color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-family:-apple-system,sans-serif;font-size:11px}.calc-step{color:#444;align-items:center;gap:14px;padding:10px 0;font-family:SF Mono,monospace;font-size:16px;display:flex}.calc-step-number{color:#fff;background:#2563eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:14px;font-weight:600;display:flex}.hint-box{background:#fffbeb;border:1px solid #fcd34d;border-radius:8px;margin:20px 0;padding:14px 18px}.hint-box summary{cursor:pointer;color:#b45309;align-items:center;gap:8px;font-weight:500;list-style:none;display:flex}.hint-box summary::-webkit-details-marker{display:none}.hint-box[open] summary{margin-bottom:12px}.run-code-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;align-items:center;gap:8px;margin:16px 0;padding:10px 18px;font-size:15px;font-weight:500;transition:background .15s;display:inline-flex}.run-code-btn:hover{background:#1d4ed8}.code-runner-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.code-runner-modal{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:800px;max-height:80vh;display:flex;box-shadow:0 20px 60px #0000004d}.code-runner-header{color:#222;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:14px 18px;font-size:15px;font-weight:600;display:flex}.code-runner-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px}.code-runner-close:hover{color:#111;background:#f3f4f6}.code-runner-body{flex:1;min-height:300px;display:flex;overflow:hidden}.code-runner-editor{border-right:1px solid #e5e7eb;flex:1;display:flex}.code-runner-editor textarea{resize:none;color:#374151;background:#fff;border:none;outline:none;width:100%;padding:16px;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6}.code-runner-output{background:#f9fafb;flex-direction:column;width:300px;display:flex}.code-runner-output-label{color:#6b7280;border-bottom:1px solid #e5e7eb;padding:10px 14px;font-size:13px;font-weight:600}.code-runner-output pre{color:#374151;white-space:pre-wrap;background:0 0;border:none;flex:1;margin:0;padding:14px;font-family:SF Mono,monospace;font-size:13px;line-height:1.5;overflow:auto}.code-runner-footer{border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.code-runner-reset{color:#374151;cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500}.code-runner-reset:hover{background:#e5e7eb}.code-runner-run{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 18px;font-size:14px;font-weight:500;display:inline-flex}.code-runner-run:hover{background:#16a34a}@media (max-width:640px){.code-runner-body{flex-direction:column}.code-runner-editor{border-bottom:1px solid #e5e7eb;border-right:none}.code-runner-output{width:100%;max-height:150px}}.sidebar-overlay{z-index:199;background:#0006;position:fixed;inset:0}.course-sidebar{z-index:200;background:#fff;border-right:1px solid #eee;flex-direction:column;width:320px;transition:transform .25s;display:flex;position:fixed;top:57px;bottom:0;left:0;overflow:hidden;transform:translate(-100%)}.course-sidebar.open{transform:translate(0)}.sidebar-drag-handle{cursor:col-resize;z-index:210;width:6px;height:100%;transition:background .15s;position:absolute;top:0;right:-3px}.sidebar-drag-handle:hover{background:#2563eb26}.sidebar-title{color:#222;margin:0;font-size:16px;font-weight:600}.sidebar-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.sidebar-close:hover{color:#222;background:#f3f4f6}.sidebar-progress{border-bottom:1px solid #e5e7eb;flex-shrink:0;padding:16px 20px}.sidebar-progress-text{color:#666;justify-content:space-between;margin-bottom:8px;font-size:13px;font-weight:500;display:flex}.sidebar-progress-bar{background:#e5e7eb;border-radius:3px;height:6px;overflow:hidden}.sidebar-progress-fill{background:#2563eb;border-radius:3px;height:100%;transition:width .3s}.sidebar-sections{overscroll-behavior:contain;flex:1;overflow-y:auto}.sidebar-section{border-bottom:1px solid #f3f4f6}.sidebar-section-header{cursor:pointer;text-align:left;background:#f9fafb;border:none;justify-content:space-between;align-items:center;width:100%;padding:14px 20px;transition:background .15s;display:flex}.sidebar-section-header:hover{background:#f3f4f6}.sidebar-section-left{align-items:center;gap:8px;display:flex}.sidebar-chevron{color:#9ca3af;flex-shrink:0;transition:transform .2s}.sidebar-chevron.expanded{transform:rotate(90deg)}.sidebar-section-name{color:#222;font-size:14px;font-weight:600}.sidebar-section-count{color:#9ca3af;font-size:12px;font-weight:500}.sidebar-lessons{padding:4px 0}.sidebar-lesson{align-items:center;gap:10px;padding:8px 20px 8px 28px;transition:background .15s;display:flex}.sidebar-lesson:hover{background:#f9fafb}.sidebar-lesson.active{background:#eff6ff}.sidebar-lesson.active .sidebar-lesson-link{color:#2563eb;font-weight:500}.sidebar-lesson.completed .sidebar-lesson-link{color:#9ca3af}.sidebar-lesson-check{cursor:pointer;background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.sidebar-lesson-link{cursor:pointer;text-align:left;color:#374151;background:0 0;border:none;flex:1;padding:0;font-size:14px;line-height:1.4}.sidebar-lesson-link:hover{color:#2563eb}.sidebar-cert-section{align-items:center;gap:12px;padding:16px 20px;display:flex}.sidebar-cert-section.locked{opacity:.5}.sidebar-cert-icon{flex-shrink:0}.sidebar-cert-text{flex-direction:column;flex:1;gap:2px;display:flex}.sidebar-cert-title{color:#222;font-size:14px;font-weight:600}.sidebar-cert-desc{color:#888;font-size:12px}.sidebar-cert-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:6px;flex-shrink:0;padding:6px 14px;font-size:13px;font-weight:600}.sidebar-cert-btn:hover{background:#16a34a}@media (max-width:768px){.course-main{margin-left:0!important}.course-sidebar.open{box-shadow:none;width:100%!important}.sidebar-drag-handle{display:none}}@media (max-width:640px){.course-sidebar.open{width:100%!important}}.cert-overlay{z-index:300;background:#0009;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.cert-modal{width:100%;max-width:620px}.cert-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.cert-border{text-align:center;border:3px solid #2563eb;border-radius:8px;margin:16px;padding:40px 32px}.cert-accent-top,.cert-accent-bottom{background:linear-gradient(90deg,#0000,#2563eb,#0000);width:60%;height:3px;margin:24px auto}.cert-heading{letter-spacing:4px;color:#2563eb;margin-bottom:16px;font-size:13px;font-weight:600}.cert-course-name{color:#222;margin-bottom:8px;font-size:32px;font-weight:600}.cert-subtitle{color:#666;margin-bottom:24px;font-size:16px}.cert-congrats{color:#555;max-width:440px;margin:0 auto;font-size:15px;line-height:1.6}.cert-brand{color:#2563eb;margin-top:8px;font-size:13px;font-weight:600}.cert-actions{gap:12px;margin-top:16px;display:flex}.cert-download-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;flex:1;padding:12px 24px;font-size:15px;font-weight:600;transition:background .15s}.cert-download-btn:hover{background:#1d4ed8}.cert-close-btn{color:#666;cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:12px 24px;font-size:15px;font-weight:500}.cert-close-btn:hover{background:#f9fafb}.dot{border-radius:50%;width:12px;height:12px}.dot.red{background:#ff5f57}.dot.yellow{background:#febc2e}.dot.green{background:#28c840}.code-editor-modal-overlay{z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.code-editor-modal{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:900px;max-height:85vh;display:flex;box-shadow:0 20px 60px #0000004d}.modal-header{background:#f3f4f6;border-bottom:1px solid #e5e7eb;border-radius:12px 12px 0 0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.modal-title{align-items:center;gap:8px;display:flex}.modal-title span{color:#6b7280;margin-left:8px;font-family:SF Mono,monospace;font-size:13px}.modal-close{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:6px}.modal-close:hover{color:#111;background:#e5e7eb}.modal-editor-container{flex:1;display:flex;overflow:hidden}.modal-editor{flex-direction:column;flex:1;display:flex}.modal-editor textarea{color:#374151;resize:none;background:#fff;border:none;outline:none;flex:1;width:100%;padding:16px;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6}.modal-editor textarea::placeholder{color:#9ca3af}.modal-output-container{background:#fafafa;border-left:1px solid #eee;flex-direction:column;width:320px;display:flex}.modal-output-header{color:#666;border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:12px 14px;font-size:13px;font-weight:600;display:flex}.output-status{border-radius:4px;padding:3px 8px;font-size:11px;font-weight:500}.output-status.success{color:#fff;background:#22c55e}.output-status.error{color:#fff;background:#ef4444}.modal-output{color:#666;white-space:pre-wrap;border:2px solid #0000;flex:1;padding:14px;font-family:SF Mono,monospace;font-size:13px;line-height:1.5;overflow-y:auto}.modal-output.success{border-color:#22c55e}.modal-output.error{border-color:#ef4444}.modal-footer{background:#fff;border-top:1px solid #eee;border-radius:0 0 12px 12px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.modal-footer-right{align-items:center;gap:12px;display:flex}.success-text{color:#22c55e;align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.btn{cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:10px 18px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-secondary{color:#444;background:#f5f5f5;border:1px solid #ddd}.btn-secondary:hover{background:#eee}.btn-success{color:#fff;background:#22c55e}.btn-success:hover{background:#16a34a}.btn:disabled{opacity:.5;cursor:not-allowed}table{border-collapse:collapse;background:#fff;border:1px solid #e5e7eb;border-radius:8px;width:100%;margin:20px 0;overflow:hidden}th,td{text-align:center;padding:12px 16px}th{color:#222;background:#f9fafb;font-size:13px;font-weight:600}td{border-top:1px solid #e5e7eb;font-family:SF Mono,monospace;font-size:14px}tr:hover td{background:#f9fafb}@media (max-width:640px){.btn{padding:8px 14px;font-size:13px}.modal-editor-container{flex-direction:column}.modal-output-container{border-top:1px solid #eee;border-left:none;width:100%;max-height:180px}.code-editor-modal{max-height:90vh;margin:12px}}.code-runner-inline{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin:20px 0;overflow:hidden}.code-editor-container{background:#1e1e2e;border-bottom:1px solid #313244;display:flex}.code-line-numbers{color:#6c7086;text-align:right;-webkit-user-select:none;user-select:none;background:#181825;min-width:45px;padding:16px 0;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6}.line-number{padding:0 12px}.code-editor{color:#cdd6f4;resize:none;background:#1e1e2e;border:none;outline:none;flex:1;min-height:120px;padding:16px;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6}.code-editor::placeholder{color:#6c7086}.code-actions{background:#f9fafb;border-bottom:1px solid #e5e7eb;align-items:center;gap:10px;padding:12px 16px;display:flex}.run-btn{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background .15s;display:inline-flex}.run-btn:hover{background:#16a34a}.reset-btn{color:#6b7280;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 14px;font-size:14px;font-weight:500;transition:all .15s}.reset-btn:hover{color:#374151;background:#f3f4f6}.code-output{background:#f9fafb}.code-output .output-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e5e7eb;padding:10px 16px;font-size:12px;font-weight:600}.code-output pre{color:#22c55e;white-space:pre-wrap;background:0 0;border:none;margin:0;padding:16px;font-family:SF Mono,Fira Code,monospace;font-size:14px;line-height:1.6}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
