@font-face{font-display:swap;font-family:roboto;font-style:normal;font-weight:400;src:url(fonts/Roboto/roboto-v30-latin-regular.eot);src:url(fonts/Roboto/roboto-v30-latin-regular.eot?#iefix)format("embedded-opentype"),url(fonts/Roboto/roboto-v30-latin-regular.woff2)format("woff2"),url(fonts/Roboto/roboto-v30-latin-regular.woff)format("woff"),url(fonts/Roboto/roboto-v30-latin-regular.ttf)format("truetype"),url(fonts/Roboto/roboto-v30-latin-regular.svg#Roboto)format("svg")}*{-webkit-transition:background-color 75ms ease-in,border-color 75ms ease-in;-moz-transition:background-color 75ms ease-in,border-color 75ms ease-in;-ms-transition:background-color 75ms ease-in,border-color 75ms ease-in;-o-transition:background-color 75ms ease-in,border-color 75ms ease-in;transition:background-color 75ms ease-in,border-color 75ms ease-in}.notransition{-webkit-transition:none;-moz-transition:none;-ms-transition:none;-o-transition:none;transition:none}html{overflow-x:hidden;width:100%}body,h1,h2,h3,h4,h5,h6,p,blockquote,pre,hr,dl,dd,ol,ul,figure{margin:0;padding:0}body{min-height:100vh;overflow-x:hidden;position:relative;color:#434648;background-color:#fff;font:16px/1.85 Roboto,sans-serif;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-webkit-font-feature-settings:"kern" 1;-moz-font-feature-settings:"kern" 1;-o-font-feature-settings:"kern" 1;font-feature-settings:"kern" 1;font-kerning:normal;box-sizing:border-box}h1,h2,h3,h4,h5,h6,p,blockquote,pre,ul,ol,dl,figure{margin-top:10px;margin-bottom:10px}strong,b{font-weight:700;color:#0d122b}hr{border-bottom:0;border-style:solid;border-color:#ececec}img{max-width:100%;vertical-align:middle;-webkit-user-drag:none;margin:0 auto;text-align:center}figure{position:relative}figure>img{display:block;position:relative}figcaption{font-size:13px;text-align:center}ul li{display:list-item;text-align:-webkit-match-parent}ol li{position:relative}ul,ol{margin-top:0;margin-left:30px}li{padding-bottom:1px;padding-top:1px}li:before{color:#0d122b}li>ul,li>ol{margin-bottom:2px;margin-top:0}h1,h2,h3,h4,h5,h6{color:#0d122b;font-weight:700}h1+ul,h1+ol,h2+ul,h2+ol,h3+ul,h3+ol,h4+ul,h4+ol,h5+ul,h5+ol,h6+ul,h6+ol{margin-top:10px}@media screen and (max-width:768px){h1,h2,h3,h4,h5,h6{scroll-margin-top:65px}}h1>a,h2>a,h3>a,h4>a,h5>a,h6>a{text-decoration:none;border:none}h1>a:hover,h2>a:hover,h3>a:hover,h4>a:hover,h5>a:hover,h6>a:hover{text-decoration:none;border:none}a{color:inherit;text-decoration-color:#d2c7c7}a:hover{color:#003fff}a:focus{outline:3px solid rgba(0,54,199,.6);outline-offset:2px}del{color:inherit}em{color:inherit}blockquote{color:#525b66;opacity:.9;border-left:5px solid #c4c8cc;padding:0 0 0 1rem;margin-left:.3rem;margin-right:.3rem;font-size:1em}blockquote>:last-child{margin-bottom:0;margin-top:0}.wrapper{max-width:-webkit-calc(720px - (30px * 2));max-width:calc(720px - (30px * 2));position:relative;margin-right:auto;margin-left:auto;padding-right:30px;padding-left:30px}@media screen and (max-width:768px){.wrapper{max-width:-webkit-calc(720px - (30px));max-width:calc(720px - (30px));padding-right:20px;padding-left:20px}.wrapper.blurry{animation:.2s ease-in forwards blur;-webkit-animation:.2s ease-in forwards blur}}u{text-decoration-color:#d2c7c7}small{font-size:14px}sup{border-radius:10%;top:-3px;left:2px;font-size:small;position:relative;margin-right:2px}.overflow-table{overflow-x:auto}table{width:100%;margin-top:15px;border-collapse:collapse;font-size:14px}table thead{font-weight:700;color:#0d122b;border-bottom:1px solid #ececec}table th,table td,table tr{border:1px solid #ececec;padding:2px 7px}.navbar:after,.wrapper:after{content:"";display:table;clear:both}mark,::selection{background:#fffba0;color:#0d122b}.gist table{border:0}.gist table tr,.gist table td{border:0}.navbar{height:auto;max-width:calc(890px - (30px * 2));max-width:-webkit-calc(890px - (30px * 2));position:relative;margin-right:auto;margin-left:auto;border-bottom:1px solid #ececec;padding:.5rem .3rem}.logo{float:left;margin:.5rem 0 0 1rem}.logo>svg{opacity:.7}.logo:hover>svg{opacity:1}@media screen and (max-width:768px){.logo{padding-top:.3rem}}.menu{user-select:none;-ms-user-select:none;-webkit-user-select:none}.menu ul{margin:0}.menu .menu-separator{margin-right:.7rem}@media screen and (max-width:768px){.menu .menu-separator{display:none}}.menu a#mode{-webkit-transform:scale(1,1);transform:scale(1,1);opacity:.7;z-index:1}.menu a#mode:hover{cursor:pointer;opacity:1}.menu a#mode:active{-webkit-transform:scale(.9,.9);transform:scale(.9,.9)}.menu a#mode .mode-moon{display:block}.menu a#mode .mode-moon line{stroke:#0d122b;fill:none}.menu a#mode .mode-moon circle{fill:#0d122b;stroke:#0d122b}.menu a#mode .mode-sunny{display:none}.menu a#mode .mode-sunny line{stroke:#eaeaea;fill:none}.menu a#mode .mode-sunny circle{fill:none;stroke:#eaeaea}.menu .trigger{float:right;display:flex;align-items:center}.menu .menu-trigger{display:none}.menu .menu-icon{display:none}.menu li{display:inline-block;margin:0;padding:0;list-style:none}@media screen and (max-width:768px){.menu li{display:block;margin:0;padding:0;list-style:none}}.menu .menu-link{color:#0d122b;line-height:2.25;text-decoration:none;padding:.3rem .5rem;opacity:.7;letter-spacing:.015rem}.menu .menu-link:hover{opacity:1}.menu .menu-link:not(:last-child){margin-right:5px}@media screen and (max-width:768px){.menu .menu-link{opacity:.8}}.menu .menu-link.active{opacity:1;font-weight:600}@media screen and (max-width:768px){.menu{position:fixed;top:0;left:0;right:0;z-index:2;text-align:center;height:50px;background-color:#fff;border-bottom:1px solid #ececec}.menu a#mode{left:10px;top:12px}.menu .menu-icon{display:block;position:absolute;right:0;margin:.7rem .3rem 0 0;cursor:pointer;text-align:center;z-index:1}.menu .menu-icon>svg{opacity:.7}.menu .menu-icon:hover>svg{opacity:1}.menu .menu-icon:active{-webkit-transform:scale(.9,.9);transform:scale(.9,.9)}.menu input[type=checkbox]:not(:checked)~.trigger{clear:both;visibility:hidden}.menu input[type=checkbox]:checked~.trigger{position:fixed;animation:.2s ease-in forwards fadein;-webkit-animation:.2s ease-in forwards fadein;flex-direction:column;justify-content:center;height:100vh;width:100%;top:0}.menu .menu-link{display:block;box-sizing:border-box;font-size:1.1em}.menu .menu-link:not(:last-child){margin:0;padding:2px 0}}.author{margin-top:6.3rem;margin-bottom:7.2rem;text-align:center}@media screen and (max-width:768px){.author{margin-bottom:3em}}.author .author-avatar{width:70px;height:70px;border-radius:100%;user-select:none;-ms-user-select:none;-webkit-user-select:none;-webkit-animation:.5s ease-in forwards fadein;animation:.5s ease-in forwards fadein;opacity:1;object-fit:cover}.author .author-name{font-size:1.7em;margin-bottom:2px}.author .author-bio{margin:0 auto;opacity:.9;max-width:393px;line-height:1.688}.posts-item-note{padding-bottom:.3rem;font-weight:500;color:#0d122b}.post-item{display:flex;padding-top:5px;padding-bottom:6px;justify-content:space-between;flex-direction:row;align-items:center}.post-item:not(:first-child){border-top:1px solid #ececec}.post-item .post-item-date{min-width:96px;color:#0d122b}@media screen and (max-width:768px){.post-item .post-item-date{font-size:16px}}.post-item .post-item-title{margin:0;border:0;padding:0;font-size:16px;font-weight:400;letter-spacing:.1px}@media screen and (max-width:768px){.post-item .post-item-title{max-width:15rem}}.post-item .post-item-title a{color:#434648;transition:all 150ms ease-in 0s}.post-item .post-item-title a:hover,.post-item .post-item-title afocus{color:#0d122b}.footer{margin-top:8em;margin-bottom:2em;text-align:center}@media screen and (max-width:768px){.footer{margin-top:3em}}.footer span.footer_item{opacity:.8;font-weight:700;font-size:14px}.footer a.footer_item{opacity:.8;text-decoration:none}.footer a.footer_item:not(:last-child){margin-right:10px}.footer a.footer_item:not(:last-child):hover{opacity:1}.footer_copyright{font-size:13px;display:block;color:#6b7886;opacity:.8;margin-top:.7rem;padding:.3rem .95rem}.footer_social-icons a{text-decoration:none;margin-right:.31rem}.footer_social-icons svg{color:#888a90;height:24px;width:24px}.footer_social-icons svg:hover{color:#ddd}.not-found{text-align:center;display:flex;justify-content:center;flex-direction:column;height:75vh}.not-found .title{font-size:5em;font-weight:700;line-height:1.1;color:#0d122b;text-shadow:1px 0 0 #003fff}.not-found .phrase{color:#434648}.not-found .solution{color:#003fff;letter-spacing:.5px}.not-found .solution:hover{color:#0036c7}.search-article{position:relative;margin-bottom:50px}.search-article label[for=search-input]{position:relative;top:10px;left:11px}.search-article input[type=search]{top:0;left:0;border:0;width:100%;height:40px;outline:none;position:absolute;border-radius:5px;padding:10px 10px 10px 35px;color:#434648;-webkit-appearance:none;font-size:16px;background-color:rgba(128,128,128,.1);border:1px solid rgba(128,128,128,.1)}.search-article input[type=search]::-webkit-input-placeholder{color:gray}.search-article input[type=search]::-webkit-search-decoration,.search-article input[type=search]::-webkit-search-results-decoration{display:none}#search-results{text-align:center}#search-results li{text-align:left}.archive-tags{height:auto}.archive-tags .tag-item{padding:1px 3px;border-radius:2px;border:1px solid rgba(128,128,128,.1);background-color:rgba(128,128,128,.1)}sub,sup{font-size:79%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}kbd{font-size:85%;border-radius:3px;color:#333638;background:#d8dbe2;display:inline-block;font-family:Consolas,monaco,monospace;line-height:1;padding:2px 4px;white-space:nowrap}mark{background:#ff0;color:#000;border-radius:3px}@media screen and (max-width:768px){.wrapper.post{padding-left:15px;padding-right:15px}}.header{margin-top:7.8em}.header .header-title{font-size:2em;line-height:1.2;margin-top:10px;margin-bottom:20px}.header .header-title.center{text-align:center}@media screen and (max-width:768px){.header .header-title{font-size:1.9em}}.post-meta{padding-top:3px;line-height:1.3;color:#6b7886}.post-meta time{position:relative;margin-right:1.5em}.post-meta span[itemprop=author]{border-bottom:1px dotted #ececec}.page-content{padding-top:8px}.page-content iframe{text-align:center}.page-content figure img{border-radius:2px}.page-content figure figcaption{margin-top:5px;font-style:italic;font-size:14px}.page-content a{color:#003fff;text-decoration:none}.page-content a[target=_blank]::after{content:" \2197";font-size:14px;line-height:0;position:relative;bottom:5px;vertical-align:baseline}.page-content a:hover{color:#0036c7}.page-content a:focus{color:#003fff}.page-content>p{margin:0;padding-top:15px;padding-bottom:15px}.page-content ul.task-list{list-style:none;margin:0}.page-content ul.task-list li::before{content:""}.page-content ul.task-list li input[type=checkbox]{margin-right:10px}.page-content dl dt{font-weight:700}.page-content h1,.page-content h2,.page-content h3,.page-content h4,.page-content h5,.page-content h6{color:#0d122b;font-weight:700;margin-top:30px;margin-bottom:0;letter-spacing:.03rem}.page-content h1:hover .anchor-head,.page-content h2:hover .anchor-head,.page-content h3:hover .anchor-head,.page-content h4:hover .anchor-head,.page-content h5:hover .anchor-head,.page-content h6:hover .anchor-head{color:#003fff;opacity:1}.page-content h1 .anchor-head,.page-content h2 .anchor-head,.page-content h3 .anchor-head,.page-content h4 .anchor-head,.page-content h5 .anchor-head,.page-content h6 .anchor-head{position:relative;opacity:0;outline:none}.page-content h1 .anchor-head::before,.page-content h2 .anchor-head::before,.page-content h3 .anchor-head::before,.page-content h4 .anchor-head::before,.page-content h5 .anchor-head::before,.page-content h6 .anchor-head::before{content:"#";position:absolute;right:-3px;width:1em;font-weight:700}.page-content h1{font-size:24px}.page-content h2{font-size:22px}.page-content h3{font-size:20px}.page-content h4{font-size:20px}.page-content h5{font-size:16px}.page-content h6{font-size:14px}.post-nav{display:flex;position:relative;margin-top:5em;border-top:1px solid #ececec;line-height:1.4}.post-nav .post-nav-item{border-bottom:0;font-weight:700;padding-bottom:10px;width:50%;padding-top:10px;text-decoration:none;box-sizing:border-box}.post-nav .post-nav-item .post-title{color:#0d122b}.post-nav .post-nav-item:hover .post-title,.post-nav .post-nav-item:focus .post-title{color:#0036c7;opacity:.9}.post-nav .post-nav-item .nav-arrow{font-weight:400;font-size:14px;color:#6b7886;margin-bottom:3px}.post-nav .post-nav-item:nth-child(odd){padding-left:0;padding-right:20px}.post-nav .post-nav-item:nth-child(even){text-align:right;padding-right:0;padding-left:20px}@media screen and (max-width:768px){.post-nav{display:block;font-size:14px}.post-nav .post-nav-item{display:block;width:100%}.post-nav .post-nav-item:nth-child(even){border-left:0;padding-left:0;border-top:1px solid #ececec}}.post-updated-at{font-family:ubuntu mono,monospace}code{font-family:Consolas,monospace;text-rendering:optimizeLegibility;font-feature-settings:"calt" 1;font-variant-ligatures:normal;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;font-size:inherit}li>code,p>code{white-space:pre-wrap;font-size:.9em;padding:1px 3px;position:relative;top:-1px;color:#333638;background-color:#d8dbe2;border-radius:2px;border:1px solid rgba(128,128,128,.1)}pre{background-color:#1a1b21;border-radius:.3rem;padding:.5rem 1rem;display:block;overflow-x:auto}@media screen and (max-width:768px){pre{margin:0 calc(51% - 51vw)}}pre::-webkit-scrollbar{height:.5rem}pre::-webkit-scrollbar-track{background:#606071;border-radius:.1rem}pre::-webkit-scrollbar-thumb{background:#999ea2;border-radius:.3rem}pre::-webkit-scrollbar-thumb:hover{background:#424546}pre>code{color:#fff;max-width:50rem;margin-left:auto;margin-right:auto;line-height:1.5;display:block;border:0}.highlight table td{padding:5px}.highlight table pre{margin:0}.highlight,.highlight .w{color:#fbf1c7}.highlight .err{color:#fb4934;font-weight:700}.highlight .c,.highlight .cd,.highlight .cm,.highlight .c1,.highlight .cs{color:#928374;font-style:italic}.highlight .cp{color:#8ec07c}.highlight .nt{color:#fb4934}.highlight .o,.highlight .ow{color:#fbf1c7}.highlight .p,.highlight .pi{color:#fbf1c7}.highlight .gi{color:#b8bb26;background-color:#282828}.highlight .gd{color:#fb4934;background-color:#282828}.highlight .gh{color:#b8bb26;font-weight:700}.highlight .k,.highlight .kn,.highlight .kp,.highlight .kr,.highlight .kv{color:#fb4934}.highlight .kc{color:#d3869b}.highlight .kt{color:#fabd2f}.highlight .kd{color:#fe8019}.highlight .s,.highlight .sb,.highlight .sc,.highlight .sd,.highlight .s2,.highlight .sh,.highlight .sx,.highlight .s1{color:#b8bb26;font-style:italic}.highlight .si{color:#b8bb26;font-style:italic}.highlight .sr{color:#b8bb26;font-style:italic}.highlight .se{color:#fe8019}.highlight .nn{color:#8ec07c}.highlight .nc{color:#8ec07c}.highlight .no{color:#d3869b}.highlight .na{color:#b8bb26}.highlight .m,.highlight .mf,.highlight .mh,.highlight .mi,.highlight .il,.highlight .mo,.highlight .mb,.highlight .mx{color:#d3869b}.highlight .ss{color:#83a598}details{cursor:pointer}.toc{margin:1.1rem 0 1rem;padding:.5rem 1rem;border-radius:.3rem;background-color:#edecec}.toc ul{padding-top:1rem;margin-left:1rem;padding-left:1rem}.toc ul li{margin-bottom:.5em;line-height:1.4}@keyframes fadein{0%{opacity:.2}100%{opacity:1}}@keyframes blur{0%{filter:blur(0)}100%{filter:blur(4px)}}.embed-responsive{height:0;max-width:100%;overflow:hidden;position:relative;padding-bottom:56.25%;margin-top:20px}.embed-responsive iframe,.embed-responsive object,.embed-responsive embed{top:0;left:0;width:100%;height:100%;position:absolute}.main-404{padding:9rem 0;text-align:center}@media(prefers-color-scheme:dark){html:not(.light) body{color:#babdc4;background-color:#131418}html:not(.light) h1,html:not(.light) h2,html:not(.light) h3,html:not(.light) h4,html:not(.light) h5,html:not(.light) h6{color:#eaeaea}html:not(.light) table thead{color:#eaeaea;border-color:#1b1d25}html:not(.light) table th,html:not(.light) table td,html:not(.light) table tr{border-color:#1b1d25}html:not(.light) .page-content a{color:#77a8fd}html:not(.light) .page-content a:hover,html:not(.light) .page-content a:active,html:not(.light) .page-content a:focus{color:#5292ff}html:not(.light) .page-content h3{border-color:#1b1d25}html:not(.light) .page-content h1 .anchor-head,html:not(.light) .page-content h2 .anchor-head,html:not(.light) .page-content h3 .anchor-head,html:not(.light) .page-content h4 .anchor-head,html:not(.light) .page-content h5 .anchor-head,html:not(.light) .page-content h6 .anchor-head{color:#77a8fd}html:not(.light) .toc{background-color:#323232}html:not(.light) #totop{color:#babdc4;background-color:#676767b3}html:not(.light) #totop:hover{background-color:#676767}html:not(.light) li>code,html:not(.light) p>code{font-size:.9em;padding:1px 3px;position:relative;top:-1px;color:#c2c4ca;background-color:#2d2d2d;border-radius:2px;border:1px solid rgba(128,128,128,.1)}html:not(.light) kbd{color:#c2c4ca;background-color:#2d2d2d}html:not(.light) hr{border-color:#1b1d25}html:not(.light) .post-meta{color:#767f87}html:not(.light) .post-meta time::after{background-color:#1b1d25}html:not(.light) .post-meta span[itemprop=author]{border-color:#1b1d25}html:not(.light) a{color:inherit;text-decoration-color:#4a4d56}html:not(.light) a:hover{color:#77a8fd}html:not(.light) a:focus{outline-color:rgba(44,118,246,.6)}html:not(.light) li:before{color:#eaeaea}html:not(.light) blockquote{color:#9b9ba3;border-color:#4a4d56}html:not(.light) strong,html:not(.light) b{color:#eaeaea}html:not(.light) .navbar{border-color:#1b1d25}html:not(.light) .navbar .menu a#mode .mode-sunny{display:block}html:not(.light) .navbar .menu a#mode .mode-moon{display:none}html:not(.light) .navbar .menu .menu-link{color:#eaeaea}}@media screen and (prefers-color-scheme:dark) and (max-width:768px){html:not(.light) .navbar .menu{background-color:#131418;border-color:#1b1d25}html:not(.light) .navbar .menu input[type=checkbox]:checked~.trigger{background:#131418}}@media(prefers-color-scheme:dark){html:not(.light) .post-item:not(:first-child){border-color:#1b1d25}html:not(.light) .post-item .post-item-date{color:#eaeaea}html:not(.light) .post-item .post-item-title a{color:#babdc4}html:not(.light) .post-item .post-item-title a:hover,html:not(.light) .post-item .post-item-title afocus{color:#eaeaea}html:not(.light) .post-nav{border-color:#1b1d25}html:not(.light) .post-nav .post-nav-item{font-weight:700}html:not(.light) .post-nav .post-nav-item .post-title{color:#eaeaea;opacity:.9}html:not(.light) .post-nav .post-nav-item:hover .post-title,html:not(.light) .post-nav .post-nav-item:focus .post-title{color:#5292ff}html:not(.light) .post-nav .post-nav-item .nav-arrow{color:#767f87}}@media screen and (prefers-color-scheme:dark) and (max-width:768px){html:not(.light) .post-nav .post-nav-item:nth-child(even){border-color:#1b1d25}}@media(prefers-color-scheme:dark){html:not(.light) .footer span.footer_item{color:#eaeaea}html:not(.light) .footer a.footer_item:not(:last-child){color:#eaeaea}html:not(.light) .footer .footer_copyright{color:#767f87;opacity:1}html:not(.light) .not-found .title{color:#eaeaea;text-shadow:1px 0 0 #77a8fd}html:not(.light) .not-found .phrase{color:#babdc4}html:not(.light) .not-found .solution{color:#77a8fd}html:not(.light) .not-found .solution:hover{color:#5292ff}html:not(.light) .search-article input[type=search]{color:#babdc4}html:not(.light) .search-article input[type=search]::-webkit-input-placeholder{color:rgba(128,128,128,.8)}}html.dark body{color:#babdc4;background-color:#131418}html.dark h1,html.dark h2,html.dark h3,html.dark h4,html.dark h5,html.dark h6{color:#eaeaea}html.dark table thead{color:#eaeaea;border-color:#1b1d25}html.dark table th,html.dark table td,html.dark table tr{border-color:#1b1d25}html.dark .page-content a{color:#77a8fd}html.dark .page-content a:hover,html.dark .page-content a:active,html.dark .page-content a:focus{color:#5292ff}html.dark .page-content h3{border-color:#1b1d25}html.dark .page-content h1 .anchor-head,html.dark .page-content h2 .anchor-head,html.dark .page-content h3 .anchor-head,html.dark .page-content h4 .anchor-head,html.dark .page-content h5 .anchor-head,html.dark .page-content h6 .anchor-head{color:#77a8fd}html.dark .toc{background-color:#323232}html.dark #totop{color:#babdc4;background-color:#676767b3}html.dark #totop:hover{background-color:#676767}html.dark li>code,html.dark p>code{font-size:.9em;padding:1px 3px;position:relative;top:-1px;color:#c2c4ca;background-color:#2d2d2d;border-radius:2px;border:1px solid rgba(128,128,128,.1)}html.dark kbd{color:#c2c4ca;background-color:#2d2d2d}html.dark hr{border-color:#1b1d25}html.dark .post-meta{color:#767f87}html.dark .post-meta time::after{background-color:#1b1d25}html.dark .post-meta span[itemprop=author]{border-color:#1b1d25}html.dark a{color:inherit;text-decoration-color:#4a4d56}html.dark a:hover{color:#77a8fd}html.dark a:focus{outline-color:rgba(44,118,246,.6)}html.dark li:before{color:#eaeaea}html.dark blockquote{color:#9b9ba3;border-color:#4a4d56}html.dark strong,html.dark b{color:#eaeaea}html.dark .navbar{border-color:#1b1d25}html.dark .navbar .menu a#mode .mode-sunny{display:block}html.dark .navbar .menu a#mode .mode-moon{display:none}html.dark .navbar .menu .menu-link{color:#eaeaea}@media screen and (max-width:768px){html.dark .navbar .menu{background-color:#131418;border-color:#1b1d25}html.dark .navbar .menu input[type=checkbox]:checked~.trigger{background:#131418}}html.dark .post-item:not(:first-child){border-color:#1b1d25}html.dark .post-item .post-item-date{color:#eaeaea}html.dark .post-item .post-item-title a{color:#babdc4}html.dark .post-item .post-item-title a:hover,html.dark .post-item .post-item-title afocus{color:#eaeaea}html.dark .post-nav{border-color:#1b1d25}html.dark .post-nav .post-nav-item{font-weight:700}html.dark .post-nav .post-nav-item .post-title{color:#eaeaea;opacity:.9}html.dark .post-nav .post-nav-item:hover .post-title,html.dark .post-nav .post-nav-item:focus .post-title{color:#5292ff}html.dark .post-nav .post-nav-item .nav-arrow{color:#767f87}@media screen and (max-width:768px){html.dark .post-nav .post-nav-item:nth-child(even){border-color:#1b1d25}}html.dark .footer span.footer_item{color:#eaeaea}html.dark .footer a.footer_item:not(:last-child){color:#eaeaea}html.dark .footer .footer_copyright{color:#767f87;opacity:1}html.dark .not-found .title{color:#eaeaea;text-shadow:1px 0 0 #77a8fd}html.dark .not-found .phrase{color:#babdc4}html.dark .not-found .solution{color:#77a8fd}html.dark .not-found .solution:hover{color:#5292ff}html.dark .search-article input[type=search]{color:#babdc4}html.dark .search-article input[type=search]::-webkit-input-placeholder{color:rgba(128,128,128,.8)}.list-page .post-year{padding-bottom:.5rem}.icon-star{color:orange;height:16px;margin-right:1rem;width:16px;display:block}.post-item-right{margin-left:auto;margin-right:0}.projects-page .projects-intro{text-align:center;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.projects-page .projects-intro p{color:#6b7886;font-size:15.008px;line-height:1.6}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-top:2rem}@media screen and (max-width:768px){.projects-grid{grid-template-columns:1fr;gap:1.5rem}}.project-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.1);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}.project-card .project-image{position:relative;overflow:hidden;height:200px;background:#ececec}.project-card .project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card .project-image .project-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.project-card .project-image .project-placeholder svg{width:100%;height:100%}.project-card .project-image a:hover img{transform:scale(1.05)}.project-card .project-content{padding:1.5rem}.project-card .project-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:700}.project-card .project-title a{color:#434648;text-decoration:none}.project-card .project-title a:hover{color:#003fff}.project-card .project-description{color:#6b7886;font-size:14px;line-height:1.6;margin-bottom:1rem}.project-card .project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.project-card .project-technologies .tech-tag{background:#d8dbe2;color:#333638;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:400}.project-card .project-actions{display:flex;gap:.75rem;flex-wrap:wrap}.project-card .project-actions .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:4px;text-decoration:none;font-size:14px;font-weight:400;transition:all .2s ease;border:1px solid transparent}.project-card .project-actions .btn .icon{width:16px;height:16px}.project-card .project-actions .btn.btn-primary{background:#003fff;color:#fff}.project-card .project-actions .btn.btn-primary:hover{background:#0036c7}.project-card .project-actions .btn.btn-secondary{background:0 0;color:#434648;border-color:#c4c8cc}.project-card .project-actions .btn.btn-secondary:hover{background:#ececec;border-color:#6b7886}.empty-state{text-align:center;padding:3rem 1rem;color:#6b7886}.empty-state h3{margin-bottom:.5rem;color:#434648}.empty-state p{font-size:15.008px}.project-single .project-article{max-width:1200px;margin:0 auto;padding:0 15px}@media screen and (max-width:768px){.project-single .project-article{padding:0 15px}}.project-single .project-hero{margin-bottom:3rem}.project-single .project-hero .project-hero-image{margin-bottom:2rem;border-radius:12px;overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,.1)}.project-single .project-hero .project-hero-image .hero-img{width:100%;height:auto;display:block;transition:transform .3s ease}.project-single .project-hero .project-hero-image .hero-img:hover{transform:scale(1.02)}.project-single .project-hero .project-hero-content{text-align:center}@media screen and (max-width:769px){.project-single .project-hero .project-hero-content{text-align:left}}.project-single .project-hero .project-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;color:#434648;line-height:1.2}@media screen and (max-width:768px){.project-single .project-hero .project-title{font-size:2rem}}.project-single .project-hero .project-description{font-size:1.2rem;color:#6b7886;margin-bottom:1.5rem;line-height:1.6;max-width:800px;margin-left:auto;margin-right:auto}@media screen and (max-width:769px){.project-single .project-hero .project-description{margin-left:0;margin-right:0}}@media screen and (max-width:768px){.project-single .project-hero .project-description{font-size:1.1rem}}.project-single .project-hero .project-technologies{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem}@media screen and (max-width:769px){.project-single .project-hero .project-technologies{justify-content:flex-start}}.project-single .project-hero .project-technologies .tech-tag{background:#ececec;color:#434648;padding:.4rem .8rem;border-radius:20px;font-size:.9rem;font-weight:400;transition:all .2s ease}.project-single .project-hero .project-technologies .tech-tag:hover{background:#003fff;color:#fff;transform:translateY(-2px)}.project-single .project-hero .project-actions{display:flex;gap:1rem;justify-content:center}@media screen and (max-width:769px){.project-single .project-hero .project-actions{justify-content:flex-start}}@media screen and (max-width:768px){.project-single .project-hero .project-actions{flex-direction:column;align-items:center}}.project-single .project-hero .project-actions .btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:400;transition:all .2s ease;border:2px solid transparent;min-width:160px;justify-content:center}@media screen and (max-width:768px){.project-single .project-hero .project-actions .btn{width:100%;max-width:280px}}.project-single .project-hero .project-actions .btn .btn-icon{flex-shrink:0}.project-single .project-hero .project-actions .btn.btn-primary{background:#003fff;color:#fff}.project-single .project-hero .project-actions .btn.btn-primary:hover{background:#0036c7;transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,63,255,.3)}.project-single .project-hero .project-actions .btn.btn-secondary{background:0 0;color:#434648;border-color:#ececec}.project-single .project-hero .project-actions .btn.btn-secondary:hover{background:#434648;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(67,70,72,.2)}.project-single .project-content{margin-bottom:3rem}.project-single .project-content h1,.project-single .project-content h2,.project-single .project-content h3,.project-single .project-content h4,.project-single .project-content h5,.project-single .project-content h6{color:#434648;margin-top:2rem;margin-bottom:1rem}.project-single .project-content h2{font-size:1.8rem;border-bottom:2px solid #ececec;padding-bottom:.5rem}.project-single .project-content h3{font-size:1.4rem}.project-single .project-content p{margin-bottom:1rem;line-height:1.7}.project-single .project-content ul,.project-single .project-content ol{margin-bottom:1rem;padding-left:2rem}.project-single .project-content ul li,.project-single .project-content ol li{margin-bottom:.5rem;line-height:1.6}.project-single .project-content strong{font-weight:700}.project-single .project-gallery{margin-bottom:3rem}.project-single .project-gallery h2{margin-bottom:1.5rem;color:#434648}.project-single .project-gallery .gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1rem}@media screen and (max-width:768px){.project-single .project-gallery .gallery-grid{grid-template-columns:1fr}}.project-single .project-gallery .gallery-grid .gallery-item{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.1);transition:all .3s ease;cursor:pointer;outline:none}.project-single .project-gallery .gallery-grid .gallery-item:hover,.project-single .project-gallery .gallery-grid .gallery-item:focus{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,.15)}.project-single .project-gallery .gallery-grid .gallery-item:hover .gallery-overlay,.project-single .project-gallery .gallery-grid .gallery-item:focus .gallery-overlay{opacity:1}.project-single .project-gallery .gallery-grid .gallery-item:hover .gallery-img,.project-single .project-gallery .gallery-grid .gallery-item:focus .gallery-img{transform:scale(1.05)}.project-single .project-gallery .gallery-grid .gallery-item:focus{box-shadow:0 8px 24px rgba(0,63,255,.3)}.project-single .project-gallery .gallery-grid .gallery-item .gallery-img{width:100%;height:auto;display:block;transition:transform .3s ease}.project-single .project-gallery .gallery-grid .gallery-item .gallery-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.project-single .project-gallery .gallery-grid .gallery-item .gallery-overlay .gallery-expand-icon{color:#fff;width:32px;height:32px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.project-single .gallery-lightbox{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s ease}.project-single .gallery-lightbox.lightbox-open{opacity:1;visibility:visible}.project-single .gallery-lightbox .lightbox-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);cursor:pointer}.project-single .gallery-lightbox .lightbox-container{position:relative;width:90%;height:90%;max-width:1200px;max-height:800px;background:#fff;border-radius:12px;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.3);transform:scale(.8);transition:transform .3s ease}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-container{width:95%;height:95%;border-radius:8px}}.project-single .gallery-lightbox.lightbox-open .lightbox-container{transform:scale(1)}.project-single .gallery-lightbox .lightbox-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #ececec;flex-shrink:0}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-header{padding:.75rem 1rem}}.project-single .gallery-lightbox .lightbox-header .lightbox-title{margin:0;font-size:1.2rem;font-weight:400;color:#434648;flex:1;padding-right:1rem}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-header .lightbox-title{font-size:1rem}}.project-single .gallery-lightbox .lightbox-header .lightbox-close{background:0 0;border:none;padding:.5rem;cursor:pointer;border-radius:6px;transition:background-color .2s ease;color:#6b7886}.project-single .gallery-lightbox .lightbox-header .lightbox-close:hover,.project-single .gallery-lightbox .lightbox-header .lightbox-close:focus{background:#ececec;color:#434648}.project-single .gallery-lightbox .lightbox-header .lightbox-close svg{display:block}.project-single .gallery-lightbox .lightbox-content{flex:1;display:flex;align-items:center;position:relative;min-height:0}.project-single .gallery-lightbox .lightbox-content .lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.5);border:none;color:#fff;padding:1rem;cursor:pointer;border-radius:50%;transition:all .2s ease;z-index:10;backdrop-filter:blur(4px)}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-content .lightbox-nav{padding:.75rem}}.project-single .gallery-lightbox .lightbox-content .lightbox-nav:hover,.project-single .gallery-lightbox .lightbox-content .lightbox-nav:focus{background:rgba(0,0,0,.7);transform:translateY(-50%)scale(1.1)}.project-single .gallery-lightbox .lightbox-content .lightbox-nav.lightbox-prev{left:1rem}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-content .lightbox-nav.lightbox-prev{left:.5rem}}.project-single .gallery-lightbox .lightbox-content .lightbox-nav.lightbox-next{right:1rem}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-content .lightbox-nav.lightbox-next{right:.5rem}}.project-single .gallery-lightbox .lightbox-content .lightbox-nav svg{display:block}.project-single .gallery-lightbox .lightbox-content .lightbox-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;padding:2rem}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-content .lightbox-image-container{padding:1rem}}.project-single .gallery-lightbox .lightbox-content .lightbox-image-container .lightbox-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;transition:opacity .3s ease}.project-single .gallery-lightbox .lightbox-content .lightbox-image-container .lightbox-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:none}.project-single .gallery-lightbox .lightbox-content .lightbox-image-container .lightbox-loading .loading-spinner{width:40px;height:40px;border:3px solid #ececec;border-top:3px solid #003fff;border-radius:50%;animation:spin 1s linear infinite}.project-single .gallery-lightbox .lightbox-footer{padding:1rem 1.5rem;border-top:1px solid #ececec;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-shrink:0}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-footer{padding:.75rem 1rem;flex-direction:column;gap:.75rem}}.project-single .gallery-lightbox .lightbox-footer .lightbox-counter{font-size:.9rem;color:#6b7886;font-weight:400}.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails{display:flex;gap:.5rem;overflow-x:auto;padding:.25rem 0;max-width:400px}@media screen and (max-width:768px){.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails{max-width:100%}}.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail{flex-shrink:0;width:60px;height:45px;border:2px solid transparent;border-radius:4px;overflow:hidden;cursor:pointer;transition:all .2s ease;background:0 0;padding:0}.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail:hover,.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail:focus{border-color:#003fff;transform:scale(1.05)}.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail.active{border-color:#003fff;box-shadow:0 0 0 1px #003fff}.project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail img{width:100%;height:100%;object-fit:cover;display:block}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.project-single .project-navigation{border-top:1px solid #ececec;padding-top:2rem;margin-top:3rem}.project-single .project-navigation .nav-links{display:flex;justify-content:space-between;gap:1rem}@media screen and (max-width:768px){.project-single .project-navigation .nav-links{flex-direction:column}}.project-single .project-navigation .nav-links .nav-link{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;text-decoration:none;color:#434648;background:#ececec;transition:all .2s ease;flex:1;max-width:300px}@media screen and (max-width:768px){.project-single .project-navigation .nav-links .nav-link{max-width:none}}.project-single .project-navigation .nav-links .nav-link:hover{background:#003fff;color:#fff;transform:translateY(-2px)}.project-single .project-navigation .nav-links .nav-link.nav-prev{justify-content:flex-start}.project-single .project-navigation .nav-links .nav-link.nav-next{justify-content:flex-end;margin-left:auto}@media screen and (max-width:768px){.project-single .project-navigation .nav-links .nav-link.nav-next{margin-left:0}}.project-single .project-navigation .nav-links .nav-link .nav-text{display:flex;flex-direction:column;gap:.25rem}.project-single .project-navigation .nav-links .nav-link .nav-text small{font-size:.8rem;opacity:.7}.project-single .project-navigation .nav-links .nav-link .nav-text strong{font-weight:400;font-size:.9rem}.project-single .project-navigation .nav-links .nav-link svg{flex-shrink:0}@media(prefers-color-scheme:dark){html:not(.light) .project-card{background:#1b1d25;box-shadow:0 2px 8px rgba(0,0,0,.3)}html:not(.light) .project-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.4)}html:not(.light) .project-card .project-image{background:#4a4d56}html:not(.light) .project-card .project-title a{color:#babdc4}html:not(.light) .project-card .project-title a:hover{color:#77a8fd}html:not(.light) .project-card .project-description{color:#767f87}html:not(.light) .project-card .project-technologies .tech-tag{background:#2d2d2d;color:#c2c4ca}html:not(.light) .project-card .project-actions .btn.btn-primary{background:#77a8fd}html:not(.light) .project-card .project-actions .btn.btn-primary:hover{background:#5292ff}html:not(.light) .project-card .project-actions .btn.btn-secondary{color:#babdc4;border-color:#4a4d56}html:not(.light) .project-card .project-actions .btn.btn-secondary:hover{background:#4a4d56;border-color:#767f87}html:not(.light) .projects-page .projects-intro p{color:#767f87}html:not(.light) .empty-state{color:#767f87}html:not(.light) .empty-state h3{color:#babdc4}html:not(.light) .project-single .project-hero .project-title{color:#eaeaea}html:not(.light) .project-single .project-hero .project-description{color:#babdc4}html:not(.light) .project-single .project-hero .project-technologies .tech-tag{background:#1b1d25;color:#babdc4;border:1px solid #4a4d56}html:not(.light) .project-single .project-hero .project-technologies .tech-tag:hover{background:#77a8fd;color:#131418;border-color:#77a8fd}html:not(.light) .project-single .project-hero .project-actions .btn.btn-primary{background:#77a8fd;color:#131418;border-color:#77a8fd}html:not(.light) .project-single .project-hero .project-actions .btn.btn-primary:hover{background:#5292ff;border-color:#5292ff;box-shadow:0 4px 12px rgba(119,168,253,.3)}html:not(.light) .project-single .project-hero .project-actions .btn.btn-secondary{background:0 0;color:#babdc4;border-color:#4a4d56}html:not(.light) .project-single .project-hero .project-actions .btn.btn-secondary:hover{background:#1b1d25;color:#eaeaea;border-color:#1b1d25}html:not(.light) .project-single .project-content{color:#babdc4}html:not(.light) .project-single .project-content h1,html:not(.light) .project-single .project-content h2,html:not(.light) .project-single .project-content h3,html:not(.light) .project-single .project-content h4,html:not(.light) .project-single .project-content h5,html:not(.light) .project-single .project-content h6{color:#eaeaea}html:not(.light) .project-single .project-content h2{border-bottom-color:#1b1d25}html:not(.light) .project-single .project-content p{color:#babdc4}html:not(.light) .project-single .project-content li{color:#babdc4}html:not(.light) .project-single .project-gallery h2{color:#eaeaea}html:not(.light) .project-single .project-gallery .gallery-item{box-shadow:0 4px 12px rgba(0,0,0,.3)}html:not(.light) .project-single .project-gallery .gallery-item:hover,html:not(.light) .project-single .project-gallery .gallery-item:focus{box-shadow:0 8px 24px rgba(0,0,0,.4)}html:not(.light) .project-single .project-gallery .gallery-item:focus{box-shadow:0 8px 24px rgba(119,168,253,.3)}html:not(.light) .project-single .gallery-lightbox .lightbox-container{background:#131418;box-shadow:0 20px 60px rgba(0,0,0,.6)}html:not(.light) .project-single .gallery-lightbox .lightbox-header{border-bottom-color:#1b1d25}html:not(.light) .project-single .gallery-lightbox .lightbox-header .lightbox-title{color:#eaeaea}html:not(.light) .project-single .gallery-lightbox .lightbox-header .lightbox-close{color:#767f87}html:not(.light) .project-single .gallery-lightbox .lightbox-header .lightbox-close:hover,html:not(.light) .project-single .gallery-lightbox .lightbox-header .lightbox-close:focus{background:#1b1d25;color:#eaeaea}html:not(.light) .project-single .gallery-lightbox .lightbox-footer{border-top-color:#1b1d25}html:not(.light) .project-single .gallery-lightbox .lightbox-footer .lightbox-counter{color:#767f87}html:not(.light) .project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail:hover,html:not(.light) .project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail:focus{border-color:#77a8fd}html:not(.light) .project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail.active{border-color:#77a8fd;box-shadow:0 0 0 1px #77a8fd}html:not(.light) .project-single .gallery-lightbox .lightbox-content .lightbox-loading .loading-spinner{border-color:#1b1d25;border-top-color:#77a8fd}html:not(.light) .project-single .project-navigation{border-top-color:#1b1d25}html:not(.light) .project-single .project-navigation .nav-link{color:#babdc4;background:#1b1d25}html:not(.light) .project-single .project-navigation .nav-link:hover{background:#77a8fd;color:#131418}html:not(.light) .project-single .project-navigation .nav-link .nav-text small{color:#767f87}html:not(.light) .project-single .project-navigation .nav-link .nav-text strong{color:#babdc4}html:not(.light) .project-single .project-navigation .nav-link:hover .nav-text small,html:not(.light) .project-single .project-navigation .nav-link:hover .nav-text strong{color:#131418}}html.dark .project-card{background:#1b1d25;box-shadow:0 2px 8px rgba(0,0,0,.3)}html.dark .project-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.4)}html.dark .project-card .project-image{background:#4a4d56}html.dark .project-card .project-title a{color:#babdc4}html.dark .project-card .project-title a:hover{color:#77a8fd}html.dark .project-card .project-description{color:#767f87}html.dark .project-card .project-technologies .tech-tag{background:#2d2d2d;color:#c2c4ca}html.dark .project-card .project-actions .btn.btn-primary{background:#77a8fd}html.dark .project-card .project-actions .btn.btn-primary:hover{background:#5292ff}html.dark .project-card .project-actions .btn.btn-secondary{color:#babdc4;border-color:#4a4d56}html.dark .project-card .project-actions .btn.btn-secondary:hover{background:#4a4d56;border-color:#767f87}html.dark .projects-page .projects-intro p{color:#767f87}html.dark .empty-state{color:#767f87}html.dark .empty-state h3{color:#babdc4}html.dark .project-single .project-hero .project-title{color:#eaeaea}html.dark .project-single .project-hero .project-description{color:#babdc4}html.dark .project-single .project-hero .project-technologies .tech-tag{background:#1b1d25;color:#babdc4;border:1px solid #4a4d56}html.dark .project-single .project-hero .project-technologies .tech-tag:hover{background:#77a8fd;color:#131418;border-color:#77a8fd}html.dark .project-single .project-hero .project-actions .btn.btn-primary{background:#77a8fd;color:#131418;border-color:#77a8fd}html.dark .project-single .project-hero .project-actions .btn.btn-primary:hover{background:#5292ff;border-color:#5292ff;box-shadow:0 4px 12px rgba(119,168,253,.3)}html.dark .project-single .project-hero .project-actions .btn.btn-secondary{background:0 0;color:#babdc4;border-color:#4a4d56}html.dark .project-single .project-hero .project-actions .btn.btn-secondary:hover{background:#1b1d25;color:#eaeaea;border-color:#1b1d25}html.dark .project-single .project-content{color:#babdc4}html.dark .project-single .project-content h1,html.dark .project-single .project-content h2,html.dark .project-single .project-content h3,html.dark .project-single .project-content h4,html.dark .project-single .project-content h5,html.dark .project-single .project-content h6{color:#eaeaea}html.dark .project-single .project-content h2{border-bottom-color:#1b1d25}html.dark .project-single .project-content p{color:#babdc4}html.dark .project-single .project-content li{color:#babdc4}html.dark .project-single .project-gallery h2{color:#eaeaea}html.dark .project-single .project-gallery .gallery-item{box-shadow:0 4px 12px rgba(0,0,0,.3)}html.dark .project-single .project-gallery .gallery-item:hover,html.dark .project-single .project-gallery .gallery-item:focus{box-shadow:0 8px 24px rgba(0,0,0,.4)}html.dark .project-single .project-gallery .gallery-item:focus{box-shadow:0 8px 24px rgba(119,168,253,.3)}html.dark .project-single .gallery-lightbox .lightbox-container{background:#131418;box-shadow:0 20px 60px rgba(0,0,0,.6)}html.dark .project-single .gallery-lightbox .lightbox-header{border-bottom-color:#1b1d25}html.dark .project-single .gallery-lightbox .lightbox-header .lightbox-title{color:#eaeaea}html.dark .project-single .gallery-lightbox .lightbox-header .lightbox-close{color:#767f87}html.dark .project-single .gallery-lightbox .lightbox-header .lightbox-close:hover,html.dark .project-single .gallery-lightbox .lightbox-header .lightbox-close:focus{background:#1b1d25;color:#eaeaea}html.dark .project-single .gallery-lightbox .lightbox-footer{border-top-color:#1b1d25}html.dark .project-single .gallery-lightbox .lightbox-footer .lightbox-counter{color:#767f87}html.dark .project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail:hover,html.dark .project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail:focus{border-color:#77a8fd}html.dark .project-single .gallery-lightbox .lightbox-footer .lightbox-thumbnails .lightbox-thumbnail.active{border-color:#77a8fd;box-shadow:0 0 0 1px #77a8fd}html.dark .project-single .gallery-lightbox .lightbox-content .lightbox-loading .loading-spinner{border-color:#1b1d25;border-top-color:#77a8fd}html.dark .project-single .project-navigation{border-top-color:#1b1d25}html.dark .project-single .project-navigation .nav-link{color:#babdc4;background:#1b1d25}html.dark .project-single .project-navigation .nav-link:hover{background:#77a8fd;color:#131418}html.dark .project-single .project-navigation .nav-link .nav-text small{color:#767f87}html.dark .project-single .project-navigation .nav-link .nav-text strong{color:#babdc4}html.dark .project-single .project-navigation .nav-link:hover .nav-text small,html.dark .project-single .project-navigation .nav-link:hover .nav-text strong{color:#131418}.project-image img,.project-image picture,.project-hero-image img,.project-hero-image picture,.gallery-img img,.gallery-img picture{aspect-ratio:attr(width)/attr(height);image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;will-change:auto;transition:opacity .3s ease}.project-image img[loading=lazy],.project-image picture[loading=lazy],.project-hero-image img[loading=lazy],.project-hero-image picture[loading=lazy],.gallery-img img[loading=lazy],.gallery-img picture[loading=lazy]{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;animation:loading-shimmer 1.5s infinite}@keyframes loading-shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}.project-gallery{contain:layout style paint}.project-gallery .gallery-grid{contain:layout}.project-gallery .gallery-grid .gallery-item{contain:layout style paint}.project-gallery .gallery-grid .gallery-item:hover{will-change:transform}.project-gallery .gallery-grid .gallery-item:not(:hover){will-change:auto}.gallery-lightbox{transform:translateZ(0)}.gallery-lightbox.lightbox-open .lightbox-container{will-change:transform,opacity}.gallery-lightbox:not(.lightbox-open) .lightbox-container{will-change:auto}.gallery-lightbox .lightbox-image{image-rendering:high-quality;transition:opacity .3s ease}.gallery-lightbox .lightbox-image[src=""]{opacity:0}.project-card{contain:layout style paint;transition:transform .2s ease,box-shadow .2s ease}.project-card:hover{will-change:transform}.project-card:not(:hover){will-change:auto}.project-hero{contain:layout style}.project-hero .project-hero-image{min-height:300px}.project-hero .project-hero-image picture,.project-hero .project-hero-image img{width:100%;height:auto;display:block}@media(prefers-reduced-motion:reduce){.project-card,.gallery-item,.lightbox-container,.gallery-img{transition:none!important;animation:none!important}.loading-shimmer{animation:none!important}}@media print{.gallery-lightbox,.project-actions,.project-navigation{display:none!important}.project-gallery .gallery-grid{display:block!important}.project-gallery .gallery-grid .gallery-item{break-inside:avoid;margin-bottom:1rem}}.post-navigation{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--border-color)}.post-navigation .nav-links{display:flex;justify-content:space-between;gap:1rem}@media(max-width:768px){.post-navigation .nav-links{flex-direction:column;gap:1.5rem}}.post-navigation .nav-link{display:flex;align-items:center;gap:.75rem;padding:1rem;border:1px solid var(--border-color);border-radius:8px;text-decoration:none;color:var(--text-color);background:var(--bg-color);transition:all .2s ease;flex:1;max-width:45%}@media(max-width:768px){.post-navigation .nav-link{max-width:100%}}.post-navigation .nav-link:hover{border-color:var(--primary-color);background:var(--hover-bg-color);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.post-navigation .nav-link.nav-prev{text-align:left}.post-navigation .nav-link.nav-prev .nav-text{order:2}.post-navigation .nav-link.nav-prev svg{order:1;flex-shrink:0}.post-navigation .nav-link.nav-next{text-align:right;justify-content:flex-end}.post-navigation .nav-link.nav-next .nav-text{order:1}.post-navigation .nav-link.nav-next svg{order:2;flex-shrink:0}.post-navigation .nav-text{display:flex;flex-direction:column;gap:.25rem;min-width:0}.post-navigation .nav-text small{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.post-navigation .nav-text strong{font-size:.9rem;font-weight:600;line-height:1.3;color:var(--text-color);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.post-navigation .nav-text time{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.post-navigation svg{color:var(--primary-color);transition:transform .2s ease}.post-navigation .nav-link:hover svg{transform:translateX(2px)}.post-navigation .nav-prev:hover svg{transform:translateX(-2px)}[data-theme=dark] .post-navigation .nav-link{border-color:var(--border-color-dark);background:var(--bg-color-dark)}[data-theme=dark] .post-navigation .nav-link:hover{border-color:var(--primary-color);background:var(--hover-bg-color-dark);box-shadow:0 4px 12px rgba(0,0,0,.3)}.project-navigation .nav-links,.post-navigation .nav-links{display:flex;justify-content:space-between;gap:1rem}.project-navigation .nav-link,.post-navigation .nav-link{display:flex;align-items:center;gap:.75rem;padding:1rem;border:1px solid var(--border-color);border-radius:8px;text-decoration:none;transition:all .2s ease}.project-navigation .nav-link:hover,.post-navigation .nav-link:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.1)}.series-navigation{margin:2rem 0;padding:1.5rem;background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px}.series-navigation .series-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}@media(max-width:768px){.series-navigation .series-header{flex-direction:column;align-items:stretch}}.series-navigation .series-info{flex:1;min-width:0}.series-navigation .series-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:600;color:#434648;line-height:1.3}.series-navigation .series-progress{display:flex;flex-direction:column;gap:.5rem}.series-navigation .progress-text{font-size:.875rem;color:#6b7886;font-weight:500}.series-navigation .progress-bar{width:100%;height:6px;background:#e9ecef;border-radius:3px;overflow:hidden}@media(max-width:768px){.series-navigation .progress-bar{max-width:200px}}.series-navigation .progress-fill{height:100%;background:linear-gradient(90deg,#003fff,#4d7fff);border-radius:3px;transition:width .3s ease}.series-navigation .series-toggle{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fff;border:1px solid #dee2e6;border-radius:8px;color:#434648;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.series-navigation .series-toggle:hover{background:#f8f9fa;border-color:#003fff;transform:translateY(-1px)}.series-navigation .series-toggle:focus{outline:2px solid #003fff;outline-offset:2px}.series-navigation .series-toggle svg{transition:transform .2s ease;color:#003fff}@media(max-width:768px){.series-navigation .series-toggle{width:100%;justify-content:center}}.series-navigation .series-list{max-height:0;overflow:hidden;transition:max-height .3s ease}.series-navigation .series-list[aria-hidden=false]{max-height:none}.series-navigation .series-posts{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.series-navigation .series-item{margin:0}.series-navigation .series-item.current .series-link{background:#e7f1ff;border-color:#003fff;color:#0036c7}.series-navigation .series-link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#fff;border:1px solid #e9ecef;border-radius:8px;text-decoration:none;color:#434648;transition:all .2s ease}.series-navigation .series-link:not(.current-post):hover{background:#f8f9fa;border-color:#003fff;transform:translateX(4px)}.series-navigation .series-link.current-post{cursor:default}.series-navigation .post-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#003fff;color:#fff;border-radius:50%;font-size:.75rem;font-weight:600;flex-shrink:0}.series-navigation .current-post .post-number{background:#0036c7}.series-navigation .post-title{flex:1;font-weight:500;line-height:1.4;min-width:0}@media(max-width:480px){.series-navigation .post-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}.series-navigation .post-date{font-size:.75rem;color:#6b7886;flex-shrink:0}@media(max-width:480px){.series-navigation .post-date{display:none}}.series-navigation .current-indicator{background:#003fff;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.series-navigation .series-description{margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}.series-navigation .series-description p{margin:0;font-size:.875rem;color:#6b7886;line-height:1.5}html.dark .series-navigation{background:#1b1d25;border-color:#4a4d56}html.dark .series-navigation .series-title{color:#babdc4}html.dark .series-navigation .progress-text{color:#767f87}html.dark .series-navigation .progress-bar{background:#4a4d56}html.dark .series-navigation .progress-fill{background:linear-gradient(90deg,#77a8fd,#9bb8ff)}html.dark .series-navigation .series-toggle{background:#131418;border-color:#4a4d56;color:#babdc4}html.dark .series-navigation .series-toggle:hover{background:#1b1d25;border-color:#77a8fd}html.dark .series-navigation .series-toggle svg{color:#77a8fd}html.dark .series-navigation .series-link{background:#131418;border-color:#4a4d56;color:#babdc4}html.dark .series-navigation .series-link:not(.current-post):hover{background:#1b1d25;border-color:#77a8fd}html.dark .series-navigation .series-item.current .series-link{background:rgba(119,168,253,.1);border-color:#77a8fd;color:#77a8fd}html.dark .series-navigation .post-number{background:#77a8fd}html.dark .series-navigation .current-post .post-number{background:#5292ff}html.dark .series-navigation .post-date{color:#767f87}html.dark .series-navigation .current-indicator{background:#77a8fd}html.dark .series-navigation .series-description{border-top-color:#4a4d56}html.dark .series-navigation .series-description p{color:#767f87}@media(max-width:768px){.series-navigation{padding:1rem;margin:1.5rem 0}.series-navigation .series-title{font-size:1.125rem}.series-navigation .series-link{padding:.75rem;gap:.5rem}.series-navigation .post-number{width:24px;height:24px;font-size:.7rem}}.series-list{transition:max-height .3s cubic-bezier(.4,0,.2,1)}.series-link:focus{outline:2px solid #003fff;outline-offset:2px}html.dark .series-link:focus{outline-color:#77a8fd}@media(prefers-color-scheme:dark){html:not(.light) .series-navigation{background:#1b1d25;border-color:#4a4d56}html:not(.light) .series-navigation .series-title{color:#babdc4}html:not(.light) .series-navigation .progress-text{color:#767f87}html:not(.light) .series-navigation .progress-bar{background:#4a4d56}html:not(.light) .series-navigation .progress-fill{background:linear-gradient(90deg,#77a8fd,#9bb8ff)}html:not(.light) .series-navigation .series-toggle{background:#131418;border-color:#4a4d56;color:#babdc4}html:not(.light) .series-navigation .series-toggle:hover{background:#1b1d25;border-color:#77a8fd}html:not(.light) .series-navigation .series-toggle svg{color:#77a8fd}html:not(.light) .series-navigation .series-link{background:#131418;border-color:#4a4d56;color:#babdc4}html:not(.light) .series-navigation .series-link:not(.current-post):hover{background:#1b1d25;border-color:#77a8fd}html:not(.light) .series-navigation .series-link:focus{outline-color:#77a8fd}html:not(.light) .series-navigation .series-item.current .series-link{background:rgba(119,168,253,.1);border-color:#77a8fd;color:#77a8fd}html:not(.light) .series-navigation .post-number{background:#77a8fd}html:not(.light) .series-navigation .current-post .post-number{background:#5292ff}html:not(.light) .series-navigation .post-date{color:#767f87}html:not(.light) .series-navigation .current-indicator{background:#77a8fd}html:not(.light) .series-navigation .series-description{border-top-color:#4a4d56}html:not(.light) .series-navigation .series-description p{color:#767f87}}@media print{.series-navigation{break-inside:avoid}.series-navigation .series-toggle{display:none}.series-navigation .series-list{max-height:none!important}}html{scroll-behavior:smooth}#totop{visibility:hidden;color:#434648;position:fixed;bottom:60px;right:30px;z-index:1;border-radius:10%;background-color:#dfe0e397;transition:visibility .5s,opacity .8s linear}#totop:hover{background-color:#dfe0e3}#totop svg{margin:auto;display:block;height:40px;width:40px}