*{padding:0;margin:0}@font-face{font-family:Lato;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/lato-latin-400-normal.woff2)format('woff2')}@font-face{font-family:Lato;font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/lato-latin-400-italic.woff2)format('woff2')}@font-face{font-family:Lato;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/lato-latin-700-normal.woff2)format('woff2')}:root{--main:#3e53cd;--bg:#ffffff;--fg:#000000;--fg-muted:#3e3e3e;--fg-soft:#535353;--fg-footer:#373737;--border:#d8d8d8;--border-soft:#f0f0f0;--card-bg:#fdfdfd;--selection-bg:#ffea8b;--selection-fg:#000000;--breakpoint0:1100px;--breakpoint1:800px;--breakpoint2:620px;color-scheme:light dark}@media(prefers-color-scheme:dark){:root{--main:#8ea1ff;--bg:#11141a;--fg:#e8eaed;--fg-muted:#c3c8d0;--fg-soft:#aab0bb;--fg-footer:#aab0bb;--border:#2a2f39;--border-soft:#1c2029;--card-bg:#161a22;--selection-bg:#3e53cd;--selection-fg:#ffffff}}html{color:var(--fg);background-color:var(--bg);font-family:Lato,sans-serif;line-height:1.15;-webkit-text-size-adjust:100%}a,a:hover{text-decoration:none}a:active{color:var(--main)}a:focus-visible{outline:2px solid var(--main);outline-offset:2px;border-radius:2px}a,a:visited{color:inherit}::selection{background-color:var(--selection-bg);color:var(--selection-fg)}.layout{min-height:100vh;min-height:100svh;display:flex;flex-direction:column}.layout>main{flex-grow:1;padding:60px 120px;padding-right:30px}.site-header{display:flex;justify-content:space-between;padding:20px 20px 10px 0;border-bottom:1px solid var(--border)}.site-header li{display:inline-block}.site-header li.logo{margin-left:4px;margin-right:-3px;width:120px;text-align:center}.site-header a{color:var(--fg);transition:.2s color}.site-header a path{fill:currentColor;transition:.2s fill}.svg-inline--fa{display:inline-block;height:1em;overflow:visible;vertical-align:-.125em}.site-header a.active,.site-header a:hover{color:var(--main)}.site-header a.active path,.site-header a:hover path{fill:var(--main)}.site-header nav[aria-label=Main] li{font-weight:700;text-transform:uppercase}.site-header nav[aria-label=Main] a{padding:13px}.site-header nav[aria-label=Main] li:nth-child(2) a{margin-left:-13px}.contact ul{list-style:none}.site-header nav.contact li svg{width:1.4em;height:1.4em;padding:10px}.mobile-nav{display:none}.site-footer{border-top:1px solid var(--border);text-align:center;padding:20px;font-size:15px;line-height:24px;color:var(--fg-footer)}.site-footer a:hover{color:var(--main)}.home-wrapper{display:flex;column-gap:120px}.home-wrapper>*{max-width:600px}.about header{display:flex;align-items:center;gap:25px;margin-bottom:30px}.about .profile{width:90px;height:90px;flex:0 0 90px;position:relative;overflow:hidden}.about .profile picture,.post-info .profile-small picture,.post-card figure picture,.content-page .hero picture,.not-found picture{display:contents}.about .profile img{position:absolute;inset:0;display:block;width:100%;height:100%;object-fit:cover;border-radius:50%}.about .profile picture{display:inline}.about h1{font-size:42px;font-weight:700;margin-top:-10px;margin-bottom:0}.about h2{font-size:24px;font-weight:700;color:#fff;background-image:linear-gradient(to right,#3023ae,#53a0fd);padding:0 4px;display:inline-block;margin-top:.5rem}.about p{font-size:19px;line-height:1.4;color:var(--fg-muted);margin-top:20px}.about a{border-radius:8px;box-shadow:2px 4px 8px color-mix(in srgb,var(--main) 20%,transparent);background-color:var(--card-bg);color:var(--fg-muted);padding:1px 4px;transition:box-shadow .1s ease-in-out}.about a:hover{box-shadow:2px 4px 8px color-mix(in srgb,var(--main) 60%,transparent)}.home-aside,.featured-projects{display:flex;flex-wrap:wrap;gap:20px;align-content:start}.home-aside h2{margin-bottom:10px}.posts ul{list-style-type:none}.posts-list{display:grid;grid-template-columns:repeat(auto-fill,255px);gap:25px}.posts-list>li{border-bottom:1px solid var(--border)}.post-card{width:255px;padding-bottom:5px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.post-card figure{max-width:100%;width:266px;height:160px;overflow:hidden;border:1px solid var(--border-soft);position:relative}.post-card figure img{position:absolute;inset:0;display:block;width:100%;height:100%;object-fit:cover;transition:transform .2s}.post-card figure picture{display:inline}.post-card figcaption{position:absolute;left:0;bottom:0;width:100%;display:flex;justify-content:space-between}.post-card figcaption>*{border-radius:2px;border:1px solid var(--border);background-color:color-mix(in srgb,var(--bg) 94%,transparent);font-size:12px;font-weight:700;color:var(--fg-muted);margin:8px;padding:3px}.post-card h2{margin:5px 0 0;font-size:16px;font-weight:700;line-height:normal;color:var(--main)}.post-card a:hover figure img{transform:scale(1.025)}.tags-list{margin-top:3px}.tags-list li{display:inline-block}.tags-list li+li{margin-left:5px}.tags-list a{font-size:12px;font-weight:700;line-height:normal;color:var(--fg-muted)}.duration{display:inline}.duration svg{margin-right:.3em;margin-bottom:-.1em;width:1em;height:1em}.content-page{max-width:600px}.content-page h1,.content-page h2,.content-page h3,.content-page h4,.content-page h5,.content-page h6{position:relative}.anchor.before{position:absolute;top:0;left:0;transform:translateX(-100%);padding-right:4px}.anchor{margin-top:-3px;width:32px;text-align:center;display:inline-block}.anchor svg{visibility:hidden}.content-page h1:hover>.anchor svg,.content-page h2:hover>.anchor svg,.content-page h3:hover>.anchor svg,.content-page h4:hover>.anchor svg,.content-page h5:hover>.anchor svg,.content-page h6:hover>.anchor svg,.anchor:focus svg{visibility:visible}.content-page header{color:var(--fg-soft)}.content-page header a{color:inherit}.content-page header a:hover{opacity:.8}.content-page header h1{font-size:38px;font-weight:400;margin:0;color:var(--fg)}.post-info{margin-top:6px;list-style:none}.post-info li{display:inline-block;margin-top:10px;height:24px;line-height:24px}.post-info .profile-small{display:inline-block;position:relative;width:24px;height:24px;overflow:hidden;vertical-align:top;margin-right:5px}.post-info img{position:absolute;inset:0;display:block;width:24px;height:24px;object-fit:cover;border-radius:50%}.post-info .profile-small picture{display:inline}.post-info svg{width:16px;height:16px}.page-tags{font-size:13px;margin-top:11px;list-style:none}.page-tags li{display:inline-block;border:1px solid var(--border);border-radius:2px;margin-top:6px;margin-right:5px}.page-tags li a{display:inline-block;padding:3px 5px}.content-page .hero{margin-top:40px;border:1px solid var(--border-soft);position:relative;overflow:hidden;aspect-ratio:2/1}.content-page .hero img{position:absolute;inset:0;width:100%;height:100%;display:block;object-fit:cover;object-position:50% 50%}.content-page .hero picture{display:inline}.post-content{margin-top:30px;color:var(--fg-muted);font-size:17px;line-height:1.7}.post-content a{color:var(--main)}.post-content h2,.post-content h3{margin-top:25px}.post-content h2{font-size:33px;font-weight:400}.post-content h3{font-size:23px;font-weight:700}.post-content blockquote{border-left:5px solid var(--border);padding-left:10px}.post-content img{max-width:100%;border:1px solid var(--border-soft)}.post-content figcaption{text-align:center;font-style:italic;margin-top:5px}.post-content pre,.post-content p,.post-content blockquote,.post-content ul,.post-content ol,.post-content table{margin-top:15px}.post-content .highlight{margin-top:15px}.post-content pre,.post-content code{color:var(--fg);direction:ltr;font-family:Consolas,Monaco,andale mono,ubuntu mono,monospace;hyphens:none;text-align:left;text-shadow:none;white-space:pre;word-break:normal;word-spacing:normal;tab-size:4}.post-content pre{position:relative;box-sizing:border-box;overflow:visible;margin:.5em 0 1em;padding:1px;background:var(--card-bg)!important;font-size:17px;line-height:1.5}.post-content>pre{margin-top:15px}.post-content pre>code{position:relative;display:block;overflow:auto;padding:0 1em;border-left:10px solid color-mix(in srgb,var(--main) 70%,transparent);background-color:var(--card-bg);background-image:linear-gradient(transparent 50%,rgba(69,142,209,4%) 50%);background-attachment:local;background-size:3em 3em;box-shadow:-1px 0 0 0 var(--main),0 0 0 1px var(--border);color:var(--fg);font-size:14px;line-height:1.5}.post-content .chroma .c,.post-content .chroma .c1,.post-content .chroma .cm{color:#7d8b99}.post-content .chroma .k,.post-content .chroma .kd,.post-content .chroma .kn,.post-content .chroma .kp,.post-content .chroma .kr,.post-content .chroma .kt{color:#1990b8;font-weight:400}.post-content .chroma .nf,.post-content .chroma .s,.post-content .chroma .s1,.post-content .chroma .s2,.post-content .chroma .sb,.post-content .chroma .sc,.post-content .chroma .sd,.post-content .chroma .se,.post-content .chroma .sh,.post-content .chroma .si,.post-content .chroma .sx,.post-content .chroma .kc,.post-content .chroma .nb{color:#2f9c0a}.post-content .chroma .p{color:#5f6364}.post-content .chroma .o,.post-content .chroma .ow{background:#ffffff80;color:#a67f59}.post-content .chroma .m,.post-content .chroma .mb,.post-content .chroma .mf,.post-content .chroma .mh,.post-content .chroma .mi,.post-content .chroma .mo,.post-content .chroma .il,.post-content .chroma .no{color:#c92c2c}@media(prefers-color-scheme:dark){.post-content .chroma .c,.post-content .chroma .c1,.post-content .chroma .cm{color:#9aa5b1}.post-content .chroma .k,.post-content .chroma .kd,.post-content .chroma .kn,.post-content .chroma .kp,.post-content .chroma .kr,.post-content .chroma .kt{color:#6cb6ff}.post-content .chroma .nf,.post-content .chroma .s,.post-content .chroma .s1,.post-content .chroma .s2,.post-content .chroma .sb,.post-content .chroma .sc,.post-content .chroma .sd,.post-content .chroma .se,.post-content .chroma .sh,.post-content .chroma .si,.post-content .chroma .sx,.post-content .chroma .kc,.post-content .chroma .nb{color:#7ee787}.post-content .chroma .p{color:#c3c8d0}.post-content .chroma .o,.post-content .chroma .ow{background:0 0;color:#ffab70}.post-content .chroma .m,.post-content .chroma .mb,.post-content .chroma .mf,.post-content .chroma .mh,.post-content .chroma .mi,.post-content .chroma .mo,.post-content .chroma .il,.post-content .chroma .no{color:#ff7b72}.post-content :not(pre)>code{color:#ff7b72}.about h2{color:#fff}}.post-content :not(pre)>code{position:relative;box-sizing:border-box;padding:.2em;border:1px solid var(--border);border-radius:.3em;background:var(--card-bg);color:#c92c2c;font-size:14px;line-height:1.5;white-space:normal}.post-content ol,.post-content ul{margin-left:30px}.post-content ul{list-style-type:circle}.attachments,.comments{margin-top:25px}.attachments h1{display:inline-block;margin-top:.67em;margin-bottom:20px;font-size:25px;font-weight:100}.attachments ul{list-style:none}.attachments li{display:inline-block}.attachments li a{display:inline-flex;align-items:center;gap:10px;padding:14px 18px;border:1px solid var(--border);line-height:1;color:var(--fg-soft)}.attachments li a:hover{color:var(--main);border-color:color-mix(in srgb,var(--main) 60%,transparent)}.attachments li a svg{width:20px;height:20px}.comments{margin-top:40px}#disqus_recommendations{display:none}.not-found{max-width:500px;font-size:19px;line-height:1.4;color:var(--fg-muted)}.not-found a{color:var(--main)}.not-found h1{margin-bottom:25px}.not-found p{margin:15px 0}.not-found h2{margin:30px 0 20px}.not-found figure{text-align:center}.not-found-image{position:relative;overflow:hidden;aspect-ratio:500/333}.not-found .not-found-image picture{display:inline}.not-found .not-found-image img{position:absolute;inset:0;width:100%;height:100%;max-width:none;object-fit:cover;object-position:50% 50%}.not-found figcaption{font-style:italic;margin-top:5px}.not-found img{max-width:100%;height:auto;display:block}@media screen and (max-width:1100px){.home-wrapper{flex-direction:column}.home-aside{margin-top:50px}}@media screen and (max-width:800px){.layout>main{padding:max(env(safe-area-inset-top),30px)max(env(safe-area-inset-right),30px)max(env(safe-area-inset-bottom),30px)max(env(safe-area-inset-left),30px)}}@media screen and (max-width:620px){.site-header{padding:30px 30px 30px 0}.site-header li:not(.logo){display:none}.mobile-nav{display:block}.mobile-toggle{position:fixed;top:15px;right:15px;margin:0 auto;width:60px;height:60px;font-size:28px;box-shadow:1px 4px 10px #3942c2e6;border-radius:100%;background-image:linear-gradient(154deg,#728be8,var(--main));cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center}.mobile-toggle svg{width:32px;height:1em}.mobile-toggle svg path{fill:#fff}.mobile-nav input[type=checkbox]{display:none}.mobile-nav input[type=checkbox]+.mobile-toggle svg:nth-child(1){display:block}.mobile-nav input[type=checkbox]+.mobile-toggle svg:nth-child(2){display:none}.mobile-nav input[type=checkbox]+.mobile-toggle+.mobile-menu{display:none}.mobile-nav input[type=checkbox]:checked+.mobile-toggle svg:nth-child(1){display:none}.mobile-nav input[type=checkbox]:checked+.mobile-toggle svg:nth-child(2){display:block}.mobile-nav input[type=checkbox]:checked+.mobile-toggle+.mobile-menu{display:grid}.mobile-menu{position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 50% 90%,#040f50cc,#040f50);backdrop-filter:blur(5px);font-size:22px;font-weight:700;color:#fff;text-transform:uppercase;justify-content:center;align-content:center;z-index:1}.mobile-entries{text-align:center}.mobile-entries ul,.mobile-entries li{list-style:none;display:inline-block}.mobile-entries>li{margin:0 auto;width:80%}.mobile-entries>li+li::before{background-image:linear-gradient(to right,#ffffff02,#ffffff 50%,#ffffff00);width:100%;height:1px;display:block;content:''}.mobile-entries a{font-size:22px;font-weight:700;text-align:center;color:#fff;padding:20px 0;display:inline-block;width:100%}.mobile-entries .contact a{color:#fff;display:unset}.mobile-entries .contact svg{width:1.4em;height:1.4em;padding:20px 15px;fill:#fff}.post-content code{word-break:break-all}}