.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}header[data-astro-cid-3ef6ksr2]{background:var(--color-bg)}nav[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;justify-content:space-between;min-height:4rem;gap:var(--space-lg);padding-block:var(--space-sm)}.name[data-astro-cid-3ef6ksr2]{font-family:var(--font-heading);font-weight:500;font-size:.95rem;color:var(--color-text);text-decoration:none;letter-spacing:-.01em}.name[data-astro-cid-3ef6ksr2]:hover{color:var(--color-accent)}ul[data-astro-cid-3ef6ksr2]{display:flex;list-style:none;gap:var(--space-lg);align-items:center;flex-shrink:0}.nav-link[data-astro-cid-3ef6ksr2]{font-size:.9rem;color:var(--color-text-muted);text-decoration:none;padding:var(--space-xs) 0;transition:color .15s ease;text-transform:lowercase}.nav-link[data-astro-cid-3ef6ksr2]:hover,.nav-link[data-astro-cid-3ef6ksr2].active{color:var(--color-text)}.nav-link[data-astro-cid-3ef6ksr2].active{text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--color-accent);text-decoration-thickness:2px}.theme-toggle[data-astro-cid-3ef6ksr2]{border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-muted);width:2.25rem;height:2.25rem;padding:0;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:color .15s ease,border-color .15s ease,background-color .15s ease}.theme-toggle-icon[data-astro-cid-3ef6ksr2]{position:relative;display:inline-block;width:1rem;height:1rem;line-height:0}.icon[data-astro-cid-3ef6ksr2]{position:absolute;inset:0;width:100%;height:100%;transition:opacity .2s ease,transform .2s ease;pointer-events:none}.icon-sun[data-astro-cid-3ef6ksr2]{opacity:0;transform:scale(.6) rotate(-30deg)}.icon-moon[data-astro-cid-3ef6ksr2]{opacity:1;transform:scale(1)}:root[data-theme=dark] .theme-toggle[data-astro-cid-3ef6ksr2] .icon-sun[data-astro-cid-3ef6ksr2]{opacity:1;transform:scale(1) rotate(0)}:root[data-theme=dark] .theme-toggle[data-astro-cid-3ef6ksr2] .icon-moon[data-astro-cid-3ef6ksr2]{opacity:0;transform:scale(.6) rotate(20deg)}.theme-toggle[data-astro-cid-3ef6ksr2]:hover{color:var(--color-text);border-color:var(--color-accent)}.theme-toggle[data-astro-cid-3ef6ksr2]:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(max-width:640px){nav[data-astro-cid-3ef6ksr2]{gap:var(--space-sm)}ul[data-astro-cid-3ef6ksr2]{gap:var(--space-sm)}.nav-link[data-astro-cid-3ef6ksr2]{font-size:.85rem}}footer[data-astro-cid-sz7xmlte]{border-top:1px solid var(--color-border);padding-block:var(--space-lg);margin-top:auto}.links[data-astro-cid-sz7xmlte]{display:flex;justify-content:center;gap:var(--space-lg)}.links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{color:var(--color-text-muted);transition:color .15s ease}.links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:var(--color-text)}:root{--color-bg: #faf8f5;--color-surface: #ffffff;--color-text: #2c2825;--color-text-muted: #8a817a;--color-border: #e8e3dd;--color-accent: #c2642b;--color-blue: #4a7fc4;--color-green: #5a8a5e;--color-purple: #7e6aab;--color-code-bg: #f0ece7;--color-code-block-bg: #2c2825;--color-code-block-text: #e8e3dd;--tag-blue-bg: #e2ebf5;--tag-blue-text: #2a5a9b;--tag-orange-bg: #f5e4d7;--tag-orange-text: #964718;--tag-green-bg: #e2eee3;--tag-green-text: #3a6b3e;--tag-purple-bg: #e7e2f2;--tag-purple-text: #594785;--font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--max-width-prose: 720px;--max-width-layout: 1000px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;color-scheme:light}:root[data-theme=dark]{--color-bg: #1d1a18;--color-surface: #262220;--color-text: #eee6de;--color-text-muted: #b5aaa1;--color-border: #403832;--color-accent: #e38b58;--color-blue: #79a7df;--color-green: #7caf82;--color-purple: #ab94cf;--color-code-bg: #342f2b;--color-code-block-bg: #14110f;--color-code-block-text: #f0e8e0;--tag-blue-bg: #233b5d;--tag-blue-text: #bdd6ff;--tag-orange-bg: #523421;--tag-orange-text: #ffbf99;--tag-green-bg: #27472d;--tag-green-text: #b1e3b8;--tag-purple-bg: #403457;--tag-purple-text: #d6c2ff;color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-body);color:var(--color-text);background-color:var(--color-bg);line-height:1.7;-webkit-font-smoothing:antialiased}body{min-height:100dvh;display:flex;flex-direction:column;background-color:var(--color-bg)}img,svg{display:block;max-width:100%}a{color:var(--color-accent);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-text)}a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:500;line-height:1.3;letter-spacing:-.02em}h1{font-size:clamp(1.6rem,1.2rem + 2vw,2.2rem)}.tags{font-family:var(--font-mono);font-size:.75rem;color:var(--color-text-muted);letter-spacing:.01em}.stack-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-xl);margin-bottom:var(--space-xl)}.stack-section h4{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.case-study .back{display:inline-block;font-family:var(--font-mono);font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--space-xl)}.case-study .back:hover{color:var(--color-text)}.case-study .header{margin-bottom:var(--space-2xl)}.case-study .header h1{font-size:clamp(1.75rem,1.3rem + 2.2vw,2.5rem);margin-bottom:var(--space-xs)}.case-study .subtitle{font-size:1.15rem;color:var(--color-text-muted);margin-bottom:var(--space-md)}.case-study .hero-screenshot{position:relative;left:50%;transform:translate(-50%);width:100vw;max-width:1200px;padding-inline:var(--space-lg);margin-block:var(--space-2xl)}.case-study .hero-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 25px 50px -12px #00000026,0 0 0 1px var(--color-border)}:root[data-theme=dark] .case-study .hero-frame{box-shadow:0 25px 50px -12px #00000080,0 0 0 1px var(--color-border)}.case-study .hero-bar{display:flex;gap:6px;padding:12px 16px;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.case-study .hero-bar .dot{width:10px;height:10px;border-radius:50%}.case-study .hero-bar .dot:nth-child(1){background:#ff5f56}.case-study .hero-bar .dot:nth-child(2){background:#ffbd2e}.case-study .hero-bar .dot:nth-child(3){background:#27c93f}.case-study .hero-frame img{width:100%;height:auto;display:block}.case-study .arch-diagram{background:var(--color-code-block-bg);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-sm);display:flex;flex-direction:column;align-items:center;gap:0}.case-study .arch-box{border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-lg);color:var(--color-code-block-text);font-family:var(--font-mono);font-size:.85rem;text-align:center;width:100%;max-width:260px}.case-study .arch-box-inner{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-xs) var(--space-sm);margin:var(--space-xs) 0;font-size:.8rem}.case-study .arch-detail{font-size:.75rem;opacity:.7}.case-study .arch-connector{display:flex;justify-content:center;gap:var(--space-lg);padding:var(--space-xs) 0}.case-study .arch-label{font-family:var(--font-mono);font-size:.75rem;color:var(--color-border);opacity:.7}.case-study .arch-caption{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:var(--space-xl)}.case-study .live-link{font-family:var(--font-mono);font-size:.85rem;color:var(--color-text-muted);text-decoration:none}.case-study .live-link:hover{color:var(--color-accent)}@media(max-width:640px){.case-study .subtitle{font-size:1.05rem}.case-study .arch-diagram{padding:var(--space-md)}.case-study .arch-box{max-width:100%}}h2{font-size:clamp(1.25rem,1.1rem + .8vw,1.5rem)}h3{font-size:1.2rem}p+p{margin-top:var(--space-md)}code{font-family:var(--font-mono);font-size:.9em;background:var(--color-code-bg);padding:.15em .4em;border-radius:4px}.container{width:100%;max-width:var(--max-width-layout);margin-inline:auto;padding-inline:var(--space-lg)}@media(max-width:640px){.container{padding-inline:var(--space-md)}}.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}.prose{max-width:var(--max-width-prose)}.prose h2{margin-top:var(--space-2xl);margin-bottom:var(--space-md)}.prose h3{margin-top:var(--space-xl);margin-bottom:var(--space-sm)}.prose p{margin-bottom:var(--space-md);color:var(--color-text)}.prose ul,.prose ol{margin-bottom:var(--space-md);padding-left:var(--space-xl)}.prose li{margin-bottom:var(--space-xs)}.prose pre{background:var(--color-code-block-bg);color:var(--color-code-block-text);padding:var(--space-lg);border-radius:var(--radius-md);overflow-x:auto;margin-bottom:var(--space-lg);font-family:var(--font-mono);font-size:.875rem;line-height:1.6}.prose pre code{background:none;padding:0;font-size:inherit}.prose a{text-decoration:underline;text-underline-offset:2px}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}main{animation:fade-up .4s ease-out}main[data-astro-cid-37fxchfa]{flex:1;padding-block:var(--space-2xl)}@media(max-width:640px){main[data-astro-cid-37fxchfa]{padding-block:var(--space-xl)}}
