@import"https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800;900&family=IBM+Plex+Mono:wght@400;500&display=swap";:root{--ink: oklch(.2 .012 255);--ink-soft: oklch(.46 .012 255);--ink-faint: oklch(.68 .01 255);--paper: oklch(.985 .004 250);--paper-2: oklch(.955 .006 250);--line: oklch(.88 .008 250);--blue: oklch(.5 .19 254);--dot: oklch(.82 .13 200);--ratio: 16 / 9;--sans: "Archivo", "Helvetica Neue", Helvetica, Arial, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace;--pad: clamp(1.25rem, 4vw, 3.5rem);--max: 1480px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:Archivo,Helvetica Neue,Helvetica,Arial,sans-serif;font-family:var(--sans);background:#f8fafd;background:var(--paper);color:#12161b;color:var(--ink);line-height:1.2;overflow-x:hidden}a{color:inherit;text-decoration:none}.wrap{max-width:1480px;max-width:var(--max);margin:0 auto;padding-inline:clamp(1.25rem,4vw,3.5rem);padding-inline:var(--pad)}.mono{font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.dot{color:#34dde5;color:var(--dot)}.dock{position:fixed;top:0;left:0;right:0;z-index:50;background:color-mix(in oklab,oklch(.985 .004 250) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid oklch(.88 .008 250);border-bottom:1px solid var(--line);transform:translateY(-101%);transition:transform .35s cubic-bezier(.4,0,.2,1)}@supports (color: color-mix(in lch,red,blue)){.dock{background:color-mix(in oklab,var(--paper) 88%,transparent)}}.dock.show{transform:translateY(0)}.dock .row{display:flex;justify-content:space-between;align-items:center;padding-block:.85rem}.dock .wm{font-weight:700;letter-spacing:-.01em;font-size:1.05rem}.dock a.contact{transition:color .2s}.dock a.contact:hover{color:oklch(.5 .19 254);color:var(--blue)}.hero{background:oklch(.5 .19 254);background:var(--blue);color:#f8fafd;color:var(--paper);min-height:92vh;display:flex;flex-direction:column}.hero-bar{display:flex;justify-content:space-between;align-items:center;padding-block:1.4rem;border-bottom:1px solid color-mix(in oklab,oklch(.985 .004 250) 22%,transparent)}@supports (color: color-mix(in lch,red,blue)){.hero-bar{border-bottom:1px solid color-mix(in oklab,var(--paper) 22%,transparent)}}.hero-bar .brand{font-weight:500}.hero-bar a:hover{opacity:.65}.hero-spacer{flex:1 1 auto;min-height:2rem}.hero-body{padding-bottom:clamp(2.5rem,6vw,4.5rem)}.hero-body h1{font-weight:900;font-size:clamp(5.5rem,26vw,19rem);line-height:.8;letter-spacing:-.05em;text-transform:uppercase}.hero-body h1 .ln{display:block;overflow:hidden}.hero-body h1 .ln>span{display:inline-block}.hero-meta{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;margin-top:clamp(2rem,4vw,3.25rem);padding-top:1.25rem;border-top:1px solid color-mix(in oklab,oklch(.985 .004 250) 35%,transparent);flex-wrap:wrap}@supports (color: color-mix(in lch,red,blue)){.hero-meta{border-top:1px solid color-mix(in oklab,var(--paper) 35%,transparent)}}.hero-meta .lead{font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:clamp(.85rem,1.1vw,1rem);line-height:1.5;text-transform:none;max-width:44ch;color:color-mix(in oklab,oklch(.985 .004 250) 90%,transparent)}@supports (color: color-mix(in lch,red,blue)){.hero-meta .lead{color:color-mix(in oklab,var(--paper) 90%,transparent)}}.hero-meta .tag{color:color-mix(in oklab,oklch(.985 .004 250) 78%,transparent)}@supports (color: color-mix(in lch,red,blue)){.hero-meta .tag{color:color-mix(in oklab,var(--paper) 78%,transparent)}}@media(prefers-reduced-motion:no-preference){.hero-body h1 .ln>span{transform:translateY(105%);transition:transform .9s cubic-bezier(.16,1,.3,1)}body.ready .hero-body h1 .ln>span{transform:translateY(0)}.hero-body h1 .ln:nth-child(2)>span{transition-delay:.08s}.hero-meta,.hero-bar{opacity:0;transition:opacity .8s ease .4s}body.ready .hero-meta,body.ready .hero-bar{opacity:1}}.work{padding-top:clamp(2.75rem,6vw,5rem);padding-bottom:clamp(4rem,10vw,8rem)}.work-head{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:.9rem;border-bottom:1px solid oklch(.2 .012 255);border-bottom:1px solid var(--ink);margin-bottom:clamp(1.75rem,4vw,3rem)}.work-head .mono{color:#54585f;color:var(--ink-soft)}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,400px),1fr));grid-gap:clamp(2rem,4vw,3.25rem) clamp(1.5rem,3vw,2.5rem);gap:clamp(2rem,4vw,3.25rem) clamp(1.5rem,3vw,2.5rem)}.project{display:block}.thumb{position:relative;aspect-ratio:16 / 9;aspect-ratio:var(--ratio);background-color:#edf0f4;background-color:var(--paper-2);background-image:repeating-linear-gradient(45deg,oklch(.9 .006 250) 0 1px,transparent 1px 13px);border:1px solid oklch(.88 .008 250);border:1px solid var(--line);overflow:hidden;transition:border-color .25s ease}.thumb .idx{position:absolute;top:.85rem;left:.95rem;font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.8rem;color:#94999e;color:var(--ink-faint);transition:color .25s}.thumb .cap{position:absolute;inset:0;display:grid;place-items:center;font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.72rem;color:#94999e;color:var(--ink-faint);letter-spacing:.06em}.thumb .go{position:absolute;bottom:.85rem;right:.95rem;font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.85rem;color:oklch(.5 .19 254);color:var(--blue);opacity:0;transform:translate(-4px,4px);transition:opacity .25s ease,transform .25s ease}.project-info{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-top:1.05rem}.project-title{font-size:clamp(1.5rem,2.4vw,2.15rem);font-weight:700;letter-spacing:-.02em;transition:color .2s}.project-cat{font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:#54585f;color:var(--ink-soft);margin-top:.5rem}.project-year{font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.8rem;color:#94999e;color:var(--ink-faint);flex-shrink:0}@media(hover:hover){.project:hover .thumb{border-color:oklch(.5 .19 254);border-color:var(--blue)}.project:hover .thumb .idx{color:oklch(.5 .19 254);color:var(--blue)}.project:hover .thumb .go{opacity:1;transform:translate(0)}.project:hover .project-title{color:oklch(.5 .19 254);color:var(--blue)}}.page{padding-top:clamp(6rem,12vw,9rem);padding-bottom:clamp(4rem,10vw,8rem);max-width:68ch}.page-head{padding-bottom:.9rem;border-bottom:1px solid oklch(.2 .012 255);border-bottom:1px solid var(--ink);margin-bottom:clamp(1.75rem,4vw,3rem);display:flex;justify-content:space-between;align-items:baseline}.page h1{font-weight:900;font-size:clamp(2.5rem,6vw,4.5rem);line-height:.9;letter-spacing:-.03em;text-transform:uppercase}.page .prose{font-size:1.05rem;line-height:1.55;color:#54585f;color:var(--ink-soft)}.page .prose p{margin-block:1em}.page .prose p:first-child{margin-top:0}.page .prose a{color:oklch(.5 .19 254);color:var(--blue);border-bottom:1px solid oklch(.88 .008 250);border-bottom:1px solid var(--line);transition:border-color .2s}.page .prose a:hover{border-color:oklch(.5 .19 254);border-color:var(--blue)}.page .prose h2{color:#12161b;color:var(--ink);font-size:1.4rem;font-weight:700;margin-top:2.5em;letter-spacing:-.01em}.project-detail{padding-top:clamp(6rem,12vw,9rem);padding-bottom:clamp(4rem,10vw,8rem)}.project-head{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:.9rem;border-bottom:1px solid oklch(.2 .012 255);border-bottom:1px solid var(--ink);margin-bottom:clamp(2.5rem,6vw,4.5rem);color:#54585f;color:var(--ink-soft)}.project-head .back{transition:color .2s}.project-head .back:hover{color:oklch(.5 .19 254);color:var(--blue)}.project-intro{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);grid-gap:clamp(1.5rem,4vw,3.5rem);gap:clamp(1.5rem,4vw,3.5rem);align-items:end;margin-bottom:clamp(2.5rem,6vw,4rem)}.project-detail-title{font-weight:900;font-size:clamp(3rem,9vw,7rem);line-height:.9;letter-spacing:-.03em;text-transform:uppercase;max-width:14ch}.project-detail-lead{font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:clamp(.95rem,1.1vw,1.05rem);line-height:1.55;color:#54585f;color:var(--ink-soft);max-width:48ch;padding-bottom:.4rem}@media(max-width:780px){.project-intro{grid-template-columns:1fr;align-items:start}.project-detail-lead{padding-bottom:0}}.project-cover{aspect-ratio:16 / 9;aspect-ratio:var(--ratio);background-color:#edf0f4;background-color:var(--paper-2);border:1px solid oklch(.88 .008 250);border:1px solid var(--line);overflow:hidden}.project-cover img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.project-cover--placeholder{background-image:repeating-linear-gradient(45deg,oklch(.9 .006 250) 0 1px,transparent 1px 13px)}.project-prose{font-size:1.05rem;line-height:1.6;color:#54585f;color:var(--ink-soft);max-width:68ch;margin-top:clamp(2.5rem,5vw,4rem)}.project-prose p{margin-block:1em}.project-prose p:first-child{margin-top:0}.project-prose a{color:oklch(.5 .19 254);color:var(--blue);border-bottom:1px solid oklch(.88 .008 250);border-bottom:1px solid var(--line);transition:border-color .2s}.project-prose a:hover{border-color:oklch(.5 .19 254);border-color:var(--blue)}.project-prose h2{color:#12161b;color:var(--ink);font-size:clamp(1.5rem,2.2vw,1.75rem);font-weight:700;margin-top:3em;margin-bottom:.6em;letter-spacing:-.015em;line-height:1.15}.project-prose h3{color:#12161b;color:var(--ink);font-size:1.25rem;font-weight:700;margin-top:2.5em;margin-bottom:.4em;letter-spacing:-.01em;line-height:1.2}.project-prose>p:first-child{font-size:1.15rem;line-height:1.55;color:#12161b;color:var(--ink);margin-bottom:1.5em}.project-prose ul,.project-prose ol{margin-block:1em;padding-left:1.4em}.project-prose li{margin-block:.35em}.project-prose blockquote{margin-block:1.5em;padding-left:1.25rem;border-left:2px solid oklch(.88 .008 250);border-left:2px solid var(--line);color:#12161b;color:var(--ink);font-style:italic}.project-prose code{font-family:IBM Plex Mono,ui-monospace,monospace;font-family:var(--mono);font-size:.9em;background:#edf0f4;background:var(--paper-2);padding:.1em .35em;border-radius:3px}.project-prose img{max-width:100%;height:auto;border:1px solid oklch(.88 .008 250);border:1px solid var(--line);margin-block:2em}.project-links{list-style:none;display:flex;flex-wrap:wrap;gap:1.5rem 2rem;margin-top:clamp(2.5rem,5vw,4rem);padding-top:1.25rem;border-top:1px solid oklch(.88 .008 250);border-top:1px solid var(--line)}.project-links a{transition:color .2s}.project-links a:hover{color:oklch(.5 .19 254);color:var(--blue)}.project-nav{display:flex;justify-content:space-between;gap:2rem;margin-top:clamp(4rem,8vw,6rem);padding-top:1.25rem;border-top:1px solid oklch(.2 .012 255);border-top:1px solid var(--ink)}.project-nav>div{flex:1 1;min-width:0}.project-nav .next{text-align:right}.project-nav a{display:inline-block;transition:color .2s}.project-nav a:hover{color:oklch(.5 .19 254);color:var(--blue)}.project-nav .label{display:block;color:#94999e;color:var(--ink-faint);margin-bottom:.4rem}.project-nav .name{display:block;font-size:clamp(1.1rem,1.6vw,1.35rem);font-weight:700;letter-spacing:-.01em}@media(max-width:600px){.project-head{flex-wrap:wrap;gap:.5rem}.project-nav{flex-direction:column;gap:1.5rem}.project-nav .next{text-align:left}.project-nav>div+div{padding-top:1.5rem;border-top:1px solid oklch(.88 .008 250);border-top:1px solid var(--line)}}.footer{border-top:1px solid oklch(.2 .012 255);border-top:1px solid var(--ink);padding-top:clamp(2.5rem,5vw,4rem);padding-bottom:clamp(2rem,5vw,3.5rem)}.footer-top{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap}.footer .wm{font-weight:900;font-size:clamp(2.5rem,6vw,4.5rem);line-height:.85;letter-spacing:-.04em;text-transform:uppercase}.footer .links{display:flex;flex-direction:column;gap:.55rem;text-align:right}.footer .links a{transition:color .2s}.footer .links a:hover{color:oklch(.5 .19 254);color:var(--blue)}.footer .colophon{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:clamp(2.5rem,5vw,4rem);padding-top:1.25rem;border-top:1px solid oklch(.88 .008 250);border-top:1px solid var(--line)}.footer .colophon .mono{color:#94999e;color:var(--ink-faint)}@media(max-width:600px){.footer .links{text-align:left}}pre.highlight{padding:16px;background-color:#f6f8fa}.highlight .hll{background-color:#ffc}.highlight .c{color:#998;font-style:italic}.highlight .err{color:#a61717;background-color:#e3d2d2}.highlight .k,.highlight .o{color:#000;font-weight:700}.highlight .cm{color:#998;font-style:italic}.highlight .cp{color:#999;font-weight:700;font-style:italic}.highlight .c1{color:#998;font-style:italic}.highlight .cs{color:#999;font-weight:700;font-style:italic}.highlight .gd{color:#000;background-color:#fdd}.highlight .ge{color:#000;font-style:italic}.highlight .gr{color:#a00}.highlight .gh{color:#999}.highlight .gi{color:#000;background-color:#dfd}.highlight .go{color:#888}.highlight .gp{color:#555}.highlight .gs{font-weight:700}.highlight .gu{color:#aaa}.highlight .gt{color:#a00}.highlight .kc,.highlight .kd,.highlight .kn,.highlight .kp,.highlight .kr{color:#000;font-weight:700}.highlight .kt{color:#458;font-weight:700}.highlight .m{color:#099}.highlight .s{color:#d01040}.highlight .na{color:teal}.highlight .nb{color:#0086b3}.highlight .nc{color:#458;font-weight:700}.highlight .no{color:teal}.highlight .nd{color:#3c5d5d;font-weight:700}.highlight .ni{color:purple}.highlight .ne,.highlight .nf,.highlight .nl{color:#900;font-weight:700}.highlight .nn{color:#555}.highlight .nt{color:navy}.highlight .nv{color:teal}.highlight .ow{color:#000;font-weight:700}.highlight .w{color:#bbb}.highlight .mf,.highlight .mh,.highlight .mi,.highlight .mo{color:#099}.highlight .sb,.highlight .sc,.highlight .sd,.highlight .s2,.highlight .se,.highlight .sh,.highlight .si,.highlight .sx{color:#d01040}.highlight .sr{color:#009926}.highlight .s1{color:#d01040}.highlight .ss{color:#990073}.highlight .bp{color:#999}.highlight .vc,.highlight .vg,.highlight .vi{color:teal}.highlight .il{color:#099}
/*# sourceMappingURL=/_bridgetown/static/index.CUVHS2BU.css.map */
