@font-face{font-family:Instrument Serif;font-style:italic;font-weight:400;font-display:swap;src:url(../media/fc0a7394b875fa43-s.614a1c00.woff2)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:Instrument Serif;font-style:italic;font-weight:400;font-display:swap;src:url(../media/7ebf22b5a21034f8-s.p.d8bad3ab.woff2)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:Instrument Serif;font-style:normal;font-weight:400;font-display:swap;src:url(../media/ccf27e5a7366fb23-s.262b87c4.woff2)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:Instrument Serif;font-style:normal;font-weight:400;font-display:swap;src:url(../media/e41d5df559864f9e-s.p.380d09ea.woff2)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:Instrument Serif Fallback;src:local(Times New Roman);ascent-override:117.94%;descent-override:36.93%;line-gap-override:0.0%;size-adjust:83.94%}.instrument_serif_70e6440a-module__QkCMAq__className{font-family:Instrument Serif,Instrument Serif Fallback;font-weight:400}.instrument_serif_70e6440a-module__QkCMAq__variable{--font-serif:"Instrument Serif","Instrument Serif Fallback"}
@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)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.18a48cbc.woff2)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.7a40eb73.woff2)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.c995e352.woff2)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.76dcb0b2.woff2)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.7cd81963.woff2)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.3a6ba036.woff2)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_5ad0e339-module__xe74na__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_5ad0e339-module__xe74na__variable{--font-sans:"Inter","Inter 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-serif:ui-serif,Georgia,Cambria,"Times New Roman",Times,serif;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--radius-sm:.25rem;--radius-md:.375rem;--ease-out:cubic-bezier(0,0,.2,1);--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}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.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}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.flex-shrink{flex-shrink: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}.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}.invert{--tw-invert:invert(100%);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,)}.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))}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#fafaf8;--text:#1a1a1a;--text-muted:#6b6b6b;--accent:#7a5c0e;--border:#e5e5e0;--surface:#f0efe8;--selection-bg:#7a5c0e;--selection-text:#fafaf8;--fg-1:var(--text);--fg-2:var(--text-muted);--fg-accent:var(--accent);--learning-correct:#46a758;--learning-incorrect:#e5484d;--learning-hint:#d4a62a;--learning-info:#7a5c0e;--learning-progress-done:var(--learning-correct);--learning-progress-current:var(--learning-info);--learning-progress-pending:var(--text-muted);--learning-surface:var(--surface);--learning-border:var(--border);--learning-rail-bg:var(--bg);--learning-rail-border:var(--border);--learning-shell-header-bg:var(--bg)}@supports (color:color-mix(in lab, red, red)){:root{--learning-shell-header-bg:color-mix(in srgb,var(--bg)80%,transparent)}}:root{--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--measure-prose:620px;--measure-wide:1060px;--radius-sm:3px;--radius-md:4px;--hairline:1px solid var(--border);--ease-out:cubic-bezier(.2,.6,.2,1);--dur-fast:.15s;--dur-base:.2s;--dur-slow:.8s;--text-xs:.6875rem;--text-sm:.875rem;--text-base:1rem;--text-body:1.125rem;--text-prose:1.0625rem;--text-essay:1.3125rem;--text-page:2.25rem;--text-hero:2.5rem;--serif:var(--font-serif),Georgia,"Times New Roman",serif;--sans:var(--font-sans),-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:var(--text-body);line-height:1.65}h1,h2,h3,h4{font-family:var(--serif);letter-spacing:-.01em;font-weight:400;line-height:1.2}h1{font-size:var(--text-page);letter-spacing:-.02em;line-height:1.15}h2{margin-top:3.5rem;margin-bottom:1rem;font-size:1.5rem}h3{margin-top:2.5rem;margin-bottom:.75rem;font-size:1.25rem}p{margin-bottom:1.375rem;line-height:1.72}a{color:inherit;text-decoration:none;transition:color .15s}a:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:2px}.quick-check-option:focus-visible,.quick-check-input:focus-visible,.quick-check-btn:focus-visible,.code-playground-btn:focus-visible,.code-playground-run-btn:focus-visible,.code-playground-editor:focus-visible,.mistake-analyzer-option:focus-visible,.confidence-rating-option:focus-visible,.hint-ladder-reveal:focus-visible,.worked-example-toggle:focus-visible,.worked-example-reveal:focus-visible,.glossary-popover-trigger:focus-visible,.glossary-popover-action:focus-visible,.live-output-panel-copy:focus-visible,.live-output-panel-explain-toggle:focus-visible,.checkpoint-card-check-btn:focus-visible,.concept-map-node:focus-visible,.concept-explorer-hotspot:focus-visible,.timeline-explorer-dot:focus-visible,.timeline-explorer-scrubber:focus-visible,.parameter-dock-preset:focus-visible,.parameter-dock-share:focus-visible,.parameter-dock-reset:focus-visible,.snippet-copy-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}@media (prefers-reduced-motion:reduce){a,.progress-rail-lesson,.quick-check-option,.quick-check-input,.quick-check-btn{transition:none}.quick-check-feedback{animation:none}.code-playground-btn{transition:none}.lesson-shell-rail{transition:none!important}.concept-map-node,.concept-explorer-hotspot,.timeline-explorer-dot,.parameter-dock-toggle,.parameter-dock-toggle:after,.parameter-dock-preset,.parameter-dock-share,.parameter-dock-reset,.mistake-analyzer-option,.confidence-rating-option,.hint-ladder-reveal,.worked-example-toggle,.worked-example-reveal,.glossary-popover-trigger,.glossary-popover-action,.live-output-panel-copy,.live-output-panel-explain-toggle,.course-progress-indicator-fill,.lesson-shell-overlay,.folio-progress-fill{transition:none}}.folio-stick{z-index:20;background:var(--bg);position:sticky;top:0}.folio-header{font-family:var(--sans)}.folio-inner{align-items:center;gap:var(--space-5);max-width:var(--measure-wide);padding:var(--space-2)var(--space-6)var(--space-2);grid-template-columns:minmax(max-content,1fr) minmax(0,2fr) minmax(max-content,1fr);min-height:44px;margin:0 auto;display:grid}.folio-name{justify-self:start;text-decoration:none;display:inline-flex}.folio-name span{color:var(--text-muted);font-size:14px}.folio-name:hover span{color:var(--accent)}.folio-center{text-align:center;justify-self:stretch;width:100%;min-width:0;max-width:100%;overflow:hidden}.folio-tagline{font-family:var(--serif);color:var(--text-muted);font-size:13px;font-style:italic}.folio-where{text-align:center;display:block}.folio-where-title{font-family:var(--sans);color:var(--text);letter-spacing:-.005em;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:12.5px;line-height:1.2;display:block;overflow:hidden}.folio-where-eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);font-size:9px;display:block}.folio-nav{justify-self:end;align-items:center;gap:var(--space-5);display:flex}.folio-link{color:var(--text-muted);transition:color var(--dur-base)ease;font-size:11.5px;text-decoration:none}.folio-link:hover,.folio-link-active{color:var(--text)}.folio-menu-btn{display:none}@media (max-width:767px){.folio-menu-btn{border:1px solid var(--border);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:color var(--dur-base)ease,border-color var(--dur-base)ease;background:0 0;justify-content:center;align-items:center;padding:0;display:inline-flex}.folio-menu-btn:hover{color:var(--text);border-color:var(--text-muted)}.folio-inner{padding:var(--space-2)var(--space-4);grid-template-columns:max-content 1fr max-content}.folio-center,.folio-link{display:none}}@media (min-width:768px){.folio-menu-btn{display:none!important}.folio-link{display:inline}.folio-center{text-align:center}}.mobile-nav-overlay{z-index:40;transition:opacity var(--dur-base)ease;background:#00000059;position:fixed;inset:0}.mobile-nav-drawer{background:var(--bg);border-left:1px solid var(--border);z-index:50;width:280px;max-width:85vw;transition:transform var(--dur-base)var(--ease-out);padding:var(--space-6);gap:var(--space-6);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.mobile-nav-drawer-open{transform:translate(0)}.mobile-nav-header{padding-bottom:var(--space-4);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.mobile-nav-close{width:28px;height:28px;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--dur-base)ease;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.mobile-nav-close:hover{color:var(--text)}.mobile-nav-links{gap:var(--space-2);flex-direction:column;display:flex}.mobile-nav-link{padding:var(--space-3)0;font-size:var(--text-base);color:var(--text);border-bottom:1px solid var(--border);transition:color var(--dur-base)ease;text-decoration:none}.mobile-nav-link:hover,.mobile-nav-link-active{color:var(--accent)}.mobile-nav-divider{background:var(--border);height:1px;margin:var(--space-4)0}.mobile-nav-contextual{flex:1;min-height:0;overflow-y:auto}.folio-progress-track{background:var(--border);width:100%;height:2px;position:relative}.folio-progress-track.folio-progress-home{background:var(--accent);opacity:.4}.folio-progress-fill{background:var(--accent);transition:width var(--dur-base)ease;position:absolute;top:0;bottom:0;left:0}::selection{background:var(--selection-bg);color:var(--selection-text)}.site-main{max-width:var(--measure-prose);padding:var(--space-12)var(--space-6)var(--space-16);margin:0 auto}.site-header{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:1px solid var(--border)}.site-title{font-family:var(--serif);font-size:var(--text-hero);letter-spacing:-.02em;margin:0;font-weight:400;line-height:1.1}.site-tagline{font-family:var(--sans);text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted);margin-top:.625rem;font-size:.75rem}.essay-list{list-style:none}.essay-entry{align-items:center;gap:0 var(--space-6);padding:var(--space-5)0;grid-template-columns:1fr auto;display:grid}.essay-entry+.essay-entry{border-top:1px solid var(--border)}.essay-link{display:contents}.essay-entry:hover .essay-title{color:var(--accent)}.essay-title-row{display:contents}.essay-title{font-family:var(--serif);font-size:var(--text-essay);transition:color var(--dur-base)ease;font-weight:400;line-height:1.35}.essay-description{font-size:var(--text-sm);color:var(--text-muted);grid-column:1/-1;margin-top:.25rem;line-height:1.5}.essay-date{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.03em;color:var(--text-muted);white-space:nowrap;text-align:right}.essay-empty{color:var(--text-muted);font-size:var(--text-base);font-style:italic}.article-header{margin-bottom:var(--space-16)}.article-title{font-family:var(--serif);font-size:var(--text-page);letter-spacing:-.02em;margin-bottom:.875rem;font-weight:400;line-height:1.15}.article-header .essay-date{letter-spacing:.02em;font-size:.8125rem;line-height:1}.article-meta{align-items:center;gap:var(--space-4);display:flex}.learn-with{align-items:center;gap:var(--space-2);display:inline-flex}.learn-with-label{font-family:var(--sans);color:var(--text-muted);letter-spacing:.02em;font-size:.8125rem;line-height:1}.learn-with-link{align-items:center;line-height:0;transition:opacity .2s;display:inline-flex}.learn-with-logo{width:16px;height:16px;display:block}.learn-with-claude{color:#d97757;opacity:.4}.learn-with-claude:hover{opacity:1}.learn-with-chatgpt{color:#10a37f;opacity:.4}.learn-with-chatgpt:hover{opacity:1}.learn-with-gemini{color:#4285f4;opacity:.4}.learn-with-gemini:hover{opacity:1}.breadcrumb{margin-bottom:var(--space-6)}.breadcrumb-list{flex-wrap:wrap;align-items:baseline;gap:0;list-style:none;display:flex}.breadcrumb-item{align-items:baseline;display:flex}.breadcrumb-sep{font-family:var(--sans);color:var(--text-muted);opacity:.5;margin:0 .5em;font-size:.75rem}.breadcrumb-link{font-family:var(--sans);color:var(--text-muted);padding:var(--space-1)0;font-size:.75rem}.breadcrumb-link:hover{color:var(--text)}.breadcrumb-current{font-family:var(--sans);color:var(--text);font-size:.75rem}.breadcrumb-item-current{display:none}.rss-link{font-family:var(--sans);color:var(--text-muted);font-size:.75rem}.rss-link:hover{color:var(--text)}.essay-toc{margin-bottom:var(--space-4)}.essay-toc-trigger{align-items:center;gap:var(--space-2);cursor:pointer;font-family:var(--sans);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:0 0;border:none;padding:0;font-size:.6875rem;transition:color .2s;display:inline-flex}.essay-toc-trigger:hover{color:var(--text)}.essay-toc-chevron{flex-shrink:0;transition:transform .2s}.essay-toc-chevron-open{transform:rotate(180deg)}.essay-toc-nav{padding:var(--space-3)0 var(--space-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-top:var(--space-2)}.essay-toc-list{list-style:none}.essay-toc-link{padding:var(--space-2)var(--space-3);font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);border-radius:4px;line-height:1.4;transition:color .2s;display:block}.essay-toc-link:hover{color:var(--text)}.content-nav{margin-top:var(--space-12);padding-top:var(--space-6);border-top:1px solid var(--border)}.content-nav-inner{justify-content:space-between;align-items:start;gap:var(--space-4);display:flex}.content-nav-prev,.content-nav-next{min-width:0}.content-nav-next{text-align:right;margin-left:auto}.content-nav-link{align-items:center;gap:var(--space-2);display:inline-flex}.content-nav-title{font-family:var(--serif);color:var(--text);font-size:1rem;font-weight:400;transition:color .2s}.content-nav-link:hover .content-nav-title{color:var(--accent)}.prose{font-size:var(--text-prose)}.prose p{margin-bottom:1.375rem;line-height:1.72}.prose h2{font-family:var(--serif);letter-spacing:-.01em;margin-top:3.5rem;margin-bottom:1rem;font-size:1.5rem;font-weight:400}.prose h3{font-family:var(--serif);margin-top:2.5rem;margin-bottom:.75rem;font-size:1.25rem;font-weight:400}.prose blockquote{border-left:2px solid var(--accent);color:var(--text-muted);font-style:italic;font-family:var(--serif);font-size:var(--text-prose);letter-spacing:.02em;margin:2.5rem 0;padding-left:1.5rem;line-height:1.75}.prose code{background:var(--surface);border-radius:3px;padding:.125rem .375rem;font-size:.85em}.prose pre{background:var(--surface);border-radius:4px;margin:1.75rem 0;padding:1.25rem;overflow-x:auto}.prose pre code{background:0 0;padding:0}.prose a{color:var(--accent);text-underline-offset:3px;text-decoration:underline;text-decoration-thickness:1px}.prose a:hover{text-decoration-thickness:2px}.prose ul{margin-bottom:1.5rem;padding-left:1.5rem;list-style-type:disc!important}.prose ol{margin-bottom:1.5rem;padding-left:1.5rem;list-style-type:decimal!important}.prose li{margin-bottom:.5rem;line-height:1.65;display:list-item}.prose hr{border:none;border-top:1px solid var(--border);margin:3rem 0}.prose>:first-child{margin-top:0}.prose>:last-child{margin-bottom:0}.prose .katex{font-size:1.05em}.prose .katex-display{margin:var(--space-8)0;padding:var(--space-2)0;overflow:auto hidden}.prose .katex-display>.katex{font-size:1.15em}.essay-layout .katex-display{max-width:none;overflow-x:visible}.mdx-sequence{gap:var(--space-4);margin:var(--space-8)0;flex-direction:column;display:flex}.mdx-step{align-items:baseline;gap:var(--space-3);padding:var(--space-4)0;border-bottom:1px solid var(--border);background:0 0;border-radius:0;line-height:1.65;display:flex}.mdx-step:last-child{border-bottom:none}.mdx-step-number{font-family:var(--serif);font-size:var(--text-sm);color:var(--text-muted);flex-shrink:0;min-width:1.25rem}.mdx-callout{border-left:2px solid var(--accent);padding:var(--space-4)var(--space-6);margin:var(--space-8)0;background:var(--surface);border-radius:0 4px 4px 0}.mdx-callout-label{font-family:var(--serif);font-size:var(--text-sm);color:var(--accent);letter-spacing:.02em;margin-bottom:var(--space-2);font-weight:400;display:block}.mdx-callout-icon{margin-right:var(--space-2)}.mdx-callout-content p:last-child{margin-bottom:0}.mdx-figure{margin:var(--space-10)0;text-align:center}.mdx-figure-content{margin-bottom:var(--space-3)}.mdx-figure-wide{grid-column:2/4}@media (max-width:1080px){.mdx-figure-wide{grid-column:unset}}.mdx-figure-caption{font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);line-height:1.5}.mdx-sidenote-marker{font-family:var(--serif);color:var(--accent);cursor:pointer;vertical-align:super;padding:0 1px;font-size:.7em;line-height:0}.mdx-sidenote-toggle{font:inherit;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0 1px}.mdx-sidenote-margin{float:right;clear:right;width:200px;font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);margin-right:-240px;line-height:1.5;position:relative}.mdx-sidenote-number{font-family:var(--serif);color:var(--accent);margin-right:var(--space-1);font-size:.75rem}.mdx-sidenote-inline{font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);background:var(--surface);padding:var(--space-3)var(--space-4);margin:var(--space-2)0 var(--space-4);border-radius:4px;line-height:1.5;display:block;overflow:hidden}@media (max-width:1080px){.mdx-sidenote-margin{display:none}}.mdx-footnote-marker{font-family:var(--serif);color:var(--text-muted);vertical-align:super;padding:0 1px;font-size:.7em;line-height:0;text-decoration:none}.mdx-footnote-marker:hover{color:var(--accent)}.mdx-footnote-list{margin-top:var(--space-12)}.mdx-footnote-divider{border:none;border-top:1px solid var(--border);margin-bottom:var(--space-6)}.mdx-footnote-list ol{counter-reset:footnote;padding-left:0;list-style:none!important}.mdx-footnote-entry{font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-3);padding-left:1.5rem;line-height:1.4;position:relative}.mdx-footnote-entry:before{counter-increment:footnote;content:counter(footnote)".";font-family:var(--serif);color:var(--text-muted);font-size:.8rem;position:absolute;left:0}.mdx-footnote-back{color:var(--text-muted);margin-left:var(--space-2);font-size:.85em;text-decoration:none}.mdx-footnote-back:hover{color:var(--accent)}.mdx-pullquote{font-family:var(--serif);color:var(--text);text-align:center;max-width:95%;margin:var(--space-16)auto;letter-spacing:-.01em;white-space:pre-line;font-size:1.75rem;font-style:italic;line-height:1.35}.mdx-pullquote p{margin-bottom:0}.mdx-diagram{margin:var(--space-10)0;text-align:center}.mdx-diagram-svg{width:100%;max-width:480px;height:auto;margin:0 auto;display:block}.mdx-diagram-box{fill:var(--surface);stroke:var(--text);stroke-width:1.5px;stroke-opacity:.7}.mdx-diagram-line{stroke:var(--text);stroke-width:1.5px;stroke-opacity:.7;fill:none}.mdx-diagram-arrowhead{fill:var(--text);fill-opacity:.7}.mdx-diagram-text{font-family:var(--sans);fill:var(--text);fill-opacity:.85;font-size:13px}.mdx-diagram-curve{fill:none;stroke:var(--text);stroke-width:1.5px;stroke-opacity:.7}.mdx-diagram-circle{fill:var(--surface);stroke:var(--text);stroke-width:1.5px;stroke-opacity:.7}.mdx-diagram-caption{font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-3);line-height:1.5}.essay-layout{grid-template-columns:1fr minmax(0,var(--measure-prose))1fr;column-gap:var(--space-6);max-width:var(--measure-wide);margin:0 auto;display:grid}.essay-layout>*{grid-column:2}@media (max-width:1080px){.essay-layout{max-width:var(--measure-prose);display:block}}.site-main:has(.essay-layout){max-width:var(--measure-wide);padding-left:var(--space-6);padding-right:var(--space-6)}body:has(.essay-layout) .site-header-nav{max-width:1060px}.guide-list{list-style:none}.guide-entry{padding:var(--space-5)0}.guide-entry+.guide-entry{border-top:1px solid var(--border)}.guide-link{display:block}.guide-entry:hover .guide-title{color:var(--accent)}.guide-title-row{justify-content:space-between;align-items:baseline;gap:var(--space-6);display:flex}.guide-title{font-family:var(--serif);font-size:var(--text-essay);transition:color var(--dur-base)ease;font-weight:400;line-height:1.35}.guide-description{font-size:var(--text-sm);color:var(--text-muted);margin-top:.25rem;line-height:1.5}.guide-lesson-count{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.03em;color:var(--text-muted);white-space:nowrap}.guide-overview-chapters~.guide-begin-link{margin-bottom:var(--space-8)}.article-header:has(+.guide-overview-chapters){margin-bottom:var(--space-8)}.guide-overview-description{font-size:var(--text-base);color:var(--text-muted);margin-top:var(--space-2);margin-bottom:var(--space-4);line-height:1.6}.course-progress-indicator{margin-top:var(--space-4);margin-bottom:var(--space-8);gap:var(--space-2);flex-direction:column;display:flex}.course-progress-indicator-placeholder{height:calc(4px + var(--space-2) + 1.2em);margin-top:var(--space-4);margin-bottom:var(--space-8)}.course-progress-indicator-bar{background:var(--learning-progress-pending);width:100%;height:4px;position:relative}@supports (color:color-mix(in lab, red, red)){.course-progress-indicator-bar{background:color-mix(in srgb,var(--learning-progress-pending)25%,transparent)}}.course-progress-indicator-bar{border-radius:2px;overflow:hidden}.course-progress-indicator-fill{background:var(--learning-progress-current);border-radius:2px;transition:width .3s;position:absolute;inset:0 auto 0 0}.course-progress-indicator-meta{justify-content:space-between;align-items:center;gap:var(--space-3);font-family:var(--sans);font-size:var(--text-sm);display:flex}.course-progress-indicator-stats{color:var(--text-muted)}.course-progress-indicator-resume{align-items:center;gap:var(--space-1);color:var(--accent);text-decoration:none;display:inline-flex}.course-progress-indicator-resume:hover{text-underline-offset:3px;text-decoration:underline}.guide-overview-chapters{margin-bottom:var(--space-8)}.guide-overview-chapter{margin-bottom:var(--space-6)}.guide-chapter-label{font-family:var(--sans);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-3);font-size:.6875rem;font-weight:400}.guide-overview-lessons{list-style:none}.guide-overview-lesson{padding:var(--space-3)0;border-bottom:1px solid var(--border)}.guide-overview-lesson a{color:var(--text);font-size:var(--text-base);text-decoration:none}.guide-overview-lesson a:hover{color:var(--accent)}.guide-overview-lesson-number{color:var(--text-muted);font-family:var(--sans);font-size:var(--text-sm)}.guide-begin-link{align-items:center;gap:var(--space-2);color:var(--accent);font-size:var(--text-base);margin-top:var(--space-2);display:inline-flex}.guide-begin-link:hover{text-underline-offset:3px;text-decoration:underline}.lesson-header{margin-bottom:var(--space-8)}.lesson-title{font-family:var(--serif);font-size:var(--text-page);letter-spacing:-.02em;margin-bottom:0;font-weight:400;line-height:1.15}.lesson-progress{font-family:var(--sans);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-2)}@media (max-width:640px){.lesson-breadcrumb-desktop{display:none}.lesson-guide-back-link{align-items:center;max-width:100%;line-height:1.4;display:inline-flex}.lesson-header{margin-bottom:var(--space-7)}.lesson-title{font-size:1.75rem}}@media (prefers-color-scheme:dark){:root{--bg:#111110;--text:#e8e8e3;--text-muted:#8a8a82;--accent:#d4a62a;--border:#2a2a26;--surface:#1a1a18;--selection-bg:#d4a62a;--selection-text:#111110;--learning-correct:#3d9a4f;--learning-incorrect:#d43a3f;--learning-hint:#ffb224;--learning-info:#d4a62a}.katex{color:var(--text)}}.skip-link{background:var(--text);color:var(--bg);padding:var(--space-2)var(--space-4);font-family:var(--sans);font-size:var(--text-sm);z-index:100;position:absolute;top:-100%;left:0}.skip-link:focus{top:0}@media (max-width:640px){:root{--text-hero:2rem;--text-page:1.625rem;--text-essay:1.125rem}.site-main{padding:var(--space-12)var(--space-5)}.site-title{font-size:2rem}.article-title{font-size:1.75rem}.essay-entry{grid-template-columns:1fr;min-height:44px}.essay-title-row{justify-content:space-between;align-items:center;gap:var(--space-2);flex-direction:row;display:flex}.essay-description{margin-top:.125rem}.content-nav-inner{align-items:center;gap:var(--space-6);flex-direction:column}.content-nav-prev,.content-nav-next{text-align:center}.content-nav-next{margin-left:0}.prose{font-size:1rem}.mdx-pullquote{margin:var(--space-12)auto;font-size:1.375rem}.quick-check-options-row{flex-direction:column}.code-playground-toolbar,.code-playground-toolbar-right{flex-wrap:wrap}.code-playground-btn span{display:none}.code-playground-editor{min-height:120px}.confidence-rating-options{flex-direction:column}}.lesson-shell{flex-direction:column;display:flex}.lesson-shell-overlay{z-index:30;background:#0000004d;position:fixed;inset:0}.lesson-shell-grid{grid-template-columns:220px 1fr;min-height:calc(100dvh - 46px);display:grid}.lesson-shell-rail{background:var(--surface);height:calc(100dvh - 46px);position:sticky;top:46px}@supports (color:color-mix(in lab, red, red)){.lesson-shell-rail{background:color-mix(in srgb,var(--surface)40%,var(--bg))}}.lesson-shell-rail{z-index:10;transition:transform var(--dur-base)ease;overflow-y:auto}.lesson-shell-rail:after{content:"";background:var(--border);width:1px;position:absolute;top:0;bottom:0;right:0}.lesson-shell-rail-inner{padding:var(--space-8)var(--space-4)}.lesson-shell-main{min-width:0;padding:var(--space-12)var(--space-10)var(--space-20);max-width:720px;transition:margin-left var(--dur-base)ease}body.lesson-mode .site-main{max-width:none;margin:0;padding:0}.lesson-shell-lab{border-left:1px solid var(--border);background:var(--surface);width:340px;min-width:340px;overflow-y:auto}@media (max-width:1080px){.lesson-shell-grid{grid-template-columns:1fr}.lesson-shell-rail{z-index:40;width:280px;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:2px 0 8px #0000001a}.lesson-shell-rail-open{transform:translate(0)}.lesson-shell-main{max-width:none;padding:var(--space-8)var(--space-5);margin-left:0}.lesson-shell-lab{display:none}}@media (max-width:640px){.lesson-shell-rail{width:100%;max-width:320px}.lesson-shell-main{padding:var(--space-6)var(--space-4)}}.progress-rail-label{font-family:var(--sans);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text);margin-bottom:var(--space-2);margin-top:0;font-weight:600}.progress-rail{gap:var(--space-4);flex-direction:column;display:flex}.progress-rail-lessons{padding-left:var(--space-3);flex-direction:column;list-style:none;display:flex}.progress-rail-lesson{padding:var(--space-2)0;color:var(--text-muted);transition:color var(--dur-fast)ease;font-size:13.5px;line-height:1.4;text-decoration:none;display:block}.progress-rail-lesson:hover,.progress-rail-current,.progress-rail-current:hover{color:var(--text)}.progress-rail-completed{color:var(--text-muted)}.progress-rail-completed:hover{color:var(--text)}.worked-example{background:var(--surface);border:1px solid var(--border);margin:var(--space-8)0;font-family:var(--sans);border-radius:6px;overflow:hidden}.worked-example-header{padding:var(--space-3)var(--space-4);border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.worked-example-header{background:color-mix(in srgb,var(--surface)50%,var(--bg))}}.worked-example-title{color:var(--text);letter-spacing:.02em;font-family:var(--sans)!important;font-size:var(--text-sm)!important;margin:0!important;font-weight:500!important}.worked-example-toggle{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;padding:var(--space-1)var(--space-2);background:0 0;border:none;border-radius:4px;transition:all .2s;display:inline-flex}.worked-example-toggle:hover{color:var(--text);background:var(--text)}@supports (color:color-mix(in lab, red, red)){.worked-example-toggle:hover{background:color-mix(in srgb,var(--text)5%,transparent)}}.worked-example-steps{padding:var(--space-4);gap:var(--space-6);flex-direction:column;display:flex}.worked-example-step{gap:var(--space-4);align-items:flex-start;display:flex}.worked-example-badge{background:var(--text);width:24px;height:24px;color:var(--bg);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:.75rem;font-weight:600;display:flex}.worked-example-step-content{flex:1;min-width:0}.worked-example-step-label{color:var(--text);margin-bottom:var(--space-2);font-weight:600;font-size:var(--text-base)}.worked-example-step-body{color:var(--text-muted);font-size:var(--text-sm);line-height:1.6}.worked-example-step-body>:first-child{margin-top:0}.worked-example-step-body>:last-child{margin-bottom:0}.worked-example-actions{padding:0 var(--space-4)var(--space-4);gap:var(--space-3);flex-direction:column;align-items:flex-start;display:flex}.worked-example-try-prompt{font-size:var(--text-sm);color:var(--learning-hint);padding-left:calc(24px + var(--space-4));font-style:italic}.worked-example-reveal{align-items:center;gap:var(--space-2);background:var(--bg);border:1px solid var(--border);color:var(--text);padding:var(--space-2)var(--space-4);font-size:var(--text-sm);cursor:pointer;margin-left:calc(24px + var(--space-4));border-radius:4px;font-weight:500;transition:all .2s;display:inline-flex}.worked-example-reveal:hover{border-color:var(--text-muted);background:var(--surface)}@supports (color:color-mix(in lab, red, red)){.worked-example-reveal:hover{background:color-mix(in srgb,var(--surface)50%,var(--bg))}}.worked-example-complete{margin:0 var(--space-4)var(--space-4);padding:var(--space-3)var(--space-4);background:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.worked-example-complete{background:color-mix(in srgb,var(--learning-correct)10%,transparent)}}.worked-example-complete{color:var(--learning-correct);font-size:var(--text-sm);text-align:center;border:1px solid var(--learning-correct);border-radius:4px;justify-content:center;align-items:center;font-weight:500;display:flex}@supports (color:color-mix(in lab, red, red)){.worked-example-complete{border:1px solid color-mix(in srgb,var(--learning-correct)20%,transparent)}}.hint-ladder{gap:var(--space-3);margin:var(--space-4)0;flex-direction:column;display:flex}.hint-ladder-hint{border:1px solid var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.hint-ladder-hint{border:1px solid color-mix(in srgb,var(--learning-hint)20%,transparent)}}.hint-ladder-hint{background-color:var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.hint-ladder-hint{background-color:color-mix(in srgb,var(--learning-hint)5%,transparent)}}.hint-ladder-hint{border-radius:var(--radius-md);padding:var(--space-3)var(--space-4)}.hint-ladder-hint-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--learning-hint);margin-bottom:var(--space-1);font-weight:600}.hint-ladder-hint-text{font-size:var(--text-sm);line-height:1.6}.hint-ladder-reveal{align-items:center;gap:var(--space-2);border:1px solid var(--learning-hint);background:0 0;display:inline-flex}@supports (color:color-mix(in lab, red, red)){.hint-ladder-reveal{border:1px solid color-mix(in srgb,var(--learning-hint)30%,transparent)}}.hint-ladder-reveal{border-radius:var(--radius-md);padding:var(--space-2)var(--space-4);font-size:var(--text-sm);color:var(--learning-hint);cursor:pointer;transition:background-color .2s,border-color .2s}.hint-ladder-reveal:hover{background-color:var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.hint-ladder-reveal:hover{background-color:color-mix(in srgb,var(--learning-hint)8%,transparent)}}.hint-ladder-reveal:hover{border-color:var(--learning-hint)}.hint-ladder-answer{margin-top:var(--space-2);padding:var(--space-3)var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);font-size:var(--text-sm);line-height:1.6}.hint-ladder-usage{font-size:var(--text-xs);color:var(--text-muted);margin-top:var(--space-1)}.l-callout{margin:var(--space-6)0;padding:var(--space-3)var(--space-4)var(--space-3)var(--space-5);border-left:2px solid #0000}.l-callout-header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-weight:500;font-size:var(--text-base);display:flex}.l-callout-content{font-size:var(--text-prose);color:var(--text);line-height:1.65}.l-callout-content p:last-child{margin-bottom:0}.l-callout-key-idea{border-left-color:var(--learning-info);background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.l-callout-key-idea{background:color-mix(in srgb,var(--learning-info)3%,transparent)}}.l-callout-key-idea .l-callout-icon{color:var(--learning-info)}.l-callout-pitfall{border-left-color:var(--learning-hint);background:var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.l-callout-pitfall{background:color-mix(in srgb,var(--learning-hint)3%,transparent)}}.l-callout-pitfall .l-callout-icon{color:var(--learning-hint)}.l-callout-done{border-left-color:var(--learning-correct);background:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.l-callout-done{background:color-mix(in srgb,var(--learning-correct)3%,transparent)}}.l-callout-done .l-callout-icon{color:var(--learning-correct)}.l-callout-careful{border-left-color:var(--learning-incorrect);background:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.l-callout-careful{background:color-mix(in srgb,var(--learning-incorrect)3%,transparent)}}.l-callout-careful .l-callout-icon{color:var(--learning-incorrect)}.glossary-popover{display:inline-block;position:relative}.glossary-popover-trigger{font:inherit;color:var(--learning-info);background:0 0;border:none}@supports (color:color-mix(in lab, red, red)){.glossary-popover-trigger{color:color-mix(in srgb,var(--learning-info)65%,var(--text))}}.glossary-popover-trigger{cursor:pointer;border-bottom:1px dotted var(--learning-info);margin:0;padding:0;transition:color .2s,border-color .2s}.glossary-popover-trigger:hover,.glossary-popover-trigger[aria-expanded=true]{color:var(--learning-info);border-bottom:1px solid var(--learning-info)}.glossary-popover-panel{bottom:calc(100% + var(--space-2));background:var(--bg);border:1px solid var(--border);width:320px;padding:var(--space-3)var(--space-4);z-index:50;font-family:var(--sans);font-size:var(--text-sm);text-align:left;gap:var(--space-2);border-radius:6px;flex-direction:column;line-height:1.5;display:flex;position:absolute;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000014}.glossary-popover-header{justify-content:space-between;align-items:flex-start;gap:var(--space-2);display:flex}.glossary-popover-term{color:var(--learning-info);margin-top:1px;font-weight:600}.glossary-popover-action{align-items:center;gap:var(--space-1);border:1px solid var(--border);padding:2px var(--space-2);font-family:var(--sans);color:var(--text-muted);cursor:pointer;white-space:nowrap;background:0 0;border-radius:4px;font-size:.7rem;transition:all .2s;display:inline-flex}.glossary-popover-action:hover{color:var(--learning-info);border-color:var(--learning-info);background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.glossary-popover-action:hover{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.glossary-popover-def{color:var(--text);margin:0}@media (max-width:640px){.glossary-popover-panel{width:100%;margin-top:var(--space-2);margin-bottom:var(--space-2);display:flex;position:static;transform:none}}.mistake-analyzer{gap:var(--space-4);margin-top:var(--space-6);margin-bottom:var(--space-6);flex-direction:column;display:flex}.mistake-analyzer-heading{font-family:var(--font-sans,inherit);font-size:var(--text-base);color:var(--learning-incorrect);font-weight:500}.mistake-analyzer-options{gap:var(--space-2);flex-direction:column;display:flex}.mistake-analyzer-option{padding:var(--space-3)var(--space-4);border:1px solid var(--border);color:var(--text-muted);font-family:var(--font-sans,inherit);font-size:var(--text-base);text-align:left;cursor:pointer;background:0 0;border-radius:6px;justify-content:flex-start;align-items:center;transition:all .2s;display:flex}.mistake-analyzer-option:hover{border-color:var(--text-muted);color:var(--text)}.mistake-analyzer-option.mistake-analyzer-option-selected{border-color:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.mistake-analyzer-option.mistake-analyzer-option-selected{border-color:color-mix(in srgb,var(--learning-incorrect)40%,transparent)}}.mistake-analyzer-option.mistake-analyzer-option-selected{background-color:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.mistake-analyzer-option.mistake-analyzer-option-selected{background-color:color-mix(in srgb,var(--learning-incorrect)10%,transparent)}}.mistake-analyzer-option.mistake-analyzer-option-selected{color:var(--text)}.mistake-analyzer-explanation{margin-top:var(--space-2);padding:var(--space-4);border:1px solid var(--border);background-color:var(--surface);gap:var(--space-2);border-radius:6px;flex-direction:column;display:flex}.mistake-analyzer-explanation-label{font-family:var(--font-sans,inherit);font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.mistake-analyzer-explanation-text{font-family:var(--font-sans,inherit);font-size:var(--text-base);color:var(--text);line-height:1.5}.quick-check{margin:var(--space-10)0;padding:var(--space-6)var(--space-6)var(--space-5);border:1px solid var(--border);background:var(--text);border-radius:10px}@supports (color:color-mix(in lab, red, red)){.quick-check{background:color-mix(in srgb,var(--text)2%,var(--bg))}}.quick-check{font-family:var(--sans)}.quick-check-eyebrow{font-family:var(--sans);font-size:var(--text-xs);letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-2);font-weight:600}.quick-check-question{font-family:var(--sans);font-size:var(--text-body);letter-spacing:-.005em;margin-bottom:var(--space-5);color:var(--text);font-weight:500;line-height:1.45}.quick-check-options{gap:var(--space-2);margin-bottom:var(--space-2);flex-direction:column;display:flex}.quick-check-options-row{gap:var(--space-3);flex-direction:row}.quick-check-option{padding:var(--space-3)var(--space-4);border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:var(--sans);font-size:var(--text-base);cursor:pointer;border-radius:8px;align-items:center;line-height:1.45;transition:border-color .15s,background-color .15s,color .15s,transform 50ms;display:flex}.quick-check-option:hover{border-color:var(--text-muted);background:var(--text)}@supports (color:color-mix(in lab, red, red)){.quick-check-option:hover{background:color-mix(in srgb,var(--text)3%,var(--bg))}}.quick-check-option:active{transform:translateY(1px)}.quick-check-option-selected{border-color:var(--learning-info);background-color:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.quick-check-option-selected{background-color:color-mix(in srgb,var(--learning-info)8%,var(--bg))}}.quick-check-option-correct{border-color:var(--learning-correct);background-color:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.quick-check-option-correct{background-color:color-mix(in srgb,var(--learning-correct)10%,transparent)}}.quick-check-option-correct{color:var(--learning-correct)}.quick-check-option-incorrect{border-color:var(--learning-incorrect);background-color:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.quick-check-option-incorrect{background-color:color-mix(in srgb,var(--learning-incorrect)10%,transparent)}}.quick-check-option-incorrect{color:var(--learning-incorrect)}.quick-check-input{width:100%;padding:var(--space-3)var(--space-4);border:1px solid var(--border);color:var(--text);font-family:var(--sans);font-size:var(--text-base);margin-bottom:var(--space-4);background:0 0;border-radius:6px;outline:none;line-height:1.4;transition:border-color .2s}.quick-check-input:focus{border-color:var(--learning-info)}.quick-check-input::placeholder{color:var(--text-muted)}.quick-check-input:disabled{opacity:.6;cursor:not-allowed}.quick-check-actions{gap:var(--space-3);margin-top:var(--space-4);display:flex}.quick-check-btn{align-items:center;gap:var(--space-2);padding:var(--space-2)var(--space-5);border:1px solid var(--text);background:var(--text);color:var(--bg);font-family:var(--sans);font-size:var(--text-sm);cursor:pointer;border-radius:6px;font-weight:500;transition:opacity .2s;display:inline-flex}.quick-check-btn:hover{opacity:.85}.quick-check-btn:disabled{opacity:.4;cursor:not-allowed}.quick-check-btn-retry{color:var(--text);border-color:var(--border);background:0 0}.quick-check-btn-retry:hover{border-color:var(--text-muted)}.quick-check-feedback{margin-top:var(--space-4);padding:var(--space-4)var(--space-5);border:1px solid;border-radius:8px;animation:.2s ease-out quick-check-feedback-in}@keyframes quick-check-feedback-in{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.quick-check-feedback-correct{border-color:var(--learning-correct);background-color:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.quick-check-feedback-correct{background-color:color-mix(in srgb,var(--learning-correct)10%,transparent)}}.quick-check-feedback-incorrect{border-color:var(--learning-incorrect);background-color:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.quick-check-feedback-incorrect{background-color:color-mix(in srgb,var(--learning-incorrect)10%,transparent)}}.quick-check-feedback-header{align-items:center;gap:var(--space-2);font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-2);display:flex}.quick-check-feedback-correct .quick-check-feedback-header{color:var(--learning-correct)}.quick-check-feedback-incorrect .quick-check-feedback-header{color:var(--learning-incorrect)}.quick-check-feedback-body{font-size:var(--text-sm);color:var(--text);margin:0;line-height:1.6}.quick-check-attempts{margin-top:var(--space-3);font-size:var(--text-sm);color:var(--text-muted)}.quick-check-sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.checkpoint-card{border:1px solid var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.checkpoint-card{border:1px solid color-mix(in srgb,var(--learning-info)40%,transparent)}}.checkpoint-card{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.checkpoint-card{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.checkpoint-card{margin:var(--space-8)0;font-family:var(--sans);border-radius:4px}.checkpoint-card-header{align-items:center;gap:var(--space-3);padding:var(--space-4)var(--space-5);border-bottom:1px solid var(--learning-info);display:flex}@supports (color:color-mix(in lab, red, red)){.checkpoint-card-header{border-bottom:1px solid color-mix(in srgb,var(--learning-info)15%,transparent)}}.checkpoint-card-badge{background:var(--learning-info);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.checkpoint-card-prompt{font-size:var(--text-base);color:var(--text);line-height:1.5}.checkpoint-card-content{padding:var(--space-4)var(--space-5)var(--space-5);margin-left:calc(28px + var(--space-3));gap:var(--space-4);flex-direction:column;display:flex}.checkpoint-card-check-btn{background:var(--learning-info);color:#fff;padding:var(--space-2)var(--space-5);font-family:var(--sans);font-size:var(--text-sm);cursor:pointer;border:none;border-radius:4px;justify-content:center;align-self:flex-start;align-items:center;font-weight:500;transition:opacity .2s;display:inline-flex}.checkpoint-card-check-btn:hover{opacity:.9}.checkpoint-card-feedback{padding:var(--space-3)var(--space-4);font-size:var(--text-sm);border-radius:4px;line-height:1.5}.checkpoint-card-feedback-correct{border:1px solid var(--learning-correct);background:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.checkpoint-card-feedback-correct{background:color-mix(in srgb,var(--learning-correct)10%,transparent)}}.checkpoint-card-feedback-correct{color:var(--learning-correct)}.checkpoint-card-feedback-incorrect{border:1px solid var(--learning-incorrect);background:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.checkpoint-card-feedback-incorrect{background:color-mix(in srgb,var(--learning-incorrect)10%,transparent)}}.checkpoint-card-feedback-incorrect{color:var(--learning-incorrect)}.checkpoint-card-learned{border:1px solid var(--border);background:var(--surface);padding:var(--space-3)var(--space-4);font-size:var(--text-sm);color:var(--text);border-radius:4px;line-height:1.5}.confidence-rating{margin:var(--space-8)0;font-family:var(--sans)}.confidence-rating-label{font-family:var(--sans);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:var(--space-3);font-size:.6875rem;font-weight:400}.confidence-rating-options{gap:var(--space-3);display:flex}.confidence-rating-option{align-items:center;gap:var(--space-1);padding:var(--space-3)var(--space-4);border:1px solid var(--border);color:var(--text-muted);font-family:var(--sans);font-size:var(--text-base);cursor:pointer;background:0 0;border-radius:6px;flex-direction:column;flex:1;font-weight:500;transition:border-color .2s,background-color .2s,color .2s;display:flex}.confidence-rating-option:hover{border-color:var(--text);color:var(--text)}.confidence-rating-option-selected{border-color:var(--learning-info);background-color:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.confidence-rating-option-selected{background-color:color-mix(in srgb,var(--learning-info)5%,transparent)}}.confidence-rating-option-selected{color:var(--text)}.confidence-rating-option-interval{font-size:var(--text-sm);color:var(--text-muted);font-weight:400}.timeline-explorer{margin:var(--space-8)0;font-family:var(--sans)}.timeline-explorer-scrubber{appearance:none;background:var(--border);cursor:pointer;border-radius:2px;outline:none;width:100%;height:4px}.timeline-explorer-scrubber::-webkit-slider-thumb{appearance:none;background:var(--learning-info);cursor:pointer;border:2px solid var(--bg);width:16px;height:16px;box-shadow:0 0 0 1px var(--learning-info);border-radius:50%}.timeline-explorer-scrubber::-moz-range-thumb{background:var(--learning-info);cursor:pointer;border:2px solid var(--bg);width:16px;height:16px;box-shadow:0 0 0 1px var(--learning-info);border-radius:50%}.timeline-explorer-dots{margin-top:var(--space-3);justify-content:space-between;align-items:center;padding:0 4px;display:flex}.timeline-explorer-dot{background:var(--text-muted);border:none;border-radius:50%;width:8px;height:8px}@supports (color:color-mix(in lab, red, red)){.timeline-explorer-dot{background:color-mix(in srgb,var(--text-muted)40%,transparent)}}.timeline-explorer-dot{cursor:pointer;padding:0;transition:background-color .2s,transform .2s}.timeline-explorer-dot:hover{transform:scale(1.3)}.timeline-explorer-dot-current{background:var(--learning-info);transform:scale(1.3)}.timeline-explorer-dot-past{background:var(--learning-correct)}.timeline-explorer-card{margin-top:var(--space-5);padding:var(--space-5);border:1px solid var(--border);background:var(--bg);border-radius:6px}.timeline-explorer-card-step{font-size:var(--text-sm);color:var(--learning-info);margin-bottom:var(--space-2);font-weight:500;display:block}.timeline-explorer-card-title{font-size:var(--text-body);color:var(--text);margin-bottom:var(--space-3);display:block}.timeline-explorer-card-desc{font-size:var(--text-base);color:var(--text);margin:0;line-height:1.6}.timeline-explorer-card-detail{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-3);margin-bottom:0;line-height:1.5}.concept-map{margin:var(--space-8)0;font-family:var(--sans)}.concept-map-canvas{aspect-ratio:16/10;width:100%;position:relative;overflow:hidden}.concept-map-svg{width:100%;height:100%;position:absolute;inset:0}.concept-map-edge{stroke:var(--text-muted);stroke-width:.3px;stroke-opacity:.4}.concept-map-edge-highlighted{stroke:var(--learning-info);stroke-width:.6px;stroke-opacity:1}.concept-map-edge-label{fill:var(--text-muted);font-size:2.5px;font-family:var(--sans)}.concept-map-node{padding:var(--space-1)var(--space-3);border:1px solid var(--border);background:var(--bg);color:var(--text-muted);font-family:var(--sans);font-size:var(--text-sm);cursor:pointer;white-space:nowrap;z-index:1;border-radius:999px;transition:background-color .2s,color .2s,border-color .2s;position:absolute;transform:translate(-50%,-50%)}.concept-map-node:hover{color:var(--text);border-color:var(--text-muted)}.concept-map-node-active{background:var(--learning-info);color:#fff;border-color:var(--learning-info)}.concept-map-node-highlighted{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.concept-map-node-highlighted{background:color-mix(in srgb,var(--learning-info)10%,transparent)}}.concept-map-node-highlighted{color:var(--learning-info);border-color:var(--learning-info)}.concept-map-detail{margin-top:var(--space-5);padding:var(--space-5);border:1px solid var(--border);background:var(--surface);border-radius:6px}.concept-map-detail-definition{font-size:var(--text-base);color:var(--text);margin:0;line-height:1.6}.concept-map-detail-examples{padding-left:var(--space-5);margin-top:var(--space-3);margin-bottom:0;list-style:outside}.concept-map-detail-examples li{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-1);line-height:1.5}.concept-map-detail-link{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--learning-info);font-weight:500;text-decoration:none;display:inline-block}.concept-map-detail-link:hover{text-underline-offset:3px;text-decoration:underline}.parameter-dock{margin:var(--space-6)0;border:1px solid var(--border);background:var(--surface);padding:var(--space-4);font-family:var(--sans);gap:var(--space-4);border-radius:8px;flex-direction:column;display:flex}.parameter-dock-header{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.parameter-dock-header-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.6875rem;font-weight:500}.parameter-dock-header-actions{align-items:center;gap:var(--space-1);display:flex}.parameter-dock-share{align-items:center;gap:var(--space-1);color:var(--learning-info);font-family:var(--sans);font-size:var(--text-sm);padding:var(--space-1)var(--space-2);cursor:pointer;background:0 0;border:none;border-radius:4px;font-weight:500;transition:background-color .2s;display:inline-flex}.parameter-dock-share:hover{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.parameter-dock-share:hover{background:color-mix(in srgb,var(--learning-info)8%,transparent)}}.parameter-dock-reset{color:var(--text-muted);cursor:pointer;padding:var(--space-1);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:color .2s,background-color .2s;display:inline-flex}.parameter-dock-reset:hover{color:var(--text);background:var(--text)}@supports (color:color-mix(in lab, red, red)){.parameter-dock-reset:hover{background:color-mix(in srgb,var(--text)6%,transparent)}}.parameter-dock-presets{align-items:center;gap:var(--space-2);flex-wrap:wrap;display:flex}.parameter-dock-presets-label{font-size:var(--text-sm);color:var(--text-muted)}.parameter-dock-preset{border:1px solid var(--border);color:var(--text-muted);padding:var(--space-1)var(--space-3);font-family:var(--sans);font-size:var(--text-sm);cursor:pointer;background:0 0;border-radius:999px;transition:border-color .2s,color .2s,background-color .2s}.parameter-dock-preset:hover{border-color:var(--text);color:var(--text)}.parameter-dock-controls{gap:var(--space-3);flex-direction:column;display:flex}.parameter-dock-control{gap:var(--space-2);flex-direction:column;display:flex}.parameter-dock-control-row{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.parameter-dock-control-label{font-size:var(--text-sm);color:var(--text-muted)}.parameter-dock-control-value{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);color:var(--text)}.parameter-dock-slider{width:100%;height:6px;accent-color:var(--learning-info);cursor:pointer}.parameter-dock-slider:focus-visible{outline:2px solid var(--learning-info);outline-offset:4px}.parameter-dock-toggle{background:var(--border);cursor:pointer;border:none;border-radius:999px;align-self:flex-end;width:36px;height:20px;padding:0;transition:background-color .2s;position:relative}.parameter-dock-toggle:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 2px #00000026}.parameter-dock-toggle[aria-checked=true]{background:var(--learning-info)}.parameter-dock-toggle[aria-checked=true]:after{transform:translate(16px)}.parameter-dock-toggle:focus-visible{outline:2px solid var(--learning-info);outline-offset:2px}.parameter-dock-select{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);padding:var(--space-2)var(--space-3);font-family:var(--sans);font-size:var(--text-base);cursor:pointer;border-radius:4px}.parameter-dock-select:focus-visible{outline:2px solid var(--learning-info);outline-offset:2px;border-color:var(--learning-info)}.live-output-panel{margin:var(--space-8)0;font-family:var(--sans);border:1px solid var(--border);border-radius:6px;overflow:hidden}.live-output-panel-header{padding:var(--space-2)var(--space-4);border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.live-output-panel-header{background:color-mix(in srgb,var(--surface)50%,var(--bg))}}.live-output-panel-label{font-size:var(--text-sm);color:var(--text-muted);letter-spacing:.02em;font-weight:500}.live-output-panel-copy{align-items:center;gap:var(--space-1);border:1px solid var(--border);padding:var(--space-1)var(--space-2);font-family:var(--sans);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;font-size:.75rem;transition:color .2s,border-color .2s,background-color .2s;display:inline-flex}.live-output-panel-copy:hover{color:var(--text);border-color:var(--text-muted)}.live-output-panel-body{padding:var(--space-4);background:var(--bg);color:var(--text);font-family:var(--font-mono,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace);font-size:var(--text-sm);white-space:pre-wrap;word-break:break-word;line-height:1.6;overflow-x:auto}.live-output-panel-changed{padding:var(--space-2)var(--space-4);background:var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.live-output-panel-changed{background:color-mix(in srgb,var(--learning-hint)8%,transparent)}}.live-output-panel-changed{color:var(--learning-hint);font-size:var(--text-sm);border-top:1px solid var(--learning-hint);font-weight:500}@supports (color:color-mix(in lab, red, red)){.live-output-panel-changed{border-top:1px solid color-mix(in srgb,var(--learning-hint)20%,transparent)}}.live-output-panel-explain{border-top:1px solid var(--border)}.live-output-panel-explain-toggle{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-3)var(--space-4);font-family:var(--sans);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:none;transition:color .2s;display:flex}.live-output-panel-explain-toggle:hover{color:var(--text)}.live-output-panel-explain-content{padding:0 var(--space-4)var(--space-4);font-size:var(--text-sm);color:var(--text);line-height:1.6}.concept-explorer{margin:var(--space-8)0;font-family:var(--sans)}.concept-explorer-diagram{width:100%;position:relative}.concept-explorer-hotspot{border:2px solid var(--border);background:var(--bg);width:28px;height:28px;color:var(--text-muted);font-family:var(--sans);cursor:pointer;z-index:1;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:.75rem;font-weight:600;transition:background-color .2s,color .2s,border-color .2s,transform .2s;display:flex;position:absolute;transform:translate(-50%,-50%)}.concept-explorer-hotspot:hover{border-color:var(--text-muted);color:var(--text)}.concept-explorer-hotspot-active{background:var(--learning-info);color:#fff;border-color:var(--learning-info);transform:translate(-50%,-50%)scale(1.1)}.concept-explorer-detail{margin-top:var(--space-5);padding:var(--space-5);border:1px solid var(--border);background:var(--surface);border-radius:6px}.concept-explorer-detail-label{font-size:var(--text-sm);color:var(--learning-info);margin-bottom:var(--space-2);font-weight:600}.concept-explorer-detail-definition{font-size:var(--text-base);color:var(--text);margin-bottom:var(--space-4);line-height:1.6}.concept-explorer-detail-card{background:var(--bg);border:1px solid var(--border);padding:var(--space-3)var(--space-4);margin-bottom:var(--space-3);border-radius:4px}.concept-explorer-detail-card-title{font-size:var(--text-sm);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-1);font-weight:600}.concept-explorer-detail-card-body{font-size:var(--text-sm);color:var(--text);line-height:1.6}.concept-explorer-detail-card-mistake{border-color:var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.concept-explorer-detail-card-mistake{border-color:color-mix(in srgb,var(--learning-hint)30%,transparent)}}.concept-explorer-detail-card-mistake{background:var(--learning-hint)}@supports (color:color-mix(in lab, red, red)){.concept-explorer-detail-card-mistake{background:color-mix(in srgb,var(--learning-hint)5%,transparent)}}.concept-explorer-detail-card-mistake .concept-explorer-detail-card-title{color:var(--learning-hint)}.concept-explorer-detail-card-example{border-color:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.concept-explorer-detail-card-example{border-color:color-mix(in srgb,var(--learning-info)20%,transparent)}}.concept-explorer-detail-card-example{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.concept-explorer-detail-card-example{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.concept-explorer-detail-card-example .concept-explorer-detail-card-title{color:var(--learning-info)}.interactive-diagram{border:1px solid var(--border);background:var(--bg);margin:var(--space-8)0;overflow:hidden}.interactive-diagram svg{width:100%;height:auto;display:block}.before-after-split{margin:var(--space-8)0;font-family:var(--sans)}.before-after-split-labels{text-align:center;font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-2);grid-template-columns:1fr 1fr;display:grid}.before-after-split-pane{-webkit-user-select:none;user-select:none;touch-action:none;display:flex;position:relative}.before-after-split-before{background:var(--bg);overflow:hidden}.before-after-split-after{background:var(--surface);overflow:hidden}.before-after-split-divider{background:var(--learning-info);cursor:col-resize;z-index:1;flex-shrink:0;width:2px;position:relative}.before-after-split-handle{color:var(--learning-info);white-space:nowrap;pointer-events:none;font-size:.875rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.diff-editor{margin:var(--space-8)0;font-family:var(--sans);border:1px solid var(--border);border-radius:6px;overflow:hidden}.diff-editor-header{padding:var(--space-2)var(--space-4);border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.diff-editor-header{background:color-mix(in srgb,var(--surface)50%,var(--bg))}}.diff-editor-header{font-size:var(--text-sm);color:var(--text-muted)}.diff-editor-filename{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);color:var(--text-muted)}.diff-editor-body{overflow-x:auto}.diff-editor-line{padding:0 var(--space-4);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);align-items:baseline;min-height:1.6em;line-height:1.6;display:flex}.diff-editor-line-added{background:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.diff-editor-line-added{background:color-mix(in srgb,var(--learning-correct)5%,transparent)}}.diff-editor-line-added{color:var(--learning-correct)}.diff-editor-line-removed{background:var(--learning-incorrect)}@supports (color:color-mix(in lab, red, red)){.diff-editor-line-removed{background:color-mix(in srgb,var(--learning-incorrect)5%,transparent)}}.diff-editor-line-removed{color:var(--learning-incorrect);text-decoration:line-through}.diff-editor-line-unchanged{color:var(--text-muted)}.diff-editor-line-num{text-align:right;width:2.5rem;padding-right:var(--space-3);color:var(--text-muted);opacity:.4;-webkit-user-select:none;user-select:none;flex-shrink:0;display:inline-block}.diff-editor-line-prefix{flex-shrink:0;width:1rem;display:inline-block}.diff-editor-line-content{flex:1;min-width:0}.diff-editor-annotation{padding:var(--space-2)var(--space-4)var(--space-2)calc(2.5rem + var(--space-3) + 1rem + var(--space-4));background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.diff-editor-annotation{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.diff-editor-annotation{border-left:2px solid var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.diff-editor-annotation{border-left:2px solid color-mix(in srgb,var(--learning-info)20%,transparent)}}.diff-editor-annotation{font-family:var(--sans);font-size:var(--text-sm);color:var(--text);line-height:1.5}.snippet-copy{align-items:center;gap:var(--space-2);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.85em;display:inline-flex}.snippet-copy-code{background:var(--surface);color:var(--text);border-radius:3px;padding:.125rem .375rem}.snippet-copy-prompt{color:var(--text-muted)}.snippet-copy-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:2px;transition:color .2s,background-color .2s;display:inline-flex}.snippet-copy-btn:hover{color:var(--text);background:var(--surface)}.task-runner{margin:var(--space-8)0;font-family:var(--sans);gap:var(--space-4);flex-direction:column;display:flex}.task-runner-prompt{border:1px solid var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.task-runner-prompt{border:1px solid color-mix(in srgb,var(--learning-info)30%,transparent)}}.task-runner-prompt{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.task-runner-prompt{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.task-runner-prompt{padding:var(--space-4)var(--space-5);border-radius:4px}.task-runner-prompt-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--learning-info);margin-bottom:var(--space-2);font-weight:600;display:inline-block}.task-runner-prompt p{font-size:var(--text-base);color:var(--text);margin:0;line-height:1.6}.task-runner-tests{gap:var(--space-2);flex-direction:column;display:flex}.task-runner-tests-label{font-size:var(--text-sm);color:var(--text-muted);margin-bottom:var(--space-1);font-weight:500}.task-runner-test-case{font-size:var(--text-sm);color:var(--text);line-height:1.5;font-family:var(--mono)}.task-runner-test-case code{font-family:var(--mono);font-size:var(--text-sm)}.task-runner-test-hidden{color:var(--text-muted)}@supports (color:color-mix(in lab, red, red)){.task-runner-test-hidden{color:color-mix(in srgb,var(--text-muted)60%,transparent)}}.task-runner-test-hidden{font-family:var(--sans);font-style:italic}.task-runner-success{border:1px solid var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.task-runner-success{border:1px solid color-mix(in srgb,var(--learning-correct)30%,transparent)}}.task-runner-success{background:var(--learning-correct)}@supports (color:color-mix(in lab, red, red)){.task-runner-success{background:color-mix(in srgb,var(--learning-correct)10%,transparent)}}.task-runner-success{color:var(--learning-correct);padding:var(--space-3)var(--space-4);font-size:var(--text-sm);border-radius:4px;font-weight:500}.resume-banner{justify-content:space-between;align-items:center;gap:var(--space-4);border:1px solid var(--learning-info);display:flex}@supports (color:color-mix(in lab, red, red)){.resume-banner{border:1px solid color-mix(in srgb,var(--learning-info)30%,transparent)}}.resume-banner{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.resume-banner{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.resume-banner{padding:var(--space-3)var(--space-4);font-family:var(--sans);border-radius:4px}.resume-banner-text{gap:var(--space-1);flex-direction:column;min-width:0;display:flex}.resume-banner-label{text-transform:uppercase;letter-spacing:.05em;color:var(--learning-info);font-size:.6875rem;font-weight:500}.resume-banner-lesson{font-size:var(--text-sm);color:var(--text);line-height:1.4}.resume-banner-lesson-muted{color:var(--text-muted)}.resume-banner-btn{align-items:center;gap:var(--space-1);background:var(--learning-info);color:#fff;padding:var(--space-2)var(--space-4);font-family:var(--sans);font-size:var(--text-sm);white-space:nowrap;border:none;border-radius:4px;font-weight:500;text-decoration:none;transition:opacity .2s;display:inline-flex}.resume-banner-btn:hover{opacity:.9}.code-playground{margin:var(--space-8)0;font-family:var(--sans);border:1px solid var(--border);border-radius:6px;overflow:hidden}.code-playground-toolbar{padding:var(--space-2)var(--space-3);border-bottom:1px solid var(--border);background:var(--surface);justify-content:space-between;align-items:center;display:flex}@supports (color:color-mix(in lab, red, red)){.code-playground-toolbar{background:color-mix(in srgb,var(--surface)50%,var(--bg))}}.code-playground-toolbar{gap:var(--space-2)}.code-playground-toolbar-left,.code-playground-toolbar-right{align-items:center;gap:var(--space-2);display:flex}.code-playground-language{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);color:var(--text-muted)}.code-playground-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--text-muted);font-size:.6875rem;font-weight:500}@supports (color:color-mix(in lab, red, red)){.code-playground-badge{background:color-mix(in srgb,var(--text-muted)10%,transparent)}}.code-playground-badge{padding:2px var(--space-2);border-radius:3px}.code-playground-btn{align-items:center;gap:var(--space-1);border:1px solid var(--border);padding:var(--space-1)var(--space-3);font-family:var(--sans);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;font-size:.75rem;transition:color .2s,border-color .2s,background-color .2s;display:inline-flex}.code-playground-btn:hover{color:var(--text);border-color:var(--text-muted)}.code-playground-btn:disabled{opacity:.4;cursor:not-allowed}.code-playground-run-btn{background:var(--text);color:var(--bg);border-color:var(--text)}.code-playground-run-btn:hover:not(:disabled){opacity:.85}.code-playground-editor{width:100%;min-height:160px;padding:var(--space-4);background:var(--bg);color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);resize:none;tab-size:2;border:none;outline:none;line-height:1.6}.code-playground-editor:focus{box-shadow:inset 0 0 0 1px var(--learning-info)}.code-playground-editor-guided{background:var(--bg);position:relative;overflow:hidden}.code-playground-editor-guided-input{opacity:0;pointer-events:none;position:absolute;inset:0}.code-playground-line-editable,.code-playground-line-readonly{padding:0 var(--space-4);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);align-items:baseline;min-height:1.6em;line-height:1.6;display:flex}.code-playground-line-editable{background:var(--learning-info)}@supports (color:color-mix(in lab, red, red)){.code-playground-line-editable{background:color-mix(in srgb,var(--learning-info)5%,transparent)}}.code-playground-line-readonly{color:var(--text-muted)}.code-playground-line-number{text-align:right;width:2.5rem;padding-right:var(--space-3);color:var(--text-muted);opacity:.4;-webkit-user-select:none;user-select:none;flex-shrink:0;display:inline-block}.code-playground-line-content{white-space:pre;flex:1;min-width:0}.code-playground-output{border-top:1px solid var(--border);background:var(--surface)}.code-playground-output-header{padding:var(--space-2)var(--space-4);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);font-size:.6875rem;font-weight:500}.code-playground-output-error{padding:var(--space-3)var(--space-4);color:var(--learning-incorrect);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);white-space:pre-wrap;word-break:break-word;line-height:1.6}.code-playground-output-text{padding:var(--space-3)var(--space-4);color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:var(--text-sm);white-space:pre-wrap;word-break:break-word;line-height:1.6}.code-playground-tests{border-top:1px solid var(--border);padding:var(--space-3)var(--space-4);gap:var(--space-2);flex-direction:column;display:flex}.code-playground-test-passed,.code-playground-test-failed{align-items:center;gap:var(--space-2);font-size:var(--text-sm);line-height:1.4;display:flex}.code-playground-test-passed{color:var(--learning-correct)}.code-playground-test-failed{color:var(--learning-incorrect)}.code-playground-test-dot{flex-shrink:0;font-size:.75rem}.code-playground-hints{border-top:1px solid var(--border);padding:var(--space-3)var(--space-4);gap:var(--space-2);background:var(--learning-hint);flex-direction:column;display:flex}@supports (color:color-mix(in lab, red, red)){.code-playground-hints{background:color-mix(in srgb,var(--learning-hint)5%,transparent)}}.code-playground-hint{align-items:baseline;gap:var(--space-2);font-size:var(--text-sm);color:var(--text);line-height:1.5;display:flex}.code-playground-hint-number{background:var(--learning-hint);border-radius:50%;flex-shrink:0;width:1.25rem;height:1.25rem}@supports (color:color-mix(in lab, red, red)){.code-playground-hint-number{background:color-mix(in srgb,var(--learning-hint)15%,transparent)}}.code-playground-hint-number{color:var(--learning-hint);justify-content:center;align-items:center;font-size:.6875rem;font-weight:600;display:inline-flex}@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}
