:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", sans-serif;--font-display: "Space Grotesk", "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "SFMono-Regular", "Fira Code", Consolas, "Liberation Mono", Menlo, monospace;--max-width: 720px;--max-width-wide: 1100px;--radius: 14px;--radius-sm: 8px;--step-fluid: clamp(1rem, calc(0.92rem + 0.4vw), 1.0625rem)}:root,:root[data-theme="light"]{--bg: #ffffff;--bg-subtle: #f6f8fa;--bg-code: #f6f8fa;--surface: #ffffff;--border: #d8dee4;--border-subtle: #eaecef;--text: #1f2328;--text-muted: #59636e;--heading: #11151a;--accent: #0969da;--accent-hover: #0a5cc7;--tag-bg: #ddf4ff;--tag-text: #0550ae;--shadow: 0 1px 2px rgba(31, 35, 40, 0.06), 0 4px 16px rgba(31, 35, 40, 0.06)}:root[data-theme="dark"]{--bg: #0d1117;--bg-subtle: #161b22;--bg-code: #161b22;--surface: #161b22;--border: #30363d;--border-subtle: #21262d;--text: #e6edf3;--text-muted: #9198a1;--heading: #f0f6fc;--accent: #4493f8;--accent-hover: #6cb0fc;--tag-bg: #1f2d3d;--tag-text: #79c0ff;--shadow: 0 1px 2px rgba(0, 0, 0, 0.3), 0 6px 20px rgba(0, 0, 0, 0.35)}*,*::before,*::after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}}body{margin:0;font-family:var(--font-sans);font-size:var(--step-fluid);line-height:1.7;color:var(--text);background-color:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;display:flex;flex-direction:column;min-height:100vh;transition:background-color 0.2s ease, color 0.2s ease}h1,h2,h3,h4,h5,h6{color:var(--heading);font-family:var(--font-display);line-height:1.2;font-weight:600;margin:2em 0 0.6em;letter-spacing:-0.02em}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.2rem}p,ul,ol,blockquote,table,pre{margin:0 0 1.25em}a{color:var(--accent);text-decoration:none;text-underline-offset:0.18em}a:hover{color:var(--accent-hover);text-decoration:underline}img{max-width:100%;height:auto;border-radius:var(--radius-sm)}hr{border:0;border-top:1px solid var(--border-subtle);margin:2.5em 0}blockquote{margin-left:0;padding:0.2em 1.1em;border-left:3px solid var(--accent);color:var(--text-muted);font-style:italic}table{width:100%;border-collapse:collapse;font-size:0.95em}th,td{padding:0.55em 0.8em;border:1px solid var(--border);text-align:left}th{background:var(--bg-subtle);font-weight:640}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:3px}.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:0.6em 1em;z-index:100;border-radius:0 0 var(--radius-sm) 0}.skip-link:focus{left:0}code{font-family:var(--font-mono);font-size:0.875em}:not(pre)>code{background:var(--bg-code);padding:0.15em 0.4em;border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.wrapper{max-width:var(--max-width);margin-inline:auto;padding-inline:1.25rem}.site-main{flex:1 0 auto;width:100%;max-width:var(--max-width-wide);margin-inline:auto;padding:2.5rem 1.25rem 4rem}.post,.page,.hero{max-width:var(--max-width);margin-inline:auto}.site-header{position:sticky;top:0;z-index:50;background:color-mix(in srgb, var(--bg) 85%, transparent);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border-subtle)}.site-header__inner{display:flex;align-items:center;gap:1rem;height:60px;max-width:var(--max-width-wide)}.site-header__brand{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--heading);letter-spacing:-0.02em;margin-right:auto}.site-header__brand:hover{text-decoration:none;color:var(--accent)}.site-nav{display:flex;align-items:center}.site-nav__links{display:flex;gap:0.4rem;list-style:none;margin:0;padding:0}.site-nav__links a{color:var(--text-muted);padding:0.4em 0.7em;border-radius:var(--radius-sm);font-size:0.95rem;font-weight:500}.site-nav__links a:hover{color:var(--text);background:var(--bg-subtle);text-decoration:none}.site-nav__links a[aria-current="page"]{color:var(--accent)}.site-nav__toggle{display:none;background:none;border:0;cursor:pointer;width:40px;height:40px;position:relative;color:var(--text)}.site-nav__bars,.site-nav__bars::before,.site-nav__bars::after{content:"";position:absolute;left:9px;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform 0.2s ease}.site-nav__bars{top:19px}.site-nav__bars::before{top:-7px}.site-nav__bars::after{top:7px}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;transition:border-color 0.15s ease, color 0.15s ease}.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}.theme-toggle__moon{display:none}:root[data-theme="dark"] .theme-toggle__sun{display:none}:root[data-theme="dark"] .theme-toggle__moon{display:block}.site-footer{flex-shrink:0;border-top:1px solid var(--border-subtle);padding:2rem 0;margin-top:3rem;font-size:0.9rem;color:var(--text-muted)}.site-footer__inner{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between;max-width:var(--max-width-wide)}.site-footer__copy{margin:0}.site-footer__social{display:flex;gap:1.1rem;list-style:none;margin:0;padding:0}.site-footer__social a{color:var(--text-muted)}.site-footer__social a:hover{color:var(--accent)}@media (max-width: 600px){.site-nav__toggle{display:block}.site-nav__links{position:absolute;top:60px;right:0;left:0;flex-direction:column;gap:0;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);padding:0.5rem 1rem 1rem;display:none}.site-nav__links.is-open{display:flex}.site-nav__links a{display:block;padding:0.7em 0.5em}}.hero{padding:1.5rem 0 2.5rem;margin-bottom:2.5rem;border-bottom:1px solid var(--border-subtle)}.hero__eyebrow{margin:0 0 0.6rem;font-family:var(--font-mono);font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--accent)}.hero__title{margin:0 0 0.5rem;font-size:clamp(2rem, calc(1.4rem + 2.4vw), 3rem)}.hero__tagline{margin:0;font-size:1.2rem;color:var(--text-muted);max-width:46ch}.section-title{font-size:0.85rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.1em;color:var(--text-muted);margin:0 0 1.25rem;padding-bottom:0.6rem;border-bottom:1px solid var(--border-subtle)}.post-card__meta{display:flex;align-items:center;gap:0.6rem;font-size:0.8rem;color:var(--text-muted);font-family:var(--font-mono)}.cat{color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:0.05em;font-size:0.75rem}.cat--lg{display:inline-block;margin-bottom:0.8rem;font-family:var(--font-mono)}.read-more{display:inline-block;margin-top:1rem;font-weight:600;color:var(--accent)}.featured{margin-bottom:3.5rem}.featured__link{display:grid;grid-template-columns:1.15fr 1fr;gap:2rem;align-items:center;color:inherit;border-radius:var(--radius)}.featured__link:hover{text-decoration:none}.featured__media{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:16 / 9}.featured__media img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:transform 0.4s ease}.featured__link:hover .featured__media img{transform:scale(1.04)}.featured__title{margin:0.6rem 0 0.6rem;font-size:clamp(1.5rem, calc(1.1rem + 1.4vw), 2.1rem)}.featured__link:hover .featured__title{color:var(--accent)}.featured__excerpt{margin:0;color:var(--text-muted)}.post-grid{margin-bottom:2rem}.post-grid__items{display:grid;grid-template-columns:repeat(auto-fill, minmax(290px, 1fr));gap:1.75rem}.post-card{border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden;background:var(--surface);transition:transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease}.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--border)}.post-card__link{display:block;color:inherit}.post-card__link:hover{text-decoration:none}.post-card__media{aspect-ratio:16 / 9;overflow:hidden;background:var(--bg-subtle)}.post-card__media img{width:100%;height:100%;object-fit:cover;border-radius:0;transition:transform 0.4s ease}.post-card:hover .post-card__media img{transform:scale(1.05)}.post-card__body{padding:1.1rem 1.2rem 1.4rem}.post-card__title{margin:0.5rem 0 0.4rem;font-size:1.2rem;color:var(--heading);line-height:1.3}.post-card:hover .post-card__title{color:var(--accent)}.post-card__excerpt{margin:0;color:var(--text-muted);font-size:0.92rem}.post-list__empty{color:var(--text-muted)}.tag-list{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.9rem}.tag{font-size:0.75rem;font-family:var(--font-mono);background:var(--tag-bg);color:var(--tag-text);padding:0.22em 0.65em;border-radius:999px;white-space:nowrap}.post__header{margin-bottom:1.75rem;text-align:center}.post__title{margin:0 0 0.6rem;font-size:clamp(1.9rem, calc(1.4rem + 1.8vw), 2.6rem)}.post__lede{font-size:1.2rem;color:var(--text-muted);max-width:50ch;margin:0 auto 1rem}.post__meta{color:var(--text-muted);font-size:0.9rem;font-family:var(--font-mono)}.post__reading-time{margin-left:0.3rem}.post__header .tag-list{justify-content:center}.post__cover{margin:0 0 2.5rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.post__cover img{width:100%;aspect-ratio:2 / 1;object-fit:cover;border-radius:0;display:block}.post__cover figcaption{font-size:0.85rem;color:var(--text-muted);padding:0.6rem 0.9rem;text-align:center;background:var(--bg-subtle)}.post__content>:first-child{margin-top:0}.post__content h2{padding-top:0.3em}.post__tags-footer{margin-top:2.5rem}.post__footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-subtle)}.post__back{font-weight:500}.page__header{margin-bottom:1.5rem}.page__title{margin:0;font-size:clamp(1.8rem, calc(1.4rem + 1.6vw), 2.4rem)}.author-bio{display:flex;gap:1.1rem;align-items:flex-start;margin-top:2.5rem;padding:1.5rem;background:var(--bg-subtle);border:1px solid var(--border-subtle);border-radius:var(--radius)}.author-bio__avatar{flex:0 0 auto;width:64px;height:64px;border-radius:50%;object-fit:cover}.author-bio__name{margin:0 0 0.3rem;font-family:var(--font-display);font-weight:600;color:var(--heading)}.author-bio__desc{margin:0 0 0.6rem;font-size:0.95rem;color:var(--text-muted)}.author-bio__links{display:flex;gap:1rem;list-style:none;margin:0;padding:0;font-size:0.9rem}.related{max-width:var(--max-width-wide);margin:4rem auto 0}.related__items{display:grid;grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));gap:1.5rem}.related__card{display:flex;flex-direction:column;color:inherit}.related__card:hover{text-decoration:none}.related__media{width:100%;aspect-ratio:16 / 9;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:0.7rem;transition:opacity 0.2s ease}.related__card:hover .related__media{opacity:0.85}.related__date{font-family:var(--font-mono);font-size:0.75rem;color:var(--text-muted)}.related__title{font-family:var(--font-display);font-weight:600;color:var(--heading);margin-top:0.2rem}.related__card:hover .related__title{color:var(--accent)}.archive__year{margin:2rem 0 0.5rem;font-size:1.1rem;color:var(--text-muted);font-family:var(--font-mono)}.archive__list{list-style:none;margin:0;padding:0}.archive__item{display:flex;gap:1rem;align-items:baseline;padding:0.6rem 0;border-bottom:1px solid var(--border-subtle)}.archive__date{flex:0 0 auto;font-family:var(--font-mono);font-size:0.85rem;color:var(--text-muted);min-width:3.5rem}.highlighter-rouge,figure.highlight{position:relative}.copy-btn{position:absolute;top:0.6rem;right:0.6rem;font:500 0.75rem var(--font-sans);padding:0.3em 0.7em;color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;opacity:0;transition:opacity 0.15s ease, color 0.15s ease}.highlighter-rouge:hover .copy-btn,figure.highlight:hover .copy-btn,.copy-btn:focus-visible{opacity:1}.copy-btn:hover{color:var(--accent);border-color:var(--accent)}@media (max-width: 720px){.featured__link{grid-template-columns:1fr;gap:1.2rem}.featured__media{aspect-ratio:16 / 9}}@media (max-width: 480px){.author-bio{flex-direction:column}}.highlight,.highlighter-rouge .highlight{background:var(--bg-code);border:1px solid var(--border-subtle);border-radius:var(--radius);overflow:hidden}div.highlighter-rouge,figure.highlight{margin:0 0 1.5rem}.highlight pre,pre.highlight{margin:0;padding:1rem 1.1rem;overflow-x:auto;font-family:var(--font-mono);font-size:0.85rem;line-height:1.6;background:transparent}.highlight code{background:none;border:0;padding:0;font-size:inherit}.highlight .lineno{color:var(--text-muted);opacity:0.6;user-select:none;padding-right:1em}.highlight{color:#1f2328}.highlight .c,.highlight .c1,.highlight .cm,.highlight .cd,.highlight .cs{color:#6e7781;font-style:italic}.highlight .cp{color:#6e7781}.highlight .err{color:#f6f8fa;background-color:#82071e}.highlight .k,.highlight .kc,.highlight .kd,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kt{color:#cf222e}.highlight .o,.highlight .ow{color:#0550ae}.highlight .p,.highlight .pi{color:#1f2328}.highlight .n,.highlight .na,.highlight .nb,.highlight .nc,.highlight .nd,.highlight .ne,.highlight .nl,.highlight .nn,.highlight .nx,.highlight .py{color:#1f2328}.highlight .nf,.highlight .nb{color:#8250df}.highlight .nt{color:#116329}.highlight .nv,.highlight .vc,.highlight .vg,.highlight .vi{color:#953800}.highlight .s,.highlight .s1,.highlight .s2,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .se,.highlight .sh,.highlight .si,.highlight .sx,.highlight .sr,.highlight .ss,.highlight .dl{color:#0a3069}.highlight .m,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .mo,.highlight .il{color:#0550ae}.highlight .gd{color:#82071e;background-color:#ffebe9}.highlight .gi{color:#116329;background-color:#dafbe1}.highlight .gh{color:#0550ae;font-weight:600}.highlight .gu{color:#8250df;font-weight:600}:root[data-theme="dark"] .highlight{color:#e6edf3}:root[data-theme="dark"] .highlight .c,:root[data-theme="dark"] .highlight .c1,:root[data-theme="dark"] .highlight .cm,:root[data-theme="dark"] .highlight .cd,:root[data-theme="dark"] .highlight .cs{color:#8b949e;font-style:italic}:root[data-theme="dark"] .highlight .cp{color:#8b949e}:root[data-theme="dark"] .highlight .err{color:#f0f6fc;background-color:#8e1519}:root[data-theme="dark"] .highlight .k,:root[data-theme="dark"] .highlight .kc,:root[data-theme="dark"] .highlight .kd,:root[data-theme="dark"] .highlight .kn,:root[data-theme="dark"] .highlight .kp,:root[data-theme="dark"] .highlight .kr,:root[data-theme="dark"] .highlight .kt{color:#ff7b72}:root[data-theme="dark"] .highlight .o,:root[data-theme="dark"] .highlight .ow{color:#79c0ff}:root[data-theme="dark"] .highlight .p,:root[data-theme="dark"] .highlight .pi{color:#e6edf3}:root[data-theme="dark"] .highlight .n,:root[data-theme="dark"] .highlight .na,:root[data-theme="dark"] .highlight .nc,:root[data-theme="dark"] .highlight .nd,:root[data-theme="dark"] .highlight .ne,:root[data-theme="dark"] .highlight .nl,:root[data-theme="dark"] .highlight .nn,:root[data-theme="dark"] .highlight .nx,:root[data-theme="dark"] .highlight .py{color:#e6edf3}:root[data-theme="dark"] .highlight .nf,:root[data-theme="dark"] .highlight .nb{color:#d2a8ff}:root[data-theme="dark"] .highlight .nt{color:#7ee787}:root[data-theme="dark"] .highlight .nv,:root[data-theme="dark"] .highlight .vc,:root[data-theme="dark"] .highlight .vg,:root[data-theme="dark"] .highlight .vi{color:#ffa657}:root[data-theme="dark"] .highlight .s,:root[data-theme="dark"] .highlight .s1,:root[data-theme="dark"] .highlight .s2,:root[data-theme="dark"] .highlight .sb,:root[data-theme="dark"] .highlight .sc,:root[data-theme="dark"] .highlight .sd,:root[data-theme="dark"] .highlight .se,:root[data-theme="dark"] .highlight .sh,:root[data-theme="dark"] .highlight .si,:root[data-theme="dark"] .highlight .sx,:root[data-theme="dark"] .highlight .sr,:root[data-theme="dark"] .highlight .ss,:root[data-theme="dark"] .highlight .dl{color:#a5d6ff}:root[data-theme="dark"] .highlight .m,:root[data-theme="dark"] .highlight .mf,:root[data-theme="dark"] .highlight .mh,:root[data-theme="dark"] .highlight .mi,:root[data-theme="dark"] .highlight .mo,:root[data-theme="dark"] .highlight .il{color:#79c0ff}:root[data-theme="dark"] .highlight .gd{color:#ffdcd7;background-color:#67060c}:root[data-theme="dark"] .highlight .gi{color:#aff5b4;background-color:#033a16}:root[data-theme="dark"] .highlight .gh{color:#79c0ff;font-weight:600}:root[data-theme="dark"] .highlight .gu{color:#d2a8ff;font-weight:600}
