@import"https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,300..900;1,8..60,300..900&family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";:root{--c-bg: #fefefe;--c-bg-alt: #f8fafc;--c-bg-interactive: linear-gradient(135deg, #eef2ff 0%, #f0f0ff 50%, #eef6ff 100%);--c-text: #0f172a;--c-text-2: #475569;--c-text-3: #94a3b8;--c-accent: #6366f1;--c-accent-hover: #4f46e5;--c-accent-light: #e0e7ff;--c-accent-glow: rgba(99, 102, 241, .15);--c-border: #e2e8f0;--c-border-interactive: #c7d2fe;--c-exercise-bg: #fffbeb;--c-exercise-border: #f59e0b;--c-exercise-text: #b45309;--c-tooltip-bg: #1e293b;--c-tooltip-text: #e2e8f0;--c-tooltip-arrow: #1e293b;--c-nav-bg: rgba(254, 254, 254, .88);--f-body: "Source Serif 4", Georgia, "Times New Roman", serif;--f-ui: "Inter", system-ui, -apple-system, sans-serif;--f-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--w-content: 720px;--w-wide: 960px;--w-full: 1200px}[data-theme=dark]{--c-bg: #0f172a;--c-bg-alt: #1e293b;--c-bg-interactive: linear-gradient(135deg, #1e1b4b 0%, #1a1a2e 50%, #172554 100%);--c-text: #e2e8f0;--c-text-2: #94a3b8;--c-text-3: #64748b;--c-accent: #818cf8;--c-accent-hover: #a5b4fc;--c-accent-light: #1e1b4b;--c-accent-glow: rgba(129, 140, 248, .2);--c-border: #334155;--c-border-interactive: #4338ca;--c-exercise-bg: #1c1917;--c-exercise-border: #d97706;--c-exercise-text: #fbbf24;--c-tooltip-bg: #e2e8f0;--c-tooltip-text: #0f172a;--c-tooltip-arrow: #e2e8f0;--c-nav-bg: rgba(15, 23, 42, .9)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:18px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--f-body);color:var(--c-text);background:var(--c-bg);line-height:1.75}.nav{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--c-nav-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border)}.nav-inner{max-width:var(--w-full);margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap}.nav-right{display:flex;align-items:center;gap:8px}.nav-hamburger{display:none;background:none;border:1px solid var(--c-border);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:1.2rem;color:var(--c-text-2)}.nav-hamburger:hover{border-color:var(--c-accent)}.nav-logo{font-family:var(--f-ui);font-weight:700;font-size:1.1rem;color:var(--c-text);text-decoration:none;letter-spacing:-.02em}.theme-toggle{background:none;border:1px solid var(--c-border);border-radius:6px;padding:4px 8px;cursor:pointer;font-size:1.1rem;line-height:1;color:var(--c-text-2);transition:border-color .2s}.theme-toggle:hover{border-color:var(--c-accent)}:root .theme-icon-dark{display:none}:root .theme-icon-light{display:inline}[data-theme=dark] .theme-icon-dark{display:inline}[data-theme=dark] .theme-icon-light{display:none}.nav-links{display:flex;gap:24px;list-style:none}.nav-links a{font-family:var(--f-ui);font-size:.85rem;font-weight:500;color:var(--c-text-2);text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--c-accent)}.nav-dropdown{position:relative}.nav-dropdown-label{font-family:var(--f-ui);font-size:.85rem;font-weight:500;color:var(--c-text-2);cursor:pointer;transition:color .2s}.nav-dropdown:hover .nav-dropdown-label,.nav-dropdown-label:hover{color:var(--c-accent)}.nav-dropdown-menu{display:none;position:absolute;top:100%;left:50%;transform:translate(-50%);padding-top:10px;list-style:none;min-width:220px;z-index:200}.nav-dropdown-menu:after{content:"";display:block;background:var(--c-bg);border:1px solid var(--c-border);border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:6px 0;position:absolute;inset:10px 0 0;z-index:-1}.nav-dropdown:hover .nav-dropdown-menu{display:block}.nav-dropdown-menu li a{display:block;padding:6px 16px;font-size:.83rem;white-space:nowrap;position:relative;z-index:1}.nav-dropdown-menu li:first-child a{padding-top:10px}.nav-dropdown-menu li:last-child a{padding-bottom:10px}.nav-dropdown-menu li a:hover{background:var(--c-bg-alt)}.article-header{max-width:var(--w-content);margin:0 auto;padding:120px 24px 40px}.article-header h1{font-family:var(--f-ui);font-size:2.5rem;font-weight:800;line-height:1.15;letter-spacing:-.03em;color:var(--c-text);margin-bottom:16px}.article-subtitle{font-family:var(--f-ui);font-size:1.15rem;font-weight:400;color:var(--c-text-2);line-height:1.5;margin-bottom:20px}.article-meta{font-family:var(--f-ui);font-size:.85rem;color:var(--c-text-3);display:flex;gap:24px}.chapter-label{font-family:var(--f-mono);font-size:.8rem;font-weight:600;color:var(--c-accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.article-content{max-width:var(--w-content);margin:0 auto;padding:0 24px 64px}.article-content h2{font-family:var(--f-ui);font-size:1.5rem;font-weight:700;letter-spacing:-.02em;margin-top:64px;margin-bottom:20px;color:var(--c-text)}.article-content h3{font-family:var(--f-ui);font-size:1.15rem;font-weight:600;margin-top:40px;margin-bottom:14px;color:var(--c-text)}.article-content p{margin-bottom:20px}.article-content strong{font-weight:700}.article-content em{font-style:italic}.article-content ul,.article-content ol{margin-bottom:20px;padding-left:28px}.article-content li{margin-bottom:8px}.article-content .lead{font-size:1.15rem;color:var(--c-text-2);line-height:1.7;margin-bottom:32px}.article-content .note{background:var(--c-exercise-bg);border-left:3px solid var(--c-exercise-border);padding:16px 20px;border-radius:0 8px 8px 0;margin:24px 0;font-size:.95rem}.interactive-panel{background:var(--c-bg-interactive);border:1px solid var(--c-border-interactive);border-radius:16px;padding:28px;margin:40px 0;position:relative;overflow:hidden}@media(min-width:800px){.interactive-panel{margin-left:-40px;margin-right:-40px;padding:28px 40px}}.interactive-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--c-accent),#818cf8,#a78bfa)}.interactive-title{font-family:var(--f-ui);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--c-accent);margin-bottom:20px}.viz-row{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}.viz-col{display:flex;flex-direction:column;align-items:center;gap:8px}.viz-label{font-family:var(--f-ui);font-size:.8rem;font-weight:600;color:var(--c-text-2);text-transform:uppercase;letter-spacing:.05em}canvas{border-radius:8px;box-shadow:0 1px 3px #00000014,0 0 0 1px #0000000a;background:var(--c-bg);max-width:100%;height:auto}.controls{display:flex;flex-direction:column;gap:14px;margin-top:20px}.slider-group{display:flex;align-items:center;gap:14px}.slider-label{font-family:var(--f-ui);font-size:.85rem;font-weight:500;color:var(--c-text-2);min-width:110px;flex-shrink:0}.slider-value{font-family:var(--f-mono);font-size:.85rem;color:var(--c-accent);min-width:55px;text-align:right;flex-shrink:0}input[type=range]{-webkit-appearance:none;appearance:none;flex:1;height:6px;border-radius:3px;background:var(--c-border);outline:none;transition:background .15s}input[type=range]:hover{background:var(--c-text-3)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--c-accent);cursor:pointer;box-shadow:0 1px 4px var(--c-accent-glow),0 0 0 3px var(--c-accent-light);transition:transform .15s,box-shadow .15s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 2px 8px var(--c-accent-glow),0 0 0 4px var(--c-accent-light)}input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--c-accent);cursor:pointer;border:none}select{font-family:var(--f-ui);font-size:.85rem;padding:8px 12px;border:1px solid var(--c-border);border-radius:8px;background:var(--c-bg);color:var(--c-text);cursor:pointer;outline:none;transition:border-color .15s}select:hover,select:focus{border-color:var(--c-accent)}.math-block{margin:28px 0;text-align:center;overflow-x:auto;padding:8px 0}.hero{text-align:center;padding:140px 24px 48px;max-width:var(--w-full);margin:0 auto}.hero h1{font-family:var(--f-ui);font-size:3.5rem;font-weight:800;letter-spacing:-.04em;line-height:1.1;background:linear-gradient(135deg,var(--c-text) 30%,var(--c-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px}.hero p{font-family:var(--f-ui);font-size:1.15rem;color:var(--c-text-2);max-width:560px;margin:0 auto 24px;line-height:1.6}.hero-stats{display:flex;justify-content:center;gap:32px;margin-bottom:48px;flex-wrap:wrap}.hero-stat{font-family:var(--f-ui);font-size:.85rem;color:var(--c-text-3)}.hero-stat-num{font-weight:700;font-size:1.3rem;color:var(--c-accent);display:block;line-height:1.2}.modules{max-width:var(--w-wide);margin:0 auto;padding:0 24px 80px}.module-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:16px;padding:32px;transition:box-shadow .2s,border-color .2s}.module-card:hover{box-shadow:0 8px 30px #0000000f;border-color:var(--c-accent-light)}.module-card h3{font-family:var(--f-ui);font-size:1.25rem;font-weight:700;margin-bottom:8px}.module-card>p{font-family:var(--f-ui);font-size:.9rem;color:var(--c-text-2);line-height:1.6}.module-number{font-family:var(--f-mono);font-size:.75rem;font-weight:600;color:var(--c-accent);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}.module-details{margin-top:16px}.module-details summary{font-family:var(--f-ui);font-size:.82rem;font-weight:500;color:var(--c-accent);cursor:pointer;list-style:none}.module-details summary:before{content:"▸ "}.module-details[open] summary:before{content:"▾ "}.module-details summary::-webkit-details-marker{display:none}.article-list{list-style:none;margin-top:12px;padding:0}.article-list li{border-top:1px solid var(--c-border)}.article-list a,.article-list .disabled{display:flex;align-items:center;gap:12px;padding:14px 0;font-family:var(--f-ui);font-size:.9rem;text-decoration:none;color:var(--c-text);transition:color .2s}.article-list a:hover{color:var(--c-accent)}.article-list .disabled{color:var(--c-text-3)}.article-list .num{font-family:var(--f-mono);font-size:.8rem;color:var(--c-text-3);min-width:24px}.badge{margin-left:auto;font-size:.7rem;font-weight:600;background:var(--c-accent-light);color:var(--c-accent);padding:2px 10px;border-radius:4px;letter-spacing:.02em}.gl{border-bottom:1.5px dotted var(--c-accent);cursor:help;position:relative}.gl:hover:before{content:attr(data-tip);position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--c-tooltip-bg);color:var(--c-tooltip-text);padding:8px 14px;border-radius:8px;font-family:var(--f-ui);font-size:.8rem;font-weight:400;line-height:1.5;white-space:normal;width:max-content;max-width:300px;z-index:100;box-shadow:0 4px 16px #0003;pointer-events:none;animation:gl-in .15s ease-out}.gl:hover:after{content:"";position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--c-tooltip-arrow);z-index:100;pointer-events:none}@keyframes gl-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}details.derivation{margin:1.5rem 0;border-left:3px solid var(--c-accent);border-radius:0 8px 8px 0;background:var(--c-bg-alt)}details.derivation summary{padding:12px 16px;font-family:var(--f-ui);font-size:.88rem;font-weight:500;color:var(--c-accent);cursor:pointer;list-style:none;user-select:none}details.derivation summary::-webkit-details-marker{display:none}details.derivation summary:before{content:"▸ ";font-size:.85rem}details.derivation[open] summary:before{content:"▾ "}details.derivation[open] summary{margin-bottom:4px}details.derivation .derivation-content{padding:0 16px 16px;font-size:.93rem;line-height:1.75;color:var(--c-text-2)}details.derivation .derivation-content p{margin-bottom:.8rem}details.derivation .derivation-content .math-block{margin:1rem 0}.exercise{margin:2rem 0;border-left:3px solid var(--c-exercise-border);border-radius:0 8px 8px 0;background:var(--c-exercise-bg);padding:16px}.exercise-header{font-family:var(--f-ui);font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--c-exercise-text);margin-bottom:8px}.exercise p{font-size:.95rem;line-height:1.7;margin-bottom:.6rem;color:var(--c-text)}.exercise details{margin-top:10px}.exercise details summary{font-family:var(--f-ui);font-size:.82rem;font-weight:500;color:var(--c-exercise-text);cursor:pointer;list-style:none;user-select:none}.exercise details summary::-webkit-details-marker{display:none}.exercise details summary:before{content:"▸ ";font-size:.8rem}.exercise details[open] summary:before{content:"▾ "}.exercise details .solution{margin-top:8px;padding:10px 12px;background:#f59e0b14;border-radius:6px;font-size:.9rem;line-height:1.6;color:var(--c-text-2)}.reading-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--c-accent);z-index:200;transition:width .1s linear}.toc{max-width:var(--w-content);margin:0 auto;padding:0 24px}.toc:empty{display:none}.toc .toc-title{font-family:var(--f-ui);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--c-text-3);margin-bottom:8px}.toc ul{list-style:none;padding:16px 20px;background:var(--c-bg-alt);border:1px solid var(--c-border);border-radius:8px;margin-bottom:32px;columns:2;column-gap:24px}.toc li{break-inside:avoid;padding:3px 0}.toc a{font-family:var(--f-ui);font-size:.85rem;color:var(--c-text-2);text-decoration:none;transition:color .15s}.toc a:hover{color:var(--c-accent)}.back-to-top{position:fixed;bottom:32px;right:32px;width:40px;height:40px;border-radius:50%;border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-text-2);font-size:1.2rem;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s,border-color .2s;z-index:90;box-shadow:0 2px 8px #0000001a}.back-to-top.visible{opacity:1;pointer-events:auto}.back-to-top:hover{border-color:var(--c-accent);color:var(--c-accent)}.article-nav{max-width:720px;margin:0 auto;padding:0 24px}.article-nav-inner{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:32px 0;border-top:1px solid var(--c-border)}.article-nav-link{display:flex;flex-direction:column;gap:4px;text-decoration:none;max-width:45%}.article-nav-prev{text-align:left}.article-nav-next{text-align:right;margin-left:auto}.article-nav-direction{font-family:var(--f-ui);font-size:.8rem;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.05em}.article-nav-title{font-family:var(--f-ui);font-size:.95rem;font-weight:600;color:var(--c-accent)}.article-nav-link:hover .article-nav-title{text-decoration:underline}.article-nav-module{font-family:var(--f-ui);font-size:.8rem;color:var(--c-text-3);text-decoration:none;align-self:center;flex-shrink:0}.article-nav-module:hover{color:var(--c-accent)}.site-footer{text-align:center;padding:48px 24px;font-family:var(--f-ui);font-size:.85rem;color:var(--c-text-3);border-top:1px solid var(--c-border)}@media(max-width:640px){html{font-size:16px}.hero h1{font-size:2.5rem}.article-header h1{font-size:1.8rem}.article-header,.hero{padding-top:100px}.viz-row{flex-direction:column;align-items:center}.viz-col canvas{max-width:100%!important;height:auto!important}.slider-group{flex-wrap:wrap}.slider-label{min-width:100%}.slider-group input[type=range]{min-width:120px;flex:1}.interactive-panel{margin-left:-16px;margin-right:-16px;padding:20px 12px;border-radius:12px}.controls{gap:8px}.module-card{padding:20px 16px}.nav-hamburger{display:block}.nav-links{display:none;width:100%;flex-direction:column;gap:4px;padding-top:12px;font-size:.9rem}.nav-links.nav-open{display:flex}.nav-links a{padding:6px 0}.nav-dropdown-menu{position:static;transform:none;margin-top:4px;box-shadow:none;border:none;padding:0 0 0 12px;min-width:auto;display:none}.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown-menu{display:block}.nav-dropdown-menu li a{padding:4px 0}.method-grid{grid-template-columns:repeat(2,1fr)}.detail-row{flex-direction:column;gap:4px}.detail-label{width:auto}.gl:hover:before{left:0;transform:none;max-width:220px}.gl:hover:after{left:20px;transform:none}.toc ul{columns:1}.back-to-top{bottom:16px;right:16px}.article-nav-inner{flex-wrap:wrap}.article-nav-link{max-width:100%}.article-nav-module{order:-1;width:100%;text-align:center;margin-bottom:8px}}
