:root{--color-teal-darkest: #003135;--color-teal-dark: #024950;--color-rust: #964734;--color-teal-bright: #0FA4AF;--color-teal-light: #AFDDE5;--color-bg-primary: #FFFFFF;--color-bg-secondary: #F8FAFB;--color-bg-tertiary: #F0F4F6;--color-bg-accent: rgba(175, 221, 229, .15);--color-text-primary: var(--color-teal-darkest);--color-text-secondary: var(--color-teal-dark);--color-text-tertiary: #5A6C74;--color-border: rgba(2, 73, 80, .15);--color-border-hover: var(--color-teal-bright);--color-link: var(--color-teal-bright);--color-link-hover: var(--color-teal-dark);--color-accent-primary: var(--color-rust);--color-accent-hover: #B05840;--color-accent-teal: var(--color-teal-bright);--color-code-bg: #F5F7F9;--color-code-text: var(--color-teal-dark);--color-code-border: var(--color-border);--color-success: #0A7E42;--color-warning: #D97706;--color-error: #DC2626;--color-info: var(--color-teal-bright);--shadow-sm: 0 1px 2px 0 rgba(0, 49, 53, .05);--shadow-md: 0 4px 6px -1px rgba(0, 49, 53, .1), 0 2px 4px -1px rgba(0, 49, 53, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 49, 53, .1), 0 4px 6px -2px rgba(0, 49, 53, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 49, 53, .1), 0 10px 10px -5px rgba(0, 49, 53, .04)}[data-theme=dark]{--color-bg-primary: var(--color-teal-darkest);--color-bg-secondary: #012428;--color-bg-tertiary: #013a3f;--color-bg-accent: rgba(15, 164, 175, .1);--color-text-primary: #F0F4F6;--color-text-secondary: var(--color-teal-light);--color-text-tertiary: rgba(175, 221, 229, .85);--color-border: rgba(175, 221, 229, .2);--color-border-hover: var(--color-teal-bright);--color-link: var(--color-teal-bright);--color-link-hover: var(--color-teal-light);--color-accent-primary: #B05840;--color-accent-hover: #C67A62;--color-code-bg: #01181A;--color-code-text: var(--color-teal-light);--color-code-border: rgba(175, 221, 229, .15);--color-success: #10B981;--color-warning: #F59E0B;--color-error: #EF4444;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .3)}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Fira Code", "Consolas", "Monaco", "Courier New", monospace;--text-xs: clamp(.75rem, .7rem + .25vw, .875rem);--text-sm: clamp(.875rem, .8rem + .3vw, 1rem);--text-base: clamp(1rem, .95rem + .25vw, 1.125rem);--text-lg: clamp(1.125rem, 1.05rem + .35vw, 1.25rem);--text-xl: clamp(1.25rem, 1.15rem + .5vw, 1.5rem);--text-2xl: clamp(1.5rem, 1.35rem + .75vw, 1.875rem);--text-3xl: clamp(1.875rem, 1.65rem + 1.125vw, 2.25rem);--text-4xl: clamp(2.25rem, 1.95rem + 1.5vw, 3rem);--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em}:root{--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--space-xl: 3rem;--space-2xl: 4rem;--space-3xl: 6rem;--space-4xl: 8rem}:root{--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-2xl: 1536px;--reading-width: 65ch;--sidebar-width: 280px;--toc-width: 240px;--header-height: 64px;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-tooltip: 1060}:root{--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1)}:root{--focus-ring: 0 0 0 3px rgba(15, 164, 175, .5);--focus-ring-offset: 0 0 0 2px var(--color-bg-primary)}:root{--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}ul[role=list],ol[role=list]{list-style:none}body{min-height:100vh;line-height:1.5}h1,h2,h3,h4,h5,h6{line-height:1.25;text-wrap:balance}a:not([class]){text-decoration-skip-ink:auto;color:currentColor}img,picture,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}button{background:none;border:none;cursor:pointer;color:inherit}textarea:not([rows]){min-height:10em}:target{scroll-margin-block:5ex}button,input[type=submit],input[type=reset]{cursor:pointer}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-results-button,input[type=search]::-webkit-search-results-decoration{-webkit-appearance:none}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}html{font-family:var(--font-sans);font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-height) + 1rem)}body{background-color:var(--color-bg-primary);color:var(--color-text-primary);font-size:var(--text-base);line-height:var(--leading-relaxed);transition:background-color var(--transition-base),color var(--transition-base)}h1,h2,h3,h4,h5,h6{color:var(--color-text-secondary);font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);margin-block-end:.5em}h1{font-size:var(--text-4xl);line-height:var(--leading-tight)}h2{font-size:var(--text-3xl);line-height:var(--leading-tight);margin-block-start:2em}h3{font-size:var(--text-2xl);line-height:var(--leading-snug);margin-block-start:1.5em}h4{font-size:var(--text-xl);line-height:var(--leading-snug);margin-block-start:1.25em}h5{font-size:var(--text-lg);line-height:var(--leading-normal);margin-block-start:1em}h6{font-size:var(--text-base);line-height:var(--leading-normal);margin-block-start:1em}p{margin-block-end:1em;max-width:var(--reading-width)}.lead{font-size:var(--text-lg);line-height:var(--leading-relaxed);color:var(--color-text-secondary)}a{color:var(--color-link);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-link-hover);text-decoration:underline}a:focus-visible{outline:2px solid var(--color-link);outline-offset:2px;border-radius:var(--radius-sm)}strong,b{font-weight:var(--font-bold);color:var(--color-text-secondary)}em,i{font-style:italic}ul,ol{margin-block-end:1em;padding-inline-start:1.5em}li{margin-block-end:.5em}li>ul,li>ol{margin-block-start:.5em;margin-block-end:.5em}ul:not([role=list]){list-style-type:disc}ul:not([role=list]) ul{list-style-type:circle}ul:not([role=list]) ul ul{list-style-type:square}ol{list-style-type:decimal}ol ol{list-style-type:lower-alpha}ol ol ol{list-style-type:lower-roman}dl{margin-block-end:1em}dt{font-weight:var(--font-bold);color:var(--color-text-secondary);margin-block-start:.75em}dd{margin-inline-start:1.5em;margin-block-end:.5em}code,kbd,samp,pre{font-family:var(--font-mono);font-size:.9em}code:not(pre code){background-color:var(--color-code-bg);color:var(--color-code-text);padding:.2em .4em;border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:.875em}kbd{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);padding:.2em .5em;border-radius:var(--radius-sm);border:1px solid var(--color-border);box-shadow:0 2px #0000001a;font-size:.875em;font-weight:var(--font-medium)}pre{background-color:var(--color-code-bg);color:var(--color-code-text);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto;margin-block:var(--space-lg);line-height:var(--leading-relaxed)}pre code{background:none;border:none;padding:0;font-size:.875em;color:inherit}blockquote{padding:var(--space-md);padding-inline-start:var(--space-lg);margin-block:var(--space-lg);border-inline-start:4px solid var(--color-accent-teal);background-color:var(--color-bg-accent);border-radius:var(--radius-md);font-style:italic;color:var(--color-text-secondary)}blockquote p:last-child{margin-block-end:0}blockquote cite{display:block;margin-block-start:.5em;font-size:var(--text-sm);font-style:normal;color:var(--color-text-tertiary)}blockquote cite:before{content:"— "}table{width:100%;border-collapse:collapse;margin-block:var(--space-lg);font-size:var(--text-sm)}thead{background-color:var(--color-bg-tertiary);border-bottom:2px solid var(--color-border)}th{padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--font-semibold);color:var(--color-text-secondary)}td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border)}tbody tr:hover{background-color:var(--color-bg-secondary)}tbody tr:last-child td{border-bottom:none}@media(max-width:768px){table{display:block;overflow-x:auto}}hr{border:none;border-top:1px solid var(--color-border);margin-block:var(--space-xl)}figure{margin-block:var(--space-lg)}figcaption{margin-block-start:var(--space-sm);font-size:var(--text-sm);color:var(--color-text-tertiary);text-align:center;font-style:italic}abbr[title]{text-decoration:underline dotted;cursor:help}mark{background-color:#96473433;color:var(--color-text-primary);padding:.1em .3em;border-radius:var(--radius-sm)}small{font-size:var(--text-sm);color:var(--color-text-tertiary)}sub,sup{font-size:.75em;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}:focus-visible{outline:2px solid var(--color-accent-teal);outline-offset:2px}:focus:not(:focus-visible){outline:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border-hover);border-radius:99px;border:2px solid var(--color-bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--color-accent-primary)}*{scrollbar-width:thin;scrollbar-color:var(--color-border-hover) var(--color-bg-secondary)}::selection{background-color:var(--color-accent-teal);color:#fff}::-moz-selection{background-color:var(--color-accent-teal);color:#fff}.skip-link{position:absolute;top:-100px;left:0;background:var(--color-accent-primary);color:#fff;padding:var(--space-sm) var(--space-md);text-decoration:none;border-radius:0 0 var(--radius-md) 0;z-index:var(--z-tooltip);font-weight:var(--font-semibold);opacity:0;pointer-events:none}.skip-link:focus{top:0;opacity:1;pointer-events:auto}.container{width:100%;max-width:var(--container-xl);margin-inline:auto;padding-inline:var(--space-md)}.container--sm{max-width:var(--container-sm)}.container--md{max-width:var(--container-md)}.container--lg{max-width:var(--container-lg)}.container--reading{max-width:var(--reading-width)}.site-layout{min-height:100vh;display:flex;flex-direction:column}.site-header{position:sticky;top:0;z-index:var(--z-sticky);background-color:#003135;border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 1px 3px #0000004d;transition:box-shadow var(--transition-base)}.site-header.is-scrolled{box-shadow:0 2px 8px #0006}.main-nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-height);gap:var(--space-md)}.logo{display:flex;align-items:center;text-decoration:none;opacity:.9;transition:opacity var(--transition-fast)}.logo:hover{opacity:1;text-decoration:none}.logo img{display:block}.nav-links{display:flex;gap:var(--space-lg);list-style:none;margin:0;padding:0}.nav-links a{color:#ffffffbf;text-decoration:none;font-weight:var(--font-medium);font-size:var(--text-sm);transition:color var(--transition-fast);padding:var(--space-sm)}.nav-links a:hover{color:#fff;text-decoration:none}.nav-links a[aria-current=page]{color:#0fa4af;font-weight:var(--font-semibold)}.nav-actions{display:flex;align-items:center;gap:var(--space-sm)}.theme-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);border:1px solid rgba(255,255,255,.2);background:#ffffff14;transition:all var(--transition-fast);font-size:var(--text-lg)}.theme-toggle:hover{background:var(--color-accent-teal);border-color:var(--color-accent-teal);transform:scale(1.05)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent-teal);outline-offset:2px}.site-header .mobile-menu-toggle{border-color:#fff3;background:#ffffff14}.site-header .mobile-menu-toggle span{background:#ffffffd9}@media(max-width:768px){.nav-links{display:none}}.page-container{display:grid;gap:var(--space-xl);margin-block-start:var(--space-lg)}@media(min-width:768px){.page-container{grid-template-columns:1fr}}@media(min-width:1024px){.page-container--with-toc{grid-template-columns:1fr var(--toc-width)}}@media(min-width:1280px){.page-container--with-sidebar{grid-template-columns:var(--sidebar-width) 1fr}.page-container--with-sidebar-and-toc{grid-template-columns:var(--sidebar-width) 1fr var(--toc-width)}}main{flex:1;padding-block:var(--space-xl)}main>.container{padding-block:var(--space-lg)}.sidebar{background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:var(--space-lg);height:fit-content;position:sticky;top:calc(var(--header-height) + var(--space-md))}@media(max-width:1279px){.sidebar{display:none}}.toc{background-color:var(--color-bg-secondary);border-radius:var(--radius-lg);padding:var(--space-lg);height:fit-content;position:sticky;top:calc(var(--header-height) + var(--space-md))}.toc__title{font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-block-end:var(--space-sm)}.toc__list{list-style:none;padding:0;margin:0}.toc__link{display:block;padding:var(--space-xs);font-size:var(--text-sm);color:var(--color-text-tertiary);text-decoration:none;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.toc__link:hover{background-color:var(--color-bg-accent);color:var(--color-accent-teal);text-decoration:none}.toc__link--active{background-color:var(--color-bg-accent);color:var(--color-accent-teal);font-weight:var(--font-medium)}@media(max-width:1023px){.toc{display:none}}.breadcrumbs{display:flex;align-items:center;gap:var(--space-xs);list-style:none;padding:0;margin-block-end:var(--space-lg);font-size:var(--text-sm);flex-wrap:wrap}.breadcrumbs li{display:flex;align-items:center;gap:var(--space-xs);margin:0}.breadcrumbs li:not(:last-child):after{content:"/";color:var(--color-text-tertiary);margin-inline-start:var(--space-xs)}.breadcrumbs a{color:var(--color-text-tertiary);text-decoration:none}.breadcrumbs a:hover{color:var(--color-accent-teal);text-decoration:underline}.breadcrumbs [aria-current=page]{color:var(--color-text-primary);font-weight:var(--font-medium)}section{margin-block:var(--space-2xl)}section:first-child{margin-block-start:0}section:last-child{margin-block-end:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.hidden{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(max-width:767px){.hide-mobile{display:none}}@media(min-width:768px){.show-mobile{display:none}}.mobile-menu-toggle{display:none;width:40px;height:40px;flex-direction:column;justify-content:center;align-items:center;gap:4px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);transition:all var(--transition-fast)}.mobile-menu-toggle:hover{background:var(--color-bg-tertiary);border-color:var(--color-accent-teal)}.mobile-menu-toggle span{display:block;width:20px;height:2px;background:var(--color-text-secondary);transition:all var(--transition-fast)}.mobile-menu-toggle[aria-expanded=true] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-menu-toggle[aria-expanded=true] span:nth-child(2){opacity:0}.mobile-menu-toggle[aria-expanded=true] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}@media(max-width:768px){.mobile-menu-toggle{display:flex}}.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:320px;background:var(--color-bg-primary);border-left:1px solid var(--color-border);z-index:var(--z-modal);transform:translate(100%);transition:transform var(--transition-base);overflow-y:auto;box-shadow:var(--shadow-xl)}.mobile-menu.is-open{transform:translate(0)}.mobile-menu__backdrop{position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-modal) - 1);opacity:0;pointer-events:none;transition:opacity var(--transition-base)}.mobile-menu__backdrop.is-visible{opacity:1;pointer-events:auto}.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.mobile-menu__title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text-secondary)}.mobile-menu__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--color-text-tertiary);transition:all var(--transition-fast)}.mobile-menu__close:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.mobile-menu__content{padding:var(--space-lg)}@media(min-width:769px){.mobile-menu,.mobile-menu__backdrop{display:none}}.sidebar-group{margin-block-end:var(--space-xl)}.sidebar-group:last-child{margin-block-end:0}.sidebar-group__title{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-block-end:var(--space-sm);padding-inline-start:var(--space-sm)}.sidebar-nav{list-style:none;padding:0;margin:0}.sidebar-nav li{margin-block-end:2px}.sidebar-nav__link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;font-size:var(--text-sm);transition:all var(--transition-fast);position:relative}.sidebar-nav__link:hover{background:var(--color-bg-accent);color:var(--color-accent-teal);text-decoration:none}.sidebar-nav__link[aria-current=page]{background:var(--color-bg-accent);color:var(--color-accent-teal);font-weight:var(--font-semibold)}.sidebar-nav__link[aria-current=page]:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:var(--color-accent-primary);border-radius:0 2px 2px 0}.sidebar-nav__number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-bg-tertiary);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--color-text-tertiary);flex-shrink:0;transition:all var(--transition-fast)}.sidebar-nav__link:hover .sidebar-nav__number,.sidebar-nav__link[aria-current=page] .sidebar-nav__number{background:var(--color-accent-teal);color:#fff}.sidebar-nav__title{flex:1;line-height:var(--leading-snug)}.sidebar-nav__status{color:var(--color-success);font-size:var(--text-sm);flex-shrink:0}.lesson-nav{display:flex;gap:var(--space-md);justify-content:space-between;margin-block-start:var(--space-3xl);padding-block-start:var(--space-xl);border-top:1px solid var(--color-border)}.lesson-nav__link{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg-secondary);text-decoration:none;transition:all var(--transition-base);flex:1;max-width:45%}.lesson-nav__link:hover{border-color:var(--color-accent-teal);transform:translateY(-2px);box-shadow:var(--shadow-md);text-decoration:none}.lesson-nav__link--prev{align-items:flex-start}.lesson-nav__link--next{align-items:flex-end;text-align:right}.lesson-nav__label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.lesson-nav__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-secondary)}.lesson-nav__link:hover .lesson-nav__title{color:var(--color-accent-teal)}@media(max-width:640px){.lesson-nav{flex-direction:column}.lesson-nav__link{max-width:100%}.lesson-nav__link--next{align-items:flex-start;text-align:left}}.lesson-progress{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-lg);margin-block-end:var(--space-lg)}.lesson-progress__text{font-size:var(--text-sm);color:var(--color-text-tertiary);font-weight:var(--font-medium)}.lesson-progress__bar{flex:1;height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.lesson-progress__fill{height:100%;background:linear-gradient(90deg,var(--color-accent-teal),var(--color-accent-primary));border-radius:var(--radius-full);transition:width var(--transition-slow)}.mark-complete{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-weight:var(--font-semibold);cursor:pointer;transition:all var(--transition-fast)}.mark-complete:hover{border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,var(--color-bg-secondary));color:var(--color-success)}.mark-complete--completed{background:var(--color-success);border-color:var(--color-success);color:#fff}.mark-complete--completed:hover{background:var(--color-success);border-color:var(--color-success);opacity:.9}.mark-complete__icon{font-size:var(--text-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-size:var(--text-base);font-weight:var(--font-semibold);text-decoration:none;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;line-height:1}.btn:focus-visible{outline:2px solid var(--color-accent-teal);outline-offset:2px}.btn--primary{background:var(--color-accent-primary);color:#fff;border-color:var(--color-accent-primary)}.btn--primary:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md);text-decoration:none}.btn--primary:active{transform:translateY(0)}.btn--secondary{background:transparent;color:var(--color-text-secondary);border-color:var(--color-border)}.btn--secondary:hover{border-color:var(--color-accent-teal);color:var(--color-accent-teal);background:var(--color-bg-accent);text-decoration:none}.btn--teal{background:var(--color-accent-teal);color:#fff;border-color:var(--color-accent-teal)}.btn--teal:hover{background:var(--color-teal-dark);border-color:var(--color-teal-dark);transform:translateY(-1px);box-shadow:var(--shadow-md);text-decoration:none}.btn--small{padding:.5rem 1rem;font-size:var(--text-sm)}.btn--large{padding:1rem 2rem;font-size:var(--text-lg)}.btn--icon{padding:.75rem;aspect-ratio:1}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;pointer-events:none}.card{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.card__header{margin-block-end:var(--space-md)}.card__title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-secondary);margin-block-end:.5rem}.card__description{color:var(--color-text-tertiary);font-size:var(--text-sm)}.card__content{margin-block-end:var(--space-md)}.card__footer{display:flex;gap:var(--space-sm);align-items:center;justify-content:space-between;padding-block-start:var(--space-md);border-top:1px solid var(--color-border)}.lesson-card{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-base);position:relative;text-decoration:none;display:block}.lesson-card:hover{border-color:var(--color-accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-lg);text-decoration:none}.lesson-card__badge{display:inline-block;background:var(--color-bg-tertiary);color:var(--color-text-secondary);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:var(--tracking-wide);margin-block-end:var(--space-sm)}.lesson-card__title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text-secondary);margin-block-end:.5rem}.lesson-card__description{color:var(--color-text-tertiary);font-size:var(--text-sm);line-height:var(--leading-normal)}.lesson-card__meta{display:flex;gap:var(--space-md);align-items:center;margin-block-start:var(--space-md);font-size:var(--text-xs);color:var(--color-text-tertiary)}.lesson-card__status{position:absolute;top:var(--space-md);right:var(--space-md);color:var(--color-success);font-size:var(--text-lg)}.callout{display:flex;gap:var(--space-md);padding:var(--space-md);border-left:4px solid;border-radius:var(--radius-md);margin-block:var(--space-lg);background:var(--color-bg-secondary)}.callout__icon{flex-shrink:0;font-size:var(--text-xl)}.callout__content{flex:1}.callout__title{font-weight:var(--font-semibold);margin-block-end:.5rem}.callout--info{border-color:var(--color-info);background:color-mix(in srgb,var(--color-info) 10%,var(--color-bg-secondary))}.callout--info .callout__icon{color:var(--color-info)}.callout--warning{border-color:var(--color-warning);background:color-mix(in srgb,var(--color-warning) 10%,var(--color-bg-secondary))}.callout--warning .callout__icon{color:var(--color-warning)}.callout--success{border-color:var(--color-success);background:color-mix(in srgb,var(--color-success) 10%,var(--color-bg-secondary))}.callout--success .callout__icon{color:var(--color-success)}.callout--error{border-color:var(--color-error);background:color-mix(in srgb,var(--color-error) 10%,var(--color-bg-secondary))}.callout--error .callout__icon{color:var(--color-error)}.code-block{background:var(--color-code-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-block:var(--space-lg);overflow:hidden}.code-block__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.code-block__language{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.code-block__copy{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-tertiary);font-size:var(--text-xs);cursor:pointer;transition:all var(--transition-fast)}.code-block__copy:hover{background:var(--color-accent-teal);color:#fff;border-color:var(--color-accent-teal)}.code-block__copy--copied{background:var(--color-success);color:#fff;border-color:var(--color-success)}.badge{display:inline-block;padding:.25rem .75rem;font-size:var(--text-xs);font-weight:var(--font-semibold);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.badge--primary{background:var(--color-accent-primary);color:#fff}.badge--teal{background:var(--color-accent-teal);color:#fff}.badge--success{background:var(--color-success);color:#fff}.badge--neutral{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.progress{width:100%;height:.5rem;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress__bar{height:100%;background:var(--color-accent-teal);border-radius:var(--radius-full);transition:width var(--transition-base)}.progress--large{height:1rem}.hero{text-align:center;padding-block:var(--space-3xl)}.hero__title{font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--color-text-secondary);margin-block-end:var(--space-md);line-height:var(--leading-tight)}.hero__description{font-size:var(--text-lg);color:var(--color-text-tertiary);max-width:60ch;margin-inline:auto;margin-block-end:var(--space-xl);line-height:var(--leading-relaxed)}.hero__actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.grid{display:grid;gap:var(--space-lg)}.grid--2{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid--3{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid--4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.lesson-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-lg);margin-block:var(--space-xl)}@media(max-width:640px){.lesson-grid{grid-template-columns:1fr}}.search-trigger{display:flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-tertiary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.search-trigger:hover{border-color:var(--color-accent-teal);color:var(--color-text-primary);background:var(--color-bg-accent)}.search-trigger:focus-visible{outline:2px solid var(--color-accent-teal);outline-offset:2px}.search-trigger__text{display:none}@media(min-width:640px){.search-trigger__text{display:inline}}.search-trigger__kbd{display:inline-flex;padding:.1rem .35rem;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:var(--font-mono);display:none}@media(min-width:768px){.search-trigger__kbd{display:inline-flex}}.search-overlay{position:fixed;inset:0;background:#0000008c;z-index:var(--z-modal-backdrop);display:flex;align-items:flex-start;justify-content:center;padding-block-start:10vh;padding-inline:var(--space-sm);opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast)}.search-overlay.is-open{opacity:1;visibility:visible}.search-modal{background:var(--color-bg-primary);border:2px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:640px;box-shadow:var(--shadow-xl);overflow:hidden;transform:translateY(-16px) scale(.98);transition:transform var(--transition-fast)}.search-overlay.is-open .search-modal{transform:translateY(0) scale(1)}.search-input-wrapper{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border)}.search-icon{color:var(--color-text-tertiary);flex-shrink:0}.search-input{flex:1;border:none;outline:none;font-size:var(--text-lg);background:transparent;color:var(--color-text-primary);font-family:var(--font-sans)}.search-input::placeholder{color:var(--color-text-tertiary)}.search-input::-webkit-search-cancel-button{display:none}.search-clear{color:var(--color-text-tertiary);background:none;border:none;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);display:flex;align-items:center;opacity:0;visibility:hidden;transition:all var(--transition-fast)}.search-clear.is-visible{opacity:1;visibility:visible}.search-clear:hover{color:var(--color-text-primary);background:var(--color-bg-tertiary)}.search-results{max-height:420px;overflow-y:auto;scroll-padding-block:.5rem}.search-initial,.search-empty{padding:var(--space-xl) var(--space-md);text-align:center;color:var(--color-text-tertiary);font-size:var(--text-sm);margin:0}.search-empty strong{color:var(--color-text-primary)}.search-result{display:block;padding:.75rem var(--space-md);text-decoration:none;color:var(--color-text-primary);transition:background var(--transition-fast);border-left:3px solid transparent;border-bottom:1px solid var(--color-border)}.search-result:last-child{border-bottom:none}.search-result:hover,.search-result.is-selected{background:var(--color-bg-accent);border-left-color:var(--color-accent-teal);text-decoration:none}.search-result__title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text-secondary);margin-block-end:.2rem}.search-result__description{font-size:var(--text-sm);color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result mark,.search-result__heading mark{background:#0fa4af2e;color:var(--color-accent-teal);border-radius:2px;padding:0 1px;font-style:normal}.search-result__heading{display:flex;align-items:center;gap:.5rem;padding:.45rem var(--space-md) .45rem calc(var(--space-md) + 1.25rem);font-size:var(--text-sm);color:var(--color-text-tertiary);text-decoration:none;transition:background var(--transition-fast);border-left:3px solid transparent;border-bottom:1px solid var(--color-border)}.search-result__heading:last-child{border-bottom:none}.search-result__heading:hover,.search-result__heading.is-selected{background:var(--color-bg-accent);border-left-color:var(--color-accent-teal);color:var(--color-accent-teal)}.search-footer{display:flex;gap:var(--space-md);padding:.6rem var(--space-md);border-top:1px solid var(--color-border);background:var(--color-bg-secondary);font-size:var(--text-xs);color:var(--color-text-tertiary)}.search-footer kbd{display:inline-flex;padding:.15rem .4rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs)}.code-wrapper{position:relative}.code-copy-btn{position:absolute;top:.5rem;right:.5rem;padding:.3rem .65rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-xs);font-family:var(--font-sans);color:var(--color-text-tertiary);cursor:pointer;opacity:0;transition:all var(--transition-fast);z-index:1}.code-wrapper:hover .code-copy-btn,.code-copy-btn:focus-visible{opacity:1}.code-copy-btn:hover{background:var(--color-accent-teal);color:#fff;border-color:var(--color-accent-teal)}.code-copy-btn.is-copied{background:var(--color-success);color:#fff;border-color:var(--color-success);opacity:1}.lesson-card.is-completed{border-color:var(--color-success)}.lesson-card.is-completed .lesson-card__badge{background:var(--color-success);color:#fff}.lesson-card__checkbox{position:absolute;top:var(--space-md);right:var(--space-md);width:1.25rem;height:1.25rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;color:#fff;transition:border-color .15s,background .15s;flex-shrink:0}.lesson-card__checkbox:hover{border-color:var(--color-accent-primary)}.lesson-card__checkbox.is-checked{background:var(--color-success);border-color:var(--color-success)}.progress-action{padding-block:var(--space-xl);display:flex;justify-content:center}.mark-complete-btn{display:inline-flex;align-items:center;gap:.6rem;padding:.85rem 1.75rem;background:transparent;border:2px solid var(--color-success);border-radius:var(--radius-md);color:var(--color-success);font-size:var(--text-base);font-weight:var(--font-semibold);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast)}.mark-complete-btn:hover{background:var(--color-success);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-md)}.mark-complete-btn.is-completed{background:var(--color-success);color:#fff}.mark-complete-btn.is-completed:hover{background:transparent;color:var(--color-success);transform:none;box-shadow:none}.progress-summary{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg)}.progress-summary__header{display:flex;justify-content:space-between;align-items:baseline;margin-block-end:var(--space-sm)}.progress-summary__label{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text-secondary)}.progress-summary__count{font-size:var(--text-sm);color:var(--color-text-tertiary)}.progress-summary__bar{width:100%;height:.5rem;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden;margin-block-end:.4rem}.progress-summary__bar-fill{height:100%;background:var(--color-success);border-radius:var(--radius-full);transition:width .4s ease;width:0%}.progress-summary__pct{font-size:var(--text-xs);color:var(--color-text-tertiary);text-align:right;display:block}.reading-progress{position:fixed;top:0;left:0;width:100%;height:3px;z-index:calc(var(--z-fixed) + 10);pointer-events:none;background:transparent}.reading-progress__bar{height:100%;width:0%;background:linear-gradient(to right,var(--color-teal-bright),var(--color-accent-primary));transition:width 80ms linear}.back-to-top{position:fixed;bottom:2rem;right:2rem;width:2.75rem;height:2.75rem;background:var(--color-accent-teal);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:var(--z-fixed);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity var(--transition-fast),visibility var(--transition-fast),transform var(--transition-fast),background var(--transition-fast);box-shadow:var(--shadow-lg)}.back-to-top.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.back-to-top:hover{background:var(--color-teal-dark);transform:translateY(-2px);box-shadow:var(--shadow-xl)}.back-to-top:focus-visible{outline:2px solid var(--color-accent-teal);outline-offset:3px}.lesson-with-toc{display:grid;grid-template-columns:1fr;gap:var(--space-xl);align-items:start}@media(min-width:1100px){.lesson-with-toc{grid-template-columns:1fr var(--toc-width)}}.lesson-toc{display:none}@media(min-width:1100px){.lesson-toc{display:block;position:sticky;top:calc(var(--header-height) + var(--space-md));max-height:calc(100vh - var(--header-height) - 2rem);overflow-y:auto;scrollbar-width:thin}}.toc__link--h3{padding-inline-start:1.25rem;font-size:var(--text-xs)}@media print{.site-header,.mobile-menu,.mobile-menu__backdrop,.reading-progress,.back-to-top,.lesson-toc,.progress-action,.lesson-nav,.breadcrumbs,.lesson-progress,.skip-link,footer{display:none!important}body{font-size:11pt;color:#000;background:#fff}.site-layout{display:block}main{padding:0}.lesson-with-toc{display:block}pre,code{background:#f5f5f5!important;color:#000!important;border:1px solid #ccc!important;font-size:9pt;page-break-inside:avoid;white-space:pre-wrap;word-break:break-all}h1,h2{page-break-after:avoid}a[href]:after{content:" (" attr(href) ")";font-size:8pt;color:#555}a[href^="#"]:after,a[href^="javascript:"]:after{content:""}}
