.blog-page.svelte-1t7vqfz.svelte-1t7vqfz{min-height:400px}.posts.svelte-1t7vqfz.svelte-1t7vqfz{display:flex;flex-direction:column;gap:40px}.post.svelte-1t7vqfz.svelte-1t7vqfz{border-bottom:1px solid #eee}.post.svelte-1t7vqfz.svelte-1t7vqfz:last-child{border-bottom:none}.post-meta.svelte-1t7vqfz.svelte-1t7vqfz{display:flex;align-items:center;gap:10px;margin-bottom:10px}.date.svelte-1t7vqfz.svelte-1t7vqfz{color:#666;font-size:14px}.category-badge.svelte-1t7vqfz.svelte-1t7vqfz{background:#0366d6;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500}.category-badge.project.svelte-1t7vqfz.svelte-1t7vqfz{background:#28a745}.category-badge.company-work.svelte-1t7vqfz.svelte-1t7vqfz{background:#6f42c1}.post.svelte-1t7vqfz h1.svelte-1t7vqfz{margin:0 0 15px;font-size:24px;line-height:1.3}.post-link.svelte-1t7vqfz.svelte-1t7vqfz{background:none;border:none;color:#333;cursor:pointer;font-size:inherit;font-weight:inherit;text-align:left;padding:0;transition:color .2s;width:100%}.post-link.svelte-1t7vqfz.svelte-1t7vqfz:hover{color:#0366d6}.post-excerpt.svelte-1t7vqfz.svelte-1t7vqfz{color:#666;line-height:1.6;font-size:16px}.no-posts.svelte-1t7vqfz.svelte-1t7vqfz{text-align:center;padding:60px 20px;color:#666}@media (max-width: 640px){.post.svelte-1t7vqfz h1.svelte-1t7vqfz{font-size:20px}.post-excerpt.svelte-1t7vqfz.svelte-1t7vqfz{font-size:14px}}.wrapper-footer.svelte-cycfom.svelte-cycfom{border-top:1px solid #ddd;background-color:#f8f9fa}.container.svelte-cycfom.svelte-cycfom{margin:30px 0;text-align:center}.footer-links.svelte-cycfom.svelte-cycfom{display:flex;justify-content:center;gap:20px}.footer-links.svelte-cycfom a.svelte-cycfom{color:#666;transition:color .2s}.footer-links.svelte-cycfom a.svelte-cycfom:hover{color:#0366d6}.svg-icon.svelte-cycfom.svelte-cycfom{width:24px;height:24px;fill:currentColor}.giscus-wrapper.svelte-5hn4bm{margin-top:50px;padding-top:20px;border-top:1px solid var(--border-color);min-height:300px}.post-detail.svelte-wlmtba{max-width:800px;margin:0 auto;padding:20px}.post-header.svelte-wlmtba{margin-bottom:40px;border-bottom:1px solid #eee;padding-bottom:20px}.post-meta.svelte-wlmtba{display:flex;align-items:center;gap:15px;margin-bottom:15px;font-size:14px;color:#666}.category-badge.svelte-wlmtba{background:#0366d6;color:#fff;padding:2px 10px;border-radius:12px;font-weight:500}.category-badge.project.svelte-wlmtba{background:#28a745}.category-badge.company-work.svelte-wlmtba{background:#6f42c1}.post-title.svelte-wlmtba{font-size:36px;margin:0 0 15px;line-height:1.2;color:#24292e}.post-tags.svelte-wlmtba{display:flex;flex-wrap:wrap;gap:8px}.tag.svelte-wlmtba{font-size:13px;color:#0366d6;background:#f1f8ff;padding:2px 8px;border-radius:4px}.post-content.svelte-wlmtba{line-height:1.6;font-size:17px;color:#24292e}.loading.svelte-wlmtba,.content-error.svelte-wlmtba{text-align:center;padding:40px;color:#666}.post-footer.svelte-wlmtba{margin-top:60px;padding-top:30px;border-top:1px solid #eee}.back-button.svelte-wlmtba{background:none;border:1px solid #0366d6;color:#0366d6;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:15px;transition:all .2s;margin-bottom:40px}.back-button.svelte-wlmtba:hover{background:#0366d6;color:#fff}.comments-section.svelte-wlmtba{margin-top:40px}.error-container.svelte-wlmtba,.loading-container.svelte-wlmtba{text-align:center;padding:100px 20px}.markdown-content{word-break:break-word}.markdown-content h2{margin-top:40px;border-bottom:1px solid #eaecef;padding-bottom:10px}.markdown-content pre{background-color:#f6f8fa;border-radius:6px;padding:16px;overflow:auto;position:relative;margin:20px 0}.markdown-content code{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:85%;background-color:#1b1f230d;padding:.2em .4em;border-radius:3px}.markdown-content pre code{background-color:transparent;padding:0}.markdown-content img{max-width:100%;height:auto}.markdown-content blockquote{margin:0;padding:0 1em;color:#6a737d;border-left:.25em solid #dfe2e5}.markdown-content table{width:100%;border-collapse:collapse;margin:20px 0}.markdown-content th,.markdown-content td{padding:6px 13px;border:1px solid #dfe2e5}.markdown-content tr:nth-child(2n){background-color:#f6f8fa}.devsite-icon-copy,.devsite-icon-theme-toggle{position:absolute;top:8px;right:8px;cursor:pointer;opacity:.5;transition:opacity .2s;z-index:10;background:#fff;border:1px solid #ddd;border-radius:4px;padding:4px;font-size:12px;line-height:1}.devsite-icon-theme-toggle{right:45px}.devsite-icon-copy:hover,.devsite-icon-theme-toggle:hover{opacity:1}.copy-toast{position:absolute;top:40px;right:8px;background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;opacity:0;transition:opacity .3s;pointer-events:none;z-index:100}.copy-toast.show{opacity:1}.markdown-content pre.dark-theme{background-color:#1e1e1e;color:#d4d4d4}.markdown-content pre.dark-theme code{color:#d4d4d4}@media (max-width: 768px){.post-title.svelte-wlmtba{font-size:28px}.post-detail.svelte-wlmtba{padding:15px}}.sidebar-header.svelte-vtf9t8.svelte-vtf9t8{padding:30px 20px;border-bottom:1px solid #e1e4e8;background:#fff;position:relative}.profile-section.svelte-vtf9t8.svelte-vtf9t8{text-align:center}.avatar-link.svelte-vtf9t8.svelte-vtf9t8{display:inline-block;margin-bottom:15px}.avatar.svelte-vtf9t8.svelte-vtf9t8{width:80px;height:80px;border-radius:50%;border:3px solid #e1e4e8;transition:border-color .2s}.avatar.svelte-vtf9t8.svelte-vtf9t8:hover{border-color:#0366d6}.site-name.svelte-vtf9t8.svelte-vtf9t8{margin:0 0 8px;font-size:24px;font-weight:600}.site-description.svelte-vtf9t8.svelte-vtf9t8{margin:0;color:#586069;font-size:14px;line-height:1.4}.sidebar-module.svelte-vtf9t8.svelte-vtf9t8{padding:20px;margin-bottom:0;border-bottom:1px solid #e1e4e8}.sidebar-module.svelte-vtf9t8.svelte-vtf9t8:last-child{border-bottom:none}.sidebar-module.svelte-vtf9t8 h4.svelte-vtf9t8{margin:0 0 15px;font-size:16px;font-weight:600;color:#24292e}.category-list.svelte-vtf9t8.svelte-vtf9t8{list-style:none;padding:0;margin:0}.category-list.svelte-vtf9t8 li.svelte-vtf9t8{margin-bottom:6px}.category-link.svelte-vtf9t8.svelte-vtf9t8{background:none;border:none;color:#0366d6;cursor:pointer;font-size:14px;padding:6px 0;text-align:left;width:100%;transition:color .2s;border-radius:4px}.category-link.svelte-vtf9t8.svelte-vtf9t8:hover{color:#0256cc;background:#f1f8ff;padding-left:8px}.category-link.active.svelte-vtf9t8.svelte-vtf9t8{color:#0256cc;font-weight:600;background:#f1f8ff;padding-left:8px}.category-link.tag-item.svelte-vtf9t8.svelte-vtf9t8{font-size:13px;color:#6a737d;padding-left:16px;position:relative}.category-link.tag-item.svelte-vtf9t8.svelte-vtf9t8:before{content:"#";position:absolute;left:8px;color:#6a737d}.category-link.tag-item.svelte-vtf9t8.svelte-vtf9t8:hover{color:#0366d6;background:#f6f8fa;padding-left:16px}.category-link.tag-item.active.svelte-vtf9t8.svelte-vtf9t8{color:#0366d6;font-weight:500;background:#f6f8fa;padding-left:16px}.sidebar-module.svelte-vtf9t8 p.svelte-vtf9t8{color:#586069;font-size:14px;line-height:1.5;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;margin:0;padding:0;background-color:#fff;color:#333}#app-container.svelte-5hq979.svelte-5hq979{display:flex;min-height:100vh;transition:all .01s ease}#sidebar.svelte-5hq979.svelte-5hq979{width:240px;background:#f8f9fa;border-right:0;position:fixed;height:100vh;overflow-y:auto;padding:0;transform:translate(0);transition:transform .01s ease;z-index:1000}#sidebar.collapsed.svelte-5hq979.svelte-5hq979{transform:translate(-100%)}#main-content.svelte-5hq979.svelte-5hq979{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh;transition:margin-left .01s ease}#content.svelte-5hq979.svelte-5hq979{flex:1;max-width:800px;margin:40px auto;width:100%}.sidebar-collapsed.svelte-5hq979 #main-content.svelte-5hq979{margin-left:0}@media (max-width: 480px){#content.svelte-5hq979.svelte-5hq979{margin:20px 15px}}.mermaid-diagram{text-align:center;margin:20px 0;padding:20px;background:#f8f9fa;border-radius:8px;border:1px solid #e1e4e8}.mermaid-diagram svg{max-width:100%;height:auto}.mermaid-error{color:#d73a49;background:#ffeef0;border:1px solid #fdaeb7;border-radius:6px;padding:16px;margin:16px 0;text-align:center}.sidebar-toggle.svelte-5hq979.svelte-5hq979{position:fixed;top:15px;left:15px;z-index:1002;background:#0366d6;color:#fff;border:none;border-radius:4px;width:40px;height:40px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:0 2px 8px #00000026;transition:background-color .2s}.sidebar-toggle.svelte-5hq979.svelte-5hq979:hover{background:#0256cc}@media (max-width: 768px){.sidebar-toggle.svelte-5hq979.svelte-5hq979{top:10px;left:10px;width:36px;height:36px}}@media (max-width: 480px){.sidebar-toggle.svelte-5hq979.svelte-5hq979{top:8px;left:8px;width:32px;height:32px}}
