:root{--color-bg: #ffffff;--color-bg-soft: #f8fafc;--color-text: #0f172a;--color-text-soft: #64748b;--color-border: #e2e8f0;--color-accent: #d0021b;--color-accent-soft: #fef2f2;--sidebar-w: 16rem;--hx-radius: 8px;--hx-shadow-lg: 0 10px 30px rgba(0,0,0,.1);--code-bg: #f6f8fa;--code-text: #24292f;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif}html.dark{--color-bg: #0f172a;--color-bg-soft: #1e293b;--color-text: #f1f5f9;--color-text-soft: #94a3b8;--color-border: #334155;--color-accent-soft: #1f1014;--code-bg: #161b22;--code-text: #e6edf3}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--color-bg);color:var(--color-text);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:inherit;text-decoration:none;transition:color .15s}a:hover{color:var(--color-accent)}img{max-width:100%;height:auto}code{font-family:ui-monospace,SFMono-Regular,JetBrains Mono,Cascadia Code,Menlo,monospace}button{font-family:inherit}.fade-in{animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.modal-bg{position:fixed;inset:0;background:#00000080;display:none;align-items:center;justify-content:center;z-index:200;backdrop-filter:blur(4px)}.modal-bg.show{display:flex}.modal{background:var(--color-bg);border-radius:12px;padding:24px;max-width:480px;width:calc(100% - 32px);position:relative;box-shadow:var(--hx-shadow-lg)}.modal h3{margin-bottom:12px;font-size:18px;font-weight:600}.modal-search{background:var(--color-bg);border-radius:12px;padding:20px;max-width:640px;width:calc(100% - 32px)}.search-input{width:100%;padding:12px 16px;font-size:16px;border:1px solid var(--color-border);border-radius:8px;background:var(--color-bg-soft);color:var(--color-text)}.search-results{margin-top:16px;max-height:60vh;overflow-y:auto}.search-results a{display:block;padding:10px 12px;border-radius:8px;border:1px solid var(--color-border);margin-bottom:8px;transition:border-color .15s,background .15s}.search-results a:hover{border-color:var(--color-accent);background:var(--color-bg-soft)}.tag{display:inline-block;padding:2px 10px;font-size:12px;background:var(--color-bg-soft);border:1px solid var(--color-border);border-radius:999px;color:var(--color-text-soft)}a.tag:hover{border-color:var(--color-accent);color:var(--color-accent)}.card{display:block;padding:16px;border:1px solid var(--color-border);border-radius:12px;background:var(--color-bg);transition:all .2s}.card:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--hx-shadow-lg)}#z-sidebar-bgmask{position:fixed;inset:0;background:#00000080;z-index:39;display:none}#z-sidebar-bgmask.open{display:block}#toggle-sidebar{position:fixed;top:12px;left:12px;width:44px;height:44px;border:1px solid var(--color-border);background:var(--color-bg);border-radius:8px;font-size:20px;z-index:38;display:flex;align-items:center;justify-content:center;cursor:pointer}@media(min-width:768px){#toggle-sidebar{display:none}}.prose{color:var(--color-text)}.prose h1{font-size:2.25rem;font-weight:700;margin:1.5em 0 .5em;line-height:1.2}.prose h2{font-size:1.5rem;font-weight:600;margin:2em 0 .5em;padding-bottom:.3em;border-bottom:1px solid var(--color-border)}.prose h3{font-size:1.25rem;font-weight:600;margin:1.5em 0 .5em}.prose h4{font-size:1.1rem;font-weight:600;margin:1.25em 0 .5em}.prose p{margin:1em 0}.prose ul,.prose ol{padding-left:1.5em;margin:1em 0}.prose li{margin:.4em 0}.prose li::marker{color:var(--color-text-soft)}.prose strong{font-weight:600;color:var(--color-text)}.prose em{font-style:italic}.prose a{color:var(--color-accent);border-bottom:1px dotted var(--color-accent)}.prose a:hover{border-bottom-style:solid}.prose hr{border:none;border-top:1px dashed var(--color-border);margin:2em 0}.prose code{background:var(--code-bg);color:var(--code-text);padding:2px 6px;border-radius:4px;font-size:.875em;border:1px solid var(--color-border);font-weight:500}.prose pre{background:var(--code-bg)!important;padding:0!important;border-radius:var(--hx-radius);overflow:hidden;margin:1.25em 0;border:1px solid var(--color-border);position:relative}.prose pre code{background:transparent;border:none;padding:0;color:inherit;font-size:.875em;font-weight:400}.prose pre.astro-code{display:block;padding:16px 20px!important;overflow-x:auto;line-height:1.6;-moz-tab-size:2;-o-tab-size:2;tab-size:2;counter-reset:line}.prose pre.astro-code code{display:block;min-width:100%}html.dark .prose pre.astro-code,html.dark .prose pre.astro-code span{color:var(--shiki-dark)!important;background-color:var(--shiki-dark-bg)!important;font-style:var(--shiki-dark-font-style)!important;font-weight:var(--shiki-dark-font-weight)!important;-webkit-text-decoration:var(--shiki-dark-text-decoration)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.prose pre.astro-code[data-line-numbers]{counter-reset:line}.prose pre.astro-code[data-line-numbers]>code>[data-line]:before{counter-increment:line;content:counter(line);display:inline-block;width:2rem;margin-right:1rem;text-align:right;color:var(--color-text-soft);border-right:1px solid var(--color-border);padding-right:.5rem}.prose blockquote{border-left:4px solid var(--color-accent);padding:.75em 1em;margin:1.5em 0;color:var(--color-text-soft);background:var(--color-accent-soft);border-radius:0 8px 8px 0;font-style:normal}.prose blockquote p{margin:.5em 0}.prose blockquote p:first-child{margin-top:0}.prose blockquote p:last-child{margin-bottom:0}.prose table{border-collapse:collapse;width:100%;margin:1.5em 0;font-size:.95em;border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.prose th,.prose td{border:1px solid var(--color-border);padding:8px 14px;text-align:left}.prose th{background:var(--color-bg-soft);font-weight:600}.prose tbody tr:nth-child(2n){background:var(--color-bg-soft)}.prose img{border-radius:8px;margin:1.5em auto;display:block;box-shadow:0 4px 12px #0000000d}.prose ul li::marker{content:"•";color:var(--color-accent)}.prose kbd{display:inline-block;padding:2px 6px;font-family:ui-monospace,monospace;font-size:.85em;color:var(--color-text);background:var(--color-bg-soft);border:1px solid var(--color-border);border-bottom-width:2px;border-radius:4px;font-weight:600}.prose mark{background:#fef08a;color:#713f12;padding:2px 4px;border-radius:3px}html.dark .prose mark{background:#713f12;color:#fef08a}.code-block-wrapper{position:relative}.code-block-wrapper .copy-btn{position:absolute;top:8px;right:8px;padding:4px 10px;background:#ffffff1a;color:var(--code-text);border:1px solid var(--color-border);border-radius:4px;font-size:11px;cursor:pointer;opacity:0;transition:opacity .15s}html.dark .code-block-wrapper .copy-btn{color:#e6edf3;background:#ffffff0d}.code-block-wrapper:hover .copy-btn{opacity:1}.code-block-wrapper .copy-btn:hover{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.code-block-wrapper .copy-btn.copied{background:#22c55e;color:#fff;border-color:#22c55e}.code-block-wrapper .code-lang-tag{position:absolute;top:6px;left:12px;font-size:10px;font-weight:600;letter-spacing:.05em;color:var(--color-text-soft);text-transform:uppercase;background:var(--color-bg-soft);padding:2px 6px;border-radius:3px;border:1px solid var(--color-border);pointer-events:none}:root{--hx-accent: #d0021b;--hx-accent-soft: rgba(208, 2, 27, .1);--hx-bg: #ffffff;--hx-bg-soft: #f5f5f7;--hx-text: #1d1d1f;--hx-text-soft: #6e6e73;--hx-border: #e5e5e7;--hx-shadow: 0 2px 8px rgba(0, 0, 0, .08);--hx-shadow-lg: 0 4px 16px rgba(0, 0, 0, .12)}.dark{--hx-bg: #1a1a1a;--hx-bg-soft: #2a2a2a;--hx-text: #f0f0f0;--hx-text-soft: #a0a0a0;--hx-border: #383838;--hx-shadow: 0 2px 8px rgba(0, 0, 0, .3);--hx-shadow-lg: 0 4px 16px rgba(0, 0, 0, .4)}@media(max-width:767px){body{padding-top:56px;padding-bottom:64px;background:var(--hx-bg)}main{padding-bottom:16px}body.dark{--hx-bg: #1a1a1a}}#scroll-progress{position:fixed;top:0;left:0;height:3px;background:var(--hx-accent);width:0%;z-index:60;transition:width 80ms linear;pointer-events:none}.mobile-header{position:fixed;top:0;left:0;right:0;height:56px;background:var(--hx-bg);border-bottom:1px solid var(--hx-border);z-index:50;display:flex;align-items:center;justify-content:space-between;padding:0 16px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffeb}.dark .mobile-header{background:#1a1a1aeb}.mobile-header .logo{font-size:16px;font-weight:700;color:var(--hx-text);text-decoration:none;display:flex;align-items:center;gap:6px}.mobile-header .logo-dot{width:8px;height:8px;background:var(--hx-accent);border-radius:50%}.mobile-header .actions{display:flex;align-items:center;gap:4px}.mobile-header .icon-btn{width:40px;height:40px;border-radius:8px;background:transparent;border:none;color:var(--hx-text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;-webkit-tap-highlight-color:transparent}.mobile-header .icon-btn:active{background:var(--hx-accent-soft)}@media(min-width:768px){.mobile-header{display:none!important}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(64px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--hx-bg);border-top:1px solid var(--hx-border);z-index:50;display:grid;grid-template-columns:repeat(5,1fr);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#ffffffeb}.dark .bottom-nav{background:#1a1a1aeb}.bottom-nav .item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:var(--hx-text-soft);font-size:11px;font-weight:500;min-height:48px;-webkit-tap-highlight-color:transparent;border:none;background:none;cursor:pointer;padding:0;position:relative}.bottom-nav .item .icon{font-size:22px;line-height:1}.bottom-nav .item.active{color:var(--hx-accent)}.bottom-nav .item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--hx-accent);border-radius:0 0 2px 2px}@media(min-width:768px){.bottom-nav{display:none!important}}#back-to-top{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));right:16px;width:44px;height:44px;border-radius:50%;background:var(--hx-accent);color:#fff;border:none;font-size:20px;z-index:40;display:flex;align-items:center;justify-content:center;box-shadow:var(--hx-shadow-lg);cursor:pointer;transition:opacity .2s,transform .2s;-webkit-tap-highlight-color:transparent}#back-to-top.hidden{opacity:0;transform:translateY(20px);pointer-events:none}@media(min-width:768px){#back-to-top{display:none!important}}.article-toc{position:fixed;top:72px;right:12px;width:200px;max-height:calc(100vh - 200px);overflow-y:auto;background:var(--hx-bg);border:1px solid var(--hx-border);border-radius:12px;padding:12px;font-size:12px;box-shadow:var(--hx-shadow);z-index:30;display:none}@media(min-width:1024px){.article-toc{display:block}}.article-toc h4{margin:0 0 8px;font-size:11px;text-transform:uppercase;color:var(--hx-text-soft);letter-spacing:.5px}.article-toc ul{list-style:none;margin:0;padding:0}.article-toc li{margin:4px 0}.article-toc a{color:var(--hx-text-soft);text-decoration:none;display:block;padding:4px 6px;border-radius:4px;line-height:1.4}.article-toc a:hover,.article-toc a.active{background:var(--hx-accent-soft);color:var(--hx-accent)}.article-toc .h3{padding-left:16px;font-size:11px}@media(max-width:767px){.article-toc{top:64px;right:8px;left:8px;width:auto;max-height:60vh}.article-toc:not(.open){display:none}}.toc-toggle{display:none;position:fixed;top:64px;right:8px;width:36px;height:36px;border-radius:50%;background:var(--hx-bg);border:1px solid var(--hx-border);font-size:16px;z-index:30;box-shadow:var(--hx-shadow);cursor:pointer;-webkit-tap-highlight-color:transparent}@media(max-width:767px){.toc-toggle{display:flex;align-items:center;justify-content:center}}@media(max-width:767px){.prose{font-size:16px!important;line-height:1.75!important}.prose h1{font-size:24px!important;line-height:1.3!important}.prose h2{font-size:20px!important;line-height:1.35!important;margin-top:32px!important;padding-top:16px;border-top:1px solid var(--hx-border)}.prose h3{font-size:17px!important}.prose p{margin:14px 0!important}.prose pre{overflow-x:auto!important;-webkit-overflow-scrolling:touch;font-size:13px!important;border-radius:8px!important;margin:16px -16px!important;padding:14px!important}.prose :not(pre)>code{font-size:13px!important;word-break:break-word}.prose table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.prose blockquote{border-left:3px solid var(--hx-accent)!important;padding:8px 12px!important;margin:16px 0!important;background:var(--hx-accent-soft);border-radius:0 8px 8px 0}.tag{font-size:11px!important;padding:2px 6px!important}}@media(max-width:767px){.grid.grid-cols-1.md\\:grid-cols-2{gap:12px!important}.card,a.block[class*=rounded]{padding:14px!important}}@media(max-width:767px){#z-sidebar{position:fixed!important;top:0!important;left:0!important;width:100%!important;max-width:320px!important;height:100vh!important;z-index:100!important;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--hx-shadow-lg)}#z-sidebar.open{transform:translate(0)}#z-sidebar-bgmask{position:fixed!important;inset:0!important;background:#0006!important;z-index:99!important;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}#z-sidebar-bgmask.open{display:block!important}}.hx-toast{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%) translateY(20px);background:var(--hx-text);color:var(--hx-bg);padding:10px 18px;border-radius:24px;font-size:14px;z-index:200;opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;box-shadow:var(--hx-shadow-lg);max-width:80vw;text-align:center}.hx-toast.show{opacity:1;transform:translate(-50%) translateY(0)}
