/*!
 * Steve Hoang (https://stevehoang.com)
 * Copyright (c) 2025 Steve Hoang
 */::-webkit-input-placeholder{color:var(--text-muted-color) !important}::-moz-placeholder{color:var(--text-muted-color) !important}::-ms-input-placeholder{color:var(--text-muted-color) !important}::placeholder{color:var(--text-muted-color) !important}:focus::-webkit-input-placeholder{opacity:.6}:focus::-moz-placeholder{opacity:.6}:focus::-ms-input-placeholder{opacity:.6}:focus::placeholder{opacity:.6}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}h1,h2,h3,h4,h5,h6{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}code,pre,kbd{font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;font-size:calc(16px - 10%)}#page-category h1,#page-tag h1,.post-navigation p,#post-list .card .card-body .card-title,blockquote.author p,h1.dynamic-title{font-family:"Noto Serif Display",serif;transform:skewX(-10deg);font-style:normal;font-stretch:87%}#page-category h1>i,#page-tag h1>i,h1.dynamic-title>i{transform:skewX(10deg)}header .post-desc,#toc-bar .label,#search-results a,h1,h2,h3,h4,h5{color:var(--heading-color);font-weight:400;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;scroll-margin-top:3.5rem;margin-top:0;margin-bottom:.5rem;line-height:1.2}h2 .anchor,h3 .anchor,h4 .anchor,h5 .anchor{font-size:80%;visibility:hidden;opacity:0}@media(hover: hover){h2 .anchor,h3 .anchor,h4 .anchor,h5 .anchor{transition:opacity .25s ease-in,visibility 0s ease-in .25s}h2:hover .anchor,h3:hover .anchor,h4:hover .anchor,h5:hover .anchor{visibility:visible;opacity:1;transition:opacity .25s ease-in,visibility 0s ease-in 0s}}.post-tags .post-tag:hover{background:var(--primary-color);color:#fff !important;transition:background .35s ease-in-out}.table-wrapper>table thead th,.table-wrapper>table tbody tr td{padding:.4rem 1rem;font-size:95%;white-space:nowrap}#search-results a:hover,footer a:hover,.post-meta a:not([class]):hover,.content a:not(.img-link):hover{transition:.25s;text-decoration:underline;text-decoration-color:var(--secondary-color);text-decoration-thickness:1px;text-underline-offset:2px}#search-results a,#search-hints .post-tag,a{color:inherit}.post-tail-wrapper .post-meta a:not(:hover),.content a:not(.img-link){position:relative;transition:240ms;text-decoration:underline;text-decoration-color:var(--link-underline-color);text-decoration-thickness:1px;text-underline-offset:2px}.profile-wrapper{transition:all .3s ease-in-out}.icon-border,.code-header,i.icons,.content a.popup{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}#page-category ul>li>a,#page-tag ul>li>a,#search-results a,main .categories a:not(:hover),main #tags a:not(:hover),main #archives a:not(:hover){border-bottom:none;text-decoration:none}.post-tail-wrapper .share-wrapper .share-icons button,#search-cancel,.code-header button{cursor:pointer}.post-meta em{font-style:normal}.post-preview,.embed-video{border-radius:0}.categories.card,.categories .list-group{border-radius:10px}.code-header button{border-radius:4px}.highlight,div[class^=language-]{border-radius:.2rem}.content a.popup+em,.embed-video+em,.embed-audio+em{display:block;text-align:center;font-style:normal;font-size:80%;padding:0;margin-bottom:2rem;color:#6d6c6c}#post-list .card .card-body .card-title,#post-list .card .card-body .card-content p{display:-webkit-box;overflow:hidden;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical}#archives ul li,#toc-wrapper ul .toc-link,#post-list .card .card-body .card-meta>div:first-child,#search-results>article>p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}footer a,footer em{color:var(--text-muted-highlight-color);font-weight:600}.post-tail-wrapper,.post-meta{font-size:.85rem}footer{font-size:.8rem}sup:target,.footnotes>ol>li:target{background-color:var(--footnote-target-bg);border-radius:4px;width:-moz-fit-content;width:-webkit-fit-content;width:fit-content;transition:background-color 1.75s ease-in-out}#toc-bar button i,#topbar button i,#toc-popup .toc-header button i{color:#999}.highlight,figure.highlight,div[class^=language-]{background-color:oklch(.85 .02 80/.1)}td.rouge-code{padding-left:1rem;padding-right:1.5rem}#toc-wrapper>*,.access>section{border-left:1px solid var(--main-border-color)}:root{font-size:16px;font-stretch:100%}html{scrollbar-color:var(--main-border-color) var(--main-bg);scrollbar-width:thin}@media(prefers-color-scheme: light){html:not([data-mode]),html[data-mode=light]{--main-bg: #ffffff;--mask-bg: #c1c3c5;--main-border-color: #f3f3f3;--primary-color: #0d6efd;--secondary-color: #0056b2;--text-color: rgb(94 94 94 / 100%);--text-muted-color: #757575;--text-muted-highlight-color: inherit;--heading-color: #4f4f4f;--label-color: #585858;--icon-color: #8e8e8e;--blockquote-border-color: #eeeeee;--blockquote-text-color: #757575;--link-underline-color: #dee2e6;--btn-border-color: #efefef;--checkbox-color: #c5c5c5;--img-bg: radial-gradient(circle, rgb(255 255 255) 0%, rgb(239 239 239) 100%);--shimmer-bg: linear-gradient( 90deg, rgb(250 250 250 / 0%) 0%, rgb(232 230 230 / 100%) 50%, rgb(250 250 250 / 0%) 100% );--site-title-color: #686868;--site-subtitle-color: #717171;--site-hover-bg: #dfe9f1a3;--site-btn-color: #8e8e8e;--avatar-border-color: #f1f1f1;--search-border-color: rgb(240 240 240);--search-icon-color: #c2c6cc;--input-focus-border-color: #b8b8b8;--toc-popup-border-color: lightgray;--btn-share-hover-color: #0d6efd;--card-hover-bg: #e2e2e2;--card-shadow: rgb(211 209 209 / 15%) 0 0 0 1px;--footnote-target-bg: lightcyan;--tb-border-color: #eaeaea;--dash-color: silver;--kbd-wrap-color: rgb(189 189 189 / 100%);--kbd-bg-color: #ffffff;--note-text-color: rgb(46 46 46 / 77%);--note-tip-bg: rgb(123 247 144 / 10%);--note-tip-icon-color: #03b303;--note-tip-border-color: #238636;--note-info-bg: rgb(225 245 254 / 30%);--note-info-icon-color: #0070cb;--note-info-border-color: #1f6feb;--note-important-bg: rgb(233 231 255 / 30%);--note-important-icon-color: #8957e5;--note-important-border-color: #8957e5;--note-warning-bg: rgb(255 243 205 / 30%);--note-warning-icon-color: #ffa500;--note-warning-border-color: #ef9c03;--note-danger-bg: rgb(248 215 218 / 30%);--note-danger-icon-color: #df3c30;--note-danger-border-color: #da3633;--tag-border: #dee2e6;--tag-hover: rgb(222 226 230);--search-tag-bg: #f8f9fa;--categories-border: rgb(0 0 0 / 12.5%);--timeline-color: rgb(0 0 0 / 7.5%);--timeline-node-bg: #c2c6cc;--language-border-color: #ececec;--highlighter-rouge-color: #6c6060fc;--highlight-lineno-color: #9e9e9e;--inline-code-bg: rgb(25 25 28 / 5%);--code-color: #3a3a3a;--code-header-text-color: #a3a3a3;--code-header-muted-color: #e5e5e5;--code-header-icon-color: #c9c8c8;--clipboard-checked-color: #43c743;--filepath-text-color: #585858}html:not([data-mode]) [class^=note-],html[data-mode=light] [class^=note-]{--link-underline-color: rgb(219 216 216)}html:not([data-mode]) .dark,html[data-mode=light] .dark{display:none}html:not([data-mode]) .highlight table td,html[data-mode=light] .highlight table td{padding:5px}html:not([data-mode]) .highlight table pre,html[data-mode=light] .highlight table pre{margin:0}html:not([data-mode]) .highlight,html:not([data-mode]) .highlight .w,html[data-mode=light] .highlight,html[data-mode=light] .highlight .w{color:#5c6773}html:not([data-mode]) .highlight .c,html:not([data-mode]) .highlight .ch,html:not([data-mode]) .highlight .cs,html[data-mode=light] .highlight .c,html[data-mode=light] .highlight .ch,html[data-mode=light] .highlight .cs{color:#828c99}html:not([data-mode]) .highlight .err,html[data-mode=light] .highlight .err{color:#fafafa;background-color:#f51818}html:not([data-mode]) .highlight .gh,html[data-mode=light] .highlight .gh{color:#36a3d9;font-weight:bold}html:not([data-mode]) .highlight .gi,html[data-mode=light] .highlight .gi{color:#86b300;background-color:#efe}html:not([data-mode]) .highlight .gl,html[data-mode=light] .highlight .gl{color:#828c99}html:not([data-mode]) .highlight .gt,html[data-mode=light] .highlight .gt{color:#828c99}html:not([data-mode]) .highlight .gu,html[data-mode=light] .highlight .gu{color:#36a3d9;font-weight:bold}html:not([data-mode]) .highlight .k,html[data-mode=light] .highlight .k{color:#f73}html:not([data-mode]) .highlight .l,html:not([data-mode]) .highlight .ld,html:not([data-mode]) .highlight .m,html:not([data-mode]) .highlight .mf,html:not([data-mode]) .highlight .mi,html:not([data-mode]) .highlight .mo,html[data-mode=light] .highlight .l,html[data-mode=light] .highlight .ld,html[data-mode=light] .highlight .m,html[data-mode=light] .highlight .mf,html[data-mode=light] .highlight .mi,html[data-mode=light] .highlight .mo{color:#36a3d9}html:not([data-mode]) .highlight .na,html[data-mode=light] .highlight .na{color:#86b300}html:not([data-mode]) .highlight .nb,html[data-mode=light] .highlight .nb{color:#f73}html:not([data-mode]) .highlight .nc,html[data-mode=light] .highlight .nc{color:#e6b450}html:not([data-mode]) .highlight .ni,html[data-mode=light] .highlight .ni{color:#5c6773}html:not([data-mode]) .highlight .nl,html[data-mode=light] .highlight .nl{color:#36a3d9}html:not([data-mode]) .highlight .no,html[data-mode=light] .highlight .no{color:#e6b450}html:not([data-mode]) .highlight .nt,html[data-mode=light] .highlight .nt{color:#86b300}html:not([data-mode]) .highlight .vc,html:not([data-mode]) .highlight .vi,html[data-mode=light] .highlight .vc,html[data-mode=light] .highlight .vi{color:#36a3d9}html:not([data-mode]) .highlight .o,html[data-mode=light] .highlight .o{color:#f73}html:not([data-mode]) .highlight .p,html[data-mode=light] .highlight .p{color:#5c6773}html:not([data-mode]) .highlight .py,html[data-mode=light] .highlight .py{color:#36a3d9}html:not([data-mode]) .highlight .s,html:not([data-mode]) .highlight .sa,html:not([data-mode]) .highlight .dl,html:not([data-mode]) .highlight .se,html:not([data-mode]) .highlight .sh,html[data-mode=light] .highlight .s,html[data-mode=light] .highlight .sa,html[data-mode=light] .highlight .dl,html[data-mode=light] .highlight .se,html[data-mode=light] .highlight .sh{color:#86b300}html:not([data-mode]) .highlight .si,html[data-mode=light] .highlight .si{color:#f07178}html[data-mode=dark]{color-scheme:dark;--main-bg: #000000;--mask-bg: rgb(68 69 70);--main-border-color: rgb(44 45 45);--primary-color: #fd7e14;--secondary-color: #c67839;--text-color: #cecdcd;--text-muted-color: #868686;--text-muted-highlight-color: #aeaeae;--heading-color: #d7d5d3;--label-color: #a7a7a7;--icon-color: #787878;--blockquote-border-color: rgb(66 66 66);--blockquote-text-color: #868686;--link-underline-color: rgb(60 60 60);--btn-border-color: #292929;--checkbox-color: rgb(118 120 121);--img-bg: radial-gradient(circle, rgb(22 22 24) 0%, rgb(32 32 32) 100%);--shimmer-bg: linear-gradient( 90deg, rgb(255 255 255 / 0%) 0%, rgb(58 55 55 / 40%) 50%, rgb(255 255 255 / 0%) 100% );--site-title-color: #afa8a8;--site-subtitle-color: #868686;--site-hover-bg: #262626;--site-btn-color: #787878;--avatar-border-color: #cececee6;--search-border-color: rgb(55 55 55);--search-icon-color: rgb(100 102 105);--input-focus-border-color: rgb(112 114 115);--toc-popup-border-color: #373737;--tag-hover: rgb(43 56 62);--tb-border-color: #252526;--footnote-target-bg: rgb(63 81 181);--btn-share-hover-color: #bfc1ca;--card-hover-bg: #393939;--card-shadow: rgb(137 135 135 / 24%) 0 0 0 1px;--kbd-wrap-color: #6a6a6a;--kbd-bg-color: #242424;--note-text-color: rgb(216 212 212 / 75%);--note-tip-bg: rgb(22 60 36 / 30%);--note-tip-icon-color: rgb(15 164 15 / 95%);--note-tip-border-color: #238636;--note-info-bg: rgb(7 59 104 / 35%);--note-info-icon-color: #0075d1;--note-info-border-color: #1f6feb;--note-important-bg: rgb(233 231 255 / 20%);--note-important-icon-color: #8957e5;--note-important-border-color: #8957e5;--note-warning-bg: rgb(90 69 3 / 30%);--note-warning-icon-color: rgb(255 165 0 / 9%);--note-warning-border-color: #ffa500;--note-danger-bg: rgb(86 28 8 / 35%);--note-danger-icon-color: #cd0202;--note-danger-border-color: #da3633;--tag-border: rgb(59 79 88);--dash-color: rgb(63 65 68);--search-tag-bg: #292828;--categories-border: rgb(64 66 69 / 50%);--timeline-node-bg: rgb(150 152 156);--timeline-color: rgb(63 65 68);--language-border-color: #2d2d2d;--highlighter-rouge-color: #d2bcae;--highlight-lineno-color: #808080;--inline-code-bg: rgb(255 255 255 / 5%);--code-color: #b0b0b0;--code-header-text-color: #6a6a6a;--code-header-muted-color: #353535;--code-header-icon-color: #565656;--clipboard-checked-color: #2bcc2b;--filepath-text-color: #cacaca}html[data-mode=dark] .light{display:none}html[data-mode=dark] .highlight table td{padding:5px}html[data-mode=dark] .highlight table pre{margin:0}html[data-mode=dark] .highlight,html[data-mode=dark] .highlight .w{color:#e6e1cf}html[data-mode=dark] .highlight .c,html[data-mode=dark] .highlight .ch,html[data-mode=dark] .highlight .cs{color:#5c6773}html[data-mode=dark] .highlight .err{color:#0f1419;background-color:#f33}html[data-mode=dark] .highlight .gh{color:#36a3d9;background-color:#0f1419;font-weight:bold}html[data-mode=dark] .highlight .gi{color:#b8cc52}html[data-mode=dark] .highlight .gl{color:#5c6773}html[data-mode=dark] .highlight .gt{color:#5c6773}html[data-mode=dark] .highlight .gu{color:#36a3d9;font-weight:bold}html[data-mode=dark] .highlight .k{color:#f73}html[data-mode=dark] .highlight .l,html[data-mode=dark] .highlight .ld{color:#b8cc52}html[data-mode=dark] .highlight .m,html[data-mode=dark] .highlight .mf,html[data-mode=dark] .highlight .mi,html[data-mode=dark] .highlight .mo{color:#b8cc52}html[data-mode=dark] .highlight .na{color:#36a3d9}html[data-mode=dark] .highlight .nb{color:#f73}html[data-mode=dark] .highlight .nc{color:#e6b450}html[data-mode=dark] .highlight .ni{color:#e6e1cf}html[data-mode=dark] .highlight .nl{color:#e6b450}html[data-mode=dark] .highlight .no{color:#e6b450}html[data-mode=dark] .highlight .nt{color:#e6b450}html[data-mode=dark] .highlight .vc,html[data-mode=dark] .highlight .vi{color:#36a3d9}html[data-mode=dark] .highlight .o{color:#e6e1cf}html[data-mode=dark] .highlight .p{color:#e6e1cf}html[data-mode=dark] .highlight .py{color:#e6b450}html[data-mode=dark] .highlight .s,html[data-mode=dark] .highlight .dl,html[data-mode=dark] .highlight .sh{color:#b8cc52}html[data-mode=dark] .highlight .sa{color:#f73}html[data-mode=dark] .highlight .se{color:#f07178}html[data-mode=dark] .highlight .si{color:#f07178}}@media(prefers-color-scheme: dark){html:not([data-mode]),html[data-mode=dark]{color-scheme:dark;--main-bg: #000000;--mask-bg: rgb(68 69 70);--main-border-color: rgb(44 45 45);--primary-color: #fd7e14;--secondary-color: #c67839;--text-color: #cecdcd;--text-muted-color: #868686;--text-muted-highlight-color: #aeaeae;--heading-color: #d7d5d3;--label-color: #a7a7a7;--icon-color: #787878;--blockquote-border-color: rgb(66 66 66);--blockquote-text-color: #868686;--link-underline-color: rgb(60 60 60);--btn-border-color: #292929;--checkbox-color: rgb(118 120 121);--img-bg: radial-gradient(circle, rgb(22 22 24) 0%, rgb(32 32 32) 100%);--shimmer-bg: linear-gradient( 90deg, rgb(255 255 255 / 0%) 0%, rgb(58 55 55 / 40%) 50%, rgb(255 255 255 / 0%) 100% );--site-title-color: #afa8a8;--site-subtitle-color: #868686;--site-hover-bg: #262626;--site-btn-color: #787878;--avatar-border-color: #cececee6;--search-border-color: rgb(55 55 55);--search-icon-color: rgb(100 102 105);--input-focus-border-color: rgb(112 114 115);--toc-popup-border-color: #373737;--tag-hover: rgb(43 56 62);--tb-border-color: #252526;--footnote-target-bg: rgb(63 81 181);--btn-share-hover-color: #bfc1ca;--card-hover-bg: #393939;--card-shadow: rgb(137 135 135 / 24%) 0 0 0 1px;--kbd-wrap-color: #6a6a6a;--kbd-bg-color: #242424;--note-text-color: rgb(216 212 212 / 75%);--note-tip-bg: rgb(22 60 36 / 30%);--note-tip-icon-color: rgb(15 164 15 / 95%);--note-tip-border-color: #238636;--note-info-bg: rgb(7 59 104 / 35%);--note-info-icon-color: #0075d1;--note-info-border-color: #1f6feb;--note-important-bg: rgb(233 231 255 / 20%);--note-important-icon-color: #8957e5;--note-important-border-color: #8957e5;--note-warning-bg: rgb(90 69 3 / 30%);--note-warning-icon-color: rgb(255 165 0 / 9%);--note-warning-border-color: #ffa500;--note-danger-bg: rgb(86 28 8 / 35%);--note-danger-icon-color: #cd0202;--note-danger-border-color: #da3633;--tag-border: rgb(59 79 88);--dash-color: rgb(63 65 68);--search-tag-bg: #292828;--categories-border: rgb(64 66 69 / 50%);--timeline-node-bg: rgb(150 152 156);--timeline-color: rgb(63 65 68);--language-border-color: #2d2d2d;--highlighter-rouge-color: #d2bcae;--highlight-lineno-color: #808080;--inline-code-bg: rgb(255 255 255 / 5%);--code-color: #b0b0b0;--code-header-text-color: #6a6a6a;--code-header-muted-color: #353535;--code-header-icon-color: #565656;--clipboard-checked-color: #2bcc2b;--filepath-text-color: #cacaca}html:not([data-mode]) .light,html[data-mode=dark] .light{display:none}html:not([data-mode]) .highlight table td,html[data-mode=dark] .highlight table td{padding:5px}html:not([data-mode]) .highlight table pre,html[data-mode=dark] .highlight table pre{margin:0}html:not([data-mode]) .highlight,html:not([data-mode]) .highlight .w,html[data-mode=dark] .highlight,html[data-mode=dark] .highlight .w{color:#e6e1cf}html:not([data-mode]) .highlight .c,html:not([data-mode]) .highlight .ch,html:not([data-mode]) .highlight .cs,html[data-mode=dark] .highlight .c,html[data-mode=dark] .highlight .ch,html[data-mode=dark] .highlight .cs{color:#5c6773}html:not([data-mode]) .highlight .err,html[data-mode=dark] .highlight .err{color:#0f1419;background-color:#f33}html:not([data-mode]) .highlight .gh,html[data-mode=dark] .highlight .gh{color:#36a3d9;background-color:#0f1419;font-weight:bold}html:not([data-mode]) .highlight .gi,html[data-mode=dark] .highlight .gi{color:#b8cc52}html:not([data-mode]) .highlight .gl,html[data-mode=dark] .highlight .gl{color:#5c6773}html:not([data-mode]) .highlight .gt,html[data-mode=dark] .highlight .gt{color:#5c6773}html:not([data-mode]) .highlight .gu,html[data-mode=dark] .highlight .gu{color:#36a3d9;font-weight:bold}html:not([data-mode]) .highlight .k,html[data-mode=dark] .highlight .k{color:#f73}html:not([data-mode]) .highlight .l,html:not([data-mode]) .highlight .ld,html[data-mode=dark] .highlight .l,html[data-mode=dark] .highlight .ld{color:#b8cc52}html:not([data-mode]) .highlight .m,html:not([data-mode]) .highlight .mf,html:not([data-mode]) .highlight .mi,html:not([data-mode]) .highlight .mo,html[data-mode=dark] .highlight .m,html[data-mode=dark] .highlight .mf,html[data-mode=dark] .highlight .mi,html[data-mode=dark] .highlight .mo{color:#b8cc52}html:not([data-mode]) .highlight .na,html[data-mode=dark] .highlight .na{color:#36a3d9}html:not([data-mode]) .highlight .nb,html[data-mode=dark] .highlight .nb{color:#f73}html:not([data-mode]) .highlight .nc,html[data-mode=dark] .highlight .nc{color:#e6b450}html:not([data-mode]) .highlight .ni,html[data-mode=dark] .highlight .ni{color:#e6e1cf}html:not([data-mode]) .highlight .nl,html[data-mode=dark] .highlight .nl{color:#e6b450}html:not([data-mode]) .highlight .no,html[data-mode=dark] .highlight .no{color:#e6b450}html:not([data-mode]) .highlight .nt,html[data-mode=dark] .highlight .nt{color:#e6b450}html:not([data-mode]) .highlight .vc,html:not([data-mode]) .highlight .vi,html[data-mode=dark] .highlight .vc,html[data-mode=dark] .highlight .vi{color:#36a3d9}html:not([data-mode]) .highlight .o,html[data-mode=dark] .highlight .o{color:#e6e1cf}html:not([data-mode]) .highlight .p,html[data-mode=dark] .highlight .p{color:#e6e1cf}html:not([data-mode]) .highlight .py,html[data-mode=dark] .highlight .py{color:#e6b450}html:not([data-mode]) .highlight .s,html:not([data-mode]) .highlight .dl,html:not([data-mode]) .highlight .sh,html[data-mode=dark] .highlight .s,html[data-mode=dark] .highlight .dl,html[data-mode=dark] .highlight .sh{color:#b8cc52}html:not([data-mode]) .highlight .sa,html[data-mode=dark] .highlight .sa{color:#f73}html:not([data-mode]) .highlight .se,html[data-mode=dark] .highlight .se{color:#f07178}html:not([data-mode]) .highlight .si,html[data-mode=dark] .highlight .si{color:#f07178}html[data-mode=light]{--main-bg: #ffffff;--mask-bg: #c1c3c5;--main-border-color: #f3f3f3;--primary-color: #0d6efd;--secondary-color: #0056b2;--text-color: rgb(94 94 94 / 100%);--text-muted-color: #757575;--text-muted-highlight-color: inherit;--heading-color: #4f4f4f;--label-color: #585858;--icon-color: #8e8e8e;--blockquote-border-color: #eeeeee;--blockquote-text-color: #757575;--link-underline-color: #dee2e6;--btn-border-color: #efefef;--checkbox-color: #c5c5c5;--img-bg: radial-gradient(circle, rgb(255 255 255) 0%, rgb(239 239 239) 100%);--shimmer-bg: linear-gradient( 90deg, rgb(250 250 250 / 0%) 0%, rgb(232 230 230 / 100%) 50%, rgb(250 250 250 / 0%) 100% );--site-title-color: #686868;--site-subtitle-color: #717171;--site-hover-bg: #dfe9f1a3;--site-btn-color: #8e8e8e;--avatar-border-color: #f1f1f1;--search-border-color: rgb(240 240 240);--search-icon-color: #c2c6cc;--input-focus-border-color: #b8b8b8;--toc-popup-border-color: lightgray;--btn-share-hover-color: #0d6efd;--card-hover-bg: #e2e2e2;--card-shadow: rgb(211 209 209 / 15%) 0 0 0 1px;--footnote-target-bg: lightcyan;--tb-border-color: #eaeaea;--dash-color: silver;--kbd-wrap-color: rgb(189 189 189 / 100%);--kbd-bg-color: #ffffff;--note-text-color: rgb(46 46 46 / 77%);--note-tip-bg: rgb(123 247 144 / 10%);--note-tip-icon-color: #03b303;--note-tip-border-color: #238636;--note-info-bg: rgb(225 245 254 / 30%);--note-info-icon-color: #0070cb;--note-info-border-color: #1f6feb;--note-important-bg: rgb(233 231 255 / 30%);--note-important-icon-color: #8957e5;--note-important-border-color: #8957e5;--note-warning-bg: rgb(255 243 205 / 30%);--note-warning-icon-color: #ffa500;--note-warning-border-color: #ef9c03;--note-danger-bg: rgb(248 215 218 / 30%);--note-danger-icon-color: #df3c30;--note-danger-border-color: #da3633;--tag-border: #dee2e6;--tag-hover: rgb(222 226 230);--search-tag-bg: #f8f9fa;--categories-border: rgb(0 0 0 / 12.5%);--timeline-color: rgb(0 0 0 / 7.5%);--timeline-node-bg: #c2c6cc;--language-border-color: #ececec;--highlighter-rouge-color: #6c6060fc;--highlight-lineno-color: #9e9e9e;--inline-code-bg: rgb(25 25 28 / 5%);--code-color: #3a3a3a;--code-header-text-color: #a3a3a3;--code-header-muted-color: #e5e5e5;--code-header-icon-color: #c9c8c8;--clipboard-checked-color: #43c743;--filepath-text-color: #585858}html[data-mode=light] [class^=note-]{--link-underline-color: rgb(219 216 216)}html[data-mode=light] .dark{display:none}html[data-mode=light] .highlight table td{padding:5px}html[data-mode=light] .highlight table pre{margin:0}html[data-mode=light] .highlight,html[data-mode=light] .highlight .w{color:#5c6773}html[data-mode=light] .highlight .c,html[data-mode=light] .highlight .ch,html[data-mode=light] .highlight .cs{color:#828c99}html[data-mode=light] .highlight .err{color:#fafafa;background-color:#f51818}html[data-mode=light] .highlight .gh{color:#36a3d9;font-weight:bold}html[data-mode=light] .highlight .gi{color:#86b300;background-color:#efe}html[data-mode=light] .highlight .gl{color:#828c99}html[data-mode=light] .highlight .gt{color:#828c99}html[data-mode=light] .highlight .gu{color:#36a3d9;font-weight:bold}html[data-mode=light] .highlight .k{color:#f73}html[data-mode=light] .highlight .l,html[data-mode=light] .highlight .ld,html[data-mode=light] .highlight .m,html[data-mode=light] .highlight .mf,html[data-mode=light] .highlight .mi,html[data-mode=light] .highlight .mo{color:#36a3d9}html[data-mode=light] .highlight .na{color:#86b300}html[data-mode=light] .highlight .nb{color:#f73}html[data-mode=light] .highlight .nc{color:#e6b450}html[data-mode=light] .highlight .ni{color:#5c6773}html[data-mode=light] .highlight .nl{color:#36a3d9}html[data-mode=light] .highlight .no{color:#e6b450}html[data-mode=light] .highlight .nt{color:#86b300}html[data-mode=light] .highlight .vc,html[data-mode=light] .highlight .vi{color:#36a3d9}html[data-mode=light] .highlight .o{color:#f73}html[data-mode=light] .highlight .p{color:#5c6773}html[data-mode=light] .highlight .py{color:#36a3d9}html[data-mode=light] .highlight .s,html[data-mode=light] .highlight .sa,html[data-mode=light] .highlight .dl,html[data-mode=light] .highlight .se,html[data-mode=light] .highlight .sh{color:#86b300}html[data-mode=light] .highlight .si{color:#f07178}}@media all and (min-width: 992px){html{overflow-y:scroll}}html ::-webkit-scrollbar{width:2px;height:2px}html ::-webkit-scrollbar-track{background-color:rgba(0,0,0,0)}html ::-webkit-scrollbar-thumb{background-color:rgba(0,0,0,0);border-radius:2px;border:1px solid var(--main-border-color)}body{margin:0;background:var(--main-bg);background-attachment:scroll;background-image:url("/assets/img/grain.png");background-repeat:repeat;background-size:100px 100px;position:relative;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);color:var(--text-color);-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(0,0,0,0);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}@media all and (max-width: calc(992px - 1px)){h1.dynamic-title{display:none}h1.dynamic-title~.content{margin-top:2.5rem}}@media all and (min-width: 1650px){main.col-12{padding-right:2rem !important}}.preview-img{aspect-ratio:4/3;width:100%;height:100%;overflow:hidden;position:relative}@media all and (max-width: calc(768px - 1px)){.preview-img{aspect-ratio:16/9;height:auto}}.preview-img.cover{aspect-ratio:40/21;border-radius:0;height:auto;margin-top:1.5rem}.preview-img:not(.no-bg){transition:left .2s ease}.preview-img:not(.no-bg)::before{content:"";position:absolute;inset:0 0 0 0;background-image:var(--lqip-url);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.3;pointer-events:none;z-index:1}.preview-img img{width:100%;-o-object-fit:cover;object-fit:cover;border-radius:0;margin:0;position:relative;z-index:2}.post-preview{border:0;display:flex;flex-wrap:wrap;margin:0;--bs-gutter-x: 0;--bs-gutter-y: 0;text-decoration:none;color:inherit}.post-preview::before{content:"";width:100%;height:100%;position:absolute;background-color:var(--card-hover-bg);opacity:0;transition:opacity .35s ease-in-out}.post-preview:hover::before{opacity:.3}.post-meta i{margin-right:.25rem}.content{font-size:16px;font-weight:400;overflow-wrap:break-word}.content a.popup{margin-top:.5rem;margin-bottom:.5rem;cursor:zoom-in}.content ol:not([class]),.content ul:not([class]){-webkit-padding-start:1.75rem;padding-inline-start:1.75rem}.content ol:not([class]) li,.content ul:not([class]) li{margin:.25rem 0;padding-left:.25rem}.content ol:not([class]) ol,.content ol:not([class]) ul,.content ul:not([class]) ol,.content ul:not([class]) ul{-webkit-padding-start:1.25rem;padding-inline-start:1.25rem;margin:.5rem 0}.content dl>dd{margin-left:1rem}.content ::marker{color:var(--text-muted-color)}@media all and (min-width: 992px){.content .table-wrapper>table{min-width:70%}}.post-tag{display:inline-block;min-width:2rem;text-align:center;border-radius:2px;border:none;background-color:rgba(135,135,135,.05);padding:0 .4rem;color:var(--text-muted-color);line-height:1.3rem}.post-tag:not(:last-child){margin-right:.2rem}.rounded-10{border-radius:10px !important}.img-link{color:rgba(0,0,0,0);display:inline-flex}.shimmer{overflow:hidden;position:relative;background:var(--img-bg)}.shimmer::before{content:"";position:absolute;background:var(--shimmer-bg);height:100%;width:100%;-webkit-animation:shimmer 1.3s infinite;animation:shimmer 1.3s infinite}@-webkit-keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}.embed-video{width:100%;height:100%;margin-top:2rem;margin-bottom:3rem;aspect-ratio:16/9}.embed-video.twitch{aspect-ratio:310/189}.embed-video.file{display:block;width:auto;height:auto;max-width:100%;max-height:100%;margin:auto;margin-bottom:0}.embed-audio{width:100%}.embed-audio.file{display:block}.embed-audio.spotify{border-radius:14px}.me-2{margin-right:.5rem !important}.mt-5{margin-top:3rem !important}.w-75{width:75% !important}.w-50{width:50% !important}.shadow{box-shadow:0 .5rem 1rem rgba(0,0,0,.15) !important}.text-muted{color:var(--text-muted-color) !important}.disabled{color:#cec4c4;pointer-events:auto;cursor:not-allowed}.input-focus{box-shadow:none;border-color:var(--input-focus-border-color) !important;background:center !important;transition:background-color .15s ease-in-out,border-color .15s ease-in-out}.left{float:left;margin:.5rem 2rem 1rem 0 !important}.right{float:right;margin:.5rem 0 1rem 2rem !important}.gap{margin-right:.25rem !important}.d-none{display:none !important}.d-block{display:block !important}.d-flex{display:flex !important}.c-center{justify-content:center !important}.mermaid{margin-top:2rem;margin-bottom:2rem;text-align:center}.chartjs-container{margin:2rem auto;position:relative;max-height:360px;width:100%;display:flex;justify-content:center;align-items:center}@media(hover: hover){.post-preview{transition:background-color .35s ease-in-out}}#mask{inset:0 0 0 0;z-index:1;height:100%;width:100%;position:fixed;display:none}#main-wrapper{position:relative;justify-content:center;display:flex;padding-left:0;padding-right:0}#main-wrapper>.container{min-height:100vh;flex-direction:column;display:flex;margin-left:auto;margin-right:auto;--bs-gutter-x: 1.5rem;--bs-gutter-y: 0;width:100%;padding-right:calc(var(--bs-gutter-x)*.5);padding-left:calc(var(--bs-gutter-x)*.5)}@media all and (min-width: 576px){#main-wrapper>.container{max-width:540px}}@media all and (max-width: 768px){#main-wrapper>.container{max-width:100%;padding-left:0;padding-right:0}}@media all and (min-width: 768px){#main-wrapper>.container{max-width:720px}}@media all and (min-width: 992px){#main-wrapper>.container{max-width:90%;margin-right:0 !important}}@media all and (min-width: 1200px){#main-wrapper>.container{max-width:85%;margin-right:0 !important}}@media all and (min-width: 1400px){#main-wrapper>.container{margin-right:0 !important;padding:0 3rem}}@media all and (min-width: 1650px){#main-wrapper>.container{max-width:85%;margin-right:0 !important;padding-left:1.75rem !important;padding-right:1.75rem !important}}#main-wrapper>.container>#header-wrapper>#topbar,#main-wrapper>.container>.content-wrapper,#search-result-wrapper>.content-wrapper{margin:0;flex-grow:1;--bs-gutter-x: 1.5rem;--bs-gutter-y: 0;display:flex;flex-wrap:wrap}#main-content{flex:0 0 auto;width:100%;--bs-gutter-x: 1.5rem;--bs-gutter-y: 0;padding-right:calc(var(--bs-gutter-x)*.5);padding-left:calc(var(--bs-gutter-x)*.5)}@media all and (min-width: 768px){#main-content{padding:0 1.5rem !important}}@media all and (min-width: 992px){#main-content{flex:0 0 auto;width:91.6666666667%}}@media all and (min-width: 1200px){#main-content{width:75%}}@media all and (min-width: 1650px){#main-content{padding-right:2rem !important}}#tail-wrapper{flex:0 0 auto;width:100%;--bs-gutter-x: 1.5rem;--bs-gutter-y: 0;padding-right:calc(var(--bs-gutter-x)*.5);padding-left:calc(var(--bs-gutter-x)*.5)}@media all and (min-width: 768px){#tail-wrapper{padding:0 1.5rem !important}}@media all and (min-width: 992px){#tail-wrapper{flex:0 0 auto;width:91.6666666667%}}@media all and (min-width: 1200px){#tail-wrapper{flex:0 0 auto;width:75%}}#tail-wrapper>:not(script){margin-top:5rem}*,::after,::before{box-sizing:border-box}h1{font-size:2rem}main h2{margin:2.5rem 0 1.25rem}h2{font-size:1.54rem}main h3{margin:2rem 0 1rem}h3{font-size:1.36rem}main h4{margin:2rem 0 1rem}h4{font-size:1.18rem}h5{font-size:1.05rem}.small{font-size:.875em}strong{font-weight:700}p{margin-top:0;margin-bottom:1rem}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}a{text-decoration:none}::selection{background-color:rgba(212,150,90,.1)}img{max-width:100%;border-radius:0;height:auto;transition:all .35s ease-in-out}.blur img{-webkit-filter:blur(20px);filter:blur(20px)}table{caption-side:bottom;border-collapse:collapse}blockquote{margin:0 0 1rem;border-left:.2rem solid var(--blockquote-border-color);padding-left:1rem;color:var(--blockquote-text-color);margin-top:1rem;position:relative}blockquote>p:last-child{margin-bottom:0}blockquote.author{padding-top:.75rem;text-align:center;border:none}blockquote.author>p:last-child{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;text-align:right;font-style:italic;transform:none;font-size:.95rem;opacity:.8;color:var(--secondary-color);padding-right:.5rem}blockquote.author>p:last-child::before{content:"— ";color:var(--blockquote-text-color)}blockquote[class^=note-]{border-left:.2rem;position:relative;padding:.75rem 1.25rem .75rem 1rem;color:var(--note-text-color)}blockquote[class^=note-]>p:last-child::after{content:"";margin-left:.5rem}blockquote.note-tip{background-color:var(--note-tip-bg);border-left:.2rem solid var(--note-tip-border-color);position:relative}blockquote.note-tip .icons{position:absolute;right:.75rem;bottom:1rem;color:var(--note-tip-icon-color)}blockquote.note-info{background-color:var(--note-info-bg);border-left:.2rem solid var(--note-info-border-color);position:relative}blockquote.note-info .icons{position:absolute;right:.75rem;bottom:1rem;color:var(--note-info-icon-color)}blockquote.note-info .icons svg{transform:rotate(180deg);transform-origin:center}blockquote.note-important{background-color:var(--note-important-bg);border-left:.2rem solid var(--note-important-border-color);position:relative}blockquote.note-important .icons{position:absolute;right:.75rem;bottom:1rem;color:var(--note-important-icon-color)}blockquote.note-warning{background-color:var(--note-warning-bg);border-left:.2rem solid var(--note-warning-border-color);position:relative}blockquote.note-warning .icons{position:absolute;right:.75rem;bottom:1rem;color:var(--note-warning-icon-color)}kbd{padding:.1875rem .375rem;font-family:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;display:inline-block;vertical-align:middle;line-height:1.3rem;min-width:1.75rem;text-align:center;margin:0 .3rem;padding-top:.1rem;color:var(--text-color);background-color:var(--kbd-bg-color);border-radius:.2rem;border:solid 1px var(--kbd-wrap-color);box-shadow:inset 0 -1.5px 0 var(--kbd-wrap-color);font-size:.85em;font-weight:500;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}hr{margin:1rem 0;color:inherit;border:.1px solid var(--main-border-color);opacity:1}img,svg{vertical-align:middle}.list-unstyled{padding-left:0;list-style:none}*:focus-visible{border:none;box-shadow:none;outline:none}dl,ol,ul{margin-top:0;margin-bottom:1rem}footer{background-color:rgba(0,0,0,0);height:5rem;border-top:1px solid var(--main-border-color)}footer p{text-align:center;margin-bottom:0}i.icons{width:1em;height:1em;display:inline-block;fill:currentcolor;vertical-align:-0.125em}i.icons svg{width:100%;height:100%;display:block}i.icons.fa-fw{width:1.25em;text-align:center}sup{top:-0.5em;position:relative;font-size:.75em;line-height:0;vertical-align:baseline}main{line-height:1.6}main h1{margin-top:2rem}@media all and (min-width: 992px){main h1{margin-top:3rem}}main p>a.popup:not(.normal):not(.left):not(.right){position:relative;left:50%;transform:translateX(-50%)}@media all and (max-width: 576px){main .content>blockquote[class^=note-]{margin-left:-1rem;margin-right:-1rem;border-radius:0;max-width:none}}.footnotes>ol{padding-left:2rem;margin-top:.5rem}.footnotes>ol>li:not(:last-child){margin-bottom:.3rem}.footnotes>ol>li>p{margin-left:.25em;margin-top:0;margin-bottom:0}a.footnote{margin-left:1px;margin-right:1px;padding-left:2px;padding-right:2px;text-decoration:none !important;color:var(--secondary-color)}a.reversefootnote{font-size:.6rem;line-height:1;position:relative;bottom:.25em;margin-left:.25em;text-decoration:none !important;color:var(--secondary-color)}.table-wrapper{overflow-x:auto;margin-bottom:1.5rem}.table-wrapper>table{min-width:100%;overflow-x:auto;border-spacing:0}.table-wrapper>table thead{border-bottom:solid 2px rgba(210,215,217,.75)}.table-wrapper>table tbody:hover tr{opacity:.3}.table-wrapper>table tbody:hover tr:nth-child(2n+1){background-color:var(--main-bg)}.table-wrapper>table tbody tr{border-bottom:1px solid var(--tb-border-color)}.table-wrapper>table tbody tr:nth-child(2n){background-color:var(--main-bg)}.table-wrapper>table tbody tr:nth-child(2n+1){background-color:oklch(.85 .02 80/.1)}.table-wrapper>table tbody tr:hover{opacity:1 !important;background-color:oklch(.85 .02 80/.1) !important;transition:.3s}.table-wrapper>table tbody tr td:hover{opacity:1 !important;color:var(--primary-color);background-color:oklch(.85 .02 80/.1) !important;transition:.3s}.highlighter-rouge{color:var(--highlighter-rouge-color);margin-top:.5rem;margin-bottom:1.2em}.highlight{overflow:auto;padding-top:.45rem;padding-bottom:.75rem}.highlight pre{margin-bottom:0;line-height:1.4rem}.highlight table td:first-child{display:inline-block;margin-left:1rem;margin-right:.75rem}.highlight table td:last-child{padding-right:2rem !important}.highlight table td pre{overflow:visible;word-break:normal}.highlight .lineno{text-align:right;color:var(--highlight-lineno-color);-webkit-user-select:none;-moz-user-select:none;-o-user-select:none;-ms-user-select:none;user-select:none}code{-webkit-hyphens:none;-ms-hyphens:none;hyphens:none;color:var(--code-color)}code.highlighter-rouge{padding:1px 5px;overflow-wrap:break-word;border-radius:4px;background-color:var(--inline-code-bg)}code.filepath{background-color:inherit;color:var(--filepath-text-color);font-weight:600;padding:0}a>code.highlighter-rouge{padding-bottom:0;color:inherit}a:hover>code.highlighter-rouge{border-bottom:none}blockquote code{color:inherit}td.rouge-code a{color:inherit !important;border-bottom:none !important;pointer-events:none}div[class^=language-]{box-shadow:var(--language-border-color) 0 0 0 1px}.content>div[class^=language-]{margin-left:-1rem;margin-right:-1rem;margin-top:1.5rem;margin-bottom:1.5rem;border-radius:0}@media all and (min-width: 576px){.content>div[class^=language-]{margin-left:0;margin-right:0;border-radius:.2rem}}@media all and (min-width: 576px){div[class^=language-] .code-header{margin-left:0;margin-right:0}div[class^=language-] .code-header::before{content:"";display:inline-block}div[class^=language-] .code-header span{margin-left:0}}div[class^=language-] .highlight{border-top-left-radius:0;border-top-right-radius:0}div.nolineno td:first-child,div.language-plaintext td:first-child,div.language-console td:first-child,div.language-terminal td:first-child{padding:0 !important;margin-right:0}div.nolineno td:first-child .lineno,div.language-plaintext td:first-child .lineno,div.language-console td:first-child .lineno,div.language-terminal td:first-child .lineno{display:none}.code-header{display:flex;justify-content:space-between;align-items:center;height:2.25rem;margin-left:.75rem;margin-right:.25rem}.code-header span{line-height:2.25rem}.code-header span i{font-size:1rem;width:1.75rem;color:var(--code-header-icon-color)}.code-header span i.small{font-size:70%}[file] .code-header span>i{position:relative;top:1px}.code-header span::after{content:attr(data-label-text);font-size:.85rem;font-weight:600;color:var(--code-header-text-color)}.code-header button{border:none;height:2rem;width:2rem;padding:0;margin:.2rem;background-color:rgba(0,0,0,0);transition:border-color .3s ease,background-color .3s ease}.code-header button i{color:var(--code-header-icon-color);font-size:1rem}.code-header button[timeout]:hover{border-color:var(--clipboard-checked-color)}.code-header button[timeout] i{color:var(--clipboard-checked-color)}.code-header button:focus{outline:none}.code-header button:not([timeout]):hover{background-color:rgba(128,128,128,.1)}.code-header button:not([timeout]):hover i{color:var(--primary-color)}#back-to-top{visibility:hidden;opacity:0;z-index:8;cursor:pointer;position:fixed;right:1rem;bottom:5.175rem;background-color:var(--main-bg);color:var(--text-color);padding:0;width:1.65rem;height:1.65rem;border-radius:1px;border:1px var(--main-border-color);transform:rotate(45deg);transition:opacity .5s ease-in-out,transform .2s ease-out;overflow:hidden;box-shadow:var(--card-shadow)}@media all and (min-width: 992px){#back-to-top{right:3.5%;bottom:4.175rem}}#back-to-top:hover{transform:rotate(45deg) scale(1.1);-webkit-transform:rotate(45deg) scale(1.1)}#back-to-top i{line-height:1.65rem;position:relative;font-size:1rem;transform:rotate(-45deg);transition:opacity .2s ease}#back-to-top:hover i{opacity:0;color:var(--primary-color)}#back-to-top.show{opacity:1;visibility:visible}#progress-circle{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);width:100%;height:100%;pointer-events:none}#progress-circle path{stroke:var(--text-color);stroke-dasharray:160;stroke-dashoffset:160;transition:stroke-dashoffset .1s;opacity:.35}#scroll-percentage{position:absolute;top:50%;left:50%;transform:translate(-50%, -50%) rotate(-45deg);font-size:9px;color:var(--text-muted-color);pointer-events:none;opacity:0;transition:opacity .2s ease,background-color .4s ease}#scroll-percentage.visible{opacity:1}.notification-container{position:fixed;z-index:10;width:100%;pointer-events:none}.notification{display:none;min-width:20rem;max-width:25rem;margin:0 auto;padding:1rem 1.5rem;border-radius:.2rem;background-color:rgba(25,25,25,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#fff;text-align:center;line-height:1.25rem;position:fixed;left:50%;bottom:20%;transform:translateX(-50%);-webkit-animation:popup .8s;animation:popup .8s;pointer-events:auto;box-shadow:1px 2px 5px 1px rgba(0,0,0,.2);-webkit-box-shadow:1px 2px 5px 1px rgba(0,0,0,.2)}.notification.show{display:block}@media all and (min-width: 1400px){.notification{min-width:22rem}}@media all and (min-width: 1650px){.notification{min-width:25rem}}.notification p{margin:0;padding:.5rem 0;font-size:.9rem}.notification button{font-size:90%;color:#fff;border:none;border-radius:.25rem;margin-top:.5rem;padding:.35rem 1rem;line-height:inherit;cursor:pointer;min-width:4rem;background:var(--secondary-color);border-color:var(--secondary-color);transition:background-color .3s ease;-webkit-appearance:button}.notification button:hover{background:var(--primary-color);border-color:var(--primary-color);transition:.35s ease-in-out}.notification button:focus{outline:none}@-webkit-keyframes popup{from{opacity:0;bottom:0}to{opacity:1;bottom:20%}}@keyframes popup{from{opacity:0;bottom:0}to{opacity:1;bottom:20%}}@-webkit-keyframes fade-out{to{opacity:0;bottom:0}}@keyframes fade-out{to{opacity:0;bottom:0}}#toc-popup{border-color:var(--toc-popup-border-color);border-width:1px;border-radius:10px;color:var(--text-color);background:var(--main-bg);background-attachment:scroll;background-image:url("/assets/img/grain.png");background-repeat:repeat;background-size:100px 100px;margin-top:3rem;min-width:20rem;font-size:1.05rem;padding:0}@media all and (min-width: 576px){#toc-popup{max-width:32rem}}#toc-popup[open]{-webkit-animation:slide-in .3s ease-out;animation:slide-in .3s ease-out}#toc-popup[closing]{-webkit-animation:slide-out .3s ease-out;animation:slide-out .3s ease-out}#toc-popup .toc-header{position:-webkit-sticky;position:sticky;top:0;align-items:center;justify-content:space-between;flex-direction:row;display:flex;background-color:rgba(0,0,0,0);border-bottom:1px solid var(--main-border-color)}#toc-popup .toc-header .label{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:.5rem 0;margin-left:1.5rem}#toc-popup .toc-header>button{margin:.25rem;padding:.375rem .75rem;background-color:rgba(0,0,0,0);border:none;cursor:pointer;opacity:.7}#toc-popup button>i{font-size:1.25rem;vertical-align:middle;-webkit-user-select:none}#toc-popup button:focus-visible{box-shadow:none;outline:none}#toc-popup ul{list-style-type:none;padding-left:0}#toc-popup ul li ul,#toc-popup ul li+li{margin-top:.25rem}#toc-popup ul li a{display:flex;line-height:1.5;padding:.375rem 0;padding-right:1.125rem}#toc-popup ul li a.toc-link::before{display:none}#toc-popup .is-active-link{color:var(--primary-color) !important;font-weight:600}#toc-popup::-webkit-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}#toc-popup::backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}#toc-popup::after{display:flex;content:"";position:relative;background:linear-gradient(transparent, var(--main-bg) 70%);height:2rem}#toc-popup #toc-popup-content{overflow:auto;max-height:calc(100vh - 12rem);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;margin-bottom:-2rem;padding:1rem 1.5rem 1.5rem 1.5rem}.tooltip-container{position:relative;display:inline-block;cursor:pointer}.tooltip-container .tooltip{position:absolute;background:rgba(16,16,16,.95);color:#fff;padding:.35rem .65rem;border-radius:4px;font-size:.7rem;line-height:1.3;text-align:center;white-space:nowrap;z-index:99;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .2s ease,transform .2s ease}.tooltip-container .tooltip::after{content:"";position:absolute;width:0;height:0;border-style:solid}.tooltip-container:hover .tooltip,.tooltip-container .tooltip.active{opacity:1;visibility:visible;pointer-events:auto}.tooltip[data-pos=top]{bottom:125%;left:50%;transform:translateX(-50%)}.tooltip[data-pos=top]::after{top:100%;left:50%;transform:translateX(-50%);border-width:6px 6px 0 6px;border-color:rgba(16,16,16,.95) rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0)}.tooltip[data-pos=bottom]{top:125%;left:50%;transform:translateX(-50%)}.tooltip[data-pos=bottom]::after{bottom:100%;left:50%;transform:translateX(-50%);border-width:0 6px 6px 6px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) rgba(16,16,16,.95) rgba(0,0,0,0)}.tooltip[data-pos=left]{right:125%;top:50%;transform:translateY(-50%)}.tooltip[data-pos=left]::after{top:50%;left:100%;transform:translateY(-50%);border-width:6px 0 6px 6px;border-color:rgba(0,0,0,0) rgba(0,0,0,0) rgba(0,0,0,0) rgba(16,16,16,.95)}.tooltip[data-pos=right]{left:125%;top:50%;transform:translateY(-50%)}.tooltip[data-pos=right]::after{top:50%;right:100%;transform:translateY(-50%);border-width:6px 6px 6px 0;border-color:rgba(0,0,0,0) rgba(16,16,16,.95) rgba(0,0,0,0) rgba(0,0,0,0)}.tooltip.long{white-space:normal;text-align:left;width:220px}#header-wrapper{height:3rem;background-color:rgba(0,0,0,0);flex-shrink:0}@media all and (max-width: calc(992px - 1px)){#header-wrapper{transition:transform .4s ease,top .2s ease;left:0}}#topbar{display:flex;align-items:center;position:relative;justify-content:space-between;width:100%;height:100%}@media all and (min-width: 768px){#topbar{padding-left:1.5rem;padding-right:1.5rem}}@media all and (max-width: calc(992px - 1px)){#topbar{max-width:100%}}@media all and (min-width: 992px)and (max-width: calc(1200px - 1px)){#topbar{flex:0 0 auto;width:91.6666666667%}}@media all and (min-width: 1200px){#topbar{width:75%}}#topbar #breadcrumb{flex:1;font-size:1rem;line-height:1.5;color:var(--text-muted-color);padding-left:.5rem}.home #topbar #breadcrumb{opacity:0}@media all and (max-width: calc(992px - 1px)){#topbar #breadcrumb{margin-left:.375rem;padding:0 .75rem}}#topbar #breadcrumb a:hover{color:var(--primary-color)}#topbar #breadcrumb span:not(:last-child)::after{content:"›";padding:0 .3rem}#topbar #breadcrumb span a{color:var(--secondary-color)}@media all and (min-width: 992px)and (max-width: calc(1200px - 1px)){#topbar #breadcrumb{width:65%;margin-left:1rem;overflow:hidden;text-overflow:ellipsis;word-break:keep-all;white-space:nowrap}}@media all and (max-width: 768px){#topbar{max-width:100%}}.topbar-right{display:flex;align-items:center;margin-left:1rem}@media all and (min-width: 992px){.topbar-right{margin-left:0}}@media all and (max-width: calc(992px - 1px)){.topbar-right{gap:.25rem}}@media all and (max-width: calc(992px - 1px)){.mode-toggle-wrapper{justify-content:end;margin-right:.5rem}}.mode-toggle-wrapper #mode-toggle{font-size:inherit;width:1.75rem;height:1.75rem;margin-top:1px;border-radius:50%;border:none;color:var(--site-btn-color);background-color:rgba(0,0,0,0);text-decoration:none;display:flex;align-items:center;justify-content:center;cursor:pointer}.mode-toggle-wrapper #mode-toggle i>svg{height:1em;width:1em}@media all and (max-width: calc(992px - 1px)){.mode-toggle-wrapper #mode-toggle{margin-right:1rem;outline:none !important}}.mode-toggle-wrapper #mode-toggle:not(:focus-visible){outline:1px solid var(--btn-border-color)}.mode-toggle-wrapper #mode-toggle:hover{background-color:var(--site-hover-bg);color:var(--primary-color)}.mode-toggle-wrapper #mode-toggle:hover i{color:var(--primary-color)}.icon-border{margin-left:calc((.8rem - 3px)/2);margin-right:calc((.8rem - 3px)/2);background-color:var(--site-btn-color);content:"";width:3px;height:3px;border-radius:50%}@media all and (max-width: calc(992px - 1px)){.icon-border{display:none}}@media all and (min-width: 1650px){.icon-border{margin-left:calc((1rem - 3px)/2);margin-right:calc((1rem - 3px)/2)}}.access{top:2rem;transition:top .2s ease-in-out;margin-top:3rem}.access:only-child{position:-webkit-sticky;position:sticky}.access>section{padding-left:1rem}.access>section:not(:first-child){margin-top:4rem}.access .content{font-size:.9rem}#panel-wrapper{color:var(--text-muted-color);padding-left:.5rem}@media all and (min-width: 1200px){#panel-wrapper{flex:0 0 auto;width:25%}}#panel-wrapper .panel-heading{padding-left:1rem;padding-bottom:.5rem;margin-bottom:0;display:none;color:var(--label-color);font-size:inherit;font-weight:700}@media all and (max-width: calc(1200px - 1px)){#panel-wrapper{display:none}}footer{color:var(--text-muted-color);background-color:rgba(0,0,0,0);height:5rem;border-top:1px solid var(--main-border-color);display:flex;line-height:1.5;justify-content:center;flex-direction:column;align-items:center}@media all and (min-width: 992px){footer{justify-content:space-between;padding-bottom:1rem;flex-direction:row;align-items:center;height:5rem}}@media all and (max-width: calc(992px - 1px)){footer{transition:transform .4s ease;height:6rem;padding:1.5rem 0}}footer a:hover{text-decoration:none}footer p{text-align:center;margin:0}.footer-social{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;column-gap:1.6rem}@media all and (max-width: calc(992px - 1px)){.footer-social{margin-bottom:.8rem}}.footer-social a{color:var(--site-btn-color)}.footer-social a:hover{color:var(--primary-color);border:none}.footer-social a i{font-size:140%}search{display:flex;width:100%;border-radius:0 0 10px 0;border-bottom:1px solid var(--search-border-color);background:rgba(0,0,0,0);padding:0 .5rem;align-items:center}search i{z-index:2;font-size:.8rem;color:var(--search-icon-color)}search i.hidden{display:none}search:focus-within i{display:none}@media all and (max-width: calc(992px - 1px)){search{display:none}}@media all and (min-width: 992px){search{max-width:120px}}#search-result-wrapper{display:flex;height:100%;width:100%;overflow:auto;justify-content:center}#search-result-wrapper .search-content{margin-top:2rem;line-height:1.5;flex:0 0 auto;width:91.6666666667%}@media all and (max-width: calc(992px - 1px)){#search-result-wrapper{width:100%}#search-result-wrapper .search-content{letter-spacing:0}}@media all and (min-width: 992px){#search-result-wrapper{justify-content:start !important;max-width:85%}}#search-results{padding-bottom:3rem;display:flex;flex-wrap:wrap;justify-content:center;color:var(--text-muted-color);margin-top:1rem}@media all and (min-width: 992px)and (max-width: calc(1200px - 1px)){#search-results>div{max-width:700px}}#search-results a{font-size:1.4rem;line-height:1.5rem}#search-results>article{width:100%;padding:0 .25rem}@media all and (min-width: 576px){#search-results>article{padding:0 .5rem}}@media all and (min-width: 992px){#search-results>article{padding:0 1.5rem}}#search-results>article:not(:last-child){margin-bottom:1rem}@media all and (min-width: 1200px){#search-results>article{width:45%;padding:0}#search-results>article:nth-child(2n+1){margin-right:1.5rem}#search-results>article:nth-child(even){margin-left:1.5rem}#search-results>article:last-child:nth-child(odd){position:relative;right:24.3%}}#search-results>article header h2{line-height:2rem}#search-results>article header .post-meta{display:flex;flex-direction:column;color:var(--text-muted-color);margin:.25rem 0}@media all and (min-width: 576px){#search-results>article header .post-meta{flex-flow:row wrap;gap:.5rem}}#search-results>article header .post-meta>*:not(:last-child){margin-right:1.5rem}#search-results>article>p{white-space:break-spaces;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}#search-results>article i{color:#818182;margin-right:.15rem;font-size:80%}#search-results>p{margin-top:3rem}#search-cancel{display:none;color:var(--icon-color);white-space:nowrap;background:rgba(0,0,0,0);border:none;text-decoration:none}#search-cancel:hover{color:var(--hover-color);text-decoration:none}#search-input{background:center;border:0;border-radius:0;padding:.18rem .25rem;font-size:.9rem;line-height:1.5;color:var(--text-color);height:auto;width:100%}#search-input:focus{box-shadow:none;outline:none}@media all and (min-width: 1200px){#search-input{transition:all .3s ease-in-out}}#search-hints{padding:0 1rem}@media all and (min-width: 992px){#search-hints{display:none}}#search-hints h4{margin-bottom:1.5rem}#search-hints .post-tag{display:inline-block;line-height:1rem;font-size:1rem;background:var(--search-tag-bg);border:none;padding:.5rem;margin:0 1.25rem 1rem 0}#search-hints .post-tag:hover{color:#fff !important}#search-hints .post-tag::before{content:"#";color:var(--text-muted-color);padding-right:.2rem}@keyframes fade-away{from{opacity:1}to{opacity:.1}}.profile-wrapper{margin-top:6.3rem;margin-bottom:7.2rem;align-items:center;flex-direction:column;display:flex;text-align:center}.profile-wrapper #avatar{display:block;width:6.5rem;height:6.5rem;border-radius:50%;overflow:hidden;box-shadow:var(--avatar-border-color) 0 0 0 2px;transform:translateZ(0)}@media all and (min-width: 576px){.profile-wrapper #avatar{width:7rem;height:7rem}}.profile-wrapper #avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover;display:block;transition:transform .3s ease-in-out;transition:transform .5s;margin:0}.profile-wrapper #avatar img:hover{transform:scale(1.2)}.profile-wrapper #avatar img:hover::before{transform:scale(1.05)}@media all and (min-width: 992px){.profile-wrapper{margin-top:4rem;margin-bottom:8rem;padding-top:1rem;padding-bottom:3rem}}@media all and (min-width: 1650px){.profile-wrapper{margin-top:8rem;margin-bottom:10rem}}.site-title{margin-top:1.25rem;margin-bottom:.5rem;text-align:center;width:fit-content;display:block}.site-title a[flex]{display:flex;align-items:center;justify-content:center}.stevehoang{width:68%;max-width:1090px;height:auto;display:block}.stevehoang path{fill:none;stroke:var(--site-title-color);stroke-linecap:round;stroke-linejoin:round;stroke-width:12px;stroke-dasharray:5200;stroke-dashoffset:5200;transform-origin:center;animation:grow 15s ease-in-out infinite;animation-delay:0s}@keyframes grow{0%{opacity:0}5%{opacity:1}35%,70%{stroke-dashoffset:0}75%{opacity:1}100%{opacity:0;stroke-dashoffset:0}}@media(prefers-reduced-motion){.stevehoang path{animation:none !important;stroke-dasharray:unset !important;opacity:1}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);border:0}header.profile-wrapper h1{font-size:inherit;margin-top:0;margin-bottom:0}.subtitle{font-size:95%;color:var(--site-subtitle-color);font-style:italic;word-spacing:1px;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-o-user-select:none;user-select:none}.subtitle:has(.iamstev:hover){color:rgba(0,0,0,0);transition:.3s}.subtitle:has(.iamstev:hover) a:not(:hover){opacity:0;transition:.3s}.subtitle a{color:var(--secondary-color)}.subtitle a:hover{color:var(--primary-color)}.subtitle a.iamstev:hover{color:var(--primary-color) !important;transition:.3s;opacity:1 !important}#post-list{margin-top:3rem;flex-grow:1 !important}@media all and (min-width: 992px){#post-list{margin-top:3.5rem}}@media all and (min-width: 1200px){#post-list{padding:0 .25rem}}#post-list .card{border:0;background-color:rgba(0,0,0,0);position:relative;overflow:visible;display:flex;flex-direction:column;min-width:0;overflow-wrap:break-word}#post-list .card:hover{text-decoration:none}#post-list .card:not(:last-child){margin-bottom:4rem;padding-bottom:2rem;border-bottom:1px solid var(--tb-border-color);border-radius:0}#post-list .card .image{width:100%;position:relative;display:inline-block}@media all and (min-width: 768px){#post-list .card .image{width:50%}}#post-list .card .image img{display:block;position:relative;z-index:2;width:100%;height:auto}#post-list .card .image.image-left{order:1}#post-list .card .image.image-right{order:2}#post-list .card .image::before{content:"";position:absolute;top:-35px;width:100%;height:100%;opacity:.3;background-image:var(--lqip-url);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:1;transition:left .2s ease}@media all and (max-width: calc(768px - 1px)){#post-list .card .image::before{display:none}}#post-list .card .image.image-left::before{left:-35px}#post-list .card .image.image-right::before{left:35px}#post-list .card .content-left{width:100%}@media all and (min-width: 768px){#post-list .card .content-left{width:50%;order:1}}#post-list .card .content-right{width:100%}@media all and (min-width: 768px){#post-list .card .content-right{width:50%;order:2}}@media all and (max-width: calc(768px - 1px)){#post-list .card .image-left,#post-list .card .image-right{order:unset !important}#post-list .card .image{order:1;margin-bottom:1.5rem}#post-list .card .content-left,#post-list .card .content-right{order:2}}#post-list .card:not(:has(.image)) .card-body{text-align:center;margin:0 auto}#post-list .card:not(:has(.image)) .card-body .card-title{margin-left:auto;margin-right:auto;display:flex}#post-list .card:not(:has(.image)) .card-body .card-meta{justify-content:center}#post-list .card .card-body{height:100%;width:100%;min-height:250px;padding:.5rem;display:flex;justify-content:space-between;flex-direction:column;flex:1 1 auto}@media all and (min-width: 768px){#post-list .card .card-body{padding:1rem}}#post-list .card .card-body .card-title{font-size:2.45rem;opacity:.45;line-height:1.35;margin:0;font-weight:700;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;text-rendering:optimizelegibility;color:oklch(.92 .012 68/.39);-webkit-text-stroke-width:.5px;-webkit-text-stroke-color:var(--text-muted-color)}#post-list .card .card-body.body-right .card-title{text-align:right}#post-list .card .card-body.body-right .card-content{text-align:right}@media all and (max-width: calc(768px - 1px)){#post-list .card .card-body.body-right .card-content{text-align:revert}}#post-list .card .card-body .card-content{color:var(--text-muted-color)}#post-list .card .card-body .card-content p{line-height:1.6;font-size:1rem}#post-list .card .card-body .card-meta{color:var(--text-muted-color);display:flex;flex-grow:1;align-items:flex-end;font-size:.85rem}#post-list .card .card-body .card-meta i:first-child{margin-right:.25rem}#post-list .card .card-body .card-meta i:not(:first-child){margin-left:1.5rem;margin-right:.25rem}@media all and (min-width: 768px){#post-list .card .card-body .card-meta i:not(:first-child){margin-left:1.75rem}}#post-list .card .card-body .card-meta>div:first-child{margin-right:auto}#post-list .card .card-body .card-meta>div:last-child.pin{margin-left:.25rem}.pagination{color:var(--text-color);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-size:1rem;justify-content:space-evenly;margin-top:3rem;margin-bottom:0;padding-top:1rem;padding-left:0;list-style:none;display:flex}@media all and (min-width: 992px){.pagination{font-size:.85rem;justify-content:center;padding-top:2rem;margin-top:1.5rem}}.pagination a:hover{text-decoration:none}@media all and (max-width: calc(992px - 1px)){.pagination .page-item:not(:first-child):not(:last-child){display:none}}@media all and (min-width: 992px){.pagination .page-item:not(:last-child){margin-right:1rem}}.pagination .page-item .page-link{color:var(--text-color);padding:0;display:flex;justify-content:center;align-items:center;position:relative;width:1.65rem;height:1.65rem;border:0;font-size:1rem;background-color:inherit}.pagination .page-item .page-link::before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;transform:rotate(45deg);border-radius:2px;z-index:-1}.pagination .page-item.active .page-link{z-index:1;background-color:rgba(0,0,0,0)}.pagination .page-item.active .page-link::before{background-color:oklch(.65 .02 80/.1)}.pagination .page-item:not(.active) .page-link:hover{box-shadow:none}.pagination .page-item:not(.active) .page-link:hover::before{box-shadow:inset var(--btn-border-color) 0 0 0 1px}.pagination .page-item.disabled{cursor:not-allowed;pointer-events:none}.pagination .page-item.disabled .page-link{color:rgba(108,117,125,.57)}.pagination .page-index{vertical-align:middle}@media all and (min-width: 992px){.pagination .page-index{display:none}}.post-navigation .navigation.disabled,.post-navigation .navigation{width:50%;position:relative;border-radius:unset;border-color:var(--btn-border-color)}header .post-desc{font-size:1.125rem;font-weight:300;line-height:1.6;margin-bottom:1.5rem}header .post-meta{margin-bottom:2rem;color:var(--text-muted-color)}header .post-meta span+span::before{content:"•";padding-left:.25rem;padding-right:.25rem}header .post-meta em a{color:inherit}header .post-meta .cover-img{margin:1rem 0}header .post-meta .cover-img>figcaption{text-align:center;padding:.5rem 0}.post-tail-wrapper{margin-top:6rem;border-bottom:1px double var(--main-border-color);color:var(--text-muted-color)}.post-tail-wrapper .post-topic{display:flex;padding-bottom:.5rem;margin-top:1rem;align-items:center;justify-content:space-between}.post-tail-wrapper .share-wrapper{vertical-align:middle;align-items:center;display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.post-tail-wrapper .share-wrapper .share-icons>*,.post-tail-wrapper .share-wrapper .share-icons i{font-size:1rem}.post-tail-wrapper .share-wrapper .share-icons{display:flex}.post-tail-wrapper .share-wrapper .share-icons i{color:var(--site-btn-color)}.post-tail-wrapper .share-wrapper .share-icons>*{margin-left:.5rem}.post-tail-wrapper .share-wrapper .share-icons button{padding:0;border:none;line-height:inherit;background-color:rgba(0,0,0,0)}.post-tags{line-height:2rem}.post-tags>i{margin-right:.25rem}.post-tags .post-tag>a{text-decoration:none}.post-navigation{display:flex;justify-content:space-between}@media all and (max-width: calc(992px - 1px)){.post-navigation{padding-left:0;padding-right:0}}.post-navigation .navigation{color:var(--text-color);cursor:pointer;padding:.375rem .75rem;text-align:center;line-height:1.5;border:1px solid var(--main-border-color);-webkit-tap-highlight-color:rgba(0,0,0,0)}.post-navigation .navigation:hover:not(.disabled){background-color:rgba(0,0,0,0);border-color:var(--main-bg);color:var(--secondary-color)}.post-navigation .navigation.disabled{pointer-events:auto;cursor:not-allowed;background:none;color:gray}.post-navigation .navigation.disabled::before{color:rgba(134,134,134,.4705882353) !important}.post-navigation .navigation.disabled.navigation:focus{box-shadow:none}.post-navigation .navigation::before{color:var(--text-muted-color);font-size:.65rem;content:attr(aria-label);display:block}.post-navigation .navigation:first-child{border-radius:50px 0 50px 0;border-top:1px;border-left:1px;border-right:1px;border-color:var(--main-border-color);left:2px}@media all and (min-width: 768px){.post-navigation .navigation:first-child{left:1.6px}}@media all and (min-width: 1200px){.post-navigation .navigation:first-child{left:1.25px}}@media all and (min-width: 1650px){.post-navigation .navigation:first-child{left:.75px}}.post-navigation .navigation:first-child::before{content:"Previous";color:var(--text-muted-color);position:absolute;bottom:0;left:0;transform:translate(5px, -2px)}.post-navigation .navigation:first-child:hover:not(.disabled)::before{color:var(--secondary-color);background-color:rgba(0,0,0,0)}.post-navigation .navigation:last-child{border-radius:50px 0 50px 0;border-bottom:1px;border-right:1px;border-left:1px;border-color:var(--main-border-color);right:2px}@media all and (min-width: 768px){.post-navigation .navigation:last-child{right:1.6px}}@media all and (min-width: 1200px){.post-navigation .navigation:last-child{right:1.25px}}@media all and (min-width: 1650px){.post-navigation .navigation:last-child{right:.75px}}.post-navigation .navigation:last-child::before{content:"Next";color:var(--text-muted-color);position:absolute;top:0;right:0;transform:translate(-5px, 2px)}.post-navigation .navigation:last-child:hover:not(.disabled)::before{color:var(--primary-color);background-color:rgba(0,0,0,0)}.post-navigation p{font-size:inherit;line-height:1.5rem;margin-top:1rem}@-webkit-keyframes fade-up{from{opacity:0;margin-top:4rem}to{opacity:1}}@keyframes fade-up{from{opacity:0;margin-top:4rem}to{opacity:1}}#toc-wrapper::before,.toc-border-cover{content:"";display:block;position:sticky;top:0;width:100%;height:3rem;background:rgba(0,0,0,0)}#toc-wrapper{top:50vh;transform:translateY(-50%);max-height:80vh;transition:top .2s ease-in-out;overflow-y:auto;scrollbar-width:none;margin-top:2rem}#toc-wrapper:not(.invisible){-webkit-animation:fade-up .8s;animation:fade-up .8s;position:sticky}#toc-wrapper ul{list-style:none;font-size:.85rem;line-height:1.25;padding-left:0}#toc-wrapper ul:hover li a{opacity:.3;color:inherit;transition:opacity .3s ease,color .3s ease}#toc-wrapper ul li a{padding:.4rem 0 .4rem 1.25rem;color:rgba(0,0,0,0);transition:opacity .5s ease,color .3s ease}#toc-wrapper ul li a:hover{opacity:1 !important;color:inherit;transition:opacity .3s ease,color .3s ease}#toc-wrapper ul .toc-link{display:block}#toc-wrapper ul .toc-link:hover{color:var(--secondary-color);text-decoration:none}#toc-wrapper ul .toc-link::before{display:none}#toc-wrapper ul .is-active-link{font-weight:700;opacity:1 !important}#toc-wrapper ul .is-active-link::before{display:inline-block;width:1px;height:1.25rem;background-color:var(--secondary-color) !important;opacity:.6 !important}#toc-wrapper ul ul{padding-left:.75rem}.toc-border-cover{margin-bottom:-1.5rem;z-index:3}#toc-bar{position:-webkit-sticky;position:sticky;top:0;z-index:1;margin:0 -1rem;margin-top:-3rem;align-items:center;justify-content:space-between;display:flex;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:linear-gradient(var(--main-bg) 70%, transparent);border-bottom:1px solid var(--main-border-color);transition:all .2s ease-in-out}#toc-bar>button{padding:.375rem .75rem;margin-right:.25rem;background-color:rgba(0,0,0,0);border:none;cursor:pointer;font-size:inherit;line-height:inherit}#toc-bar .label{margin:0 0 0 .375rem;padding:0 .75rem;color:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#toc-bar.invisible{top:-3rem;transition:none;visibility:hidden}@media all and (min-width: 1200px){#toc-bar{display:none}}#toc-solo-trigger{color:var(--text-muted-color);border:1px solid var(--btn-border-color);border-radius:.2rem;margin-top:-2rem;background-color:rgba(0,0,0,0);cursor:pointer;visibility:hidden}#toc-solo-trigger .label{font-size:1rem;padding-left:.5rem;padding-right:.25rem;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}#toc-solo-trigger:hover{box-shadow:none;background:none}@media all and (min-width: 1200px){#toc-solo-trigger{display:none !important}}@-webkit-keyframes slide-in{from{opacity:.7;transform:translateY(-3rem)}to{opacity:1;transform:translateY(0)}}@keyframes slide-in{from{opacity:.7;transform:translateY(-3rem)}to{opacity:1;transform:translateY(0)}}@-webkit-keyframes slide-out{0%{transform:translateY(0);opacity:1}100%{transform:translateY(-3rem);opacity:0}}@keyframes slide-out{0%{transform:translateY(0);opacity:1}100%{transform:translateY(-3rem);opacity:0}}.post-tail-wrapper .share-wrapper .share-icons>*:hover i{color:var(--btn-share-hover-color) !important}.share-label{color:var(--text-muted-color);color:inherit;font-size:inherit;font-weight:400}.share-label::after{content:""}@media all and (max-width: 768px){.content>p>img{max-width:calc(100% + 1rem)}}@media all and (min-width: 1200px){h2,h3,h4{scroll-margin-top:2rem;scroll-behavior:smooth}}.categories{margin-bottom:2rem !important;border:1px solid var(--categories-border);background-color:rgba(0,0,0,0);color:var(--text-color)}.categories.card,.categories .list-group{background-color:rgba(0,0,0,0);display:flex;flex-direction:column;padding-left:0;margin-bottom:0}.categories{display:flex;flex-direction:column;min-height:0}.categories .card-header{padding:.75rem;border-radius:9px;border-bottom:0;background-color:oklch(.85 .02 80/.1);display:flex;justify-content:space-between}.categories .card-header span:first-child{margin-left:.5rem}.categories .card-header span:first-child a{margin:0 .5rem}.categories .card-header.hide-border-bottom{border-bottom:0;border-bottom-left-radius:0;border-bottom-right-radius:0}.categories i{font-size:86%;color:var(--icon-color)}.categories .list-group-item{border:none;border-top:1px solid var(--tb-border-color);background-color:rgba(0,0,0,0);color:var(--text-color);padding-left:2rem;padding-top:.5rem;padding-bottom:.5rem;position:relative;display:block}.categories .list-group-item a{margin:0 .5rem}.categories .list-group-item:first-child{border-top-left-radius:0;border-top-right-radius:0}.categories .list-group-item:last-child{border-bottom:0;border-bottom-right-radius:inherit;border-bottom-left-radius:inherit}.categories .collapse{max-height:0;overflow:hidden;transition:max-height .3s ease,opacity .3s ease;opacity:0;visibility:hidden}.categories .collapse.show{max-height:1000px;opacity:1;visibility:visible}.category-trigger{width:1.7rem;height:1.7rem;border-radius:50%;border-bottom:0;text-align:center;color:#6c757d !important;cursor:pointer}.category-trigger i{position:relative;height:.7rem;width:1rem;transition:transform .3s ease}.category-trigger:hover i{color:var(--primary-color)}.category-trigger.disabled{cursor:not-allowed;opacity:.5}@media(hover: hover){.category-trigger:hover{background-color:var(--site-hover-bg)}}.rotate{transform:rotate(-90deg)}.tag{border-radius:.5em;padding:6px 8px 7px;margin-right:.8rem;line-height:3rem;letter-spacing:0;border:1px solid var(--btn-border-color) !important;box-shadow:0 0 3px 0 var(--btn-border-color);text-decoration:none !important}.tag:hover{opacity:1 !important;transition:.3s}.tag sup{margin-left:.6em;font-size:.7em;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}#tags{display:flex;flex-wrap:wrap;margin-bottom:3rem}#tags:hover .tag{opacity:.3}@media all and (max-width: calc(992px - 1px)){#tags{justify-content:center !important}}#archives{letter-spacing:.03rem}#archives>h2{margin-top:3rem}@media all and (max-width: calc(576px - 1px)){#archives{margin-top:-1rem}#archives ul{letter-spacing:0}}#archives .year{font-family:"Helvetica Neue";font-size:8em;height:3.5rem;opacity:.1;color:rgba(0,0,0,0);font-weight:700;display:block;position:relative;margin-bottom:4rem;top:1rem;align-items:center;text-align:end;-webkit-text-stroke-width:3px;-webkit-text-stroke-color:var(--heading-color)}#archives ul:hover li{opacity:.3}#archives ul li{font-size:1.1rem;line-height:3rem;border-radius:2px}#archives ul li:hover{opacity:1 !important;transition:.3s}#archives ul li:nth-child(odd){background-image:linear-gradient(to right, transparent 20%, oklch(85% 0.02 80deg / 0.1) 50%, transparent)}#archives ul:last-child li:last-child::before{height:1.5rem}#archives .date{white-space:nowrap;display:inline-block;position:relative;right:.5rem}#archives .date.month{width:1.4rem;text-align:center;font-size:.875rem;margin-left:.25rem}#archives .date.day{font-size:85%;font-family:Inter,sans-serif}#archives a{margin-left:2.5rem;position:relative;top:.1rem;text-decoration:none}#archives a:hover{border-bottom:none;color:var(--secondary-color)}#archives a::before{content:"";display:inline-block;position:relative;border-radius:50%;width:8px;height:8px;float:left;top:1.35rem;left:71px;border:1px solid var(--icon-color);z-index:1}.dash{flex-grow:1;margin:0 .5rem .6rem .5rem;border-bottom:2px dotted var(--dash-color)}@media all and (min-width: 992px){#page-category h1,#page-tag h1{padding-left:.5rem}}#page-category h1>sup,#page-tag h1>sup{padding-left:.5rem;font-size:1.25rem;font-weight:300;color:var(--text-muted-color)}#page-category ul,#page-tag ul{padding-left:0}#page-category ul:hover li,#page-tag ul:hover li{opacity:.3;transition:none}#page-category ul>li,#page-tag ul>li{line-height:1.5rem;padding:.6rem 0;display:flex;justify-content:space-between}#page-category ul>li:hover,#page-tag ul>li:hover{opacity:1 !important;transition:.3s}@media all and (min-width: 768px){#page-category ul>li,#page-tag ul>li{padding-left:1rem;padding-right:1rem}}#page-category ul>li::before,#page-tag ul>li::before{background:#999;width:5px;height:5px;border-radius:50%;display:block;content:"";position:relative;top:.6rem;margin-right:.5rem}@media all and (max-width: calc(576px - 1px)){#page-category ul>li::before,#page-tag ul>li::before{margin:0 .5rem}}#page-category ul>li>a,#page-tag ul>li>a{font-size:1.1rem}@media all and (max-width: calc(576px - 1px)){#page-category ul>li>a,#page-tag ul>li>a{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}}#page-category .datetime,#page-tag .datetime{color:var(--text-muted-color);font-size:.875rem;white-space:nowrap}#page-category h1>i,#page-tag h1>i{font-size:1.25rem}.wrapper{padding:0 20px;box-sizing:border-box}.not-found{display:flex;align-items:center;justify-content:center;min-height:75vh;text-align:center}.not-found h1.title{font-size:5em;font-weight:bold;text-shadow:1px 0px 0px var(--primary-color);margin:0 0 1rem}.not-found a{display:inline-block;margin-top:1.5rem;font-weight:bold}.not-found a:hover{color:var(--primary-color)}