.fade-up-enter-active[data-v-dc5a55c8],.fade-up-leave-active[data-v-dc5a55c8]{transition:all .3s ease}.fade-up-enter-from[data-v-dc5a55c8],.fade-up-leave-to[data-v-dc5a55c8]{opacity:0;transform:translateY(20px)}.back-to-top[data-v-dc5a55c8]{position:fixed;bottom:2rem;right:2rem;width:3rem;height:3rem;opacity:.8;background:var(--bg-tertiary);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px var(--shadow);transition:all .3s ease;z-index:999}.back-to-top[data-v-dc5a55c8]:hover{background:var(--accent-color);transform:translateY(-4px);box-shadow:0 6px 16px var(--shadow-hover)}.back-to-top[data-v-dc5a55c8]:active{transform:translateY(-2px)}.back-to-top-icon[data-v-dc5a55c8]{font-size:1.5rem;line-height:1}@media (max-width:768px){.back-to-top[data-v-dc5a55c8]{bottom:1.5rem;right:1.5rem;width:2.75rem;height:2.75rem}.back-to-top-icon[data-v-dc5a55c8]{font-size:1.25rem}}@media (max-width:600px){.back-to-top[data-v-dc5a55c8]{bottom:1rem;right:1rem;width:2.5rem;height:2.5rem}.back-to-top-icon[data-v-dc5a55c8]{font-size:1.125rem}}:root{--white:#fff;--black:#000;--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#e0e0e0;--text-primary:#2c3e50;--text-secondary:#555;--text-tertiary:#7f8c8d;--accent-color:#4285f4;--accent-hover:#174ea6;--border-color:#e0e0e0;--shadow:rgba(0,0,0,.1);--shadow-hover:rgba(0,0,0,.15);--aura-accent-hover:rgba(210,227,252,.8);--error-color:#e74c3c;--warning-color:#f39c12;--border-radius:.5rem;--border-radius-lg:1rem;--text-inverse:var(--white);--bg-inverse:var(--black);--border-color-inverse:hsla(0,0%,100%,.2);--shadow-inverse:hsla(0,0%,100%,.1)}[data-theme=dark]{--bg-primary:#1a1a1a;--bg-secondary:#2d2d2d;--bg-tertiary:#3d3d3d;--text-primary:#e0e0e0;--text-secondary:#b0b0b0;--text-tertiary:#888;--accent-color:#4285f4;--accent-hover:#174ea6;--border-color:#404040;--shadow:rgba(0,0,0,.3);--shadow-hover:rgba(0,0,0,.5);--aura-accent-hover:rgba(210,227,252,.1);--text-inverse:var(--black);--bg-inverse:var(--white);--border-color-inverse:var(--border-color);--shadow-inverse:rgba(0,0,0,.2)}*{touch-action:manipulation}body,html{margin:0;padding:0}.base-layout,body,html{background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.base-layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--bg-primary);box-shadow:0 2px 4px var(--shadow);position:sticky;top:0;z-index:1000;transition:background-color .3s ease,box-shadow .3s ease}.nav-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:60px}.nav-brand{font-size:1.5rem;font-weight:700}.brand-link{font-family:"Noto Serif TC",serif;color:var(--text-primary);text-decoration:none;text-transform:uppercase;transition:color .3s ease}.brand-link:active,.brand-link:focus{outline:none}.nav-right{gap:20px}.nav-actions,.nav-right{display:flex;align-items:center}.nav-actions{gap:12px}.nav-menu{display:flex;list-style:none;margin:0;padding:0;gap:30px}.mobile-menu-toggle{display:none;color:var(--text-primary);background:transparent;border:none;cursor:pointer;padding:8px;transition:all .3s ease;font-size:1.5rem;align-items:center;justify-content:center}.mobile-menu-toggle:hover{color:var(--accent-color)}.menu-icon{display:block;line-height:1;width:1.5rem;height:1.5rem}.nav-link{color:var(--text-primary);text-decoration:none;font-weight:500;padding:8px 0;transition:color .3s ease;position:relative}.nav-link:hover{color:var(--accent-color)}.nav-link.router-link-exact-active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent-color)}.lang-toggle{width:1.875rem;height:1.875rem;color:var(--text-primary);background:transparent;border:1px solid var(--border-color);border-radius:50%;padding:0;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-align:center}.lang-toggle:hover{background:var(--bg-tertiary)}.theme-toggle{color:var(--text-primary);background:transparent;border:1px solid var(--border-color);border-radius:50%;width:1.875rem;height:1.875rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:0;font-size:1rem}.theme-toggle:hover{background:var(--bg-tertiary);transform:scale(1.1)}.theme-icon{display:block;line-height:1}.main-content{flex:1;width:100%;transition:background-color .3s ease}#app,.main-content{background-color:var(--bg-primary)}#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text-primary);transition:background-color .3s ease,color .3s ease}@media (max-width:768px){.mobile-menu-toggle{display:flex}.nav-menu{position:fixed;top:60px;left:0;right:0;background:var(--bg-primary);flex-direction:column;padding:20px;gap:0;box-shadow:0 4px 6px var(--shadow);transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .3s ease,opacity .3s ease,visibility .3s ease;z-index:999;border-top:1px solid var(--border-color)}.nav-menu.nav-menu-open{transform:translateY(0);opacity:1;visibility:visible}.nav-menu li{width:100%;border-bottom:1px solid var(--border-color)}.nav-menu li:last-child{border-bottom:none}.nav-link{display:block;padding:15px 0;width:100%}.nav-link.router-link-exact-active:after{display:none}.nav-link.router-link-exact-active{color:var(--accent-color);font-weight:600}}@media (max-width:600px){.nav-container{padding:0 15px}.nav-brand{font-size:1.2rem}.nav-actions,.nav-right{gap:8px}.lang-toggle{font-size:.75rem}.lang-toggle,.theme-toggle{width:1.875rem;height:1.875rem;padding:0}.theme-toggle{font-size:1rem}}.footer{text-align:center;color:var(--text-secondary)}.footer,.footer-text{font-size:.875rem}.home{min-height:calc(100vh - 60px);background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}.container{max-width:1200px;margin:0 auto;padding:0 20px}.hero{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:0 20px 60px 20px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--bg-black) 0,var(--bg-primary) 100%);opacity:.5;z-index:0}.hero-content{max-width:1200px;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}.hero-text{animation:fadeInUp .8s ease-out;width:100%;max-width:100%;box-sizing:border-box}.hero-title{font-size:4.5rem;font-weight:700;line-height:1.2;margin-bottom:20px;color:var(--text-primary);transition:color .3s ease}.hero-title .greeting{display:block;font-size:2rem;font-weight:400;margin-bottom:10px;animation:fadeIn .5s ease-in}.hero-title .greeting .cursor{display:inline-block;margin-left:2px;animation:blink 1s infinite;font-weight:300}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.hero-title .name{font-family:"Noto Serif TC",serif;display:block;background:linear-gradient(135deg,var(--text-primary) 0,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.8rem;margin-bottom:20px;font-weight:500;transition:color .3s ease}.hero-description{font-size:1.2rem;color:var(--text-secondary);line-height:1.8;margin-bottom:40px;max-width:500px;transition:color .3s ease}.hero-actions{display:flex;gap:20px;flex-wrap:wrap;width:100%;max-width:100%}.hero-visual{animation:fadeInRight .8s ease-out}.code-block{background:var(--bg-secondary);border-radius:var(--border-radius-lg);overflow:hidden;box-shadow:0 10px 40px var(--shadow);border:1px solid var(--border-color);transition:all .3s ease}.code-block:hover{transform:translateY(-5px);box-shadow:0 15px 50px var(--shadow-hover)}.code-header{background:var(--bg-tertiary);padding:12px 20px;display:flex;gap:8px;border-bottom:1px solid var(--border-color)}.code-dot{width:12px;height:12px;border-radius:50%;background:var(--text-tertiary)}.code-dot:first-child{background:#ff5f56}.code-dot:nth-child(2){background:#ffbd2e}.code-dot:nth-child(3){background:#27c93f}.code-content{padding:30px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.95rem;line-height:1.8;background:var(--bg-secondary);color:var(--text-primary)}.code-line{margin-bottom:8px}.code-line.indent{padding-left:20px}.code-line.indent-more{padding-left:40px}:root .code-keyword{color:#8b3fa8}:root .code-variable{color:#c0392b}:root .code-operator{color:#34495e}:root .code-value{color:#1a1a1a}:root .code-property{color:#2980b9}:root .code-string{color:#27ae60}[data-theme=dark] .code-keyword{color:#c678dd}[data-theme=dark] .code-variable{color:#e06c75}[data-theme=dark] .code-operator{color:var(--text-secondary)}[data-theme=dark] .code-value{color:var(--text-primary)}[data-theme=dark] .code-property{color:#61afef}[data-theme=dark] .code-string{color:#98c379}.about-section{padding:100px 20px;background:var(--bg-secondary);transition:background-color .3s ease}.section-title{font-family:"Noto Serif TC",serif;font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:50px;color:var(--text-primary);position:relative;transition:color .3s ease}.section-title:after{content:"";position:absolute;bottom:-15px;left:50%;transform:translateX(-50%);width:60px;height:4px;background:var(--accent-color);border-radius:2px}.about-content{display:grid;grid-template-columns:2fr 1fr;gap:60px;align-items:center;max-width:1200px;margin:0 auto}.about-text-wrapper{text-align:left}.about-text{font-size:1.2rem;line-height:1.8;color:var(--text-secondary);transition:color .3s ease;margin:0;white-space:pre-line}.about-portrait{display:flex;justify-content:center;align-items:center}.portrait-image{width:100%;max-width:300px;height:auto;border-radius:var(--border-radius);-o-object-fit:cover;object-fit:cover;box-shadow:0 10px 40px var(--shadow);border:1px solid var(--border-color);transition:all .5s ease;filter:grayscale(70%) brightness(100%);-webkit-filter:grayscale(70%) brightness(100%)}.portrait-image:hover{filter:grayscale(0) brightness(100%)}.works-section{padding:100px 20px;background:var(--bg-primary);transition:background-color .3s ease}.works-description{text-align:center;color:var(--text-secondary);font-size:1.1rem;margin-bottom:50px;max-width:600px;margin-left:auto;margin-right:auto;transition:color .3s ease}.works-carousel{position:relative;overflow:hidden;margin:0 auto;max-width:1200px;border-radius:var(--border-radius-lg);width:100%}.works-track{padding:.5rem 0;display:flex;transition:transform .5s ease;will-change:transform;width:100%}.work-item{min-width:50%;max-width:50%;width:50%;flex-shrink:0;padding:0 10px;align-items:stretch}.work-item,.work-link{box-sizing:border-box;display:flex}.work-link{flex-direction:column;text-decoration:none;color:inherit;background:var(--bg-primary);border-radius:var(--border-radius-lg);overflow:hidden;border:1px solid var(--border-color);transition:all .3s ease;width:100%;height:100%}.work-link:hover{transform:translateY(-2px);border-color:var(--accent-color)}.work-thumbnail{width:100%;height:300px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.work-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.work-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.work-icon{font-size:4rem;color:var(--text-tertiary);opacity:.5}.work-info{padding:30px;display:flex;flex-direction:column;flex-grow:1}.work-title{font-size:1.5rem;font-weight:600;margin-bottom:12px;color:var(--text-primary);transition:color .3s ease}.work-description{color:var(--text-secondary);line-height:1.6;margin-bottom:20px;transition:color .3s ease;flex-grow:1}.work-tags{display:flex;flex-wrap:wrap;gap:8px}.work-tag{display:inline-block;padding:3px 6px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;transition:all .3s ease}.works-controls{gap:20px;margin-top:40px}.works-btn,.works-controls{display:flex;align-items:center;justify-content:center}.works-btn{width:48px;height:48px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .3s ease;font-size:1.5rem}.works-btn:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color);transform:scale(1.1)}.works-btn:disabled{opacity:.4;cursor:not-allowed}.works-dots{display:flex;gap:10px}.works-dot{width:12px;height:12px;border-radius:50%;border:none;background:var(--border-color);cursor:pointer;transition:all .3s ease;padding:0}.works-dot:hover{background:var(--accent-color);transform:scale(1.2)}.works-dot.active{background:var(--accent-color);width:32px;border-radius:var(--border-radius)}.skills-section{padding:100px 20px;background:var(--bg-primary);transition:background-color .3s ease}.skills-categories{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px;margin-top:60px}.skill-category{background:var(--bg-secondary);border-radius:var(--border-radius-lg);padding:30px;border:1px solid var(--border-color);transition:all .3s ease;animation:fadeInUp .6s ease-out both;cursor:default}.skill-category:hover{transform:translateY(-5px);box-shadow:0 10px 30px var(--shadow-hover);border-color:var(--accent-color)}.skill-category-title-container{display:inline-flex;align-items:center;justify-content:start;margin-bottom:1rem}.skill-icon{font-size:1.4rem;margin-right:.5rem;display:inline-flex;transition:all .3s ease}.skill-category:hover .skill-icon{transform:scale(1.1)}.category-title{font-size:1.3rem;font-weight:600;color:var(--text-primary);transition:color .3s ease;display:inline-flex}.category-skills{color:var(--text-secondary);line-height:1.8;transition:color .3s ease;font-size:1rem}.cta-section{padding:100px 20px;background:var(--bg-inverse);text-align:center;color:var(--text-inverse);position:relative}.cta-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.1);z-index:0}.cta-section .container{position:relative;z-index:1}.cta-title{font-family:"Noto Serif TC",serif;font-size:2.5rem;font-weight:700;margin-bottom:20px}.cta-description{font-size:1.2rem;margin-bottom:40px;opacity:.95;max-width:600px;margin-left:auto;margin-right:auto}.cta-actions{gap:20px;flex-wrap:wrap}.cta-actions,.social-link{display:flex;justify-content:center;align-items:center}.social-link{width:56px;height:56px;border-radius:50%;background:rgba(var(--border-color-inverse),.1);border:2px solid var(--border-color-inverse);color:var(--text-inverse);text-decoration:none;transition:all .3s ease;backdrop-filter:blur(10px)}.social-link:hover{border-color:var(--border-color-inverse);color:var(--text-inverse);transform:translateY(-3px) scale(1.05);box-shadow:0 8px 12px var(--shadow-inverse)}.social-link[data-social=github]:hover{background:#2b3137;border-color:#2b3137;color:var(--text-color)}.social-link[data-social=linkedin]:hover{background:#0077b5;border-color:#0077b5}.social-link[data-social=instagram]:hover{background:linear-gradient(45deg,#f09433,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888);border-color:#e4405f}.social-link[data-social=email]:hover{background:var(--accent-color);border-color:var(--accent-color)}.social-link:active{transform:translateY(-1px) scale(1.02)}.social-icon{font-size:1.75rem;width:1.75rem;height:1.75rem}.social-icon svg{width:100%;height:100%;fill:currentColor;color:inherit}.social-icon svg *{fill:currentColor;stroke:currentColor}.social-link[data-social=github]:hover{color:var(--white)}.social-link[data-social=github]:hover .social-icon svg,.social-link[data-social=github]:hover .social-icon svg *{fill:var(--white)!important;stroke:var(--white)!important;color:var(--white)}.social-link[data-social=linkedin]:hover{color:var(--white)}.social-link[data-social=linkedin]:hover .social-icon svg,.social-link[data-social=linkedin]:hover .social-icon svg *{fill:var(--white)!important;stroke:var(--white)!important;color:var(--white)}.social-link[data-social=instagram]:hover{color:var(--white)}.social-link[data-social=instagram]:hover .social-icon svg,.social-link[data-social=instagram]:hover .social-icon svg *{fill:var(--white)!important;stroke:var(--white)!important;color:var(--white)}.social-link[data-social=email]:hover{color:var(--white)}.social-link[data-social=email]:hover .social-icon svg,.social-link[data-social=email]:hover .social-icon svg *{fill:var(--white)!important;stroke:var(--white)!important;color:var(--white)}.btn{padding:14px 32px;border:none;border-radius:var(--border-radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px var(--aura-accent-hover)}.btn-outline-primary{background:transparent;color:var(--accent-color);border:2px solid var(--accent-color)}.btn-outline-primary:hover{background:var(--accent-color);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px var(--aura-accent-hover)}.btn-mono{color:#fff}.btn-mono,.btn-mono:hover{background:var(--text-primary)}.btn-mono:hover{transform:translateY(-2px);box-shadow:0 8px 20px var(--shadow-hover)}.btn-outline-mono{background:transparent;color:var(--text-primary);border:2px solid var(--text-primary)}.btn-outline-mono:hover{background:var(--text-primary);color:#fff;transform:translateY(-2px);box-shadow:0 8px 20px var(--shadow-hover)}[data-theme=dark] .btn-mono{background:#fff;color:#1a1a1a}[data-theme=dark] .btn-mono:hover{background:#f0f0f0;transform:translateY(-2px);box-shadow:0 8px 20px hsla(0,0%,100%,.2)}[data-theme=dark] .btn-outline-mono{background:transparent;color:#fff;border:2px solid #fff}[data-theme=dark] .btn-outline-mono:hover{background:#fff;color:#1a1a1a;transform:translateY(-2px);box-shadow:0 8px 20px hsla(0,0%,100%,.2)}.btn-secondary{background:transparent;color:var(--text-primary);border:2px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--accent-color);transform:translateY(-2px)}.btn-outline{background:transparent;color:#fff;border:2px solid #fff}.btn-outline:hover{background:#fff;color:var(--accent-color);transform:translateY(-2px)}.btn-large{padding:16px 40px;font-size:1.1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@media (max-width:968px){.hero-content{grid-template-columns:1fr;gap:40px;text-align:center}.hero-title{font-size:3.5rem}.hero-description{max-width:100%;margin-left:auto}.hero-actions{justify-content:center;gap:16px}.hero-visual{order:-1}}@media (max-width:600px){.hero{padding:40px 20px;min-height:auto}.hero-title{font-size:2.5rem}.hero-title .greeting{font-size:1.5rem}.hero-subtitle{font-size:1.4rem}.hero-description{font-size:1rem}.section-title{font-size:2rem}.about-section,.cta-section,.skills-section{padding:60px 20px}.about-content{grid-template-columns:1fr;gap:40px}.about-text-wrapper{text-align:center}.portrait-image{max-width:300px}.skills-categories{grid-template-columns:1fr}.hero-actions{flex-direction:column;gap:12px;width:100%}.btn{width:100%;max-width:100%;box-sizing:border-box}.cta-actions{gap:16px}.social-link{width:52px;height:52px}.social-icon{font-size:1.5rem;width:1.5rem;height:1.5rem}.code-content{font-size:.8rem;padding:20px}.works-section{padding:60px 20px}.works-description{font-size:1rem;margin-bottom:30px}.work-item{min-width:100%;max-width:100%;width:100%;padding:0}.work-thumbnail{height:200px}.work-info{padding:20px}.work-title{font-size:1.25rem}.work-description{font-size:.95rem}.works-controls{margin-top:30px;gap:15px}.works-btn{width:40px;height:40px;font-size:1.25rem}}