﻿@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/bricolage-grotesque-400.woff2") format("woff2")}@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/bricolage-grotesque-600.woff2") format("woff2")}@font-face{font-family:"Bricolage Grotesque";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/bricolage-grotesque-700.woff2") format("woff2")}@font-face{font-family:"Karla";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/karla-400.woff2") format("woff2")}@font-face{font-family:"Karla";font-style:italic;font-weight:400;font-display:swap;src:url("/fonts/karla-400-italic.woff2") format("woff2")}@font-face{font-family:"Karla";font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/karla-500.woff2") format("woff2")}@font-face{font-family:"Karla";font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/karla-700.woff2") format("woff2")}@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/jetbrains-mono-400.woff2") format("woff2")}@font-face{font-family:"JetBrains Mono";font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/jetbrains-mono-500.woff2") format("woff2")}:root{--bg-deep: #0a0e1a;--bg-mid: #111827;--glass-bg: rgba(255, 255, 255, 0.04);--glass-bg-hover: rgba(255, 255, 255, 0.07);--glass-border: rgba(255, 255, 255, 0.08);--glass-border-hover: rgba(255, 255, 255, 0.14);--glass-subtle-bg: rgba(255, 255, 255, 0.02);--text-primary: rgba(255, 255, 255, 0.92);--text-secondary: rgba(255, 255, 255, 0.55);--text-muted: rgba(255, 255, 255, 0.35);--accent: #64b5f6;--accent-warm: #f0a060;--accent-glow: rgba(100, 181, 246, 0.15);--code-bg: rgba(0, 0, 0, 0.35);--tldr-bg: rgba(100, 181, 246, 0.08);--tldr-border: rgba(100, 181, 246, 0.25);--table-header-bg: rgba(255, 255, 255, 0.06);--table-row-hover: rgba(255, 255, 255, 0.03);--scrollbar-thumb: rgba(255, 255, 255, 0.12);--content-width: 52rem;--toc-width: 16rem;--gap: 2rem;--radius: 12px;--radius-sm: 8px;--font-display: "Bricolage Grotesque", system-ui, sans-serif;--font-body: "Karla", system-ui, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, monospace}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{color-scheme:dark;scroll-behavior:smooth;scrollbar-color:var(--scrollbar-thumb) rgba(0,0,0,0);scroll-padding-top:5rem}body{font-family:var(--font-body);font-size:1.05rem;line-height:1.72;color:var(--text-primary);background:var(--bg-deep);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-warm)}.bg-layer{position:fixed;inset:0;z-index:-1;overflow:hidden}.bg-image{width:100%;height:100%;object-fit:cover;opacity:.3;filter:saturate(0.6)}.bg-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at 20% 0%, rgba(100,181,246,.08) 0%, rgba(0,0,0,0) 60%),radial-gradient(ellipse at 80% 100%, rgba(240,160,96,.06) 0%, rgba(0,0,0,0) 60%),linear-gradient(180deg, rgba(10,14,26,.4) 0%, rgba(10,14,26,.7) 100%)}.glass{background:var(--glass-bg);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border:1px solid var(--glass-border);border-radius:var(--radius)}.glass-subtle{background:var(--glass-subtle-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius)}.site-header{position:sticky;top:0;z-index:100;max-width:calc(var(--content-width) + var(--toc-width) + var(--gap) + 3rem);margin:1rem auto 0;border-radius:var(--radius);animation:fadeSlideDown .5s ease}.site-nav{padding:.75rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.site-brand{display:flex;align-items:center;gap:.6rem;color:var(--text-primary);text-decoration:none;font-family:var(--font-display);font-weight:600;font-size:1.1rem;letter-spacing:-.01em}.site-brand:hover{color:var(--accent)}.site-brand .site-logo{transition:color .2s ease}.nav-links{display:flex;align-items:center;gap:1.5rem}.nav-link{color:var(--text-secondary);font-size:.9rem;font-weight:500;letter-spacing:.02em;transition:color .2s ease}.nav-link:hover{color:var(--text-primary)}.nav-link svg{display:block}.site-main{max-width:calc(var(--content-width) + var(--toc-width) + var(--gap) + 3rem);margin:0 auto;padding:2rem 1.5rem 4rem}.hero{text-align:center;padding:3rem 2rem;margin-bottom:2.5rem;animation:fadeSlideUp .6s ease}.hero-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);font-weight:700;letter-spacing:-.03em;line-height:1.15;margin-bottom:.5rem;background:linear-gradient(90deg, #3a7abd 0%, #7cb8e8 25%, #c8dff2 50%, #7cb8e8 75%, #3a7abd 100%);-webkit-background-clip:text;-webkit-text-fill-color:rgba(0,0,0,0);background-clip:text}.hero-tagline{color:var(--text-secondary);font-size:1.1rem}.post-list{animation:fadeSlideUp .7s ease .1s both}.year-group{margin-bottom:2rem}.year-label{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--text-muted);margin-bottom:1rem;padding-left:.25rem}.post-card{margin-bottom:.75rem;transition:background .25s ease,border-color .25s ease,transform .25s ease}.post-card:hover{background:var(--glass-bg-hover);border-color:var(--glass-border-hover);transform:translateY(-1px)}.post-card-link{display:block;padding:1.25rem 1.5rem;color:inherit;text-decoration:none}.post-card-meta{display:flex;align-items:center;gap:1rem;font-size:.85rem;color:var(--text-muted);margin-bottom:.4rem}.meta-sep{color:var(--text-muted);opacity:.5;user-select:none}.post-card-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;line-height:1.35;color:var(--text-primary);margin-bottom:.35rem}.post-card-desc{color:var(--text-secondary);font-size:.95rem;line-height:1.55}.post-card-tags{display:flex;gap:.5rem;margin-top:.6rem}.tag{font-size:.8rem;color:var(--accent);opacity:.75;transition:opacity .2s}.tag:hover{opacity:1}.tags-page,.tag-page{animation:fadeSlideUp .6s ease}.page-title{font-family:var(--font-display);font-size:1.8rem;font-weight:700;margin-bottom:1.5rem}.tags-cloud{padding:2rem;display:flex;flex-wrap:wrap;gap:.75rem}.tag-cloud-item{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:2rem;font-size:.9rem;color:var(--text-primary);transition:all .2s ease}.tag-cloud-item:hover{background:var(--glass-bg-hover);border-color:var(--accent);color:var(--accent)}.tag-name{font-weight:500}.tag-count{font-size:.75rem;color:var(--text-muted)}.post{animation:fadeSlideUp .6s ease}.post-header{padding:2rem 2rem 1.5rem;margin-bottom:var(--gap)}.back-link{display:inline-block;font-size:.85rem;color:var(--text-muted);margin-bottom:1rem;transition:color .2s}.back-link:hover{color:var(--accent)}.post-title{font-family:var(--font-display);font-size:clamp(1.7rem,4vw,2.5rem);font-weight:700;line-height:1.2;letter-spacing:-.025em;margin-bottom:1rem}.post-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem .5rem;font-size:.88rem;color:var(--text-secondary)}.post-tags{display:flex;gap:.6rem;margin-top:.75rem}.post-layout{display:grid;grid-template-columns:1fr var(--toc-width);gap:var(--gap);align-items:start}.toc-nav{grid-column:2;grid-row:1;position:sticky;top:5.5rem;max-height:calc(100vh - 7rem);overflow-y:auto;padding:1.25rem;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) rgba(0,0,0,0)}.toc-title{font-family:var(--font-display);font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}@media (max-width: 64rem){.post-layout{grid-template-columns:1fr}.toc-nav{position:relative;top:auto;max-height:none;overflow:visible;padding:0;grid-column:1;grid-row:1}.post-content{grid-row:2}.toc-title{cursor:pointer;display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;color:var(--text-secondary);margin-bottom:0}.toc-title::after{content:"▸";opacity:.6}.toc-list{display:none;padding:0 1.25rem}.toc-nav[data-open]{padding-bottom:1rem}.toc-nav[data-open] .toc-title{margin-bottom:.5rem}.toc-nav[data-open] .toc-title::after{content:"▾"}.toc-nav[data-open] .toc-list{display:block}}.toc-list{list-style:none}.toc-list a{display:block;padding:.25rem 0;font-size:.82rem;color:var(--text-secondary);line-height:1.45;border-left:2px solid rgba(0,0,0,0);padding-left:.75rem;transition:all .2s ease}.toc-list a:hover,.toc-list a.active{color:var(--accent);border-left-color:var(--accent)}.toc-list ul{list-style:none;padding-left:.75rem}.toc-list ul a{font-size:.78rem;color:var(--text-muted)}.post-content{grid-column:1;grid-row:1;padding:2rem 2.5rem 3rem;overflow:hidden}.post-tldr{padding:1rem 1.25rem;margin-bottom:2rem;background:var(--tldr-bg);border-left:3px solid var(--tldr-border);border-radius:var(--radius-sm);font-size:.95rem;color:var(--text-secondary);line-height:1.6}.post-tldr strong{color:var(--accent);font-weight:600}.post-content h2{font-family:var(--font-display);font-size:1.55rem;font-weight:700;margin-top:3rem;margin-bottom:1rem;line-height:1.3;letter-spacing:-.02em;padding-bottom:.4rem;border-bottom:1px solid var(--glass-border)}.post-content h3{font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin-top:2rem;margin-bottom:.75rem;line-height:1.35}.post-content h4{font-family:var(--font-display);font-size:1.05rem;font-weight:600;margin-top:1.5rem;margin-bottom:.5rem;color:var(--text-secondary)}.post-content p{margin-bottom:1.15rem}.post-content ul,.post-content ol{margin-bottom:1.15rem;padding-left:1.5rem}.post-content ul li,.post-content ol li{margin-bottom:.3rem}.post-content ul ul,.post-content ul ol,.post-content ol ul,.post-content ol ol{margin-top:.3rem;margin-bottom:.3rem}.post-content code{font-family:var(--font-mono);font-size:.88em;padding:.15em .4em;background:var(--code-bg);border-radius:4px;word-break:break-word}.post-content pre{margin-bottom:1.5rem;padding:1.25rem 1.5rem;background:var(--code-bg);border:1px solid var(--glass-border);border-radius:var(--radius-sm);overflow-x:auto;line-height:1.55;scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) rgba(0,0,0,0)}.post-content pre code{padding:0;background:none;font-size:.85rem}.post-content table{width:100%;margin-bottom:1.5rem;border-collapse:collapse;font-size:.92rem}.post-content table th{background:var(--table-header-bg);font-weight:600;text-align:left;padding:.65rem 1rem;border-bottom:1px solid var(--glass-border);white-space:nowrap}.post-content table td{padding:.6rem 1rem;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:top}.post-content table tr:hover td{background:var(--table-row-hover)}.post-content blockquote{margin:1.5rem 0;padding:.75rem 1.25rem;border-left:3px solid var(--accent);background:var(--glass-bg);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary)}.post-content blockquote p:last-child{margin-bottom:0}.post-content img{max-width:100%;height:auto;border-radius:var(--radius-sm);border:1px solid var(--glass-border);margin:1rem 0}.post-content .post-thumb{cursor:zoom-in;transition:transform .2s ease,border-color .2s ease}.post-content .post-thumb:hover{transform:scale(1.03);border-color:var(--glass-border-hover)}.post-content .figure-detail{display:flex;gap:1.5rem;align-items:flex-start;padding:1.25rem;margin:1rem 0}.post-content .figure-detail .figure-detail-img{flex-shrink:0}.post-content .figure-detail .figure-detail-img .post-thumb{margin:0}.post-content .figure-detail .figure-detail-text{flex:1;min-width:0}.post-content .figure-detail .figure-detail-text p:last-child{margin-bottom:0}@media (max-width: 48rem){.post-content .figure-detail{flex-direction:column}}.post-content hr{border:none;border-top:1px solid var(--glass-border);margin:2.5rem 0}.post-content .zola-anchor{opacity:0;margin-left:.4rem;font-size:.85em;color:var(--text-muted);transition:opacity .2s}.post-content h2:hover .zola-anchor,.post-content h3:hover .zola-anchor,.post-content h4:hover .zola-anchor{opacity:1}.site-footer{padding:2rem 1.5rem 1.5rem;text-align:center;font-size:.8rem;color:var(--text-muted)}@keyframes fadeSlideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeSlideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 48rem){:root{--gap: 1.25rem}body{font-size:1rem}.site-header{margin:.5rem .5rem 0}.site-main{padding:1.25rem .75rem 3rem}.hero{padding:2rem 1.25rem}.post-header{padding:1.5rem 1.25rem 1.25rem}.post-content{padding:1.5rem 1.25rem 2rem}.post-content h2{font-size:1.35rem}.post-content pre{margin-left:-1.25rem;margin-right:-1.25rem;border-radius:0;border-left:none;border-right:none}.post-content table{display:block;overflow-x:auto;white-space:nowrap}.post-card-link{padding:1rem 1.25rem}}.lightbox-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);opacity:0;visibility:hidden;cursor:zoom-out;transition:opacity .25s ease,visibility .25s ease}.lightbox-overlay.active{opacity:1;visibility:visible}.lightbox-img{max-width:90vw;max-height:90vh;border-radius:var(--radius);box-shadow:0 8px 40px rgba(0,0,0,.5)}.lightbox-close{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:50%;width:2.5rem;height:2.5rem;font-size:1.4rem;color:rgba(255,255,255,.8);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease,color .2s ease}.lightbox-close:hover,.lightbox-close:focus{background:rgba(255,255,255,.2);color:#fff;outline:none}.lightbox-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}