:root{--c-bg: #ffffff;--c-text: #171717;--c-text-light: #737373;--c-primary: #2563eb;--c-primary-text: #2563eb;--c-primary-subtle: rgba(37, 99, 235, .1);--c-primary-border: rgba(37, 99, 235, .2);--c-primary-hover: rgba(37, 99, 235, .18);--c-border: #e5e5e5;--c-fill-subtle: rgba(128, 128, 128, .1);--c-fill-hover: rgba(128, 128, 128, .15);--c-code-header-bg: var(--c-fill-subtle);--c-code-inline-bg: rgba(175, 184, 193, .2);--c-code-inline-text: #24292f;--shiki-bg: #f8f9fa;--font-sans: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono: "JetBrains Mono", "DM Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--shiki-light: #24292e;--shiki-light-bg: #ffffff;--shiki-light-font-style: normal;--shiki-light-font-weight: normal;--shiki-light-text-decoration: none}html.dark{--c-bg: #121212;--c-text: #e0e0e0;--c-text-light: #a0a0a0;--c-primary: #3b82f6;--c-primary-text: #60a5fa;--c-primary-subtle: rgba(96, 165, 250, .15);--c-primary-border: rgba(96, 165, 250, .25);--c-primary-hover: rgba(96, 165, 250, .25);--c-border: #2e2e2e;--c-code-inline-bg: rgba(110, 118, 129, .4);--c-code-inline-text: #c9d1d9;--shiki-bg: #0a0a0a;--shiki-dark: inherit;--shiki-dark-bg: inherit;--shiki-dark-font-style: inherit;--shiki-dark-font-weight: inherit;--shiki-dark-text-decoration: inherit}html{scroll-padding-top:5rem}body{background-color:var(--c-bg);color:var(--c-text);font-family:var(--font-sans);line-height:1.7;transition:background-color .2s,color .2s;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);padding-bottom:env(safe-area-inset-bottom)}.anchor-link{display:none}@media(min-width:768px){.anchor-link{display:block}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background-color:#a3a3a3;border-radius:3px}html.dark ::-webkit-scrollbar-thumb{background-color:#404040}::-webkit-scrollbar-thumb:hover{background:#737373}html.dark ::-webkit-scrollbar-thumb:hover{background:#525252}img{backface-visibility:hidden;transform:translateZ(0);will-change:transform}html.dark img{filter:brightness(.85);transition:filter .3s ease-out}html.dark img:hover{filter:brightness(1)}.code-container pre{margin:0;border:none;border-radius:0;padding:1rem;max-height:600px;overflow:auto;font-family:var(--font-mono);line-height:1.6;font-variant-ligatures:common-ligatures;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;background-color:transparent!important;font-size:.875rem}.shiki{background-color:transparent!important}.shiki span{color:var(--shiki-light)}html.dark .shiki span{color:var(--shiki-dark)}.code-container{position:relative;margin:1.5em 0;border-radius:.75rem;overflow:hidden;background-color:var(--shiki-bg);border:1px solid var(--c-border)}.code-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background-color:var(--c-code-header-bg);border-bottom:1px solid var(--c-border);font-family:var(--font-mono);font-size:.85rem;line-height:1}.mac-buttons{display:flex;gap:.5rem}.mac-button{width:.75rem;height:.75rem;border-radius:50%}.mac-button.close{background-color:#ff5f56}.mac-button.minimize{background-color:#ffbd2e}.mac-button.maximize{background-color:#27c93f}.code-actions{display:flex;align-items:center;gap:.75rem}.lang-badge{color:var(--c-text-light);font-weight:600;text-transform:uppercase;font-size:.75rem;opacity:.8}.copy-btn{background:transparent;border:none;color:var(--c-text-light);cursor:pointer;padding:.25rem;border-radius:.25rem;transition:all .2s;display:flex;align-items:center;gap:.25rem;font-size:.75rem}.copy-btn:hover{background-color:var(--c-fill-hover);color:var(--c-primary)}html body .prose :where(code):not(:where(pre code)){padding:.2em .4em;margin:0;font-size:.875em;background-color:var(--c-code-inline-bg);border-radius:6px;font-family:var(--font-mono)!important;white-space:break-spaces;word-break:break-word;font-weight:400;color:var(--c-code-inline-text);vertical-align:baseline}html body .prose :where(code):not(:where(pre code)):before,html body .prose :where(code):not(:where(pre code)):after{content:none!important}html.dark img[src*="error.svg"]{content:url(/error-dark.svg)}.astro-route-announcer{position:absolute;left:0;top:0;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap;width:1px;height:1px}
