/*
  PaperMod v8+
  License: MIT https://github.com/adityatelange/hugo-PaperMod/blob/master/LICENSE
  Copyright (c) 2020 nanxiaobei and adityatelange
  Copyright (c) 2021-2025 adityatelange
*/
:root{--gap:24px;--content-gap:20px;--nav-width:1024px;--main-width:720px;--header-height:60px;--footer-height:60px;--radius:8px;--theme:rgb(255, 255, 255);--entry:rgb(255, 255, 255);--primary:rgb(30, 30, 30);--secondary:rgb(108, 108, 108);--tertiary:rgb(214, 214, 214);--content:rgb(31, 31, 31);--code-block-bg:rgb(28, 29, 33);--code-bg:rgb(245, 245, 245);--border:rgb(238, 238, 238)}.dark{--theme:rgb(29, 30, 32);--entry:rgb(46, 46, 51);--primary:rgb(218, 218, 219);--secondary:rgb(155, 156, 157);--tertiary:rgb(65, 66, 68);--content:rgb(196, 196, 197);--code-block-bg:rgb(46, 46, 51);--code-bg:rgb(55, 56, 62);--border:rgb(51, 51, 51)}.list{background:var(--code-bg)}.dark.list{background:var(--theme)}*,::after,::before{box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;overflow-y:scroll;-webkit-text-size-adjust:100%;text-size-adjust:100%}a,button,body,h1,h2,h3,h4,h5,h6{color:var(--primary)}body{font-family:-apple-system,BlinkMacSystemFont,segoe ui,Roboto,Oxygen,Ubuntu,Cantarell,open sans,helvetica neue,sans-serif;font-size:18px;line-height:1.6;word-break:break-word;background:var(--theme)}article,aside,figcaption,figure,footer,header,hgroup,main,nav,section,table{display:block}h1,h2,h3,h4,h5,h6{line-height:1.2}h1,h2,h3,h4,h5,h6,p{margin-top:0;margin-bottom:0}ul{padding:0}a{text-decoration:none}body,figure,ul{margin:0}table{width:100%;border-collapse:collapse;border-spacing:0;overflow-x:auto;word-break:keep-all}button,input,textarea{padding:0;font:inherit;background:0 0;border:0}input,textarea{outline:0}button,input[type=button],input[type=submit]{cursor:pointer}input:-webkit-autofill,textarea:-webkit-autofill{box-shadow:0 0 0 50px var(--theme)inset}img{display:block;max-width:100%}.not-found{position:absolute;left:0;right:0;display:flex;align-items:center;justify-content:center;height:80%;font-size:160px;font-weight:700}.archive-posts{width:100%;font-size:16px}.archive-year{margin-top:40px}.archive-year:not(:last-of-type){border-bottom:2px solid var(--border)}.archive-month{display:flex;align-items:flex-start;padding:10px 0}.archive-month-header{margin:25px 0;width:200px}.archive-month:not(:last-of-type){border-bottom:1px solid var(--border)}.archive-entry{position:relative;padding:5px;margin:10px 0}.archive-entry-title{margin:5px 0;font-weight:400}.archive-count,.archive-meta{color:var(--secondary);font-size:14px}.footer,.top-link{font-size:12px;color:var(--secondary)}.footer{max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:calc((var(--footer-height) - var(--gap))/2)var(--gap);text-align:center;line-height:24px}.footer span{margin-inline-start:1px;margin-inline-end:1px}.footer span:last-child{white-space:nowrap}.footer a{color:inherit;border-bottom:1px solid var(--secondary)}.footer a:hover{border-bottom:1px solid var(--primary)}.top-link{visibility:hidden;position:fixed;bottom:60px;right:30px;z-index:99;background:var(--tertiary);width:42px;height:42px;padding:12px;border-radius:64px;transition:visibility .5s,opacity .8s linear}.top-link,.top-link svg{filter:drop-shadow(0 0 0 var(--theme))}.footer a:hover,.top-link:hover{color:var(--primary)}.top-link:focus,#theme-toggle:focus{outline:0}.nav{display:flex;flex-wrap:wrap;justify-content:space-between;max-width:calc(var(--nav-width) + var(--gap) * 2);margin-inline-start:auto;margin-inline-end:auto;line-height:var(--header-height)}.nav a{display:block}.logo,#menu{display:flex;margin:auto var(--gap)}.logo{flex-wrap:inherit}.logo a{font-size:24px;font-weight:700}.logo a img,.logo a svg{display:inline;vertical-align:middle;pointer-events:none;transform:translate(0,-10%);border-radius:6px;margin-inline-end:8px}button#theme-toggle{font-size:26px;margin:auto 4px}body.dark #moon{vertical-align:middle;display:none}body:not(.dark) #sun{display:none}#menu{list-style:none;word-break:keep-all;overflow-x:auto;white-space:nowrap}#menu li+li{margin-inline-start:var(--gap)}#menu a{font-size:16px}#menu .active{font-weight:500;border-bottom:2px solid}.lang-switch li,.lang-switch ul,.logo-switches{display:inline-flex;margin:auto 4px}.lang-switch{display:flex;flex-wrap:inherit}.lang-switch a{margin:auto 3px;font-size:16px;font-weight:500}.logo-switches{flex-wrap:inherit}.main{position:relative;min-height:calc(100vh - var(--header-height) - var(--footer-height));max-width:calc(var(--main-width) + var(--gap) * 2);margin:auto;padding:var(--gap)}.page-header h1{font-size:40px}.pagination{display:flex}.pagination a{color:var(--theme);font-size:13px;line-height:36px;background:var(--primary);border-radius:calc(36px/2);padding:0 16px}.pagination .next{margin-inline-start:auto}.social-icons a{display:inline-flex;padding:10px}.social-icons a svg{height:26px;width:26px}code{direction:ltr}div.highlight,pre{position:relative}.copy-code{display:none;position:absolute;top:4px;right:4px;color:rgba(255,255,255,.8);background:rgba(78,78,78,.8);border-radius:var(--radius);padding:0 5px;font-size:14px;user-select:none}div.highlight:hover .copy-code,pre:hover .copy-code{display:block}.first-entry{position:relative;display:flex;flex-direction:column;justify-content:center;min-height:320px;margin:var(--gap)0 calc(var(--gap) * 2)}.first-entry .entry-header{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.first-entry .entry-header h1{font-size:34px;line-height:1.3}.first-entry .entry-content{margin:14px 0;font-size:16px;-webkit-line-clamp:3}.first-entry .entry-footer{font-size:14px}.home-info .entry-content{-webkit-line-clamp:unset}.post-entry{position:relative;margin-bottom:var(--gap);padding:var(--gap);background:var(--entry);border-radius:var(--radius);transition:transform .1s;border:1px solid var(--border)}.post-entry:active{transform:scale(.96)}.tag-entry .entry-cover{display:none}.entry-header h2{font-size:24px;line-height:1.3}.entry-content{margin:8px 0;color:var(--secondary);font-size:14px;line-height:1.6;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.entry-footer{color:var(--secondary);font-size:13px}.entry-link{position:absolute;left:0;right:0;top:0;bottom:0}.entry-hint{color:var(--secondary)}.entry-hint-parent{display:flex;justify-content:space-between}.entry-cover{font-size:14px;margin-bottom:var(--gap);text-align:center}.entry-cover img{border-radius:var(--radius);width:100%;height:auto}.entry-cover a{color:var(--secondary);box-shadow:0 1px 0 var(--primary)}.page-header,.post-header{margin:24px auto var(--content-gap)}.post-title{margin-bottom:2px;font-size:40px}.post-description{margin-top:10px;margin-bottom:5px}.post-meta,.breadcrumbs{color:var(--secondary);font-size:14px;display:flex;flex-wrap:wrap;align-items:center}.post-meta .i18n_list li{display:inline-flex;list-style:none;margin:auto 3px;box-shadow:0 1px 0 var(--secondary)}.breadcrumbs a{font-size:16px}.post-content{color:var(--content)}.post-content h3,.post-content h4,.post-content h5,.post-content h6{margin:24px 0 16px}.post-content h1{margin:40px auto 32px;font-size:40px}.post-content h2{margin:32px auto 24px;font-size:32px}.post-content h3{font-size:24px}.post-content h4{font-size:16px}.post-content h5{font-size:14px}.post-content h6{font-size:12px}.post-content a,.toc a:hover{box-shadow:0 1px;box-decoration-break:clone;-webkit-box-decoration-break:clone}.post-content a code{margin:auto 0;border-radius:0;box-shadow:0 -1px 0 var(--primary)inset}.post-content del{text-decoration:line-through}.post-content dl,.post-content ol,.post-content p,.post-content figure,.post-content ul{margin-bottom:var(--content-gap)}.post-content ol,.post-content ul{padding-inline-start:20px}.post-content li{margin-top:5px}.post-content li p{margin-bottom:0}.post-content dl{display:flex;flex-wrap:wrap;margin:0}.post-content dt{width:25%;font-weight:700}.post-content dd{width:75%;margin-inline-start:0;padding-inline-start:10px}.post-content dd~dd,.post-content dt~dt{margin-top:10px}.post-content table{margin-bottom:var(--content-gap)}.post-content table th,.post-content table:not(.highlighttable,.highlight table,.gist .highlight) td{min-width:80px;padding:8px 5px;line-height:1.5;border-bottom:1px solid var(--border)}.post-content table th{text-align:start}.post-content table:not(.highlighttable) td code:only-child{margin:auto 0}.post-content .highlight table{border-radius:var(--radius)}.post-content .highlight:not(table){margin:10px auto;background:var(--code-block-bg)!important;border-radius:var(--radius);direction:ltr}.post-content li>.highlight{margin-inline-end:0}.post-content ul pre{margin-inline-start:calc(var(--gap) * -2)}.post-content .highlight pre{margin:0}.post-content .highlighttable{table-layout:fixed}.post-content .highlighttable td:first-child{width:40px}.post-content .highlighttable td .linenodiv{padding-inline-end:0!important}.post-content .highlighttable td .highlight,.post-content .highlighttable td .linenodiv pre{margin-bottom:0}.post-content code{margin:auto 4px;padding:4px 6px;font-size:.78em;line-height:1.5;background:var(--code-bg);border-radius:2px}.post-content pre code{display:grid;margin:auto 0;padding:10px;color:#d5d5d6;background:var(--code-block-bg)!important;border-radius:var(--radius);overflow-x:auto;word-break:break-all}.post-content blockquote{margin:20px 0;padding:0 14px;border-inline-start:3px solid var(--primary)}.post-content hr{margin:30px 0;height:2px;background:var(--tertiary);border:0}.post-content iframe{max-width:100%}.post-content img{border-radius:4px;margin:1rem 0}.post-content img[src*="#center"]{margin:1rem auto}.post-content figure.align-center{text-align:center}.post-content figure>figcaption{color:var(--primary);font-size:16px;font-weight:700;margin:8px 0 16px}.post-content figure>figcaption>p{color:var(--secondary);font-size:14px;font-weight:400}.toc{margin:0 2px 40px;border:1px solid var(--border);background:var(--code-bg);border-radius:var(--radius);padding:.4em}.dark .toc{background:var(--entry)}.toc details summary{cursor:zoom-in;margin-inline-start:10px;user-select:none}.toc details[open] summary{cursor:zoom-out}.toc .details{display:inline;font-weight:500}.toc .inner{margin:5px 20px 0;padding:0 10px;opacity:.9}.toc li ul{margin-inline-start:var(--gap)}.toc summary:focus{outline:0}.post-footer{margin-top:56px}.post-footer>*{margin-bottom:10px}.post-tags{display:flex;flex-wrap:wrap;gap:10px}.post-tags li{display:inline-block}.post-tags a,.share-buttons,.paginav{border-radius:var(--radius);background:var(--code-bg);border:1px solid var(--border)}.post-tags a{display:block;padding:0 14px;color:var(--secondary);font-size:14px;line-height:34px;background:var(--code-bg)}.post-tags a:hover,.paginav a:hover{background:var(--border)}.share-buttons{padding:10px;display:flex;justify-content:center;overflow-x:auto;gap:10px}.share-buttons li,.share-buttons a{display:inline-flex}.share-buttons a:not(:last-of-type){margin-inline-end:12px}h1:hover .anchor,h2:hover .anchor,h3:hover .anchor,h4:hover .anchor,h5:hover .anchor,h6:hover .anchor{display:inline-flex;color:var(--secondary);margin-inline-start:8px;font-weight:500;user-select:none}.paginav{display:flex;line-height:30px}.paginav a{padding-inline-start:14px;padding-inline-end:14px;border-radius:var(--radius)}.paginav .title{letter-spacing:1px;text-transform:uppercase;font-size:small;color:var(--secondary)}.paginav .prev,.paginav .next{width:50%}.paginav span:hover:not(.title){box-shadow:0 1px}.paginav .next{margin-inline-start:auto;text-align:right}[dir=rtl] .paginav .next{text-align:left}h1>a>svg{display:inline}img.in-text{display:inline;margin:auto}.buttons,.main .profile{display:flex;justify-content:center}.main .profile{align-items:center;min-height:calc(100vh - var(--header-height) - var(--footer-height) - (var(--gap) * 2));text-align:center}.profile .profile_inner{display:flex;flex-direction:column;align-items:center;gap:10px}.profile img{border-radius:50%}.buttons{flex-wrap:wrap;max-width:400px}.button{background:var(--tertiary);border-radius:var(--radius);margin:8px;padding:6px;transition:transform .1s}.button-inner{padding:0 8px}.button:active{transform:scale(.96)}#searchbox input{padding:4px 10px;width:100%;color:var(--primary);font-weight:700;border:2px solid var(--tertiary);border-radius:var(--radius)}#searchbox input:focus{border-color:var(--secondary)}#searchResults li{list-style:none;border-radius:var(--radius);padding:10px;margin:10px 0;position:relative;font-weight:500}#searchResults{margin:10px 0;width:100%}#searchResults li:active{transition:transform .1s;transform:scale(.98)}#searchResults a{position:absolute;width:100%;height:100%;top:0;left:0;outline:none}#searchResults .focus{transform:scale(.98);border:2px solid var(--tertiary)}.terms-tags li{display:inline-block;margin:10px;font-weight:500}.terms-tags a{display:block;padding:3px 10px;background:var(--tertiary);border-radius:6px;transition:transform .1s}.terms-tags a:active{background:var(--tertiary);transform:scale(.96)}.bg{color:#cad3f5;background-color:#24273a}.chroma{color:#cad3f5;background-color:#24273a}.chroma .x{}.chroma .err{color:#ed8796}.chroma .cl{}.chroma .lnlinks{outline:none;text-decoration:none;color:inherit}.chroma .lntd{vertical-align:top;padding:0;margin:0;border:0}.chroma .lntable{border-spacing:0;padding:0;margin:0;border:0}.chroma .hl{background-color:#474733}.chroma .lnt{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .ln{white-space:pre;-webkit-user-select:none;user-select:none;margin-right:.4em;padding:0 .4em;color:#8087a2}.chroma .line{display:flex}.chroma .k{color:#c6a0f6}.chroma .kc{color:#f5a97f}.chroma .kd{color:#ed8796}.chroma .kn{color:#8bd5ca}.chroma .kp{color:#c6a0f6}.chroma .kr{color:#c6a0f6}.chroma .kt{color:#ed8796}.chroma .n{}.chroma .na{color:#8aadf4}.chroma .nb{color:#91d7e3}.chroma .bp{color:#91d7e3}.chroma .nc{color:#eed49f}.chroma .no{color:#eed49f}.chroma .nd{color:#8aadf4;font-weight:700}.chroma .ni{color:#8bd5ca}.chroma .ne{color:#f5a97f}.chroma .nf{color:#8aadf4}.chroma .fm{color:#8aadf4}.chroma .nl{color:#91d7e3}.chroma .nn{color:#f5a97f}.chroma .nx{}.chroma .py{color:#f5a97f}.chroma .nt{color:#c6a0f6}.chroma .nv{color:#f4dbd6}.chroma .vc{color:#f4dbd6}.chroma .vg{color:#f4dbd6}.chroma .vi{color:#f4dbd6}.chroma .vm{color:#f4dbd6}.chroma .l{}.chroma .ld{}.chroma .s{color:#a6da95}.chroma .sa{color:#ed8796}.chroma .sb{color:#a6da95}.chroma .sc{color:#a6da95}.chroma .dl{color:#8aadf4}.chroma .sd{color:#6e738d}.chroma .s2{color:#a6da95}.chroma .se{color:#8aadf4}.chroma .sh{color:#6e738d}.chroma .si{color:#a6da95}.chroma .sx{color:#a6da95}.chroma .sr{color:#8bd5ca}.chroma .s1{color:#a6da95}.chroma .ss{color:#a6da95}.chroma .m{color:#f5a97f}.chroma .mb{color:#f5a97f}.chroma .mf{color:#f5a97f}.chroma .mh{color:#f5a97f}.chroma .mi{color:#f5a97f}.chroma .il{color:#f5a97f}.chroma .mo{color:#f5a97f}.chroma .o{color:#91d7e3;font-weight:700}.chroma .ow{color:#91d7e3;font-weight:700}.chroma .p{}.chroma .c{color:#6e738d;font-style:italic}.chroma .ch{color:#6e738d;font-style:italic}.chroma .cm{color:#6e738d;font-style:italic}.chroma .c1{color:#6e738d;font-style:italic}.chroma .cs{color:#6e738d;font-style:italic}.chroma .cp{color:#6e738d;font-style:italic}.chroma .cpf{color:#6e738d;font-weight:700;font-style:italic}.chroma .g{}.chroma .gd{color:#ed8796;background-color:#363a4f}.chroma .ge{font-style:italic}.chroma .gr{color:#ed8796}.chroma .gh{color:#f5a97f;font-weight:700}.chroma .gi{color:#a6da95;background-color:#363a4f}.chroma .go{}.chroma .gp{}.chroma .gs{font-weight:700}.chroma .gu{color:#f5a97f;font-weight:700}.chroma .gt{color:#ed8796}.chroma .gl{text-decoration:underline}.chroma .w{}.chroma{background-color:unset!important}.chroma .hl{display:flex}.chroma .lnt{padding:0 0 0 12px}.highlight pre.chroma code{padding:8px 0}.highlight pre.chroma .line .cl,.chroma .ln{padding:0 10px}.chroma .lntd:last-of-type{width:100%}::-webkit-scrollbar-track{background:0 0}.list:not(.dark)::-webkit-scrollbar-track{background:var(--code-bg)}::-webkit-scrollbar-thumb{background:var(--tertiary);border:5px solid var(--theme);border-radius:var(--radius)}.list:not(.dark)::-webkit-scrollbar-thumb{border:5px solid var(--code-bg)}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}::-webkit-scrollbar:not(.highlighttable,.highlight table,.gist .highlight){background:var(--theme)}.post-content .highlighttable td .highlight pre code::-webkit-scrollbar{display:none}.post-content :not(table) ::-webkit-scrollbar-thumb{border:2px solid var(--code-block-bg);background:#717175}.post-content :not(table) ::-webkit-scrollbar-thumb:hover{background:#a3a3a5}.gist table::-webkit-scrollbar-thumb{border:2px solid #fff;background:#adadad}.gist table::-webkit-scrollbar-thumb:hover{background:#707070}.post-content table::-webkit-scrollbar-thumb{border-width:2px}@media screen and (min-width:768px){::-webkit-scrollbar{width:19px;height:11px}}@media screen and (max-width:768px){:root{--gap:14px}.profile img{transform:scale(.85)}.first-entry{min-height:260px}.archive-month{flex-direction:column}.archive-year{margin-top:20px}.footer{padding:calc((var(--footer-height) - var(--gap) - 10px)/2)var(--gap)}}@media screen and (max-width:900px){.list .top-link{transform:translateY(-5rem)}}@media screen and (max-width:340px){.share-buttons{justify-content:unset}}@media(prefers-reduced-motion){.terms-tags a:active,.button:active,.post-entry:active,.top-link,#searchResults .focus,#searchResults li:active{transform:none}}.notfound{padding:3rem 1rem;display:grid;place-items:center}.notfound__content{max-width:720px;text-align:center}.notfound__title{font-size:clamp(1.75rem,6vw,2.5rem);margin:0 0 .5rem}.notfound__subtitle{color:var(--secondary,#6b7280);margin:0 0 1.25rem}.notfound__illustration{margin-bottom:.75rem}.notfound__illustration img{max-width:200px;width:60%;height:auto;opacity:.9;border-radius:12px}.notfound__search{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center;margin:0 auto 1rem}@media(max-width:560px){.notfound__search{grid-template-columns:1fr}}.notfound__search input[type=search]{flex:1;padding:.55rem .75rem;color:var(--primary,#111827)}.notfound__actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1rem}.notfound__hint{color:var(--secondary,#6b7280)}.notfound__suggestions{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin:.5rem 0 .75rem}.notfound__heading{margin:0 0 .35rem;font-size:1.05rem}.notfound__list{text-align:left;list-style:disc outside;padding-left:1.25rem;margin:.25rem 0 .5rem}.notfound__list li{margin:.25rem 0}.notfound__list a{text-decoration:none}.notfound__list a:hover{text-decoration:underline}.notfound__actions .btn--outline{color:var(--primary,#111827);border-color:var(--entry,rgba(0,0,0,.2));background:0 0;font-weight:500}.notfound__actions .btn--outline:hover{background:rgba(59,130,246,6%)}@media(prefers-color-scheme:dark){.notfound__actions .btn--outline{color:#e5e7eb;border-color:rgba(255,255,255,.35)}.notfound__list a{color:inherit}}.contact{padding:2rem 0}.contact__header{margin-bottom:1rem}.contact__title{margin:0 0 .25rem;font-size:clamp(1.5rem,4vw,2rem)}.contact__intro{color:var(--secondary,#6b7280)}.contact__form{max-width:720px;padding:1rem 0}.form__row{display:grid;gap:.35rem;margin-bottom:.9rem}label{font-weight:600}label span[aria-hidden=true]{color:#ef4444;margin-left:.25rem}input[type=text],input[type=email],input[type=tel],select,textarea{width:100%;padding:.6rem .75rem;color:var(--primary,#111827)}textarea{resize:vertical}.form__actions{margin-top:1rem}.btn{display:inline-block;padding:.6rem 1rem;border-radius:8px;text-decoration:none;cursor:pointer;border:1px solid transparent}.btn--primary{background:var(--primary,#3b82f6);color:#fff}.btn--primary:hover{filter:brightness(.95)}.form__checkbox{display:flex;gap:.5rem;align-items:center}.form__checkbox input[type=checkbox]{width:1rem;height:1rem}.faq{padding:2rem 0}.faq__header{margin-bottom:1rem}.faq__title{margin:0 0 .25rem;font-size:clamp(1.5rem,4vw,2rem)}.faq__intro{color:var(--secondary,#6b7280)}.faq__controls{display:flex;gap:.5rem;margin:.5rem 0 1rem;flex-wrap:wrap}.faq__list{display:grid;gap:.75rem}.faq__item{border:1px solid var(--ui-input-border);border-radius:var(--ui-input-radius);background:var(--theme,#fff)}.faq__q{list-style:none;padding:.75rem 1rem;margin:0;font-weight:600;cursor:pointer}.faq__q::-webkit-details-marker{display:none}.faq__q::after{content:"\25B8";float:right;transform:rotate(0);transition:transform .15s ease;opacity:.75}.faq__item[open] .faq__q::after{transform:rotate(90deg)}.faq__a{padding:0 1rem .9rem;color:var(--secondary,#6b7280);animation:faq-reveal .15s ease}@keyframes faq-reveal{from{opacity:0}to{opacity:1}}.halftone{position:relative;display:inline-block}.halftone>img{display:block;height:auto;max-width:100%}.halftone::after{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,rgba(0,0,0,.45) 38%,transparent 39%);background-size:8px 8px;background-position:0 0;mix-blend-mode:multiply;opacity:.22}.halftone.is-small::after{opacity:.25;background-size:7px 7px}.halftone--color::after{opacity:0!important}.halftone--color>img{-webkit-mask-image:radial-gradient(circle,#000 32%,transparent 33%);mask-image:radial-gradient(circle,#000 32%,transparent 33%);-webkit-mask-size:4px 4px;mask-size:4px 4px;-webkit-mask-position:0 0;mask-position:0 0}.project-card__image{position:relative;display:block;overflow:hidden;background:0 0}.project-card__image img{width:100%;height:auto;display:block;transition:transform .3s ease}.project-card__image:hover img{transform:scale(1.02)}.project-single__hero{position:relative}.project-single__overlay{position:relative;z-index:1}.hero{position:relative;width:100vw;height:100vh;margin-left:50%;left:0;right:0;transform:translateX(-50%);background-size:cover;background-position:50%;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero__overlay{position:absolute;inset:0;background:rgba(0,0,0,.45)}.hero__content{position:relative;z-index:1;max-width:900px;width:100%;padding:2rem;text-align:center;color:#fff;margin:0 auto;display:flex;flex-direction:column;align-items:center;justify-content:center}.hero__content h1{font-size:clamp(2rem,6vw,4rem);margin:0 0 1rem}.hero__subtitle{font-size:clamp(1rem,2.5vw,1.5rem);opacity:.95;margin-bottom:2rem}.hero__btn{display:inline-block;background:var(--primary,#3b82f6);color:#fff;padding:.75rem 1.25rem;border-radius:.5rem;text-decoration:none;transition:transform .15s ease,opacity .15s ease}.hero__btn:hover{transform:translateY(-1px);opacity:.95}.posts{padding:2rem 0}.posts__header{margin-bottom:1rem}.posts__title{margin:0 0 .25rem;font-size:clamp(1.5rem,4vw,2rem)}.posts__intro{color:var(--secondary,#6b7280)}.posts__filters{display:grid;gap:.75rem;margin:0 0 1rem}.posts__search{display:flex;gap:.5rem;align-items:center}.posts__search input[type=search]{flex:1;padding:.55rem .75rem;color:var(--primary,#111827)}.posts__filter-group{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.posts__filter-group .label{font-size:.85rem;color:var(--secondary,#6b7280);margin-right:.25rem}.posts__filters .filter{}@media(max-width:640px){.posts__filters .filter{padding:var(--chip-pad-y-sm)var(--chip-pad-x-sm);font-size:.8rem}}.filter--clear{background:0 0}.posts__latest h2,.posts__older h2{margin:1rem 0 .75rem;font-size:1.25rem}.posts__latest-list{display:grid;gap:1rem}.post-card--latest{display:grid;grid-template-columns:240px 1fr;gap:1rem;align-items:stretch}@media(max-width:720px){.post-card--latest{grid-template-columns:1fr}}.posts__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}@media(max-width:1024px){.posts__grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.posts__grid{grid-template-columns:1fr}}.post-card{background:var(--theme,#fff);border:1px solid var(--entry,rgba(0,0,0,.1));border-radius:12px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,4%)}.post-card__image{display:block;background:var(--code-bg,#f4f4f5)}.post-card__image img{width:100%;height:100%;display:block;object-fit:cover}.post-card__placeholder{width:100%;height:100%;aspect-ratio:16/9;background:repeating-linear-gradient(45deg,#e5e7eb,#e5e7eb 10px,#f3f4f6 10px,#f3f4f6 20px)}.post-card--latest .post-card__image{aspect-ratio:unset}.post-card:not(.post-card--latest) .post-card__image{aspect-ratio:16/9}.post-card__body{padding:.85rem 1rem 1rem}.post-card__title{margin:0 0 .5rem;font-size:1.05rem}.post-card__title a{text-decoration:none}.post-card__meta{color:var(--secondary,#6b7280);font-size:.85rem;display:flex;align-items:center;gap:.35rem;margin:0 0 .5rem}.dot{opacity:.6}.post-card__categories,.post-card__tags{display:flex;flex-wrap:wrap;gap:.35rem;margin:0 0 .5rem}.badge--category{background:rgba(59,130,246,.12);color:#1f2937}.post-card__desc{margin:0;color:var(--secondary,#6b7280);display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;overflow:hidden}.post-single__hero{position:relative;min-height:40vh;background-size:cover;background-position:50%;display:flex;align-items:end}.post-single__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.25),rgba(0,0,0,.55))}.post-single__header{position:relative;z-index:1;width:100%;padding:2.5rem 1rem;color:#fff}.post-single__title{margin:0 0 .5rem;font-size:clamp(1.75rem,5vw,2.5rem)}.post-single__meta{opacity:.9}.post-single__title,.post-single__meta,.post-single__tags{text-shadow:0 1px 1px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.18)}.post-single__meta .badge{vertical-align:middle;margin-right:.35rem}.post-single__meta .dot{margin:0 .35rem}.post-single__meta .badge--draft{color:#92400e;background:rgba(251,191,36,.18);border-color:rgba(251,191,36,.35)}@media(prefers-color-scheme:dark){.post-single__meta .badge--draft{color:#fcd34d;background:rgba(251,191,36,.25);border-color:rgba(251,191,36,.45)}}.post-single__categories{margin-top:.5rem}.post-single__tags{margin-top:.5rem}.post-single__categories .tag,.post-single__tags .tag,.post-single__sticky-tags .tag{border-color:#bf9000}.post-single__content{width:100vw;position:relative;left:50%;right:50%;margin-left:-50vw;margin-right:-50vw;padding:2rem clamp(.75rem,2vw,2rem)}.post-single__sticky{position:sticky;top:0;z-index:5;background:var(--theme,#fff);backdrop-filter:saturate(120%)blur(4px);-webkit-backdrop-filter:saturate(120%)blur(4px);border-bottom:none}.post-single__sticky::after{content:"";position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:100vw;height:1px;background:#a02121;opacity:0;transition:opacity .15s ease-in-out;pointer-events:none}.post-single__sticky.is-stuck::after{opacity:1}.post-single__sticky-inner{display:flex;align-items:center;gap:.75rem 1rem;padding:.6rem .25rem;flex-wrap:wrap}.post-single__sticky-title{margin:0;font-size:clamp(1.05rem,2.5vw,1.25rem);font-weight:600}.post-single__sticky-tags{display:flex;flex-wrap:wrap;gap:.35rem}.post-single__sticky-sentinel{height:0}.post-single__layout{display:grid;grid-template-columns:300px minmax(0,1fr);gap:clamp(1rem,2vw,2rem)}@media(max-width:960px){.post-single__layout{grid-template-columns:1fr}.post-single__toc{position:static;top:auto;max-height:none;overflow:visible;padding-right:0}}.post-single__toc{position:sticky;top:6rem;align-self:start;max-height:calc(100vh - 7rem);overflow:auto;padding-right:.5rem}@media(max-width:960px){.post-single__toc{position:static;top:auto;max-height:none;overflow:visible;padding-right:0}}.toc__title{font-weight:600;margin-bottom:.5rem}.toc{font-size:.95rem}.toc ul{list-style:none;padding-left:.75rem}.toc li{margin:.25rem 0}.toc a{text-decoration:none;color:var(--secondary,#374151)}.toc a:hover{text-decoration:underline}.toc a.active{color:var(--primary,#111827);font-weight:600;border-left:3px solid var(--primary,#3b82f6);padding-left:.4rem}.toc__top{display:inline-block;margin-top:.75rem;font-size:.9rem;color:var(--secondary,#374151);text-decoration:none}.toc__top:hover{text-decoration:underline}.post-single__article{min-width:0}.post-single__article img,.post-single__article video,.post-single__article iframe{max-width:100%;height:auto}@media(prefers-color-scheme:light){.post-single__article .highlight:not(table),.post-single__article .chroma,.post-single__article pre code{background:#fff!important;color:var(--primary,#111827)}.post-single__article .lntable{background:#fff!important;border-collapse:separate;border-spacing:0}.post-single__article .lntable .lntd:first-child{background:#f8fafc;border-right:1px solid #e5e7eb}.post-single__article .lntable .lntd:last-child{background:#fff}}.post-single__article ul,.post-single__article ol{list-style-position:inside;padding-left:1em;text-indent:-1em;margin-left:0}.post-single__article li{margin-left:0}.post-single__article li ul,.post-single__article li ol{padding-left:1.25em;text-indent:0}.post-single__article img.align-center,.post-single__article .align-center img{display:block;margin:1rem auto}.post-single__article img.img--right,.post-single__article .img--right img{float:right;margin:0 0 1rem 1rem;max-width:var(--img-w,50%)}.post-single__article img.img--left,.post-single__article .img--left img{float:left;margin:0 1rem 1rem 0;max-width:var(--img-w,50%)}@media(max-width:700px){.post-single__article img.img--right,.post-single__article img.img--left,.post-single__article .img--right img,.post-single__article .img--left img{float:none;display:block;margin:.75rem auto;max-width:100%}}.clear-both{clear:both}.post-single__pager{margin-top:2.5rem;display:flex;justify-content:space-between;gap:1rem}.post-single__pager a{flex:1;padding:.75rem 1rem;border:1px solid var(--entry,rgba(0,0,0,.1));border-radius:10px;text-decoration:none;color:var(--primary,#111827);background:var(--theme,#fff)}.post-single__pager a:hover{background:var(--code-bg,#f3f4f6)}.pager__prev{text-align:left}.pager__next{text-align:right}html{scroll-behavior:smooth}.post-single__article h1,.post-single__article h2,.post-single__article h3,.post-single__article h4,.post-single__article h5,.post-single__article h6{scroll-margin-top:80px}.projects{padding:2rem 0}.projects__header{margin-bottom:1.25rem}.projects__title{margin:0 0 .25rem;font-size:clamp(1.5rem,4vw,2rem)}.projects__intro{color:var(--secondary,#6b7280)}.projects__filters{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1rem}.projects__filters .filter{}.filter{appearance:none;border:1px solid #d1d5db;background:#fff;color:var(--secondary,#374151);padding:.4rem .75rem;border-radius:999px;cursor:pointer;font-size:.85rem;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}@media(max-width:640px){.projects__filters .filter{padding:var(--chip-pad-y-sm)var(--chip-pad-x-sm);font-size:.8rem}}.filter.is-active{background:var(--primary,#3b82f6);color:#fff;border-color:transparent}.filter:hover{background:var(--code-bg,#f3f4f6)}.filter:focus-visible{outline:none;border-color:#9ca3af;box-shadow:0 0 0 3px rgba(59,130,246,.15)}.projects__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}.project-card{background:var(--theme,#fff);border:2px solid rgba(191,144,0,.5);border-radius:12px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,4%);transition:transform .12s ease,box-shadow .12s ease}.project-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,0,0,8%);border-color:rgba(212,163,14,.5);transition:all .2s ease-in-out}.project-card__image{display:block;aspect-ratio:16/9;background:var(--code-bg,#f4f4f5)}.project-card__image img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;background:0 0}.project-card__placeholder{width:100%;height:100%;background:repeating-linear-gradient(45deg,#e5e7eb,#e5e7eb 10px,#f3f4f6 10px,#f3f4f6 20px)}.project-card__body{padding:1rem 1rem 1.25rem}.project-card__title{font-size:1.05rem;margin:0 0 .5rem}.project-card__title a{text-decoration:none}.project-card__categories{display:flex;flex-wrap:wrap;gap:.35rem;margin:0 0 .4rem}.project-card__categories .badge--category{background:rgba(59,130,246,.15)!important;color:#1e40af!important;border:1px solid rgba(59,130,246,.3)!important;transition:all .2s ease!important}.project-card__categories .badge--category:hover{background:rgba(59,130,246,.25)!important}@media(prefers-color-scheme:dark){.project-card__categories .badge--category{background:rgba(96,165,250,.25)!important;color:#e0f2fe!important;border-color:rgba(96,165,250,.4)!important}.project-card__categories .badge--category:hover{background:rgba(96,165,250,.35)!important;color:#fff!important}}.project-card__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:.5rem 0 1rem}.project-card__tags .tag{appearance:none;display:inline-block;border:1px solid #bf9000;background:var(--theme,#fff);color:var(--secondary,#374151);padding:.35rem .75rem;border-radius:999px;cursor:pointer;font-size:.85rem;text-decoration:none;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.project-card__tags .tag:hover{background:var(--code-bg,#f3f4f6)}.project-card__tags .tag:focus-visible{outline:none;border-color:#bf9000;box-shadow:0 0 0 3px var(--ui-focus-ring,rgba(59,130,246,.15))}@media(prefers-color-scheme:dark){.project-card__tags .tag{background:var(--theme,#111827);color:var(--secondary,#d1d5db)}.project-card__tags .tag:hover{background:rgba(255,255,255,6%)}}.project-single__tags{display:flex;flex-wrap:wrap;gap:.5rem;margin:.75rem 0}.project-single__tags .tag{border-color:#bf9000;font-size:.8rem;padding:.35rem .75rem;background:var(--code-bg,#f3f4f6);color:var(--secondary,#6b7280);border:1px solid #bf9000;border-radius:999px;transition:all .2s ease}.project-single__tags .tag:hover{background:#bf9000;color:#fff}@media(prefers-color-scheme:dark){.project-card__tags .tag{background:rgba(75,85,99,.3);color:var(--secondary,#d1d5db);border-color:rgba(75,85,99,.5)}.project-card__tags .tag:hover{background:rgba(75,85,99,.5);color:#fff}.project-single__tags .tag{background:rgba(191,144,0,.1);color:#e5c76b;border-color:#bf9000}.project-single__tags .tag:hover{background:#bf9000;color:#fff}}.project-card__duration{display:flex;align-items:center;gap:.35rem;margin:.5rem 0;color:var(--secondary,#6b7280);font-size:.85rem}.project-card__duration .icon{width:1rem;height:1rem;flex-shrink:0;color:var(--primary,#4b5563)}.project-card__desc{margin:0;color:var(--secondary,#6b7280);display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.project-single__header{position:sticky;top:0;display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 0;background:var(--theme,#fff);z-index:100;border-bottom:2px solid #a02121;box-shadow:0 2px 4px rgba(0,0,0,5%)}.project-header-content{flex:1;max-width:70%}.project-logo{flex-shrink:0;width:200px;padding:1rem;display:flex;align-items:center;justify-content:center;position:relative;background:#fff;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,8%);border:1px solid rgba(0,0,0,5%);transition:all .2s ease;overflow:hidden}.project-logo::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;z-index:1;border-radius:7px}.project-logo img{max-width:100%;height:auto;max-height:80px;object-fit:contain;position:relative;z-index:2;transition:all .2s ease;padding:.5rem;box-sizing:border-box}@media(prefers-color-scheme:dark){.project-logo{background:#f8f9fa;border-color:rgba(255,255,255,.1);box-shadow:0 2px 10px rgba(0,0,0,.2)}.project-logo::before{background:#f8f9fa}.project-logo:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 15px rgba(0,0,0,.25)}.project-logo:hover::before{background:#fff}}@media(max-width:768px){.project-single__header{flex-direction:column;gap:1.5rem;padding:1.5rem 0}.project-header-content{max-width:100%;width:100%;order:1}.project-logo{width:100%;padding:0;margin:0;order:2;background:0 0;box-shadow:none;border:none;justify-content:flex-start}.project-logo::before{display:none}.project-logo img{max-height:60px;max-width:200px;padding:.75rem 1rem;background:#fff;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1)}@media(prefers-color-scheme:dark){.project-logo img{background:#f8f9fa;box-shadow:0 2px 8px rgba(0,0,0,.2)}}}.project-single__title{margin:0 0 .5rem;font-size:clamp(1.75rem,5vw,2.5rem)}.project-single__title,.project-single__meta{text-shadow:0 1px 1px rgba(0,0,0,.18),0 2px 6px rgba(0,0,0,.18)}.project-single__tags{text-shadow:none}.project-single__meta{opacity:.9}.project-single__content{padding:2rem 1rem;max-width:900px;margin:0 auto}.no-results{text-align:center;color:var(--secondary,#6b7280);font-size:1.1rem;margin:2rem 0;padding:1.5rem;background:var(--code-bg,#f9fafb);border-radius:.5rem;grid-column:1/-1}.pagination{width:100%;margin:3rem 0 1rem;padding:1rem 0}.pagination__inner{display:flex;justify-content:center;align-items:center;gap:1.5rem;flex-wrap:wrap;max-width:1200px;margin:0 auto;padding:0 1rem}.pagination__link{display:inline-flex;align-items:center;padding:.5rem 1rem;border-radius:6px;text-decoration:none;font-weight:500;transition:all .2s ease;border:1px solid var(--entry,rgba(0,0,0,.1));background:var(--theme,#fff);color:var(--primary,#111827);white-space:nowrap}.pagination__link:hover{border-color:#bf9000;color:#000;transform:translateY(-1px)}.pagination__link--prev::before{content:"";display:inline-block;width:.5rem;height:.5rem;border-left:2px solid;border-bottom:2px solid;transform:rotate(45deg);margin-right:.5rem}.pagination__link--next::after{content:"";display:inline-block;width:.5rem;height:.5rem;border-top:2px solid;border-right:2px solid;transform:rotate(45deg);margin-left:.5rem;margin-left:.5rem}.pagination__info{color:var(--secondary,#6b7280);font-size:.9rem;margin:0 .5rem}@media(prefers-color-scheme:dark){.pagination__link{background:var(--theme,#111827);color:#e5e7eb;border-color:rgba(255,255,255,.1)}.pagination__link:hover{border-color:#d4a30e;color:#fff}}.project-single__sticky{position:sticky;top:0;z-index:5;background:var(--theme,#fff);backdrop-filter:saturate(120%)blur(4px);-webkit-backdrop-filter:saturate(120%)blur(4px);border-bottom:none}.project-single__sticky::after{content:"";position:absolute;left:50%;.project-single__pager { margin-top: 2.5rem; display: flex; flex-direction: column; gap: 0.75rem; } .project-single__pager .pager__item { width: 100%; } .project-single__pager .pager__link { display: block; width: 100%; padding: 0.75rem 1rem; border: 1px solid var(--entry, rgba(0,0,0,0.1)); border-radius: 10px; text-decoration: none; color: var(--primary, #111827); background: var(--theme, #fff); transition: background-color 0.2s ease; } .project-single__pager .pager__link:hover { background: var(--code-bg, #f3f4f6); } .project-single__pager .pager__prev { text-align: left; } .project-single__pager .pager__next { text-align: right; }}.services{padding:2rem 0}.services__header{margin-bottom:1rem}.services__title{margin:0 0 .25rem;font-size:clamp(1.5rem,4vw,2rem)}.services__intro{color:var(--secondary,#6b7280)}.services__list{display:grid;gap:1rem}.service-card{background:var(--theme,#fff);border:1px solid var(--entry,rgba(0,0,0,.1));border-radius:12px;box-shadow:0 1px 2px rgba(0,0,0,4%);overflow:hidden}.service-card__title{margin:0;padding:.85rem 1rem 0;font-size:1.1rem}.service-card__body{padding:.5rem 1rem 1rem}.service-card__items{margin:.25rem 0 0 1.1rem}.service-card__items li{margin:.25rem 0}.service-card__actions{margin-top:.75rem}#menu li a[href="#"]{opacity:.6;cursor:default;pointer-events:none;text-decoration:none}:root{--ui-input-border:#d1d5db;--ui-input-radius:10px;--ui-focus-border:#9ca3af;--ui-focus-ring:rgba(59, 130, 246, 0.15);--chip-pad-y:0.35rem;--chip-pad-x:0.75rem;--chip-pad-y-sm:0.25rem;--chip-pad-x-sm:0.6rem;--chip-pad-y-lg:0.45rem;--chip-pad-x-lg:0.9rem}.hero .hero__content h1{color:#fff!important;font-family:cascadia mono,cascade mono,ui-monospace,SFMono-Regular,Menlo,Consolas,liberation mono,monospace;font-weight:600}@media(prefers-color-scheme:dark){:root{--ui-input-border:rgba(255,255,255,0.18);--ui-focus-border:rgba(255,255,255,0.35);--ui-focus-ring:rgba(59, 130, 246, 0.25)}}:is(input[type=text],input[type=email],input[type=tel],input[type=search],select,textarea){border:1px solid var(--ui-input-border);border-radius:var(--ui-input-radius);background:var(--theme,#fff);transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}:is(input[type=text],input[type=email],input[type=tel],input[type=search],select,textarea):focus{outline:none;border-color:var(--ui-focus-border);box-shadow:0 0 0 3px var(--ui-focus-ring)}.chip,.filter{appearance:none;border:1px solid #bf9000;background:var(--theme,#fff);color:var(--secondary,#374151);padding:var(--chip-pad-y)var(--chip-pad-x);border-radius:999px;cursor:pointer;font-size:.85rem;transition:border-color .15s ease,box-shadow .15s ease,background-color .15s ease}.chip:hover,.filter:hover{background:var(--code-bg,#f3f4f6)}.chip:focus-visible,.filter:focus-visible{outline:none;border-color:#bf9000;box-shadow:0 0 0 3px var(--ui-focus-ring)}.chip.is-active,.filter.is-active{background:var(--primary,#3b82f6);color:#fff;border-color:#bf9000}@media(prefers-color-scheme:dark){.chip,.filter{background:var(--theme,#111827)}.chip:hover,.filter:hover{background:rgba(255,255,255,6%)}}.chip--sm,.filter.filter--sm{padding:var(--chip-pad-y-sm)var(--chip-pad-x-sm);font-size:.8rem}.chip--lg,.filter.filter--lg{padding:var(--chip-pad-y-lg)var(--chip-pad-x-lg);font-size:.9rem}.btn{display:inline-block;padding:.6rem 1rem;border-radius:8px;text-decoration:none;cursor:pointer;border:1px solid transparent}.btn--primary{background:var(--primary,#3b82f6);color:#fff;border-color:#bf9000}.btn--primary:hover{filter:brightness(.95)}.btn--primary:focus-visible{outline:none;border-color:#bf9000}.btn--secondary{background:#bfbfbf;color:var(--primary,#111827);border-color:#bfbfbf}.btn--secondary:hover{filter:brightness(.98)}.btn--outline{background:0 0;color:#000;border-color:#6b7280;font-weight:500;transition:all .2s ease}.btn--outline:hover{background:rgba(37,99,235,.1);border-color:#4b5563;color:#000;transform:translateY(-1px);box-shadow:0 1px 2px rgba(0,0,0,5%)}@media(prefers-color-scheme:dark){.btn--secondary{background:#bfbfbf}.btn--outline{color:#e5e7eb;border-color:#4b5563}.btn--outline:hover{background:rgba(59,130,246,.15);border-color:#6b7280}}.badge{display:inline-block;font-size:.72rem;line-height:1;padding:.3rem .5rem;border-radius:6px;border:1px solid var(--entry,rgba(0,0,0,8%))}.badge--draft{background:rgba(251,191,36,.18);color:#92400e;border-color:rgba(251,191,36,.35)}.badge--featured{background:rgba(251,191,36,.18);color:#92400e;border-color:rgba(251,191,36,.35)}@media(prefers-color-scheme:dark){.badge--draft{background:rgba(251,191,36,.25);color:#fcd34d;border-color:rgba(251,191,36,.45)}.badge--featured{background:rgba(251,191,36,.25);color:#fcd34d;border-color:rgba(251,191,36,.45)}}.badge--category{background:rgba(59,130,246,.12);color:var(--primary,#1f2937)}@media(prefers-color-scheme:dark){.badge--category{background:rgba(59,130,246,.2)}}.tag{display:inline-block;font-size:.75rem;line-height:1;padding:.35rem .5rem;border-radius:999px;background:var(--code-bg,#f3f4f6);color:var(--secondary,#6b7280);border:1px solid var(--entry,rgba(0,0,0,8%))}.to-top{position:fixed;right:1rem;bottom:1.25rem;z-index:50;border:1px solid var(--entry,rgba(0,0,0,8%));background:var(--theme,#fff);color:var(--primary,#111827);padding:.5rem .65rem;border-radius:999px;box-shadow:0 6px 18px rgba(0,0,0,.12);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.to-top:hover{transform:translateY(-2px)}@media(prefers-color-scheme:dark){.to-top{background:var(--theme,#0b0f19);color:#e5e7eb}}.header{position:relative;z-index:60}.header .logo a{display:inline-flex;align-items:center;gap:.5rem;font-family:cascade mono,ui-monospace,SFMono-Regular,Menlo,Consolas,liberation mono,monospace;font-weight:400;letter-spacing:.01em;white-space:nowrap}.header .logo{padding-left:.5rem}.header .logo picture{display:inline-flex;align-items:center}.header .logo img{display:block;height:auto;max-height:36px;margin-right:.25rem}.header .logo a b,.header .logo a strong{font-weight:600}@media(max-width:600px){.header .logo img{max-height:32px}}.footer .footer-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}.footer .footer-left{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}.footer .footer-right{display:flex;align-items:center}.footer .footer-logo img{display:block;height:auto;max-height:36px;margin-right:.5rem}@media(max-width:600px){.footer .footer-inner{flex-direction:column;align-items:flex-start;gap:.5rem}.footer .footer-right{align-self:stretch;display:flex;justify-content:flex-end;width:100%}}.footer{max-width:calc(var(--nav-width) + var(--gap) * 2);text-align:left}.lang-dropdown{position:relative;display:inline-block;margin-left:.25rem}.lang-dropdown__toggle{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:999px;border:1px solid transparent;background:0 0;cursor:pointer;font-size:.85rem}.lang-dropdown__toggle:focus-visible{outline:none;border-color:var(--ui-focus-border,#9ca3af);box-shadow:0 0 0 3px var(--ui-focus-ring,rgba(59,130,246,.25))}.lang-flag{display:inline-block}.lang-label{white-space:nowrap}.lang-dropdown__menu{position:absolute;right:0;margin-top:0;padding:.25rem 0;list-style:none;min-width:7.5rem;background:var(--theme,#fff);border-radius:.5rem;border:1px solid var(--entry,rgba(0,0,0,8%));box-shadow:0 10px 30px rgba(0,0,0,.15);z-index:80;display:none}.lang-dropdown__menu li a{display:flex;align-items:center;gap:.4rem;padding:.3rem .75rem;font-size:.85rem}.lang-dropdown__menu li a.lang-option--current{font-weight:600;cursor:default;pointer-events:none}.lang-dropdown__menu li a:hover{background:var(--code-bg,#f3f4f6)}@media(prefers-color-scheme:dark){.lang-dropdown__menu{background:var(--theme,#0b0f19);border-color:rgba(55,65,81,.8)}.lang-dropdown__menu li a:hover{background:rgba(255,255,255,6%)}}.lang-dropdown:hover .lang-dropdown__menu,.lang-dropdown:focus-within .lang-dropdown__menu{display:block}.header .logo{padding-left:.25rem}.header .logo-switches{display:inline-flex;align-items:center;gap:.35rem}.lang-dropdown__toggle{padding-inline:.4rem;font-size:.8rem}@media(max-width:768px){.lang-dropdown__toggle .lang-label,.lang-dropdown__menu .lang-label{display:none}}@media(min-width:960px){.header .nav{display:flex;align-items:center;justify-content:space-between;flex-wrap:nowrap}.header .logo{padding-left:.25rem}.header .logo-switches{flex-wrap:nowrap;gap:.3rem}#menu{display:flex;flex-wrap:nowrap}#menu li a{padding-inline:.45rem;font-size:.9rem}}.project-single__header,.project-single__content,.project-single__pager{position:relative;z-index:1;overflow:visible}