@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:400;src:url(/_astro/barlow-latin-400-normal.qiz4-Cze.woff2) format("woff2"),url(/_astro/barlow-latin-400-normal.fsAxiSwU.woff) format("woff")}@font-face{font-family:Barlow;font-style:normal;font-display:swap;font-weight:700;src:url(/_astro/barlow-latin-700-normal.A9pxMQ4z.woff2) format("woff2"),url(/_astro/barlow-latin-700-normal.__SGTsZ1.woff) format("woff")}:root{--accent-blue: #eab308;--accent-blue-strong: #a16207;--page-bg: #f8fafc;--surface: #ffffff;--surface-muted: #f1f5f9;--text: #111827;--text-muted: color-mix(in srgb, var(--text) 68%, transparent);--border-subtle: color-mix(in srgb, var(--text) 14%, transparent);--shadow-soft: 0 8px 22px rgb(15 23 42 / 8%);--shadow-lifted: 0 14px 34px rgb(15 23 42 / 13%);--accent-blue-soft: color-mix(in srgb, var(--accent-blue) 14%, var(--surface));--accent-blue-softer: color-mix(in srgb, var(--accent-blue) 8%, var(--surface));color:var(--text);color-scheme:light;font-family:Barlow,Noto Sans TC,Noto Sans JP,system-ui,sans-serif}:root[data-theme=dark]{--accent-blue: #facc15;--accent-blue-strong: #fef08a;--page-bg: #10151d;--surface: #171e28;--surface-muted: #202938;--text: #eef4fb;--text-muted: color-mix(in srgb, var(--text) 68%, transparent);--border-subtle: color-mix(in srgb, var(--text) 16%, transparent);--shadow-soft: 0 10px 26px rgb(0 0 0 / 26%);--shadow-lifted: 0 18px 44px rgb(0 0 0 / 34%);color-scheme:dark}h1[data-astro-cid-4dqtj3le],h2[data-astro-cid-4dqtj3le],h3[data-astro-cid-4dqtj3le],.site-title[data-astro-cid-4dqtj3le]{font-family:Barlow,Noto Sans TC,Noto Sans JP,sans-serif;font-weight:700;letter-spacing:.01em}code[data-astro-cid-4dqtj3le],pre[data-astro-cid-4dqtj3le]{font-family:JetBrains Mono,Cascadia Code,monospace}body{margin:0;background:var(--page-bg);color:var(--text)}header[data-astro-cid-4dqtj3le]{position:sticky;top:0;z-index:20;border-bottom:1px solid var(--border-subtle);background:color-mix(in srgb,var(--page-bg) 88%,transparent);backdrop-filter:blur(14px)}nav[data-astro-cid-4dqtj3le]{max-width:1320px;margin:0 auto;padding:14px 20px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}nav[data-astro-cid-4dqtj3le] a[data-astro-cid-4dqtj3le]{display:inline-flex;align-items:center;min-height:1.85rem;padding:.08rem .18rem;color:inherit;text-decoration:none}nav[data-astro-cid-4dqtj3le] a[data-astro-cid-4dqtj3le]:hover{color:var(--accent-blue-strong)}nav[data-astro-cid-4dqtj3le] a[data-astro-cid-4dqtj3le][aria-current=page]{color:var(--accent-blue-strong);font-weight:750}.nav-actions[data-astro-cid-4dqtj3le]{display:inline-flex;gap:.45rem;align-items:center;margin-left:auto}.language-select[data-astro-cid-4dqtj3le]{height:2rem;min-width:4.4rem;border:1px solid var(--border-subtle);border-radius:999px;background:color-mix(in srgb,var(--surface) 82%,transparent);color:color-mix(in srgb,var(--text) 82%,transparent);cursor:pointer;font:inherit;font-size:.82rem;font-weight:720;padding:0 1.65rem 0 .72rem}.language-wrap[data-astro-cid-4dqtj3le]{display:inline-grid;gap:.12rem;justify-items:end}.language-available[data-astro-cid-4dqtj3le]{color:color-mix(in srgb,var(--text) 64%,transparent);font-size:.72rem;font-weight:720;line-height:1;text-decoration:none}.language-available[data-astro-cid-4dqtj3le]:hover{color:var(--accent-blue-strong)}.theme-toggle[data-astro-cid-4dqtj3le]{display:inline-grid;place-items:center;width:2rem;height:2rem;padding:0;border:1px solid var(--border-subtle);border-radius:999px;background:color-mix(in srgb,var(--surface) 82%,transparent);color:color-mix(in srgb,var(--text) 78%,transparent);cursor:pointer;font:inherit;font-size:.95rem}.language-select[data-astro-cid-4dqtj3le]:hover,.theme-toggle[data-astro-cid-4dqtj3le]:hover{border-color:color-mix(in srgb,var(--accent-blue) 40%,transparent);color:var(--accent-blue-strong)}.site-title[data-astro-cid-4dqtj3le]{color:var(--accent-blue-strong);font-size:1.35rem;font-weight:750;line-height:1;margin-right:.35rem;text-decoration:none;letter-spacing:-.02em}main[data-astro-cid-4dqtj3le]{max-width:1320px;margin:0 auto;padding:34px 20px 72px}.site-footer[data-astro-cid-4dqtj3le]{max-width:1320px;margin:0 auto;padding:0 20px 28px;color:color-mix(in srgb,var(--text) 58%,transparent);font-size:.9rem}a[data-astro-cid-4dqtj3le]{text-decoration-thickness:.08em;text-underline-offset:.18em}img[data-astro-cid-4dqtj3le],video[data-astro-cid-4dqtj3le]{max-width:100%;height:auto}.muted[data-astro-cid-4dqtj3le]{opacity:.72}@media(max-width:760px){header[data-astro-cid-4dqtj3le] nav[data-astro-cid-4dqtj3le]{padding:9px 14px;gap:10px;font-size:.9rem;line-height:1.2}main[data-astro-cid-4dqtj3le]{max-width:960px;padding:14px 14px 52px}}.blog-shell{display:grid;grid-template-columns:minmax(250px,310px) minmax(0,1fr);gap:2.4rem;align-items:start}.side-rail{position:sticky;top:4.4rem;max-height:calc(100vh - 5.4rem);overflow:auto;padding:.8rem .85rem .9rem 0;border-right:2px solid color-mix(in srgb,currentColor 22%,transparent)}.blog-index-sidebar.side-rail{top:74px;max-height:calc(100vh - 90px)}.post-sidebar.side-rail{display:grid;grid-template-rows:minmax(0,1fr) auto;overflow:hidden}.catalogue-outline-rail{grid-template-rows:auto}.catalogue-outline-rail .post-toc{margin-top:.85rem;padding-top:0;border-top:0}.post-sidebar-scroll{min-height:0;overflow:auto;padding-right:.1rem}.post-sidebar-head{display:flex;align-items:center;gap:.5rem;margin:.85rem 0 .65rem}.side-rail h2{margin:0;font-size:1.25rem;letter-spacing:0}.sidebar-filter-summary{display:inline-flex;align-items:center;gap:.45rem}.sidebar-filter-summary[hidden]{display:none}.sidebar-filter-summary span{display:inline-flex;align-items:center;min-height:1.2rem;padding:0 .42rem;border:1px solid color-mix(in srgb,var(--accent-blue) 26%,transparent);border-radius:999px;background:var(--accent-blue-softer);color:var(--accent-blue-strong);font-size:.68rem;font-weight:800;letter-spacing:.04em}.sidebar-filter-summary button{padding:0;border:0;background:transparent;color:color-mix(in srgb,currentColor 62%,transparent);cursor:pointer;font:inherit;font-size:.8rem;font-weight:700;text-decoration:underline;text-underline-offset:.16em}.sidebar-filter-summary button:hover{color:var(--accent-blue-strong)}.post-sidebar nav{display:grid;gap:.1rem;max-width:none;margin:0;padding:0}.sidebar-post{display:grid;gap:.06rem;padding:.38rem .6rem;border-left:4px solid transparent;border-radius:0 7px 7px 0;color:color-mix(in srgb,currentColor 78%,transparent);text-decoration:none}.sidebar-post:hover,.sidebar-post.is-current{color:var(--accent-blue-strong);border-left-color:var(--accent-blue);background:var(--accent-blue-softer)}.sidebar-post[data-filtered=muted]{opacity:.42}.sidebar-post span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-post small{color:color-mix(in srgb,currentColor 62%,transparent);font-weight:600}.post-toc{position:sticky;bottom:0;z-index:2;margin-top:1.15rem;padding:.85rem 0 .15rem;border-top:1px solid color-mix(in srgb,currentColor 12%,transparent);background:color-mix(in srgb,var(--page-bg) 96%,var(--surface) 4%);backdrop-filter:blur(12px)}.post-toc[hidden]{display:none}.post-toc nav,.post-floating-outline nav{display:grid;gap:.12rem;max-width:none;margin:.45rem 0 0;padding:0}.post-toc a,.post-floating-outline a{display:block;overflow:hidden;padding:.26rem .48rem;border-radius:6px;color:color-mix(in srgb,currentColor 72%,transparent);font-size:.84rem;line-height:1.25;text-decoration:none;text-overflow:ellipsis;white-space:nowrap}.post-toc a[data-level=h2],.post-floating-outline a[data-level=h2]{padding-left:1.1rem}.post-toc a[data-level=h3],.post-floating-outline a[data-level=h3]{padding-left:1.85rem;font-size:.8rem}.post-toc a[data-level=h4],.post-toc a[data-level=h5],.post-toc a[data-level=h6],.post-floating-outline a[data-level=h4],.post-floating-outline a[data-level=h5],.post-floating-outline a[data-level=h6]{display:none;font-size:.76rem}.post-toc a[data-level=h4],.post-floating-outline a[data-level=h4]{padding-left:2.55rem}.post-toc a[data-level=h5],.post-floating-outline a[data-level=h5]{padding-left:3.1rem}.post-toc a[data-level=h6],.post-floating-outline a[data-level=h6]{padding-left:3.55rem}.post-toc a.is-active-branch,.post-floating-outline a.is-active-branch{display:block}.post-toc a[data-level=h1],.post-floating-outline a[data-level=h1]{font-weight:750}.post-toc a[data-role=top]:before,.post-floating-outline a[data-role=top]:before{content:"↑";display:inline-block;width:1.05rem;margin-right:.18rem;color:color-mix(in srgb,currentColor 82%,transparent);font-weight:800;text-align:center}.post-toc a[data-outline-kind=comments]:before,.post-floating-outline a[data-outline-kind=comments]:before{content:"🗨︎";display:inline-block;width:1.05rem;margin-right:.18rem;color:color-mix(in srgb,currentColor 82%,transparent);font-family:Segoe UI Symbol,"Noto Sans Symbols 2",Noto Sans TC,sans-serif;font-size:.96em;font-weight:800;line-height:1;text-align:center}.post-toc a[data-outline-kind=comments],.post-floating-outline a[data-outline-kind=comments]{font-weight:750}.post-toc a:hover,.post-toc a.is-active,.post-floating-outline a:hover,.post-floating-outline a.is-active{background:var(--accent-blue-softer);color:var(--accent-blue-strong)}.side-calendar{padding-top:1rem;border-top:1px solid color-mix(in srgb,currentColor 12%,transparent)}.post-calendar.side-calendar{margin-top:1.4rem}.side-calendar h2{margin:0 0 .8rem}.side-calendar-month{display:grid;gap:.45rem;margin:0 0 .85rem}.side-calendar-month-label{color:color-mix(in srgb,currentColor 62%,transparent);font-size:.82rem;font-weight:600;letter-spacing:0}.side-calendar-days{display:flex;flex-wrap:wrap;gap:.28rem}.side-calendar .side-calendar-day{display:inline-grid;place-items:center;width:1.8rem;height:1.8rem;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:6px;background:color-mix(in srgb,var(--surface) 94%,currentColor 6%);color:color-mix(in srgb,currentColor 76%,transparent);font-size:.78rem;font-weight:650;text-decoration:none}.side-calendar .side-calendar-day:hover,.side-calendar a.side-calendar-day:hover,.side-calendar .side-calendar-day.is-current,.side-calendar .blog-calendar-day-group.has-multiple:hover>.side-calendar-day{border-color:var(--accent-blue);background:var(--accent-blue-soft);color:var(--accent-blue-strong)}@media(max-width:850px){.blog-index-sidebar.side-rail{position:static;max-height:none;margin-bottom:1rem;padding:0 0 1rem;border-right:0;border-bottom:1px solid color-mix(in srgb,currentColor 12%,transparent)}}.post-article{width:100%;max-width:880px;margin-inline:auto;min-width:0;text-autospace:ideograph-alpha ideograph-numeric}.catalogue-article{max-width:900px;margin-inline:auto}.catalogue-detail-header{margin-bottom:1.2rem}.about-article>p:first-of-type{color:color-mix(in srgb,currentColor 82%,transparent);font-size:1.15rem;line-height:1.65}.post-article>*{max-width:840px;margin-left:auto;margin-right:auto}.post-article>.post-header{max-width:none}.post-header{position:sticky;top:58px;z-index:10;display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:.7rem;align-items:center;margin-bottom:.9rem;margin-right:-16px;margin-left:-16px;padding:.65rem 16px .72rem;border-bottom:1px solid color-mix(in srgb,currentColor 10%,transparent);background:color-mix(in srgb,var(--page-bg) 92%,transparent);backdrop-filter:blur(12px)}.post-header-back{display:inline-flex;align-items:center;justify-content:center;gap:.2rem;min-width:3.35rem;min-height:2rem;padding:0 .5rem;border:2px solid color-mix(in srgb,var(--accent-blue) 52%,transparent);border-radius:999px;background:color-mix(in srgb,var(--page-bg) 92%,var(--surface) 8%);color:color-mix(in srgb,currentColor 78%,transparent);font-size:.9rem;font-weight:600;line-height:1;text-decoration:none}.post-header-back:hover{color:var(--accent-blue-strong);border-color:var(--accent-blue);background:var(--accent-blue-soft)}.post-header-copy{min-width:0}.post-header-outline-button{display:none;align-items:center;justify-content:center;min-height:2rem;padding:0 .55rem;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:999px;background:color-mix(in srgb,var(--surface) 94%,currentColor 6%);color:color-mix(in srgb,currentColor 76%,transparent);cursor:pointer;font:inherit;font-size:.84rem;font-weight:700}.post-header-outline-button:hover,.post-header-outline-button[aria-expanded=true]{border-color:color-mix(in srgb,var(--accent-blue) 42%,transparent);background:var(--accent-blue-softer);color:var(--accent-blue-strong)}.post-floating-outline{display:none}.back-link{display:inline-flex;align-items:center;min-height:1.85rem;padding:.12rem .55rem;border:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:999px;background:color-mix(in srgb,var(--surface) 94%,currentColor 6%);color:color-mix(in srgb,currentColor 72%,transparent);font-size:.95rem;font-weight:500;text-decoration:none}.back-link:hover{color:var(--accent-blue-strong);text-decoration:underline}.post-meta{display:flex;flex-wrap:wrap;gap:.45rem .7rem;color:color-mix(in srgb,currentColor 68%,transparent);font-size:.95rem;font-weight:600}.post-meta span:before,.post-card-meta span:before{content:"/";margin-right:.7rem;opacity:.45}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.post-tags{margin-bottom:1.6rem}.tag{display:inline-flex;align-items:center;min-height:1.6rem;padding:.1rem .58rem;border:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:999px;background:color-mix(in srgb,var(--surface) 92%,currentColor 8%);color:color-mix(in srgb,currentColor 78%,transparent);font-size:.85rem;text-decoration:none}.tag:hover{color:var(--accent-blue-strong);border-color:color-mix(in srgb,var(--accent-blue) 34%,transparent);background:var(--accent-blue-softer)}.tag[data-tone=build],.tag[data-tone=anime],.tag[data-tone=software]{border-color:var(--tone-border);background:var(--tone-bg);color:var(--tone-color)}.tag[data-tone]:not([data-tone=site]):hover{border-color:color-mix(in srgb,var(--tone-color) 58%,transparent);background:color-mix(in srgb,var(--tone-color) 20%,var(--surface));color:var(--tone-color)}.post-pager{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;width:100%;margin-top:3rem;padding-top:1.25rem;border-top:1px solid color-mix(in srgb,currentColor 12%,transparent)}.post-pager a{display:grid;gap:.15rem;min-width:0;padding:.78rem .95rem;border:2px solid color-mix(in srgb,currentColor 18%,transparent);border-radius:8px;color:inherit;text-decoration:none;background:color-mix(in srgb,var(--surface) 96%,currentColor 4%);transition:border-color .15s ease,background .15s ease,transform .15s ease}.post-pager a:hover{border-color:color-mix(in srgb,var(--accent-blue) 48%,transparent);background:var(--accent-blue-softer);transform:translateY(-1px)}.post-pager a:last-child{text-align:right}.post-pager a[aria-disabled]{pointer-events:none;opacity:.42}.post-pager span{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem;color:color-mix(in srgb,currentColor 64%,transparent);font-size:.9rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.post-pager span b{position:relative;top:-.03em;font-size:1.9rem;line-height:.55}.post-pager em{display:inline-flex;align-items:center;min-height:1.15rem;padding:0 .35rem;border:1px solid color-mix(in srgb,var(--accent-blue) 30%,transparent);border-radius:999px;color:var(--accent-blue-strong);font-size:.68rem;font-style:normal;letter-spacing:0;text-transform:none}.post-pager em[hidden]{display:none}.post-pager a:last-child span{justify-content:flex-end}.post-pager strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem}.post-article h1{margin:0 0 .25rem;line-height:1.16;letter-spacing:-.025em}.post-article h1,.post-article h2,.post-article h3,.post-article h4,.post-article h5,.post-article h6{scroll-margin-top:8rem}.post-article h2,.post-article h3,.post-article h4,.post-article h5,.post-article h6{margin-top:2rem}.post-article h2{color:color-mix(in srgb,var(--accent-blue) 42%,var(--text));font-size:1.72rem;line-height:1.14;font-weight:850}.post-article h3{font-size:1.42rem;line-height:1.18;font-weight:830}.post-article h4{font-size:1.12rem;line-height:1.28;font-weight:820}.post-article h5,.post-article h6{color:var(--text-muted);line-height:1.32;font-weight:850;letter-spacing:.02em}.post-article h5{font-size:1rem}.post-article h6{font-size:.92rem;text-transform:uppercase}.post-article p,.post-article li{line-height:1.68}.post-article blockquote{margin:1.35rem 0;padding:.1rem 0 .1rem 1rem;border-left:4px solid color-mix(in srgb,var(--accent-blue) 72%,transparent);color:color-mix(in srgb,var(--text) 76%,transparent)}.post-article blockquote>:last-child{margin-bottom:0}.post-article .task-list-item{list-style:none}.post-article .task-list-item-checkbox{width:1rem;height:1rem;margin:0 .45rem 0 -1.35rem;accent-color:var(--accent-blue);vertical-align:-.13em}.post-article pre{overflow-x:auto;padding:16px;border:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 88%,currentColor 12%)}.post-article hr{width:min(12rem,42%);height:6px;margin:2.35rem auto;border:0;border-radius:999px;background:color-mix(in srgb,currentColor 34%,transparent)}:root[data-theme=dark] .post-article hr{background:color-mix(in srgb,currentColor 48%,transparent)}.post-article mark{padding:.02em .18em;border-radius:4px;background:color-mix(in srgb,#facc15 34%,var(--surface));color:inherit}.post-article code{font-size:.92em}.post-article :not(pre)>code{padding:.12rem .28rem;border-radius:5px;background:color-mix(in srgb,currentColor 9%,transparent)}.post-article .katex{color:color-mix(in srgb,var(--text) 92%,var(--accent-blue) 8%);font-size:1.02em}.post-article .katex-display{overflow-x:auto;overflow-y:hidden;margin:1.35rem 0;padding:.9rem 1rem;border:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 92%,currentColor 4%)}.post-article .katex-display>.katex{display:inline-block;min-width:100%}.post-article table{width:100%;border-collapse:collapse;display:block;overflow-x:auto;margin:1.5rem 0;font-size:.95rem}.post-article th,.post-article td{padding:.55rem .7rem;border:1px solid color-mix(in srgb,currentColor 16%,transparent);vertical-align:top}.post-article th{background:color-mix(in srgb,currentColor 8%,transparent);text-align:left}.post-article tr:nth-child(2n) td{background:color-mix(in srgb,currentColor 3%,transparent)}.related-posts,.file-download,.countdown-widget,.engagement{margin:1.5rem 0;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 94%,currentColor 6%)}.engagement{display:grid;gap:.5rem;padding:.95rem;border-color:color-mix(in srgb,var(--accent-blue) 22%,transparent)}.comment-submit{display:grid;gap:.65rem}.comment-heading{color:var(--accent-blue-strong);font-family:Barlow,Noto Sans TC,Noto Sans JP,system-ui,sans-serif;font-size:1.24rem;font-weight:820;letter-spacing:0;line-height:1.12}.post-article .comment-heading{margin:0}.comment-list{display:grid;gap:.65rem;padding-bottom:.85rem;border-bottom:1px solid color-mix(in srgb,currentColor 12%,transparent)}.comment-list [data-comment-items]{display:grid;gap:.55rem}.comment-item{display:grid;gap:.35rem;padding:.7rem;border:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:7px;background:color-mix(in srgb,var(--surface) 96%,currentColor 4%)}.comment-item header{display:flex;gap:.75rem;align-items:baseline;justify-content:space-between}.comment-item time{color:color-mix(in srgb,currentColor 58%,transparent);font-size:.8rem;font-weight:720}.comment-item p{margin:0}.comment-reply{display:grid;gap:.25rem;margin-top:.25rem;padding:.55rem .65rem;border-left:3px solid color-mix(in srgb,var(--accent-blue) 48%,transparent);border-radius:0 6px 6px 0;background:color-mix(in srgb,var(--accent-blue-softer) 70%,transparent)}.comment-reply strong{color:var(--accent-blue-strong);font-size:.82rem}.comment-submit p{margin:-.3rem 0 0;color:color-mix(in srgb,currentColor 64%,transparent);font-size:.9rem}.comment-submit label{display:grid;gap:.28rem}.comment-field-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.comment-submit label span{color:color-mix(in srgb,currentColor 68%,transparent);font-size:.8rem;font-weight:760}.comment-submit label small{color:color-mix(in srgb,currentColor 55%,transparent);font-size:.74rem}.comment-submit input,.comment-submit textarea{width:100%;box-sizing:border-box;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:7px;background:var(--surface);color:inherit;font:inherit}.comment-submit input{min-height:2.35rem;padding:0 .65rem}.comment-submit textarea{min-height:3.15rem;max-height:16rem;padding:.55rem .65rem;resize:vertical;overflow-y:hidden}.comment-submit-actions{display:flex;gap:.7rem;align-items:center;justify-content:space-between}.comment-submit-actions span{color:color-mix(in srgb,currentColor 62%,transparent);font-size:.85rem}.comment-submit-actions button{min-height:2.35rem;padding:.25rem .85rem;border:1px solid color-mix(in srgb,var(--accent-blue) 34%,transparent);border-radius:7px;background:var(--accent-blue-softer);color:var(--accent-blue-strong);cursor:pointer;font:inherit;font-weight:780}.countdown-widget{display:grid;grid-template-columns:minmax(8rem,.9fr) minmax(0,1.45fr);gap:.52rem;align-items:center;padding:.68rem .72rem;border-color:color-mix(in srgb,var(--accent-blue) 32%,transparent);background:linear-gradient(135deg,color-mix(in srgb,var(--accent-blue) 10%,transparent),transparent 45%),color-mix(in srgb,var(--surface) 94%,currentColor 6%)}.countdown-widget[data-complete=true]{border-color:color-mix(in srgb,currentColor 16%,transparent);background:color-mix(in srgb,var(--surface-muted) 86%,currentColor 14%);opacity:.76}.countdown-widget[data-complete=true] .countdown-head p{color:color-mix(in srgb,currentColor 70%,transparent)}.countdown-widget[data-complete=true] .countdown-unit strong{background:linear-gradient(to bottom,rgb(0 0 0 / 16%),transparent 48%,rgb(255 255 255 / 5%) 49%,rgb(255 255 255 / 0%) 52%),color-mix(in srgb,var(--surface-muted) 82%,black 18%);color:color-mix(in srgb,currentColor 72%,transparent)}.countdown-head{display:grid;gap:.18rem;min-width:0}.countdown-head p{margin:0;color:var(--accent-blue-strong);font-size:clamp(1rem,2.1vw,1.28rem);font-weight:850;line-height:1.05}.countdown-head time{color:var(--text);font-size:clamp(.96rem,1.6vw,1.16rem);font-weight:820;line-height:1.12}.countdown-weekday.is-weekend{color:#d83a2f}.countdown-head span{color:color-mix(in srgb,currentColor 66%,transparent);font-size:.84rem;line-height:1.25}.countdown-units{display:grid;grid-template-columns:repeat(4,max-content);gap:.55rem;justify-content:end;min-width:0}.countdown-unit{display:grid;grid-template-columns:max-content auto;gap:.18rem;align-items:center;justify-content:center;min-width:0}.countdown-unit strong{position:relative;display:grid;place-items:center;min-width:calc(2ch + .32rem);width:max-content;min-height:clamp(1.78rem,3vw,2.35rem);padding:0 .16rem;overflow:hidden;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:8px;background:linear-gradient(to bottom,rgb(0 0 0 / 18%),transparent 48%,rgb(255 255 255 / 6%) 49%,rgb(255 255 255 / 0%) 52%),color-mix(in srgb,var(--surface) 78%,black 22%);color:color-mix(in srgb,var(--text) 92%,var(--accent-blue) 8%);font-family:Barlow Condensed,Barlow,sans-serif;font-size:clamp(1.02rem,2.75vw,1.65rem);font-variant-numeric:tabular-nums;line-height:.9;box-shadow:inset 0 -1px #ffffff14}.countdown-unit strong:after{content:"";position:absolute;inset:50% 0 auto;height:1px;background:#0000005c;box-shadow:0 1px #ffffff14}.countdown-unit strong span{grid-area:1 / 1;will-change:transform,opacity}.countdown-unit strong [data-countdown-next]{transform:translateY(-105%);opacity:0}.countdown-unit strong.is-changing [data-countdown-current]{animation:countdown-roll-out .36s cubic-bezier(.22,.75,.28,1) forwards}.countdown-unit strong.is-changing [data-countdown-next]{animation:countdown-roll-in .36s cubic-bezier(.22,.75,.28,1) forwards}.countdown-unit small{color:color-mix(in srgb,currentColor 64%,transparent);font-size:1.02rem;font-weight:950;letter-spacing:.015em;text-align:left;text-transform:uppercase}@keyframes countdown-roll-out{0%{transform:translateY(0);opacity:1}to{transform:translateY(105%);opacity:0}}@keyframes countdown-roll-in{0%{transform:translateY(-105%);opacity:0}to{transform:translateY(0);opacity:1}}.collapse-block{margin:1.35rem 0;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 96%,currentColor 4%)}.collapse-block summary{display:flex;align-items:center;gap:.5rem;min-height:2.55rem;padding:0 .85rem;cursor:pointer;font-weight:750}.collapse-block summary:before{content:"›";display:inline-block;color:var(--accent-blue-strong);font-size:1.25rem;line-height:1;transform:rotate(0);transition:transform .15s ease}.collapse-block[open] summary:before{transform:rotate(90deg)}.collapse-block-content{padding:.15rem .85rem .85rem;border-top:1px solid color-mix(in srgb,currentColor 10%,transparent)}.collapse-block-content>:last-child{margin-bottom:0}.content-frame,.callout{margin:1.35rem 0;border:1px solid color-mix(in srgb,currentColor 14%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 96%,currentColor 4%)}.content-frame{padding:.95rem}.content-frame h2{margin:0 0 .7rem;color:var(--accent-blue-strong);font-size:1.18rem;line-height:1.2}.content-frame-body>:first-child,.callout-body>:first-child{margin-top:0}.content-frame-body>:last-child,.callout-body>:last-child{margin-bottom:0}.content-frame-caption{margin:.7rem 0 0;color:var(--text-muted);font-size:.88rem;text-align:center}.callout{display:grid;grid-template-columns:.4rem minmax(0,1fr);overflow:hidden}.callout:before{content:"";background:var(--callout-color, var(--accent-blue))}.callout>strong{padding:.78rem .9rem .15rem;color:var(--callout-strong, var(--accent-blue-strong));font-size:.92rem;font-weight:850}.callout-body{grid-column:2;padding:0 .9rem .85rem}.callout-info,.callout-note{--callout-color: #3b82f6;--callout-strong: color-mix(in srgb, #3b82f6 72%, var(--text))}.callout-tip{--callout-color: #22c55e;--callout-strong: color-mix(in srgb, #22c55e 66%, var(--text))}.callout-warning,.callout-danger{--callout-color: #f97316;--callout-strong: color-mix(in srgb, #f97316 72%, var(--text))}.related-posts{border:1px solid color-mix(in srgb,var(--accent-blue) 28%,transparent);background:color-mix(in srgb,var(--surface) 94%,var(--accent-blue) 6%);padding:.95rem}.related-posts-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.related-posts h2{margin:0 0 .75rem;color:var(--accent-blue-strong);font-size:1.1rem;line-height:1.2;letter-spacing:0}.related-posts-head h2{margin:0}.related-posts-head nav{display:inline-flex;flex:0 0 auto;gap:.35rem}.related-posts-head nav a{display:inline-flex;align-items:center;min-height:1.65rem;padding:0 .55rem;border:1px solid color-mix(in srgb,var(--accent-blue) 20%,transparent);border-radius:999px;color:color-mix(in srgb,var(--accent-blue-strong) 78%,currentColor);font-size:.78rem;font-weight:700;text-decoration:none}.related-posts-head nav a:hover{color:var(--accent-blue-strong);border-color:color-mix(in srgb,var(--accent-blue) 42%,transparent)}.related-posts-list{display:flex;gap:.55rem;overflow-x:auto;padding-bottom:.08rem}.related-post-card{display:grid;grid-template-columns:74px minmax(0,1fr);gap:.62rem;flex:0 0 min(20rem,84%);min-width:0;padding:.55rem;border:1px solid color-mix(in srgb,var(--accent-blue) 14%,transparent);border-radius:7px;background:color-mix(in srgb,var(--surface) 96%,var(--accent-blue) 4%);color:inherit;text-decoration:none}.related-post-card:hover{border-color:color-mix(in srgb,var(--accent-blue) 42%,transparent);background:var(--accent-blue-softer)}.related-post-cover{display:block;width:74px;aspect-ratio:4 / 3;overflow:hidden;border-radius:6px;background:linear-gradient(135deg,#7f7f7f2e,#7f7f7f0d),color-mix(in srgb,currentColor 7%,transparent)}.related-post-cover img{display:block;width:100%;height:100%;object-fit:cover}.related-post-copy{display:grid;align-content:center;gap:.2rem;min-width:0}.related-post-card strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem}.related-post-copy>span{display:flex;flex-wrap:wrap;gap:.35rem .6rem;color:color-mix(in srgb,currentColor 64%,transparent);font-size:.84rem;font-weight:600}.related-post-copy>span span:before{content:"/";margin-right:.6rem;opacity:.45}.related-posts-empty{border-style:dashed}.related-posts-empty-text{margin:0;color:color-mix(in srgb,currentColor 62%,transparent);font-size:.92rem;font-weight:600;line-height:1.45}.file-download{display:grid;gap:.65rem;padding:.82rem}.file-download-head,.file-download-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.file-download-list{display:grid;gap:.55rem}.file-download-row{padding:.68rem .72rem;border:1px solid color-mix(in srgb,currentColor 10%,transparent);border-radius:7px;background:var(--surface)}.file-download-row-bundle{border-color:color-mix(in srgb,var(--accent-blue) 32%,transparent);background:var(--surface)}.file-download-copy{min-width:0}.file-download-copy strong{display:block;font-size:1rem}.file-download-copy p{margin:.18rem 0 0;color:color-mix(in srgb,currentColor 76%,transparent);line-height:1.42}.file-download-copy span{display:block;margin-top:.22rem;color:color-mix(in srgb,currentColor 58%,transparent);font-size:.82rem;font-weight:600}.file-download-button{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;min-height:2.25rem;padding:0 .85rem;border:1px solid color-mix(in srgb,var(--accent-blue) 34%,transparent);border-radius:7px;background:var(--accent-blue-softer);color:var(--accent-blue-strong);font-size:.9rem;font-weight:700;text-decoration:none}.file-download-button:hover{border-color:var(--accent-blue);background:var(--accent-blue-soft)}.file-download-row-bundle .file-download-button{background:var(--accent-blue-soft)}.web-link{display:grid;grid-template-columns:2.7rem minmax(0,1fr);gap:.72rem;align-items:center;margin:1.35rem 0;padding:.72rem .82rem;border:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 96%,currentColor 4%);color:inherit;text-decoration:none}.web-link:hover{border-color:color-mix(in srgb,var(--accent-blue) 36%,transparent);background:var(--accent-blue-softer)}.web-link-icon{display:inline-grid;place-items:center;width:2.7rem;height:2.7rem;overflow:hidden;border-radius:8px;background:color-mix(in srgb,currentColor 10%,transparent);color:var(--accent-blue-strong);font-size:.82rem;font-weight:800}.web-link-icon img{width:1.8rem;height:1.8rem;object-fit:contain}.web-link-copy{display:grid;gap:.12rem;min-width:0}.web-link-copy strong,.web-link-copy span,.web-link-copy small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.web-link-copy strong{color:var(--accent-blue-strong);font-size:1rem}.web-link-copy span{color:color-mix(in srgb,currentColor 76%,transparent);font-size:.92rem}.web-link-copy small{color:color-mix(in srgb,currentColor 56%,transparent);font-size:.8rem;font-weight:600}.web-link-github .web-link-icon{background:#24292f;color:#fff}.web-link-youtube .web-link-icon,.web-link-youtu .web-link-icon{background:#f03;color:#fff}.web-link-threads .web-link-icon{background:#111;color:#fff}@media(max-width:760px){.post-header{top:49px;padding-top:.58rem}.blog-shell{display:block}.post-sidebar{position:static;max-height:none;margin-bottom:1rem;padding:0 0 1rem;border-right:0;border-bottom:1px solid color-mix(in srgb,currentColor 12%,transparent)}.side-rail{position:static;max-height:none;padding:0 0 1rem;border-right:0;border-bottom:1px solid color-mix(in srgb,currentColor 12%,transparent)}.post-sidebar.side-rail{display:block;overflow:visible}.post-sidebar-scroll{overflow:visible;padding-right:0}.post-sidebar nav{display:flex;max-width:none;margin:0;padding:0 0 .2rem;overflow-x:auto}.post-toc nav{display:grid;padding:0;overflow:visible}.post-toc{display:none}.sidebar-filter-summary{flex:0 0 auto}.sidebar-post{min-width:10rem;padding:.42rem .55rem;border-left:0;border-bottom:3px solid transparent;border-radius:7px 7px 0 0}.sidebar-post[data-filtered=muted],.post-calendar{display:none}.post-article{font-size:.98rem}.post-header{gap:.5rem;margin-bottom:.65rem;margin-right:-14px;margin-left:-14px;padding:.58rem 14px .5rem}.post-header-back{min-width:2.25rem;min-height:1.75rem;padding:0 .42rem;font-size:.85rem}.post-header-back span{display:none}.post-header-outline-button{display:inline-flex}.post-floating-outline{position:sticky;top:108px;z-index:9;display:block;box-sizing:border-box;overflow:hidden;width:calc(100% + 28px);max-height:min(48vh,22rem);margin:-.65rem -14px .75rem;padding:.75rem 14px;border-top:1px solid color-mix(in srgb,currentColor 12%,transparent);border-bottom:1px solid color-mix(in srgb,currentColor 12%,transparent);border-radius:0;background:color-mix(in srgb,var(--page-bg) 94%,transparent);backdrop-filter:blur(12px);opacity:1;transform:translateY(0);transition:max-height .16s ease,opacity .13s ease,padding .16s ease,transform .16s ease}.post-floating-outline[hidden]{display:block;max-height:0;padding-top:0;padding-bottom:0;border-width:0;opacity:0;pointer-events:none;transform:translateY(-.35rem)}.post-floating-outline.is-jump-closing{transition:none}.post-floating-outline h2{margin:0;font-size:1.25rem;letter-spacing:0}.post-floating-outline nav{max-height:min(42vh,18rem);overflow:auto}.comment-field-row{grid-template-columns:1fr}.post-header h1{font-size:1.3rem;line-height:1.08}.post-article>h1{font-size:1.5rem;line-height:1.12}.post-article>h2{font-size:1.38rem;line-height:1.16}.post-article>h3{font-size:1.18rem;line-height:1.22}.post-article>h4{font-size:1.04rem;line-height:1.26}.post-article>h2,.post-article>h3,.post-article>h4,.post-article>h5,.post-article>h6{margin-top:1.45rem}.post-article h1,.post-article h2,.post-article h3,.post-article h4,.post-article h5,.post-article h6{scroll-margin-top:6.5rem}.post-meta{font-size:.78rem;line-height:1.2}.post-tags{margin-bottom:1.1rem}.post-article p,.post-article li{line-height:1.52}.file-download-head,.file-download-row{align-items:flex-start;gap:.75rem}.file-download-button{width:auto}.related-posts{padding:.75rem}.countdown-widget{grid-template-columns:minmax(0,.7fr) minmax(0,1.3fr);gap:.28rem;padding:.48rem}.countdown-head{gap:.08rem}.countdown-head p{font-size:.9rem}.countdown-head time{font-size:.9rem;line-height:1.08}.countdown-head span{font-size:.75rem;line-height:1.15}.countdown-units{grid-template-columns:repeat(4,max-content);gap:.42rem;justify-content:end}.countdown-unit{grid-template-columns:max-content auto;gap:.14rem;justify-content:center}.countdown-unit strong{min-width:calc(2ch + .24rem);width:max-content;min-height:1.52rem;padding:0 .12rem;border-radius:6px;font-size:clamp(.86rem,5vw,1.08rem)}.countdown-unit small{font-size:.92rem;line-height:1;text-align:left}.related-posts-head{align-items:flex-start;flex-direction:column;gap:.55rem}.related-post-card{grid-template-columns:64px minmax(0,1fr);flex-basis:88%}.related-post-cover{width:64px}}@media(max-width:620px){.post-pager{margin-top:2.2rem;grid-template-columns:1fr;gap:.65rem}.post-pager a:last-child{text-align:left}.post-pager a:last-child span{justify-content:flex-start}}
