@keyframes astroFadeInOut{0%{opacity:1}to{opacity:0}}@keyframes astroFadeIn{0%{opacity:0;mix-blend-mode:plus-lighter}to{opacity:1;mix-blend-mode:plus-lighter}}@keyframes astroFadeOut{0%{opacity:1;mix-blend-mode:plus-lighter}to{opacity:0;mix-blend-mode:plus-lighter}}@keyframes astroSlideFromRight{0%{transform:translate(100%)}}@keyframes astroSlideFromLeft{0%{transform:translate(-100%)}}@keyframes astroSlideToRight{to{transform:translate(100%)}}@keyframes astroSlideToLeft{to{transform:translate(-100%)}}@media(prefers-reduced-motion){::view-transition-group(*),::view-transition-old(*),::view-transition-new(*){animation:none!important}[data-astro-transition-scope]{animation:none!important}}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}:root{color-scheme:dark;--font-cursive: var(--font);--bg: #1a1a1a;--text: #f0f0f0;--border: #f0f0f0;--accent: #ff6b81;--card-bg: #2d2d2d;--code-bg: #1a1a1a;--code-fg: #f0f0f0;--border-thin: 2px;--border-thick: 3px;--radius-chip: 10px 5px 12px 4px / 4px 12px 5px 10px;--radius-sketchy: 255px 15px 225px 15px / 15px 225px 15px 255px;--radius-sketchy-invert: 15px 225px 15px 255px / 255px 15px 225px 15px;--shadow-sketchy: 6px 6px 0px var(--accent);--shadow-sketchy-lg: 8px 8px 0px var(--accent);--shadow-muted: 4px 4px 0px var(--border);--shadow-muted-hover: 6px 6px 0px var(--border);--section-padding: 4rem 2rem;--content-padding: 3rem 2rem 6rem 2rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--text-xs: .8rem;--text-sm: .9rem;--text-md: 1rem;--text-lg: 1.1rem;--text-xl: 1.2rem;--text-2xl: 1.5rem;--text-3xl: 1.8rem;--text-4xl: 2.5rem;--text-5xl: 3.5rem;--max-content: 800px;--max-wide: 1000px}html.light{color-scheme:light;--bg: #ffffff;--text: #2d2d2d;--border: #2d2d2d;--accent: #ff4757;--card-bg: #fff;--code-bg: #1a1a1a;--code-fg: #f0f0f0}html,body{margin:0;padding:0;width:100%;min-height:100vh;min-height:100dvh;overflow-x:hidden}.prose{font-variant-east-asian:proportional-width;font-feature-settings:"palt" 1}body{display:flex;flex-direction:column;font-family:var(--font);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg);color:var(--text);transition:background-color .3s ease,color .3s ease}:is(.social-links,.post-list,.tag-list,.tech-stack),.site-nav ul,.list-reset{list-style:none;margin:0;padding:0}.section{width:100%;margin:0 auto;padding:var(--section-padding);box-sizing:border-box}.section-title{font-family:var(--font-cursive);font-size:var(--text-4xl);text-align:center;margin-bottom:var(--space-2xl)}.prose a:not(.breadcrumbs a),.not-found a,.music-more a{color:var(--text);text-decoration:underline;text-decoration-style:wavy;text-decoration-color:var(--accent);text-decoration-thickness:2px;text-underline-offset:5px}.prose a:hover:not(.breadcrumbs a),.not-found a:hover,.music-more a:hover{color:var(--accent)}.card{background:var(--card-bg);border:var(--border-thick) solid var(--border);border-radius:var(--radius-sketchy)}.code-stack{margin:var(--space-2xl) auto;background:var(--bg);border:var(--border-thin) solid var(--border);border-radius:var(--radius-sketchy-invert);overflow:hidden;width:100%}.stack{display:flex;flex-direction:column;gap:var(--space-lg)}.stack--sm{gap:var(--space-md)}.stack--xs{gap:var(--space-xs)}.row{display:flex;align-items:center;gap:var(--space-md)}.row--between{justify-content:space-between}.row--wrap{flex-wrap:wrap}.row--top{align-items:flex-start}.center{display:flex;align-items:center;justify-content:center}.media{display:flex;align-items:center;gap:var(--space-xl)}@media(max-width:600px){.media--stack-sm{flex-direction:column;text-align:center}}.flex-1{flex:1}.flex-2{flex:2}.pad-md{padding:var(--space-md)}.pad-lg{padding:var(--space-lg)}.pad-xl{padding:var(--space-xl)}.pad-lg-wide{padding:var(--space-lg) var(--space-xl)}.grid{display:grid}.grid--cards{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem}.section--wide{max-width:var(--max-wide)}.section--content{max-width:var(--max-content)}.card--shadow{box-shadow:var(--shadow-sketchy)}.card--shadow-lg{box-shadow:var(--shadow-sketchy-lg)}.site-nav{width:100%;align-self:center;top:0;left:0;position:fixed;z-index:100;background:var(--bg);border-bottom:var(--border-thin) solid var(--border)}.site-nav ul{display:flex;gap:1.5rem;align-items:center;margin:0;padding:var(--space-md) var(--space-xl)}.site-nav .toggle-item{margin-left:auto;margin-right:var(--space-lg)}.site-nav .nav-link{text-decoration:none;color:var(--text-main)}.site-nav .nav-link.active{font-weight:700;border-bottom:var(--border-thin) solid var(--accent)}.site-footer{margin-top:auto;padding:3rem 0 4rem;width:100%;position:relative}.site-footer:before{content:"";position:absolute;top:0;left:10%;right:10%;height:2px;border-top:var(--border-thin) dashed var(--border);opacity:.5}.footer-content{max-width:var(--max-content);margin:0 auto;padding:0 var(--space-xl);display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.sign-off{font-family:var(--font-cursive);color:var(--text);opacity:.6;font-size:var(--text-lg)}.social-links{display:flex;gap:var(--space-xl);flex-wrap:wrap;justify-content:center}.social-links li a{color:var(--text);text-decoration:none;font-weight:700;font-size:var(--text-lg);transition:color .2s;position:relative;padding-bottom:4px}.social-links li a:after{content:"";position:absolute;width:100%;height:3px;bottom:0;left:0;background:var(--accent);border-radius:10px;transform:scaleX(0);transform-origin:right;transition:transform .3s cubic-bezier(.65,0,.35,1)}.social-links li a:hover{color:var(--accent)}.social-links li a:hover:after{transform:scaleX(1);transform-origin:left}.sketchy-btn{font-family:inherit;padding:var(--space-xs) var(--space-md);border:var(--border-thin) solid var(--border);background:transparent;color:var(--text);border-radius:var(--radius-chip);cursor:pointer}.sketchy-btn:active{transform:translate(2px,2px)}.breadcrumbs{width:100%;border-bottom:var(--border-thin) dashed var(--border);background:var(--bg);padding:var(--space-md) 0;position:sticky;top:0;z-index:50}.breadcrumb-container{max-width:var(--max-content);margin:0 auto;padding:0 var(--space-xl);display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-cursive);font-size:var(--text-lg)}.breadcrumb-container a{color:var(--text);text-decoration:none;border-bottom:var(--border-thin) solid transparent;transition:color .2s,border-color .2s}.breadcrumb-container a:hover{color:var(--accent);border-bottom:var(--border-thin) solid var(--accent)}.breadcrumb-container .separator{color:var(--border);font-weight:700}.breadcrumb-container .current{color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reading-container{width:100%;max-width:var(--max-content);margin:0 auto;padding:var(--content-padding);box-sizing:border-box}.post-content{width:100%}.post-header{margin-bottom:var(--space-2xl);padding-bottom:var(--space-xl);border-bottom:var(--border-thick) solid var(--border);border-radius:0 0 255px 15px/0 0 15px 10px}.post-header h1{font-family:var(--font-cursive);font-size:var(--text-5xl);color:var(--text);margin:0 0 var(--space-md) 0;line-height:1.1}.meta-row{display:flex;align-items:center;gap:var(--space-md);font-family:var(--font-cursive);color:var(--text);opacity:.8;font-size:var(--text-lg);flex-wrap:wrap}.meta-row .divider{color:var(--accent)}.meta-row .tags{display:flex;gap:var(--space-xs);color:var(--accent);font-weight:700}.image-wrapper{overflow:hidden;border-radius:var(--radius-sketchy)}.image-wrapper img{display:block;width:100%;height:auto;filter:sepia(.2)}.info-group{margin-bottom:var(--space-md)}.info-group dt{font-weight:700;font-size:var(--text-sm);text-transform:uppercase;margin-bottom:.2rem;opacity:.7}.info-group dd{margin-left:0;font-size:var(--text-xl);font-family:var(--font-cursive)}.project-card{display:flex;flex-direction:column;transition:transform .2s ease}.project-card:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-sketchy-lg)}.project-card.archived{opacity:.85;box-shadow:var(--shadow-muted)}.project-card.archived:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow-muted-hover)}.project-card p{flex-grow:1}.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);border-bottom:var(--border-thin) dashed var(--border);padding-bottom:.5rem;margin-bottom:1rem}.card-header h3{margin:0;border:none;padding:0;font-size:var(--text-2xl)}.sketchy-stamp{font-family:var(--font-cursive);font-size:var(--text-xs);text-transform:uppercase;color:var(--text);border:var(--border-thin) solid var(--text);padding:.2rem .6rem;opacity:.6;border-radius:var(--radius-sketchy);transform:rotate(4deg);flex-shrink:0}.tech-stack{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-bottom:var(--space-lg)}.tech-stack li{font-size:.85rem;padding:.2rem .6rem;border:1px solid var(--border);border-radius:var(--radius-chip)}.sketchy-link{align-self:flex-start;color:var(--text);text-decoration:none;font-weight:700;border-bottom:var(--border-thin) solid var(--accent)}.sketchy-link:hover{color:var(--accent)}.music-cover{display:block;margin-bottom:var(--space-md)}.music-cover img{width:100%;height:auto;border:var(--border-thin) solid var(--border);border-radius:var(--radius-sketchy)}.music-artist{margin-top:-.5rem;margin-bottom:.75rem;opacity:.7;font-style:italic}.music-more{text-align:center;margin-top:var(--space-xl)}.post-list{display:flex;flex-direction:column;gap:var(--space-xl)}.post-item{transition:transform .2s ease,box-shadow .2s ease}.post-item:hover{transform:translate(4px);box-shadow:var(--shadow-sketchy-lg)}.post-meta{font-family:var(--font-cursive);font-size:var(--text-md);color:var(--text);opacity:.7;margin-bottom:.5rem;border-bottom:var(--border-thin) dashed var(--border);display:inline-block;padding-bottom:.2rem}.title-link{text-decoration:none;color:var(--text);display:block}.title-link h3{font-size:var(--text-3xl);margin:.5rem 0}.title-link h3:hover{color:var(--accent);text-decoration:underline;text-decoration-style:wavy}.blog-section p{margin-bottom:var(--space-lg);line-height:1.6}.tag-list{display:flex;gap:var(--space-md);flex-wrap:wrap}.tag-list li{font-family:var(--font-cursive);font-size:var(--text-sm);color:var(--accent);font-weight:700}.code-stack{background:var(--code-bg)}.stack-scroll{overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--accent) transparent}.stack-scroll::-webkit-scrollbar{height:12px}.stack-scroll::-webkit-scrollbar-track{background:transparent;margin:0 2rem}.stack-scroll::-webkit-scrollbar-thumb{background-color:var(--accent);border-radius:10px;border:4px solid var(--code-bg)}.stack-scroll::-webkit-scrollbar-corner{background:transparent}.stack-scroll pre{background:transparent!important;border:none!important;margin:0!important;padding:0!important;border-radius:0!important;overflow:visible!important;font-family:var(--font-mono)!important}.stack-scroll pre>code{display:block!important;overflow-x:visible!important;padding:var(--space-lg)!important;padding-bottom:var(--space-xl)!important}.block-divider{border:none;border-top:var(--border-thin) dashed var(--border);opacity:.3;margin:0}.code-embed{margin:var(--space-2xl) 0}.code-embed pre{margin-top:0;border-top-left-radius:0;border-top-right-radius:0}.embed-header{display:flex;justify-content:space-between;align-items:center;background:var(--code-bg);border:var(--border-thin) solid var(--border);border-bottom:none;padding:var(--space-sm) var(--space-lg);font-family:var(--font-cursive);font-size:.95rem;color:var(--code-fg);opacity:.8;border-radius:15px 225px 0 0/255px 15px 0 0}.embed-header a{color:var(--code-fg)!important;text-decoration:none;font-weight:700}.embed-header a:hover{color:var(--accent)!important;text-decoration:underline wavy;text-underline-offset:5px}.embed-header .meta{color:var(--code-fg);opacity:.6;font-size:var(--text-sm)}.mermaid-wrapper{margin:var(--space-3xl) auto;width:100%;display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.mermaid-wrapper figcaption{font-family:var(--font-cursive);font-size:var(--text-md);color:var(--text);opacity:.7;text-align:center;max-width:500px;line-height:1.4}.mermaid-wrapper figcaption:before{content:"";display:block;width:60px;height:3px;background:var(--accent);margin:0 auto var(--space-md) auto;border-radius:10px 2px}.mermaid-wrapper figcaption strong{color:var(--accent)}.mermaid-graph{width:100%;max-width:500px;margin:0 auto}.mermaid-graph svg{width:100%!important;height:auto!important;max-width:100%!important}.hero{min-height:100vh;min-height:100dvh;width:100%;display:flex;align-items:center;justify-content:center;padding:80px var(--space-xl) var(--space-xl) var(--space-xl);box-sizing:border-box}.hero.container{display:flex;justify-content:center;align-items:center;height:100%}main{width:100%;min-height:100vh;min-height:100dvh;flex:1 0 auto}.not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:60vh;text-align:center}.not-found h1{font-size:6rem;margin:0}.prose{font-size:var(--text-lg);color:var(--text)}.prose code{font-family:inherit;color:var(--accent)}.prose h2,.prose h3{font-family:var(--font);color:var(--text);margin-bottom:var(--space-md);line-height:1}.prose h2{font-size:var(--text-3xl)}.prose h3{font-size:var(--text-2xl)}.prose p{margin-bottom:var(--space-lg)}.prose ul,.prose ol{margin-bottom:var(--space-lg);padding-left:var(--space-lg)}.prose ul li,.prose ol li{margin-bottom:var(--space-xs)}.prose blockquote{margin:var(--space-xl) 0;padding:var(--space-md) var(--space-lg);border-left:var(--border-thin) solid var(--accent);background:var(--card-bg);font-style:italic;border-radius:0 15px 15px 0}.prose pre>code{display:block;overflow-x:auto;padding:var(--space-lg);padding-bottom:var(--space-xl);scrollbar-width:auto;scrollbar-color:var(--accent) transparent}.prose pre>code::-webkit-scrollbar{height:14px}.prose pre>code::-webkit-scrollbar-track{background:transparent;margin:0 2rem}.prose pre>code::-webkit-scrollbar-thumb{background-color:var(--accent);border-radius:10px;border:4px solid var(--bg)}.prose pre>code::-webkit-scrollbar-thumb:hover{background-color:var(--text)}.prose pre>code::-webkit-scrollbar-corner{background:transparent}.prose pre{font-family:var(--font-mono);background:var(--bg);padding:0;overflow:hidden;border:var(--border-thin) solid var(--border);border-radius:var(--radius-sketchy-invert);overflow-x:auto;margin:var(--space-xl) 0}.prose .code-embed pre{margin-top:0;border-top-left-radius:0;border-top-right-radius:0}
