#app{min-height:100vh}.theme-toggle[data-v-4f5f16f6]{position:relative;display:flex;align-items:center;justify-content:center;padding:4px;background:transparent;border:none;cursor:pointer;outline:none}.toggle-track[data-v-4f5f16f6]{position:relative;display:flex;align-items:center;width:52px;height:28px;padding:2px;background:var(--bg-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-color);transition:background var(--transition-normal),border-color var(--transition-normal)}.toggle-icon[data-v-4f5f16f6]{position:absolute;display:flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--text-tertiary);transition:opacity var(--transition-normal),color var(--transition-normal)}.toggle-icon svg[data-v-4f5f16f6]{width:14px;height:14px}.toggle-icon.sun[data-v-4f5f16f6]{left:6px;opacity:1}.toggle-icon.moon[data-v-4f5f16f6]{right:6px;opacity:.4}.toggle-slider[data-v-4f5f16f6]{position:absolute;left:2px;width:22px;height:22px;background:var(--bg-primary);border-radius:50%;box-shadow:var(--shadow-sm);transition:transform .3s cubic-bezier(.4,0,.2,1)}.theme-toggle.dark .toggle-track[data-v-4f5f16f6]{background:var(--bg-tertiary)}.theme-toggle.dark .toggle-slider[data-v-4f5f16f6]{transform:translateX(24px)}.theme-toggle.dark .toggle-icon.sun[data-v-4f5f16f6]{opacity:.4}.theme-toggle.dark .toggle-icon.moon[data-v-4f5f16f6]{opacity:1;color:var(--accent-secondary)}.theme-toggle:hover .toggle-track[data-v-4f5f16f6]{border-color:var(--accent-primary)}.theme-toggle:focus-visible .toggle-track[data-v-4f5f16f6]{outline:2px solid var(--accent-primary);outline-offset:2px}.home-page[data-v-a2f9a53e]{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden}.particles-container[data-v-a2f9a53e]{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden}.particle[data-v-a2f9a53e]{position:absolute;top:-20px;background:var(--accent-secondary);border-radius:50%;opacity:.3;animation:particleFall-a2f9a53e linear infinite}@keyframes particleFall-a2f9a53e{0%{transform:translateY(-10vh) rotate(0deg);opacity:0}10%{opacity:.3}90%{opacity:.3}to{transform:translateY(110vh) rotate(1turn);opacity:0}}.home-content[data-v-a2f9a53e]{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:var(--spacing-6);text-align:center}.avatar-section[data-v-a2f9a53e]{margin-bottom:var(--spacing-6)}.avatar-link[data-v-a2f9a53e]{display:block;text-decoration:none}.avatar[data-v-a2f9a53e]{width:120px;height:120px;border-radius:50%;border:3px solid var(--border-color);box-shadow:0 0 30px var(--shadow-color);transition:all .4s ease;-o-object-fit:cover;object-fit:cover}@media (hover:hover){.avatar[data-v-a2f9a53e]:hover{transform:translateY(-4px);box-shadow:0 8px 30px var(--shadow-color),0 0 0 4px var(--accent-secondary)}}.avatar-link[data-v-a2f9a53e]{-webkit-tap-highlight-color:transparent}.avatar-link.is-pressed .avatar[data-v-a2f9a53e]{transform:scale(.95);box-shadow:0 0 20px var(--shadow-color)}.info-section[data-v-a2f9a53e]{margin-bottom:var(--spacing-8)}.name[data-v-a2f9a53e]{margin:0 0 var(--spacing-3) 0;font-size:var(--text-2xl);font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.slogan[data-v-a2f9a53e]{margin:0;font-family:var(--font-cursive);font-size:var(--text-lg);color:var(--text-secondary);max-width:400px;line-height:var(--leading-relaxed)}.hub-section[data-v-a2f9a53e]{display:flex;justify-content:center;flex-wrap:wrap;margin:calc(var(--spacing-2)*-1);padding:var(--spacing-6) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.hub-item[data-v-a2f9a53e]{display:flex;flex-direction:column;align-items:center;margin:var(--spacing-2);padding:var(--spacing-4);min-width:80px;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}@media (hover:hover){.hub-item[data-v-a2f9a53e]:hover{background:var(--bg-secondary)}.hub-item:hover .hub-icon[data-v-a2f9a53e]{transform:translateY(-2px);color:var(--accent-primary)}}.hub-item[data-v-a2f9a53e]{-webkit-tap-highlight-color:transparent}.hub-item.is-pressed[data-v-a2f9a53e]{transform:scale(.95);background:var(--bg-secondary)}.hub-item.is-pressed .hub-icon[data-v-a2f9a53e]{color:var(--accent-primary)}.hub-icon[data-v-a2f9a53e]{width:40px;height:40px;margin-bottom:var(--spacing-2);color:var(--text-secondary);transition:all .3s ease}.hub-icon svg[data-v-a2f9a53e]{width:100%;height:100%}.hub-label[data-v-a2f9a53e]{font-size:var(--text-sm);font-weight:500;color:var(--text-primary)}.home-footer[data-v-a2f9a53e]{margin-top:var(--spacing-8)}.footer-content[data-v-a2f9a53e]{display:flex;align-items:center;color:var(--text-tertiary);font-size:var(--text-sm)}.divider[data-v-a2f9a53e]{margin:0 var(--spacing-3)}@media (max-width:768px){.avatar[data-v-a2f9a53e]{width:100px;height:100px}.name[data-v-a2f9a53e]{font-size:var(--text-xl)}.slogan[data-v-a2f9a53e]{font-size:var(--text-base);max-width:300px}.hub-item[data-v-a2f9a53e]{padding:var(--spacing-3);min-width:70px}.hub-icon[data-v-a2f9a53e]{width:32px;height:32px}}@media (max-width:480px){.home-content[data-v-a2f9a53e]{padding:var(--spacing-4)}.hub-section[data-v-a2f9a53e]{padding:var(--spacing-4) 0}.hub-item[data-v-a2f9a53e]{min-width:60px;padding:var(--spacing-2)}.hub-label[data-v-a2f9a53e]{font-size:var(--text-xs)}.footer-content[data-v-a2f9a53e]{flex-direction:column}.footer-content .divider[data-v-a2f9a53e]{display:none}.copyright[data-v-a2f9a53e]{margin-bottom:var(--spacing-2)}}.project-card[data-v-28b363ea]{display:flex;flex-direction:column;height:100%;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--spacing-6);transition:all .3s cubic-bezier(.4,0,.2,1)}@media (hover:hover){.project-card[data-v-28b363ea]:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent-primary)}}.project-card[data-v-28b363ea]{-webkit-tap-highlight-color:transparent}.project-card.is-pressed[data-v-28b363ea]{transform:scale(.97);border-color:var(--accent-primary)}.project-name[data-v-28b363ea]{margin:0 0 var(--spacing-2) 0;font-size:var(--text-lg);font-weight:600;color:var(--text-primary)}.project-description[data-v-28b363ea]{flex-grow:1;margin:0 0 var(--spacing-4) 0;font-size:var(--text-sm);color:var(--text-secondary);line-height:var(--leading-relaxed);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project-languages[data-v-28b363ea]{display:flex;flex-wrap:wrap;margin:calc(var(--spacing-1)*-1);margin-bottom:var(--spacing-4)}.language-tag[data-v-28b363ea]{display:flex;align-items:center;margin:var(--spacing-1);font-size:var(--text-xs);color:var(--text-tertiary)}.language-dot[data-v-28b363ea]{width:8px;height:8px;border-radius:50%;margin-right:var(--spacing-1)}.project-link[data-v-28b363ea]{display:inline-flex;align-items:center;font-size:var(--text-sm);color:var(--link-color);text-decoration:none;transition:color var(--transition-fast)}@media (hover:hover){.project-link[data-v-28b363ea]:hover{color:var(--accent-primary)}.project-link:hover .link-icon[data-v-28b363ea]{transform:translate(2px,-2px)}}.link-icon[data-v-28b363ea]{width:14px;height:14px;margin-left:var(--spacing-1);transition:transform var(--transition-fast)}@media (max-width:768px){.project-card[data-v-28b363ea]{padding:var(--spacing-4)}.project-name[data-v-28b363ea]{font-size:var(--text-base)}.project-description[data-v-28b363ea]{font-size:var(--text-xs)}}.nav-bar[data-v-f47cecf2]{position:fixed;top:0;left:0;right:0;height:60px;background:var(--bg-primary);background:hsla(36,33%,97%,.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:var(--z-fixed);transition:transform var(--transition-normal),background var(--transition-normal)}[data-theme=dark] .nav-bar[data-v-f47cecf2]{background:rgba(26,25,23,.85)}.nav-bar.nav-hidden[data-v-f47cecf2]{transform:translateY(-100%)}.nav-content[data-v-f47cecf2]{max-width:var(--container-lg);height:100%;margin:0 auto;padding:0 var(--spacing-4);justify-content:space-between}.nav-content[data-v-f47cecf2],.nav-links[data-v-f47cecf2]{display:flex;align-items:center}.nav-link[data-v-f47cecf2]{position:relative;padding:var(--spacing-2) var(--spacing-4);color:var(--text-secondary);text-decoration:none;font-size:var(--text-sm);font-weight:500;letter-spacing:.02em;transition:color var(--transition-fast)}.nav-link.router-link-active[data-v-f47cecf2],.nav-link[data-v-f47cecf2]:hover{color:var(--text-primary)}.nav-link.router-link-active[data-v-f47cecf2]:after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:20px;height:2px;background:var(--accent-primary);border-radius:1px}@media (max-width:768px){.nav-bar[data-v-f47cecf2]{height:56px}.nav-link[data-v-f47cecf2]{padding:var(--spacing-2) var(--spacing-3);font-size:var(--text-xs)}}@media (max-width:480px){.nav-link[data-v-f47cecf2]{padding:var(--spacing-1) var(--spacing-2)}}.project-page[data-v-0e7b8858]{min-height:100vh}.project-main[data-v-0e7b8858]{padding-top:calc(60px + var(--spacing-8));padding-bottom:var(--spacing-12)}.project-header[data-v-0e7b8858]{text-align:center;margin-bottom:var(--spacing-8);padding:0 var(--spacing-4)}.page-title[data-v-0e7b8858]{margin:0 0 var(--spacing-2) 0;font-size:var(--text-3xl);font-weight:600;color:var(--text-primary)}.page-subtitle[data-v-0e7b8858]{margin:0;font-size:var(--text-base);color:var(--text-tertiary)}.project-container[data-v-0e7b8858]{max-width:var(--container-lg);margin:0 auto;padding:0 var(--spacing-4)}.loading[data-v-0e7b8858]{text-align:center;padding:var(--spacing-12);color:var(--text-tertiary)}.loading-text[data-v-0e7b8858]{font-size:var(--text-base)}.projects-grid[data-v-0e7b8858]{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--spacing-6)}@media (max-width:768px){.project-main[data-v-0e7b8858]{padding-top:calc(56px + var(--spacing-6))}.page-title[data-v-0e7b8858]{font-size:var(--text-2xl)}.projects-grid[data-v-0e7b8858]{grid-template-columns:1fr}}@media (max-width:480px){.project-container[data-v-0e7b8858]{padding:0 var(--spacing-2)}.projects-grid[data-v-0e7b8858]{gap:var(--spacing-4)}}.post-card[data-v-66add37d]{display:flex;align-items:center;padding:var(--spacing-4) var(--spacing-5);margin:var(--spacing-2) 0;background:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}@media (hover:hover){.post-card[data-v-66add37d]:hover{background:var(--bg-tertiary);transform:translateX(8px)}.post-card:hover .post-title[data-v-66add37d]{color:var(--accent-primary)}.post-card:hover .post-arrow[data-v-66add37d]{opacity:1;transform:translateX(4px)}}.post-card[data-v-66add37d]{-webkit-tap-highlight-color:transparent}.post-card.is-pressed[data-v-66add37d]{transform:scale(.97);background:var(--bg-tertiary)}.post-card.is-pressed .post-title[data-v-66add37d]{color:var(--accent-primary)}.post-date[data-v-66add37d]{flex-shrink:0;width:60px;font-size:var(--text-sm);color:var(--text-tertiary);font-family:var(--font-mono)}.post-title[data-v-66add37d]{flex:1;margin:0;font-size:var(--text-base);font-weight:500;color:var(--text-primary);transition:color var(--transition-fast);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.post-arrow[data-v-66add37d]{flex-shrink:0;margin-left:var(--spacing-3);color:var(--text-tertiary);opacity:0;transition:all var(--transition-fast)}@media (max-width:768px){.post-card[data-v-66add37d]{padding:var(--spacing-3) var(--spacing-4)}.post-date[data-v-66add37d]{width:50px;font-size:var(--text-xs)}.post-title[data-v-66add37d]{font-size:var(--text-sm)}}@media (max-width:480px){.post-card[data-v-66add37d]{flex-direction:column;align-items:flex-start;padding:var(--spacing-3)}.post-date[data-v-66add37d]{width:auto;margin-bottom:var(--spacing-1)}.post-title[data-v-66add37d]{white-space:normal;line-height:var(--leading-snug)}.post-arrow[data-v-66add37d]{display:none}}.blog-page[data-v-731b3a8c]{min-height:100vh}.blog-main[data-v-731b3a8c]{padding-top:calc(60px + var(--spacing-8));padding-bottom:var(--spacing-12)}.blog-header[data-v-731b3a8c]{text-align:center;margin-bottom:var(--spacing-8);padding:0 var(--spacing-4)}.page-title[data-v-731b3a8c]{margin:0 0 var(--spacing-2) 0;font-size:var(--text-3xl);font-weight:600;color:var(--text-primary)}.page-subtitle[data-v-731b3a8c]{margin:0;font-size:var(--text-base);color:var(--text-tertiary)}.blog-container[data-v-731b3a8c]{max-width:var(--container-md);margin:0 auto;padding:0 var(--spacing-4)}.blog-list[data-v-731b3a8c]{background:var(--bg-primary);border-radius:var(--radius-xl);padding:var(--spacing-6);box-shadow:var(--shadow-lg);border:1px solid var(--border-color)}.year-section[data-v-731b3a8c]{margin-bottom:var(--spacing-8)}.year-section[data-v-731b3a8c]:last-child{margin-bottom:0}.year-title[data-v-731b3a8c]{display:flex;align-items:center;margin:0 0 var(--spacing-4) 0;font-size:var(--text-sm);font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.1em}.year-text[data-v-731b3a8c]{padding-right:var(--spacing-4)}.year-title[data-v-731b3a8c]:after{content:"";flex:1;height:1px;background:var(--border-color)}@media (max-width:768px){.blog-main[data-v-731b3a8c]{padding-top:calc(56px + var(--spacing-6))}.page-title[data-v-731b3a8c]{font-size:var(--text-2xl)}.blog-list[data-v-731b3a8c]{padding:var(--spacing-4);border-radius:var(--radius-lg)}}@media (max-width:480px){.blog-container[data-v-731b3a8c]{padding:0 var(--spacing-2)}.blog-list[data-v-731b3a8c]{padding:var(--spacing-3);border-radius:var(--radius-md)}}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}.hljs{color:#383a42;background:#fafafa}.hljs-comment,.hljs-quote{color:#a0a1a7;font-style:italic}.hljs-doctag,.hljs-formula,.hljs-keyword{color:#a626a4}.hljs-deletion,.hljs-name,.hljs-section,.hljs-selector-tag,.hljs-subst{color:#e45649}.hljs-literal{color:#0184bb}.hljs-addition,.hljs-attribute,.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#50a14f}.hljs-attr,.hljs-number,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-pseudo,.hljs-template-variable,.hljs-type,.hljs-variable{color:#986801}.hljs-bullet,.hljs-link,.hljs-meta,.hljs-selector-id,.hljs-symbol,.hljs-title{color:#4078f2}.hljs-built_in,.hljs-class .hljs-title,.hljs-title.class_{color:#c18401}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:700}.hljs-link{text-decoration:underline}.blog-post-page{min-height:100vh}.post-main{padding-top:calc(60px + var(--spacing-8));padding-bottom:var(--spacing-12)}.post-article{max-width:var(--container-prose);margin:0 auto;padding:0 var(--spacing-4)}.post-header{text-align:center;margin-bottom:var(--spacing-10);padding-bottom:var(--spacing-6);border-bottom:1px solid var(--border-color)}.post-title{margin:0 0 var(--spacing-4) 0;font-size:var(--text-3xl);font-weight:600;color:var(--text-primary);line-height:var(--leading-tight)}.post-meta{color:var(--text-tertiary);font-size:var(--text-sm)}.post-content{color:var(--text-primary)}.post-content h1,.post-content h2,.post-content h3,.post-content h4,.post-content h5,.post-content h6{color:var(--text-primary);margin-top:var(--spacing-8);margin-bottom:var(--spacing-4)}.post-content p{margin-bottom:var(--spacing-4);line-height:var(--leading-relaxed)}.post-content a{color:var(--link-color);text-decoration:underline;text-decoration-color:var(--border-color);text-underline-offset:2px}.post-content a:hover{color:var(--accent-primary);text-decoration-color:var(--accent-primary)}.post-content blockquote{margin:var(--spacing-6) 0;padding:var(--spacing-4) var(--spacing-6);border-left:3px solid var(--accent-tertiary);background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);font-style:italic}.post-content blockquote p:last-child{margin-bottom:0}.post-content .code-block{position:relative;margin:var(--spacing-6) 0;padding-bottom:0;border-radius:var(--radius-md);overflow:hidden;background:var(--code-bg);border:1px solid var(--code-border)}.post-content pre code::-webkit-scrollbar{height:5px}.post-content pre code::-webkit-scrollbar-track{background:var(--code-bg);border-radius:0 0 var(--radius-md) var(--radius-md)}.post-content pre code::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:3px}.post-content .code-lang-badge{position:absolute;top:0;left:0;padding:2px 10px;font-size:11px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;background:var(--code-lang-bg);color:var(--code-lang-text);border-radius:0 0 var(--radius-sm) 0;z-index:1}.post-content pre code{display:block;padding:var(--spacing-6) var(--spacing-3) var(--spacing-3) var(--spacing-2);font-family:var(--font-mono);font-size:var(--text-sm);line-height:var(--leading-relaxed);white-space:pre;-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;overflow-x:auto}.post-content pre code.no-line-numbers{padding-top:12px}.post-content pre code.hljs{padding-bottom:12px}.post-content .code-block table.hljs-ln,.post-content table.hljs-ln{border-collapse:collapse;border-spacing:0;width:100%;margin:12px 0 0 0;border:none}.post-content .code-block table.hljs-ln tr,.post-content table.hljs-ln tr{background:transparent!important;border:none!important}.post-content .code-block table.hljs-ln td,.post-content table.hljs-ln td{border-top:none!important;border-bottom:none!important;border-left:none!important;background:transparent!important;line-height:var(--leading-relaxed);font-size:inherit}.post-content .code-block td.hljs-ln-numbers,.post-content td.hljs-ln-numbers{text-align:right;color:var(--code-line-number);border-right:1px solid var(--code-line-border)!important;padding:0 6px 0 0!important;-webkit-user-select:none;-moz-user-select:none;user-select:none;vertical-align:top;width:1%;white-space:nowrap}.post-content .code-block td.hljs-ln-code,.post-content td.hljs-ln-code{padding:0 0 0 12px!important;border-right:none!important;white-space:pre}.post-content code{font-family:var(--font-mono);font-size:.875em;background:var(--bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);color:var(--accent-primary)}.post-content pre code{background:transparent;color:inherit}.post-content img{display:block;margin:var(--spacing-6) auto;max-width:100%;height:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.post-content ol,.post-content ul{margin:var(--spacing-4) 0;padding-left:var(--spacing-6)}.post-content ul{list-style-type:disc}.post-content ol{list-style-type:decimal}.post-content li{margin-bottom:var(--spacing-2)}.post-content li::marker{color:var(--accent-primary)}.post-content hr{margin:var(--spacing-8) 0;border:none;height:1px;background:var(--border-color)}.post-footer{margin-top:var(--spacing-5);padding-top:var(--spacing-5)}.end-mark{width:100%;margin:0 0 var(--spacing-6) 0!important;font-family:var(--font-cursive);font-size:var(--text-lg);display:flex;align-items:center;justify-content:center}.end-mark:after,.end-mark:before{content:""!important;flex:1;height:1px;background:var(--border-color);letter-spacing:normal}.post-info{text-align:left;color:var(--text-tertiary);font-size:var(--text-sm)}.post-info p{margin:var(--spacing-1) 0}.hljs,[data-theme=dark] .hljs{background:transparent!important}[data-theme=dark] .hljs-keyword,[data-theme=dark] .hljs-selector-tag{color:#c678dd}[data-theme=dark] .hljs-doctag,[data-theme=dark] .hljs-string{color:#98c379}[data-theme=dark] .hljs-number{color:#d19a66}[data-theme=dark] .hljs-function .hljs-title,[data-theme=dark] .hljs-title.function_{color:#61afef}[data-theme=dark] .hljs-comment{color:#5c6370;font-style:italic}[data-theme=dark] .hljs-title{color:#61afef}[data-theme=dark] .hljs-params{color:#abb2bf}[data-theme=dark] .hljs-built_in{color:#e6c07b}[data-theme=dark] .hljs-literal,[data-theme=dark] .hljs-type{color:#56b6c2}[data-theme=dark] .hljs-attr,[data-theme=dark] .hljs-attribute{color:#d19a66}[data-theme=dark] .hljs-template-variable,[data-theme=dark] .hljs-variable{color:#e06c75}[data-theme=dark] .hljs-class .hljs-title,[data-theme=dark] .hljs-title.class_{color:#e6c07b}[data-theme=dark] .hljs-name,[data-theme=dark] .hljs-selector-class,[data-theme=dark] .hljs-selector-id{color:#e06c75}[data-theme=dark] .hljs-regexp{color:#98c379}[data-theme=dark] .hljs-symbol{color:#56b6c2}[data-theme=dark] .hljs-meta{color:#61afef}[data-theme=dark] .hljs-deletion{color:#e06c75}[data-theme=dark] .hljs-addition{color:#98c379}@media (max-width:768px){.post-main{padding-top:calc(56px + var(--spacing-6))}.post-title{font-size:var(--text-2xl)}.post-content pre code{font-size:var(--text-xs)}}@media (max-width:480px){.post-article{padding:0 var(--spacing-3)}.post-title{font-size:var(--text-xl)}.end-mark:after,.end-mark:before{width:40px}}.post-content .code-copy-btn{position:absolute;top:0;right:0;display:flex;align-items:center;justify-content:center;width:32px;height:24px;background:var(--code-lang-bg);color:var(--code-lang-text);border:none;border-radius:0 0 0 var(--radius-sm);cursor:pointer;opacity:0;z-index:1;transform:translateY(-4px);transition:opacity .2s ease,transform .2s ease,background .2s ease,color .2s ease}.post-content .code-block:hover .code-copy-btn{opacity:1;transform:translateY(0)}.post-content .code-copy-btn:hover{background:var(--accent-primary);color:var(--bg-primary);transform:scale(1.05)}.post-content .code-copy-btn:active{transform:scale(.95);transition:transform .1s ease}.post-content .code-copy-btn svg{width:14px;height:14px;transition:transform .2s ease,opacity .2s ease}.post-content .code-copy-btn:hover .copy-icon{transform:rotate(-8deg)}.post-content .code-copy-btn .check-icon{display:none}.post-content .code-copy-btn.copied{opacity:1;background:var(--border-color);color:var(--text-primary);transform:translateY(0);animation:copySuccess .3s ease}.post-content .code-copy-btn.copied .copy-icon{display:none}.post-content .code-copy-btn.copied .check-icon{display:block;animation:checkPop .3s ease}@keyframes copySuccess{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes checkPop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.15);opacity:1}to{transform:scale(1);opacity:1}}@media (max-width:768px){.post-content .code-copy-btn{opacity:1;transform:translateY(0)}}.about-page[data-v-501ca798]{min-height:100vh}.about-main[data-v-501ca798]{padding-top:calc(60px + var(--spacing-6));padding-bottom:var(--spacing-8);display:flex;justify-content:center}.terminal[data-v-501ca798]{width:90%;max-width:900px;background:var(--terminal-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);overflow:hidden}.terminal-header[data-v-501ca798]{display:flex;align-items:center;padding:var(--spacing-3) var(--spacing-4);background:#2d2a28;border-bottom:1px solid #3a3735}.terminal-buttons[data-v-501ca798]{display:flex;align-items:center}.terminal-btn[data-v-501ca798]{width:12px;height:12px;border-radius:50%;margin-right:var(--spacing-2)}.terminal-btn.close[data-v-501ca798]{background:#ff5f57}.terminal-btn.minimize[data-v-501ca798]{background:#ffbd2e}.terminal-btn.maximize[data-v-501ca798]{background:#28ca42}.terminal-title[data-v-501ca798]{flex:1;text-align:center;font-size:var(--text-sm);font-weight:500;color:var(--terminal-text);opacity:.8}.terminal-spacer[data-v-501ca798]{width:60px}.terminal-body[data-v-501ca798]{height:70vh;padding:var(--spacing-4);overflow-y:auto;font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.8;color:var(--terminal-text)}.terminal-body[data-v-501ca798]::-webkit-scrollbar{width:6px}.terminal-body[data-v-501ca798]::-webkit-scrollbar-track{background:transparent}.terminal-body[data-v-501ca798]::-webkit-scrollbar-thumb{background:#3a3735;border-radius:var(--radius-full)}.terminal-line[data-v-501ca798]{margin-bottom:var(--spacing-1);word-break:break-word}.prompt[data-v-501ca798]{color:var(--terminal-prompt);font-weight:600}.tag[data-v-501ca798]{display:inline-block;padding:1px 8px;margin-right:var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:500}.tag-name[data-v-501ca798]{background:var(--tag-name);color:#1a1917}.tag-success[data-v-501ca798]{background:var(--tag-skill-a);color:#1a1917}.tag-system[data-v-501ca798]{background:var(--tag-system);color:#1a1917}.tag-warning[data-v-501ca798]{background:var(--tag-skill-b);color:#1a1917}.tag-error[data-v-501ca798]{background:var(--tag-error);color:#1a1917}.terminal-input-line[data-v-501ca798]{display:flex;align-items:center;margin-top:var(--spacing-2)}.cursor[data-v-501ca798]{display:inline-block;width:8px;height:16px;background:var(--terminal-text);animation:cursorBlink-501ca798 1s ease-in-out infinite}@keyframes cursorBlink-501ca798{0%,to{opacity:1}50%{opacity:0}}.hidden-input[data-v-501ca798]{position:absolute;opacity:0;width:0;height:0}@media (max-width:768px){.about-main[data-v-501ca798]{padding-top:calc(56px + var(--spacing-4))}.terminal[data-v-501ca798]{width:95%;border-radius:var(--radius-md)}.terminal-body[data-v-501ca798]{height:65vh;font-size:var(--text-xs)}}@media (max-width:480px){.terminal[data-v-501ca798]{width:100%;border-radius:0}.terminal-body[data-v-501ca798]{height:60vh;padding:var(--spacing-3)}.terminal-header[data-v-501ca798]{padding:var(--spacing-2) var(--spacing-3)}.tag[data-v-501ca798]{padding:1px 6px;font-size:10px}}.not-found[data-v-50948310]{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:var(--bg-primary);color:var(--text-primary);position:relative;overflow:hidden;padding:var(--spacing-8)}.not-found-content[data-v-50948310]{text-align:center;position:relative;z-index:1}.enso-circle[data-v-50948310]{width:150px;height:150px;margin:0 auto var(--spacing-6);color:var(--accent-primary);opacity:.6}.enso-svg[data-v-50948310]{width:100%;height:100%;animation:drawEnso-50948310 2s ease-out forwards}@keyframes drawEnso-50948310{0%{stroke-dashoffset:480;opacity:0}to{stroke-dashoffset:40;opacity:1}}.error-code[data-v-50948310]{font-family:var(--font-serif);font-size:120px;font-weight:300;letter-spacing:.1em;color:var(--text-primary);margin:0 0 var(--spacing-6);line-height:1;opacity:.9}.error-message[data-v-50948310]{margin-bottom:var(--spacing-6);padding:var(--spacing-4) 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color)}.haiku-line[data-v-50948310]{font-family:var(--font-cursive);font-size:var(--text-lg);color:var(--text-secondary);margin:var(--spacing-2) 0;letter-spacing:.2em}.error-hint[data-v-50948310]{font-size:var(--text-sm);color:var(--text-tertiary);margin-bottom:var(--spacing-8);font-style:italic}.home-link[data-v-50948310]{display:inline-flex;align-items:center;padding:var(--spacing-3) var(--spacing-6);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);text-decoration:none;font-size:var(--text-base);transition:all var(--transition-normal)}.home-link[data-v-50948310]:hover{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.home-link:hover .link-arrow[data-v-50948310]{transform:translateX(4px)}.link-arrow[data-v-50948310]{margin-left:var(--spacing-2);transition:transform var(--transition-fast)}.wave-decoration[data-v-50948310]{position:absolute;bottom:0;left:0;right:0;height:120px;color:var(--bg-secondary);opacity:.5}.wave-decoration svg[data-v-50948310]{width:100%;height:100%}@media (max-width:768px){.enso-circle[data-v-50948310]{width:100px;height:100px}.error-code[data-v-50948310]{font-size:80px}.haiku-line[data-v-50948310]{font-size:var(--text-base)}}@media (max-width:480px){.not-found[data-v-50948310]{padding:var(--spacing-4)}.error-code[data-v-50948310]{font-size:60px}.haiku-line[data-v-50948310]{font-size:var(--text-sm);letter-spacing:.1em}.home-link[data-v-50948310]{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm)}}:root{--bg-primary:#faf8f5;--bg-secondary:#f5f2ed;--bg-tertiary:#ede8e0;--text-primary:#2c2825;--text-secondary:#5c5650;--text-tertiary:#8c8680;--accent-primary:#c4a77d;--accent-secondary:#d4a5a5;--accent-tertiary:#7eb5a6;--link-color:#6b8e8d;--border-color:#e0dcd5;--shadow-color:rgba(44,40,37,.08);--shadow-sm:0 1px 2px rgba(44,40,37,.05);--shadow-md:0 4px 6px rgba(44,40,37,.07);--shadow-lg:0 10px 15px rgba(44,40,37,.1);--shadow-xl:0 20px 25px rgba(44,40,37,.1);--terminal-bg:#2a2725;--terminal-text:#e8e4df;--terminal-prompt:#b4d4b0;--code-bg:#fafafa;--code-border:#e0dcd5;--code-lang-bg:#e8e8e8;--code-lang-text:#666;--code-line-number:#999;--code-line-border:#e0e0e0;--tag-name:#7eb5a6;--tag-school:#d4a5a5;--tag-skill-a:#b4d4b0;--tag-skill-b:#e8c88c;--tag-system:#9c9890;--tag-error:#d4a5a5;--font-sans:"Noto Sans SC","PingFang SC","Hiragino Sans GB","Microsoft YaHei","Noto Sans JP",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-serif:"Noto Serif SC","Noto Serif JP",Georgia,"Times New Roman",serif;--font-mono:"JetBrains Mono","Fira Code","Source Code Pro",Consolas,"Courier New",monospace;--font-cursive:"Ma Shan Zheng","Liu Jian Mao Cao",cursive;--text-xs:12px;--text-sm:14px;--text-base:16px;--text-lg:18px;--text-xl:20px;--text-2xl:24px;--text-3xl:30px;--text-4xl:36px;--leading-tight:1.25;--leading-snug:1.375;--leading-normal:1.5;--leading-relaxed:1.625;--leading-loose:2;--spacing-1:4px;--spacing-2:8px;--spacing-3:12px;--spacing-4:16px;--spacing-5:20px;--spacing-6:24px;--spacing-8:32px;--spacing-10:40px;--spacing-12:48px;--spacing-16:64px;--spacing-20:80px;--spacing-24:96px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:24px;--radius-full:9999px;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px;--container-prose:750px;--transition-fast:0.15s ease;--transition-normal:0.3s ease;--transition-slow:0.5s ease;--transition-slower:0.6s ease;--z-dropdown:100;--z-sticky:200;--z-fixed:300;--z-modal-backdrop:400;--z-modal:500;--z-tooltip:600}[data-theme=dark]{--bg-primary:#1a1917;--bg-secondary:#242220;--bg-tertiary:#2e2b28;--text-primary:#e8e4df;--text-secondary:#b8b2a8;--text-tertiary:#807a70;--accent-primary:#d4b896;--accent-secondary:#e8b4b4;--accent-tertiary:#8ecab8;--link-color:#9bc5c4;--border-color:#3a3735;--shadow-color:rgba(0,0,0,.3);--shadow-sm:0 1px 2px rgba(0,0,0,.2);--shadow-md:0 4px 6px rgba(0,0,0,.25);--shadow-lg:0 10px 15px rgba(0,0,0,.3);--shadow-xl:0 20px 25px rgba(0,0,0,.35);--terminal-bg:#1a1917;--terminal-text:#e8e4df;--terminal-prompt:#c8e8c4;--code-bg:#282c34;--code-border:#3a3735;--code-lang-bg:#3e4451;--code-lang-text:#abb2bf;--code-line-number:#636d83;--code-line-border:#3e4451;--tag-name:#8ecab8;--tag-school:#e8b4b4;--tag-skill-a:#c8e8c4;--tag-skill-b:#f0d090;--tag-system:#9c9890;--tag-error:#e8b4b4}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text-primary);background-color:var(--bg-primary);transition:background-color var(--transition-normal),color var(--transition-normal);min-height:100vh}a{color:var(--link-color);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary)}img{max-width:100%;height:auto;display:block}button{font-family:inherit;font-size:inherit;line-height:inherit;cursor:pointer;border:none;background:none;color:inherit}ol,ul{list-style:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--text-tertiary) var(--bg-secondary)}::-moz-selection{background:rgba(173,214,255,.5)}::selection{background:rgba(173,214,255,.5)}[data-theme=dark] ::-moz-selection{background:rgba(100,160,220,.4)}[data-theme=dark] ::selection{background:rgba(100,160,220,.4)}.container{width:100%;max-width:var(--container-lg);margin-left:auto;margin-right:auto;padding-left:var(--spacing-4);padding-right:var(--spacing-4)}.container-prose{max-width:var(--container-prose)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.washi-texture{position:relative}.washi-texture:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:0}.glass{background:hsla(36,33%,97%,.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}[data-theme=dark] .glass{background:rgba(26,25,23,.85)}.card{background:var(--bg-secondary);border-radius:var(--radius-lg);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.card-hover:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}h1,h2,h3,h4,h5,h6{font-family:var(--font-sans);font-weight:600;line-height:var(--leading-tight);color:var(--text-primary)}h1{font-size:var(--text-4xl)}h1,h2{letter-spacing:-.025em}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{margin-bottom:var(--spacing-4)}.prose,p{line-height:var(--leading-relaxed)}.prose{font-size:var(--text-base);color:var(--text-primary)}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{margin-top:var(--spacing-8);margin-bottom:var(--spacing-4)}.prose h1:first-child,.prose h2:first-child,.prose h3:first-child,.prose h4:first-child,.prose h5:first-child,.prose h6:first-child{margin-top:0}.prose h1{font-size:var(--text-3xl)}.prose h2{font-size:var(--text-2xl)}.prose h3{font-size:var(--text-xl)}.prose h4{font-size:var(--text-lg)}.prose p{margin-bottom:var(--spacing-4)}.prose a{color:var(--link-color);text-decoration:underline;text-decoration-color:var(--border-color);text-underline-offset:2px;transition:all var(--transition-fast)}.prose a:hover{color:var(--accent-primary);text-decoration-color:var(--accent-primary)}.prose b,.prose strong{font-weight:600;color:var(--text-primary)}.prose em,.prose i{font-style:italic}.prose blockquote{margin:var(--spacing-6) 0;padding:var(--spacing-4) var(--spacing-6);border-left:3px solid var(--accent-tertiary);background:var(--bg-secondary);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-secondary);font-style:italic}.prose blockquote p:last-child{margin-bottom:0}.prose code{font-family:var(--font-mono);font-size:.875em;padding:2px 6px;border-radius:var(--radius-sm);color:var(--accent-primary)}.prose code,.prose pre{background:var(--bg-tertiary)}.prose pre{margin:var(--spacing-6) 0;padding:var(--spacing-4);border-radius:var(--radius-md);overflow-x:auto}.prose pre code{background:none;padding:0;color:inherit}.prose ol,.prose ul{margin:var(--spacing-4) 0;padding-left:var(--spacing-6)}.prose ul{list-style-type:disc}.prose ol{list-style-type:decimal}.prose li{margin-bottom:var(--spacing-2)}.prose li::marker{color:var(--accent-primary)}.prose img{margin:var(--spacing-6) auto;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.prose hr{margin:var(--spacing-8) 0;border:none;height:1px;background:var(--border-color)}.prose table{width:100%;margin:var(--spacing-6) 0;border-collapse:collapse}.prose table td,.prose table th{padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--border-color);text-align:left}.prose table th{font-weight:600}.prose table th,.prose table tr:nth-child(2n){background:var(--bg-secondary)}.divider{display:flex;align-items:center;margin:var(--spacing-6) 0;color:var(--text-tertiary)}.divider:after,.divider:before{content:"";flex:1;height:1px;background:var(--border-color)}.divider:before{margin-right:var(--spacing-4)}.divider:after{margin-left:var(--spacing-4)}.end-mark{text-align:center;margin:var(--spacing-12) 0 var(--spacing-8);color:var(--text-tertiary);font-size:var(--text-sm)}.end-mark:before{margin-right:var(--spacing-4)}.end-mark:after,.end-mark:before{content:"─────";letter-spacing:-.2em}.end-mark:after{margin-left:var(--spacing-4)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}@keyframes softBlink{0%,to{opacity:1}50%{opacity:.3}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes sakuraFall{0%{transform:translateY(-10vh) rotate(0deg);opacity:1}to{transform:translateY(110vh) rotate(2turn);opacity:0}}@keyframes sway{0%,to{transform:translateX(0) rotate(0deg)}25%{transform:translateX(10px) rotate(5deg)}75%{transform:translateX(-10px) rotate(-5deg)}}.animate-fade-in{animation:fadeIn var(--transition-slow) ease forwards}.animate-fade-in-up{animation:fadeInUp var(--transition-slower) ease forwards}.animate-fade-in-down{animation:fadeInDown var(--transition-slower) ease forwards}.animate-fade-in-left{animation:fadeInLeft var(--transition-slower) ease forwards}.animate-fade-in-right{animation:fadeInRight var(--transition-slower) ease forwards}.animate-scale-in{animation:scaleIn var(--transition-slow) ease forwards}.animate-float{animation:float 3s ease-in-out infinite}.fade-slide-enter-active,.fade-slide-leave-active{transition:opacity .4s ease,transform .4s ease}.fade-slide-enter-from{opacity:0;transform:translateY(20px)}.fade-slide-leave-to{opacity:0;transform:translateY(-20px)}.fade-enter-active,.fade-leave-active{transition:opacity .3s ease}.fade-enter-from,.fade-leave-to{opacity:0}.scale-enter-active,.scale-leave-active{transition:opacity .3s ease,transform .3s ease}.scale-enter-from,.scale-leave-to{opacity:0;transform:scale(.95)}.stagger-list>*{opacity:0;animation:fadeInUp var(--transition-slower) ease forwards}.stagger-list>:first-child{animation-delay:0s}.stagger-list>:nth-child(2){animation-delay:.05s}.stagger-list>:nth-child(3){animation-delay:.1s}.stagger-list>:nth-child(4){animation-delay:.15s}.stagger-list>:nth-child(5){animation-delay:.2s}.stagger-list>:nth-child(6){animation-delay:.25s}.stagger-list>:nth-child(7){animation-delay:.3s}.stagger-list>:nth-child(8){animation-delay:.35s}.stagger-list>:nth-child(9){animation-delay:.4s}.stagger-list>:nth-child(10){animation-delay:.45s}.stagger-list>:nth-child(11){animation-delay:.5s}.stagger-list>:nth-child(12){animation-delay:.55s}.stagger-list>:nth-child(13){animation-delay:.6s}.stagger-list>:nth-child(14){animation-delay:.65s}.stagger-list>:nth-child(15){animation-delay:.7s}.stagger-list>:nth-child(16){animation-delay:.75s}.stagger-list>:nth-child(17){animation-delay:.8s}.stagger-list>:nth-child(18){animation-delay:.85s}.stagger-list>:nth-child(19){animation-delay:.9s}.stagger-list>:nth-child(20){animation-delay:.95s}.hover-lift{transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.hover-lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.hover-scale{transition:transform var(--transition-normal)}.hover-scale:hover{transform:scale(1.02)}.hover-glow{transition:box-shadow var(--transition-normal)}.hover-glow:hover{box-shadow:0 0 20px hsla(35,38%,63%,.3)}.link-underline{position:relative}.link-underline:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:currentColor;transition:width var(--transition-normal)}.link-underline:hover:after{width:100%}