*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{--bg: #fffdf6;--bg-surface: #faf6e9;--bg-card: #f3eed8;--bg-card-h: #ece7d0;--bg-code: #f0ecd8;--green: #a0c878;--gold: #c89640;--diamond: #45c4d0;--red: #c0533a;--text: #1e2818;--text-sec: #4a6030;--text-muted: #7a9058;--border: #ddeb9d;--border-subtle: #e8e4cc;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--radius: 5px;--radius-lg: 10px}body{background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:#a0c87859;color:var(--text)}.skip-link{position:absolute;top:-100px;left:12px;padding:8px 16px;background:var(--green);color:#0a0c0b;font-family:var(--font-mono);font-size:13px;font-weight:700;border-radius:0 0 4px 4px;z-index:9999;text-decoration:none;transition:top .15s}.skip-link:focus{top:0}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}a{color:inherit}strong{color:var(--text);font-weight:600}button:focus-visible{outline:2px solid var(--green);outline-offset:2px}.tutorial-list{font-family:var(--font-body);font-size:15px;color:var(--text-sec);line-height:2;margin:0 0 20px;padding-left:22px}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;border-bottom:1px solid transparent;transition:background .25s,border-color .25s}.navbar.scrolled{background:#fffdf6f7;backdrop-filter:blur(14px);border-bottom-color:var(--border-subtle)}.navbar.menu-open{background:#fffdf6fc}.navbar-inner{max-width:1200px;margin:0 auto;padding:0 28px;height:60px;display:flex;align-items:center}.navbar-wordmark{font-family:var(--font-body);font-size:15px;font-weight:800;color:var(--text);letter-spacing:-.02em;text-decoration:none;margin-right:28px}.navbar-links{display:flex;gap:2px;list-style:none}.navbar-links a{padding:6px 14px;border-radius:var(--radius);font-family:var(--font-body);font-size:14px;font-weight:400;color:var(--text-sec);text-decoration:none;transition:color .15s}.navbar-links a:hover,.navbar-links a[aria-current=page]{color:var(--text);font-weight:600}.navbar-cta{padding:8px 20px;background:var(--green);color:#fffdf6;border:none;border-radius:2px;font-family:var(--font-mono);font-size:12px;font-weight:700;cursor:pointer;letter-spacing:.04em;text-decoration:none;transition:opacity .15s}.navbar-cta:hover{opacity:.82}.navbar-spacer{margin-left:auto;display:flex;align-items:center;gap:12px}.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}.hamburger-bar{width:22px;height:2px;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}.mobile-menu{display:none;background:#fffdf6fc;border-top:1px solid var(--border-subtle);padding:8px 28px 24px;flex-direction:column}.mobile-menu a{border-bottom:1px solid var(--border-subtle);padding:14px 0;font-family:var(--font-body);font-size:18px;color:var(--text-sec);text-decoration:none}.mobile-menu a[aria-current=page]{font-weight:700;color:var(--text)}.mobile-menu-cta{margin-top:16px;padding:14px 24px;background:var(--green);color:#fffdf6;border:none;border-radius:2px;font-family:var(--font-mono);font-size:13px;font-weight:700;text-decoration:none;text-align:center;cursor:pointer}@media(max-width:720px){.navbar-links,.navbar-cta{display:none}.hamburger,.mobile-menu.open{display:flex}}.footer-link{font-family:var(--font-body);font-size:13px;color:var(--text-muted);text-decoration:none;line-height:2;transition:color .15s}.footer-link:hover{color:var(--text-sec)}.btn-primary{display:inline-block;padding:14px 30px;background:var(--green);color:#fffdf6;border:none;border-radius:2px;font-family:var(--font-body);font-size:15px;font-weight:700;cursor:pointer;letter-spacing:.01em;text-decoration:none;transition:opacity .15s}.btn-primary:hover{opacity:.82}.btn-secondary{display:inline-block;padding:14px 30px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:2px;font-family:var(--font-body);font-size:15px;font-weight:500;cursor:pointer;text-decoration:none;transition:border-color .15s}.btn-secondary:hover{border-color:var(--text-sec)}.tutorial-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:10px;text-decoration:none;transition:border-color .15s,background .15s}.tutorial-card:hover{background:var(--bg-card-h);border-color:var(--border)}.series-btn{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:7px 14px;border:1px solid var(--border-subtle);border-radius:2px;background:transparent;text-decoration:none;transition:all .15s}.series-btn:hover{border-color:var(--border);background:var(--bg-card)}.series-btn.current{border-color:var(--diamond);background:#45c4d01a;cursor:default;pointer-events:none}.toc-btn{text-align:left;background:none;border:none;cursor:pointer;padding:6px 10px;border-radius:3px;border-left:2px solid transparent;font-family:var(--font-body);font-size:13px;color:var(--text-muted);line-height:1.4;transition:all .15s;text-decoration:none;display:block;width:100%}.toc-btn:hover{color:var(--text-sec)}.toc-btn.active{border-left-color:var(--green);color:var(--text)}.mod-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden;transition:border-color .15s;display:flex;flex-direction:column}.mod-card:hover{border-color:var(--border)}.about-link{font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text);text-decoration:none;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:3px;transition:background .15s}.about-link:hover{background:#5cc44e21}@media(max-width:768px){.grid-2col,.grid-3col{grid-template-columns:1fr!important}.hide-mobile{display:none!important}}@media(max-width:1080px){.grid-3col{grid-template-columns:1fr 1fr!important}.hide-tablet{display:none!important}}@media(max-width:768px){.footer-grid[data-astro-cid-37fxchfa]{grid-template-columns:1fr!important}}
