@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap";:root[data-theme=cappuccino]{--ctp-base: #f5f5dc;--ctp-mantle: #ebe5c6;--ctp-crust: #ded7b5;--ctp-surface0: #e9e2c1;--ctp-surface1: #ddd6b2;--ctp-surface2: #cfc49c;--ctp-overlay0: #b9ad7a;--ctp-overlay1: #a09068;--ctp-overlay2: #7f7453;--ctp-subtext0: #6a5e42;--ctp-subtext1: #5a4d37;--ctp-text: #3b2f20;--ctp-primary: #8b4513;--ctp-secondary: #a9742a;--ctp-accent: #daa520;--ctp-lavender: #9c8ac5;--ctp-blue: #5a7ba0;--ctp-sapphire: #6d8faa;--ctp-sky: #a2c4cf;--ctp-teal: #6da79e;--ctp-green: #769b5f;--ctp-yellow: #d1a642;--ctp-peach: #f0b67f;--ctp-maroon: #9c3b2c;--ctp-red: #c35b4c;--ctp-mauve: #b58bc1;--ctp-pink: #d8979e;--ctp-flamingo: #e8b4a1;--ctp-rosewater: #f6e4d1;--color-bg: var(--ctp-base);--color-bg-alt: var(--ctp-mantle);--color-surface: var(--ctp-surface0);--color-surface-alt: var(--ctp-surface1);--color-text: var(--ctp-text);--color-text-alt: var(--ctp-subtext1);--color-text-muted: var(--ctp-overlay1);--color-primary: var(--ctp-mauve);--color-secondary: var(--ctp-blue);--color-accent: var(--ctp-peach);--color-success: var(--ctp-green);--color-warning: var(--ctp-yellow);--color-error: var(--ctp-red);--color-border: var(--ctp-surface2);--color-shadow: rgba(222, 215, 181, 0.15)}:root[data-theme=macchiato]{--ctp-rosewater: #f4dbd6;--ctp-flamingo: #f0c6c6;--ctp-pink: #f5bde6;--ctp-mauve: #c6a0f6;--ctp-red: #ed8796;--ctp-maroon: #ee99a0;--ctp-peach: #f5a97f;--ctp-yellow: #eed49f;--ctp-green: #a6da95;--ctp-teal: #8bd5ca;--ctp-sky: #91d7e3;--ctp-sapphire: #7dc4e4;--ctp-blue: #8aadf4;--ctp-lavender: #b7bdf8;--ctp-text: #cad3f5;--ctp-subtext1: #b8c0e0;--ctp-subtext0: #a5adcb;--ctp-overlay2: #939ab7;--ctp-overlay1: #8087a2;--ctp-overlay0: #6e738d;--ctp-surface2: #5b6078;--ctp-surface1: #494d64;--ctp-surface0: #363a4f;--ctp-base: #24273a;--ctp-mantle: #1e2030;--ctp-crust: #181926;--color-bg: var(--ctp-base);--color-bg-alt: var(--ctp-mantle);--color-surface: var(--ctp-surface0);--color-surface-alt: var(--ctp-surface1);--color-text: var(--ctp-text);--color-text-alt: var(--ctp-subtext1);--color-text-muted: var(--ctp-overlay1);--color-primary: var(--ctp-mauve);--color-secondary: var(--ctp-blue);--color-accent: var(--ctp-peach);--color-success: var(--ctp-green);--color-warning: var(--ctp-yellow);--color-error: var(--ctp-red);--color-border: var(--ctp-surface2);--color-shadow: rgba(24, 25, 38, 0.15)}:root{--ctp-rosewater: #f4dbd6;--ctp-flamingo: #f0c6c6;--ctp-pink: #f5bde6;--ctp-mauve: #c6a0f6;--ctp-red: #ed8796;--ctp-maroon: #ee99a0;--ctp-peach: #f5a97f;--ctp-yellow: #eed49f;--ctp-green: #a6da95;--ctp-teal: #8bd5ca;--ctp-sky: #91d7e3;--ctp-sapphire: #7dc4e4;--ctp-blue: #8aadf4;--ctp-lavender: #b7bdf8;--ctp-text: #cad3f5;--ctp-subtext1: #b8c0e0;--ctp-subtext0: #a5adcb;--ctp-overlay2: #939ab7;--ctp-overlay1: #8087a2;--ctp-overlay0: #6e738d;--ctp-surface2: #5b6078;--ctp-surface1: #494d64;--ctp-surface0: #363a4f;--ctp-base: #24273a;--ctp-mantle: #1e2030;--ctp-crust: #181926;--color-bg: var(--ctp-base);--color-bg-alt: var(--ctp-mantle);--color-surface: var(--ctp-surface0);--color-text: var(--ctp-text);--color-primary: var(--ctp-mauve);--color-secondary: var(--ctp-blue);--color-accent: var(--ctp-peach);--color-success: var(--ctp-green);--color-warning: var(--ctp-yellow);--color-error: var(--ctp-red);--color-border: var(--ctp-surface2);--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-size-sm: 0.875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--line-height-tight: 1.25;--line-height-base: 1.5;--line-height-relaxed: 1.75;--spacing-xs: 0.25rem;--spacing-sm: 0.5rem;--spacing-base: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--border-radius: 0.375rem;--border-radius-lg: 0.5rem;--transition: all 0.2s ease-in-out}*,*::before,*::after{box-sizing:border-box}*{margin:0;padding:0}html{scroll-behavior:smooth}body{line-height:var(--line-height-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button{background:none;border:none;cursor:pointer}ul,ol{list-style:none}a{color:inherit;text-decoration:none}:root{--font-family-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-family-mono: "JetBrains Mono", "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", Consolas, "Courier New", monospace;--font-family-heading: var(--font-family-base);--font-size-xs: clamp(0.75rem, 0.9vw, 0.875rem);--font-size-sm: clamp(0.875rem, 1vw, 1rem);--font-size-base: clamp(1rem, 1.1vw, 1.125rem);--font-size-lg: clamp(1.125rem, 1.3vw, 1.25rem);--font-size-xl: clamp(1.25rem, 1.5vw, 1.5rem);--font-size-2xl: clamp(1.5rem, 2vw, 1.875rem);--font-size-3xl: clamp(1.875rem, 2.5vw, 2.25rem);--font-size-4xl: clamp(2.25rem, 3vw, 3rem);--font-size-5xl: clamp(3rem, 4vw, 4rem);--line-height-none: 1;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--line-height-loose: 2;--letter-spacing-tighter: -0.05em;--letter-spacing-tight: -0.025em;--letter-spacing-normal: 0;--letter-spacing-wide: 0.025em;--letter-spacing-wider: 0.05em;--letter-spacing-widest: 0.1em;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text);background-color:var(--color-bg);transition:var(--transition);font-weight:var(--font-weight-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeSpeed}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text);letter-spacing:var(--letter-spacing-tight);margin-top:var(--spacing-3xl);margin-bottom:var(--spacing-xl)}h1:first-child,h2:first-child,h3:first-child,h4:first-child,h5:first-child,h6:first-child{margin-top:0}h1+h1,h2+h1,h3+h1,h1+h2,h2+h2,h3+h2,h1+h3,h2+h3,h3+h3,h1+h4,h2+h4,h3+h4,h1+h5,h2+h5,h3+h5,h1+h6,h2+h6,h3+h6{margin-top:var(--spacing-xl)}h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-none);margin-top:0;margin-bottom:var(--spacing-2xl)}h2{font-size:var(--font-size-3xl);margin-top:var(--spacing-4xl);margin-bottom:var(--spacing-xl)}h1+h2,h2+h2,h3+h2{margin-top:var(--spacing-2xl)}h3{font-size:var(--font-size-2xl);margin-top:var(--spacing-3xl);margin-bottom:var(--spacing-lg)}h1+h3,h2+h3{margin-top:var(--spacing-xl)}h4{font-size:var(--font-size-xl);margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-base)}h1+h4,h2+h4,h3+h4{margin-top:var(--spacing-lg)}h5{font-size:var(--font-size-lg);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-base)}h1+h5,h2+h5,h3+h5,h4+h5{margin-top:var(--spacing-base)}h6{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}h1+h6,h2+h6,h3+h6,h4+h6,h5+h6{margin-top:var(--spacing-base)}p{margin-bottom:var(--spacing-xl);color:var(--color-text-alt);line-height:var(--line-height-relaxed)}p+ul,p+ol{margin-top:calc(var(--spacing-base)*-1)}p+p{margin-top:var(--spacing-sm)}.lead{font-size:var(--font-size-lg);font-weight:var(--font-weight-light);line-height:var(--line-height-relaxed);color:var(--color-text);margin-bottom:var(--spacing-2xl)}@media(min-width: 768px){.lead{font-size:var(--font-size-xl);margin-bottom:var(--spacing-3xl)}}a{color:var(--color-primary);text-decoration:underline;text-decoration-color:rgba(0,0,0,0);text-decoration-thickness:2px;text-underline-offset:2px;transition:var(--transition)}a:hover{text-decoration-color:currentColor;color:var(--color-secondary)}a:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:2px}strong,b{font-weight:var(--font-weight-semibold);color:var(--color-text)}em,i{font-style:italic}mark{background-color:var(--color-accent);color:var(--color-bg);padding:.1em .2em;border-radius:2px}code{font-family:var(--font-family-mono);font-size:.9em;background-color:var(--color-surface);color:var(--color-accent);padding:.2em .4em;border-radius:var(--border-radius);font-weight:var(--font-weight-medium)}pre{font-family:var(--font-family-mono);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-xl);margin:var(--spacing-2xl) 0;overflow-x:auto;line-height:var(--line-height-normal)}pre code{background:none;padding:0;color:var(--color-text)}ul,ol{margin:var(--spacing-xl) 0 var(--spacing-2xl) 0;padding-left:var(--spacing-2xl)}ul li,ol li{margin-bottom:var(--spacing-base);color:var(--color-text-alt);line-height:var(--line-height-relaxed)}ul li ul,ul li ol,ol li ul,ol li ol{margin:var(--spacing-base) 0;padding-left:var(--spacing-xl)}ul li ul li,ul li ol li,ol li ul li,ol li ol li{margin-bottom:var(--spacing-sm)}h1+ul,h2+ul,h3+ul,h4+ul,h5+ul,h6+ul,h1+ol,h2+ol,h3+ol,h4+ol,h5+ol,h6+ol{margin-top:var(--spacing-lg)}p+ul,p+ol{margin-top:var(--spacing-lg)}ul{list-style-type:disc}ul ul{list-style-type:circle}ul ul ul{list-style-type:square}ol{list-style-type:decimal}ol ol{list-style-type:lower-alpha}ol ol ol{list-style-type:lower-roman}blockquote{border-left:4px solid var(--color-primary);margin:var(--spacing-3xl) 0;padding:var(--spacing-xl) var(--spacing-2xl);font-style:italic;font-size:var(--font-size-lg);color:var(--color-text-alt);background-color:var(--color-surface);border-radius:var(--border-radius-lg)}blockquote p:last-child{margin-bottom:0}blockquote p:first-child{margin-top:0}blockquote p{margin-bottom:var(--spacing-lg)}hr{border:none;height:1px;background-color:var(--color-border);margin:var(--spacing-3xl) 0}@media(min-width: 768px){hr{margin:calc(var(--spacing-2xl) + var(--spacing-xl)) 0}}.btn-group+hr{margin-top:var(--spacing-4xl)}table{width:100%;margin:var(--spacing-2xl) 0;border-collapse:collapse;border:1px solid var(--color-border);border-radius:var(--border-radius-lg);overflow:hidden}table th,table td{padding:var(--spacing-base) var(--spacing-lg);text-align:left;border-bottom:1px solid var(--color-border)}table th{background-color:var(--color-surface);font-weight:var(--font-weight-semibold);color:var(--color-text);padding:var(--spacing-lg)}table tr:last-child td{border-bottom:none}dl{margin:var(--spacing-xl) 0}dl dt{font-weight:var(--font-weight-semibold);color:var(--color-text);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm)}dl dt:first-child{margin-top:0}dl dd{margin-left:var(--spacing-xl);margin-bottom:var(--spacing-base);color:var(--color-text-alt);line-height:var(--line-height-relaxed)}figure{margin:var(--spacing-2xl) 0}figure img{width:100%;height:auto;border-radius:var(--border-radius-lg)}figure figcaption{margin-top:var(--spacing-base);font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;font-style:italic}address{margin:var(--spacing-xl) 0;font-style:normal;line-height:var(--line-height-relaxed);color:var(--color-text-alt)}details{margin:var(--spacing-lg) 0;border:1px solid var(--color-border);border-radius:var(--border-radius-lg)}details summary{padding:var(--spacing-base) var(--spacing-lg);cursor:pointer;font-weight:var(--font-weight-medium);background-color:var(--color-surface);border-radius:var(--border-radius-lg)}details summary:hover{background-color:var(--color-surface-alt)}details[open] summary{border-bottom:1px solid var(--color-border);border-radius:var(--border-radius-lg) var(--border-radius-lg) 0 0}details>*:not(summary){padding:var(--spacing-lg)}.text-xs{font-size:var(--font-size-xs) !important}.text-sm{font-size:var(--font-size-sm) !important}.text-base{font-size:var(--font-size-base) !important}.text-lg{font-size:var(--font-size-lg) !important}.text-xl{font-size:var(--font-size-xl) !important}.text-2xl{font-size:var(--font-size-2xl) !important}.text-3xl{font-size:var(--font-size-3xl) !important}.text-light{font-weight:var(--font-weight-light) !important}.text-normal{font-weight:var(--font-weight-normal) !important}.text-medium{font-weight:var(--font-weight-medium) !important}.text-semibold{font-weight:var(--font-weight-semibold) !important}.text-bold{font-weight:var(--font-weight-bold) !important}.text-muted{color:var(--color-text-muted) !important}.text-alt{color:var(--color-text-alt) !important}.text-primary{color:var(--color-primary) !important}.text-secondary{color:var(--color-secondary) !important}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}@media(max-width: 640px){.mobile\:text-center{text-align:center !important}.mobile\:text-sm{font-size:var(--font-size-sm) !important}.mobile\:text-base{font-size:var(--font-size-base) !important}h1,h2,h3,h4,h5,h6{margin-top:var(--spacing-2xl);margin-bottom:var(--spacing-base)}h1{margin-bottom:var(--spacing-lg)}h2{margin-top:var(--spacing-3xl)}p{margin-bottom:var(--spacing-lg)}ul,ol{margin:var(--spacing-lg) 0 var(--spacing-xl) 0}}@media(min-width: 768px){.desktop\:text-left{text-align:left !important}.desktop\:text-lg{font-size:var(--font-size-lg) !important}.desktop\:text-xl{font-size:var(--font-size-xl) !important}}.content-flow>*+*{margin-top:var(--spacing-lg)}.content-flow>h1+*,.content-flow>h2+*,.content-flow>h3+*{margin-top:var(--spacing-base)}.content-flow>hr+*{margin-top:var(--spacing-2xl)}:root{--container-xs: 100%;--container-sm: 100%;--container-md: 100%;--container-lg: 1200px;--container-xl: 1400px;--content-narrow: 60rem;--content-medium: 75rem;--content-wide: 85rem;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--spacing-xs: 0.25rem;--spacing-sm: 0.5rem;--spacing-base: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--spacing-4xl: 6rem}.container{width:100%;margin:0 auto;padding-left:var(--spacing-base);padding-right:var(--spacing-base)}@media(min-width: 640px){.container{padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}@media(min-width: 1024px){.container{padding-left:var(--spacing-xl);padding-right:var(--spacing-xl);max-width:var(--container-lg)}}@media(min-width: 1280px){.container{padding-left:var(--spacing-2xl);padding-right:var(--spacing-2xl);max-width:var(--container-xl)}}.container-xs{max-width:var(--container-xs)}.container-sm{max-width:var(--content-narrow)}.container-md{max-width:var(--content-medium)}.container-lg{max-width:var(--content-wide)}.container-xl{max-width:var(--container-xl)}.prose{max-width:var(--content-narrow)}.prose--wide{max-width:var(--content-medium)}.prose--full{max-width:none}.grid{display:grid;gap:var(--spacing-lg)}@media(min-width: 768px){.grid{gap:var(--spacing-xl)}}@media(min-width: 1024px){.grid{gap:var(--spacing-2xl)}}.grid--cols-1{grid-template-columns:1fr}.grid--cols-2{grid-template-columns:1fr}@media(min-width: 640px){.grid--cols-2{grid-template-columns:repeat(2, 1fr)}}.grid--cols-3{grid-template-columns:1fr}@media(min-width: 640px){.grid--cols-3{grid-template-columns:repeat(2, 1fr)}}@media(min-width: 1024px){.grid--cols-3{grid-template-columns:repeat(3, 1fr)}}.grid--cols-4{grid-template-columns:repeat(2, 1fr)}@media(min-width: 768px){.grid--cols-4{grid-template-columns:repeat(3, 1fr)}}@media(min-width: 1024px){.grid--cols-4{grid-template-columns:repeat(4, 1fr)}}.btn-group{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;margin-bottom:var(--spacing-xl)}@media(min-width: 768px){.btn-group{gap:var(--spacing-base);margin-bottom:var(--spacing-2xl)}}.btn-group--center{justify-content:center}@media(max-width: 640px){.btn-group--mobile-stack{flex-direction:column;width:100%}.btn-group--mobile-stack .btn{width:100%;justify-content:center}}.btn-group+hr,.btn-group+.divider{margin-top:var(--spacing-2xl)}@media(min-width: 768px){.btn-group+hr,.btn-group+.divider{margin-top:var(--spacing-2xl)}}.grid-auto{display:grid;gap:var(--spacing-lg)}.grid-auto--sm{grid-template-columns:repeat(auto-fit, minmax(280px, 1fr))}.grid-auto--md{grid-template-columns:repeat(auto-fit, minmax(350px, 1fr))}.grid-auto--lg{grid-template-columns:repeat(auto-fit, minmax(450px, 1fr))}.flex{display:flex}.flex--center{align-items:center;justify-content:center}.flex--between{justify-content:space-between}.flex--around{justify-content:space-around}.flex--start{align-items:flex-start}.flex--end{align-items:flex-end}.flex--column{flex-direction:column}.flex--wrap{flex-wrap:wrap}.flex--gap{gap:var(--spacing-base)}.flex--gap-sm{gap:var(--spacing-sm)}.flex--gap-lg{gap:var(--spacing-lg)}@media(max-width: 767px){.flex--mobile-column{flex-direction:column !important}.flex--mobile-center{justify-content:center !important}.flex--mobile-wrap{flex-wrap:wrap !important}}@media(min-width: 768px)and (max-width: 1023px){.flex--tablet-wrap{flex-wrap:wrap !important}.flex--tablet-column{flex-direction:column !important}}.coffee-shop{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg)}.main{flex:1;padding:var(--spacing-xl) 0}@media(min-width: 768px){.main{padding:var(--spacing-2xl) 0}}@media(min-width: 1024px){.main{padding:var(--spacing-3xl) 0}}.section{padding:var(--spacing-2xl) 0}@media(min-width: 768px){.section{padding:var(--spacing-3xl) 0}}@media(min-width: 1024px){.section{padding:var(--spacing-4xl) 0}}.section--sm{padding:var(--spacing-xl) 0}@media(min-width: 768px){.section--sm{padding:var(--spacing-2xl) 0}}.section--lg{padding:var(--spacing-3xl) 0}@media(min-width: 768px){.section--lg{padding:var(--spacing-4xl) 0}}.mt{margin-top:var(--spacing-base) !important}.mb{margin-bottom:var(--spacing-base) !important}.ml{margin-left:var(--spacing-base) !important}.mr{margin-right:var(--spacing-base) !important}.mt-sm{margin-top:var(--spacing-sm) !important}.mb-sm{margin-bottom:var(--spacing-sm) !important}.mt-lg{margin-top:var(--spacing-lg) !important}.mb-lg{margin-bottom:var(--spacing-lg) !important}.mt-xl{margin-top:var(--spacing-xl) !important}.mb-xl{margin-bottom:var(--spacing-xl) !important}.mt-2xl{margin-top:var(--spacing-2xl) !important}.mb-2xl{margin-bottom:var(--spacing-2xl) !important}.mt-3xl{margin-top:var(--spacing-3xl) !important}.mb-3xl{margin-bottom:var(--spacing-3xl) !important}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}@media(max-width: 767px){.mobile\:text-center{text-align:center !important}.mobile\:text-left{text-align:left !important}}@media(min-width: 768px){.tablet\:text-center{text-align:center !important}.desktop\:text-left{text-align:left !important}}.hidden{display:none !important}@media(max-width: 639px){.sm\:hidden{display:none !important}}@media(min-width: 640px){.sm\:block{display:block !important}.sm\:flex{display:flex !important}.sm\:grid{display:grid !important}}@media(max-width: 767px){.md\:hidden{display:none !important}}@media(min-width: 768px){.md\:block{display:block !important}.md\:flex{display:flex !important}.md\:grid{display:grid !important}}@media(min-width: 1024px){.lg\:block{display:block !important}.lg\:flex{display:flex !important}.lg\:grid{display:grid !important}}.error-page{text-align:center;padding:var(--spacing-4xl) 0}@media(min-width: 768px){.error-page{padding:var(--spacing-4xl) var(--spacing-2xl)}}.error-page__content{max-width:600px;margin:0 auto}.error-page__icon{font-size:4rem;margin-bottom:var(--spacing-lg)}@media(min-width: 768px){.error-page__icon{font-size:6rem;margin-bottom:var(--spacing-xl)}}.error-page__title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-base);color:var(--color-text)}@media(min-width: 768px){.error-page__title{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg)}}.error-page__subtitle{font-size:var(--font-size-lg);color:var(--color-text-alt);margin-bottom:var(--spacing-xl);font-weight:300}@media(min-width: 768px){.error-page__subtitle{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2xl)}}.error-page__description{text-align:left;margin-bottom:var(--spacing-2xl)}@media(min-width: 768px){.error-page__description{margin-bottom:var(--spacing-3xl)}}.error-page__description p{margin-bottom:var(--spacing-base);color:var(--color-text-alt)}.error-page__actions{margin-bottom:var(--spacing-2xl)}@media(min-width: 768px){.error-page__actions{margin-bottom:var(--spacing-3xl)}}.error-page__actions h3{margin-bottom:var(--spacing-lg);font-size:var(--font-size-xl);color:var(--color-text)}.error-page__search{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl)}@media(min-width: 768px){.error-page__search{padding:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}}.error-page__search p{margin-bottom:var(--spacing-sm)}.error-page__search p:last-of-type{margin-bottom:var(--spacing-base)}.error-page__search strong{color:var(--color-text)}.error-page__footer p{color:var(--color-text-muted);font-size:var(--font-size-sm)}.error-page__footer a{color:var(--color-primary)}.error-page__footer a:hover{color:var(--color-secondary)}.error-list{list-style:none;padding:0;margin:var(--spacing-base) 0}.error-list li{padding:var(--spacing-sm) 0;color:var(--color-text-alt);border-bottom:1px solid var(--color-border)}.error-list li:last-child{border-bottom:none}.breadcrumbs{margin-bottom:var(--spacing-lg)}.breadcrumbs__list{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);list-style:none;padding:0;margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.breadcrumbs__item:not(:last-child)::after{content:"/";margin-left:var(--spacing-sm);color:var(--color-text-muted)}.breadcrumbs__link{color:var(--color-primary);text-decoration:none}.breadcrumbs__link:hover{text-decoration:underline;color:var(--color-secondary)}.coffee-header{background-color:var(--color-bg-alt);border-bottom:1px solid var(--color-border);transition:var(--transition);position:sticky;top:0;z-index:100;backdrop-filter:blur(10px)}.nav{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-base) 0;margin:0 auto;max-width:var(--max-width);width:100%;padding-left:var(--spacing-base);padding-right:var(--spacing-base)}@media(min-width: 768px){.nav{padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}@media(min-width: 1024px){.nav{padding-left:var(--spacing-xl);padding-right:var(--spacing-xl)}}.nav__brand{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);text-decoration:none}.nav__brand:hover{color:var(--color-primary)}.nav__menu{display:flex;align-items:center;gap:var(--spacing-lg)}@media(max-width: 768px){.nav__menu{display:none;position:absolute;top:100%;left:0;right:0;background-color:var(--color-bg);border-top:1px solid var(--color-border);box-shadow:0 8px 16px rgba(0,0,0,.1);padding:var(--spacing-base);padding-left:var(--spacing-base);padding-right:var(--spacing-base);flex-direction:column;z-index:1000}.nav__menu.is-active{display:flex !important}}@media(min-width: 768px)and (max-width: 1023px){.nav__menu{padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}@media(min-width: 1024px){.nav__menu{padding-left:var(--spacing-xl);padding-right:var(--spacing-xl)}}.nav__link{color:var(--color-text-alt);text-decoration:none;font-weight:500;transition:var(--transition);position:relative}.nav__link:hover,.nav__link.is-current{color:var(--color-primary)}.nav__link::after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background-color:var(--color-primary);transition:var(--transition)}.nav__link:hover::after,.nav__link.is-current::after{width:100%}.nav__actions{display:flex;align-items:center;gap:var(--spacing-sm)}.nav__toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;padding:0}@media(max-width: 767px){.nav__toggle{display:flex;width:40px;height:40px;color:var(--color-text);z-index:1001}}.nav .nav__toggle-line{background-color:var(--color-text);display:block;height:2px;width:18px;margin:2px 0;transition:var(--transition);transform-origin:center}.nav__toggle.is-active .nav .nav__toggle-line:nth-child(1){transform:translateY(6px) rotate(45deg)}.nav__toggle.is-active .nav .nav__toggle-line:nth-child(2){opacity:0}.nav__toggle.is-active .nav .nav__toggle-line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--border-radius);background-color:var(--color-surface);color:var(--color-text-alt);transition:var(--transition)}.theme-toggle:hover{background-color:var(--color-surface-alt);color:var(--color-primary)}.theme-toggle .theme-icon{width:20px;height:20px;transition:var(--transition)}.theme-toggle .theme-icon--light{display:block}.theme-toggle .theme-icon--dark{display:none}[data-theme=macchiato] .theme-toggle .theme-icon--light{display:block}[data-theme=macchiato] .theme-toggle .theme-icon--dark{display:none}[data-theme=latte] .theme-toggle .theme-icon--light{display:none}[data-theme=latte] .theme-toggle .theme-icon--dark{display:block}.coffee-footer{background-color:var(--color-bg-alt);border-top:1px solid var(--color-border);padding:var(--spacing-2xl) 0 var(--spacing-xl);margin-top:auto}.coffee-footer__content{text-align:center;color:var(--color-text-muted)}.coffee-footer__content p{margin-bottom:var(--spacing-sm)}.coffee-footer__content a{color:var(--color-primary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-lg);font-weight:500;text-decoration:none;border-radius:var(--border-radius);transition:var(--transition);cursor:pointer;border:1px solid rgba(0,0,0,0);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn--primary{background-color:var(--color-secondary);color:var(--color-bg)}.btn--primary:hover{filter:brightness(1.1);transform:translateY(-1px);background-color:var(--color-primary);color:var(--color-bg)}.btn--secondary{background-color:var(--color-primary);color:var(--color-bg)}.btn--secondary:hover{filter:brightness(1.1);transform:translateY(-1px);background-color:var(--color-secondary);color:var(--color-bg)}.btn--ghost{background-color:rgba(0,0,0,0);color:var(--color-text);border-color:var(--color-border)}.btn--ghost:hover{background-color:var(--color-surface);border-color:var(--color-primary)}.btn--sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.btn-group{display:flex;gap:var(--spacing-sm)}.btn-group--center{justify-content:center}.post-grid{display:grid;gap:var(--spacing-base);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:1fr}@media(min-width: 640px){.post-grid{grid-template-columns:repeat(2, 1fr);gap:var(--spacing-lg);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}}@media(min-width: 768px){.post-grid{gap:var(--spacing-xl);margin-top:var(--spacing-2xl)}}@media(min-width: 1024px){.post-grid{grid-template-columns:repeat(3, 1fr);gap:var(--spacing-lg)}}@media(min-width: 1280px){.post-grid{gap:var(--spacing-xl);margin-top:var(--spacing-3xl)}}@media(min-width: 1536px){.post-grid{grid-template-columns:repeat(3, 1fr)}}.post-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius-lg);transition:var(--transition);height:100%;display:flex;flex-direction:column;position:relative;overflow:hidden;padding:var(--spacing-base)}@media(min-width: 640px){.post-card{padding:var(--spacing-lg)}}@media(min-width: 768px){.post-card{padding:var(--spacing-lg)}}@media(min-width: 1024px){.post-card{padding:var(--spacing-base)}}@media(min-width: 1280px){.post-card{padding:var(--spacing-lg)}}.post-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px var(--color-shadow);border-color:var(--color-primary)}.post-card:focus-within{outline:2px solid var(--color-primary);outline-offset:2px}.post-card__header{margin-bottom:var(--spacing-sm);flex-shrink:0}@media(min-width: 640px){.post-card__header{margin-bottom:var(--spacing-base)}}.post-card__title{margin:0 0 var(--spacing-xs) 0;line-height:var(--line-height-tight);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}@media(min-width: 640px){.post-card__title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm)}}@media(min-width: 768px){.post-card__title{font-size:var(--font-size-xl)}}@media(min-width: 1024px){.post-card__title{font-size:var(--font-size-lg)}}@media(min-width: 1280px){.post-card__title{font-size:var(--font-size-xl)}}.post-card__title a{color:var(--color-text);text-decoration:none;transition:var(--transition)}.post-card__title a:hover{color:var(--color-primary)}.post-card__title a::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0}.post-card__date{color:var(--color-text-muted);font-weight:500;margin:0;font-size:var(--font-size-xs)}@media(min-width: 640px){.post-card__date{font-size:var(--font-size-sm)}}.post-card__body{flex:1;margin-bottom:var(--spacing-sm)}@media(min-width: 640px){.post-card__body{margin-bottom:var(--spacing-base)}}@media(min-width: 768px){.post-card__body{margin-bottom:var(--spacing-lg)}}@media(min-width: 1024px){.post-card__body{margin-bottom:var(--spacing-sm)}}@media(min-width: 1280px){.post-card__body{margin-bottom:var(--spacing-base)}}.post-card__excerpt{margin-bottom:0;color:var(--color-text-alt);line-height:var(--line-height-relaxed);display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;font-size:var(--font-size-sm);-webkit-line-clamp:2}@media(min-width: 640px){.post-card__excerpt{font-size:var(--font-size-base);-webkit-line-clamp:3}}@media(min-width: 768px){.post-card__excerpt{-webkit-line-clamp:4}}@media(min-width: 1024px){.post-card__excerpt{font-size:var(--font-size-sm);-webkit-line-clamp:3}}@media(min-width: 1280px){.post-card__excerpt{font-size:var(--font-size-base);-webkit-line-clamp:4}}.post-card__footer{margin-top:auto;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);flex-shrink:0}@media(min-width: 640px){.post-card__footer{padding-top:var(--spacing-base)}}@media(min-width: 768px){.post-card__footer{padding-top:var(--spacing-lg)}}@media(min-width: 1024px){.post-card__footer{padding-top:var(--spacing-sm)}}@media(min-width: 1280px){.post-card__footer{padding-top:var(--spacing-base)}}.post-card__meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-muted)}@media(min-width: 640px){.post-card__meta{gap:var(--spacing-sm)}}@media(max-width: 640px){.post-card__meta{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}.post-card--featured{grid-column:span 1}@media(min-width: 640px){.post-card--featured{grid-column:span 2;padding:var(--spacing-lg)}.post-card--featured .post-card__title{font-size:var(--font-size-xl)}.post-card--featured .post-card__excerpt{-webkit-line-clamp:4}}@media(min-width: 768px){.post-card--featured{padding:var(--spacing-xl)}.post-card--featured .post-card__title{font-size:var(--font-size-2xl)}}@media(min-width: 1024px){.post-card--featured{grid-column:span 3}.post-card--featured .post-card__body{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-xl);align-items:start}}@media(min-width: 1536px){.post-card--featured{grid-column:span 2}.post-card--featured .post-card__body{display:block}}.post-card--compact{padding:var(--spacing-sm)}@media(min-width: 640px){.post-card--compact{padding:var(--spacing-base)}}.post-card--compact .post-card__header{margin-bottom:var(--spacing-xs)}.post-card--compact .post-card__title{font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}@media(min-width: 640px){.post-card--compact .post-card__title{font-size:var(--font-size-base)}}.post-card--compact .post-card__body{margin-bottom:var(--spacing-xs)}@media(min-width: 640px){.post-card--compact .post-card__body{margin-bottom:var(--spacing-sm)}}.post-card--compact .post-card__excerpt{font-size:var(--font-size-xs);-webkit-line-clamp:2}@media(min-width: 640px){.post-card--compact .post-card__excerpt{font-size:var(--font-size-sm)}}.post-card--compact .post-card__footer{padding-top:var(--spacing-xs)}@media(min-width: 640px){.post-card--compact .post-card__footer{padding-top:var(--spacing-sm)}}.post-card__tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);list-style:none;padding:0;margin:0}@media(min-width: 640px){.post-card__tags{gap:var(--spacing-sm)}}.post-card__tag{background-color:var(--color-primary);color:var(--color-bg);border-radius:var(--border-radius);text-decoration:none;font-weight:var(--font-weight-medium);transition:var(--transition);white-space:nowrap;position:relative;z-index:2;font-size:var(--font-size-xs);padding:calc(var(--spacing-xs)/2) var(--spacing-xs)}@media(min-width: 640px){.post-card__tag{padding:var(--spacing-xs) var(--spacing-sm)}}@media(max-width: 639px){.post-card__tag:nth-child(n+3){display:none}}@media(min-width: 640px)and (max-width: 1023px){.post-card__tag:nth-child(n+4){display:none}}@media(min-width: 1024px){.post-card__tag:nth-child(n+5){display:none}}.post-card__tag:hover{background-color:var(--color-secondary);transform:translateY(-1px)}.post-card__read-more{color:var(--color-primary);text-decoration:none;font-weight:var(--font-weight-medium);white-space:nowrap;position:relative;z-index:2;font-size:var(--font-size-xs)}@media(min-width: 640px){.post-card__read-more{font-size:var(--font-size-sm)}}.post-card__read-more:hover{color:var(--color-secondary);text-decoration:underline}.blog-section{padding:var(--spacing-xl) 0}@media(min-width: 640px){.blog-section{padding:var(--spacing-2xl) 0}}@media(min-width: 768px){.blog-section{padding:var(--spacing-3xl) 0}}@media(min-width: 1280px){.blog-section{padding:var(--spacing-4xl) 0}}.blog-section .section-header{text-align:center;margin-bottom:var(--spacing-xl)}@media(min-width: 640px){.blog-section .section-header{margin-bottom:var(--spacing-2xl)}}@media(min-width: 768px){.blog-section .section-header{margin-bottom:var(--spacing-3xl)}}.blog-section .section-header .section-title{font-weight:var(--font-weight-bold);color:var(--color-text);margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-xl)}@media(min-width: 640px){.blog-section .section-header .section-title{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-base)}}@media(min-width: 768px){.blog-section .section-header .section-title{font-size:var(--font-size-3xl)}}@media(min-width: 1024px){.blog-section .section-header .section-title{font-size:var(--font-size-4xl)}}.blog-section .section-header .section-subtitle{color:var(--color-text-alt);margin:0;font-weight:var(--font-weight-light);font-size:var(--font-size-base)}@media(min-width: 640px){.blog-section .section-header .section-subtitle{font-size:var(--font-size-lg)}}.load-more{text-align:center;margin-top:var(--spacing-xl)}@media(min-width: 640px){.load-more{margin-top:var(--spacing-2xl)}}@media(min-width: 768px){.load-more{margin-top:var(--spacing-3xl)}}.load-more .btn--load-more{background:linear-gradient(45deg, var(--color-primary), var(--color-secondary));color:var(--color-bg);border:none;border-radius:var(--border-radius-lg);font-weight:var(--font-weight-medium);transition:var(--transition);cursor:pointer;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}@media(min-width: 640px){.load-more .btn--load-more{padding:var(--spacing-base) var(--spacing-xl);font-size:var(--font-size-base)}}@media(min-width: 768px){.load-more .btn--load-more{padding:var(--spacing-lg) var(--spacing-2xl)}}.load-more .btn--load-more:hover{transform:translateY(-2px);box-shadow:0 8px 16px rgba(0,0,0,.2)}.load-more .btn--load-more:active{transform:translateY(0)}.post-grid--empty{text-align:center;padding:var(--spacing-4xl) var(--spacing-xl);color:var(--color-text-muted)}.post-grid--empty .empty-icon{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg);opacity:.5}.post-grid--empty .empty-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-base);color:var(--color-text)}.post-grid--empty .empty-description{font-size:var(--font-size-base);line-height:var(--line-height-relaxed)}.form__group{margin-bottom:var(--spacing-lg)}.form__label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--color-text)}.input,.textarea,.select{width:100%;padding:var(--spacing-sm) var(--spacing-base);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--border-radius);color:var(--color-text);font-size:var(--font-size-base);transition:var(--transition)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--color-primary)}.input::placeholder,.textarea::placeholder,.select::placeholder{color:var(--color-text-muted)}.textarea{min-height:120px;resize:vertical}pre[class*=language-]{background-color:var(--color-surface) !important;border:1px solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-base);overflow-x:auto}code[class*=language-],pre[class*=language-]{color:var(--color-text);font-family:var(--font-family-mono);line-height:1.5}.token.comment{color:var(--ctp-overlay1)}.token.string{color:var(--ctp-green)}.token.keyword{color:var(--ctp-mauve)}.token.function{color:var(--ctp-blue)}.token.number{color:var(--ctp-peach)}.skip-link{position:absolute;top:-40px;left:6px;background:var(--color-primary);color:var(--color-bg);padding:8px;text-decoration:none;border-radius:var(--border-radius);z-index:1000}.skip-link:focus{top:6px}.text-center{text-align:center}.text-muted{color:var(--color-text-muted) !important}.d-flex{display:flex !important}.align-center{align-items:center !important}.justify-between{justify-content:space-between !important}@media(max-width: 767px){.flex--mobile-column{flex-direction:column !important}}.tags-cloud{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);justify-content:center;margin:var(--spacing-xl) 0}@media(min-width: 640px){.tags-cloud{gap:var(--spacing-base)}}.tag-cloud-item{display:inline-flex;align-items:center;gap:var(--spacing-xs);background-color:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-alt);text-decoration:none;border-radius:var(--border-radius);padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:var(--transition);white-space:nowrap}.tag-cloud-item:hover{background-color:var(--color-primary);color:var(--color-bg);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 8px var(--color-shadow)}.tag-cloud-item--active{background-color:var(--color-primary);color:var(--color-bg);border-color:var(--color-primary)}.tag-cloud-item--active:hover{background-color:var(--color-secondary);border-color:var(--color-secondary)}.tag-count{background-color:rgba(0,0,0,.1);color:inherit;border-radius:var(--border-radius);padding:calc(var(--spacing-xs)/2) var(--spacing-xs);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);min-width:1.25rem;text-align:center}.tag-cloud-item--active .tag-count{background-color:hsla(0,0%,100%,.2)}.post-card__tag--active{background-color:var(--color-secondary) !important}.post-card__tag--active:hover{background-color:var(--color-primary) !important}.post-grid--empty{text-align:center;padding:var(--spacing-4xl) var(--spacing-xl);color:var(--color-text-muted)}.post-grid--empty .empty-icon{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg);opacity:.6}.post-grid--empty .empty-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-base);color:var(--color-text)}.post-grid--empty .empty-description{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);max-width:500px;margin:0 auto var(--spacing-lg)}.tags-page .section-header{text-align:center;margin-bottom:var(--spacing-2xl)}.tags-page .section-header .section-title{margin-bottom:var(--spacing-base);color:var(--color-text)}.tags-page .section-header .section-subtitle{color:var(--color-text-alt);font-size:var(--font-size-lg)}.tags-page .post-grid{margin-bottom:var(--spacing-3xl)}@media(max-width: 640px){.tags-cloud{justify-content:flex-start;gap:var(--spacing-xs)}.tag-cloud-item{font-size:var(--font-size-xs);padding:calc(var(--spacing-xs)/2) var(--spacing-xs)}.tag-count{display:none}}@media(min-width: 768px){.tags-cloud{margin:var(--spacing-2xl) 0}.tag-cloud-item{padding:var(--spacing-sm) var(--spacing-base)}}[data-theme=dark] .tag-cloud-item{background-color:var(--color-surface-dark);border-color:var(--color-border-dark);color:var(--color-text-alt-dark)}[data-theme=dark] .tag-cloud-item:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark);color:var(--color-bg-dark)}[data-theme=dark] .tag-cloud-item--active{background-color:var(--color-primary-dark);color:var(--color-bg-dark);border-color:var(--color-primary-dark)}[data-theme=dark] .post-grid--empty{color:var(--color-text-muted-dark)}[data-theme=dark] .post-grid--empty .empty-title{color:var(--color-text-dark)}.post-card--featured{position:relative;background:linear-gradient(135deg, var(--color-surface) 0%, rgba(var(--color-primary-rgb), 0.05) 100%);border:2px solid var(--color-primary);grid-column:span 1}@media(min-width: 640px){.post-card--featured{grid-column:span 2}}@media(min-width: 1024px){.post-card--featured{grid-column:span 2}.post-card--featured .post-card__body{display:grid;grid-template-columns:2fr 1fr;gap:var(--spacing-xl);align-items:start}}@media(min-width: 1536px){.post-card--featured{grid-column:span 2}.post-card--featured .post-card__body{display:block}}.post-card--featured:hover{transform:translateY(-4px);box-shadow:0 12px 32px var(--color-shadow);border-color:var(--color-secondary)}.post-card--featured .post-card__excerpt{font-size:var(--font-size-base);-webkit-line-clamp:4}@media(min-width: 640px){.post-card--featured .post-card__excerpt{font-size:var(--font-size-lg);-webkit-line-clamp:5}}@media(min-width: 1024px){.post-card--featured .post-card__excerpt{-webkit-line-clamp:6}}.post-card--featured .post-card__title{font-size:var(--font-size-lg)}@media(min-width: 640px){.post-card--featured .post-card__title{font-size:var(--font-size-xl)}}@media(min-width: 768px){.post-card--featured .post-card__title{font-size:var(--font-size-2xl)}}@media(min-width: 1024px){.post-card--featured .post-card__title{font-size:var(--font-size-3xl)}}.post-card--featured .post-card__read-more{background:linear-gradient(45deg, var(--color-primary), var(--color-secondary));color:var(--color-bg);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);text-decoration:none;font-weight:var(--font-weight-semibold);display:inline-block;transition:var(--transition)}@media(min-width: 768px){.post-card--featured .post-card__read-more{padding:var(--spacing-sm) var(--spacing-base)}}.post-card--featured .post-card__read-more:hover{background:linear-gradient(45deg, var(--color-secondary), var(--color-primary));transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.2)}.featured-badge{display:inline-block;background:linear-gradient(45deg, var(--color-primary), var(--color-secondary));color:var(--color-bg);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-sm);box-shadow:0 2px 4px rgba(0,0,0,.1);position:relative}@media(min-width: 768px){.featured-badge{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-base)}}.featured-badge::after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg, var(--color-secondary), var(--color-primary));border-radius:var(--border-radius);opacity:0;transition:opacity var(--transition);z-index:-1}.post-card--featured:hover .featured-badge::after{opacity:1}.post-card--featured{padding:var(--spacing-base)}@media(min-width: 640px){.post-card--featured{padding:var(--spacing-lg)}}@media(min-width: 768px){.post-card--featured{padding:var(--spacing-xl)}}@media(min-width: 1024px){.post-card--featured{padding:var(--spacing-2xl)}}.post-card--featured .post-card__header{margin-bottom:var(--spacing-base)}@media(min-width: 640px){.post-card--featured .post-card__header{margin-bottom:var(--spacing-lg)}}@media(min-width: 1024px){.post-card--featured .post-card__header{margin-bottom:var(--spacing-xl)}}.post-card--featured .post-card__date{font-size:var(--font-size-sm)}@media(min-width: 640px){.post-card--featured .post-card__date{font-size:var(--font-size-base)}}.post-card--featured .post-card__footer{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg)}@media(min-width: 640px){.post-card--featured .post-card__footer{margin-top:var(--spacing-xl);padding-top:var(--spacing-xl)}}@media(min-width: 1024px){.post-card--featured .post-card__footer{margin-top:var(--spacing-2xl);padding-top:var(--spacing-2xl)}}.post-card--featured .post-card__tag{background-color:var(--color-secondary);font-weight:var(--font-weight-semibold)}.post-card--featured .post-card__tag:hover{background-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.15)}@media(max-width: 639px){.post-card--featured{border-width:1px;padding:var(--spacing-base)}.post-card--featured .post-card__title{font-size:var(--font-size-base)}.post-card--featured .featured-badge{font-size:var(--font-size-xs);padding:calc(var(--spacing-xs)/2) var(--spacing-xs);margin-bottom:var(--spacing-xs)}.post-card--featured .post-card__excerpt{font-size:var(--font-size-sm);-webkit-line-clamp:3}}@media(min-width: 640px)and (max-width: 1023px){.post-card--featured .post-card__excerpt{-webkit-line-clamp:4}}@media(min-width: 1024px){.post-card--featured .post-card__body .post-card__excerpt{-webkit-line-clamp:8}}[data-theme=dark] .post-card--featured{background:linear-gradient(135deg, var(--color-surface-dark) 0%, rgba(var(--color-primary-rgb), 0.1) 100%);border-color:var(--color-primary-dark)}[data-theme=dark] .post-card--featured:hover{border-color:var(--color-secondary-dark)}[data-theme=dark] .featured-badge{background:linear-gradient(45deg, var(--color-primary-dark), var(--color-secondary-dark));color:var(--color-bg-dark)}[data-theme=dark] .featured-badge::after{background:linear-gradient(45deg, var(--color-secondary-dark), var(--color-primary-dark))}[data-theme=dark] .post-card--featured .post-card__read-more{background:linear-gradient(45deg, var(--color-primary-dark), var(--color-secondary-dark));color:var(--color-bg-dark)}[data-theme=dark] .post-card--featured .post-card__read-more:hover{background:linear-gradient(45deg, var(--color-secondary-dark), var(--color-primary-dark))}.featured-badge::before{content:"Featured story: ";position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}@media(prefers-contrast: high){.post-card--featured{border-width:3px}.post-card--featured .featured-badge{border:2px solid currentColor}}.blog-section .post-grid{display:grid;gap:var(--spacing-base);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:1fr}@media(min-width: 640px){.blog-section .post-grid{grid-template-columns:repeat(2, 1fr);gap:var(--spacing-lg);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-2xl)}}@media(min-width: 768px){.blog-section .post-grid{gap:var(--spacing-xl);margin-top:var(--spacing-2xl)}}@media(min-width: 1024px){.blog-section .post-grid{grid-template-columns:repeat(3, 1fr);gap:var(--spacing-lg)}}@media(min-width: 1280px){.blog-section .post-grid{gap:var(--spacing-xl);margin-top:var(--spacing-3xl)}}@media(min-width: 1536px){.blog-section .post-grid{grid-template-columns:repeat(4, 1fr)}}.blog-section .post-card{padding:var(--spacing-base)}@media(min-width: 640px){.blog-section .post-card{padding:var(--spacing-lg)}}@media(min-width: 768px){.blog-section .post-card{padding:var(--spacing-lg)}}@media(min-width: 1024px){.blog-section .post-card{padding:var(--spacing-base)}}@media(min-width: 1280px){.blog-section .post-card{padding:var(--spacing-lg)}}.post-card__tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);list-style:none;padding:0;margin:0}@media(min-width: 640px){.post-card__tags{gap:var(--spacing-sm)}}.post-card__tags li:first-child{margin-left:0}.post-card__tags li:first-child .post-card__tag{margin-left:0}.post-card__tags li:not(:first-child){margin-left:var(--spacing-xs)}@media(min-width: 640px){.post-card__tags li:not(:first-child){margin-left:var(--spacing-sm)}}.post-card__tag{background-color:var(--color-primary);color:var(--color-bg);border-radius:var(--border-radius);text-decoration:none;font-weight:var(--font-weight-medium);transition:var(--transition);white-space:nowrap;font-size:var(--font-size-xs);padding:calc(var(--spacing-xs)/2) var(--spacing-xs)}@media(min-width: 640px){.post-card__tag{padding:var(--spacing-xs) var(--spacing-sm)}}.post-card__tag:hover{background-color:var(--color-secondary);color:var(--color-bg);transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.15)}.post-card:not(.post-card--featured) .post-card__read-more{background:linear-gradient(45deg, var(--color-primary), var(--color-secondary));color:var(--color-bg);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--border-radius);text-decoration:none;font-weight:var(--font-weight-semibold);display:inline-block;transition:var(--transition);font-size:var(--font-size-xs)}@media(min-width: 640px){.post-card:not(.post-card--featured) .post-card__read-more{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-base)}}.post-card:not(.post-card--featured) .post-card__read-more:hover{background:linear-gradient(45deg, var(--color-secondary), var(--color-primary));transform:translateY(-1px);box-shadow:0 4px 8px rgba(0,0,0,.2)}.post-card--featured .post-card__tag{background-color:var(--color-primary);font-weight:var(--font-weight-medium)}.post-card--featured .post-card__tag:hover{background-color:var(--color-secondary);color:var(--color-bg);transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.15)}.post-card--featured .post-card__tags{gap:var(--spacing-xs)}@media(min-width: 640px){.post-card--featured .post-card__tags{gap:var(--spacing-sm)}}.post-card--featured .post-card__tags li:first-child{margin-left:0}.post-card--featured .post-card__tags li:not(:first-child){margin-left:var(--spacing-xs)}@media(min-width: 640px){.post-card--featured .post-card__tags li:not(:first-child){margin-left:var(--spacing-sm)}}.post-card__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}@media(min-width: 640px){.post-card__footer{margin-top:var(--spacing-base);padding-top:var(--spacing-base)}}@media(max-width: 640px){.post-card__footer{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}}.post-card__meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm);width:100%}@media(max-width: 640px){.post-card__meta{flex-direction:column;align-items:flex-start}}@media(max-width: 640px){.blog-section .post-grid{gap:var(--spacing-base);margin-top:var(--spacing-lg)}.blog-section .post-card{padding:var(--spacing-base)}.post-card__header{margin-bottom:var(--spacing-sm)}.post-card__body{margin-bottom:var(--spacing-sm)}}@media(min-width: 640px)and (max-width: 1023px){.blog-section .post-grid{gap:var(--spacing-lg)}.blog-section .post-card{padding:var(--spacing-lg)}}@media(min-width: 1024px){.blog-section .post-grid{gap:var(--spacing-lg)}.blog-section .post-card{padding:var(--spacing-base)}.blog-section .post-card--featured{padding:var(--spacing-xl)}}[data-theme=dark] .post-card__tag{background-color:var(--color-primary-dark);color:var(--color-bg-dark)}[data-theme=dark] .post-card__tag:hover{background-color:var(--color-secondary-dark);color:var(--color-bg-dark)}[data-theme=dark] .post-card:not(.post-card--featured) .post-card__read-more{background:linear-gradient(45deg, var(--color-primary-dark), var(--color-secondary-dark));color:var(--color-bg-dark)}[data-theme=dark] .post-card:not(.post-card--featured) .post-card__read-more:hover{background:linear-gradient(45deg, var(--color-secondary-dark), var(--color-primary-dark))}.tags{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center;margin-top:var(--spacing-base)}.tag{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary);color:var(--color-bg);border-radius:var(--border-radius);font-size:var(--font-size-sm);font-weight:500;text-decoration:none;transition:var(--transition);white-space:nowrap}.tag:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 2px 8px var(--color-shadow)}.tag:active{transform:translateY(0)}.tag--ghost{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.tag--ghost:hover{background-color:var(--color-surface-alt);border-color:var(--color-primary);color:var(--color-primary);filter:none}.tag--active{background-color:var(--color-secondary);color:var(--color-bg);box-shadow:0 2px 8px var(--color-shadow)}.tag--active:hover{filter:brightness(1.1)}pre .tag,code .tag{all:unset;display:inline;background:none;color:inherit;padding:0;font:inherit}.btn-group{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}@media(min-width: 768px){.btn-group{gap:var(--spacing-base)}}.btn-group--center{justify-content:center}@media(max-width: 640px){.btn-group--mobile-stack{flex-direction:column;width:100%}.btn-group--mobile-stack .btn{width:100%;justify-content:center}}.theme-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:var(--border-radius);background-color:var(--color-surface);color:var(--color-text-alt);transition:var(--transition);border:1px solid var(--color-border);cursor:pointer}.theme-toggle:hover{background-color:var(--color-surface-alt);color:var(--color-primary);transform:translateY(-1px);border-color:var(--color-primary)}.theme-toggle:active{transform:translateY(0)}.theme-toggle .theme-icon{width:20px;height:20px;transition:var(--transition)}.theme-toggle .theme-icon--light{display:block}.theme-toggle .theme-icon--dark{display:none}[data-theme=cappuccino] .theme-toggle .theme-icon--light{display:none}[data-theme=cappuccino] .theme-toggle .theme-icon--dark{display:block}.breadcrumbs{margin-bottom:var(--spacing-lg)}.breadcrumbs__list{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm);list-style:none;padding:0;margin:0;font-size:var(--font-size-sm);color:var(--color-text-muted)}.breadcrumbs__item:not(:last-child)::after{content:"/";margin-left:var(--spacing-sm);color:var(--color-text-muted)}.breadcrumbs__link{color:var(--color-primary);text-decoration:none}.breadcrumbs__link:hover{text-decoration:underline;color:var(--color-secondary)}.hero{text-align:center;padding:var(--spacing-2xl) 0}@media(min-width: 768px){.hero{padding:var(--spacing-3xl) 0}}.hero__title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-base)}@media(min-width: 768px){.hero__title{font-size:var(--font-size-4xl)}}.hero__subtitle{font-size:var(--font-size-lg);color:var(--color-text-alt);margin-bottom:var(--spacing-xl);max-width:600px;margin-left:auto;margin-right:auto}@media(min-width: 768px){.hero__subtitle{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2xl)}}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:2px}*,*::before,*::after{transition-property:background-color,border-color,color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}@media(prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}.nav__brand img,.nav__brand picture{float:left;margin-right:0;height:auto}.image_to_left img,.image_to_left picture{float:left;margin-right:0;height:auto}.form-container{max-width:480px;margin:20px auto}.toggle-button{background-color:var(--ctp-surface0);color:var(--ctp-subtext0);padding:15px;border:none;border-radius:8px;cursor:pointer;font-size:18px;width:100%;touch-action:manipulation;-webkit-appearance:none}.toggle-button:hover{background-color:var(--color-bg-alt);border-color:var(--color-primary)}.form-wrapper{overflow:hidden !important;max-height:0 !important;opacity:0 !important;transform:translateY(-10px) !important;transition:max-height .5s cubic-bezier(0.4, 0, 0.2, 1),opacity .3s ease,transform .4s ease !important}.form-wrapper.show{max-height:350px !important;opacity:1 !important;transform:translateY(0) !important}