@font-face{font-family:"Lora";font-style:normal;font-weight:400 700;font-display:swap;src:url("/fonts/lora-latin.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"Lora";font-style:normal;font-weight:400 700;font-display:swap;src:url("/fonts/lora-latin-ext.woff2") format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"Inter";font-style:normal;font-weight:400 700;font-display:swap;src:url("/fonts/inter-latin.woff2") format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:"Inter";font-style:normal;font-weight:400 700;font-display:swap;src:url("/fonts/inter-latin-ext.woff2") format("woff2");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}:root{--text: #4c4f69;--subtext: #6c6f85;--overlay: #8c8fa1;--surface: #ccd0da;--base: #eff1f5;--mantle: #e6e9ef;--crust: #dce0e8;--accent: #8839ef;--link: #209fb5;--link-hover: #04a5e5;--code-bg: #e6e9ef;--border: #bcc0cc;--gradient-top: #e8ddf5}html.dark{--text: #cdd6f4;--subtext: #a6adc8;--overlay: #7f849c;--surface: #313244;--base: #1e1e2e;--mantle: #181825;--crust: #11111b;--accent: #cba6f7;--link: #74c7ec;--link-hover: #89dceb;--code-bg: #313244;--border: #45475a;--gradient-top: #2a2240}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:"Lora",Georgia,"Times New Roman",serif;font-size:1rem;line-height:1.7;color:var(--text);background:linear-gradient(180deg, var(--gradient-top) 0%, var(--base) 45%) no-repeat,var(--base);min-height:100vh;display:flex;flex-direction:column}header,main,footer{width:100%;max-width:42rem;margin:0 auto;padding:0 1.5rem}main{flex:1;padding-top:2rem;padding-bottom:4rem}header{font-family:"Inter",system-ui,-apple-system,sans-serif;padding-top:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border);margin-bottom:0}header nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}.site-name{font-weight:700;font-size:1.1rem;color:var(--text);text-decoration:none}.site-name:hover{color:var(--accent)}.nav-links{display:flex;align-items:center;gap:1.25rem}.nav-links a{font-size:.9rem;color:var(--subtext);text-decoration:none;transition:color .2s}.nav-links a:hover,.nav-links a.active{color:var(--accent)}#theme-toggle{background:none;border:none;cursor:pointer;font-size:1.1rem;color:var(--overlay);padding:.25rem;line-height:1;transition:color .2s}#theme-toggle:hover{color:var(--text)}#theme-toggle .icon-sun{display:none}#theme-toggle .icon-moon{display:inline}html.dark #theme-toggle .icon-sun{display:inline}html.dark #theme-toggle .icon-moon{display:none}footer{padding-top:2rem;padding-bottom:2rem;border-top:1px solid var(--border);margin-top:auto}footer p{font-size:.85rem;color:var(--overlay)}footer a{color:var(--overlay);text-decoration:none}footer a:hover{color:var(--link)}h1,h2,h3{font-family:"Inter",system-ui,-apple-system,sans-serif;font-weight:700;line-height:1.25;color:var(--text);text-transform:uppercase;letter-spacing:.05em;text-shadow:2px 2px 0 rgba(136,57,239,.08)}html.dark h1,html.dark h2,html.dark h3{text-shadow:2px 2px 0 rgba(203,166,247,.1)}h1{font-size:1.75rem;margin-bottom:.5rem;letter-spacing:.04em}h2{font-size:1.25rem;margin-top:2.5rem;margin-bottom:.75rem}h3{font-size:1rem;margin-top:2rem;margin-bottom:.5rem}a{color:var(--link);text-decoration:none;transition:color .2s}a:hover{color:var(--link-hover);text-decoration:underline}.hero{margin-bottom:2.5rem}.avatar{float:left;width:80px;height:80px;border-radius:12px;border:2px solid var(--border);margin:.25rem 1.25rem .75rem 0;shape-outside:margin-box}.section-desc{color:var(--subtext);margin-bottom:1.5rem}.note-list{list-style:none}.note-list li{display:flex;align-items:baseline;gap:.75rem;padding:.4rem 0}.note-list time{font-size:.85rem;color:var(--overlay);font-variant-numeric:tabular-nums;flex-shrink:0}.note-list a{color:var(--text);text-decoration:none}.note-list a:hover{color:var(--link)}.project-list{list-style:none}.project-list li{padding:.75rem 0;border-bottom:1px solid var(--border)}.project-list li:last-child{border-bottom:none}.project-list a{font-weight:600;color:var(--text)}.project-list a:hover{color:var(--link);text-decoration:none}.project-list .lang{font-size:.8rem;color:var(--accent);margin-left:.5rem}.project-list p{font-size:.9rem;color:var(--subtext);margin-top:.25rem}article header{margin-bottom:2rem;padding-bottom:0;border-bottom:none}article .meta{font-size:.85rem;color:var(--overlay);margin-top:.25rem}.prose{line-height:1.8}.prose p{margin-bottom:1.25rem}.prose ul,.prose ol{margin-bottom:1.25rem;padding-left:1.5rem}.prose li{margin-bottom:.35rem}.prose blockquote{border-left:3px solid var(--accent);padding-left:1rem;color:var(--subtext);margin:1.5rem 0;font-style:italic}.prose code{font-family:ui-monospace,"SFMono-Regular",Menlo,monospace;font-size:.875em;background:var(--code-bg);padding:.15em .35em;border-radius:4px}.prose pre{background:var(--mantle);border:1px solid var(--border);border-radius:6px;padding:1rem;overflow-x:auto;margin:1.5rem 0}.prose pre code{background:none;padding:0;font-size:.85rem}.prose img{max-width:100%;height:auto;border-radius:6px}.prose hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;font-size:.9rem;color:var(--overlay)}.page-footer{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--border);font-size:.9rem}.empty{color:var(--overlay);font-style:italic;padding:2rem 0}@media (max-width: 480px){h1{font-size:1.35rem}.avatar{width:64px;height:64px}.note-list li{flex-direction:column;gap:.15rem}}