.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}.theme-toggle[data-astro-cid-x3pjskd3]{position:relative}.sun-icon[data-astro-cid-x3pjskd3],.moon-icon[data-astro-cid-x3pjskd3]{position:absolute;transition:opacity .15s ease,transform .15s ease}html:not([data-theme=dark]) .sun-icon[data-astro-cid-x3pjskd3]{opacity:1;transform:rotate(0)}html:not([data-theme=dark]) .moon-icon[data-astro-cid-x3pjskd3]{opacity:0;transform:rotate(-90deg)}[data-theme=dark] .sun-icon[data-astro-cid-x3pjskd3]{opacity:0;transform:rotate(90deg)}[data-theme=dark] .moon-icon[data-astro-cid-x3pjskd3]{opacity:1;transform:rotate(0)}:root{--md-sys-color-primary: #0d5c6d;--md-sys-color-on-primary: #ffffff;--md-sys-color-primary-container: #b8eaff;--md-sys-color-on-primary-container: #001f28;--md-sys-color-secondary: #4a6267;--md-sys-color-on-secondary: #ffffff;--md-sys-color-secondary-container: #cde7ec;--md-sys-color-on-secondary-container: #051f23;--md-sys-color-tertiary: #525e7d;--md-sys-color-on-tertiary: #ffffff;--md-sys-color-tertiary-container: #dae2ff;--md-sys-color-on-tertiary-container: #0e1b36;--md-sys-color-background: #f8fafa;--md-sys-color-on-background: #191c1c;--md-sys-color-surface: #ffffff;--md-sys-color-on-surface: #191c1c;--md-sys-color-surface-variant: #dbe4e6;--md-sys-color-on-surface-variant: #3f484a;--md-sys-color-outline: #5f6a6c;--md-sys-color-outline-variant: #bfc8ca;--md-sys-color-error: #ba1a1a;--md-sys-color-on-error: #ffffff;--md-sys-color-success: #146b3a;--md-sys-elevation-1: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--md-sys-elevation-2: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--md-sys-elevation-3: 0 10px 20px rgba(0,0,0,.08), 0 3px 6px rgba(0,0,0,.06);--md-sys-typescale-body-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--md-sys-typescale-display-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.5rem;--space-6: 2rem;--space-7: 2.5rem;--space-8: 3rem;--space-9: 4rem;--max-width: 1100px;--content-width: 680px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease}[data-theme=dark]{--md-sys-color-primary: #5dd5fc;--md-sys-color-on-primary: #003542;--md-sys-color-primary-container: #004e5f;--md-sys-color-on-primary-container: #b8eaff;--md-sys-color-secondary: #b1cbcf;--md-sys-color-on-secondary: #1c3438;--md-sys-color-secondary-container: #334b4f;--md-sys-color-on-secondary-container: #cde7ec;--md-sys-color-tertiary: #bac6ea;--md-sys-color-on-tertiary: #24304d;--md-sys-color-tertiary-container: #3b4664;--md-sys-color-on-tertiary-container: #dae2ff;--md-sys-color-background: #0e1415;--md-sys-color-on-background: #e0e3e3;--md-sys-color-surface: #191c1c;--md-sys-color-on-surface: #e0e3e3;--md-sys-color-surface-variant: #3f484a;--md-sys-color-on-surface-variant: #bfc8ca;--md-sys-color-outline: #899294;--md-sys-color-outline-variant: #3f484a;--md-sys-elevation-1: 0 1px 3px rgba(0,0,0,.3), 0 1px 2px rgba(0,0,0,.24);--md-sys-elevation-2: 0 4px 6px rgba(0,0,0,.28), 0 2px 4px rgba(0,0,0,.24);--md-sys-elevation-3: 0 10px 20px rgba(0,0,0,.32), 0 3px 6px rgba(0,0,0,.24)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--md-sys-typescale-body-font);font-size:1rem;line-height:1.6;color:var(--md-sys-color-on-background);background-color:var(--md-sys-color-background);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color var(--transition-normal),color var(--transition-normal)}h1,h2,h3,h4,h5,h6{font-family:var(--md-sys-typescale-display-font);font-weight:600;line-height:1.25;color:var(--md-sys-color-on-surface);letter-spacing:-.01em}h1{font-size:2.5rem;font-weight:700;letter-spacing:-.02em}h2{font-size:1.75rem;margin-top:var(--space-8);margin-bottom:var(--space-4)}h3{font-size:1.375rem;margin-top:var(--space-6);margin-bottom:var(--space-3)}p{margin-bottom:var(--space-5);color:var(--md-sys-color-on-surface-variant)}a{color:var(--md-sys-color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--md-sys-color-secondary);text-decoration:underline;text-underline-offset:2px}strong{font-weight:600;color:var(--md-sys-color-on-surface)}small{font-size:.875rem}.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-5)}.content{max-width:var(--content-width)}.section{padding:var(--space-9) 0}.section-alt{background-color:var(--md-sys-color-surface)}.site-header{position:sticky;top:0;z-index:100;background-color:var(--md-sys-color-surface);border-bottom:1px solid var(--md-sys-color-outline-variant);box-shadow:var(--md-sys-elevation-1);transition:background-color var(--transition-normal),box-shadow var(--transition-normal)}.header-inner{display:flex;justify-content:space-between;align-items:center;height:64px}.site-logo{font-size:1.125rem;font-weight:700;color:var(--md-sys-color-on-surface);text-decoration:none;letter-spacing:-.01em}.site-logo:hover{color:var(--md-sys-color-primary);text-decoration:none}.header-right{display:flex;align-items:center;gap:var(--space-6)}.site-nav{display:flex;gap:var(--space-5)}.site-nav a{font-size:.9375rem;font-weight:500;color:var(--md-sys-color-on-surface-variant);text-decoration:none;padding:var(--space-2) 0;position:relative}.site-nav a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--md-sys-color-primary);transition:width var(--transition-fast)}.site-nav a:hover,.site-nav a.active{color:var(--md-sys-color-primary);text-decoration:none}.site-nav a:hover:after,.site-nav a.active:after{width:100%}.site-footer{background-color:var(--md-sys-color-surface);border-top:1px solid var(--md-sys-color-outline-variant);padding:var(--space-8) 0;margin-top:var(--space-9)}.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.footer-text{font-size:.875rem;color:var(--md-sys-color-on-surface-variant);margin:0}.footer-links{display:flex;gap:var(--space-5)}.footer-links a{font-size:.875rem;color:var(--md-sys-color-on-surface-variant)}.footer-links a:hover{color:var(--md-sys-color-primary)}.hero{padding:var(--space-9) 0;background:linear-gradient(135deg,var(--md-sys-color-surface) 0%,var(--md-sys-color-background) 100%)}.hero h1{font-size:clamp(2.25rem,5vw,3.25rem);margin-bottom:var(--space-4);color:var(--md-sys-color-on-surface)}.hero .subtitle{font-size:1.25rem;color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--space-6);max-width:560px;line-height:1.5}.hero-actions{display:flex;gap:var(--space-4);flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--md-sys-typescale-body-font);font-size:.9375rem;font-weight:500;text-decoration:none;border-radius:var(--radius-full);border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);box-shadow:var(--md-sys-elevation-1)}.btn-primary:hover{background-color:var(--md-sys-color-primary-container);color:var(--md-sys-color-on-primary-container);box-shadow:var(--md-sys-elevation-2);text-decoration:none}.btn-tonal{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container)}.btn-tonal:hover{box-shadow:var(--md-sys-elevation-1);text-decoration:none}.btn-outline{background-color:transparent;color:var(--md-sys-color-primary);border:1px solid var(--md-sys-color-outline)}.btn-outline:hover{background-color:var(--md-sys-color-primary-container);border-color:var(--md-sys-color-primary);text-decoration:none}.card{background-color:var(--md-sys-color-surface);border-radius:var(--radius-md);padding:var(--space-5);transition:box-shadow var(--transition-normal)}.card-elevated{box-shadow:var(--md-sys-elevation-1)}.card-elevated:hover{box-shadow:var(--md-sys-elevation-2)}.card-outlined{border:1px solid var(--md-sys-color-outline-variant)}.card-outlined:hover{border-color:var(--md-sys-color-outline)}.post-list{display:flex;flex-direction:column;gap:var(--space-5)}.post-card{background-color:var(--md-sys-color-surface);border-radius:var(--radius-md);padding:var(--space-5);border:1px solid var(--md-sys-color-outline-variant);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.post-card:hover{border-color:var(--md-sys-color-outline);box-shadow:var(--md-sys-elevation-1)}.post-meta{display:flex;align-items:center;gap:var(--space-3);font-size:.875rem;color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--space-2)}.post-meta .separator{color:var(--md-sys-color-outline)}.post-card h3{font-size:1.25rem;margin:0 0 var(--space-2) 0}.post-card h3 a{color:var(--md-sys-color-on-surface)}.post-card h3 a:hover{color:var(--md-sys-color-primary);text-decoration:none}.post-excerpt{color:var(--md-sys-color-on-surface-variant);margin-bottom:var(--space-3);line-height:1.6}.tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag{display:inline-block;padding:var(--space-1) var(--space-3);background-color:var(--md-sys-color-surface-variant);color:var(--md-sys-color-on-surface-variant);font-size:.8125rem;font-weight:500;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.tag:hover{background-color:var(--md-sys-color-secondary-container);color:var(--md-sys-color-on-secondary-container);text-decoration:none}.post-header{margin-bottom:var(--space-8)}.post-header h1{margin-bottom:var(--space-4)}.post-content{max-width:var(--content-width)}.post-content>*:first-child{margin-top:0}.post-content p{font-size:1.0625rem;line-height:1.7}.post-content h2{margin-top:var(--space-8);padding-top:var(--space-4);border-top:1px solid var(--md-sys-color-outline-variant)}.post-content h3{margin-top:var(--space-6)}.post-content ul,.post-content ol{margin-bottom:var(--space-5);padding-left:var(--space-5)}.post-content li{margin-bottom:var(--space-2);color:var(--md-sys-color-on-surface-variant);line-height:1.6}.post-content blockquote{margin:var(--space-6) 0;padding:var(--space-4) var(--space-5);background-color:var(--md-sys-color-surface-variant);border-left:4px solid var(--md-sys-color-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.post-content blockquote p{margin-bottom:0;font-style:italic;color:var(--md-sys-color-on-surface)}.post-content pre{margin:var(--space-5) 0;padding:var(--space-4);background-color:var(--md-sys-color-surface-variant);border-radius:var(--radius-sm);overflow-x:auto;font-size:.9rem;line-height:1.5}.post-content code{font-family:Fira Code,SF Mono,Consolas,monospace;font-size:.9em}.post-content p code,.post-content li code{padding:.15em .4em;background-color:var(--md-sys-color-surface-variant);border-radius:4px}.post-content img{max-width:100%;height:auto;border-radius:var(--radius-sm);margin:var(--space-5) 0}.post-content a{text-decoration:underline;text-underline-offset:2px}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;color:var(--md-sys-color-on-surface-variant);transition:background-color var(--transition-fast),color var(--transition-fast)}.theme-toggle:hover{background-color:var(--md-sys-color-surface-variant);color:var(--md-sys-color-on-surface)}.theme-toggle svg{width:20px;height:20px}.share-buttons{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) 0;border-top:1px solid var(--md-sys-color-outline-variant);margin-top:var(--space-8)}.share-buttons span{font-size:.875rem;font-weight:500;color:var(--md-sys-color-on-surface-variant)}.share-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--md-sys-color-surface-variant);color:var(--md-sys-color-on-surface-variant);transition:all var(--transition-fast)}.share-btn:hover{background-color:var(--md-sys-color-primary);color:var(--md-sys-color-on-primary);text-decoration:none}.share-btn:hover svg,.share-btn:hover span{color:inherit}.share-btn svg{width:18px;height:18px}.related-posts{margin-top:var(--space-8);padding-top:var(--space-6);border-top:1px solid var(--md-sys-color-outline-variant)}.related-posts h2{font-size:1.25rem;margin-top:0;margin-bottom:var(--space-5)}.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-4)}.post-footer{margin-top:var(--space-8);padding-top:var(--space-5)}.post-footer a{font-size:.9375rem;color:var(--md-sys-color-on-surface-variant)}.post-footer a:hover{color:var(--md-sys-color-primary)}.text-center{text-align:center}.text-muted{color:var(--md-sys-color-on-surface-variant)}.mb-1{margin-bottom:var(--space-2)}.mb-2{margin-bottom:var(--space-4)}.mb-3{margin-bottom:var(--space-5)}.mb-4{margin-bottom:var(--space-6)}.mb-5{margin-bottom:var(--space-8)}.mt-1{margin-top:var(--space-2)}.mt-2{margin-top:var(--space-4)}.mt-3{margin-top:var(--space-5)}.mt-4{margin-top:var(--space-6)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.error-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center}.error-page h1{font-size:6rem;color:var(--md-sys-color-outline);margin-bottom:var(--space-2)}.error-page p{font-size:1.25rem;margin-bottom:var(--space-6)}@media(max-width:768px){:root{--space-9: 3rem}h1{font-size:2rem}h2{font-size:1.5rem}.header-inner{height:auto;flex-direction:column;padding:var(--space-4) 0;gap:var(--space-4)}.header-right{width:100%;justify-content:space-between}.site-nav{gap:var(--space-4)}.hero h1{font-size:2rem}.hero .subtitle{font-size:1.125rem}.footer-inner{flex-direction:column;text-align:center}.post-content p{font-size:1rem}.share-buttons{flex-wrap:wrap}}@media(max-width:480px){.container{padding:0 var(--space-4)}.hero-actions{flex-direction:column}.btn{width:100%;justify-content:center}}
