:root{--brand-primary: #6366f1;--brand-accent: #f59e0b;--bg: #ffffff;--bg-alt: #f8fafc;--bg-code: #0f172a;--surface: #ffffff;--border: #e2e8f0;--border-focus: var(--brand-primary);--text: #0f172a;--text-muted: #64748b;--text-inv: #ffffff;--link: var(--brand-primary);--link-hover: color-mix(in srgb, var(--brand-primary) 80%, black);--callout-note: #3b82f6;--callout-tip: #10b981;--callout-warn: #f59e0b;--callout-danger: #ef4444;--callout-quote: #8b5cf6;--diff-beginner: #10b981;--diff-intermediate: #f59e0b;--diff-advanced: #ef4444}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:1rem;line-height:1.75;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.3;color:var(--text);margin-top:2rem;margin-bottom:.75rem}h1:first-child,h2:first-child,h3:first-child,h4:first-child,h5:first-child,h6:first-child{margin-top:0}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}p{margin-bottom:1rem}a{color:var(--link);text-decoration:none}a:hover{color:var(--link-hover);text-decoration:underline}ul,ol{margin:0 0 1rem 1.5rem}ul li,ol li{margin-bottom:.25rem}hr{border:none;border-top:1px solid var(--border);margin:2rem 0}table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.9rem}table th,table td{text-align:left;padding:.5rem 1rem;border-bottom:1px solid var(--border)}table th{font-weight:600;background:var(--bg-alt);color:var(--text)}table tr:hover td{background:var(--bg-alt)}img{max-width:100%;height:auto;border-radius:8px}strong{font-weight:600}blockquote{border-left:3px solid var(--brand-primary);padding:.75rem 1rem .75rem 1.5rem;margin:1.5rem 0;color:var(--text-muted);font-style:italic}code:not(pre code){font-family:"JetBrains Mono","Fira Code","Cascadia Code",monospace;font-size:.875em;background:var(--bg-alt);border:1px solid var(--border);border-radius:4px;padding:.15em .4em;color:var(--brand-primary)}.site-header{position:sticky;top:0;z-index:100;height:60px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:0 1px 3px rgba(0,0,0,.06)}.site-header--dark{background:var(--brand-primary);border-bottom-color:rgba(0,0,0,0)}.site-header--dark .site-header__logo-text,.site-header--dark .site-nav__link,.site-header--dark .site-header__menu-toggle{color:var(--text-inv)}.site-header--dark .site-nav__link:hover{opacity:.85;color:var(--text-inv)}.site-header--dark .site-nav__link.is-active{color:var(--text-inv);border-bottom-color:hsla(0,0%,100%,.6)}.site-header__inner{max-width:1200px;margin:0 auto;padding:0 1.5rem;height:100%;display:flex;align-items:center;gap:1rem}.site-header__logo{display:flex;align-items:center;flex-shrink:0;text-decoration:none}.site-header__logo img{height:36px;width:auto}.site-header__logo-text{font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:-0.02em}.site-nav{display:flex;align-items:center;gap:.25rem;margin-left:auto}.site-nav__link{padding:.5rem .75rem;font-size:.9rem;font-weight:500;color:var(--text-muted);border-radius:8px;border-bottom:2px solid rgba(0,0,0,0);transition:color 120ms ease,background 120ms ease;text-decoration:none}.site-nav__link:hover{color:var(--text);background:var(--bg-alt);text-decoration:none}.site-nav__link.is-active{color:var(--brand-primary);background:var(--bg-alt)}.site-header__menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text);margin-left:auto;border-radius:8px}.site-header__menu-toggle:hover{background:var(--bg-alt)}@media(max-width: 768px){.site-nav{display:none;position:absolute;top:60px;left:0;right:0;background:var(--surface);border-bottom:1px solid var(--border);flex-direction:column;align-items:stretch;padding:.75rem 1.5rem;gap:.25rem;box-shadow:0 4px 12px rgba(0,0,0,.08)}.site-nav.is-open{display:flex}.site-header__menu-toggle{display:flex}.site-header__inner{position:relative}}.hero{background:linear-gradient(135deg, color-mix(in srgb, var(--brand-primary) 90%, transparent) 0%, color-mix(in srgb, var(--brand-primary) 70%, var(--brand-accent)) 100%);padding:4rem 1.5rem;color:var(--text-inv);text-align:center}.hero__inner{max-width:640px;margin:0 auto}.hero__title{font-size:clamp(1.8rem,5vw,3rem);font-weight:800;color:var(--text-inv);margin-bottom:.75rem;letter-spacing:-0.03em}.hero__tagline{font-size:1.15rem;opacity:.88;margin-bottom:2rem;color:var(--text-inv)}.site-main{min-height:calc(100vh - 60px - 64px)}.home-content{max-width:1200px;margin:0 auto;padding:3rem 1.5rem}.prose-page{max-width:680px;margin:0 auto;padding:3rem 1.5rem}.section-title{font-size:1rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:1rem;margin-top:0;display:flex;align-items:center;gap:.5rem}.section-title svg{width:15px;height:15px}.article-page{max-width:calc(780px + 240px + 3rem);margin:0 auto;padding:3rem 1.5rem}.article-header{max-width:780px;margin:0 0 2rem;padding-bottom:2rem;border-bottom:1px solid var(--border);position:relative}.edit-on-github{position:absolute;top:0;right:0;display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:8px;font-size:.78rem;font-weight:500;color:var(--text-muted);text-decoration:none;opacity:.45;transition:opacity 120ms ease,background 120ms ease,color 120ms ease}.edit-on-github svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}.edit-on-github:hover{opacity:1;background:var(--bg-alt);color:var(--text);text-decoration:none}.article-header__back{display:inline-flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-muted);margin-bottom:1.5rem;transition:color 120ms ease}.article-header__back svg{width:14px;height:14px}.article-header__back:hover{color:var(--brand-primary);text-decoration:none}.article-header__emoji{font-size:3rem;line-height:1;margin-bottom:1rem}.article-header__title{font-size:clamp(1.5rem,4vw,2.25rem);letter-spacing:-0.02em;margin-top:0;margin-bottom:.75rem}.article-header__desc{font-size:1.1rem;color:var(--text-muted);margin-bottom:1rem}.article-header__meta{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;font-size:.875rem;color:var(--text-muted)}.article-header__meta svg{width:13px;height:13px}.article-meta__date,.article-meta__author{display:inline-flex;align-items:center;gap:.25rem}.article-header__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.article-layout{display:grid;grid-template-columns:minmax(0, 1fr) 240px;gap:3rem;align-items:start}@media(max-width: 1024px){.article-layout{grid-template-columns:1fr}.article-sidebar{order:-1;display:grid;grid-template-columns:1fr 1fr;gap:1rem}}@media(max-width: 768px){.article-sidebar{grid-template-columns:1fr}.article-page{padding:2rem 1rem}.home-content{padding:2rem 1rem}}.article-content h2{margin-top:3rem}.article-content h3{margin-top:2rem}.article-content h2,.article-content h3{scroll-margin-top:calc(60px + 1rem)}.article-sidebar{position:sticky;top:calc(60px + 1.5rem)}.site-footer{border-top:1px solid var(--border);padding:1.5rem;background:var(--bg-alt)}.site-footer__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.85rem;color:var(--text-muted)}.site-footer__brand{font-weight:600;color:var(--text)}.site-footer__sep{opacity:.4}.site-footer__feed{display:inline-flex;align-items:center;gap:.25rem}.site-footer__feed svg{width:13px;height:13px}.article-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));gap:1.5rem;margin-top:1rem}.search-wrap{position:relative;max-width:480px;margin:0 auto}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);width:18px;height:18px;color:hsla(0,0%,100%,.6);pointer-events:none}.search-input{width:100%;padding:.75rem 1rem .75rem 2.5rem;font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:1rem;background:hsla(0,0%,100%,.15);border:1px solid hsla(0,0%,100%,.3);border-radius:9999px;color:#fff;outline:none;transition:background 120ms ease,border-color 120ms ease,box-shadow 120ms ease;backdrop-filter:blur(4px)}.search-input::placeholder{color:hsla(0,0%,100%,.6)}.search-input:focus{background:hsla(0,0%,100%,.25);border-color:hsla(0,0%,100%,.6);box-shadow:0 0 0 3px hsla(0,0%,100%,.15)}.tag{display:inline-flex;align-items:center;gap:3px;padding:2px 10px;font-size:.78rem;font-weight:500;border-radius:9999px;background:color-mix(in srgb, var(--tag-color, var(--brand-primary)) 12%, transparent);color:color-mix(in srgb, var(--tag-color, var(--brand-primary)) 90%, #000);border:1px solid color-mix(in srgb, var(--tag-color, var(--brand-primary)) 25%, transparent);cursor:pointer;transition:background 120ms ease,transform 120ms ease;white-space:nowrap}.tag:hover{background:color-mix(in srgb, var(--tag-color, var(--brand-primary)) 20%, transparent);transform:translateY(-1px)}.tag.is-active{background:var(--tag-color, var(--brand-primary));color:#fff;border-color:rgba(0,0,0,0)}.tag-cloud-section{margin-bottom:3rem}.tag-cloud{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.tag-filter{display:inline-flex;align-items:center;padding:2px 10px;font-size:.78rem;font-weight:500;border-radius:9999px;background:var(--bg-alt);color:var(--text-muted);border:1px solid var(--border);cursor:pointer;font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;transition:all 120ms ease}.tag-filter:hover,.tag-filter.is-active{background:var(--brand-primary);color:#fff;border-color:rgba(0,0,0,0)}.article-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;color:var(--text);transition:box-shadow 220ms ease,transform 220ms ease,border-color 220ms ease;height:100%;position:relative}.article-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.1);transform:translateY(-2px);border-color:var(--brand-primary)}.article-card__emoji{font-size:2.25rem;line-height:1;margin-bottom:1rem}.article-card__title{font-size:1.05rem;font-weight:600;margin:0 0 .5rem;line-height:1.4}.article-card__link{color:var(--text);text-decoration:none}.article-card__link::after{content:"";position:absolute;inset:0;border-radius:12px}.article-card__link:hover{color:var(--text);text-decoration:none}.article-card__meta{position:relative;z-index:1}.article-card__desc{font-size:.875rem;color:var(--text-muted);margin-bottom:1rem;flex:1;line-height:1.6}.article-card__meta{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-top:auto}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:9999px}.badge svg{width:11px;height:11px}.badge--beginner{background:color-mix(in srgb, var(--diff-beginner) 12%, transparent);color:var(--diff-beginner);border:1px solid color-mix(in srgb, var(--diff-beginner) 30%, transparent)}.badge--intermediate{background:color-mix(in srgb, var(--diff-intermediate) 12%, transparent);color:var(--diff-intermediate);border:1px solid color-mix(in srgb, var(--diff-intermediate) 30%, transparent)}.badge--advanced{background:color-mix(in srgb, var(--diff-advanced) 12%, transparent);color:var(--diff-advanced);border:1px solid color-mix(in srgb, var(--diff-advanced) 30%, transparent)}.badge--outdated{background:color-mix(in srgb, #94a3b8 15%, transparent);color:#64748b;border:1px solid #e2e8f0}.callout{border-radius:8px;padding:1rem 1.5rem;margin:1.5rem 0;border-left:4px solid;font-size:.95rem}.callout>strong:first-child,.callout>p>strong:first-child{display:block;font-size:.8rem;text-transform:uppercase;letter-spacing:.07em;margin-bottom:.5rem;opacity:.75}.callout p:last-child{margin-bottom:0}.callout code:not(pre code){border:1px solid currentColor;opacity:.8}.callout-note{background:color-mix(in srgb, var(--callout-note) 8%, transparent);border-color:var(--callout-note);color:color-mix(in srgb, var(--callout-note) 85%, #000)}.callout-tip{background:color-mix(in srgb, var(--callout-tip) 8%, transparent);border-color:var(--callout-tip);color:color-mix(in srgb, var(--callout-tip) 85%, #000)}.callout-warn{background:color-mix(in srgb, var(--callout-warn) 10%, transparent);border-color:var(--callout-warn);color:color-mix(in srgb, var(--callout-warn) 80%, #000)}.callout-danger{background:color-mix(in srgb, var(--callout-danger) 8%, transparent);border-color:var(--callout-danger);color:color-mix(in srgb, var(--callout-danger) 85%, #000)}.callout-quote{background:color-mix(in srgb, var(--callout-quote) 8%, transparent);border-color:var(--callout-quote);color:color-mix(in srgb, var(--callout-quote) 85%, #000)}.highlight-wrap{position:relative;margin:1.5rem 0}.highlight{background:var(--bg-code) !important;border-radius:12px;overflow:hidden;margin:0}.highlight pre{overflow-x:auto;padding:1.5rem;margin:0;background:rgba(0,0,0,0) !important;font-family:"JetBrains Mono","Fira Code","Cascadia Code",monospace;font-size:.875rem;line-height:1.65;color:#e2e8f0}.highlight[data-lang]::before{content:attr(data-lang);display:block;padding:.5rem 1rem;background:hsla(0,0%,100%,.06);font-family:"JetBrains Mono","Fira Code","Cascadia Code",monospace;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:#94a3b8;border-bottom:1px solid hsla(0,0%,100%,.07)}.copy-btn{position:absolute;top:.5rem;right:.5rem;padding:.25rem .75rem;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.15);border-radius:4px;color:#94a3b8;font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:.72rem;font-weight:500;cursor:pointer;transition:all 120ms ease;display:inline-flex;align-items:center;gap:.25rem}.copy-btn svg{width:12px;height:12px}.copy-btn:hover{background:hsla(0,0%,100%,.2);color:#e2e8f0}.copy-btn.copied{background:color-mix(in srgb, var(--callout-tip) 25%, transparent);color:var(--callout-tip);border-color:var(--callout-tip)}.toc{background:var(--bg-alt);border:1px solid var(--border);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem}.toc__title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.toc__title svg{width:13px;height:13px}#toc-nav ol{list-style:none;margin:0;padding:0}#toc-nav li{margin:.25rem 0}#toc-nav a{font-size:.85rem;color:var(--text-muted);display:block;padding:1px 0;border-left:2px solid rgba(0,0,0,0);padding-left:.75rem;transition:color 120ms ease,border-color 120ms ease}#toc-nav a:hover{color:var(--brand-primary);text-decoration:none;border-left-color:var(--brand-primary)}#toc-nav a.toc-active{color:var(--brand-primary);border-left-color:var(--brand-primary);font-weight:500}#toc-nav ol ol a{padding-left:1.5rem;font-size:.82rem}.related-articles{background:var(--bg-alt);border:1px solid var(--border);border-radius:12px;padding:1rem 1.5rem}.related-articles__title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.related-articles__title svg{width:13px;height:13px}.related-articles__list{list-style:none;margin:0;padding:0}.related-articles__list li{margin-bottom:.5rem}.related-articles__list a{font-size:.875rem;color:var(--text);display:flex;align-items:baseline;gap:.5rem}.related-articles__list a:hover{color:var(--brand-primary);text-decoration:none}.tags-page{max-width:780px;margin:0 auto;padding:3rem 1.5rem}.tag-group{margin-bottom:2rem}.tag-group__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.tag-group__count{font-size:.8rem;color:var(--text-muted);font-weight:normal}.tag-group__page-link{text-decoration:none}.tag-group__page-link:hover .tag{transform:translateY(-1px)}.tag-page-header{margin:1.5rem 0 2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.tag-page-header .tag{font-size:1rem;padding:.25rem 1rem}.tag-page-header__desc{margin-top:.75rem;color:var(--text-muted);font-size:1rem}.tag-group__articles{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.tag-group__article{display:flex;align-items:center;gap:.75rem;font-size:.925rem}.tag-group__article .emoji{font-size:1.1rem}.no-results{text-align:center;color:var(--text-muted);padding:3rem;font-size:1rem}.highlight .hll{background-color:#1e293b}.highlight .c{color:#64748b;font-style:italic}.highlight .err{color:#f87171}.highlight .k{color:#c084fc;font-weight:600}.highlight .l{color:#34d399}.highlight .n{color:#e2e8f0}.highlight .o{color:#94a3b8}.highlight .p{color:#94a3b8}.highlight .cm{color:#64748b;font-style:italic}.highlight .cp{color:#64748b}.highlight .c1{color:#64748b;font-style:italic}.highlight .cs{color:#64748b;font-style:italic}.highlight .gd{color:#f87171}.highlight .ge{font-style:italic}.highlight .gh{color:#e2e8f0;font-weight:bold}.highlight .gi{color:#34d399}.highlight .gp{color:#64748b}.highlight .gs{font-weight:bold}.highlight .gu{color:#38bdf8;font-weight:bold}.highlight .kc{color:#c084fc;font-weight:600}.highlight .kd{color:#c084fc;font-weight:600}.highlight .kn{color:#c084fc;font-weight:600}.highlight .kp{color:#c084fc}.highlight .kr{color:#c084fc;font-weight:600}.highlight .kt{color:#38bdf8}.highlight .ld{color:#34d399}.highlight .m{color:#fb923c}.highlight .s{color:#34d399}.highlight .na{color:#38bdf8}.highlight .nb{color:#38bdf8}.highlight .nc{color:#38bdf8;font-weight:600}.highlight .nd{color:#c084fc}.highlight .ne{color:#f87171;font-weight:600}.highlight .nf{color:#38bdf8}.highlight .nl{color:#e2e8f0}.highlight .nn{color:#38bdf8}.highlight .nx{color:#38bdf8}.highlight .py{color:#e2e8f0}.highlight .nt{color:#f472b6}.highlight .nv{color:#e2e8f0}.highlight .ow{color:#c084fc;font-weight:600}.highlight .w{color:#e2e8f0}.highlight .mf{color:#fb923c}.highlight .mh{color:#fb923c}.highlight .mi{color:#fb923c}.highlight .mo{color:#fb923c}.highlight .sb{color:#34d399}.highlight .sc{color:#34d399}.highlight .sd{color:#64748b;font-style:italic}.highlight .s2{color:#34d399}.highlight .se{color:#fb923c;font-weight:600}.highlight .sh{color:#34d399}.highlight .si{color:#fb923c}.highlight .sx{color:#34d399}.highlight .sr{color:#34d399}.highlight .s1{color:#34d399}.highlight .ss{color:#34d399}.highlight .bp{color:#38bdf8}.highlight .vc{color:#e2e8f0}.highlight .vg{color:#e2e8f0}.highlight .vi{color:#e2e8f0}.highlight .il{color:#fb923c}/*# sourceMappingURL=main.css.map */