@font-face{font-family:JetBrains Mono;src:url("../media/JetBrains Mono-400.ec718a33.woff2")format("woff2");font-weight:400}@font-face{font-family:Helvetica;src:url(../media/Helvetica-300.f7999635.woff2)format("woff2");font-weight:300}@font-face{font-family:Helvetica;src:url(../media/Helvetica-300i.d4df1414.woff2)format("woff2");font-style:italic;font-weight:300}@font-face{font-family:Helvetica;src:url(../media/Helvetica-400.1cbf7acb.woff2)format("woff2");font-weight:400}@font-face{font-family:Helvetica;src:url(../media/Helvetica-400i.d88ffb30.woff2)format("woff2");font-style:italic;font-weight:400}@font-face{font-family:Helvetica;src:url(../media/Helvetica-700.4e0e19a9.woff2)format("woff2");font-weight:700}@font-face{font-family:Helvetica;src:url(../media/Helvetica-700i.c0b33a2b.woff2)format("woff2");font-style:italic;font-weight:700}@font-face{font-family:Mulish;font-style:normal;font-weight:200 1000;font-display:swap;src:url(../media/Mulish.9e0e5e41.woff2)}
html{-moz-text-size-adjust:100%;text-size-adjust:100%;line-height:1.15}body{margin:0}main{display:block}h1{font-size:2em}ul{margin:0;padding:0;list-style:none}h1,h2,h3,h4,h5,h6{margin:0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-size:1em}a{background-color:#0000;text-decoration:none}abbr[title]{border-bottom:none;text-decoration:underline}b,strong{font-weight:bolder}code,kbd,samp{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}figure{margin:0}img{border-style:none}button,input,optgroup,select,textarea{margin:0;padding:0;font-family:inherit;font-size:100%;line-height:1.15}button,input{overflow:visible}button,select{text-transform:none}button,[type=button],[type=reset],[type=submit]{appearance:button}button::-moz-focus-inner{border-style:none;padding:0}[type=button]::-moz-focus-inner{border-style:none;padding:0}[type=reset]::-moz-focus-inner{border-style:none;padding:0}[type=submit]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring{outline:1px dotted buttontext}[type=button]:-moz-focusring{outline:1px dotted buttontext}[type=reset]:-moz-focusring{outline:1px dotted buttontext}[type=submit]:-moz-focusring{outline:1px dotted buttontext}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;white-space:normal;max-width:100%;padding:0;display:table}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button{height:auto}[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{appearance:none}::-webkit-file-upload-button{appearance:button;font:inherit}details{display:block}summary{display:list-item}template,[hidden]{display:none}p{margin:0 0 1em}p:last-child{margin-bottom:0}button{background-color:#0000;border-width:0}
.shiki{box-sizing:border-box;width:100%;display:inline-block}.html--dark .shiki,.html--dark .shiki span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;-webkit-text-decoration:var(--shiki-dark-text-decoration)!important;text-decoration:var(--shiki-dark-text-decoration)!important}
.mapboxgl-marker:has(.map__marker--active){z-index:1}.mapboxgl-marker:hover{z-index:2}
.html{background-color:var(--c-gray-lightest);--c-white:#fff;--c-gray-lightest:#fafafa;--c-gray-lighter:#f0f0f0;--c-gray-light:#d2d2d2;--c-gray:#656565;--c-gray-dark:#2d2d2d;--c-gray-darker:#1f1f1f;--c-gray-darkest:#111;--c-black:#000;--c-main:#09f;--c-main-light:#6bf;--c-main-dark:#069;transition:background-color .25s}.html--dark{--c-white:#000;--c-gray-lightest:#111;--c-gray-lighter:#1f1f1f;--c-gray-light:#2d2d2d;--c-gray:#9a9a9a;--c-gray-dark:#d2d2d2;--c-gray-darker:#f0f0f0;--c-gray-darkest:#fafafa;--c-black:#fff}.html:has(.top-nav__button--dark:hover){background-color:var(--c-gray-lighter)}.html:has(.body--fixed){overflow:hidden}.html:has(.article){scrollbar-gutter:stable}
.body{color:var(--c-black);--spacing:10px;font-family:Helvetica,sans-serif;container:meta-container teaser-container/inline-size}@media screen and (min-width:768px){.body{--spacing:25px}}@media screen and (min-width:1200px){.body{--spacing:50px}}.body--fixed{overflow:hidden}
.home{flex-direction:column-reverse;justify-content:flex-end;max-width:768px;min-height:100svh;display:flex}@media screen and (min-width:768px){.home{width:100%}}@media screen and (min-width:1200px){.home{flex-direction:row;justify-content:flex-start;width:auto;max-width:2558px;margin-left:auto}}.home__image-container{box-sizing:border-box;width:100%;margin:0 auto 50px;position:relative}@media screen and (min-width:620px){.home__image-container{margin-bottom:-30px}}@media screen and (min-width:768px){.home__image-container{padding:var(--spacing)var(--spacing)50px;margin:0}}@media screen and (min-width:1200px){.home__image-container{width:calc(100% - 600px);max-width:none;height:100svh;padding:0}}@media screen and (min-width:1680px){.home__image-container{width:calc(100% - 1037.5px)}}.home__image{aspect-ratio:4/3;height:100%;margin-left:auto}@media screen and (min-width:620px){.home__image{width:65vw}}@media screen and (min-width:768px){.home__image{width:auto}}@media screen and (min-width:1200px){.home__image{aspect-ratio:unset}}.home__content{box-sizing:border-box;width:100%;padding:0 var(--spacing)100px;z-index:2;flex-direction:column;justify-content:space-between;align-items:stretch;margin:0 auto;display:flex;position:relative}@media screen and (min-width:1200px){.home__content{padding:var(--spacing);width:600px;min-height:100vh}}@media screen and (min-width:1680px){.home__content{grid-template-columns:repeat(4,minmax(0,1fr));width:1037.5px}}.home__title{border-bottom:1px solid var(--c-gray-darkest);border-bottom:1px solid var(--c-gray-darkest);width:100%;padding-bottom:25px;font-size:40px;font-weight:300;line-height:1.25}@media screen and (min-width:768px){.home__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.home__title{font-size:73px;line-height:84px}}@media screen and (min-width:768px){.home__title{padding-bottom:50px}}.home__text-container{width:100%;max-width:500px;padding-top:50px}@media screen and (min-width:1200px){.home__text-container{border-top:1px solid var(--c-gray-darkest);max-width:none}}.home__text{color:var(--c-gray-darkest);-webkit-hyphens:auto;hyphens:auto;align-items:flex-end;max-width:725px;font-size:20px;font-weight:300;line-height:28px;display:flex}@media screen and (min-width:1680px){.home__text{font-size:25px;line-height:35px}}@media screen and (min-width:1200px){.home__text{width:auto}}@media screen and (min-width:1905px){.home__text{width:auto;margin-left:362.5px}}
.article{flex-direction:column;display:flex}@media screen and (min-width:1200px){.article{display:block}}.article__customize{padding-left:var(--spacing);z-index:1;padding-bottom:25px}@media screen and (min-width:1200px){.article__customize{top:var(--spacing);padding-bottom:0;position:absolute}}@media screen and (min-width:1905px){.article__customize{padding-left:493.75px}}.article:has(.article__image) .article__customize{top:calc(62.5vw + var(--spacing)*2)}@media screen and (min-width:768px){.article:has(.article__image) .article__customize{top:calc(50vh + var(--spacing)*2)}}@media screen and (min-width:1200px){.article:has(.article__image) .article__customize{top:max(425px,30vw - 87.5px);translate:0 -100%}}@media screen and (min-width:1905px){.article:has(.article__image) .article__customize{padding-left:50px}}.article__header{padding:125px var(--spacing)0;flex-direction:column;justify-content:space-between;display:contents;position:relative}@media screen and (min-width:1200px){.article__header{display:flex}}.article:has(.article__image) .article__header{padding-top:calc(62.5vw + 50px + var(--spacing)*3)}@media screen and (min-width:768px){.article:has(.article__image) .article__header{padding-top:calc(50vh + 50px + var(--spacing)*3)}}@media screen and (min-width:1200px){.article:has(.article__image) .article__header{padding-top:max(450px,30vw - 62.5px)}}.article__tags{max-width:812.5px;padding-top:25px;padding-left:var(--spacing);flex-wrap:wrap;justify-content:flex-start;gap:6.25px 12.5px;display:flex;position:relative}@media screen and (min-width:1200px){.article__tags{padding-top:37.5px;padding-left:0}}@media screen and (min-width:1905px){.article__tags{width:1280.25px;padding-left:443.75px}}.article__tags:before{content:"";background-color:var(--c-gray-darkest);height:1px;width:calc(100% - var(--spacing)*2);position:absolute;top:0}@media screen and (min-width:768px){.article__tags:before{max-width:768px;width:calc(100% - var(--spacing)*2)}}@media screen and (min-width:1200px){.article__tags:before{width:calc(50vw - 115px);max-width:none}}@media screen and (min-width:1905px){.article__tags:before{width:837.5px}.article:has(.article__image) .article__tags{padding-left:0}}.article__tag{color:var(--c-main);font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.article__tag{font-size:18px;line-height:30px}}.article__title{border-bottom:1px solid var(--c-gray-darkest);width:100%;color:var(--c-black);padding-bottom:25px;padding:12.5px var(--spacing)12.5px;text-wrap:balance;box-sizing:border-box;border-bottom-width:0;width:100%;scroll-margin-top:50px;font-size:40px;font-weight:300;line-height:1.25;position:relative}@media screen and (min-width:768px){.article__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.article__title{font-size:73px;line-height:84px}}@media screen and (min-width:768px){.article__title{max-width:calc(100vw - 100px);font-size:50px;line-height:1.25}}@media screen and (min-width:1024px){.article__title{font-size:62px;line-height:71px}}@media screen and (min-width:1200px){.article__title{box-sizing:content-box;padding:12.5px 0}}@media screen and (min-width:1680px){.article__title{font-size:73px;line-height:84px}}@media screen and (min-width:1905px){.article__title{width:1280.25px;padding-left:443.75px}.article:has(.article__image) .article__title{padding-left:0}}.article__date{color:#9a9a9a;padding:0 0 var(--spacing)var(--spacing);font-size:16px;font-style:italic;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.article__date{padding-left:0;font-size:18px;line-height:30px}}@media screen and (min-width:1905px){.article__date{width:1280.25px;padding-left:443.75px}.article:has(.article__image) .article__date{padding-left:0}}.article__meta{border-bottom:1px solid var(--c-black);justify-content:center;padding-bottom:50px;display:flex}.article__meta:has(+.article__content-container){padding-bottom:0}.article__image{height:62.5vw;margin-left:var(--spacing);width:calc(100% - var(--spacing)*2);padding-top:var(--spacing);order:-1;top:0;right:0}@media screen and (min-width:768px){.article__image{height:56.25vw}}@media screen and (min-width:1200px){.article__image{width:calc(100vw - 1017.5px);min-width:calc(50vw - 65px);height:30vw;min-height:500px;max-height:100%;padding-top:0;position:absolute}}.article__content-container{padding:50px var(--spacing);width:100%;max-width:calc(100vw - var(--spacing)*2);grid-template-columns:repeat(3,minmax(0,1fr));align-items:flex-start;position:static}@media screen and (min-width:768px){.article__content-container{padding:var(--spacing)var(--spacing)calc(var(--spacing)/2)var(--spacing);max-width:calc(100vw - 80px - var(--spacing)*2);min-height:100vh}}@media screen and (min-width:1024px){.article__content-container{grid-gap:var(--spacing);display:grid}}@media screen and (min-width:1680px){.article__content-container{grid-template-columns:repeat(4,minmax(0,1fr))}}@media screen and (min-width:1905px){.article__content-container{max-width:1725px}.article__content-container:before{content:"";display:block}}.article__sidebar{border-left:1px solid var(--c-gray-darkest);flex-shrink:0;grid-area:auto/span 1;height:100%;display:none;position:relative}@media screen and (min-width:1200px){.article__sidebar{display:block}}.article__sidebar-content{position:sticky;top:50px}.article__content{flex-direction:column;grid-area:auto/span 4;gap:25px;width:100%;max-width:768px;display:flex}@media screen and (min-width:1024px){.article__content{grid-area:auto/span 3;gap:50px}}@media screen and (min-width:1200px){.article__content{grid-area:auto/span 2;max-width:none;padding-bottom:50px}}.article__footer{border-top:1px solid var(--c-gray-darkest);justify-content:space-between;width:100%;padding-top:25px;padding-bottom:50px;display:flex}@media screen and (min-width:768px){.article__footer{margin-top:50px}}@media screen and (min-width:1200px){.article__footer{padding-bottom:0}}.article__footer:has(>.article__footer-link--next:only-child){justify-content:flex-end}
.article-nav{padding-left:50px}.article-nav__title{letter-spacing:.05em;text-transform:uppercase;color:var(--c-black);padding-bottom:25px;font-size:16px;display:block}.article-nav__list{margin-left:-8px}.article-nav__link{color:var(--c-gray);padding:6px 8px;font-size:16px;font-weight:300;line-height:25.6px;transition:color .25s;display:block;position:relative}.article-nav__link--current,.article-nav__link:hover{color:var(--c-main-dark)}.html--dark .article-nav__link--current,.html--dark .article-nav__link:hover{color:var(--c-main)}.article-nav__link--level-3{padding-left:16px}.article-nav__link--level-4{padding-left:32px}.article-nav__progress{background:var(--c-main);width:2px;height:10px;transition:translate .25s,height .25s;position:absolute;top:0;left:-1px}.article-nav__toplink-container{border-top:1px solid var(--c-gray-darkest);margin-top:25px;padding-top:25px;transition:opacity .25s}.article-nav__toplink-container:first-child{border-top-width:0;margin-top:-8px;padding-top:0}.article-nav__toplink{color:var(--c-gray);white-space:nowrap;cursor:pointer;align-items:center;gap:6px;padding:8px 0;font-size:16px;font-weight:300;line-height:25.6px;transition:color .25s;display:inline-flex;position:relative}.article-nav__toplink:before{content:"";border-style:solid;border-width:1px 1px 0 0;border-color:var(--c-gray);width:4px;height:4px;transition:border-color .25s;position:absolute;top:19px;right:6px;rotate:-45deg}.article-nav__toplink:after{content:"";border:1px solid var(--c-gray);border-radius:50%;width:15px;height:15px;transition:border-color .25s}.article-nav__toplink:hover{color:var(--c-main-dark)}.article-nav__toplink:hover:before,.article-nav__toplink:hover:after{border-color:var(--c-main-dark)}
.articles{grid-gap:25px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);display:grid}@media screen and (min-width:1024px){.articles{padding-top:97px}}@media screen and (min-width:1200px){.articles{padding-top:121px}}@media screen and (min-width:1680px){.articles{padding-top:134px}}@media screen and (min-width:1024px){.articles{grid-gap:50px}}@media screen and (min-width:1200px){.articles{grid-gap:100px 50px}}@media screen and (min-width:1680px){.articles{grid-gap:100px 50px}}@media screen and (min-width:1024px){.articles--dev{grid-gap:50px}}.articles__item{grid-area:auto/span 2}@media screen and (min-width:1680px){.articles__item{grid-area:auto/span 1}}.articles--dev .articles__item{grid-area:auto/span 2}
.blog{padding:50px var(--spacing);width:100%;max-width:calc(100vw - var(--spacing)*2);grid-template-columns:repeat(3,minmax(0,1fr));align-items:flex-start;position:relative}@media screen and (min-width:768px){.blog{padding:var(--spacing)var(--spacing)calc(var(--spacing)/2)var(--spacing);max-width:calc(100vw - 80px - var(--spacing)*2);min-height:100vh}}@media screen and (min-width:1024px){.blog{grid-gap:var(--spacing);display:grid}}@media screen and (min-width:1680px){.blog{grid-template-columns:repeat(4,minmax(0,1fr))}}@media screen and (min-width:1905px){.blog{max-width:1725px}}.blog__header{flex-direction:column;justify-content:space-between;display:flex;position:relative}@media screen and (min-width:1024px){.blog__header{top:var(--spacing);height:calc(100vh - var(--spacing)*2);position:sticky}}.blog__title{border-bottom:1px solid var(--c-gray-darkest);width:100%;padding-bottom:25px;font-size:40px;font-weight:300;line-height:1.25}@media screen and (min-width:768px){.blog__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.blog__title{font-size:73px;line-height:84px}}.blog__meta{border-bottom:1px solid var(--c-gray-darkest);border-width:0;justify-content:center;padding-top:25px;padding-bottom:25px;display:flex}@media screen and (min-width:1024px){.blog__meta{border-bottom-width:1px}}.blog__content{grid-area:auto/span 2;padding-bottom:50px}@media screen and (min-width:1680px){.blog__content{grid-area:auto/span 3}}
.brand{background-color:var(--c-white);mix-blend-mode:exclusion;text-transform:uppercase;letter-spacing:2px;z-index:5;width:60px;height:60px;box-shadow:inset 0 0 0 1px var(--c-black);border-radius:50%;justify-content:center;align-items:center;font-size:32px;position:fixed;top:10px;left:21.5px}.brand__logo{justify-content:center;align-items:center;width:100%;height:100%;font-weight:700;display:flex}.brand__letter{align-items:center;display:flex}.brand__letter:first-child{transform:translateY(4.5px)}.brand__letter:last-child{transform:translateY(-2.5px)}
.content__title{color:var(--c-black);scroll-margin-top:50px;transition:padding-left .5s cubic-bezier(.7,0,.2,1);position:relative}.content__title--level-2{border-top:1px solid var(--c-gray-darkest);margin-top:var(--spacing);padding-top:25px;font-size:24px;font-weight:300;line-height:1.3}@media screen and (min-width:768px){.content__title--level-2{font-size:32px}}@media screen and (min-width:1200px){.content__title--level-2{font-size:48px}}.content__title--level-3{font-size:20px;font-weight:300;line-height:1.3}@media screen and (min-width:768px){.content__title--level-3{font-size:25px}}@media screen and (min-width:1200px){.content__title--level-3{font-size:30px}}@media screen and (min-width:1024px){.content__title--level-3{margin-bottom:-30px}}.content__title--level-4{font-size:16px;font-weight:300;line-height:1.3}@media screen and (min-width:1200px){.content__title--level-4{font-size:20px}}@media screen and (min-width:1024px){.content__title--level-4{margin-bottom:-30px}}.content__title:hover{padding-left:37.5px}@media screen and (min-width:1905px){.content__title:hover{padding-left:0}}.content__hash{width:25px;color:var(--c-gray);opacity:0;align-items:center;height:1em;padding-right:12.5px;transition:opacity .25s,color .25s,translate .5s cubic-bezier(.7,0,.2,1);display:flex;position:absolute;top:50%;right:100%;translate:0 -50%}@media screen and (min-width:1905px){.content__hash{padding-right:25px}}.content__title:hover .content__hash{opacity:1;transition:opacity .15s .35s;translate:37.5px -50%}@media screen and (min-width:1905px){.content__title:hover .content__hash{transition:opacity .25s;translate:0 -50%}}.content__hash:hover{color:var(--c-main)}.content__title--level-2 .content__hash{padding-top:25px}.content__code code{white-space:pre-wrap;font-family:JetBrains Mono,monospace}.content__code pre{tab-size:4;border-radius:8px;padding:20px;font-size:16px;line-height:20px}@media screen and (min-width:1200px){.content__code pre{font-size:16px;line-height:24px}}.content__image-container{position:relative;overflow:hidden}.content__image{cursor:pointer;transition:scale .25s}.content__image--contain{aspect-ratio:unset}.content__image:hover{scale:1.01}.content__caption{color:var(--c-gray);text-align:center;padding-top:12px;font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.content__caption{font-size:18px;line-height:30px}}.content__text{color:var(--c-gray-darkest);font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.content__text{font-size:18px;line-height:30px}}.content__text :not(.shiki):not(:has(.shiki))>code{white-space:nowrap;color:#d73a49;background-color:#fff;border-radius:4px;padding:3px 5px;font-family:JetBrains Mono,monospace;font-size:14px}@media screen and (min-width:1200px){.content__text :not(.shiki):not(:has(.shiki))>code{font-size:16px}}.html--dark .content__text :not(.shiki):not(:has(.shiki))>code{color:var(--c-main-light);background-color:#24292e}.content__text a{color:var(--c-main-dark)}.html--dark .content__text a{color:var(--c-main)}.content__text ol,.content__text ul,.content__text pre{margin:0 0 1em}.content__text ol:last-child,.content__text ul:last-child,.content__text pre:last-child{margin-bottom:0}.content__text ul li{padding-left:30px;position:relative}.content__text ul li:before{content:"";background-color:var(--c-gray);width:20px;height:1px;position:absolute;top:13px;left:0}@media screen and (min-width:1200px){.content__text ul li:before{top:14.5px}}.content__text ol li{padding-left:10px}.content__text table{border-collapse:collapse;margin-bottom:1em}.content__text tr{transition:background-color .25s}.content__text tr:hover{background-color:var(--c-gray-lightest)}.content__text tr:has(th){background-color:var(--c-gray-light)}.content__text tr:has(th):hover{background-color:var(--c-gray-light)}.content__text th,.content__text td{text-align:left;border:1px solid var(--c-gray-light);padding:4px 8px}
.hover-link{display:inline-block}.hover-link__tooltip{opacity:0;pointer-events:none;z-index:1;border-radius:8px;padding:0;transition:translate .125s}.hover-link:hover .hover-link__tooltip{opacity:1;translate:0 -12px}.hover-link__image{aspect-ratio:3/2;width:300px}.hover-link__title{text-align:center;max-width:300px;white-space:wrap;box-sizing:border-box;padding:12px;font-size:16px;font-weight:700;line-height:25.6px;display:block}.hover-link__link{color:var(--c-gray-darkest);background-color:#0000;align-items:center;gap:4px;font-size:16px;font-weight:300;line-height:27px;display:flex;position:relative}@media screen and (min-width:1200px){.hover-link__link{font-size:18px;line-height:30px}}.hover-link__link:before{content:"";background:color-mix(in srgb,var(--c-black)5%,transparent);z-index:-1;opacity:0;border-radius:4px;transition:opacity .25s;position:absolute;inset:-8px}.hover-link__link:hover:before{opacity:1}.hover-link__link:hover{color:var(--c-black)}.hover-link__icon{width:20px;height:20px}.hover-link__icon--after{order:1}
.image{width:100%;height:100%;position:relative}.html--dark .image--invert,.popup .image--invert{filter:invert()}.image__image{object-fit:cover}.image--contain .image__image{object-fit:contain;position:relative!important}.popup__image .image__image{object-fit:contain}.home__image .image__image{object-position:50% 15%}
.main{box-sizing:border-box;width:100%;margin:0 auto;position:relative;overflow:clip}@media screen and (min-width:768px){.main{padding-left:80px}}.main__transition{z-index:100;background:#09f;width:100%;display:none;position:fixed;bottom:0}.main__transition:nth-of-type(2){background:var(--c-gray-lightest);display:block}
.meta{flex-direction:column;gap:10px;width:100%;font-size:16px;font-weight:300;line-height:25.6px;display:flex}@container meta-container (min-width:768px){.meta{flex-direction:row;width:auto}}@container meta-container (min-width:1200px){.meta{gap:16px}}.teaser__meta .meta{flex-direction:column-reverse}@container meta-container (min-width:768px){.teaser__meta .meta{flex-direction:row}}.article__meta .meta,.blog__meta .meta{width:100%}@media screen and (min-width:1024px){.article__meta .meta,.blog__meta .meta{flex-direction:column}}.meta__item{white-space:nowrap;align-items:center;gap:10px;display:flex}.meta__icon{flex-shrink:0;width:16px;height:16px;margin-top:-2px}@container meta-container (min-width:1024px){.meta__icon{display:none}}@container meta-container (min-width:1200px){.meta__icon{display:block}}.meta__separator{display:none}@container meta-container (min-width:768px){.meta__separator{display:block}}.meta__separator:before{content:"";background-color:var(--c-gray-darkest);width:1px;height:18px;margin-top:3.5px;display:block}@media screen and (min-width:1024px){.article__meta .meta__separator,.blog__meta .meta__separator{display:none}}
.nav{z-index:6;pointer-events:none;border-right:1px solid var(--c-gray-darkest);width:100%;height:100%;position:fixed}@media screen and (min-width:768px){.nav{pointer-events:all;width:80px}}.nav__toggle{background:var(--c-black);pointer-events:all;width:40px;height:40px;color:var(--c-white);border:1px solid #9a9a9a40;transition:translate .25s;position:absolute;bottom:10px;left:50%;translate:-50%}@media screen and (min-width:768px){.nav__toggle{display:none}}.nav__toggle--hidden{translate:-50% calc(100% + 10px)}.nav:has(+.main .popup--active) .nav__toggle{translate:-50% calc(100% + 10px)}.nav__toggle-icon{background-color:var(--c-gray-lightest);width:calc(100% - 10px);height:2px;margin-left:5px;transition:background-color .25s;display:block}.nav__toggle-icon:after,.nav__toggle-icon:before{content:"";background-color:var(--c-gray-lightest);width:calc(100% - 10px);height:2px;transition:rotate .25s,top .25s;position:absolute;left:5px;right:5px}.nav__toggle-icon:before{top:9px}.nav__toggle-icon:after{top:calc(100% - 11px)}.nav--active .nav__toggle-icon{background-color:#0000}.nav--active .nav__toggle-icon:before,.nav--active .nav__toggle-icon:after{transform-origin:50%;top:calc(50% - 2px)}.nav--active .nav__toggle-icon:after{rotate:-45deg}.nav--active .nav__toggle-icon:before{rotate:45deg}.nav__logo{color:var(--c-gray-darkest);letter-spacing:2px;border-bottom:1px solid #9a9a9a40;justify-content:center;align-items:center;width:100%;height:70px;font-size:20px;font-weight:700;transition:background-color .25s;display:flex}@media screen and (min-width:768px){.nav__logo{border-bottom-width:0}}.body--dark .nav__logo{filter:invert()}.body:not(.body--dark) .nav__logo{transition:background-color .25s,color .25s}.nav__logo:hover{background-color:var(--c-main);color:#fff}.nav__lists{box-sizing:border-box;flex-direction:column;justify-content:flex-start;height:100%;display:flex}@media screen and (min-width:768px){.nav__lists{justify-content:space-between}}.nav__container{box-sizing:border-box;pointer-events:all;background-color:var(--c-gray-lightest);flex-direction:column;width:100%;height:100lvh;padding-bottom:70px;transition:background-color .25s;display:none}.body:has(.top-nav__button--dark:hover) .nav__container{background-color:var(--c-gray-lighter)}.nav--active .nav__container{display:flex}@media screen and (min-width:768px){.nav__container{width:100%;height:100svh;padding-bottom:0;display:flex}}.nav__list{flex-direction:column;align-items:center;width:100%;display:contents}@media screen and (min-width:768px){.nav__list{display:flex}}.nav__list--socials{border-bottom:1px solid #9a9a9a40;flex-direction:row;order:1;display:flex}@media screen and (min-width:768px){.nav__list--socials{border-width:0;flex-direction:column}}.nav__item{z-index:1;width:100%;position:relative}.nav__item:first-of-type{order:0}.nav__item:not(:first-of-type){order:2}.nav__link{color:var(--c-gray-darkest);border-bottom:1px solid #9a9a9a40;place-content:center flex-start;align-items:center;gap:20px;width:100%;padding:20px 25px;font-weight:300;display:flex;position:relative;overflow:hidden}@media screen and (min-width:768px){.nav__link{border-bottom-width:0;padding:0 25px}}.nav__link:before{content:"";background:color-mix(in srgb,var(--c-black)5%,transparent);z-index:-1;opacity:0;border-radius:4px;transition:opacity .25s;display:none;position:absolute;inset:5px}@media screen and (min-width:768px){.nav__link:before{display:block}.nav__link{writing-mode:sideways-lr;justify-content:center;padding:15px 0}}@media screen and (min-height:870px) and (min-width:768px){.nav__link{padding:25px 0}}.nav__list--socials .nav__link{border-bottom-width:0;justify-content:center;padding:20px 0}.nav__list--socials .nav__link:hover:before{opacity:1}.nav__label-container{overflow:hidden}.nav__label{font-size:18px;transition:translate .25s;position:relative}@media screen and (min-width:768px){.nav__label{font-size:16px;font-weight:700;translate:-100%}.nav__link:hover .nav__label{translate:-200%}}.nav__label:before,.nav__label:after{content:attr(data-text);text-align:center;width:100%;height:100%;font-weight:300;display:none;position:absolute;inset:0 100%}@media screen and (min-width:768px){.nav__label:before,.nav__label:after{display:block}}.nav__label:after{inset:0 0 0 200%}.nav__link--active .nav__label,.nav__link--active .nav__label:before,.nav__link--active .nav__label:after{font-weight:700}.nav__icon{width:24px}.nav__tooltip{margin-left:8px;display:none}@media screen and (min-width:768px){.nav__tooltip{display:block}}.nav__list--socials .nav__tooltip{display:block}
.project{flex-direction:column;align-items:flex-start;gap:50px;display:flex}@media screen and (min-width:1680px){.project{grid-gap:50px;grid-template-columns:repeat(3,minmax(0,1fr));display:grid}}.project__images{display:none}.project__header{grid-area:auto/span 2}.project__title{border-top:1px solid var(--c-gray-darkest);padding-top:25px;padding-bottom:25px;font-size:24px;font-weight:300;line-height:1.3}@media screen and (min-width:768px){.project__title{font-size:32px}}@media screen and (min-width:1200px){.project__title{font-size:48px}}.project__title p{margin:0}.project:first-child .project__title{padding-top:75px}@media screen and (min-width:1024px){.project:first-child .project__title{padding-top:25px}}.project__content{box-sizing:border-box;flex-direction:column;grid-area:auto/span 1;justify-content:space-between;align-items:flex-start;height:100%;display:flex}@media screen and (min-width:1680px){.project__content{border-top:1px solid var(--c-gray-darkest);padding-top:25px}}.project__description{color:var(--c-gray-darkest);z-index:1;-webkit-hyphens:auto;hyphens:auto;padding-bottom:50px;font-size:20px;font-weight:300;line-height:28px;position:relative}.project__description :not(.shiki):not(:has(.shiki))>code{white-space:nowrap;color:#d73a49;background-color:#fff;border-radius:4px;padding:3px 5px;font-family:JetBrains Mono,monospace;font-size:14px}@media screen and (min-width:1200px){.project__description :not(.shiki):not(:has(.shiki))>code{font-size:16px}}.html--dark .project__description :not(.shiki):not(:has(.shiki))>code{color:var(--c-main-light);background-color:#24292e}.project__description ol,.project__description ul,.project__description pre{margin:0 0 1em}.project__description ol:last-child,.project__description ul:last-child,.project__description pre:last-child{margin-bottom:0}.project__description ul li{padding-left:30px;position:relative}.project__description ul li:before{content:"";background-color:var(--c-gray);width:20px;height:1px;position:absolute;top:13px;left:0}@media screen and (min-width:1200px){.project__description ul li:before{top:14.5px}}.project__description ol li{padding-left:10px}.project__description table{border-collapse:collapse;margin-bottom:1em}.project__description tr{transition:background-color .25s}.project__description tr:hover{background-color:var(--c-gray-lightest)}.project__description tr:has(th){background-color:var(--c-gray-light)}.project__description tr:has(th):hover{background-color:var(--c-gray-light)}.project__description th,.project__description td{text-align:left;border:1px solid var(--c-gray-light);padding:4px 8px}@media screen and (min-width:1680px){.project__description{font-size:25px;line-height:35px}}.project__description a{color:var(--c-project)}.html--dark .project__description a{color:var(--c-project-lighter)}.project__subtitle{letter-spacing:.05em;text-transform:uppercase;color:var(--c-gray);padding-bottom:12.5px;font-size:16px}.project__contributions{color:var(--c-gray-darkest);font-size:20px;font-weight:300;line-height:28px}.project__contributions :not(.shiki):not(:has(.shiki))>code{white-space:nowrap;color:#d73a49;background-color:#fff;border-radius:4px;padding:3px 5px;font-family:JetBrains Mono,monospace;font-size:14px}@media screen and (min-width:1200px){.project__contributions :not(.shiki):not(:has(.shiki))>code{font-size:16px}}.html--dark .project__contributions :not(.shiki):not(:has(.shiki))>code{color:var(--c-main-light);background-color:#24292e}.project__contributions a{color:var(--c-main-dark)}.html--dark .project__contributions a{color:var(--c-main)}.project__contributions ol,.project__contributions ul,.project__contributions pre{margin:0 0 1em}.project__contributions ol:last-child,.project__contributions ul:last-child,.project__contributions pre:last-child{margin-bottom:0}.project__contributions ul li{padding-left:30px;position:relative}.project__contributions ul li:before{content:"";background-color:var(--c-gray);width:20px;height:1px;position:absolute;top:13px;left:0}@media screen and (min-width:1200px){.project__contributions ul li:before{top:14.5px}}.project__contributions ol li{padding-left:10px}.project__contributions table{border-collapse:collapse;margin-bottom:1em}.project__contributions tr{transition:background-color .25s}.project__contributions tr:hover{background-color:var(--c-gray-lightest)}.project__contributions tr:has(th){background-color:var(--c-gray-light)}.project__contributions tr:has(th):hover{background-color:var(--c-gray-light)}.project__contributions th,.project__contributions td{text-align:left;border:1px solid var(--c-gray-light);padding:4px 8px}@media screen and (min-width:1680px){.project__contributions{font-size:25px;line-height:35px}}.project__technologies{z-index:1;flex-wrap:wrap;gap:5px;width:100%;max-width:620px;padding-bottom:50px;list-style:none;display:flex;position:relative}.project__technology{border:1px solid var(--c-project);background-color:color-mix(in srgb,var(--c-project)12.5%,transparent);color:var(--c-project);cursor:help;padding:4px 12px;font-size:14px}.html--dark .project__technology{color:var(--c-project-lighter);border-color:var(--c-project-lighter)}@media screen and (min-width:1680px){.project__technology{padding:6.25px 12.5px;font-size:16px}}.project__technology--secondary{border-style:dashed}.project__tooltip{margin-top:-10px}
.projects{padding:50px var(--spacing);width:100%;max-width:calc(100vw - var(--spacing)*2);grid-template-columns:repeat(3,minmax(0,1fr));align-items:flex-start;position:relative}@media screen and (min-width:768px){.projects{padding:var(--spacing)var(--spacing)calc(var(--spacing)/2)var(--spacing);max-width:calc(100vw - 80px - var(--spacing)*2);min-height:100vh}}@media screen and (min-width:1024px){.projects{grid-gap:var(--spacing);display:grid}}@media screen and (min-width:1680px){.projects{grid-template-columns:repeat(4,minmax(0,1fr))}}@media screen and (min-width:1905px){.projects{max-width:1725px}}.projects__header{flex-direction:column;justify-content:space-between;display:flex;position:relative}@media screen and (min-width:1024px){.projects__header{top:var(--spacing);position:sticky}}.projects__title{border-bottom:1px solid var(--c-gray-darkest);grid-column:1;width:100%;padding-bottom:25px;font-size:40px;font-weight:300;line-height:1.25}@media screen and (min-width:768px){.projects__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.projects__title{font-size:73px;line-height:84px}}.projects__text{padding:25px 0;font-size:20px;font-weight:300;line-height:28px}@media screen and (min-width:1680px){.projects__text{font-size:25px;line-height:35px}}.projects__customize{border-top:1px solid var(--c-gray-darkest);border-width:0;padding-top:0}@media screen and (min-width:1024px){.projects__customize{border-top-width:1px}}.projects--private .projects__customize{display:none}@media screen and (min-width:1024px){.projects--private .projects__customize{display:block}}.projects__list{box-sizing:border-box;flex-direction:column;grid-area:auto/span 2;gap:75px;width:100%;max-width:2560px;margin:0;padding-bottom:50px;list-style:none;display:flex}@media screen and (min-width:1024px){.projects__list{padding-top:97px}}@media screen and (min-width:1200px){.projects__list{padding-top:121px}}@media screen and (min-width:1680px){.projects__list{padding-top:134px}}@media screen and (min-width:1200px){.projects__list{gap:100px}}@media screen and (min-width:1680px){.projects__list{grid-area:auto/span 3}}@media screen and (min-width:1024px){.projects--private .projects__list{padding-top:192px}}@media screen and (min-width:1680px){.projects--private .projects__list{padding-top:219px}}
.root{display:block}@media screen and (min-width:768px){.root{display:flex}}
.skills{padding:50px var(--spacing);width:100%;max-width:calc(100vw - var(--spacing)*2);grid-template-columns:repeat(3,minmax(0,1fr));align-items:flex-start;position:relative}@media screen and (min-width:768px){.skills{padding:var(--spacing)var(--spacing)calc(var(--spacing)/2)var(--spacing);max-width:calc(100vw - 80px - var(--spacing)*2);min-height:100vh}}@media screen and (min-width:1024px){.skills{grid-gap:var(--spacing);display:grid}}@media screen and (min-width:1680px){.skills{grid-template-columns:repeat(4,minmax(0,1fr))}}@media screen and (min-width:1905px){.skills{max-width:1725px}}.skills__header{flex-direction:column;justify-content:space-between;display:flex;position:relative}@media screen and (min-width:1024px){.skills__header{top:var(--spacing);position:sticky}}.skills__title{border-bottom:1px solid var(--c-gray-darkest);width:100%;padding-bottom:25px;font-size:40px;font-weight:300;line-height:1.25}@media screen and (min-width:768px){.skills__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.skills__title{font-size:73px;line-height:84px}}.skills__categories{grid-area:auto/span 2}@media screen and (min-width:1024px){.skills__categories{padding-top:97px}}@media screen and (min-width:1200px){.skills__categories{padding-top:121px}}@media screen and (min-width:1680px){.skills__categories{grid-area:auto/span 3;padding-top:134px}}.skills__category{flex-direction:column;align-items:flex-start;padding-bottom:50px;display:flex}@media screen and (min-width:1680px){.skills__category{grid-gap:50px;grid-template-columns:repeat(3,1fr);display:grid}}.skills__category-title{border-top:1px solid var(--c-gray-darkest);width:100%;padding-top:25px;padding-bottom:25px;font-size:24px;font-weight:300;line-height:1.3}@media screen and (min-width:768px){.skills__category-title{font-size:32px}}@media screen and (min-width:1200px){.skills__category-title{font-size:48px}}@media screen and (min-width:768px){.skills__category-title{padding-bottom:var(--spacing)}}@media screen and (min-width:1680px){.skills__category-title{padding-bottom:0}}@media screen and (min-width:1905px){.skills__category-title{grid-area:auto/span 2}}.skills__category:first-child .skills__category-title{border-width:0;padding-top:75px}@media screen and (min-width:1024px){.skills__category:first-child .skills__category-title{border-top-width:1px;padding-top:25px}}.skills__skills{grid-area:auto/span 2;width:100%}@media screen and (min-width:1680px){.skills__skills{border-top:1px solid var(--c-gray-darkest);padding-top:25px}}@media screen and (min-width:1905px){.skills__skills{grid-area:auto/span 1}}.skills__skill{flex-wrap:wrap;justify-content:space-between;align-items:center;display:flex}.skills__skill:has(.skills__children){padding-top:25px}.skills__skill:first-child{padding-top:0}.skills__children{width:100%;padding-bottom:25px;padding-left:50px}.skills__skill:has(+.skills__skill .skills__children) .skills__children{padding-bottom:0}.skills__label{color:var(--c-gray-darkest);border-top-width:0;width:50%;margin-left:0;padding-top:0;font-size:18px;font-weight:300;line-height:32px;position:relative}@media screen and (min-width:768px){.skills__label{font-size:20px}}@media screen and (min-width:1680px){.skills__label{font-size:25px;line-height:40px}}.skills__hint{color:color-mix(in srgb,var(--c-black)50%,transparent);font-size:14px;font-style:italic;font-weight:300;display:block}@media screen and (min-width:768px){.skills__hint{font-size:16px}}
.slider{background-color:var(--c-gray-lighter);pointer-events:none;aspect-ratio:16/9;flex-shrink:0;width:100%;transition:width .25s;position:relative}@media screen and (min-width:1200px){.slider{aspect-ratio:unset;pointer-events:all;cursor:pointer;height:100%;overflow:hidden}.slider--active{cursor:default}}.slider__hint{z-index:1;color:#000;opacity:0;background-color:#ffffff40;border:2px solid #000;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;transition:opacity .25s;display:none;position:absolute;top:50%;left:calc(50% + -1*clamp(0px,6.25vw,100px));translate:-50% -50%;box-shadow:0 20px 48px #0000001a}@media screen and (min-width:1200px){.slider__hint{display:flex}}.slider:hover .slider__hint{opacity:1}.slider--active:hover .slider__hint{opacity:0}.project:nth-child(2n) .slider__hint{left:calc(50% + clamp(0px,6.25vw,100px))}.slider__icon{width:20px}@media screen and (min-width:768px){.slider__icon{width:28px}}.slider__images{background-color:var(--c-white);aspect-ratio:16/9;width:auto;min-width:clamp(0px,62.5vw,1050px);max-width:clamp(0px,100vw,1680px);height:calc(100% + 1px);margin:0 auto;transition:scale .25s,filter .25s;position:absolute;right:50%;translate:50%}.slider__images:before{content:"";background-color:var(--c-gray-lighter);opacity:.1;pointer-events:none;z-index:1;width:100%;height:100%;transition:opacity .25s;position:absolute;top:0;left:0}@media screen and (min-width:1200px){.slider--active .slider__images:before{opacity:0}}.project:nth-child(2n) .slider__images{left:50%;right:auto;translate:-50%}@media screen and (min-width:1200px){.body:not(.body--safari) .slider:not(.slider--active):hover .slider__images{filter:saturate(1.5);scale:1.025}.body--safari .slider:not(.slider--active):hover .slider__images{filter:saturate(1.5)}}.slider__image-container{aspect-ratio:16/9;opacity:0;pointer-events:none;background-color:#f0f0f0;width:auto;max-width:clamp(0px,150vw,2520px);height:100%;transition:opacity .25s,max-width .25s;position:absolute;top:0;left:50%;translate:-50%}.html--dark .slider__image-container{background-color:#000}@media screen and (min-width:1200px){.slider--active .slider__image-container{max-width:clamp(0px,100vw,1680px)}}.slider__image-container--active{opacity:1}@media screen and (min-width:1024px){.slider__image-container--active{pointer-events:all}}.slider__image{object-position:center;object-fit:contain}
.slider-controls{background-color:var(--c-project);z-index:1;height:40px;padding:0 4px;transition:opacity .25s;display:flex;position:absolute;top:100%;right:0}@media screen and (min-width:768px){.slider-controls{height:50px}}@media screen and (min-width:1200px){.slider-controls{opacity:0;pointer-events:none;background-color:#111;border-radius:4px;inset:auto auto 4px 50%;translate:-50%}}.popup .slider-controls{pointer-events:none;transition:none;top:auto;bottom:10px;right:auto}.popup--active .slider-controls{opacity:1;pointer-events:all;transition:none}@media screen and (min-width:1200px){.slider--active .slider-controls{opacity:1;pointer-events:all}}.slider-controls__control{color:#fff;z-index:1;cursor:pointer;pointer-events:all;justify-content:center;align-items:center;width:40px;height:100%;display:flex;position:relative}.popup .slider-controls__control{pointer-events:none}.popup--active .slider-controls__control{opacity:1;pointer-events:all}@media screen and (min-width:768px){.slider-controls__control{width:60px}}@media screen and (min-width:1200px){.slider-controls__control{color:#9a9a9a}}.slider-controls__control:before{content:"";z-index:-1;opacity:0;background:#2d2d2d;border-radius:4px;transition:opacity .25s;position:absolute;inset:8px 4px}.slider-controls__control:hover{color:#fff}@media screen and (min-width:1200px){.slider-controls__control:hover:before{opacity:1}}.slider-controls__control--close{display:none}@media screen and (min-width:1200px){.slider-controls__control--close{display:flex}}.popup .slider-controls__control--close{display:flex}.slider-controls__icon{width:20px}@media screen and (min-width:768px){.slider-controls__icon{width:28px}}
.stat{border:1px solid var(--c-gray-light);box-sizing:border-box;flex-direction:column;justify-content:space-between;gap:20px;padding:20px;display:flex}@media screen and (min-width:1905px){.stat{width:100%}}.stat--bar{grid-column:auto/span 16;width:calc(66.6667% - 8.33334px)}@media screen and (min-width:1680px){.stat--bar{grid-row:auto/span 3;width:auto}}@media screen and (min-width:1905px){.stat--bar{grid-column:auto/span 13}}.stat--donut{grid-column:auto/span 8;width:calc(33.3333% - 16.6667px)}@media screen and (min-width:1680px){.stat--donut{grid-row:auto/span 3;width:auto}}@media screen and (min-width:1905px){.stat--donut{grid-column:auto/span 7}}.stat--count,.stat--text{grid-area:auto/auto/span 1/span 4;gap:10px;width:calc(25% - 18.75px)}@media screen and (min-width:1680px){.stat--count,.stat--text{gap:0;width:100%}}@media screen and (min-width:1905px){.stat--count,.stat--text{width:auto;height:100%}}.stat--1{order:1}.stat--2{order:2}.stat--3{order:3}.stat--4{order:4}.stat--5{order:5}.stat--6{order:6}@media screen and (min-width:1680px){.stat--1,.stat--2,.stat--3,.stat--4,.stat--5,.stat--6{order:unset}}.stat__title{color:var(--c-black);font-size:20px}.stat--count .stat__title,.stat--text .stat__title{text-align:center}.stat__chart{text-align:center;justify-content:center;width:100%;display:flex}.stat__value{font-size:60px;font-weight:700;line-height:1}@media screen and (min-width:1200px){.stat__value{font-size:70px}}.stat__value--small{font-size:30px;line-height:60px}@media screen and (min-width:1200px){.stat__value--small{font-size:35px;line-height:70px}}@media screen and (min-width:1905px){.stat__value--small{font-size:45px}}
.statistics{box-sizing:border-box;width:100%;max-width:1840px;margin:0 auto;padding:10px;position:relative;overflow:hidden}@media screen and (min-width:1024px){.statistics{padding:25px}}.statistics__title{border-bottom:1px solid var(--c-gray-darkest);width:100%;color:var(--c-black);padding-bottom:100px;font-size:40px;font-weight:300;line-height:1.25}@media screen and (min-width:768px){.statistics__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.statistics__title{font-size:73px;line-height:84px}}.statistics__grid{flex-wrap:wrap;grid-template-columns:repeat(24,1fr);grid-auto-rows:1fr;align-items:stretch;gap:10px;display:flex}@media screen and (min-width:1024px){.statistics__grid{gap:25px}}@media screen and (min-width:1680px){.statistics__grid{display:grid}}.statistics__group{grid-area:auto/auto/span 1/span 12;gap:25px;width:auto;display:contents}@media screen and (min-width:1680px){.statistics__group{display:flex}}@media screen and (min-width:1905px){.statistics__group{flex-direction:column;grid-area:auto/auto/span 3/span 4}}
.teaser{flex-flow:column wrap;padding-top:50px;display:flex;position:relative;overflow:hidden}.teaser--dev:after{content:"";border-left:1px solid var(--c-gray-darkest);width:1px;height:0;transition:height .4s;position:absolute;top:0;left:0}@container teaser-container (min-width:768px){.teaser--dev:hover:after{height:calc(100% - 50px);transition-delay:.2s}}.teaser:before{border-top:1px solid var(--c-gray-darkest);content:"";width:100%;padding-top:25px;transition:width .5s cubic-bezier(.7,0,.2,1);position:absolute;top:0}@container teaser-container (min-width:768px){.teaser:hover:before{width:calc(100% - 100px)}.teaser{flex-direction:row}}.drawer .teaser{container:meta-container/inline-size}.teaser__content{z-index:2;box-sizing:border-box;width:calc(100% - 100px);transition:translate .75s cubic-bezier(.7,0,.2,1)}.teaser--dev .teaser__content{width:100%;max-width:600px}@container teaser-container (min-width:768px){.teaser--dev .teaser__content{width:calc(100% - 50px);max-width:none}}@container teaser-container (min-width:1680px){.teaser--dev .teaser__content{width:calc(100% - 150px)}}.drawer .teaser__content{padding-bottom:25px}@container teaser-container (min-width:768px){.teaser__content{margin-top:0;bottom:0;left:0}}.teaser:has(.teaser__image) .teaser__content{width:100%;padding-top:25px}@container teaser-container (min-width:1200px){.teaser:has(.teaser__image) .teaser__content{max-width:850px}}@container teaser-container (min-width:768px){.teaser--dev:hover .teaser__content{translate:50px}}.teaser__tags{flex-wrap:wrap;justify-content:flex-start;gap:6.25px 12.5px;margin-bottom:12.5px;display:flex}.teaser__tag{color:var(--c-main)}.teaser__title{border-bottom:1px solid var(--c-gray-darkest);-webkit-hyphens:auto;hyphens:auto;text-wrap:balance;color:var(--c-black);border-bottom-width:0;padding-bottom:15px;font-size:24px;font-weight:300;line-height:1.3;transition:translate .5s cubic-bezier(.7,0,.2,1);position:relative}@container teaser-container (min-width:768px){.teaser__title{padding-bottom:25px;font-size:32px}}@container teaser-container (min-width:1200px){.teaser__title{font-size:48px}}.teaser__text{color:var(--c-black);-webkit-hyphens:auto;hyphens:auto;padding-bottom:25px;font-size:20px;font-weight:300;line-height:28px}@media screen and (min-width:1680px){.teaser__text{font-size:25px;line-height:35px}}.teaser__text:empty{display:none}.teaser__image-container{width:100%;position:relative}.teaser__image-container:before{content:"";border-left:1px solid var(--c-gray-darkest);width:1px;height:0;transition:height .4s;position:absolute;top:-50px;left:0}@container teaser-container (min-width:768px){.teaser:hover .teaser__image-container:before{height:calc(100% + 50px);transition-delay:.2s}}.teaser__image{aspect-ratio:16/9;width:100%;transition:translate .5s cubic-bezier(.7,0,.2,1);position:relative}@container teaser-container (min-width:768px){.teaser__image{width:calc(100% - 75px);margin-left:0}.teaser:hover .teaser__image{translate:50px}}.teaser__meta{color:var(--c-gray-darkest);box-sizing:border-box;gap:8px;width:180px;display:flex}@container teaser-container (min-width:768px){.teaser__meta{gap:16px}}
.top-nav{box-sizing:border-box;z-index:5;pointer-events:none;align-items:center;width:auto;height:50px;padding-top:5px;display:flex;position:absolute;top:0;right:0}@media screen and (min-width:768px){.top-nav{padding-top:20px}}@media screen and (min-width:1024px){.top-nav{width:100%;padding-top:25px;padding-right:10px;position:static}}.top-nav:has(.top-nav__title){justify-content:space-between;position:relative}@media screen and (min-width:768px){.top-nav:has(.top-nav__title){background-color:var(--c-gray-lightest);border-left:1px solid #9a9a9a40}}.article__customize .top-nav,.home .top-nav{width:100%;padding-top:25px;position:static}.top-nav__title{color:#9a9a9a;pointer-events:all;white-space:nowrap;padding-left:20px;font-size:24px;font-weight:400;display:none}.top-nav__title:before{content:"/ "}@media screen and (min-width:768px){.top-nav__title{display:block}}.top-nav__nav{gap:16px;display:flex}.top-nav__section{pointer-events:all;gap:16px;display:flex}.top-nav__item{display:flex}.top-nav__button{cursor:pointer;width:40px;height:40px;color:var(--c-gray-darkest);z-index:1;justify-content:center;align-items:center;transition:color .25s;display:flex;position:relative;overflow:hidden}@media screen and (min-width:1200px){:is(.top-nav:has(+.home) .top-nav__button,.top-nav:has(+.blogs) .top-nav__button){color:#fff}}:is(.body:has(.blogs) .top-nav:has(+.home) .top-nav__button,.body:has(.blogs) .top-nav:has(+.blogs) .top-nav__button){color:#fff}.top-nav__button:before{content:"";background:color-mix(in srgb,var(--c-black)5%,transparent);z-index:-1;opacity:0;border-radius:4px;transition:opacity .25s;position:absolute;inset:0}.top-nav__button:hover{color:var(--c-black)}.top-nav__button:hover:before{opacity:1}:is(.top-nav:has(+.home) .top-nav__button:hover,.top-nav:has(+.blogs) .top-nav__button:hover){color:#fff}.top-nav__icon-container{aspect-ratio:1;width:24px;position:relative;overflow:hidden}.top-nav__icon{flex-shrink:0;width:24px;transition:scale .25s,translate .25s}.top-nav__button:hover .top-nav__icon{scale:1.1}.top-nav__button--back:hover .top-nav__icon{translate:-100%;scale:1}.top-nav__button--back:hover .top-nav__icon--hover{translate:0}.top-nav__icon--hover{position:absolute;left:0;translate:100%}.top-nav__tooltip{margin-top:10px}
.not-found{padding:50px var(--spacing);width:100%;max-width:calc(100vw - var(--spacing)*2);flex-direction:column;grid-template-columns:repeat(3,minmax(0,1fr));justify-content:center;align-items:flex-start;gap:25px;height:100svh;padding-top:0;padding-bottom:0;display:flex;position:relative}@media screen and (min-width:768px){.not-found{padding:var(--spacing)var(--spacing)calc(var(--spacing)/2)var(--spacing);max-width:calc(100vw - 80px - var(--spacing)*2);min-height:100vh}}@media screen and (min-width:1024px){.not-found{grid-gap:var(--spacing);display:grid}}@media screen and (min-width:1680px){.not-found{grid-template-columns:repeat(4,minmax(0,1fr))}}@media screen and (min-width:1905px){.not-found{max-width:1725px}}@media screen and (min-width:768px){.not-found{padding-top:0;padding-bottom:0}}@media screen and (min-width:1024px){.not-found{display:flex}}@media screen and (min-width:1200px){.not-found{padding-top:0;padding-bottom:0}}.not-found__title{border-bottom:1px solid var(--c-gray-darkest);border-width:0;width:100%;padding-bottom:0;font-size:40px;font-weight:300;line-height:1.25}@media screen and (min-width:768px){.not-found__title{padding-bottom:var(--spacing);font-size:62px;line-height:71px}}@media screen and (min-width:1680px){.not-found__title{font-size:73px;line-height:84px}}@media screen and (min-width:768px){.not-found__title{padding-bottom:0}}.not-found__subtitle{border-bottom:1px solid var(--c-gray-darkest);white-space:pre-line;text-wrap:balance;border-width:0;padding-bottom:0;font-size:24px;font-weight:300;line-height:1.3}@media screen and (min-width:768px){.not-found__subtitle{font-size:32px}}@media screen and (min-width:1200px){.not-found__subtitle{font-size:48px}}@media screen and (min-width:768px){.not-found__subtitle{padding-bottom:0}}.not-found__button{color:#fff;background-color:#09f;border-radius:4px;padding:16px 32px;font-weight:700;transition:box-shadow .25s,background-color .25s}.not-found__button:hover{background-color:#6bf;box-shadow:0 20px 48px #0000001a}
@keyframes pulse-opacity{0%{opacity:1}50%{opacity:.25}}.map{width:100%;height:100svh;position:relative}@media screen and (min-width:768px){.map{margin-top:0}}.map__marker{width:20px;height:20px}.map__marker:hover:before{scale:2.5}.map__marker:before{content:"";background-color:var(--c-marker);border-radius:50%;width:8px;height:8px;transition:scale .25s;position:absolute;top:50%;left:50%;translate:-50% -50%;box-shadow:inset 0 0 0 1px #fff}.html--dark .map__marker:before{box-shadow:inset 0 0 0 1px #d2d2d2}.map__marker--active-year{animation:1s ease-in-out infinite pulse-opacity}.map__marker--active:before{background-color:red;scale:2.5}.html--dark .map__marker--active:before{background-color:red}.map__tooltip{pointer-events:none;margin-top:-5px}@media screen and (pointer:coarse){.map__tooltip--force{display:block}}
.drawer{background:var(--c-gray-lightest);box-sizing:border-box;z-index:5;scrollbar-width:none;opacity:0;border-radius:20px 20px 0 0;width:100%;max-height:calc(100svh - 20px);position:fixed;top:0;left:0;overflow:hidden;translate:0 100%;container:teaser-container/inline-size}@media screen and (min-width:768px){.drawer{z-index:2;border-radius:0;width:450px;transition:translate .25s;inset:10px 0 auto auto;overflow:auto;translate:100%}}.drawer--transportation{max-height:none}@media screen and (min-width:768px){.drawer--transportation{width:600px}}.drawer--animated{transition:translate .25s}.drawer--visible{opacity:1}.drawer--active{translate:0}@media screen and (min-width:768px){.drawer--active{translate:-10px}}.drawer--big{height:calc(100vh - 100px);overflow:auto}.drawer__header{z-index:3;background-color:var(--c-gray-lightest);padding:40px 30px 20px;position:sticky;top:0;overflow:hidden}.drawer__header:before{content:"";background-color:var(--c-gray-light);border-radius:2px;width:100px;height:4px;position:absolute;top:15px;left:50%;translate:-50%}@media screen and (min-width:768px){.drawer__header:before{display:none}}.drawer__close{cursor:pointer;width:35px;height:35px;color:var(--c-black);position:absolute;top:42px;right:40px}.drawer__title{color:var(--c-black);padding-bottom:4px;padding-right:80px;font-size:20px;font-weight:300;line-height:1.3}@media screen and (min-width:768px){.drawer__title{font-size:25px}}@media screen and (min-width:1200px){.drawer__title{font-size:30px}}.drawer__subtitle{letter-spacing:.05em;text-transform:uppercase;color:var(--c-gray);padding-bottom:12.5px;font-size:16px}.drawer__content{padding:20px 30px 40px}.drawer__tagline{letter-spacing:.1em;opacity:.8;text-transform:uppercase;color:var(--c-black);padding-bottom:10px;font-size:14px;font-weight:200;line-height:18px}.drawer__footer .drawer__tagline,.infobox__fact .drawer__tagline{padding-bottom:0}.drawer__stories{flex-direction:column;gap:40px;display:flex}.drawer__footer{flex-wrap:wrap;gap:40px;margin-top:40px;display:flex}.drawer__fact{flex-direction:column;display:flex}.drawer__text{color:var(--c-gray-darkest);white-space:nowrap;font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.drawer__text{font-size:18px;line-height:30px}}
.quote{background-color:var(--c-gray-lightest);padding:20px}@media screen and (min-width:768px){.quote{padding:60px 40px}}.quote__text{text-align:center;color:var(--c-gray-dark);font-size:20px;font-weight:200;line-height:1.3}@media screen and (min-width:768px){.quote__text{font-size:25px}}@media screen and (min-width:1200px){.quote__text{font-size:30px}}.quote__author{color:var(--c-gray-darkest);text-align:center;padding-top:20px;font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.quote__author{font-size:18px;line-height:30px}}.quote__author:before{content:"— "}
.popup{z-index:6;pointer-events:none;background-color:#1f1f1f;justify-content:center;align-items:center;width:100%;height:100%;display:none;position:fixed;top:0;left:0}@media screen and (min-width:768px){.popup{width:calc(100% - 80px);left:80px}}.popup--active{pointer-events:all;transition:opacity .25s;display:flex}.popup__image{width:calc(100vw - 40px);height:calc(100vh - 100px);margin-top:-50px}@media screen and (min-width:768px){.popup__image{width:calc(100vw - 180px)}}.popup__button{width:30px;height:30px;position:absolute;bottom:10px;left:50%}.popup__button--prev{translate:calc(-150% - 10px)}.popup__button--next{translate:calc(10px - 50%)}
.location{background-color:var(--c-gray-lightest);box-sizing:border-box;flex-direction:column;max-width:50%;height:auto;padding-right:20px;display:flex;container:location}@media screen and (min-width:500px){.location{max-width:35%}}@media screen and (min-width:768px){.location{max-width:45%;padding-right:40px}}.location:before,.location:after{display:none}@media screen and (min-width:500px){.location:before,.location:after{display:block}}.journey .location:last-child{padding-left:20px;padding-right:0;position:relative}@media screen and (min-width:768px){.journey .location:last-child{padding-left:40px}}.journey .location:last-child:before{content:"";background-color:var(--c-black);z-index:-1;width:100vw;height:1px;position:absolute;top:50%;right:calc(100% + 5px)}.journey .location:last-child:after{content:"";border-top:5px solid #0000;border-bottom:5px solid #0000;border-left:10px solid var(--c-black);position:absolute;top:50%;right:100%;translate:0 -50%}.location__title{letter-spacing:.1em;opacity:.8;text-transform:uppercase;color:var(--c-black);padding-bottom:10px;font-size:14px;font-weight:200;line-height:18px}.drawer__footer .location__title,.infobox__fact .location__title{padding-bottom:0}.location__name{text-transform:uppercase;text-wrap:balance;padding-bottom:20px;font-size:16px;font-weight:700;line-height:1.3}@media screen and (min-width:1200px){.location__name{font-size:20px}}.location__code+.location__name{color:var(--c-gray-darkest);letter-spacing:.05em;font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.location__code+.location__name{font-size:18px;line-height:30px}}.location__code{color:var(--c-main);letter-spacing:.05em;font-size:45px;font-weight:900}@media screen and (min-width:768px){.location__code{font-size:60px}}.location__date{color:var(--c-gray-darkest);margin-top:auto;font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.location__date{font-size:18px;line-height:30px}}.location__time{color:var(--c-gray-darkest);font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.location__time{font-size:18px;line-height:30px}}
.visits{padding-bottom:40px}.visits:last-child{padding-bottom:0}.visits__title{letter-spacing:.1em;opacity:.8;text-transform:uppercase;color:var(--c-black);padding-bottom:10px;font-size:14px;font-weight:200;line-height:18px}.drawer__footer .visits__title,.infobox__fact .visits__title{padding-bottom:0}.visits__item{color:var(--c-gray-darkest);justify-content:space-between;font-size:16px;font-weight:300;line-height:27px;display:flex}@media screen and (min-width:1200px){.visits__item{font-size:18px;line-height:30px}}.visits__date{width:50%;display:block}.visits__date:last-child{text-align:right}
.journey{justify-content:space-between;align-items:stretch;display:flex;position:relative;overflow:hidden}.journey__icon{aspect-ratio:1;background:var(--c-gray-lightest);align-self:center;width:64px;display:none;position:relative}@media screen and (min-width:500px){.journey__icon{display:block}}
.infobox{z-index:4;pointer-events:none;position:fixed;bottom:5px;left:10px;overflow:hidden}.infobox--active{pointer-events:all}@media screen and (min-width:768px){.infobox{bottom:10px;left:90px}}.infobox__container{pointer-events:none;opacity:0;width:250px;padding:30px 30px 60px;position:relative}.infobox--active .infobox__container{opacity:1;transition:opacity .25s .25s}.infobox--active .infobox__content{pointer-events:all}.infobox__years{grid-template-rows:auto;grid-template-columns:1fr 1fr;grid-auto-flow:column;display:grid}.infobox__year{color:var(--c-gray-darkest);align-items:center;gap:16px;font-size:16px;font-weight:300;line-height:27px;display:flex}@media screen and (min-width:1200px){.infobox__year{font-size:18px;line-height:30px}}.infobox__year:nth-child(odd){grid-column:1}.infobox__year:nth-child(2n){grid-column:2}.infobox__color{aspect-ratio:1;border-radius:50%;width:8px;display:block}.infobox__fact{flex-direction:column;padding-bottom:40px;display:flex}.infobox__fact:last-child{padding-bottom:0}.infobox__tagline{letter-spacing:.1em;opacity:.8;text-transform:uppercase;color:var(--c-black);padding-bottom:10px;font-size:14px;font-weight:200;line-height:18px;display:block}.drawer__footer .infobox__tagline,.infobox__fact .infobox__tagline{padding-bottom:0}.infobox__text{color:var(--c-gray-darkest);font-size:16px;font-weight:300;line-height:27px}@media screen and (min-width:1200px){.infobox__text{font-size:18px;line-height:30px}}.infobox__toggle{width:32px;height:32px;color:var(--c-black);cursor:pointer;pointer-events:all;border-radius:50%;position:absolute;bottom:10px;left:10px}.infobox__toggle:before{pointer-events:none;content:"";background-color:var(--c-gray-lightest);z-index:-1;border-radius:50%;width:100%;height:100%;transition:scale .25s;position:absolute}.infobox--active .infobox__toggle:before{transition:scale .5s;scale:50}
.contact-button{align-items:center;font-size:18px;display:flex}.contact-button__icon{width:35px;color:var(--c-gray-darkest);margin-right:12.5px}.contact-button__link{color:var(--c-gray-darkest);position:relative}.contact-button__link:after{content:"";z-index:-1;background-color:var(--c-project);width:0;height:3px;transition:width .25s cubic-bezier(.7,0,.2,1);position:absolute;bottom:0;left:0}.contact-button:hover .contact-button__link:after{width:100%;transition:width .5s cubic-bezier(.7,0,.2,1)}.html--dark .contact-button__link:after{background-color:var(--c-project-lighter)}.contact-button__text{color:var(--c-gray-darkest)}
.view-button{color:var(--c-gray-darkest);align-items:center;font-size:20px;font-weight:300;line-height:28px;display:flex;position:relative}@media screen and (min-width:1680px){.view-button{font-size:25px;line-height:35px}}.view-button__plus{aspect-ratio:1;border:1px solid var(--c-gray);width:50px;transition:rotate .25s cubic-bezier(.7,0,.2,1),background-color .25s cubic-bezier(.7,0,.2,1),border-color .25s cubic-bezier(.7,0,.2,1);display:block;position:relative}@media screen and (min-width:1680px){.view-button__plus{width:75px}}.view-button__plus:before,.view-button__plus:after{content:"";background-color:var(--c-gray-darkest);width:24px;height:4px;position:absolute;top:50%;left:50%;translate:-50% -50%}@media screen and (min-width:1680px){.view-button__plus:before,.view-button__plus:after{width:35px;height:6px}}.view-button__plus:after{rotate:90deg}.view-button:hover .view-button__plus{background-color:var(--c-project,var(--c-main));border-color:var(--c-project,var(--c-main));rotate:90deg}.view-button__back{aspect-ratio:1;border:1px solid var(--c-gray);width:50px;transition:rotate .25s cubic-bezier(.7,0,.2,1),background-color .25s cubic-bezier(.7,0,.2,1),border-color .25s cubic-bezier(.7,0,.2,1);display:block;position:relative}@media screen and (min-width:1680px){.view-button__back{width:75px}}.view-button:hover .view-button__back{background-color:var(--c-project,var(--c-main));border-color:var(--c-project,var(--c-main))}.view-button__icon{width:30px;position:absolute;inset:50%;translate:-50% -50%}@media screen and (min-width:1680px){.view-button__icon{width:50px}}.view-button__text{z-index:1;transition:translate .25s cubic-bezier(.7,0,.2,1);position:relative;translate:-6px}@media screen and (min-width:1680px){.view-button__text{translate:-10px}}.view-button__text:after{content:"";z-index:-1;background-color:var(--c-project,var(--c-main));width:0;height:3px;transition:width .25s cubic-bezier(.7,0,.2,1);position:absolute;bottom:1px;left:0}.view-button:hover .view-button__text:after{width:100%;transition:width .5s cubic-bezier(.7,0,.2,1)}.view-button:hover .view-button__text{translate:12px}
@media screen and (pointer:coarse){.tooltip{display:none}}.hover-link .tooltip>div{padding:0}.tooltip__content{color:var(--c-white);background-color:var(--c-gray-darkest);text-wrap:nowrap;border-radius:4px;padding:6px 12px;font-size:14px;transition:opacity .25s;position:relative}.tooltip__arrow{fill:var(--c-black)}.tooltip--top .tooltip__arrow{translate:0 -1px}.tooltip--bottom .tooltip__arrow{translate:0 1px}.tooltip--left .tooltip__arrow{translate:-1px}.tooltip--right .tooltip__arrow{translate:1px}
