:root{--accent: #c65c2f;--accent-dark: #9b431f;--accent-soft: rgba(198, 92, 47, .12);--highlight: #3d67a5;--highlight-soft: rgba(61, 103, 165, .12);--black: 24, 31, 37;--gray: 110, 106, 98;--gray-light: 214, 206, 193;--gray-dark: 72, 69, 63;--background-color: #f8f6f2;--text-color: rgb(var(--black));--text-body: rgba(24, 31, 37, .78);--text-muted: rgba(24, 31, 37, .44);--card-background: #fbfaf7;--header-background: rgba(248, 246, 242, .9);--bg-secondary: #f1ece4;--gray-gradient: rgba(255, 255, 255, .45), rgba(248, 246, 242, .75);--purple-gradient: linear-gradient(135deg, #d37a55, #c65c2f);--pink-gradient: linear-gradient(135deg, #d37a55, #a8686f);--blue-gradient: linear-gradient(135deg, #5878a6, #3d67a5);--infoq-gradient: linear-gradient(135deg, #3d67a5, #27456d);--hackernoon-gradient: linear-gradient(135deg, #6a7f47, #4c6232);--towardsai-gradient: linear-gradient(135deg, #5e6d7e, #314458);--dzone-gradient: linear-gradient(135deg, #3d67a5, #5e8b60);--freecodecamp-gradient: linear-gradient(135deg, #27456d, #3d67a5);--box-shadow: 0 18px 45px rgba(24, 31, 37, .07);--color-typescript: #3178c6;--color-javascript: #f7df1e;--color-rust: #b7410e;--color-python: #3572A5;--border-color: rgba(var(--gray-light), .95);--btn-hover: rgba(var(--gray-light), .45);--pagination-active: rgba(var(--gray-light), .2);--touch-feedback: rgba(var(--gray-light), .28);--font-sans: "Public Sans", system-ui, sans-serif;--font-display: "Newsreader", Georgia, serif;--font-mono: "IBM Plex Mono", "SFMono-Regular", Consolas, ui-monospace, monospace}.dark{--accent: #e18c66;--accent-dark: #f3b08d;--accent-soft: rgba(225, 140, 102, .16);--highlight: #8ba9d7;--highlight-soft: rgba(139, 169, 215, .18);--black: 235, 234, 229;--gray: 155, 152, 145;--gray-light: 74, 71, 66;--gray-dark: 205, 201, 192;--background-color: #141617;--text-color: rgb(var(--black));--text-body: rgba(235, 234, 229, .82);--text-muted: rgba(235, 234, 229, .52);--card-background: #1b1d1f;--header-background: rgba(20, 22, 23, .9);--bg-secondary: #171a1c;--gray-gradient: rgba(255, 255, 255, .02), rgba(20, 22, 23, .75);--box-shadow: 0 20px 50px rgba(0, 0, 0, .35);--border-color: rgba(var(--gray-light), .88);--btn-hover: rgba(var(--gray-light), .28);--pagination-active: rgba(var(--gray-light), .2)}html{scroll-behavior:smooth;touch-action:manipulation;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);margin:0;padding:0;padding-top:env(safe-area-inset-top);padding-right:env(safe-area-inset-right);padding-left:env(safe-area-inset-left);text-align:left;background:var(--background-color);background-image:linear-gradient(180deg,#fcfbf7,#f8f6f2 48%,#f5f1ea);background-repeat:no-repeat;background-size:100% 100%;word-wrap:break-word;overflow-wrap:break-word;color:var(--text-color);font-size:18px;line-height:1.65;transition:background-color .3s ease,color .3s ease;-webkit-tap-highlight-color:transparent;position:relative}body:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(var(--gray-light),.12) 1px,transparent 1px),linear-gradient(90deg,rgba(var(--gray-light),.12) 1px,transparent 1px);background-size:104px 104px;mask-image:linear-gradient(180deg,rgba(0,0,0,.2),transparent 72%);opacity:.05}main{width:100%;max-width:1280px;margin:auto;padding:clamp(1.35rem,3vw,2.2rem) clamp(1.05rem,3vw,2.2rem) 4.25rem;position:relative;z-index:1}h1,h2,h3,h4,h5,h6{margin:0 0 .5rem;color:var(--text-color);line-height:1.2;font-family:var(--font-display);font-weight:400;text-wrap:balance}h1{font-size:clamp(3.2rem,8vw,5.8rem);line-height:.96;letter-spacing:-.05em}h2{font-size:clamp(2.2rem,4vw,3.4rem);letter-spacing:-.04em}h3{font-size:clamp(1.45rem,2.4vw,2.2rem);letter-spacing:-.03em}h4{font-size:1.563em}h5{font-size:1.25em}strong,b{font-weight:700}a{color:inherit;text-decoration-color:#c65c2f73;text-decoration-thickness:1px;text-underline-offset:.16em}a:hover{color:var(--accent)}@media (hover: none) and (pointer: coarse){button,a,input[type=button],input[type=submit],.interactive{min-height:44px;min-width:44px}a:active,button:active,.interactive:active{background-color:var(--touch-feedback);transition:background-color .1s ease}}p{margin-bottom:1em}.prose p{margin-bottom:1.5em}.eyebrow,.section-kicker{margin:0;font-family:var(--font-mono);font-size:.76rem;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}.surface-card{border:1px solid rgba(var(--gray-light),.95);border-radius:1.4rem;background:linear-gradient(180deg,#ffffff7a,#ffffff1f),var(--card-background);box-shadow:0 10px 24px #181f250a}.button-link,button,input,textarea{font:inherit}textarea{width:100%;font-size:16px}input{font-size:16px}table{width:100%}img{max-width:100%;height:auto;border-radius:8px}button,.button-link{border:1px solid rgba(var(--black),.14);background:transparent;color:var(--text-color);cursor:pointer;transition:transform .2s ease,color .2s ease,border-color .2s ease,background-color .2s ease}button:hover,.button-link:hover{border-color:rgba(var(--black),.32);transform:translateY(-1px)}code{padding:.12rem .35rem;background-color:rgba(var(--gray-light),.45);border-radius:.3rem;font-family:var(--font-mono);font-size:.88em}pre{padding:1.5em;border-radius:1rem;border:1px solid rgba(var(--gray-light),.95);background:rgba(var(--gray-light),.18);overflow-x:auto}pre>code{all:unset}blockquote{border-left:2px solid var(--accent);padding:0 0 0 1rem;margin:0;font-size:1.15em;color:rgb(var(--gray-dark))}hr{border:none;border-top:1px solid rgba(var(--gray-light),.95)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 900px){main{padding-top:1rem}body:before{background-size:56px 56px}}@media (max-width: 720px){body{font-size:17px}main{padding-top:.9rem;padding-bottom:3.5rem}h1{font-size:clamp(2.8rem,14vw,4.2rem)}h2{font-size:clamp(2rem,9vw,2.8rem)}}@media (max-width: 1100px){.projects-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.projects-grid{grid-template-columns:minmax(0,1fr)}}.project-card{padding:1.5rem;border-radius:10px;background:var(--card-background);box-shadow:0 1px 3px rgba(var(--gray),15%);transition:transform .2s ease,box-shadow .2s ease,background-color .3s ease,color .3s ease;border:1px solid rgba(var(--gray-light),.7);width:100%;color:var(--text-color);overflow:hidden;display:flex;flex-direction:column;min-height:240px;gap:.75rem;position:static;box-sizing:border-box;z-index:1;text-decoration:none}.project-card:hover{transform:translateY(-5px);box-shadow:var(--box-shadow);border-color:var(--accent)}.project-title{margin:0;font-size:1.2rem;font-weight:500;color:var(--text-color)}.project-description{margin:0;font-size:.95rem;color:rgb(var(--gray));line-height:1.6}.language{display:flex;align-items:center;color:rgb(var(--gray));font-size:.9rem}.lang-dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:5px}.lang-dot.typescript{background-color:var(--color-typescript)}.lang-dot.javascript{background-color:var(--color-javascript)}.lang-dot.rust{background-color:var(--color-rust)}.lang-dot.python{background-color:var(--color-python)}.project-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto;padding-top:1.5rem}.project-tag{padding:.4rem .75rem;border-radius:100px;background-color:rgba(var(--gray-light),.5);color:rgb(var(--gray));font-size:.8rem}.project-stats{display:flex;gap:1rem;margin-top:.5rem;color:rgb(var(--gray))}.post-filter-tabs{display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:3rem}.filter-tab{background:none;border:none;padding:.5rem 0;cursor:pointer;color:rgb(var(--gray));font-weight:500;font-size:1.1rem;border-bottom:3px solid transparent;transition:color .2s ease,border-color .2s ease}.filter-tab:hover{color:var(--accent)}.filter-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.external-card{position:relative;border:1px solid rgb(var(--gray-light))}.infoq-card .post-content,.hackernoon-card .post-content,.towardsai-card .post-content,.dzone-card .post-content,.freecodecamp-card .post-content{background-color:var(--card-background);color:var(--text-color)}.infoq-card .post-title,.hackernoon-card .post-title,.towardsai-card .post-title,.dzone-card .post-title,.freecodecamp-card .post-title{color:var(--text-color)}.infoq-card .post-date,.hackernoon-card .post-date,.towardsai-card .post-date,.dzone-card .post-date,.freecodecamp-card .post-date,.infoq-card .post-description,.hackernoon-card .post-description,.towardsai-card .post-description,.dzone-card .post-description,.freecodecamp-card .post-description{color:rgb(var(--gray))}.infoq-card-header{background:var(--infoq-gradient)}.hackernoon-card-header{background:var(--hackernoon-gradient)}.towardsai-card-header{background:var(--towardsai-gradient)}.dzone-card-header{background:var(--dzone-gradient)}.freecodecamp-card-header{background:var(--freecodecamp-gradient)}.external-badge{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;border-radius:20px;background-color:#ffffff40;color:#fff;font-size:.75rem;font-weight:500;z-index:2}.platform-badge{position:absolute;bottom:1rem;left:1rem;padding:.25rem .75rem;border-radius:20px;background-color:#fff3;color:#fff;font-size:.8rem;font-weight:600;z-index:2}.post-description{margin:.5rem 0 0;font-size:.95rem;color:rgb(var(--gray));line-height:1.5}.post-cta{font-size:.9rem;font-weight:500;color:var(--accent);margin-top:1.5rem;display:block;position:relative;z-index:5}@media (max-width: 767px){body{font-size:18px;padding-bottom:calc(60px + env(safe-area-inset-bottom))}main{padding:1em;padding-bottom:calc(60px + env(safe-area-inset-bottom))}footer{padding-bottom:calc(60px + env(safe-area-inset-bottom))}.post-filter-tabs{display:flex;overflow-x:auto;white-space:nowrap;padding-bottom:.5rem;padding-top:.25rem;margin-bottom:1.5rem;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.post-filter-tabs::-webkit-scrollbar{display:none}.post-filter-tabs .filter-tab{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;margin-right:1rem}}.sr-only{border:0;padding:0;margin:0;position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}footer[data-astro-cid-sz7xmlte]{padding:1rem clamp(1rem,3vw,2rem) 3rem;color:var(--text-body)}.footer-content[data-astro-cid-sz7xmlte]{display:grid;grid-template-columns:minmax(0,1.3fr) repeat(2,minmax(0,.75fr));gap:2rem;max-width:1280px;margin:0 auto;padding:1.7rem 0 0;border-top:1px solid rgba(var(--gray-light),.72)}.footer-eyebrow[data-astro-cid-sz7xmlte],.footer-heading[data-astro-cid-sz7xmlte]{margin:0 0 .75rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}.footer-copy[data-astro-cid-sz7xmlte],.footer-meta[data-astro-cid-sz7xmlte],.footer-copyright[data-astro-cid-sz7xmlte]{margin:0}.footer-copy[data-astro-cid-sz7xmlte]{max-width:32rem;line-height:1.7}.footer-meta[data-astro-cid-sz7xmlte]{margin-top:1rem;color:var(--text-muted)}.footer-links[data-astro-cid-sz7xmlte]{display:flex;flex-direction:column;gap:.8rem}.footer-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{text-decoration:none}.social-links[data-astro-cid-sz7xmlte]{display:flex;flex-wrap:wrap;gap:1rem}.social-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{text-decoration:none;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);transition:color .2s ease}.social-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--accent)}.footer-copyright[data-astro-cid-sz7xmlte]{max-width:1280px;margin:1rem auto 0;padding:0;font-size:.92rem;color:var(--text-muted)}@media (max-width: 768px){.footer-content[data-astro-cid-sz7xmlte]{grid-template-columns:1fr}.social-links[data-astro-cid-sz7xmlte]{justify-content:flex-start}}a[data-astro-cid-eimmu3lg]{display:inline-block;text-decoration:none;transition:color .2s ease}a[data-astro-cid-eimmu3lg].active{font-weight:600;color:var(--accent)}.menu-toggle[data-astro-cid-6aabv5oc]{display:none;background:none;border:1px solid rgba(var(--gray-light),.95);cursor:pointer;padding:10px;width:44px;height:44px;align-items:center;justify-content:center;border-radius:999px;background:#ffffff52}.hamburger-icon[data-astro-cid-6aabv5oc]{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px}.hamburger-line[data-astro-cid-6aabv5oc]{display:block;width:100%;height:1.5px;background-color:var(--text-color);transition:transform .3s ease,opacity .3s ease}.mobile-menu[data-astro-cid-6aabv5oc]{display:none;position:fixed;top:0;right:-100%;width:min(24rem,100%);height:100vh;background-color:var(--card-background);border-left:1px solid rgba(var(--gray-light),.95);box-shadow:-18px 0 40px #181f2529;z-index:1001;transition:right .3s ease;flex-direction:column;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom)}.mobile-menu[data-astro-cid-6aabv5oc].active{right:0}.mobile-menu-header[data-astro-cid-6aabv5oc]{display:flex;justify-content:space-between;align-items:flex-start;padding:1.2rem;border-bottom:1px solid rgba(var(--gray-light),.95)}.mobile-menu-eyebrow[data-astro-cid-6aabv5oc]{margin:0 0 .45rem;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}.mobile-menu-header[data-astro-cid-6aabv5oc] h3[data-astro-cid-6aabv5oc]{margin:0;font-family:var(--font-display);font-size:1.9rem;letter-spacing:-.04em}.close-menu[data-astro-cid-6aabv5oc]{background:transparent;border:1px solid rgba(var(--gray-light),.95);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;color:var(--text-color);border-radius:999px}.mobile-menu-items[data-astro-cid-6aabv5oc]{display:flex;flex-direction:column;padding:.8rem 1.2rem 1.4rem}.mobile-menu-item[data-astro-cid-6aabv5oc]{padding:1rem 0;color:var(--text-color);text-decoration:none;font-family:var(--font-display);font-size:1.75rem;line-height:1.05;border-bottom:1px solid rgba(var(--gray-light),.72);transition:color .3s ease,transform .3s ease}.mobile-menu-item[data-astro-cid-6aabv5oc]:last-child{border-bottom:none}.mobile-menu-item[data-astro-cid-6aabv5oc]:hover,.mobile-menu-item[data-astro-cid-6aabv5oc]:active,.mobile-menu-item[data-astro-cid-6aabv5oc].active{color:var(--accent);transform:translate(4px)}.menu-overlay[data-astro-cid-6aabv5oc]{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:1000;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .3s ease}.menu-overlay[data-astro-cid-6aabv5oc].active{opacity:1;visibility:visible;pointer-events:auto}body.menu-open{overflow:hidden}@media (max-width: 880px){.menu-toggle[data-astro-cid-6aabv5oc]{display:flex!important}.mobile-menu[data-astro-cid-6aabv5oc]{display:flex}.menu-overlay[data-astro-cid-6aabv5oc]{display:block}}.site-header[data-astro-cid-3ef6ksr2]{margin:0;padding:0 clamp(1.05rem,3vw,2.2rem);background:transparent;border-bottom:1px solid rgba(var(--gray-light),.72)}.site-title[data-astro-cid-3ef6ksr2]{margin:0;font-size:1rem;font-family:var(--font-mono);font-weight:500}.site-title[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{text-decoration:none;color:var(--text-color);display:inline-flex;align-items:center;min-height:44px}.site-title[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]:hover{color:var(--text-color)}.site-title-mark[data-astro-cid-3ef6ksr2]{font-family:var(--font-mono);font-size:.82rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--text-color)}.site-nav[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:1rem 0;gap:1rem}.internal-links[data-astro-cid-3ef6ksr2] a{display:inline-flex;align-items:center;min-height:32px;padding:0;color:var(--text-muted);text-decoration:none;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase}.internal-links[data-astro-cid-3ef6ksr2] a.active{color:var(--accent)}.nav-right[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:.6rem;margin-left:auto}.internal-links[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:1.25rem}@media (max-width: 880px){.internal-links[data-astro-cid-3ef6ksr2]{display:none}.nav-right[data-astro-cid-3ef6ksr2] .menu-toggle{display:flex}}@media (max-width: 720px){.site-nav[data-astro-cid-3ef6ksr2]{padding:.8rem 0}.site-title-mark[data-astro-cid-3ef6ksr2]{font-size:.8rem;letter-spacing:.2em}}
