:root{--accent: #2D6B3F;--accent-hover: #245533;--accent-muted: #2D6B3F1A;--bg-primary: #FFFFFF;--bg-secondary: #F4F5F5;--bg-tertiary: #EAEBEB;--bg-hover: #EDEFED;--bg-active: #E5E8E5;--text-primary: #1E3322;--text-secondary: #6B7B6B;--text-tertiary: #808A80;--text-disabled: #B0B8B0;--text-inverse: #FFFFFF;--border-default: #D0D4D0;--border-strong: #B0B8B0;--border-subtle: #E8E9E8;--border-focus: #2D6B3F;--success: #2D6B3F;--warning: #E8A800;--error: #D93025;--info: #3B82C4;--recording: #D93025;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-pill: 9999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 40px;--space-8: 64px;--space-9: 96px;--shadow-sm: 0 1px 2px rgba(30, 51, 34, .05);--shadow-md: 0 12px 30px rgba(30, 51, 34, .08);--font-body: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-sans: "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-caption: "Inter", -apple-system, system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", Consolas, monospace;--font-heading: "Playfair Display", Georgia, serif}@font-face{font-family:Geist;src:url(/fonts/Geist-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Geist;src:url(/fonts/Geist-Medium.woff2) format("woff2");font-weight:500;font-style:normal;font-display:swap}@font-face{font-family:Inter;src:url(/fonts/Inter-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:IBM Plex Mono;src:url(/fonts/IBMPlexMono-Regular.woff2) format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Playfair Display;src:url(/fonts/PlayfairDisplay-SemiBold.woff2) format("woff2");font-weight:600;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;scrollbar-gutter:stable}html,body{margin:0;padding:0}body{font-family:var(--font-body);font-size:16px;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}img,svg{max-width:100%;display:block}button{font:inherit;cursor:pointer}ul,ol{margin:0;padding:0}h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600;color:var(--text-primary);line-height:1.15;margin:0 0 var(--space-4);letter-spacing:-.01em}h1{font-size:clamp(2.5rem,8vw,4rem)}h2{font-size:clamp(1.75rem,4vw,2.25rem)}h3{font-size:clamp(1.125rem,2.5vw,1.25rem)}p{margin:0 0 var(--space-4);color:var(--text-secondary);max-width:38rem}a{color:var(--text-primary);text-decoration:underline;text-decoration-color:var(--border-default);text-underline-offset:.2em;transition:color .15s ease,text-decoration-color .15s ease}a:hover{color:var(--accent);text-decoration-color:var(--accent)}code{font-family:var(--font-mono);font-size:.875em}:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.container{max-width:960px;margin:0 auto;padding:0 var(--space-4)}.container-prose{max-width:720px;margin:0 auto;padding:0 var(--space-4)}@media(min-width:768px){.container,.container-prose{padding:0 var(--space-5)}}main>section{padding-block:var(--space-8)}@media(min-width:1024px){main>section{padding-block:var(--space-9)}}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 var(--space-5);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;text-decoration:none;border:1px solid transparent;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease;width:100%;white-space:nowrap}@media(min-width:640px){.btn{width:auto}}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover{background:var(--accent-hover);color:var(--text-inverse);text-decoration:none}.btn-secondary{background:transparent;color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);text-decoration:none;border-color:var(--border-strong)}.btn-group{display:flex;flex-direction:column;gap:var(--space-3)}@media(min-width:640px){.btn-group{flex-direction:row;flex-wrap:wrap}}.screenshot-frame{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);background:var(--bg-secondary);overflow:hidden;box-shadow:var(--shadow-md);width:100%}.screenshot-frame img{width:100%;height:100%;object-fit:cover;display:block}.screenshot-placeholder{display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:.75rem;color:var(--text-tertiary)}.screenshot-hero{aspect-ratio:16 / 10}.screenshot-prompt{aspect-ratio:4 / 3}.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}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}summary{cursor:pointer}summary::-webkit-details-marker{display:none}.site-header:where(.astro-ctg3m53h){border-bottom:1px solid var(--border-subtle);background:var(--bg-primary)}.site-header-row:where(.astro-ctg3m53h){display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);height:56px}.brand:where(.astro-ctg3m53h){font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--text-primary);text-decoration:none;letter-spacing:-.005em;line-height:1}.brand:where(.astro-ctg3m53h):hover{color:var(--accent)}.site-nav:where(.astro-ctg3m53h){display:flex;align-items:center;gap:var(--space-5)}.site-nav:where(.astro-ctg3m53h) a:where(.astro-ctg3m53h){font-family:var(--font-body);font-size:.9375rem;color:var(--text-secondary);text-decoration:none}.site-nav:where(.astro-ctg3m53h) a:where(.astro-ctg3m53h):hover{color:var(--accent)}@media(min-width:768px){.site-header-row:where(.astro-ctg3m53h){height:64px}}.footer:where(.astro-sz7xmlte){padding-block:var(--space-7);border-top:1px solid var(--border-subtle)}.footer-line:where(.astro-sz7xmlte){font-family:var(--font-mono);font-size:.75rem;color:var(--text-tertiary);margin:0;line-height:1.8;max-width:none}.footer-line:where(.astro-sz7xmlte) a:where(.astro-sz7xmlte){color:var(--text-tertiary);text-decoration:none}.footer-line:where(.astro-sz7xmlte) a:where(.astro-sz7xmlte):hover{color:var(--accent)}.footer-line:where(.astro-sz7xmlte)+.footer-line:where(.astro-sz7xmlte){margin-top:var(--space-2)}.footer-line:where(.astro-sz7xmlte) span:where(.astro-sz7xmlte)[aria-hidden]{margin:0 var(--space-2);color:var(--border-strong)}
