@import"https://fonts.googleapis.com/css2?family=Nunito:ital,wght@0,200..1000;1,200..1000&display=swap";@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/inter-regular.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,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:500;font-display:swap;src:url(/fonts/inter-medium.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,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:600;font-display:swap;src:url(/fonts/inter-semibold.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,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:700;font-display:swap;src:url(/fonts/inter-semibold.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Google Sans Code;font-style:normal;font-weight:100 900;font-stretch:normal;font-display:swap;src:url(/fonts/google-sans-code.ttf) format("truetype");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Google Sans Code;font-style:italic;font-weight:100 900;font-stretch:normal;font-display:swap;src:url(/fonts/google-sans-code-italic.ttf) format("truetype");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--base: #F5F3EE;--mantle: #EFEEE9;--crust: #E8E7E2;--base-rgb: 245, 243, 238;--secondary-bg-rgb: 239, 238, 233;--tertiary-bg-rgb: 232, 231, 226;--border-rgb: 224, 223, 218;--accent-primary-rgb: 28, 28, 28;--accent-secondary-rgb: 153, 153, 153;--green-rgb: 28, 28, 28;--blue-rgb: 28, 28, 28;--surface0: #EFEEE9;--surface1: #E8E7E2;--surface2: #E0DFDA;--overlay0: #D0CFCA;--overlay1: #B0AFAA;--overlay2: #90908A;--text: #1C1C1C;--subtext1: #666666;--subtext0: #999999;--rosewater: #1C1C1C;--flamingo: #1C1C1C;--pink: #1C1C1C;--mauve: #666666;--red: #1C1C1C;--maroon: #1C1C1C;--peach: #1C1C1C;--yellow: #1C1C1C;--green: #1C1C1C;--teal: #1C1C1C;--sky: #1C1C1C;--sapphire: #1C1C1C;--blue: #1C1C1C;--lavender: #666666;--primary-bg: var(--base);--secondary-bg: var(--surface0);--tertiary-bg: var(--surface1);--primary-text: var(--text);--secondary-text: var(--subtext1);--muted-text: var(--subtext0);--accent-primary: var(--blue);--accent-secondary: var(--mauve);--success: var(--green);--warning: var(--yellow);--error: var(--red);--border: var(--surface2);--hover: var(--surface1);--font-serif: Georgia, "Times New Roman", Times, serif;--font-mono: "IBM Plex Mono", "Courier New", Courier, monospace;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", Arial, sans-serif}*{transition:none}::selection{background-color:var(--primary-text);color:var(--primary-bg)}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--primary-bg)}::-webkit-scrollbar-thumb{background:var(--border)}::-webkit-scrollbar-thumb:hover{background:var(--secondary-text)}*{margin:0;padding:0;box-sizing:border-box}html{background-color:var(--base)!important;color:var(--text)!important}html{background-color:var(--primary-bg);color:var(--primary-text)}body{background:transparent;color:var(--primary-text)}body{min-height:100vh;background:var(--primary-bg);color:var(--muted-text);font-family:var(--font-mono);line-height:1.6;font-size:15px;font-weight:400;overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--primary-text);font-family:var(--font-serif);font-weight:400;line-height:1.3;margin-bottom:1.5rem;margin-top:2rem;letter-spacing:-.02em}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.5rem}h4{font-size:1.25rem}p{margin-bottom:1rem;color:var(--secondary-text)}a{color:var(--primary-text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}a:hover{opacity:.6}header{background:var(--primary-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1000}.title{color:var(--primary-text);font-size:1.25rem;font-weight:400;margin:0;text-align:center}.menu-btn{display:none;flex-direction:column;cursor:pointer;padding:.5rem;background:transparent;border:none}.menu-btn__burger{width:1.5rem;height:1px;background:var(--primary-text);margin:3px 0}.nav{display:flex;justify-content:center;padding:1rem 0}.nav__list{display:flex;list-style:none;gap:2rem;align-items:center;padding:0;margin:0}.nav__item a{color:var(--primary-text);font-weight:400;font-size:.95rem;text-decoration:none}.nav__item a:hover{opacity:.6}@media (max-width: 768px){header{padding:1rem;display:flex;justify-content:space-between;align-items:center}.menu-btn{display:flex}.nav{position:absolute;top:100%;left:0;right:0;background-color:var(--secondary-bg);border-top:1px solid var(--border);padding:1rem;display:none;box-shadow:0 4px 12px #0000001a}.nav.active{display:block}.nav__list{flex-direction:column;gap:1rem;width:100%}.nav__item{text-align:center;width:100%}.nav__item a{display:block;width:100%;padding:1rem}}main{max-width:650px;margin:0 auto;padding:4rem 2rem;min-height:calc(100vh - 200px)}.row{width:100%;max-width:650px;margin:0 auto}.container{background:var(--primary-bg);padding:0;margin-bottom:3rem}.card{background:var(--primary-bg);padding:0;margin-bottom:2rem}@media (max-width: 768px){main{padding:1rem .5rem}.container{padding:1rem;margin-bottom:1rem;border-radius:8px}.row{padding:0 .5rem}}@media (min-width: 1200px){main{padding:3rem 2rem}}.navbar{background:var(--primary-bg);color:var(--primary-text);padding:2rem 1rem;width:100%;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:1000}.navbar a{color:var(--primary-text);text-decoration:none;font-size:.95rem;font-weight:400}.navbar a:hover{opacity:.6}.navbar .title{font-family:var(--font-mono);font-weight:400;font-size:.95rem;margin:0;text-decoration:none;color:var(--primary-text)}.navbar .list{display:flex;align-items:center;gap:2rem}.navbar .list ul{display:flex;list-style:none;gap:2rem;margin:0;padding:0}.navbar .list ul li{display:flex}@media (max-width: 768px){.navbar{padding:1.5rem 1rem;flex-wrap:wrap}.navbar .title{font-size:.95rem}.navbar .list,.navbar .list ul{flex-wrap:wrap;gap:1rem}}.about-container{background-color:var(--primary-bg);border:none;padding:0;margin:2rem 0;display:flex;flex-direction:column;gap:2rem}.about-container .title{color:var(--primary-text);font-family:var(--font-serif);font-size:2rem;font-weight:400;margin:0 0 2rem;text-align:left;border-bottom:1px solid var(--border);padding-bottom:1rem;letter-spacing:-.02em}.about-container p{color:var(--secondary-text);font-size:1rem;line-height:1.6;margin-bottom:1.5rem;text-align:left}.about-container a{color:var(--primary-text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.about-container a:hover{opacity:.6}.about-image-container{background:var(--secondary-bg);border:1px solid var(--border);padding:2rem;margin:2rem auto;max-width:400px;width:100%;text-align:center;color:var(--primary-text);font-weight:400}svg{width:100%;height:auto;max-width:300px}@media (max-width: 768px){.about-container{padding:0;margin:1.5rem 0}.about-container .title{font-size:1.75rem}.about-image-container{margin:1.5rem auto;padding:1.5rem}}.social-links-container{display:flex;justify-content:center;align-items:center;padding:2rem 0}.social-links{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.social-links a{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:8px;font-size:.95rem;font-weight:500;text-decoration:none;color:var(--primary-text);background-color:var(--secondary-bg);border:1px solid var(--border);transition:all .2s ease;min-width:120px;justify-content:center}.social-links a:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.social-links a i{font-size:1.1rem}.social-links .linkedin{background:linear-gradient(135deg,#0077b5,#005885);color:#fff;border-color:#0077b5}.social-links .linkedin:hover{background:linear-gradient(135deg,#005885,#004065);color:#fff}.social-links .github{background:linear-gradient(135deg,var(--surface0),var(--surface1));color:var(--primary-text);border-color:var(--border)}.social-links .github:hover{background:linear-gradient(135deg,var(--surface1),var(--surface2));border-color:var(--accent-primary);color:var(--accent-primary)}.social-links .twitter{background:linear-gradient(135deg,#1da1f2,#0d8bd9);color:#fff;border-color:#1da1f2}.social-links .twitter:hover{background:linear-gradient(135deg,#0d8bd9,#0a73b8);color:#fff}.social-links .email{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:var(--base);border-color:var(--accent-primary)}.social-links .email:hover{background:linear-gradient(135deg,var(--accent-secondary),var(--mauve));color:var(--base)}.social-links .website{background:linear-gradient(135deg,var(--green),var(--teal));color:var(--base);border-color:var(--green)}.social-links .website:hover{background:linear-gradient(135deg,var(--teal),var(--sky));color:var(--base)}@media (max-width: 768px){.social-links{gap:.75rem;padding:0 1rem}.social-links a{padding:.5rem 1rem;font-size:.875rem;min-width:100px}.social-links a i{font-size:1rem}}@media (max-width: 480px){.social-links{flex-direction:column;align-items:center;gap:.5rem}.social-links a{width:100%;max-width:200px}}.post-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:3rem}.post-list li{background:var(--primary-bg);border-bottom:1px solid var(--border);padding:0 0 3rem}.post-list li:last-child{border-bottom:none}.post-list li a{color:var(--primary-text);text-decoration:none;display:block;font-family:var(--font-serif);font-weight:400;font-size:1.5rem;line-height:1.3;letter-spacing:-.02em}.post-list li a:hover{opacity:.6}.post-meta{color:var(--muted-text);font-size:.85rem;margin-top:.5rem;display:flex;align-items:center;gap:1rem}.post-excerpt{color:var(--secondary-text);font-size:1rem;line-height:1.6;margin-top:1rem}.post-tags{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1rem}.post-tag{background-color:transparent;color:var(--muted-text);padding:0;font-size:.85rem;font-weight:400;border:none}@media (max-width: 768px){.post-list{gap:2rem}.post-list li{padding:0 0 2rem}.post-list li a{font-size:1.1rem}.post-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.post-tags{margin-top:.75rem}}.loading-container{display:flex;align-items:center;justify-content:center;min-height:200px;padding:2rem;color:var(--secondary-text);font-size:1rem}.post-content{max-width:650px;margin:0 auto;padding:2rem 0}.post-header{background-color:var(--primary-bg);border:none;padding:0;margin-bottom:3rem;text-align:left}.post-title{color:var(--primary-text);font-family:var(--font-serif);font-size:2.5rem;font-weight:400;margin:0 0 1rem;line-height:1.3;letter-spacing:-.02em}.post-meta{display:flex;justify-content:flex-start;align-items:center;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}.post-date{color:var(--muted-text);font-size:.85rem;font-weight:400;margin-right:0;font-family:var(--font-mono)}.post-featured-image{width:100%;max-height:400px;object-fit:cover;border:1px solid var(--border);margin:2rem 0}.btn-copy-code{position:absolute;top:.75rem;right:.75rem;background:var(--secondary-bg);color:var(--primary-text);border:1px solid var(--border);padding:.25rem .5rem;cursor:pointer;font-size:.75rem;font-weight:400;display:flex;align-items:center;gap:.25rem;z-index:1}.btn-copy-code:hover{opacity:.6}.btn-copy-code i{font-size:.875rem}.code-block-wrapper{position:relative;margin:1.5rem 0}.code-block-wrapper pre{margin:0}.post-navigation{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border);gap:1rem}.nav-button{background:var(--primary-bg);border:1px solid var(--border);padding:.75rem 1rem;color:var(--primary-text);text-decoration:none;flex:1;max-width:200px}.nav-button:hover{opacity:.6}.nav-button.prev{text-align:left}.nav-button.next{text-align:right}@media (max-width: 768px){.post-content{padding:1.5rem 0}.post-header{padding:0;margin-bottom:2rem}.post-title{font-size:1.75rem}.post-meta{flex-direction:column;align-items:flex-start;gap:.5rem}.post-featured-image{max-height:250px}.post-navigation{flex-direction:column;gap:1rem}.nav-button{max-width:none;text-align:center}}.post-body{background-color:var(--primary-bg);border:none;padding:0;margin:2rem 0;line-height:1.6;font-size:1rem}.post-body h1,.post-body h2,.post-body h3,.post-body h4,.post-body h5,.post-body h6{color:var(--primary-text);font-family:var(--font-serif);margin-top:2.5rem;margin-bottom:1rem;font-weight:400;line-height:1.3;letter-spacing:-.02em}.post-body h1{font-size:2.5rem;margin-top:0}.post-body h2{font-size:2rem}.post-body h3{font-size:1.5rem}.post-body p{color:var(--secondary-text);margin-bottom:1.5rem;text-align:left}.post-body a{color:var(--primary-text);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.post-body a:hover{opacity:.6}.post-body blockquote{background-color:transparent;border-left:2px solid var(--border);padding:0 0 0 1.5rem;margin:1.5rem 0;font-style:italic;color:var(--secondary-text)}.post-body blockquote p{margin-bottom:0}.post-body code{background-color:var(--secondary-bg);color:var(--primary-text);padding:.2rem .4rem;font-family:var(--font-mono);font-size:.9em;border:none}.post-body pre{background-color:#2e3440;border:1px solid #434c5e;padding:1.5rem;margin:1.5rem 0;overflow-x:auto;font-family:var(--font-mono);font-size:.875rem;line-height:1.6}.post-body pre code{background:none;border:none;padding:0;color:#d8dee9;font-size:inherit}.post-body ul,.post-body ol{padding-left:2rem;margin-bottom:1.5rem;color:var(--secondary-text)}.post-body li{margin-bottom:.5rem}.post-body img{max-width:100%;height:auto;margin:1.5rem 0;border:1px solid var(--border)}.post-body table{width:100%;border-collapse:collapse;margin:1.5rem 0;background-color:transparent}.post-body th,.post-body td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.post-body th{color:var(--primary-text);font-weight:400}.post-body td{color:var(--secondary-text)}.post-body hr{border:none;height:1px;background:var(--border);margin:2rem 0}@media (max-width: 768px){.post-body{padding:0;margin:1.5rem 0}.post-body h1{font-size:1.75rem}.post-body h2{font-size:1.35rem}.post-body h3{font-size:1.15rem}.post-body pre{padding:1rem;font-size:.8rem}}
