@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;700&family=Montserrat:wght@400;500&family=Poppins:ital,wght@0,400;0,700;1,400;1,700&display=swap";.hero[data-v-5bccfdd3]{position:relative;width:100%;height:85vh;overflow:hidden}.hero-slogan[data-v-5bccfdd3]{position:absolute;right:var(--page-x-padding);bottom:10%;text-align:right;color:#fff;font-weight:500}@media (max-width: 768px){.hero-slogan[data-v-5bccfdd3]{width:100%;text-align:center;right:0;bottom:10%;font-size:2rem}}.background-container[data-v-5bccfdd3]{position:relative;width:100vw;height:100%}.background-container>.slider[data-v-5bccfdd3]{position:absolute;top:0;height:100%;width:max-content;display:flex;transition:left 0s cubic-bezier(.85,0,.15,1)}@media (prefers-reduced-motion: reduce){.background-container>.slider[data-v-5bccfdd3]{transition:none}}.background-container>.slider>img[data-v-5bccfdd3]{height:100%;width:100vw;object-fit:cover}.background-container[data-v-5bccfdd3]:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#0003}.intro[data-v-70d38290]{width:100%;max-width:calc(100% - var(--page-x-padding) * 2);padding-block:256px;margin-inline:auto;text-align:center;font-size:2rem}@media (max-width: 768px){.intro[data-v-70d38290]{font-size:1.5rem}}.project-cards[data-v-8d03c4fd]{width:100%;padding-block:96px 128px;background-color:#f9efd8}.project-cards .title[data-v-8d03c4fd]{line-height:1;text-align:center;margin-bottom:48px;font-weight:700}.project-cards .container[data-v-8d03c4fd]{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;margin-inline:auto;width:min-content}@media (max-width: 1024px){.project-cards .container[data-v-8d03c4fd]{grid-template-columns:1fr;gap:0}}.project-cards .container>button[data-v-8d03c4fd]{width:min-content;padding:0;background-color:transparent;border:none;border-radius:8px;transition:background-color .2s ease-in-out,opacity .2s ease-in-out,filter .2s ease-in-out;cursor:pointer}.project-cards .container>button[data-v-8d03c4fd]:hover{background-color:#90a8e033}.project-cards .container>button[data-v-8d03c4fd]:active{background-color:#90a8e066}.project-cards .container>button[data-v-8d03c4fd]:disabled{background-color:transparent;cursor:default;filter:grayscale(1);opacity:.5}.project-cards .container>button>svg[data-v-8d03c4fd]{width:36px;height:36px;color:#90a8e0}@media (max-width: 1024px){.project-cards .container>button[data-v-8d03c4fd]{display:none}}.project-cards .carousel[data-v-8d03c4fd]{width:80vw;container-type:inline-size;display:grid;grid-auto-columns:1fr;grid-auto-flow:column;grid-template-rows:repeat(3,auto);place-items:center;row-gap:16px;overflow-x:scroll;scroll-snap-type:x mandatory;overscroll-behavior-x:contain;align-items:start;border-radius:8px 8px 0 0;-ms-overflow-style:none;scrollbar-width:none}.project-cards .carousel[data-v-8d03c4fd]::-webkit-scrollbar{display:none}@media (max-width: 1024px){.project-cards .carousel[data-v-8d03c4fd]{grid-auto-flow:row;row-gap:32px;width:min(80vw,600px)}}.project-cards .card[data-v-8d03c4fd]{scroll-snap-align:center;min-width:33.3333333333cqw;padding:16px;border-radius:8px;transition:background-color .2s ease-in-out;display:grid;grid-template-columns:1fr;grid-template-rows:subgrid;grid-row:1/4}@media (max-width: 1024px){.project-cards .card[data-v-8d03c4fd]{grid-row:unset;grid-template-rows:repeat(3,auto);gap:16px;padding:12px;width:100%;background-color:#90a8e033}}.project-cards .card img[data-v-8d03c4fd]{width:100%;height:256px;object-fit:cover;border-radius:8px}.project-cards .card h3[data-v-8d03c4fd]{text-align:center;font-size:1.5rem;font-weight:700;height:fit-content;place-self:center;text-decoration:none}@media (max-width: 1024px){.project-cards .card h3[data-v-8d03c4fd]{font-size:1.2rem;text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:2px;color:#90a8e0}}.project-cards .card p[data-v-8d03c4fd]{text-align:center}.project-cards .card[data-v-8d03c4fd]:hover{background-color:#90a8e033;cursor:pointer}.project-cards .card:hover h3[data-v-8d03c4fd]{text-decoration:underline}.posts[data-v-4bcf2644]{display:grid;grid-auto-columns:1fr;width:100%;margin:0 auto}@media (max-width: 1024px){.posts[data-v-4bcf2644]{grid-template-rows:auto;width:80vw}}.posts .card[data-v-4bcf2644]{padding-block:32px;display:grid;grid-template-columns:auto 1fr;gap:32px}@media (max-width: 1024px){.posts .card[data-v-4bcf2644]{grid-template-columns:1fr;grid-template-rows:auto 1fr;gap:16px}}.posts .card[data-v-4bcf2644]:not(:last-child){border-bottom:1px solid #90a8e0}.posts .card img[data-v-4bcf2644]{height:256px;width:455px;border-radius:8px;object-fit:cover}@media (max-width: 1024px){.posts .card img[data-v-4bcf2644]{width:100%;height:auto;max-height:256px;margin-inline:auto}}.posts .card .post-content[data-v-4bcf2644]{display:grid;grid-template-rows:auto 1fr auto}@media (max-width: 1024px){.posts .card .post-content[data-v-4bcf2644]{padding-inline:32px;text-align:center;display:block}}@media (max-width: 768px){.posts .card .post-content[data-v-4bcf2644]{padding-inline:16px}}.posts .card .post-content>h3[data-v-4bcf2644]{font-size:1.5rem;font-weight:700;height:fit-content;margin-block:1rem}@media (max-width: 768px){.posts .card .post-content>h3[data-v-4bcf2644]{font-size:1.2rem}}@media (max-width: 1024px){.posts .card .post-content>h3[data-v-4bcf2644]{margin-block:0 .5rem}}.posts .card .post-content>p[data-v-4bcf2644]{max-width:100%;max-height:80%;display:-webkit-box;line-clamp:5;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;margin-bottom:1.5rem}@media (max-width: 1024px){.posts .card .post-content>p[data-v-4bcf2644]{line-clamp:4;-webkit-line-clamp:4;margin-bottom:.5rem}}.posts .card .post-content>a[data-v-4bcf2644]{display:inline-flex;align-items:center;gap:4px;margin-bottom:8px}@media (max-width: 1024px){.posts .card .post-content>a[data-v-4bcf2644]{margin-bottom:0}}.recent-posts[data-v-696d85e2]{width:100%;padding-block:96px 128px;background-color:#f9f3e6;padding-inline:var(--page-x-padding)}.recent-posts .title[data-v-696d85e2]{line-height:1;text-align:center;margin-bottom:48px;font-weight:700}.recent-posts .view-all[data-v-696d85e2]{display:block;width:fit-content;margin-inline:auto;padding:8px 32px;color:#90a8e0;border:1px solid #90a8e0;border-radius:4px;transition:background-color .2s ease-in-out,color .2s ease-in-out}.recent-posts .view-all[data-v-696d85e2]:hover{background-color:#90a8e0;color:#f9f3e6;text-decoration:none}@media (max-width: 768px){.recent-posts .view-all[data-v-696d85e2]{width:80vw;text-align:center}}p[data-v-69648eb5]{font-size:1.25rem;margin-block:1rem}@media (max-width: 768px){p[data-v-69648eb5]{font-size:1rem}}a[data-v-700687e6]{display:inline-block;height:fit-content;border:1px solid #90a8e0;border-radius:100vw;padding:2px 10px;background-color:#90a8e01a}a[data-v-700687e6]:hover{background-color:#90a8e033;text-decoration:none}a>.lucide[data-v-700687e6]{vertical-align:middle;margin-right:4px;margin-bottom:1px}.description[data-v-c78c6e87]{line-height:200%;display:inline-block;margin-right:.5ch}.tags[data-v-b686339e]{display:flex;flex-wrap:wrap;gap:1ch}.description[data-v-b686339e]{margin-bottom:1rem;line-height:200%}.nav-bar[data-v-56c80043]{position:fixed;height:var(--nav-height);width:100%;background-color:#90a8e0;top:0;left:0;z-index:100;display:grid;grid-template-columns:auto 1fr;align-items:center;justify-content:space-between;padding-inline:var(--page-x-padding)}@media (max-width: 768px){.nav-bar[data-v-56c80043]{grid-template-columns:1fr auto 1fr;grid-template-rows:var(--nav-height) 1fr}}@media (max-width: 768px) and (prefers-reduced-motion: no-preference){.nav-bar[data-v-56c80043]{transition:height .6s cubic-bezier(.85,0,.15,1)}}@media (max-width: 768px){.nav-bar.open[data-v-56c80043]{height:100vh}}.nav-bar .title[data-v-56c80043]{margin:0;width:fit-content;font-size:1.7rem;line-height:100%;color:#fff;line-height:85%;text-decoration:none}@media (max-width: 768px){.nav-bar .title[data-v-56c80043]{font-size:1.5rem;grid-column:2;place-self:center}}.nav-bar ul[data-v-56c80043]{display:flex;justify-content:flex-end;list-style:none;gap:20px;padding:0;margin:0}@media (max-width: 768px){.nav-bar ul[data-v-56c80043]{flex-direction:column;grid-column:2;grid-row:2;margin-bottom:var(--nav-height);pointer-events:none}}@media (max-width: 768px) and (max-height: 400px){.nav-bar ul[data-v-56c80043]{margin-bottom:0;gap:4px}}@media (max-width: 768px){.nav-bar ul>li[data-v-56c80043]{opacity:0}}@media (max-width: 768px) and (prefers-reduced-motion: no-preference){.nav-bar ul>li[data-v-56c80043]{transition:opacity .2s ease-in-out 0s}}@media (max-width: 768px){.nav-bar ul.open[data-v-56c80043]{pointer-events:auto}.nav-bar ul.open>li[data-v-56c80043]{opacity:1}}@media (max-width: 768px) and (prefers-reduced-motion: no-preference){.nav-bar ul.open>li[data-v-56c80043]{transition:opacity .2s ease-in-out .3s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(1){transition-delay:.3s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(2){transition-delay:.35s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(3){transition-delay:.4s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(4){transition-delay:.45s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(5){transition-delay:.5s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(6){transition-delay:.55s}.nav-bar ul.open>li[data-v-56c80043]:nth-child(7){transition-delay:.6s}}.nav-bar ul a[data-v-56c80043]{text-decoration:none;color:#fff}.nav-bar ul a[data-v-56c80043]:hover{text-underline-offset:4px;text-decoration:underline 2px solid}@media (max-width: 768px){.nav-bar ul a[data-v-56c80043]{display:block;text-align:center;font-size:1.5rem}}.nav-bar .mobile-menu[data-v-56c80043]{display:none}@media (max-width: 768px){.nav-bar .mobile-menu[data-v-56c80043]{width:fit-content;background:none;border:none;cursor:pointer;color:#fff;place-self:center end;padding:4px;display:grid;place-items:center;grid-column:3}.nav-bar .mobile-menu[data-v-56c80043]:hover{opacity:.8}}aside[data-v-7259c5c9]{position:fixed;top:var(--nav-height);right:0;width:calc(var(--aside-width) - var(--page-x-padding));max-height:calc(100vh - var(--nav-height) - 2rem);z-index:50;border-left:4px solid rgba(144,168,224,.3);padding:1rem;padding-right:0;margin-block:1rem;margin-right:var(--page-x-padding)}@media (max-width: 768px){aside[data-v-7259c5c9]{display:none}}.level-1[data-v-7259c5c9]{margin-left:1rem}.level-2[data-v-7259c5c9]{margin-left:2rem}.level-3[data-v-7259c5c9]{margin-left:3rem}.level-4[data-v-7259c5c9]{margin-left:4rem}.level-5[data-v-7259c5c9]{margin-left:5rem}.level-6[data-v-7259c5c9]{margin-left:6rem}.toc[data-v-7259c5c9]{display:block;margin-bottom:.25rem}ul[data-v-7259c5c9]{list-style:none;padding-left:0;margin:0}footer[data-v-9b00584c]{height:72px;background-color:#90a8e0;color:#fff;padding-inline:var(--page-x-padding);display:flex;justify-content:space-between;align-items:center}@media (max-width: 768px){footer[data-v-9b00584c]{flex-direction:column-reverse;gap:1rem;padding-block:2rem;height:unset}}footer>a[data-v-9b00584c]{text-decoration:none;color:#fff}footer>a[data-v-9b00584c]:hover{text-underline-offset:4px;text-decoration:underline 2px solid}.md p{margin-block:1rem}.md blockquote{border-left:4px solid #acdda1;padding:.5rem 1rem;background-color:#acdda133;box-shadow:0 0 1rem #0000001a}.md small{display:block;border-left:4px solid #acdda1;padding:.5rem 1rem;background-color:#acdda133;width:fit-content;margin-inline:auto;margin-block:1rem}.md hr{border:none;border-top:2px solid #acdda1}.md strong,.md b{font-weight:700}.md table{padding:0;margin-block:1rem;border:1px solid #acdda1;overscroll-behavior-x:contain;border-collapse:collapse;box-shadow:0 0 1rem #0000001a;display:block;width:100%;width:max-content;max-width:100%;overflow:auto}.md table th{background-color:#acdda1;color:#f9f3e6;border:1px solid #acdda1;font-weight:400}.md table th:not(:last-child){border-right:1px solid #f9f3e6}.md table th,.md table td{padding:.5rem 1rem;border:1px solid #acdda1}.md table tr:nth-child(odd){background-color:#acdda133}.md details summary{cursor:pointer;color:#90a8e0;width:fit-content}.md img{max-width:100%;max-height:80vh;display:block;margin-inline:auto;box-shadow:0 0 1rem #0000001a;border-radius:.25rem}.md a:has(img){display:block;width:fit-content;margin-inline:auto;border:4px solid transparent;border-radius:.5rem;transition:border-color .2s ease-in-out}.md a:has(img)>img{margin:none}.md a:has(img):hover{border-color:#90a8e0}.md div:has(>pre.shiki){box-shadow:0 0 1rem #0000001a;background-color:#fdf6e3;padding:0 1rem;border-radius:.5rem;position:relative;margin-block:1rem;display:grid;grid-template-columns:1fr}.md div:has(>pre.shiki):has(>.line-numbers-wrapper){grid-template-columns:auto 1fr}.md div:has(>pre.shiki):has(>.line-numbers-wrapper)>pre{order:2}.md div:has(>pre.shiki):has(>.line-numbers-wrapper)>.line-numbers-wrapper{order:1;padding-right:.5rem;padding-block:2rem 1rem;margin-right:.5rem;border-right:2px solid rgba(147,159,145,.2);color:#939f91;-webkit-user-select:none;user-select:none}.md div:has(>pre.shiki):has(>.line-numbers-wrapper)>.line-numbers-wrapper>.line-number{font-family:IBM Plex Mono,monospace;font-style:normal;font-weight:400;display:inline-block;width:100%;text-align:right}.md div:has(>pre.shiki)>pre{margin:0;padding:2rem 0 1rem;overscroll-behavior-x:contain;overflow-x:auto;scrollbar-width:thin}.md div:has(>pre.shiki)>pre .highlighted{background-color:#fce29a;outline:3px solid #fce29a}.md div:has(>pre.shiki)>button.copy{background:url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9ImN1cnJlbnRDb2xvciIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiIGNsYXNzPSJsdWNpZGUgbHVjaWRlLWNvcHktaWNvbiBsdWNpZGUtY29weSI+PHJlY3Qgd2lkdGg9IjE0IiBoZWlnaHQ9IjE0IiB4PSI4IiB5PSI4IiByeD0iMiIgcnk9IjIiLz48cGF0aCBkPSJNNCAxNmMtMS4xIDAtMi0uOS0yLTJWNGMwLTEuMS45LTIgMi0yaDEwYzEuMSAwIDIgLjkgMiAyIi8+PC9zdmc+);background-size:contain;background-repeat:no-repeat;background-position:center;position:absolute;top:.5rem;right:.5rem;width:1.5rem;height:1.5rem;border:none;padding:0;opacity:.5;cursor:pointer;border:.25rem solid transparent;border-radius:.375rem;transition:background-color .2s ease-in-out,border-color .2s ease-in-out,transform .1s ease-in-out}.md div:has(>pre.shiki)>button.copy:hover{background-color:#f8df9c;border-color:#f8df9c}.md div:has(>pre.shiki)>button.copy:active{transform:scale(.95)}.md div:has(>pre.shiki)>span.lang{position:absolute;top:.5rem;right:2.5rem;text-transform:uppercase;opacity:.5;-webkit-user-select:none;user-select:none}.md p>code{font-family:IBM Plex Mono,monospace;font-style:normal;font-weight:400;padding-inline:2px;background-color:#a1ddc340;outline:2px solid rgba(161,221,195,.25);border-radius:2px;color:#5c6a72}.md s{text-decoration-thickness:2px;text-decoration-color:#ff000080}.md :not(li)>.contains-task-list{padding-left:0}.md :not(li)>.contains-task-list .task-list-item::marker{content:""}.md li::marker{color:#90a8e0}.md ol>li::marker{font-family:IBM Plex Mono,monospace;font-style:normal;font-weight:400}.md h1>.header-anchor{opacity:0;transition:opacity .2s ease-in-out;position:relative}.md h1>.header-anchor:after{content:"#";font-size:.75em;position:absolute;top:0}.md h1:hover>.header-anchor{opacity:1}.md h2>.header-anchor{opacity:0;transition:opacity .2s ease-in-out;position:relative}.md h2>.header-anchor:after{content:"#";font-size:.75em;position:absolute;top:0}.md h2:hover>.header-anchor{opacity:1}.md h3>.header-anchor{opacity:0;transition:opacity .2s ease-in-out;position:relative}.md h3>.header-anchor:after{content:"#";font-size:.75em;position:absolute;top:0}.md h3:hover>.header-anchor{opacity:1}.md h4>.header-anchor{opacity:0;transition:opacity .2s ease-in-out;position:relative}.md h4>.header-anchor:after{content:"#";font-size:.75em;position:absolute;top:0}.md h4:hover>.header-anchor{opacity:1}.md h5>.header-anchor{opacity:0;transition:opacity .2s ease-in-out;position:relative}.md h5>.header-anchor:after{content:"#";font-size:.75em;position:absolute;top:0}.md h5:hover>.header-anchor{opacity:1}.md h6>.header-anchor{opacity:0;transition:opacity .2s ease-in-out;position:relative}.md h6>.header-anchor:after{content:"#";font-size:.75em;position:absolute;top:0}.md h6:hover>.header-anchor{opacity:1}.tags-line[data-v-928ff34c]{border-left:4px solid #90a8e0;padding-inline:1rem;display:flex;flex-wrap:wrap;align-items:center;gap:1ch}@media (max-width: 768px){.tags-line[data-v-928ff34c]{padding-inline:.5rem}}.tags-line>span[data-v-928ff34c]{color:#90a8e0}.layout[data-v-be94e0ad]{--nav-height: 72px;--aside-width: 320px;--page-x-padding: 64px}@media (max-width: 1024px){.layout[data-v-be94e0ad]{--page-x-padding: 32px;--aside-width: 240px}}@media (max-width: 768px){.layout[data-v-be94e0ad]{--nav-height: 64px;--aside-width: 0;--page-x-padding: 16px}}@media (min-width: 1536px){.layout[data-v-be94e0ad]{--page-x-padding: max( calc((100vw - 1536px)/2) , 64px)}}main[data-v-be94e0ad]{margin-top:var(--nav-height);overflow-x:hidden;min-height:calc(100vh - var(--nav-height) - 72px)}@media (max-width: 768px){main[data-v-be94e0ad]{min-height:calc(100vh - var(--nav-height))}}main.has-padding[data-v-be94e0ad]{padding-top:4rem;padding-bottom:6rem;padding-inline:var(--page-x-padding)}main.has-aside[data-v-be94e0ad]{padding-right:2rem;margin-right:var(--aside-width)}html{background-color:#f9f3e6}html,body{margin:0;font-size:100%}*{box-sizing:border-box;font-family:Poppins,sans-serif}h1{font-family:Montserrat,sans-serif;font-optical-sizing:auto;font-style:normal;font-weight:400;font-size:3.1573345183rem;line-height:1.5;margin:0;color:#222018}@media (max-width: 768px){h1{font-size:1.894400711rem}}h2{font-family:Montserrat,sans-serif;font-optical-sizing:auto;font-style:normal;font-weight:400;font-size:2.368593037rem;line-height:1.5;margin:0;color:#222018}@media (max-width: 768px){h2{font-size:1.4211558222rem}}h3{font-family:Montserrat,sans-serif;font-optical-sizing:auto;font-style:normal;font-weight:400;font-size:1.776889rem;line-height:1.5;margin:0;color:#222018}@media (max-width: 768px){h3{font-size:1.0661334rem}}h4{font-family:Montserrat,sans-serif;font-optical-sizing:auto;font-style:normal;font-weight:400;font-size:1.333rem;line-height:1.5;margin:0;color:#222018}@media (max-width: 768px){h4{font-size:.7998rem}}h5{font-family:Montserrat,sans-serif;font-optical-sizing:auto;font-style:normal;font-weight:400;font-size:1rem;line-height:1.5;margin:0;color:#222018}@media (max-width: 768px){h5{font-size:.6rem}}h6{font-family:Montserrat,sans-serif;font-optical-sizing:auto;font-style:normal;font-weight:400;font-size:.7501875469rem;line-height:1.5;margin:0;color:#222018}@media (max-width: 768px){h6{font-size:.4501125281rem}}h1{margin-bottom:1rem}code,code span{font-family:IBM Plex Mono,monospace;font-style:normal;font-weight:400}p{margin:0;color:#222018}a{color:#90a8e0;text-decoration:none;transition:all .2s ease-in-out}a:hover{color:#90a8e0;text-decoration:underline;text-underline-offset:.2rem;text-decoration-thickness:2px}a:visited{color:#90a8e0}
