@layer reset, tokens, base, layout, components, utilities;@font-face{font-display:swap;font-family:Aileron;font-style:normal;font-weight:400;src:url(/assets/fonts/aileron/Aileron-Regular.woff2) format("woff2"),url(/assets/fonts/aileron/Aileron-Regular.woff) format("woff")}@font-face{font-display:swap;font-family:Aileron;font-style:italic;font-weight:400;src:url(/assets/fonts/aileron/Aileron-Italic.woff2) format("woff2"),url(/assets/fonts/aileron/Aileron-Italic.woff) format("woff")}@font-face{font-display:swap;font-family:Aileron;font-style:normal;font-weight:600;src:url(/assets/fonts/aileron/Aileron-SemiBold.woff2) format("woff2"),url(/assets/fonts/aileron/Aileron-SemiBold.woff) format("woff")}@font-face{font-display:swap;font-family:Aileron;font-style:italic;font-weight:600;src:url(/assets/fonts/aileron/Aileron-SemiBoldItalic.woff2) format("woff2"),url(/assets/fonts/aileron/Aileron-SemiBoldItalic.woff) format("woff")}@font-face{font-display:swap;font-family:Aileron;font-style:normal;font-weight:700;src:url(/assets/fonts/aileron/Aileron-Bold.woff2) format("woff2"),url(/assets/fonts/aileron/Aileron-Bold.woff) format("woff")}@font-face{font-display:swap;font-family:Aileron;font-style:italic;font-weight:700;src:url(/assets/fonts/aileron/Aileron-BoldItalic.woff2) format("woff2"),url(/assets/fonts/aileron/Aileron-BoldItalic.woff) format("woff")}@font-face{font-display:swap;font-family:Fira Code;font-style:normal;font-weight:300 700;src:url(/assets/fonts/fira-code/FiraCode-VF.woff2) format("woff2-variations")}@font-face{font-display:swap;font-family:Libre Baskerville;font-style:normal;font-weight:400;src:url(/assets/fonts/libre-baskerville/LibreBaskerville-Regular.woff2) format("woff2"),url(/assets/fonts/libre-baskerville/LibreBaskerville-Regular.woff) format("woff")}@font-face{font-display:swap;font-family:Libre Baskerville;font-style:italic;font-weight:400;src:url(/assets/fonts/libre-baskerville/LibreBaskerville-Italic.woff2) format("woff2"),url(/assets/fonts/libre-baskerville/LibreBaskerville-Italic.woff) format("woff")}@font-face{font-display:swap;font-family:Libre Baskerville;font-style:normal;font-weight:700;src:url(/assets/fonts/libre-baskerville/LibreBaskerville-Bold.woff2) format("woff2"),url(/assets/fonts/libre-baskerville/LibreBaskerville-Bold.woff) format("woff")}@font-face{font-display:swap;font-family:Libre Baskerville;font-style:italic;font-weight:700;src:url(/assets/fonts/libre-baskerville/LibreBaskerville-BoldItalic.woff2) format("woff2"),url(/assets/fonts/libre-baskerville/LibreBaskerville-BoldItalic.woff) format("woff")}@layer reset{*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;scroll-behavior:smooth}body{min-height:100dvh}h1,h2,h3,h4,h5,h6{text-wrap:balance}figcaption,li,p{text-wrap:pretty}a:not([class]){-webkit-text-decoration-skip:ink;color:currentcolor;text-decoration-skip-ink:auto}canvas,img,picture,svg,video{display:block;height:auto;max-width:100%}button,input,select,textarea{color:inherit;font:inherit}button{cursor:pointer}textarea{resize:vertical}ol[role=list],ul[role=list]{list-style:none}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}}@layer tokens{:root{color-scheme:light dark;interpolate-size:allow-keywords;--color-sand-25:oklch(0.993 0.003 60);--color-sand-50:oklch(0.985 0.005 60);--color-sand-75:oklch(0.968 0.006 60);--color-sand-100:oklch(0.95 0.008 60);--color-sand-125:oklch(0.932 0.009 60);--color-sand-150:oklch(0.915 0.01 60);--color-sand-200:oklch(0.88 0.012 60);--color-sand-300:oklch(0.78 0.016 60);--color-sand-400:oklch(0.65 0.014 60);--color-sand-500:oklch(0.55 0.012 60);--color-sand-600:oklch(0.45 0.012 60);--color-sand-700:oklch(0.37 0.01 60);--color-sand-800:oklch(0.28 0.008 60);--color-sand-850:oklch(0.24 0.007 60);--color-sand-900:oklch(0.2 0.006 60);--color-sand-925:oklch(0.165 0.005 60);--color-sand-950:oklch(0.13 0.005 60);--color-accent:oklch(0.6135 0.1974 36.29);--color-accent-light:oklch(from var(--color-accent) calc(l + 0.115) c h);--color-accent-dark:#a12b00;--text-primary:var(--color-sand-700);--text-secondary:var(--color-sand-600);--text-muted:var(--color-sand-500);--bg-primary:var(--color-sand-50);--bg-surface:var(--color-sand-25);--bg-hover:var(--color-sand-100);--bg-secondary:var(--color-sand-75);--bg-code:var(--color-sand-800);--border:var(--color-sand-200);--border-strong:var(--color-sand-400);--link:var(--color-accent-dark);--link-hover:var(--color-accent);--font-sans:"Aileron",system-ui,-apple-system,"Segoe UI",sans-serif;--font-serif:"Libre Baskerville",Georgia,"Times New Roman",serif;--font-mono:"Fira Code",ui-monospace,"SF Mono","Cascadia Code",monospace;--font-primary:var(--font-serif);--font-secondary:var(--font-sans);--text-xs:clamp(0.75rem,0.7rem + 0.2vw,0.8rem);--text-sm:clamp(0.8rem,0.75rem + 0.25vw,0.875rem);--text-base:clamp(1rem,0.925rem + 0.35vw,1.125rem);--text-lg:clamp(1.15rem,1rem + 0.55vw,1.35rem);--text-xl:clamp(1.35rem,1.1rem + 0.85vw,1.7rem);--text-2xl:clamp(1.65rem,1.3rem + 1.3vw,2.15rem);--text-3xl:clamp(2rem,1.5rem + 1.8vw,2.75rem);--leading-tight:1.2;--leading-snug:1.35;--leading-normal:1.6;--leading-relaxed:1.75;--tracking-tight:-0.015em;--tracking-normal:0;--tracking-wide:0.02em;--weight-normal:400;--weight-medium:600;--weight-bold:700;--space-3xs:clamp(0.125rem,0.1rem + 0.1vw,0.25rem);--space-2xs:clamp(0.25rem,0.2rem + 0.2vw,0.375rem);--space-xs:clamp(0.5rem,0.4rem + 0.35vw,0.625rem);--space-s:clamp(0.75rem,0.6rem + 0.5vw,1rem);--space-m:clamp(1rem,0.8rem + 0.75vw,1.5rem);--space-l:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);--space-xl:clamp(2rem,1.5rem + 1.8vw,3rem);--space-2xl:clamp(3rem,2.2rem + 2.8vw,4.5rem);--space-3xl:clamp(4rem,3rem + 3.5vw,6rem);--content-width:75ch;--wide-width:85ch;--max-width:80rem;--gutter:var(--space-m);--shadow-sm:0 1px 3px oklch(0 0 0/0.04);--shadow-md:0 4px 12px oklch(0 0 0/0.08);--shadow-lg:0 4px 16px oklch(0 0 0/0.08);--radius-s:0.25rem;--radius-m:0.5rem;--radius-l:0.75rem;--radius-full:9999px;--ease-out:cubic-bezier(0.22,1,0.36,1);--ease-in-out:cubic-bezier(0.65,0,0.35,1);--ease-expressive:cubic-bezier(0.4,0,0.1,1);--duration-fast:150ms;--duration-normal:300ms;--duration-slow:500ms}@media (color-gamut:p3){:root{--color-accent-dark:oklch(0.47 0.18 36.29)}}}@layer tokens{[data-theme=dark]{--icon-fill-opacity:0.25;--text-primary:var(--color-sand-200);--text-secondary:var(--color-sand-300);--text-muted:var(--color-sand-400);--bg-primary:var(--color-sand-900);--bg-surface:var(--color-sand-850);--bg-hover:var(--color-sand-850);--bg-secondary:var(--color-sand-800);--bg-code:var(--color-sand-800);--border:var(--color-sand-700);--border-strong:var(--color-sand-600);--link:var(--color-accent-light);--link-hover:var(--color-accent)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--icon-fill-opacity:0.25;--text-primary:var(--color-sand-200);--text-secondary:var(--color-sand-300);--text-muted:var(--color-sand-400);--bg-primary:var(--color-sand-900);--bg-surface:var(--color-sand-850);--bg-hover:var(--color-sand-850);--bg-secondary:var(--color-sand-800);--bg-code:var(--color-sand-800);--border:var(--color-sand-700);--border-strong:var(--color-sand-600);--link:var(--color-accent-light);--link-hover:var(--color-accent)}}}@layer base{html{scrollbar-gutter:stable;-webkit-tap-highlight-color:transparent}body{background-color:oklch(.985 .005 60);background-color:var(--bg-primary);color:oklch(.37 .01 60);color:var(--text-primary);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(1rem,.925rem + .35vw,1.125rem);font-size:var(--text-base);line-height:1.6;line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-optical-sizing:auto;word-wrap:break-word;transition:color .3s cubic-bezier(.22,1,.36,1),background-color .3s cubic-bezier(.22,1,.36,1);transition:color var(--duration-normal) var(--ease-out),background-color var(--duration-normal) var(--ease-out)}h1,h2,h3,h4,h5,h6{font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-weight:700;font-weight:var(--weight-bold);letter-spacing:-.015em;letter-spacing:var(--tracking-tight);line-height:1.2;line-height:var(--leading-tight);margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s);text-rendering:optimizeLegibility}h1{font-size:clamp(2rem,1.5rem + 1.8vw,2.75rem);font-size:var(--text-3xl);margin-block-end:clamp(1rem,.8rem + .75vw,1.5rem);margin-block-end:var(--space-m)}h2{font-size:clamp(1.65rem,1.3rem + 1.3vw,2.15rem);font-size:var(--text-2xl)}h3{font-size:clamp(1.35rem,1.1rem + .85vw,1.7rem);font-size:var(--text-xl)}h4{font-size:clamp(1.15rem,1rem + .55vw,1.35rem);font-size:var(--text-lg)}h5{font-size:clamp(1rem,.925rem + .35vw,1.125rem);font-size:var(--text-base)}h5,h6{font-weight:600;font-weight:var(--weight-medium)}h6{font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm)}a{color:oklch(.47 .18 36.29);color:var(--link);-webkit-text-decoration:none;text-decoration:none;transition:color .15s cubic-bezier(.22,1,.36,1);transition:color var(--duration-fast) var(--ease-out)}@media (hover:hover){a:hover{color:oklch(.6135 .1974 36.29);color:var(--link-hover)}}code,kbd,samp{font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono);font-size:.875em}code:not(pre code),kbd,samp{color:oklch(.968 .006 60);color:var(--color-sand-75)}code:not(pre code){border-radius:.25rem;border-radius:var(--radius-s);padding:.125em .3em}code:not(pre code),pre{background:oklch(.28 .008 60);background:var(--bg-code)}pre{border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius-m);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);line-height:1.35;line-height:var(--leading-snug);overflow-x:auto;padding:clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-m)}::-moz-selection{background:rgba(225,72,23,.3)}::selection{background:rgba(225,72,23,.3)}@supports (color:lab(from red l 1 1%/calc(alpha + 0.1))){::-moz-selection{background:oklch(from var(--color-accent) l c h/.3)}::selection{background:oklch(from var(--color-accent) l c h/.3)}}:focus-visible{outline:2px solid oklch(.6135 .1974 36.29);outline:2px solid var(--color-accent);outline-offset:2px}small,time{color:oklch(.45 .012 60);color:var(--text-secondary);font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);font-style:italic}}@layer layout{body{display:flex;flex-direction:column;min-height:100dvh;overflow-x:clip}body>header{backdrop-filter:blur(.75rem);background:hsla(20,60%,98%,.85);border-block-end:1px solid oklch(.88 .012 60);border-block-end:1px solid var(--border);padding-inline:clamp(1rem,.8rem + .75vw,1.5rem);padding-inline:var(--gutter);position:sticky;top:0;z-index:10}@supports (color:lab(from red l 1 1%/calc(alpha + 0.1))){body>header{background:oklch(from var(--bg-primary) l c h/.85)}}body>header>nav{align-items:center;display:flex;gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m);justify-content:space-between;margin-inline:auto;max-width:80rem;max-width:var(--max-width);padding-block:clamp(.75rem,.6rem + .5vw,1rem);padding-block:var(--space-s)}main{flex:1;margin-inline:auto;max-width:75ch;max-width:var(--content-width);padding-block:clamp(3rem,2.2rem + 2.8vw,4.5rem);padding-block:var(--space-2xl);padding-inline:clamp(1rem,.8rem + .75vw,1.5rem);padding-inline:var(--gutter);width:100%}body>footer{border-block-start:1px solid oklch(.88 .012 60);border-block-start:1px solid var(--border);margin-block-start:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-start:var(--space-xl);padding:clamp(2rem,1.5rem + 1.8vw,3rem) clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-xl) var(--gutter)}.footer-inner{margin-inline:auto;max-width:80rem;max-width:var(--max-width)}.footer-nav{display:grid;grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));grid-gap:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);grid-gap:var(--space-l);gap:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);gap:var(--space-l);margin-block-end:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-end:var(--space-xl)}.footer-nav h3{color:oklch(.55 .012 60);color:var(--text-muted);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);font-weight:600;font-weight:var(--weight-medium);letter-spacing:.02em;letter-spacing:var(--tracking-wide);margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s);text-transform:uppercase}.footer-nav ul{display:flex;flex-direction:column;list-style:none}.footer-nav a{border-radius:.25rem;border-radius:var(--radius-s);color:oklch(.45 .012 60);color:var(--text-secondary);display:block;font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);padding:clamp(.25rem,.2rem + .2vw,.375rem) clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-2xs) var(--space-xs);-webkit-text-decoration:none;text-decoration:none;transition:color .15s cubic-bezier(.22,1,.36,1),background-color .15s cubic-bezier(.22,1,.36,1);transition:color var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out);width:-moz-fit-content;width:fit-content}@media (hover:hover){.footer-nav a:hover{background:oklch(.968 .006 60);background:var(--bg-secondary);color:oklch(.37 .01 60);color:var(--text-primary)}}.footer-copy{color:oklch(.55 .012 60);color:var(--text-muted);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs)}}@layer components{.skip-link{background:oklch(.985 .005 60);background:var(--bg-primary);border:1px solid oklch(.65 .014 60);border:1px solid var(--border-strong);border-radius:.5rem;border-radius:var(--radius-m);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);left:clamp(.5rem,.4rem + .35vw,.625rem);left:var(--space-xs);padding:clamp(.5rem,.4rem + .35vw,.625rem) clamp(.75rem,.6rem + .5vw,1rem);padding:var(--space-xs) var(--space-s);position:absolute;top:clamp(.5rem,.4rem + .35vw,.625rem);top:var(--space-xs);transform:translateY(-200%);transition:transform .15s cubic-bezier(.22,1,.36,1);transition:transform var(--duration-fast) var(--ease-out);z-index:100}.skip-link:focus-visible{transform:translateY(0)}.icon{flex-shrink:0;height:1.25em;transition:transform .15s cubic-bezier(.4,0,.1,1);transition:transform var(--duration-fast) var(--ease-expressive);width:1.25em}.icon .duo-fill{fill:oklch(.6135 .1974 36.29);fill:var(--color-accent);opacity:.2;opacity:var(--icon-fill-opacity,.2);transition:opacity .15s cubic-bezier(.22,1,.36,1);transition:opacity var(--duration-fast) var(--ease-out)}.icon .duo-stroke{stroke:oklch(.47 .18 36.29);stroke:var(--color-accent-dark)}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;transition-duration:.01ms!important}}}@layer components{.site-logo{color:oklch(.37 .01 60);color:var(--text-primary);cursor:pointer;font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-size:clamp(1.15rem,1rem + .55vw,1.35rem);font-size:var(--text-lg);font-weight:700;font-weight:var(--weight-bold);white-space:nowrap;z-index:52}.nav-item,.site-logo{position:relative;-webkit-text-decoration:none;text-decoration:none}.nav-item{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-m);color:oklch(.45 .012 60);color:var(--text-secondary);display:inline-flex;font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);font-weight:600;font-weight:var(--weight-medium);gap:var(--_nav-gap);line-height:1;padding:clamp(.5rem,.4rem + .35vw,.625rem) clamp(.75rem,.6rem + .5vw,1rem);padding:var(--space-xs) var(--space-s);transition:color .15s cubic-bezier(.22,1,.36,1),background-color .15s cubic-bezier(.22,1,.36,1);transition:color var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out)}@media (hover:hover){.nav-item:hover{background:oklch(.95 .008 60);background:var(--bg-hover);color:oklch(.37 .01 60);color:var(--text-primary)}}.nav-item[aria-current=page]{background:oklch(.968 .006 60);background:var(--bg-secondary);color:oklch(.47 .18 36.29);color:var(--link);font-weight:700;font-weight:var(--weight-bold)}@media (hover:hover){.nav-item:hover .icon .duo-fill{opacity:.45}.nav-dropdown-item:hover .icon--wrench,.nav-item:hover .icon--wrench{transform:rotate(-20deg)}.nav-dropdown-item:hover .icon--headset,.nav-item:hover .icon--headset{transform:translateY(-1.5px)}.nav-dropdown-item:hover .icon--page,.nav-item:hover .icon--page{transform:rotate(-5deg) translateY(-1px)}.nav-dropdown-item:hover .icon--compass,.nav-item:hover .icon--compass{transform:rotate(20deg)}.nav-dropdown-item:hover .icon--journal,.nav-item:hover .icon--journal{transform:rotate(-4deg)}}.site-nav{--_nav-gap:0.75ch;display:flex;gap:.75ch;list-style:none}.nav-dropdown-trigger,.site-nav{align-items:center;gap:var(--_nav-gap)}.nav-dropdown-trigger{display:inline-flex}.nav-icon-plus{display:inline-block;height:.75em;position:relative;transition:transform .3s cubic-bezier(.4,0,.1,1);transition:transform var(--duration-normal) var(--ease-expressive);width:.75em}.nav-icon-plus__h,.nav-icon-plus__v{background:currentColor;left:50%;position:absolute;top:50%;transition:transform .3s cubic-bezier(.4,0,.1,1),opacity .3s cubic-bezier(.4,0,.1,1);transition:transform var(--duration-normal) var(--ease-expressive),opacity var(--duration-normal) var(--ease-expressive)}.nav-icon-plus__h{height:1.25px;transform:translate(-50%,-50%);width:100%}.nav-icon-plus__v{height:100%;transform:translate(-50%,-50%) rotate(0deg);width:1.5px}.nav-dropdown-wrapper{position:relative}.nav-dropdown{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:clamp(.125rem,.1rem + .1vw,.25rem);grid-gap:var(--space-3xs);background:oklch(.985 .005 60);background:var(--bg-primary);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius-m);box-shadow:0 4px 12px oklch(0 0 0/.08);box-shadow:var(--shadow-md);gap:clamp(.125rem,.1rem + .1vw,.25rem);gap:var(--space-3xs);left:0;list-style:none;min-width:40rem;opacity:0;padding:clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-xs);pointer-events:none;position:absolute;top:calc(100% + clamp(.25rem, .2rem + .2vw, .375rem));top:calc(100% + var(--space-2xs));transform:translateY(-.25rem) scale(.97);transform-origin:top left;transition:opacity .15s cubic-bezier(.22,1,.36,1),visibility 0s .15s,transform .15s cubic-bezier(.4,0,.1,1);transition:opacity var(--duration-fast) var(--ease-out),visibility 0s var(--duration-fast),transform var(--duration-fast) var(--ease-expressive);visibility:hidden;z-index:20}.nav-dropdown>li{opacity:0;transform:translateY(.5rem);transition:opacity .3s cubic-bezier(.22,1,.36,1),transform .3s cubic-bezier(.4,0,.1,1);transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-expressive)}.nav-dropdown-item{align-items:flex-start;border-radius:.25rem;border-radius:var(--radius-s);color:oklch(.37 .01 60);color:var(--text-primary);display:flex;gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs);padding:clamp(.75rem,.6rem + .5vw,1rem);padding:var(--space-s);-webkit-text-decoration:none;text-decoration:none;transition:background-color .15s cubic-bezier(.22,1,.36,1);transition:background-color var(--duration-fast) var(--ease-out)}@media (hover:hover){.nav-dropdown-item:hover{background:oklch(.95 .008 60);background:var(--bg-hover)}}.nav-dropdown-item[aria-current=page]{background:oklch(.95 .008 60);background:var(--bg-hover)}.nav-dropdown-icon{flex-shrink:0;line-height:0;padding-block-start:.1em}.nav-dropdown-title{display:block;font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);font-weight:600;font-weight:var(--weight-medium);line-height:1}.nav-dropdown-desc{color:oklch(.45 .012 60);color:var(--text-secondary);display:block;font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);line-height:1.6;line-height:var(--leading-normal);margin-block-start:clamp(.5rem,.4rem + .35vw,.625rem);margin-block-start:var(--space-xs);text-wrap:balance}.nav-dropdown-wrapper.is-open .nav-dropdown{opacity:1;pointer-events:auto;transform:translateY(0) scale(1);transition-delay:0s;visibility:visible}.nav-dropdown-wrapper.is-open .nav-dropdown>li{opacity:1;transform:translateY(0)}.nav-dropdown-wrapper.is-open .nav-dropdown>li:first-child{transition-delay:.1s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(2){transition-delay:.15s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(3){transition-delay:.2s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(4){transition-delay:.25s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(5){transition-delay:.3s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(6){transition-delay:.35s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(7){transition-delay:.4s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(8){transition-delay:.45s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(9){transition-delay:.5s}.nav-dropdown-wrapper.is-open .nav-icon-plus{transform:rotate(180deg)}.nav-dropdown-wrapper.is-open .nav-icon-plus__v{transform:translate(-50%,-50%) rotate(90deg)}.nav-toggle{background:none;border:none;color:oklch(.37 .01 60);color:var(--text-primary);display:none;padding:clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-xs);position:relative;z-index:52}.burger{display:block;height:.75rem;position:relative;width:1.5rem}.burger__line{background:currentColor;border-radius:1px;display:block;height:1.5px;left:0;position:absolute;transition:transform .3s cubic-bezier(.4,0,.1,1);transition:transform var(--duration-normal) var(--ease-expressive);width:100%}.burger__line--top{top:0}.burger__line--bottom{bottom:0}.nav-toggle.is-active .burger__line--top{transform:translateY(calc(.375rem - .75px)) rotate(45deg)}.nav-toggle.is-active .burger__line--bottom{transform:translateY(calc(-.375rem + .75px)) rotate(-45deg)}body.nav-overlay-open{overflow:hidden}@media (max-width:52rem){.site-logo{margin-inline-end:auto}.nav-toggle{display:block;order:1}.site-nav{align-items:center;background:oklch(.985 .005 60);background:var(--bg-primary);flex-direction:column;gap:clamp(.75rem,.6rem + .5vw,1rem);gap:var(--space-s);height:100dvh;inset:0;justify-content:center;list-style:none;opacity:0;padding:clamp(2rem,1.5rem + 1.8vw,3rem) clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-xl) var(--gutter);position:fixed;transition:opacity .5s cubic-bezier(.4,0,.1,1),visibility .5s cubic-bezier(.4,0,.1,1);transition:opacity var(--duration-slow) var(--ease-expressive),visibility var(--duration-slow) var(--ease-expressive);visibility:hidden;z-index:51}.site-nav .nav-item{font-size:clamp(1.65rem,1.3rem + 1.3vw,2.15rem);font-size:var(--text-2xl);opacity:0;padding:clamp(.75rem,.6rem + .5vw,1rem) clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-s) var(--space-m);transform:translateY(.5rem);transition:color .3s cubic-bezier(.22,1,.36,1),background-color .3s cubic-bezier(.22,1,.36,1),opacity .3s cubic-bezier(.4,0,.1,1),transform .3s cubic-bezier(.4,0,.1,1);transition:color var(--duration-normal) var(--ease-out),background-color var(--duration-normal) var(--ease-out),opacity var(--duration-normal) var(--ease-expressive),transform var(--duration-normal) var(--ease-expressive)}.site-nav.is-open{opacity:1;visibility:visible}.site-nav.is-open .nav-item{opacity:1;transform:translateY(0)}.site-nav.is-open>:first-child .nav-item{transition-delay:80ms}.site-nav.is-open>:nth-child(2) .nav-item{transition-delay:.14s}.site-nav.is-open>:nth-child(3) .nav-dropdown-trigger,.site-nav.is-open>:nth-child(3) .nav-item{transition-delay:.2s}.site-nav.is-open>:nth-child(4) .nav-item{transition-delay:.26s}.site-nav.is-open>:nth-child(5) .nav-item{transition-delay:.32s}.nav-dropdown-wrapper{position:static;text-align:center}.nav-dropdown{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:clamp(.25rem,.2rem + .2vw,.375rem);grid-gap:var(--space-2xs);background:transparent;border:none;box-shadow:none;gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs);min-width:0;opacity:1;padding:0;pointer-events:auto;position:static;transform:none;visibility:visible;interpolate-size:allow-keywords;height:0;overflow:hidden;transition:height .3s cubic-bezier(.4,0,.1,1);transition:height var(--duration-normal) var(--ease-expressive)}.nav-dropdown-item{text-align:start}.nav-dropdown>li{opacity:0;transform:translateY(.5rem);transition:opacity .3s cubic-bezier(.4,0,.1,1),transform .3s cubic-bezier(.4,0,.1,1);transition:opacity var(--duration-normal) var(--ease-expressive),transform var(--duration-normal) var(--ease-expressive)}.nav-dropdown-wrapper.is-open .nav-dropdown{height:auto;padding-block-start:clamp(.25rem,.2rem + .2vw,.375rem);padding-block-start:var(--space-2xs)}.nav-dropdown-wrapper.is-open .nav-dropdown>li{opacity:1;transform:translateY(0)}.nav-dropdown-wrapper.is-open .nav-dropdown>li:first-child{transition-delay:50ms}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(2){transition-delay:.1s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(3){transition-delay:.15s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(4){transition-delay:.2s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(5){transition-delay:.25s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(6){transition-delay:.3s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(7){transition-delay:.35s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(8){transition-delay:.4s}.nav-dropdown-wrapper.is-open .nav-dropdown>li:nth-child(9){transition-delay:.45s}}}@layer components{.theme-toggle{align-items:center;background:none;border:none;color:oklch(.45 .012 60);color:var(--text-secondary);display:inline-flex;justify-content:center;padding:clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-xs);transition:color .15s cubic-bezier(.22,1,.36,1);transition:color var(--duration-fast) var(--ease-out)}@media (hover:hover){.theme-toggle:hover{color:oklch(.37 .01 60);color:var(--text-primary)}}.theme-icon{background:currentColor;border-radius:50%;height:1.25rem;position:relative;transform-origin:center;transition:transform .75s cubic-bezier(.4,0,.1,1);transition:transform .75s var(--ease-expressive);width:1.25rem}.theme-icon:after{background:oklch(.985 .005 60);background:var(--bg-primary);content:"";height:.8rem;right:-.15rem;top:-.15rem;transition:transform .5s cubic-bezier(.4,0,.1,1),right .3s cubic-bezier(.22,1,.36,1),top .3s cubic-bezier(.22,1,.36,1);transition:transform var(--duration-slow) var(--ease-expressive),right var(--duration-normal) var(--ease-out),top var(--duration-normal) var(--ease-out);width:.8rem}.theme-icon:after,.theme-icon__ray{border-radius:50%;position:absolute;transform-origin:center}.theme-icon__ray{background:currentColor;height:.375rem;left:calc(50% - .1875rem);top:calc(50% - .1875rem);transition:transform .5s cubic-bezier(.4,0,.1,1);transition:transform var(--duration-slow) var(--ease-expressive);width:.375rem}.theme-icon__ray:first-child{transform:rotate(45deg) translateX(0)}.theme-icon__ray:nth-child(2){transform:rotate(90deg) translateX(0)}.theme-icon__ray:nth-child(3){transform:rotate(135deg) translateX(0)}.theme-icon__ray:nth-child(4){transform:rotate(180deg) translateX(0)}.theme-icon__ray:nth-child(5){transform:rotate(225deg) translateX(0)}.theme-icon__ray:nth-child(6){transform:rotate(270deg) translateX(0)}.theme-icon__ray:nth-child(7){transform:rotate(315deg) translateX(0)}.theme-icon__ray:nth-child(8){transform:rotate(1turn) translateX(0)}[data-theme=dark] .theme-icon{transform:scale(.55)}[data-theme=dark] .theme-icon:after{right:0;top:0;transform:scale(0)}[data-theme=dark] .theme-icon__ray:first-child{transform:rotate(45deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(2){transform:rotate(90deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(3){transform:rotate(135deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(4){transform:rotate(180deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(5){transform:rotate(225deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(6){transform:rotate(270deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(7){transform:rotate(315deg) translateX(-1rem)}[data-theme=dark] .theme-icon__ray:nth-child(8){transform:rotate(1turn) translateX(-1rem)}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .theme-icon{transform:scale(.55)}:root:not([data-theme=light]) .theme-icon:after{right:0;top:0;transform:scale(0)}:root:not([data-theme=light]) .theme-icon__ray:first-child{transform:rotate(45deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(2){transform:rotate(90deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(3){transform:rotate(135deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(4){transform:rotate(180deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(5){transform:rotate(225deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(6){transform:rotate(270deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(7){transform:rotate(315deg) translateX(-1rem)}:root:not([data-theme=light]) .theme-icon__ray:nth-child(8){transform:rotate(1turn) translateX(-1rem)}}}@layer components{.hero{margin-block-end:clamp(3rem,2.2rem + 2.8vw,4.5rem);margin-block-end:var(--space-2xl)}.hero h1{margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s)}.hero h1 em{position:relative}.hero h1 em:after{background:currentColor;content:"";inset-inline:0;bottom:-.05em;height:.15em;-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 14'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-width='8' d='M0 7q14-6 28-.5Q40 13 55 6 68 .5 82 7q12 6 18 0'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 14'%3E%3Cpath fill='none' stroke='%23000' stroke-linecap='round' stroke-width='8' d='M0 7q14-6 28-.5Q40 13 55 6 68 .5 82 7q12 6 18 0'/%3E%3C/svg%3E");-webkit-mask-repeat:repeat-x;mask-repeat:repeat-x;-webkit-mask-size:auto 100%;mask-size:auto 100%;position:absolute}.hero p{color:oklch(.45 .012 60);color:var(--text-secondary);font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-size:clamp(1.15rem,1rem + .55vw,1.35rem);font-size:var(--text-lg);line-height:1.75;line-height:var(--leading-relaxed);max-width:40ch}.hero em{color:oklch(.6135 .1974 36.29);color:var(--color-accent)}.article-meta{align-items:center;color:oklch(.45 .012 60);color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs);margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s)}article:not(.card)>.prose,article:not(.card)>header{margin-block-end:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-end:var(--space-xl)}article:not(.card)>footer{border-block-start:1px solid oklch(.88 .012 60);border-block-start:1px solid var(--border);color:oklch(.45 .012 60);color:var(--text-secondary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);padding-block-start:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);padding-block-start:var(--space-l)}.prose>*+*{margin-block-start:clamp(1rem,.8rem + .75vw,1.5rem);margin-block-start:var(--space-m)}.prose h2,.prose h3,.prose h4{margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s);margin-block-start:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-start:var(--space-xl)}.prose h2{font-size:clamp(1.35rem,1.1rem + .85vw,1.7rem);font-size:var(--text-xl)}.prose h3{font-size:clamp(1.15rem,1rem + .55vw,1.35rem);font-size:var(--text-lg)}.prose h4{font-size:clamp(1rem,.925rem + .35vw,1.125rem);font-size:var(--text-base);font-weight:600;font-weight:var(--weight-medium)}.prose ol,.prose ul{padding-inline-start:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);padding-inline-start:var(--space-l)}.prose li+li{margin-block-start:clamp(.5rem,.4rem + .35vw,.625rem);margin-block-start:var(--space-xs)}.prose li,.prose p{font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary)}.prose p{line-height:1.75;line-height:var(--leading-relaxed)}.prose blockquote{border-inline-start:.25rem solid oklch(.6135 .1974 36.29);border-inline-start:.25rem solid var(--color-accent);color:oklch(.45 .012 60);color:var(--text-secondary);font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-style:italic;padding-block:clamp(.5rem,.4rem + .35vw,.625rem);padding-block:var(--space-xs);padding-inline-start:clamp(1rem,.8rem + .75vw,1.5rem);padding-inline-start:var(--space-m)}.prose hr{border:none;border-block-start:1px solid oklch(.88 .012 60);border-block-start:1px solid var(--border);margin-block:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block:var(--space-xl)}.prose strong{font-weight:600;font-weight:var(--weight-medium)}.prose img{border-radius:.5rem;border-radius:var(--radius-m)}.prose figure,.prose img{margin-block:clamp(1rem,.8rem + .75vw,1.5rem);margin-block:var(--space-m)}.prose figcaption{color:oklch(.45 .012 60);color:var(--text-secondary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);margin-block-start:clamp(.25rem,.2rem + .2vw,.375rem);margin-block-start:var(--space-2xs);text-align:center}.prose a,main p:not(.does-not-exist) a{background-image:linear-gradient(oklch(.6135 .1974 36.29),oklch(.6135 .1974 36.29));background-image:linear-gradient(var(--color-accent),var(--color-accent));background-position:0 100%;background-repeat:no-repeat;background-size:0 1px;font-weight:600;font-weight:var(--weight-medium);transition:background-size .5s cubic-bezier(.22,1,.36,1),color .5s cubic-bezier(.22,1,.36,1);transition:background-size var(--duration-slow) var(--ease-out),color var(--duration-slow) var(--ease-out)}}@layer components{}@layer components{@media (hover:hover){.prose a:hover,main p:not(.does-not-exist) a:hover{background-size:100% 1px}}}@layer components{.badge-list{display:flex;flex-wrap:wrap;gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs);list-style:none}.badge{align-items:center;background:oklch(.968 .006 60);background:var(--bg-secondary);border-radius:9999px;border-radius:var(--radius-full);color:oklch(.45 .012 60);color:var(--text-secondary);display:inline-flex;font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);gap:clamp(.125rem,.1rem + .1vw,.25rem);gap:var(--space-3xs);padding:clamp(.25rem,.2rem + .2vw,.375rem) clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-2xs) var(--space-xs);white-space:nowrap}a[target=_blank]:after{background:currentColor;content:"";display:inline-block;height:.65em;margin-inline-start:.25em;-webkit-mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' viewBox='0 0 14 14'%3E%3Cpath d='M4 1h9v9M13 1 1 13'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23000' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' viewBox='0 0 14 14'%3E%3Cpath d='M4 1h9v9M13 1 1 13'/%3E%3C/svg%3E");-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:contain;mask-size:contain;vertical-align:baseline;width:.65em}.work-intro{color:oklch(.45 .012 60);color:var(--text-secondary);font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-size:clamp(1.15rem,1rem + .55vw,1.35rem);font-size:var(--text-lg);line-height:1.75;line-height:var(--leading-relaxed);margin-block-end:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-end:var(--space-xl);max-width:50ch}.work-clients,.work-contact{margin-block-start:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-start:var(--space-xl)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,18rem),1fr));grid-gap:clamp(1rem,.8rem + .75vw,1.5rem);grid-gap:var(--space-m);gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m);margin-block-end:clamp(3rem,2.2rem + 2.8vw,4.5rem);margin-block-end:var(--space-2xl)}.card-grid--cols-2{grid-template-columns:repeat(2,1fr)}.card-grid--cols-3{grid-template-columns:repeat(3,1fr)}.card-grid--cols-4{grid-template-columns:repeat(4,1fr)}.card-grid--list{gap:clamp(.75rem,.6rem + .5vw,1rem);gap:var(--space-s);grid-template-columns:1fr}}@layer components{}@layer components{@media (max-width:52rem){.card-grid--cols-3,.card-grid--cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:32rem){.card-grid[class*=card-grid--cols-]{grid-template-columns:1fr}}.card--span-2{grid-column:span 2}.card--span-row-2{grid-row:span 2}.card--span-2x2{grid-column:span 2;grid-row:span 2}@media (max-width:32rem){.card--span-2,.card--span-2x2{grid-column:span 1}.card--span-2x2,.card--span-row-2{grid-row:span 1}}.card{background:oklch(.993 .003 60);background:var(--bg-surface);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.75rem;border-radius:var(--radius-l);box-shadow:0 1px 3px oklch(0 0 0/.04);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;overflow:hidden;position:relative;transition:transform .15s cubic-bezier(.22,1,.36,1),box-shadow .15s cubic-bezier(.22,1,.36,1);transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}@media (hover:hover){.card:has(.card__title a):hover{box-shadow:0 4px 16px oklch(0 0 0/.08);box-shadow:var(--shadow-lg);transform:translateY(-2px)}}.card:has(:focus-visible){outline:2px solid oklch(.6135 .1974 36.29);outline:2px solid var(--color-accent);outline-offset:2px}.card .card__title a:before{content:"";inset:0;position:absolute}.card a[target=_blank]:after{content:none}.card__content{display:flex;flex-direction:column;flex-grow:1;justify-content:space-between;padding:clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-m)}.card--static{pointer-events:none}.card__icon{margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s)}.card__icon .icon{height:2rem;width:2rem}.card__external-icon{color:oklch(.55 .012 60);color:var(--text-muted);display:inline-block;flex-shrink:0;height:.65em;margin-inline-start:.5em;vertical-align:baseline;width:.65em}.card__media{aspect-ratio:16/9;background:oklch(.968 .006 60);background:var(--bg-secondary);overflow:hidden}.card__media img{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.card__media--square{aspect-ratio:1/1}.card__media--portrait{aspect-ratio:2/3}.card__media--fit{aspect-ratio:auto}.card__media--fit img{height:auto;-o-object-fit:contain;object-fit:contain}.card__media--icon{align-items:center;aspect-ratio:16/9;display:flex;justify-content:center}.card__media--icon .icon{height:2.5rem;width:2.5rem}.card__media--logo{align-items:center;display:flex;justify-content:center;padding:clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-m)}.card__media--logo img{border-radius:.75rem;border-radius:var(--radius-l);height:auto;max-height:100%;max-width:100%;-o-object-fit:contain;object-fit:contain;width:auto}.card__title{font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-size:clamp(1rem,.925rem + .35vw,1.125rem);font-size:var(--text-base);font-weight:600;font-weight:var(--weight-medium);line-height:1.35;line-height:var(--leading-snug);margin:0}.card__title a{color:oklch(.37 .01 60);color:var(--text-primary);-webkit-text-decoration:none;text-decoration:none}.card__title a:focus-visible{outline:none}.card__subtitle{font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);margin:clamp(.125rem,.1rem + .1vw,.25rem) 0 0;margin:var(--space-3xs) 0 0}.card__subtitle,.card__time{color:oklch(.55 .012 60);color:var(--text-muted)}.card__time{display:block;font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);margin-block-start:clamp(.25rem,.2rem + .2vw,.375rem);margin-block-start:var(--space-2xs)}.card__body{margin-block-start:clamp(.5rem,.4rem + .35vw,.625rem);margin-block-start:var(--space-xs)}.card__body p{color:oklch(.45 .012 60);color:var(--text-secondary);display:-webkit-box;font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);line-height:1.6;line-height:var(--leading-normal);margin:0;-webkit-box-orient:vertical;-webkit-line-clamp:3;line-clamp:3;overflow:hidden}.card__footer{align-items:center;flex-wrap:wrap;margin-block-start:clamp(.75rem,.6rem + .5vw,1rem);margin-block-start:var(--space-s)}.card__actions,.card__footer{display:flex;gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs)}.card__actions{margin-block-start:clamp(.5rem,.4rem + .35vw,.625rem);margin-block-start:var(--space-xs);width:100%}.card__actions a{border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.25rem;border-radius:var(--radius-s);color:oklch(.47 .18 36.29);color:var(--link);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);font-weight:600;font-weight:var(--weight-medium);padding:clamp(.25rem,.2rem + .2vw,.375rem) clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-2xs) var(--space-xs);position:relative;-webkit-text-decoration:none;text-decoration:none;transition:color .15s cubic-bezier(.22,1,.36,1),background-color .15s cubic-bezier(.22,1,.36,1);transition:color var(--duration-fast) var(--ease-out),background-color var(--duration-fast) var(--ease-out);z-index:2}@media (hover:hover){.card__actions a:hover{background:oklch(.95 .008 60);background:var(--bg-hover);color:oklch(.6135 .1974 36.29);color:var(--link-hover)}}.card__action-arrow{display:inline-block;height:.7em;margin-inline-start:.35em;vertical-align:middle;width:.7em}.card--horizontal{flex-direction:row}.card--horizontal .card__media{aspect-ratio:4/3;flex-shrink:0;max-width:16rem;width:40%}.card--horizontal .card__media--square{aspect-ratio:1/1}.card--horizontal .card__media--portrait{aspect-ratio:2/3}.card--horizontal .card__media--icon{aspect-ratio:1/1;max-width:8rem;width:25%}.card--horizontal .card__content{flex:1;min-width:0}.card--horizontal .card__body p{-webkit-line-clamp:5;line-clamp:5}.card-grid--list-alt .card--horizontal:nth-child(2n),.card-grid--list-right .card--horizontal{flex-direction:row-reverse}@media (max-width:40rem){.card--horizontal{flex-direction:column}.card--horizontal .card__media{aspect-ratio:16/9;max-width:none;width:auto}.card--horizontal .card__media--square{aspect-ratio:1/1}.card--horizontal .card__media--portrait{aspect-ratio:2/3}.card--horizontal .card__media--icon{max-width:none;width:auto}.card-grid--list-alt .card--horizontal:nth-child(2n),.card-grid--list-right .card--horizontal{flex-direction:column}}}@layer components{.sg-section{border-block-end:1px solid oklch(.88 .012 60);border-block-end:1px solid var(--border);margin-block-end:clamp(3rem,2.2rem + 2.8vw,4.5rem);margin-block-end:var(--space-2xl);padding-block-end:clamp(3rem,2.2rem + 2.8vw,4.5rem);padding-block-end:var(--space-2xl)}.sg-section:last-child{border-block-end:none}.sg-section-title{font-size:clamp(1.65rem,1.3rem + 1.3vw,2.15rem);font-size:var(--text-2xl);margin-block-end:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);margin-block-end:var(--space-l)}.sg-subtitle{font-size:clamp(1.15rem,1rem + .55vw,1.35rem);font-size:var(--text-lg);margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s);margin-block-start:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);margin-block-start:var(--space-l)}.sg-toc{background:oklch(.993 .003 60);background:var(--bg-surface);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius-m);margin-block-end:clamp(3rem,2.2rem + 2.8vw,4.5rem);margin-block-end:var(--space-2xl);padding:clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-m)}.sg-toc__title{color:oklch(.55 .012 60);color:var(--text-muted);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);letter-spacing:.02em;letter-spacing:var(--tracking-wide);margin-block-end:clamp(.75rem,.6rem + .5vw,1rem);margin-block-end:var(--space-s);text-transform:uppercase}.sg-toc__list{display:grid;grid-template-columns:repeat(auto-fill,minmax(14rem,1fr));list-style:none;grid-gap:clamp(.25rem,.2rem + .2vw,.375rem);grid-gap:var(--space-2xs);gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs);padding:0}.sg-toc__list a{font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm)}.sg-swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(5rem,1fr));grid-gap:clamp(.5rem,.4rem + .35vw,.625rem);grid-gap:var(--space-xs);gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs)}.sg-swatch{display:flex;flex-direction:column;gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs)}.sg-swatch__color{aspect-ratio:1;border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius-m)}.sg-label{color:oklch(.45 .012 60);color:var(--text-secondary);font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs)}.sg-tokens{display:grid;grid-template-columns:repeat(auto-fill,minmax(16rem,1fr));grid-gap:clamp(.5rem,.4rem + .35vw,.625rem);grid-gap:var(--space-xs);gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs)}.sg-token{align-items:center;display:flex;gap:clamp(.75rem,.6rem + .5vw,1rem);gap:var(--space-s)}.sg-token__preview{border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.25rem;border-radius:var(--radius-s);flex-shrink:0;height:2.5rem;width:2.5rem}.sg-type-sample{align-items:baseline;border-block-end:1px solid oklch(.88 .012 60);border-block-end:1px solid var(--border);display:flex;gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m);padding-block:clamp(.5rem,.4rem + .35vw,.625rem);padding-block:var(--space-xs)}.sg-type-sample:last-child{border-block-end:none}.sg-type-label{color:oklch(.55 .012 60);color:var(--text-muted);flex-shrink:0;font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);min-inline-size:9ch}.sg-spacing-bar{align-items:center;display:flex;gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m);padding-block:clamp(.25rem,.2rem + .2vw,.375rem);padding-block:var(--space-2xs)}.sg-spacing-bar__visual{background:oklch(.6135 .1974 36.29);background:var(--color-accent);border-radius:.25rem;border-radius:var(--radius-s);height:1.5rem;opacity:.3}.sg-spacing-bar__label{color:oklch(.55 .012 60);color:var(--text-muted);flex-shrink:0;font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);min-inline-size:11ch}.sg-radii{display:flex;flex-wrap:wrap;gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m)}.sg-radius-sample{align-items:center;display:flex;flex-direction:column;gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs)}.sg-radius-sample__box{background:oklch(.968 .006 60);background:var(--bg-secondary);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);height:4rem;width:4rem}.sg-icon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(6rem,1fr));grid-gap:clamp(1rem,.8rem + .75vw,1.5rem);grid-gap:var(--space-m);gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m)}.sg-icon-item{align-items:center;border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.5rem;border-radius:var(--radius-m);display:flex;flex-direction:column;gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs);padding:clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-m)}.sg-icon-item .icon{height:2rem;width:2rem}.sg-motion-demo{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);gap:var(--space-l)}.sg-motion-item{align-items:center;display:flex;flex-direction:column;gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs)}.sg-motion-box{background:oklch(.6135 .1974 36.29);background:var(--color-accent);border-radius:.5rem;border-radius:var(--radius-m);cursor:pointer;height:4rem;opacity:.5;width:4rem}@media (hover:hover){.sg-motion-box:hover{opacity:1;transform:translateY(-.5rem)}}.sg-dl{display:grid;grid-template-columns:max-content 1fr;grid-gap:clamp(.25rem,.2rem + .2vw,.375rem) clamp(1rem,.8rem + .75vw,1.5rem);grid-gap:var(--space-2xs) var(--space-m);align-items:baseline;gap:clamp(.25rem,.2rem + .2vw,.375rem) clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-2xs) var(--space-m)}.sg-dl dt{font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono)}.sg-dl dd,.sg-dl dt{font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm)}.sg-dl dd{color:oklch(.45 .012 60);color:var(--text-secondary);margin:0}[data-theme=dark] .phiki,[data-theme=dark] .phiki span{background-color:var(--phiki-dark-background-color)!important;color:var(--phiki-dark-color)!important;font-style:inherit!important;font-style:var(--phiki-dark-font-style,inherit)!important;font-weight:inherit!important;font-weight:var(--phiki-dark-font-weight,inherit)!important}}@layer components{@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .phiki,:root:not([data-theme=light]) .phiki span{background-color:var(--phiki-dark-background-color)!important;color:var(--phiki-dark-color)!important;font-style:inherit!important;font-style:var(--phiki-dark-font-style,inherit)!important;font-weight:inherit!important;font-weight:var(--phiki-dark-font-weight,inherit)!important}}pre.phiki{position:relative}pre.phiki code{font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono)}.code-block{background:oklch(.28 .008 60);background:var(--code-bg-light,var(--bg-code));border-radius:.5rem;border-radius:var(--radius-m);overflow:hidden;position:relative}@media (hover:hover){.code-block:hover .code-copy{opacity:1}}[data-theme=dark] .code-block{background:oklch(.28 .008 60);background:var(--code-bg-dark,var(--bg-code))}@media (prefers-color-scheme:dark){:root:not([data-theme=light]) .code-block{background:oklch(.28 .008 60);background:var(--code-bg-dark,var(--bg-code))}}.prose>.code-block{--_breakout:min(100vw - 2 * var(--gutter),60rem);margin-inline:calc((min(100vw - 2 * clamp(1rem, .8rem + .75vw, 1.5rem), 60rem) - 100%) / -2);margin-inline:calc((var(--_breakout) - 100%) / -2);width:min(100vw - 2 * clamp(1rem,.8rem + .75vw,1.5rem),60rem);width:var(--_breakout)}.code-copy{background:oklch(.968 .006 60);background:var(--bg-secondary);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.25rem;border-radius:var(--radius-s);color:oklch(.45 .012 60);color:var(--text-secondary);cursor:pointer;font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);opacity:0;padding:clamp(.25rem,.2rem + .2vw,.375rem) clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-2xs) var(--space-xs);position:absolute;right:clamp(.5rem,.4rem + .35vw,.625rem);right:var(--space-xs);top:clamp(.5rem,.4rem + .35vw,.625rem);top:var(--space-xs);transition:opacity .15s cubic-bezier(.22,1,.36,1);transition:opacity var(--duration-fast) var(--ease-out)}@media (hover:hover){.code-copy:hover{background:oklch(.95 .008 60);background:var(--bg-hover);color:oklch(.37 .01 60);color:var(--text-primary)}}@media (hover:none){.code-copy{opacity:1}}.code-copy:focus-visible{opacity:1}}@layer components{.highlight-group{margin-block-end:clamp(3rem,2.2rem + 2.8vw,4.5rem);margin-block-end:var(--space-2xl)}.highlight-group__header{align-items:center;border-block-end:1px solid oklch(.88 .012 60);border-block-end:1px solid var(--border);display:flex;gap:clamp(1rem,.8rem + .75vw,1.5rem);gap:var(--space-m);margin-block-end:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);margin-block-end:var(--space-l);padding-block-end:clamp(.75rem,.6rem + .5vw,1rem);padding-block-end:var(--space-s)}.highlight-group__cover{border-radius:.25rem;border-radius:var(--radius-s);flex-shrink:0;height:auto;-o-object-fit:cover;object-fit:cover;width:3rem}.highlight-group__info{min-width:0}.highlight-group__title{font-size:clamp(1.35rem,1.1rem + .85vw,1.7rem);font-size:var(--text-xl);line-height:1.2;line-height:var(--leading-tight);margin:0}.highlight-group__title a{color:inherit;-webkit-text-decoration:none;text-decoration:none}@media (hover:hover){.highlight-group__title a:hover{color:oklch(.6135 .1974 36.29);color:var(--link-hover)}}.highlight-group__author{color:oklch(.55 .012 60);color:var(--text-muted);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);margin:clamp(.25rem,.2rem + .2vw,.375rem) 0 0;margin:var(--space-2xs) 0 0}.highlight-list{-moz-columns:2;column-count:2;-moz-column-gap:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);column-gap:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);-moz-column-gap:var(--space-l);column-gap:var(--space-l);list-style:none;padding:0}@media (max-width:48rem){.highlight-list{-moz-columns:1;column-count:1}}.highlight-item{page-break-inside:avoid;-moz-column-break-inside:avoid;background:oklch(.993 .003 60);background:var(--bg-surface);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.75rem;border-radius:var(--radius-l);break-inside:avoid;margin-block-end:clamp(1.5rem,1.2rem + 1.2vw,2.25rem);margin-block-end:var(--space-l);padding:clamp(1rem,.8rem + .75vw,1.5rem);padding:var(--space-m)}.highlight-quote{border-inline-start:.25rem solid oklch(.6135 .1974 36.29);border-inline-start:.25rem solid var(--color-accent);margin:0;padding-inline-start:clamp(1rem,.8rem + .75vw,1.5rem);padding-inline-start:var(--space-m)}.highlight-quote p{color:oklch(.37 .01 60);color:var(--text-primary);font-family:Libre Baskerville,Georgia,Times New Roman,serif;font-family:var(--font-primary);font-size:clamp(1rem,.925rem + .35vw,1.125rem);font-size:var(--text-base);font-style:italic;line-height:1.75;line-height:var(--leading-relaxed);margin:0}.highlight-note{color:oklch(.45 .012 60);color:var(--text-secondary);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);font-style:italic;margin:0 0 clamp(.5rem,.4rem + .35vw,.625rem);margin:0 0 var(--space-xs);margin-inline-start:.25rem;padding-inline-start:clamp(1rem,.8rem + .75vw,1.5rem);padding-inline-start:var(--space-m)}.highlight-meta{align-items:center;border-block-start:1px solid oklch(.88 .012 60);border-block-start:1px solid var(--border);display:flex;flex-wrap:wrap;gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs);margin-block-start:clamp(.75rem,.6rem + .5vw,1rem);margin-block-start:var(--space-s);padding-block-start:clamp(.75rem,.6rem + .5vw,1rem);padding-block-start:var(--space-s)}.highlight-actions{display:flex;margin-inline-start:auto}.highlight-actions,.highlight-copy,.highlight-share{gap:clamp(.25rem,.2rem + .2vw,.375rem);gap:var(--space-2xs)}.highlight-copy,.highlight-share{align-items:center;background:oklch(.968 .006 60);background:var(--bg-secondary);border:1px solid oklch(.88 .012 60);border:1px solid var(--border);border-radius:.25rem;border-radius:var(--radius-s);color:oklch(.45 .012 60);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);padding:clamp(.25rem,.2rem + .2vw,.375rem) clamp(.5rem,.4rem + .35vw,.625rem);padding:var(--space-2xs) var(--space-xs);transition:color .15s cubic-bezier(.22,1,.36,1),background .15s cubic-bezier(.22,1,.36,1);transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}@media (hover:hover){.highlight-copy:hover,.highlight-share:hover{background:oklch(.95 .008 60);background:var(--bg-hover);color:oklch(.37 .01 60);color:var(--text-primary)}}.highlight-action-icon{height:.875em;width:.875em}.travel-layout{max-width:80rem;max-width:var(--max-width)}.gallery{display:grid;grid-auto-flow:dense;grid-auto-rows:8rem;grid-template-columns:repeat(2,1fr);grid-gap:clamp(.5rem,.4rem + .35vw,.625rem);grid-gap:var(--space-xs);gap:clamp(.5rem,.4rem + .35vw,.625rem);gap:var(--space-xs);margin-block-start:clamp(2rem,1.5rem + 1.8vw,3rem);margin-block-start:var(--space-xl)}.gallery--cols-3{grid-template-columns:repeat(3,1fr)}.gallery__item{border-radius:.5rem;border-radius:var(--radius-m);display:block;outline:none;overflow:hidden;-webkit-text-decoration:none;text-decoration:none}}@layer components{.gallery__item:focus-visible{outline:2px solid oklch(.6135 .1974 36.29);outline:2px solid var(--color-accent);outline-offset:2px}@media (hover:hover){.gallery__item:hover .gallery__img{transform:scale(1.03)}}.gallery__item--landscape{grid-row:span 2}.gallery__item--portrait{grid-row:span 3}.gallery__img{display:block;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s cubic-bezier(.22,1,.36,1);transition:transform var(--duration-normal) var(--ease-out);width:100%}@media (max-width:52rem){.gallery--cols-3{grid-template-columns:repeat(2,1fr)}}@media (max-width:32rem){.gallery{grid-template-columns:1fr}.gallery__item--landscape,.gallery__item--portrait{grid-row:span 1}.gallery__item{aspect-ratio:3/2}}.pswp-caption-content{display:none}.pswp__dynamic-caption{color:oklch(.88 .012 60);color:var(--color-sand-200);font-family:Aileron,system-ui,-apple-system,Segoe UI,sans-serif;font-family:var(--font-secondary);font-size:clamp(.8rem,.75rem + .25vw,.875rem);font-size:var(--text-sm);line-height:1.6;line-height:var(--leading-normal)}.pswp-caption__text{display:block}.pswp-caption__text+.pswp-caption__credit,.pswp-caption__text+.pswp-caption__exif{margin-block-start:clamp(.125rem,.1rem + .1vw,.25rem);margin-block-start:var(--space-3xs)}.pswp-caption__exif{color:oklch(.65 .014 60);color:var(--color-sand-400);display:block;font-family:Fira Code,ui-monospace,SF Mono,Cascadia Code,monospace;font-family:var(--font-mono);font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);letter-spacing:.02em;letter-spacing:var(--tracking-wide)}.pswp-caption__exif+.pswp-caption__credit{margin-block-start:clamp(.125rem,.1rem + .1vw,.25rem);margin-block-start:var(--space-3xs)}.pswp-caption__credit{color:oklch(.65 .014 60);color:var(--color-sand-400);display:block;font-size:clamp(.75rem,.7rem + .2vw,.8rem);font-size:var(--text-xs);font-style:italic}}@layer utilities{.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}.wide{max-width:85ch;max-width:var(--wide-width)}}
/*# sourceMappingURL=main.css.map */