@charset "UTF-8";:root{--bg:#f8f9fa;--bg-surface:#ffffff;--bg-subtle:#f1f3f5;--bg-code:#f1f3f5;--text:#1a1a2e;--text-2:#4a4a6a;--text-3:#8888a8;--accent:#5046e5;--accent-light:#ede9fe;--border:#e2e4e9;--border-2:#c8cad2;--container:740px;--radius:6px;--radius-lg:12px;--font:'Inter', system-ui, -apple-system, sans-serif;--font-mono:'Fira Code', 'Cascadia Code', ui-monospace, monospace;--ease:cubic-bezier(0.4, 0, 0.2, 1);--ease-spring:cubic-bezier(0.34, 1.56, 0.64, 1)}html.dark{--bg:#0f1117;--bg-surface:#161b27;--bg-subtle:#1e2433;--bg-code:#1a1e2e;--text:#e8eaf0;--text-2:#9da3b4;--text-3:#5c6375;--accent:#7c6dfa;--accent-light:#2a2250;--border:#252b3b;--border-2:#353d52}*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;min-height:100vh;display:flex;flex-direction:column;transition:background .25s var(--ease),color .25s var(--ease)}a{color:var(--accent);text-decoration:none;transition:opacity .15s var(--ease)}a:hover{opacity:.75}img{max-width:100%;height:auto;display:block}.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem;width:100%}.main-content{flex:1;padding:3rem 0 4rem}.header{position:sticky;top:0;z-index:100;background:var(--bg-surface);border-bottom:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.header .container{display:flex;align-items:center;justify-content:space-between;height:56px}.logo{font-size:1rem;font-weight:700;letter-spacing:-.02em;color:var(--text);border-bottom:2px solid var(--accent);padding-bottom:1px}.logo:hover{opacity:1}.nav .menu{display:flex;list-style:none;gap:1.5rem}.nav .menu a{font-size:.85rem;font-weight:500;color:var(--text-2);letter-spacing:.01em}.nav .menu a:hover{color:var(--text);opacity:1}.nav .menu a.active{color:var(--accent);font-weight:600;position:relative}.nav .menu a.active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--accent);border-radius:2px}.header-actions{display:flex;align-items:center;gap:.25rem}.icon-btn{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:var(--radius);background:0 0;color:var(--text-2);cursor:pointer;transition:background .15s var(--ease),color .15s var(--ease)}.icon-btn:hover{background:var(--bg-subtle);color:var(--text)}.social-icon-btn{color:var(--text-3);text-decoration:none}.social-icon-btn:hover{color:var(--text);opacity:1;background:var(--bg-subtle)}.social-icon-btn svg{display:block}#search-btn{margin-left:.25rem;border-left:1px solid var(--border);border-radius:0 var(--radius)var(--radius)0;padding-left:.6rem}#search-btn:hover{border-radius:var(--radius)}.page-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.page-header h1{font-size:1.4rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.post-list{display:flex;flex-direction:column;gap:0}.post-item{display:flex;align-items:baseline;gap:1rem;padding:.85rem 0;border-bottom:1px solid var(--border);transition:background .15s}.post-item-date{flex-shrink:0;font-family:var(--font-mono);font-size:.75rem;color:var(--text-3);width:80px}.post-item-title{font-size:.95rem;font-weight:500;color:var(--text);transition:color .15s}.post-item:hover .post-item-title{color:var(--accent)}.post-item-tags{display:flex;gap:.4rem;margin-left:auto;flex-shrink:0}.tag-chip{font-size:.7rem;font-weight:500;color:var(--text-3);background:var(--bg-subtle);border:1px solid var(--border);border-radius:4px;padding:.1rem .45rem;letter-spacing:.01em}.hero{margin-bottom:2.5rem}.hero h1{font-size:1.6rem;font-weight:700;letter-spacing:-.03em;color:var(--text);margin-bottom:.4rem}.hero .subtitle{font-size:.9rem;color:var(--text-2)}.post-header{margin-bottom:2.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.post-header .post-title{font-size:1.9rem;font-weight:800;letter-spacing:-.03em;color:var(--text);margin-bottom:.75rem;line-height:1.2}.post-meta{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.8rem;color:var(--text-3);font-family:var(--font-mono)}.post-meta .sep{color:var(--border-2)}.post-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.75rem}.post-tags a{font-size:.72rem;font-weight:500;color:var(--accent);background:var(--accent-light);border-radius:4px;padding:.15rem .5rem;letter-spacing:.01em}.post-tags a:hover{opacity:.8}.lang-tabs{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.lang-tab{display:inline-block;padding:.3rem .85rem;border-radius:var(--radius);border:1px solid var(--border);font-size:.78rem;font-weight:600;letter-spacing:.02em;color:var(--text-3);background:var(--bg-surface);text-decoration:none;transition:border-color .15s,color .15s,background .15s}.lang-tab:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-light);opacity:1}.lang-tab--active{color:var(--accent);border-color:var(--accent);background:var(--accent-light);cursor:default;pointer-events:none}.post-content{font-size:.95rem;line-height:1.75;color:var(--text-2)}.post-content>*+*{margin-top:1.25rem}.post-content h1,.post-content h2,.post-content h3,.post-content h4{color:var(--text);font-weight:700;letter-spacing:-.025em;line-height:1.25;margin-top:2.5rem;margin-bottom:.75rem}.post-content h2{font-size:1.35rem;padding-bottom:.4rem;border-bottom:1px solid var(--border)}.post-content h3{font-size:1.1rem}.post-content h4{font-size:.95rem}.post-content p{margin:0}.post-content p+p{margin-top:1rem}.post-content a{color:var(--accent);text-decoration:underline;text-decoration-color:color-mix(in srgb,var(--accent) 40%,transparent);text-underline-offset:3px}.post-content a:hover{opacity:1;text-decoration-color:var(--accent)}.post-content ul,.post-content ol{padding-left:1.5rem}.post-content li+li{margin-top:.35rem}.post-content hr{border:none;border-top:1px solid var(--border);margin:2rem 0}.post-content blockquote{margin:1.5rem 0;padding:.75rem 1.25rem;border-left:3px solid var(--accent);background:var(--accent-light);border-radius:0 var(--radius)var(--radius)0;font-style:italic;color:var(--text-2)}.post-content blockquote p{color:inherit}.post-content :not(pre)>code{font-family:var(--font-mono);font-size:.82em;background:var(--bg-code);color:var(--accent);border:1px solid var(--border);border-radius:4px;padding:.1em .35em}.post-content pre{margin:1.5rem 0;border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;position:relative}.post-content pre>.chroma,.post-content .chroma{margin:0;padding:1.1rem 1.25rem;overflow-x:auto;font-family:var(--font-mono);font-size:.82rem;line-height:1.6;border-radius:0}.post-content figure{margin:2rem 0}.post-content figure img{border-radius:var(--radius-lg);border:1px solid var(--border);width:100%}.post-content figcaption{margin-top:.5rem;text-align:center;font-size:.8rem;color:var(--text-3);font-style:italic}.i18n-tabs{margin:2rem 0;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-surface)}.tabs-header{display:flex;background:var(--bg-subtle);border-bottom:1px solid var(--border);overflow-x:auto}.tab-btn{padding:.55rem 1rem;background:0 0;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:var(--font);font-size:.82rem;font-weight:600;color:var(--text-3);white-space:nowrap;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent);background:var(--bg-surface)}.tab-content{display:none;padding:1.5rem}.tab-content.active{display:block;animation:fadeIn .2s ease}.tab-content p:first-child{margin-top:0}.footer{padding:1.5rem 0;border-top:1px solid var(--border);background:var(--bg-surface)}.footer .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem}.social-links{display:flex;gap:1rem}.social-links a{font-size:.78rem;font-weight:600;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase}.social-links a:hover{color:var(--accent);opacity:1}.copyright{font-size:.75rem;color:var(--text-3);font-family:var(--font-mono)}.pagination-default{display:flex;align-items:center;gap:.25rem;list-style:none;padding:0;margin:2.5rem 0 0;flex-wrap:wrap}.page-item{display:flex}.page-link{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 .5rem;border-radius:var(--radius);border:1px solid var(--border);font-size:.82rem;font-family:var(--font-mono);color:var(--text-2);background:var(--bg-surface);cursor:pointer;transition:background .15s,border-color .15s,color .15s;text-decoration:none}.page-link:hover{background:var(--bg-subtle);border-color:var(--border-2);color:var(--text);opacity:1}.page-item.active .page-link{background:var(--accent);border-color:var(--accent);color:#fff}.page-item.disabled .page-link{opacity:.35;cursor:not-allowed;pointer-events:none}.fade-in{opacity:0;transform:translateY(8px);animation:slideUp .45s var(--ease)forwards}@keyframes slideUp{to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{from{opacity:0}to{opacity:1}}html:not(.dark) .chroma{background:#f6f8fa;color:#24292e}html:not(.dark) .chroma .err{color:#a61717;background-color:#e3d2d2}html:not(.dark) .chroma .hl{background-color:#e5e5e5}html:not(.dark) .chroma .lnt,html:not(.dark) .chroma .ln{color:#7f7f7f;white-space:pre;user-select:none;margin-right:.4em;padding:0 .4em}html:not(.dark) .chroma .k,html:not(.dark) .chroma .kc,html:not(.dark) .chroma .kd,html:not(.dark) .chroma .kn,html:not(.dark) .chroma .kp,html:not(.dark) .chroma .kr{color:#000;font-weight:700}html:not(.dark) .chroma .kt{color:#458;font-weight:700}html:not(.dark) .chroma .na{color:teal}html:not(.dark) .chroma .nb{color:#0086b3}html:not(.dark) .chroma .nc{color:#458;font-weight:700}html:not(.dark) .chroma .no{color:teal}html:not(.dark) .chroma .nd{color:#3c5d5d;font-weight:700}html:not(.dark) .chroma .ni{color:purple}html:not(.dark) .chroma .ne,html:not(.dark) .chroma .nf,html:not(.dark) .chroma .nl{color:#900;font-weight:700}html:not(.dark) .chroma .nn{color:#555}html:not(.dark) .chroma .nt{color:navy}html:not(.dark) .chroma .nv,html:not(.dark) .chroma .vc,html:not(.dark) .chroma .vg,html:not(.dark) .chroma .vi{color:teal}html:not(.dark) .chroma .s,html:not(.dark) .chroma .sa,html:not(.dark) .chroma .sb,html:not(.dark) .chroma .sc,html:not(.dark) .chroma .dl,html:not(.dark) .chroma .sd,html:not(.dark) .chroma .s2,html:not(.dark) .chroma .se,html:not(.dark) .chroma .sh,html:not(.dark) .chroma .si,html:not(.dark) .chroma .sx,html:not(.dark) .chroma .s1{color:#d14}html:not(.dark) .chroma .sr{color:#009926}html:not(.dark) .chroma .ss{color:#990073}html:not(.dark) .chroma .m,html:not(.dark) .chroma .mb,html:not(.dark) .chroma .mf,html:not(.dark) .chroma .mh,html:not(.dark) .chroma .mi,html:not(.dark) .chroma .il,html:not(.dark) .chroma .mo{color:#099}html:not(.dark) .chroma .o,html:not(.dark) .chroma .ow{color:#000;font-weight:700}html:not(.dark) .chroma .c,html:not(.dark) .chroma .ch,html:not(.dark) .chroma .cm,html:not(.dark) .chroma .c1{color:#998;font-style:italic}html:not(.dark) .chroma .cs,html:not(.dark) .chroma .cp,html:not(.dark) .chroma .cpf{color:#999;font-weight:700;font-style:italic}html:not(.dark) .chroma .gd{color:#000;background-color:#fdd}html:not(.dark) .chroma .ge{font-style:italic}html:not(.dark) .chroma .gr{color:#a00}html:not(.dark) .chroma .gh{color:#999}html:not(.dark) .chroma .gi{color:#000;background-color:#dfd}html:not(.dark) .chroma .go{color:#888}html:not(.dark) .chroma .gp{color:#555}html:not(.dark) .chroma .gs{font-weight:700}html:not(.dark) .chroma .gu{color:#aaa}html:not(.dark) .chroma .gt{color:#a00}html:not(.dark) .chroma .gl{text-decoration:underline}html:not(.dark) .chroma .w{color:#bbb}html.dark .chroma{background:#1e2433;color:#f8f8f2}html.dark .chroma .k,html.dark .chroma .kc,html.dark .chroma .kn,html.dark .chroma .kp,html.dark .chroma .kr{color:#ff79c6}html.dark .chroma .kd{color:#8be9fd;font-style:italic}html.dark .chroma .kt{color:#8be9fd}html.dark .chroma .na,html.dark .chroma .nc,html.dark .chroma .nf{color:#50fa7b}html.dark .chroma .nb{color:#8be9fd;font-style:italic}html.dark .chroma .nl{color:#8be9fd;font-style:italic}html.dark .chroma .nt{color:#ff79c6}html.dark .chroma .nv,html.dark .chroma .vc,html.dark .chroma .vg,html.dark .chroma .vi{color:#8be9fd;font-style:italic}html.dark .chroma .s,html.dark .chroma .s2,html.dark .chroma .se,html.dark .chroma .s1{color:#f1fa8c}html.dark .chroma .c,html.dark .chroma .c1,html.dark .chroma .cm{color:#6272a4}html.dark .chroma .o{color:#ff79c6}html.dark .chroma .p{color:#f8f8f2}html.dark .chroma .m,html.dark .chroma .mi,html.dark .chroma .mf{color:#bd93f9}html.dark .chroma .hl{background:#44475a}html.dark .chroma .ln,html.dark .chroma .lnt{color:#6272a4}