:root{--accent: #2337ff;--accent-dark: #000d8a;--black: 15, 18, 25;--gray: 96, 115, 159;--gray-light: 229, 233, 240;--gray-dark: 34, 41, 57;--gray-gradient: rgba(var(--gray-light), 50%), #fff;--box-shadow: 0 2px 6px rgba(var(--gray), 25%), 0 8px 24px rgba(var(--gray), 33%), 0 16px 32px rgba(var(--gray), 33%)}@font-face{font-family:Atkinson;src:url(/CSBlog/fonts/atkinson-regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Atkinson;src:url(/CSBlog/fonts/atkinson-bold.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans SC,PingFang SC,Microsoft YaHei,Hiragino Sans GB,sans-serif;margin:0;padding:0;text-align:left;background:linear-gradient(var(--gray-gradient)) no-repeat;background-size:100% 600px;word-wrap:break-word;overflow-wrap:break-word;color:rgb(var(--gray-dark));font-size:16px;line-height:1.6}main{max-width:calc(100% - 2em);margin:auto;padding:3em 1em}h1,h2,h3,h4,h5,h6{margin:0 0 .5rem;color:rgb(var(--black));line-height:1.2}h1{font-size:3.052em}h2{font-size:2.441em}h3{font-size:1.953em}h4{font-size:1.563em}h5{font-size:1.25em}strong,b{font-weight:700}a,a:hover{color:var(--accent)}p{margin-bottom:1em}.prose p{margin-bottom:1.25em}textarea{width:100%;font-size:16px}input{font-size:16px}table{width:100%}img{max-width:100%;height:auto;border-radius:8px}code{padding:2px 6px;background-color:rgba(var(--gray-light),.6);border-radius:6px;font-family:Cascadia Code,Fira Code,JetBrains Mono,ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace;font-size:.85em}pre{position:relative;padding:1em;border-radius:0 0 8px 8px;border:1px solid rgb(var(--gray-light));border-top:none;font-size:.875rem;line-height:1.45;overflow-x:auto;margin:0}pre>code{all:unset;font-family:Cascadia Code,Fira Code,JetBrains Mono,ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,Liberation Mono,monospace}.code-block{margin-bottom:1em;border-radius:8px;overflow:hidden;border:1px solid rgb(var(--gray-light))}.code-block pre{border:none;border-radius:0}.code-bar{display:flex;align-items:center;justify-content:space-between;padding:.4em .75em;background:rgba(var(--gray-light),.35);border-bottom:1px solid rgb(var(--gray-light));font-size:.8rem;min-height:1.8em}.code-lang{font-weight:600;color:rgb(var(--gray-dark));user-select:none}.code-bar .copy-btn{background:none;border:1px solid transparent;border-radius:6px;color:rgb(var(--gray));cursor:pointer;padding:.2em;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s}.code-bar .copy-btn:hover{background:rgba(var(--gray-light),.8);color:rgb(var(--gray-dark));border-color:rgb(var(--gray-light))}.code-bar .copy-btn.copied{color:#22c55e}blockquote{border-left:4px solid var(--accent);padding:0 0 0 20px;margin:0;font-size:1em;color:rgb(var(--gray))}hr{border:none;border-top:1px solid rgb(var(--gray-light))}@media(max-width:768px){body{font-size:15px}main{padding:1em}h1{font-size:1.75em}h2{font-size:1.5em}h3{font-size:1.25em}pre{padding:.75em;font-size:.8rem;border-radius:0 0 6px 6px}.code-block{border-radius:6px}blockquote{padding-left:12px;font-size:.95em}}.sr-only{border:0;padding:0;margin:0;position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px 1px 1px 1px);clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}:root{--pagefind-ui-scale: .85;--pagefind-ui-primary: var(--accent);--pagefind-ui-text: rgb(var(--gray-dark));--pagefind-ui-background: #fff;--pagefind-ui-border: rgb(var(--gray-light));--pagefind-ui-border-width: 1px;--pagefind-ui-border-radius: 8px;--pagefind-ui-font: inherit}footer[data-astro-cid-sz7xmlte]{padding:2em 1em 6em;background:linear-gradient(var(--gray-gradient)) no-repeat;color:rgb(var(--gray));text-align:center}.social-links[data-astro-cid-sz7xmlte]{display:flex;justify-content:center;gap:1em;margin-top:1em}.social-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]{text-decoration:none;color:rgb(var(--gray))}.social-links[data-astro-cid-sz7xmlte] a[data-astro-cid-sz7xmlte]:hover{color:rgb(var(--gray-dark))}a[data-astro-cid-eimmu3lg]{display:inline-block;text-decoration:none}a[data-astro-cid-eimmu3lg].active{font-weight:bolder;text-decoration:underline}header[data-astro-cid-3ef6ksr2]{margin:0;padding:0 1em;background:#fff;box-shadow:0 2px 8px rgba(var(--black),5%)}h2[data-astro-cid-3ef6ksr2]{margin:0;font-size:1em}h2[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2],h2[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2].active{text-decoration:none}nav[data-astro-cid-3ef6ksr2]{display:flex;align-items:center;justify-content:space-between}nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{padding:1em .5em;color:var(--black);border-bottom:4px solid transparent;text-decoration:none}nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2].active{text-decoration:none;border-bottom-color:var(--accent)}.social-links[data-astro-cid-3ef6ksr2],.social-links[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{display:flex}@media(max-width:768px){.social-links[data-astro-cid-3ef6ksr2]{display:none}nav[data-astro-cid-3ef6ksr2] a[data-astro-cid-3ef6ksr2]{padding:.75em .4em;font-size:.9rem}}.search-modal-overlay{display:none;position:fixed;inset:0;z-index:1000;background:#0006;justify-content:center;align-items:flex-start;padding-top:10vh}.search-modal-overlay.active{display:flex}.search-modal{background:#fff;border-radius:12px;width:90%;max-width:560px;max-height:70vh;overflow-y:auto;box-shadow:0 16px 48px #0003;padding:1rem}
