/*
  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{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}.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center}.i18n_list{display:inline-flex}.post-meta .i18n_list li{list-style:none;margin:auto 3px}.breadcrumbs a{font-size:16px}.post-content{color:var(--content);margin:30px 0}.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,.post-meta .i18n_list li 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-bottom:var(--content-gap);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;padding:0 10px;opacity:.9}.toc li ul{margin-inline-start:var(--gap)}.toc summary:focus{outline:0}.post-footer{margin-top:var(--content-gap)}.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}}@property --primary-lightness{syntax: "<percentage>";
  inherits: true;
  initial-value: 50%;
}@property --theme-bg-lightness{syntax: "<percentage>";
  inherits: true;
  initial-value: 100%;
}:root{--primary-hsl:211 100% 50%;--primary:#007bff !important;--primary-rgb:0, 123, 255;--theme:#fff !important;--theme-rgb:255, 255, 255;--secondary:#737373 !important;--tertiary:#a3a3a3 !important;--content:#404040 !important;--code-bg:#f5f5f5 !important;--border:#e5e5e5 !important;--yellow:#ffd700;--fg:var(--content);--selection-text-color:var(--primary);--selection-underline-color:oklch(from var(--primary) calc(l + 0.2) calc(c * 0.6) h / 0.6);--spacing-xxs:2px;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--spacing-3xl:64px;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji";--font-serif:"New York", Georgia, "Times New Roman", serif;--font-mono:ui-monospace, 'Courier New', Monaco, "Cascadia Code",
    "Source Code Pro", monospace;--text-xs:clamp(11px, 0.75rem, 12px);--text-sm:clamp(13px, 0.9rem, 14px);--text-base:14px;--text-lg:clamp(16px, 1.1rem, 18px);--text-xl:clamp(18px, 1.3rem, 20px);--text-2xl:clamp(22px, 1.6rem, 24px);--text-3xl:clamp(26px, 1.9rem, 28px);--text-4xl:clamp(32px, 2.25rem, 34px);--leading-tight:1.2;--leading-snug:1.4;--leading-normal:1.6;--leading-relaxed:1.75;--transition-fast:0.2s cubic-bezier(0.4, 0, 0.2, 1);--transition-normal:0.3s cubic-bezier(0.4, 0, 0.2, 1);--transition-slow:0.5s cubic-bezier(0.4, 0, 0.2, 1);--radius-sm:3px;--radius:4px;--radius-md:6px;--radius-lg:8px;--radius-full:9999px;--shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.05);--shadow:0 1px 3px 0 rgb(0 0 0 / 0.1);--shadow-md:0 4px 6px -1px rgb(0 0 0 / 0.1);--shadow-lg:0 10px 15px -3px rgb(0 0 0 / 0.1);--shadow-xl:0 20px 25px -5px rgb(0 0 0 / 0.1);--container-sm:640px;--container-md:768px;--container-lg:800px;--container-xl:1024px;--side-panel-width:clamp(220px, 85vw, 300px)}.dark{--primary:#66b0ff !important;--primary-rgb:102, 176, 255;--theme:#1a1a1a !important;--theme-rgb:26, 26, 26;--secondary:#aaa !important;--tertiary:#777 !important;--content:#ddd !important;--code-bg:#2d2d2d !important;--border:#333 !important;--fg:var(--content);--selection-text-color:var(--primary);--selection-underline-color:oklch(from var(--primary) l calc(c * 0.7) h / 0.7);--shadow-sm:0 1px 2px 0 rgb(0 0 0 / 0.3);--shadow:0 1px 3px 0 rgb(0 0 0 / 0.4);--shadow-md:0 4px 6px -1px rgb(0 0 0 / 0.5);--shadow-lg:0 10px 15px -3px rgb(0 0 0 / 0.5);--shadow-xl:0 20px 25px -5px rgb(0 0 0 / 0.6)}.post-list-page{padding:0 var(--spacing-md)}.post-list-header{max-width:var(--container-lg);margin:0 auto var(--spacing-lg)}.post-list-header h1{margin:0 0 var(--spacing-sm);font-size:var(--text-2xl);font-weight:600}.post-list-desc{margin:0;color:var(--secondary)}.posts-grid{max-width:var(--container-lg);margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-lg)}.post-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;border:1px solid var(--border);border-radius:var(--radius);background:var(--theme);transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.post-card:hover{border-color:var(--tertiary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.post-card__cover{width:100%;aspect-ratio:16/9;overflow:hidden;border-bottom:1px solid var(--border);border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.post-card__image{width:100%;height:100%;object-fit:cover;display:block}.post-card__content{padding:var(--spacing-md)}.post-card__content .badge{margin-bottom:var(--spacing-xs)}.post-card__title{margin:0 0 var(--spacing-xs);font-size:var(--text-lg);font-weight:600}.post-card__excerpt{margin:0 0 var(--spacing-sm);color:var(--secondary);font-size:var(--text-sm)}.post-card__meta{margin:0;color:var(--tertiary);font-size:var(--text-sm)}.post-card__tags{margin-top:var(--spacing-sm);display:flex;gap:.35rem;flex-wrap:wrap}.badge{display:inline-block;font-size:11px;line-height:1;padding:4px 6px;border-radius:var(--radius);border:1px solid var(--border);color:var(--tertiary)}.badge--featured{color:#a2582a;border-color:#f1c18a;background:color-mix(in oklab,#f1c18a 30%,transparent)}.posts-view-all{max-width:var(--container-lg);margin:var(--spacing-lg)auto 0;display:flex;justify-content:center}html{font-size:14px}.main,.post-content{font-family:var(--font-serif);font-size:var(--text-base);line-height:var(--leading-normal);font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6,.post-title{font-family:var(--font-serif);font-weight:400;line-height:var(--leading-tight);text-wrap:balance}::selection{color:var(--selection-text-color);background-color:transparent;text-decoration:underline wavy transparent;-webkit-text-decoration:underline wavy transparent;text-decoration-thickness:1px}p::selection,li::selection,h1::selection,h2::selection,h3::selection,h4::selection,h5::selection,h6::selection,td::selection,th::selection,figcaption::selection,span::selection,a::selection,strong::selection,em::selection{text-decoration-color:var(--selection-underline-color);-webkit-text-decoration-color:var(--selection-underline-color)}pre ::selection,code ::selection{color:inherit;background-color:Highlight;text-decoration:none;-webkit-text-decoration:none}.header,body .header,.list .header,.single .header{background:var(--theme)!important;background-color:var(--theme)!important;border-bottom:2px solid var(--border)!important;position:sticky;top:0;z-index:1000;width:100%;transform:translateY(0);transition:transform var(--transition-normal)}.dark .header,.dark body .header,.dark .list .header,.dark .single .header{background:var(--theme)!important;background-color:var(--theme)!important;border-bottom:2px solid var(--border)!important}.header--hidden{transform:translateY(-100%)}.nav{max-width:var(--container-lg);margin:0 auto;padding:1rem var(--spacing-lg);display:flex;align-items:center;justify-content:space-between}.nav-right{display:inline-flex;gap:8px;align-items:center}.logo{display:flex!important;flex-direction:row!important;align-items:center!important;text-decoration:none;gap:0}.logo-icon{height:24px;width:24px;margin-right:.5rem;display:block;transition:transform var(--transition-fast)}.logo-text{font-family:caveat,cursive;font-size:26px;font-weight:600;color:var(--primary);display:inline-block;transition:opacity var(--transition-fast)}.logo-break{display:inline}@media(min-width:768px){.logo-text{white-space:nowrap}.logo-break{display:none}}.logo:hover .logo-icon{transform:rotate(45deg)}.logo:hover .logo-text{opacity:.8}.menu-toggle{background:0 0;border:none;cursor:pointer;padding:8px;color:var(--content);transition:color var(--transition-fast)}.menu-toggle:hover{color:var(--primary)}.menu-icon{display:block;stroke:currentColor;transition:transform var(--transition-fast)}.header-theme-toggle{background:0 0;border:none;cursor:pointer;margin-right:4px;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;color:var(--content)}.header-theme-toggle:hover{color:var(--primary)}.header-theme-toggle:focus{outline:none}.header-theme-toggle .icon-sun{display:inline}.header-theme-toggle .icon-moon{display:none}body.dark .header-theme-toggle .icon-sun{display:none}body.dark .header-theme-toggle .icon-moon{display:inline}.menu-inline{display:none;list-style:none;margin:0;padding:0;gap:var(--spacing-lg);align-items:center}.menu-inline__link{color:var(--content);text-decoration:none;font-size:var(--text-sm);padding:6px 0;border-bottom:1px solid transparent;transition:color var(--transition-fast),border-color var(--transition-fast)}.menu-inline__link:hover{color:var(--primary);border-bottom-color:var(--primary)}.menu-inline__link.is-active{color:var(--primary)}.side-menu{position:fixed;inset:0;z-index:1200;opacity:0;visibility:hidden;pointer-events:none;transition:opacity var(--transition-normal),visibility var(--transition-normal)}.side-menu.open{opacity:1;visibility:visible;pointer-events:auto}.side-menu__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);opacity:0;transition:opacity var(--transition-normal)}.side-menu.open .side-menu__backdrop{opacity:1}.dark .side-menu__backdrop{background:rgba(0,0,0,.7)}.side-menu__panel{position:absolute;top:0;right:0;height:100%;width:var(--side-panel-width);background:var(--theme);border-left:1px solid var(--border);box-shadow:0 10px 30px rgba(0,0,0,.2);transform:translateX(var(--side-panel-width));opacity:0;transition:transform 260ms cubic-bezier(.2,.8,.2,1),opacity 200ms ease;display:flex;flex-direction:column;will-change:transform,opacity}.side-menu.open .side-menu__panel{transform:translateX(0);opacity:1}.side-menu__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);border-bottom:1px solid var(--border)}.side-menu__title{font-family:var(--font-serif);font-size:var(--text-lg);color:var(--content);white-space:nowrap}.side-menu__actions{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.side-menu__title{overflow:hidden;text-overflow:ellipsis}.side-menu__close{background:0 0;border:none;color:var(--content);cursor:pointer;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center}.side-menu__close:hover{color:var(--primary)}.side-menu__nav{display:flex;flex-direction:column;padding:var(--spacing-sm)0}.side-menu__profile{padding:var(--spacing-md);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm)}.side-menu__avatar{width:64px;height:64px;border-radius:var(--radius-full);object-fit:cover;box-shadow:var(--shadow-sm)}.side-menu__bio{margin:0;font-size:var(--text-sm);color:var(--secondary);text-align:center}.side-menu__link{font-size:var(--text-base);color:var(--content);text-decoration:none;padding:var(--spacing-sm)var(--spacing-lg);transition:background-color var(--transition-fast),color var(--transition-fast)}.side-menu__link:hover{background:var(--code-bg);color:var(--primary)}:where(a,button,.btn,.post-card,.menu-inline__link,.side-menu__link):focus-visible{outline:2px solid color-mix(in oklab,var(--primary),black 15%);outline-offset:2px;border-radius:4px}.side-menu__link--icon{display:inline-flex;align-items:center;gap:var(--spacing-sm)}.side-menu__social{margin-top:auto;padding:var(--spacing-md);border-top:1px solid var(--border);display:flex;gap:var(--spacing-md);justify-content:center;align-items:center}.social-btn{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-full);color:var(--content);background:var(--theme);border:1px solid var(--border);transition:color var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-fast)}.social-btn:hover{color:var(--primary);border-color:var(--primary);background:var(--code-bg)}.social-btn svg{width:22px;height:22px}.social-btn--github:hover{color:#24292f;border-color:#24292f}.social-btn--linkedin:hover{color:#0a66c2;border-color:#0a66c2}.social-btn--x:hover,.social-btn--twitter:hover{color:#000;border-color:#000}.dark .social-btn--github:hover{color:#fff;background:#24292f;border-color:#24292f}.dark .social-btn--linkedin:hover{color:#fff;background:#0a66c2;border-color:#0a66c2}.dark .social-btn--x:hover,.dark .social-btn--twitter:hover{color:#000;background:#fff;border-color:#fff}.no-scroll{overflow:hidden}@media(min-width:768px){.menu-inline{display:flex}.menu-toggle{display:none}}.home-hero{margin-bottom:2rem;padding:0}.home-hero-name{padding:0;margin:0}.home-hero-name h1{font-family:plus jakarta sans,var(--font-sans);font-size:2.5rem;font-weight:600;line-height:1.2;margin:0 0 1rem;padding:0;color:var(--primary);letter-spacing:-.02em;white-space:normal}.mobile-only{display:none}.desktop-only{display:inline}@media(max-width:767px){.mobile-only{display:inline}.desktop-only{display:none}}.social-icons{display:flex;gap:1rem;margin:1rem 0 0!important;padding:0!important;flex-wrap:wrap;align-items:center;justify-content:flex-start;list-style:none}.social-icons a,.social-icon{display:block;width:24px;height:24px;margin:0;padding:0;color:var(--secondary);text-decoration:none!important;border:none!important;border-bottom:none!important;background:0 0!important;transition:color .2s ease}.social-icons a svg,.social-icon svg{width:24px;height:24px;fill:currentColor;display:block}.social-icons a:hover,.social-icon:hover{color:var(--primary);text-decoration:none!important;border:none!important;border-bottom:none!important}.main{max-width:var(--container-lg);margin:0 auto;padding:0 var(--spacing-md)}.home-page{max-width:var(--container-lg);margin:0 auto;padding:0 var(--spacing-xl)}.home-content{max-width:800px;margin:0 auto;padding:1rem 0;& h2 { font-size: var(--text-2xl); margin-bottom: var(--spacing-lg); margin-top: 0; font-weight: 400; line-height: var(--leading-tight); } & p { font-family: var(--font-serif); font-size: 1.1rem; line-height: 1.6; color: var(--content); margin-bottom: 1.5rem; } & ul { list-style-type: disc; margin-left: 1.5rem; margin-bottom: 2rem; padding-left: 0; & li { margin-bottom: 1rem; line-height: 1.6; color: var(--content); font-size: var(--text-base); } } & strong { font-weight: 700; color: var(--content); } & a { color: var(--primary); text-decoration: none; border-bottom: 1px solid var(--primary); transition: opacity var(--transition-fast); &:hover { opacity: 0.7; } }}.footer{font-size:var(--text-sm);color:var(--tertiary);padding:var(--spacing-3xl)var(--spacing-lg)var(--spacing-2xl);border-top:1px solid var(--border);text-align:center;max-width:var(--container-lg);margin:0 auto;& .social-links { justify-content: center; margin-bottom: var(--spacing-md); }}.footer-theme-toggle{display:flex;justify-content:center;align-items:center;margin-bottom:var(--spacing-lg)}.accessibility-tools{display:flex;align-items:center}button#theme-toggle{background:0 0!important;border:none!important;cursor:pointer;margin:0;padding:0;display:flex;align-items:center;justify-content:center;color:var(--content)!important;transition:color var(--transition-fast),transform var(--transition-fast);width:44px;height:44px}button#theme-toggle:hover{color:var(--primary)!important;transform:scale(1.05)}button#theme-toggle svg{width:22px!important;height:22px!important;fill:currentColor!important;stroke:currentColor!important;display:block}body:not(.dark) #moon{display:none!important}body:not(.dark) #sun{display:block!important}body.dark #sun{display:none!important}body.dark #moon{display:block!important;vertical-align:middle}.social-links{display:flex;gap:var(--spacing-md);list-style:none;margin:0;padding:0;& li { margin: 0; padding: 0; } & a { color: var(--content); text-decoration: none; font-size: var(--text-sm); transition: color var(--transition-fast); &:hover { color: var(--primary); } }}.home-avatar{text-align:center;margin-bottom:var(--spacing-md);& img { width: 120px; height: 120px; border-radius: var(--radius-full); object-fit: cover; margin: 0 auto; box-shadow: var(--shadow-md); }}.home-hero-heading{font-family:var(--font-serif);font-size:var(--text-2xl);margin-bottom:var(--spacing-sm);margin-top:0;font-weight:400;line-height:var(--leading-tight);text-align:center}.home-social-links{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-md);& a { color: var(--content); text-decoration: none; font-size: var(--text-sm); transition: color var(--transition-fast); &:hover { color: var(--primary); } }}.home-cta-section{text-align:center;margin:.75rem 0}.btn-group--center{display:flex;justify-content:center;gap:.75rem;margin:.75rem 0;flex-wrap:wrap}.btn{padding:.6rem 1.2rem;border-radius:var(--radius);font-size:1rem}.btn{font-family:var(--font-sans);font-weight:600;font-size:13px;text-decoration:none;border-radius:var(--radius-md);background:var(--theme);padding:6px 10px;margin:0;display:inline-flex;align-items:center;justify-content:center;position:relative;transform:translateY(0);transition:all .1s cubic-bezier(.4,0,.2,1);cursor:pointer}.btn--outline{color:var(--primary);border:1.5px solid var(--primary);box-shadow:0 3px 0 0 var(--primary);&:hover { transform:translateY(-2px); box-shadow:0 5px 0 0 var(--primary); } &:active { transform:translateY(2px); box-shadow:0 1px 0 0 var(--primary); transition:all 0.05s ease; }}.btn--primary{background:var(--primary);color:#fff;border:1.5px solid var(--primary);box-shadow:0 3px color-mix(in oklab,var(--primary),black 20%);&:hover { box-shadow:0 5px 0 0 color-mix(in oklab,var(--primary),black 20%); } &:active { box-shadow:0 1px 0 0 color-mix(in oklab,var(--primary),black 20%); }}.btn--ghost{color:var(--primary);border:1px dashed var(--primary);background:0 0}.btn--sm{padding:6px 10px;font-size:13px}.btn--md{padding:10px 16px;font-size:14px}.btn--lg{padding:12px 20px;font-size:15px}.btn--block{display:flex;width:100%}.btn__icon{margin-left:var(--spacing-xs)}.btn-group{display:inline-flex;gap:var(--spacing-sm);flex-wrap:wrap;align-items:center}.btn-group--center{display:flex;justify-content:center;flex-wrap:wrap}.btn-group--end{display:flex;justify-content:flex-end}.btn-group--block{display:flex;width:100%}.btn-group--stack{display:flex;flex-direction:column;align-items:stretch}.cta-link{color:var(--primary);border:1.5px solid var(--primary);background:var(--theme);padding:6px 10px;box-shadow:0 3px 0 0 var(--primary);font-family:var(--font-sans);font-weight:600;font-size:13px;text-decoration:none;border-radius:var(--radius-md);display:inline-flex;align-items:center;justify-content:center;position:relative;transform:translateY(0);transition:all .1s cubic-bezier(.4,0,.2,1);cursor:pointer;&:hover { transform:translateY(-2px); box-shadow:0 5px 0 0 var(--primary); } &:active { transform:translateY(2px); box-shadow:0 1px 0 0 var(--primary); transition:all 0.05s ease; }}.dark .btn--outline,.dark .cta-link{background:var(--theme);color:#66b0ff;border-color:#66b0ff}.published-posts{margin-top:1rem;padding:var(--spacing-md)0 var(--spacing-lg);& > h2 { font-size: var(--text-xl); margin-bottom: var(--spacing-lg); font-weight: 600; font-style: italic; }}.posts-list{display:flex;flex-direction:column;gap:2rem;padding:0;margin:0}.post-entry-link{display:block;text-decoration:none;color:inherit;&:hover .post-entry { background:var(--code-bg); border-color:var(--tertiary); transform:translateY(-4px); box-shadow:0 8px 16px rgba(var(--theme-rgb)/0.08); } &:hover .entry-header h3 { color:var(--primary); }}.post-entry{padding:1.5rem;margin:0;border:1px solid var(--border);background:0 0;border-radius:var(--radius-lg);transition:all .3s ease;cursor:pointer;& .entry-header h3 { font-size: var(--text-base); margin-bottom: var(--spacing-xs); margin-top: 0; font-weight: 400; color: var(--content); transition: color var(--transition-fast); } & .entry-content { font-size: var(--text-sm); color: var(--secondary); margin: var(--spacing-xs) 0 var(--spacing-sm) 0; line-height: var(--leading-normal); } &:hover { background: var(--code-bg); border-color: var(--tertiary); }}.dark .post-entry-link:hover .post-entry{box-shadow:0 8px 16px rgba(0,0,0,.3)}.post-meta{font-size:.9rem;color:var(--tertiary);font-family:var(--font-mono);margin-bottom:.5rem;font-variant-numeric:tabular-nums;& time { font-family: var(--font-mono); }}.post-tags{margin-top:var(--spacing-sm);display:flex;gap:.5rem;flex-wrap:wrap;& .tag { background: var(--code-bg); border: 1px solid var(--border); border-radius: var(--radius); padding: 0.25rem 0.5rem; font-size: 0.8rem; color: var(--tertiary); transition: all var(--transition-fast); &:hover { border-color: var(--primary); color: var(--primary); } }}.post-single{max-width:720px;margin:0 auto;position:relative}.post-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--border)}.post-single .post-title{font-size:var(--text-3xl);margin-bottom:var(--spacing-md);font-weight:400}.post-description{font-size:var(--text-base);color:var(--secondary);margin:var(--spacing-md)0;line-height:var(--leading-normal)}.post-content{& h2 { font-size: var(--text-xl); font-weight: 400; margin-top: var(--spacing-2xl); margin-bottom: var(--spacing-md); } & h3 { font-size: var(--text-lg); margin-top: var(--spacing-xl); margin-bottom: var(--spacing-sm); font-weight: 400; } & p { font-family: var(--font-serif); font-size: var(--text-base); line-height: 1.6; color: var(--fg); margin: 0 0 1rem; padding: 0; letter-spacing: 0; word-spacing: 0; text-align: left; text-indent: 0; hyphens: auto; } & ul, & ol { margin: var(--spacing-md) 0; padding-left: var(--spacing-xl); line-height: var(--leading-normal); } & li { margin: var(--spacing-sm) 0; } & strong { font-weight: 600; color: var(--content); } & code { font-family: var(--font-mono); font-size: var(--text-base); background: var(--code-bg); padding: var(--spacing-xxs) var(--spacing-sm); border-radius: var(--radius); } & pre code { padding: 0; }}.post-content p{& .underline, & u { text-decoration: underline; text-decoration-thickness: 0.06em; text-underline-offset: 0.14em; } & mark, & .highlight { background-color: oklch(from var(--yellow) calc(l + 0.3) c h / 0.15); color: inherit; padding: 0.05em 0.1em; border-radius: 0.15em; } & .highlight-underline { text-decoration-line: underline; text-decoration-color: oklch(from var(--yellow) l c h / 0.6); text-decoration-thickness: 0.14em; text-underline-offset: 0.18em; }}.dark .post-content p{& mark, & .highlight { background-color: oklch(from var(--yellow) calc(l - 0.3) c h / 0.25); }}.post-content a,.entry-content a{color:var(--primary);text-decoration:none;border-bottom:1px solid var(--primary);transition:opacity var(--transition-fast);&:hover { opacity:0.7; }}.post-content p a:hover{text-decoration:underline;text-underline-offset:2px;text-decoration-color:oklch(from var(--fg) l c h/.2)}.highlight{margin:var(--spacing-md)0;border-radius:var(--radius);overflow:hidden;position:relative;&::before { content:attr(data-lang); position:absolute; top:0; right:0; padding:var(--spacing-xs) var(--spacing-sm); font-size:11px; font-family:var(--font-mono); background:rgba(0,0,0,0.3); color:var(--tertiary); text-transform:uppercase; letter-spacing:0.5px; border-bottom-left-radius:var(--radius); }}.dark .highlight::before{background:rgba(255,255,255,.1)}.year-progress{margin-bottom:var(--spacing-md);max-width:300px;margin-left:auto;margin-right:auto}.year-progress-label{font-size:var(--text-xs);color:var(--tertiary);margin-bottom:var(--spacing-sm);font-family:var(--font-mono);font-variant-numeric:tabular-nums}.year-progress-bar{height:var(--spacing-xs);background:var(--border);border-radius:var(--spacing-xxs);overflow:hidden}.year-progress-fill{height:100%;background:var(--primary);transition:width var(--transition-normal);border-radius:var(--spacing-xxs)}.related-posts{margin-top:var(--spacing-3xl);padding-top:var(--spacing-2xl);border-top:1px solid var(--border);& h2 { font-size: var(--text-xl); margin-bottom: var(--spacing-lg); font-weight: 600; }}.related-posts-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.related-post-card{padding:var(--spacing-sm);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition-fast),background-color var(--transition-fast);&:hover { background:var(--code-bg); border-color:var(--tertiary); & h3 a { color:var(--primary); } } & h3 { font-size:var(--text-base); margin:0 0 var(--spacing-sm) 0; font-weight:500; & a { color:var(--content); text-decoration:none; border-bottom:none; transition:color var(--transition-fast); } }}.related-post-description{font-size:var(--text-sm);color:var(--secondary);margin:var(--spacing-sm)0;line-height:var(--leading-snug)}.related-post-meta{font-size:var(--text-xs);color:var(--tertiary);font-family:var(--font-mono);margin-top:var(--spacing-sm);font-variant-numeric:tabular-nums}.footnotes{margin-top:var(--spacing-3xl);padding-top:var(--spacing-2xl);border-top:1px solid var(--border);font-size:var(--text-sm);color:var(--secondary);& ol { padding-left: var(--spacing-md); } & li { margin: var(--spacing-md) 0; line-height: var(--leading-normal); } & a { color: var(--primary); }}sup{line-height:0}a.footnote-ref{text-decoration:none;color:var(--primary);font-weight:600;padding:0 2px}a.footnote-backref{text-decoration:none;margin-left:var(--spacing-xs)}.sidenote{float:right;clear:right;width:200px;margin-right:-220px;margin-bottom:var(--spacing-md);font-size:var(--text-xs);line-height:var(--leading-snug);color:var(--secondary);border-left:var(--spacing-xxs)solid var(--border);padding-left:var(--spacing-md)}@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.share-buttons,.paginav{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.text-balance{text-wrap:balance}.text-pretty{text-wrap:pretty}@media(max-width:1024px){.sidenote{float:none;margin-right:0;width:100%;margin-top:var(--spacing-sm);margin-bottom:var(--spacing-sm);padding:var(--spacing-sm);background:var(--code-bg);border-radius:var(--radius)}}@media(max-width:768px){.post-single .post-title{font-size:var(--text-2xl)}.post-content h2{font-size:var(--text-lg)}.post-content h3{font-size:var(--text-base)}.related-posts-grid{grid-template-columns:1fr}#theme-toggle svg{width:18px;height:18px}#theme-toggle{padding:var(--spacing-xs)}.header{padding:0 15px}body{font-size:15px;line-height:1.5}.home-hero-heading{font-size:var(--text-xl)}.home-cta-section{display:flex;flex-direction:column;gap:var(--spacing-md);align-items:center}.btn,.cta-link{padding:12px 32px;font-size:15px}.main,.home-page{padding:0 15px}.post-single{padding:0 15px}.published-posts{padding-left:0;padding-right:0}}@media(max-width:768px){.home-hero-name h1{font-size:1.8rem}.mobile-only{display:inline}.btn-group--center{flex-direction:column;align-items:center}.post-entry{padding:1rem}}@media(max-width:640px){.nav{flex-wrap:wrap;gap:0;row-gap:var(--spacing-xs);padding:var(--spacing-xs)0}.logo{font-size:var(--text-sm);flex:none}.header-right{display:contents}#theme-toggle{margin-left:auto;flex:none;order:1}#theme-toggle svg{width:18px;height:18px}.social-links{flex-basis:100%;justify-content:center;gap:var(--spacing-sm);order:2;padding:0;margin:0;min-height:auto}.social-links li{margin:0;padding:0}.social-links a{font-size:var(--text-sm);padding:0;display:inline-block;line-height:1}.btn-group--center,.btn-group--block{justify-content:center}}@supports(container-type:inline-size){.post-entry{container-type:inline-size;container-name:post-card}@container post-card (min-width:400px){.post-entry .entry-header h3 {
      font-size: var(--text-lg);
    }
  }}.easter-egg-guitar{cursor:pointer;text-decoration:underline dotted;transition:all var(--transition-fast)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:var(--radius-sm)}:focus:not(:focus-visible){outline:none}.skip-to-main{position:absolute;top:-40px;left:0;background:var(--primary);color:#fff;padding:var(--spacing-sm)var(--spacing-md);text-decoration:none;z-index:100;&:focus { top:0; }}@media(prefers-contrast:high){:root{--border:#000}.dark{--border:#fff}}@media(prefers-color-scheme:dark){}.not-found{max-width:var(--container-lg);margin:0 auto;padding:var(--spacing-3xl)var(--spacing-md);text-align:center}.terms-page{max-width:var(--container-lg);margin:0 auto;padding:var(--spacing-2xl)var(--spacing-md)}.terms-list{list-style:none;padding:0;margin:var(--spacing-lg)0 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--spacing-sm)var(--spacing-lg)}.terms-list li{display:flex;align-items:center;gap:var(--spacing-xs)}.terms-list a{text-decoration:none;color:var(--content);border-bottom:1px solid transparent;transition:border-color var(--transition-fast),color var(--transition-fast)}.terms-list a:hover{color:var(--primary);border-color:var(--primary)}.terms-list .count{color:var(--tertiary);font-size:var(--text-sm)}.reading-progress{position:fixed;top:0;left:0;width:100%;height:4px;background:0 0;z-index:9999;opacity:0;transition:opacity .3s ease;pointer-events:none}.reading-progress.visible{opacity:1}.reading-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),color-mix(in oklch,var(--primary),white 20%));width:0%;transition:width .1s ease-out;box-shadow:0 0 10px var(--primary)}.menu-icon line{transition:transform var(--transition-fast),opacity var(--transition-fast);transform-box:fill-box;transform-origin:50% 50%}.menu-toggle.open .menu-icon line:nth-child(1){transform:translateY(6px)rotate(45deg)}.menu-toggle.open .menu-icon line:nth-child(2){opacity:0}.menu-toggle.open .menu-icon line:nth-child(3){transform:translateY(-6px)rotate(-45deg)}