.header__actions[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;gap:var(--space-3)}.header__github[data-astro-cid-3ef6ksr2]{display:inline-flex;align-items:center;color:var(--text-muted);transition:color .15s}.header__github[data-astro-cid-3ef6ksr2]:hover{color:var(--text)}.header__github[data-astro-cid-3ef6ksr2] svg[data-astro-cid-3ef6ksr2]{width:18px;height:18px}.top-actions[data-astro-cid-wzmmqmh6]{display:inline-flex;align-items:center;gap:8px}.top-actions__icon[data-astro-cid-wzmmqmh6]{display:none}html:not(.dark) .top-actions__icon--moon[data-astro-cid-wzmmqmh6]{display:block}html.dark .top-actions__icon--sun[data-astro-cid-wzmmqmh6]{display:block}.top-bar[data-astro-cid-z56keymw]{position:sticky;top:0;z-index:40;background:color-mix(in oklch,var(--bg) 80%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}.top-bar__inner[data-astro-cid-z56keymw]{max-width:64rem;margin:0 auto;padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between}.top-bar__brand[data-astro-cid-z56keymw]{font-size:14px;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.14em;text-decoration:none;transition:color .2s var(--ease)}.top-bar__brand[data-astro-cid-z56keymw]:hover{text-decoration:none;color:var(--accent)}.top-bar__desktop[data-astro-cid-z56keymw]{display:flex;align-items:center;gap:16px}.top-bar__nav[data-astro-cid-z56keymw]{display:flex;align-items:center;gap:4px}.top-bar__actions[data-astro-cid-z56keymw]{padding-left:12px;border-left:1px solid var(--line)}.top-bar__mobile-menu[data-astro-cid-z56keymw]{display:none;position:relative}.top-bar__mobile-toggle[data-astro-cid-z56keymw]{list-style:none;display:inline-grid;gap:4px;width:32px;height:32px;padding:8px 7px;border:1px solid var(--line);background:var(--card);cursor:pointer;transition:border-color .25s var(--ease),background .25s var(--ease)}.top-bar__mobile-toggle[data-astro-cid-z56keymw]::-webkit-details-marker{display:none}.top-bar__mobile-toggle-line[data-astro-cid-z56keymw]{display:block;width:100%;height:1px;background:var(--ink)}.top-bar__mobile-panel[data-astro-cid-z56keymw]{position:absolute;top:calc(100% + 10px);right:0;width:min(320px,calc(100vw - 32px));padding:10px;border:1px solid var(--line);background:color-mix(in oklch,var(--bg) 96%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.top-bar__mobile-nav[data-astro-cid-z56keymw]{display:flex;flex-direction:column}.top-bar__mobile-link[data-astro-cid-z56keymw]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 10px;border:1px solid transparent;color:var(--muted);font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.14em;text-decoration:none;transition:border-color .2s var(--ease),color .2s var(--ease),background .2s var(--ease)}.top-bar__mobile-link[data-astro-cid-z56keymw]:hover,.top-bar__mobile-link--active[data-astro-cid-z56keymw]{color:var(--ink);border-color:var(--line);text-decoration:none}.top-bar__mobile-link-meta[data-astro-cid-z56keymw]{display:inline-flex;align-items:center;gap:8px}.top-bar__mobile-link-idx[data-astro-cid-z56keymw]{font-family:var(--font-mono);font-size:10px;opacity:.6}.top-bar__mobile-actions[data-astro-cid-z56keymw]{margin-top:8px;padding-top:10px;border-top:1px solid var(--line)}.top-bar__mobile-actions[data-astro-cid-z56keymw] .top-actions{width:100%;justify-content:flex-end}.top-bar__mobile-menu[data-astro-cid-z56keymw][open] .top-bar__mobile-toggle[data-astro-cid-z56keymw]{border-color:var(--ink)}@media(max-width:760px){.top-bar__inner[data-astro-cid-z56keymw]{height:60px;padding:0 16px}.top-bar__brand[data-astro-cid-z56keymw]{font-size:12.5px;letter-spacing:.12em}.top-bar__desktop[data-astro-cid-z56keymw]{display:none}.top-bar__mobile-menu[data-astro-cid-z56keymw]{display:block}}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:-apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif;--font-mono:ui-monospace, "SF Mono", Menlo, monospace;--spacing:.25rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.static{position:static}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-wrap{flex-wrap:wrap}.border{border-style:var(--tw-border-style);border-width:1px}.text-wrap{text-wrap:wrap}.uppercase{text-transform:uppercase}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:oklch(98.5% .004 75);--ink:oklch(18% .008 60);--muted:oklch(52% .012 60);--line:oklch(88% .01 70);--card:oklch(100% .003 75);--accent-olive:oklch(52% .09 125);--accent:var(--accent-olive);--ease:cubic-bezier(.7, .1, .2, 1);--text:var(--ink);--text-muted:var(--muted);--border:var(--line);--surface:var(--card);--dropdown-bg:var(--card);--dropdown-text:var(--ink);--nav-1:var(--accent);--nav-2:var(--accent);--nav-3:var(--accent);--nav-4:var(--accent);--nav-5:var(--muted);--nav-text-1:var(--bg);--nav-text-2:var(--bg);--nav-text-3:var(--bg);--nav-text-4:var(--bg);--nav-text-5:var(--ink)}html.dark{--bg:oklch(15% .006 60);--ink:oklch(98% .005 75);--muted:oklch(66% .012 70);--line:oklch(28% .008 60);--card:oklch(19.5% .008 60);--accent:var(--accent-olive)}.header{padding:var(--space-5) var(--space-6);justify-content:space-between;align-items:center;display:flex}.header__name{font-size:var(--text-lg);color:var(--text);letter-spacing:-.02em;border:1px solid var(--border);padding:var(--space-2) var(--space-4);font-weight:600;text-decoration:none}.header__name:hover{color:var(--accent);text-decoration:none}@media(max-width:600px){.header{padding:var(--space-4) var(--space-4)}.header__name{font-size:var(--text-sm);padding:var(--space-1) var(--space-3)}}.header__mode-toggle{background:var(--surface);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:background .15s;display:flex;position:relative}.header__mode-toggle:hover{background:var(--border)}.header__mode-toggle:hover .header__mode-icon{color:var(--text)}.header__mode-icon{width:16px;height:16px;color:var(--text-muted)}.header__mode-icon--moon{display:block}.header__mode-icon--sun,[data-mode=light] .header__mode-icon--moon{display:none}[data-mode=light] .header__mode-icon--sun{display:block}.header__mode-tooltip{top:calc(100% + var(--space-2));font-family:var(--font-body);letter-spacing:.02em;color:var(--dropdown-text);background:var(--dropdown-bg);padding:var(--space-2) var(--space-3);white-space:nowrap;pointer-events:none;border-radius:4px;font-size:.7rem;font-weight:600;display:none;position:absolute;right:0;box-shadow:0 2px 8px #0003}.header__mode-tooltip--dark,.header__mode-tooltip--light{display:none}.header__mode-toggle:hover .header__mode-tooltip--dark{display:block}[data-mode=light] .header__mode-toggle:hover .header__mode-tooltip--dark{display:none}[data-mode=light] .header__mode-toggle:hover .header__mode-tooltip--light{display:block}.palette-nav{padding:var(--space-7) var(--space-5) var(--space-5);justify-content:center;display:flex}.palette-nav__wrapper{flex-direction:column;align-items:flex-start;display:flex;position:relative}.palette-nav__controls{gap:var(--space-2);margin-bottom:var(--space-2);display:flex}.palette-nav__mode-toggle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;padding:var(--space-1) var(--space-2);background:0 0;border:none;border-radius:4px;transition:background .15s,color .15s}.palette-nav__mode-toggle:hover{background:var(--dropdown-bg);color:var(--dropdown-text)}.palette-nav__theme-toggle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;padding:var(--space-1) var(--space-2);background:0 0;border:none;border-radius:4px;transition:background .15s,color .15s}.palette-nav__theme-toggle:hover,.palette-nav__theme-toggle[aria-expanded=true]{background:var(--dropdown-bg);color:var(--dropdown-text)}.palette-nav__dropdown{z-index:200;background:var(--dropdown-bg);border-radius:0 6px 6px;min-width:200px;position:absolute;top:100%;left:0;overflow:hidden;box-shadow:0 4px 16px #00000040}.palette-nav__dropdown[hidden]{display:none}.palette-nav__dropdown-item{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:var(--text-sm);color:var(--dropdown-text);cursor:pointer;text-align:left;background:0 0;border:none;transition:background .1s;display:flex}.palette-nav__dropdown-item:hover{background:#ffffff14}.palette-nav__dropdown-item[data-active=true]{background:#ffffff0f}.palette-nav__dropdown-swatches{gap:3px;display:flex}.palette-nav__dropdown-swatch{border-radius:2px;width:10px;height:10px;display:block}.palette-nav__dropdown-name{flex:1}.palette-nav__dropdown-check{text-align:center;width:16px}.palette-nav__dropdown-item[data-active=true] .palette-nav__dropdown-check:after{content:"✓"}.palette-nav__strip{border-radius:6px;display:flex;overflow:hidden;box-shadow:0 1px 4px #0000001a}.palette-nav__swatch{min-width:120px;padding:var(--space-4) var(--space-5);font-family:var(--font-body);letter-spacing:.06em;text-transform:uppercase;text-align:center;flex:1 1 0;font-size:11px;font-weight:600;text-decoration:none;transition:opacity .15s}.palette-nav__swatch:hover{opacity:.85;text-decoration:none}@media(max-width:720px){.palette-nav__wrapper{align-items:center}.palette-nav__dropdown{border-radius:6px;left:50%;transform:translate(-50%)}.palette-nav__strip{border-radius:6px;flex-direction:column}.palette-nav__swatch{min-width:unset;width:100%;padding:var(--space-3) var(--space-5)}}.footer{border-top:1px solid var(--border);padding:var(--space-6) var(--space-5);margin-top:var(--space-8);text-align:center}.footer__icons{justify-content:center;gap:var(--space-5);margin-bottom:var(--space-5);display:flex}.footer__icons a{color:var(--text-muted);opacity:.5;transition:opacity .15s,color .15s}.footer__icons a:hover{color:var(--text);opacity:1}.footer__icons svg{width:18px;height:18px}.footer__note{color:var(--text-muted);opacity:.4;margin-bottom:var(--space-1);font-size:.7rem;line-height:1.6}.footer__note:last-child{margin-bottom:0}.project-card{border:1px solid var(--border);padding:var(--space-6);color:var(--text);text-decoration:none;transition:border-color .15s;display:block}.project-card:hover{border-color:var(--accent);text-decoration:none}.project-card__title{font-size:var(--text-lg);font-weight:600}.breadcrumb-bar{background:var(--surface);padding:var(--space-3) var(--space-4);max-width:680px;margin:0 auto var(--space-5);font-size:var(--text-sm);border-radius:6px;justify-content:space-between;align-items:center;display:flex}.breadcrumb-bar__path{align-items:center;gap:var(--space-2);display:flex}.breadcrumb-bar__segment{font-weight:600;text-decoration:none}.breadcrumb-bar__segment--1{color:var(--nav-1)}.breadcrumb-bar__segment--2{color:var(--nav-2)}.breadcrumb-bar__segment--3{color:var(--nav-3)}a.breadcrumb-bar__segment:hover{text-decoration:underline}.breadcrumb-bar__sep{color:var(--nav-5)}.breadcrumb-wrapper{max-width:680px;margin:0 auto var(--space-5)}.breadcrumb-wrapper .breadcrumb-bar{border-radius:6px 6px 0 0;max-width:none;margin:0}.breadcrumb-tabs{background:var(--surface);border-top:1px solid var(--border);scrollbar-width:none;border-radius:0 0 6px 6px;gap:0;display:flex;overflow-x:auto}.breadcrumb-tabs::-webkit-scrollbar{display:none}.breadcrumb-tabs__tab{padding:var(--space-2) var(--space-4);color:var(--text-muted);white-space:nowrap;border-bottom:2px solid #0000;font-size:11px;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s}.breadcrumb-tabs__tab:hover{color:var(--text);text-decoration:none}.breadcrumb-tabs__tab--active{color:var(--accent);border-bottom-color:var(--accent)}.breadcrumb-wrapper .breadcrumb-bar__theme{top:var(--space-3);right:var(--space-4);position:absolute}.breadcrumb-wrapper{position:relative}@media(max-width:600px){.breadcrumb-bar{padding:var(--space-2) var(--space-3)}.breadcrumb-wrapper .breadcrumb-bar__theme{margin-bottom:var(--space-2);align-self:flex-end;position:static}.breadcrumb-tabs__tab{padding:var(--space-2) var(--space-3);font-size:10px}}.breadcrumb-bar__theme{align-items:center;gap:var(--space-2);display:flex;position:relative}.breadcrumb-bar__mode-toggle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;padding:var(--space-1) var(--space-2);background:0 0;border:none;border-radius:4px;transition:background .15s,color .15s}.breadcrumb-bar__mode-toggle:hover{background:var(--dropdown-bg);color:var(--dropdown-text)}.breadcrumb-bar__theme-toggle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;padding:var(--space-1) var(--space-2);background:0 0;border:none;border-radius:4px;transition:background .15s,color .15s}.breadcrumb-bar__theme-toggle:hover,.breadcrumb-bar__theme-toggle[aria-expanded=true]{background:var(--dropdown-bg);color:var(--dropdown-text)}.breadcrumb-bar__dropdown{z-index:200;background:var(--dropdown-bg);min-width:200px;margin-top:var(--space-1);border-radius:6px;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 16px #00000040}.breadcrumb-bar__dropdown[hidden]{display:none}.screenshot-grid{gap:var(--space-4);margin:var(--space-6) 0;grid-template-columns:1fr 1fr;display:grid}.screenshot-grid img{border:1px solid var(--border);aspect-ratio:16/10;object-fit:cover;cursor:pointer;border-radius:6px;width:100%;margin:0;transition:opacity .15s}.screenshot-grid img:hover{opacity:.9}.screenshot-grid p{color:var(--text-muted);margin:var(--space-2) 0 0;font-size:11px}@media(max-width:600px){.screenshot-grid{grid-template-columns:1fr}}.screenshot-strip{gap:var(--space-4);margin:var(--space-6) 0;flex-direction:column;display:flex}.screenshot-strip img{border:1px solid var(--border);object-fit:contain;background:var(--surface);cursor:pointer;border-radius:6px;width:100%;height:auto;margin:0;transition:opacity .15s}.screenshot-strip img:hover{opacity:.9}.ph{background:repeating-linear-gradient(135deg,var(--ink) 0 1px,transparent 1px 9px),var(--card)}@supports (color:color-mix(in lab,red,red)){.ph{background:repeating-linear-gradient(135deg,color-mix(in oklch,var(--ink) 6%,transparent) 0 1px,transparent 1px 9px),var(--card)}}.ph{border:1px solid var(--line);color:var(--muted)}.project-header{max-width:680px;padding:var(--space-8) var(--space-5) 0;margin:0 auto}.project-header__title{letter-spacing:-.02em}.project-header__subtitle{color:var(--text-muted);font-size:var(--text-lg);margin-top:var(--space-3)}.project-header__links{gap:var(--space-5);margin-top:var(--space-5);display:flex}.project-header__links a{font-size:var(--text-sm);color:var(--accent);font-weight:600}.project-header__rule{margin-top:var(--space-6)}.project-content{max-width:680px;padding:var(--space-4) var(--space-5) var(--space-8);margin:0 auto}.project-content h2{font-size:var(--text-xl);margin-top:var(--space-7);margin-bottom:var(--space-4)}.project-content h2:first-child{margin-top:0}.project-content p{margin-bottom:var(--space-5);line-height:1.7}.project-content img{border:1px solid var(--border);margin:var(--space-6) 0 var(--space-2);aspect-ratio:16/10;object-fit:cover;cursor:pointer;border-radius:6px;width:100%;transition:opacity .15s}.project-content>img:first-child{margin-top:0}.project-content img:hover{opacity:.9}.img-caption{margin:0;position:relative}.img-caption__text{color:var(--text-muted);opacity:.6;margin-top:var(--space-2);font-size:.7rem}.lightbox{z-index:1000;padding:var(--space-6);cursor:pointer;background:#000000d9;justify-content:center;align-items:center;animation:.15s lightbox-in;display:flex;position:fixed;inset:0}@keyframes lightbox-in{0%{opacity:0}to{opacity:1}}.project-prevnext{max-width:680px;padding:0 var(--space-5);border-top:1px solid var(--border);padding-top:var(--space-5);justify-content:space-between;margin:0 auto;display:flex}.project-prevnext__link{font-size:var(--text-lg);color:var(--text-muted);text-decoration:none}.project-prevnext__link:hover{color:var(--text);text-decoration:none}.project-prevnext__link--label{font-size:var(--text-sm)}.project-siblings{max-width:680px;padding:0 var(--space-5) var(--space-8);border-top:1px solid var(--border);padding-top:var(--space-6);margin:0 auto}.project-siblings__label{color:var(--border);font-size:var(--text-sm);margin-bottom:var(--space-2)}.project-siblings__listing{line-height:2.2}.project-siblings__row{white-space:nowrap}.project-siblings__chevron{color:var(--accent);margin-right:var(--space-2)}.project-siblings__link{font-weight:600;font-size:var(--text-sm);border-bottom:1px dashed #fff3;text-decoration:none}.project-siblings__link:hover{border-bottom-style:solid;border-bottom-color:currentColor;text-decoration:none}.project-siblings__link--1{color:var(--nav-1)}.project-siblings__link--2{color:var(--nav-2)}.project-siblings__link--3{color:var(--nav-3)}.project-siblings__link--4{color:var(--nav-4)}.project-siblings__link--5{color:var(--accent)}.project-siblings__pages{gap:var(--space-5);padding-top:var(--space-4);margin-top:var(--space-4);border-top:1px solid var(--border);display:flex}.project-siblings__page-link{font-size:var(--text-sm);color:var(--text-muted);text-decoration:none}.project-siblings__page-link:hover{color:var(--text);text-decoration:none}.lightbox img{border:1px solid var(--border);object-fit:contain;aspect-ratio:auto;cursor:default;border-radius:6px;width:auto;max-width:90vw;max-height:90vh;margin:0}@font-face{font-family:Google Sans Code;src:url(/fonts/google-sans-code-400.woff2)format("woff2");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Google Sans Code;src:url(/fonts/google-sans-code-600.woff2)format("woff2");font-weight:600;font-style:normal;font-display:swap}:root{--font-body:"Google Sans Code", "SF Mono", "Fira Code", monospace;--text-sm:.875rem;--text-base:1rem;--text-lg:1.25rem;--text-xl:1.5rem;--text-2xl:2rem;--text-3xl:2.5rem;--line-height:1.6;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:100%;overflow-x:hidden}body{font-family:var(--font-sans);font-feature-settings:"ss01";color:var(--ink);background:var(--bg);text-wrap:pretty;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .3s var(--ease),color .3s var(--ease);font-size:15px;line-height:1.65}img{max-width:100%;height:auto;display:block}a{color:var(--accent);text-decoration:none}a:visited,a:active{color:var(--accent)}a:hover{color:var(--accent);text-decoration:underline}h1,h2,h3,h4{color:var(--ink);text-wrap:balance;font-weight:600;line-height:1.2}h1{letter-spacing:.01em;text-transform:uppercase;font-size:40px}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}hr{border:none;border-top:1px solid var(--line);margin:var(--space-6) 0}.project-content p,.about__text{text-align:justify}.sera-label{text-transform:uppercase;letter-spacing:.14em;font-size:10.5px;font-weight:600}.paper:before{content:"";mix-blend-mode:multiply;pointer-events:none;opacity:.35;z-index:1;background-image:radial-gradient(#00000006 1px,#0000 1px);background-size:3px 3px;position:fixed;inset:0}html.dark .paper:before{mix-blend-mode:screen;opacity:.08}::selection{background:var(--accent)}@supports (color:color-mix(in lab,red,red)){::selection{background:color-mix(in oklch,var(--accent) 30%,transparent)}}::selection{color:var(--ink)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.site{z-index:2;flex-direction:column;min-height:100vh;display:flex;position:relative}.site>main{flex:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
