@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap);@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css);#app{font-family:Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-align:center;color:#2c3e50}nav{padding:30px}nav a{font-weight:700;color:#2c3e50}nav a.router-link-exact-active{color:#42b983}[data-v-1297273d] nav{position:fixed;top:0;left:0;width:100%;z-index:1000;background-color:transparent;backdrop-filter:blur(0);transition:background-color .3s ease,backdrop-filter .3s ease;padding:20px 0}[data-v-1297273d] nav.scrolled{background-color:var(--glass-bg,hsla(0,0%,100%,.7));backdrop-filter:blur(var(--blur-amount,8px));border-bottom:1px solid var(--glass-border,#e0e0e0)}[data-v-1297273d] .nav-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 20px;position:relative}[data-v-1297273d] .nav-right-content{display:flex;align-items:center;flex-wrap:nowrap}[data-v-1297273d] .logo{font-size:1.8rem;font-weight:700;color:var(--text-color,#1a1a1a);letter-spacing:-.05em;transition:color .2s ease}[data-v-1297273d] .logo:hover{text-decoration:none;cursor:pointer;color:var(--accent-color,#007aff)}[data-v-1297273d] .nav-links{list-style:none;margin:0;padding:0;display:flex;align-items:center;align-self:center}[data-v-1297273d] .nav-links li{margin-left:30px;display:flex;align-items:center;align-self:center}[data-v-1297273d] .nav-links li a{color:var(--text-dimmed-color,#555);font-weight:500;font-size:1.05rem;transition:color .2s ease;position:relative;padding-bottom:5px}[data-v-1297273d] .nav-links li a:hover{color:var(--accent-color,#007aff);text-decoration:none}[data-v-1297273d] .nav-links li a:after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background-color:var(--accent-color,#007aff);transition:width .3s ease}[data-v-1297273d] .nav-links li a:hover:after{width:100%}[data-v-1297273d] .menu-icon{display:none;font-size:1.8rem;color:var(--text-color,#1a1a1a);cursor:pointer;padding:10px;border-radius:8px;transition:all .3s ease}[data-v-1297273d] .menu-icon:hover{background-color:var(--glass-bg,hsla(0,0%,100%,.7));backdrop-filter:blur(var(--blur-amount,8px))}[data-v-1297273d] .menu-icon i{transition:transform .3s ease}[data-v-1297273d] .menu-icon:hover i{transform:scale(1.1)}[data-v-1297273d] .theme-toggle{color:var(--text-color,#1a1a1a);cursor:pointer;margin-left:30px;padding:10px;border-radius:8px;transition:color .2s ease,background-color .3s ease;display:flex;align-items:center;justify-content:center;align-self:center;font-size:1.5rem}[data-v-1297273d] .theme-toggle:hover{color:var(--accent-color,#007aff)}@media (max-width:1024px){[data-v-1297273d] .nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;width:100%;background-color:var(--secondary-bg-color,#fff);border-top:1px solid var(--border-color,#e0e0e0);box-shadow:0 5px 15px rgba(0,0,0,.1);padding:20px 0;animation:slideDown-1297273d .3s ease-out forwards}[data-v-1297273d] .nav-links.mobile-menu-open{display:flex}[data-v-1297273d] .nav-links li{margin:10px 0;text-align:center}[data-v-1297273d] .nav-links li a{padding:10px 20px;display:block}[data-v-1297273d] .menu-icon{display:block}@keyframes slideDown-1297273d{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}}@media (max-width:1024px){[data-v-1297273d] .nav-right-content{display:none}[data-v-1297273d] .menu-icon{display:block;position:relative;z-index:1002}[data-v-1297273d] .mobile-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:hsla(0,0%,100%,.98);backdrop-filter:blur(28px) saturate(180%);z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center;animation:none;box-shadow:0 8px 32px 0 rgba(31,38,135,.18);color:var(--text-color,#1a1a1a)}body.dark-mode[data-v-1297273d] .mobile-menu-overlay{background:rgba(30,32,40,.98);color:#fff;box-shadow:0 8px 32px 0 rgba(0,0,0,.32)}[data-v-1297273d] .close-btn{position:static;background:hsla(0,0%,100%,.7);border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;z-index:2001;transition:background .2s}body.dark-mode[data-v-1297273d] .close-btn{background:rgba(40,44,52,.7);color:#fff}[data-v-1297273d] .close-btn:hover{background:hsla(0,0%,100%,.9)}[data-v-1297273d] .mobile-menu-list{list-style:none;padding:0;margin:40px 0 0 0;width:100%;display:flex;flex-direction:column;align-items:center;gap:24px}[data-v-1297273d] .mobile-menu-list li a{font-size:1.4rem;color:inherit;font-weight:600;letter-spacing:.02em;padding:12px 32px;border-radius:8px;transition:background .2s,color .2s}[data-v-1297273d] .mobile-menu-list li a:hover{background:var(--accent-color,#007aff);color:#fff}body.dark-mode[data-v-1297273d] .mobile-menu-list li a:hover{background:#222e3a;color:#fff}[data-v-1297273d] .menu-top-bar{position:absolute;top:24px;right:24px;display:flex;flex-direction:row;align-items:center;gap:16px;z-index:2001}[data-v-1297273d] .mobile-theme-toggle{position:static;background:hsla(0,0%,100%,.7);border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;box-shadow:0 2px 8px rgba(0,0,0,.08);cursor:pointer;transition:background .2s}body.dark-mode[data-v-1297273d] .mobile-theme-toggle{background:rgba(40,44,52,.7);color:#fff}[data-v-1297273d] .mobile-theme-toggle:hover{background:hsla(0,0%,100%,.9)}}.mobile-menu-fade-slide-enter-active[data-v-1297273d],.mobile-menu-fade-slide-leave-active[data-v-1297273d]{transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1)}.mobile-menu-fade-slide-enter-from[data-v-1297273d],.mobile-menu-fade-slide-leave-to[data-v-1297273d]{opacity:0;transform:translateY(-24px)}.mobile-menu-fade-slide-enter-to[data-v-1297273d],.mobile-menu-fade-slide-leave-from[data-v-1297273d]{opacity:1;transform:translateY(0)}[data-v-1297273d] .mobile-menu-list li{opacity:0;transform:translateY(24px);transition:opacity .4s,transform .4s}[data-v-1297273d] .mobile-menu-list.menu-animate li{opacity:1;transform:translateY(0)}body.dark-mode .mobile-menu-overlay{background:rgba(30,32,40,.98)!important;color:#fff!important}body.dark-mode .mobile-menu-list li a{color:#fff!important}body.dark-mode .close-btn,body.dark-mode .mobile-theme-toggle{background:rgba(40,44,52,.7)!important;color:#fff!important}body.dark-mode .mobile-menu-list li a:hover{background:#222e3a!important;color:#fff!important}:deep(.close-btn):active,:deep(.mobile-theme-toggle):active{transform:scale(.92);transition:transform .1s}.footer[data-v-a0500da0]{display:flex;flex-direction:row;justify-content:center;align-items:center;flex-wrap:wrap;gap:0 8px;text-align:center;font-size:.85rem;color:#888;margin:32px 0 12px 0;line-height:1.7;letter-spacing:.01em}.icp[data-v-a0500da0]{color:#888;text-decoration:none;transition:color .3s ease}.icp[data-v-a0500da0]:hover{color:#666}@media (max-width:1024px){.footer[data-v-a0500da0]{flex-direction:column;gap:2px 0;font-size:.92rem}}:root{--bg-color:#f8f8f8;--secondary-bg-color:#fff;--text-color:#1a1a1a;--text-dimmed-color:#555;--accent-color:#007aff;--accent-color-rgb:0,122,255;--glass-bg:hsla(0,0%,100%,.7);--glass-border:hsla(0,0%,86%,.5);--border-color:#ccc;--blur-amount:8px;--shadow-color-rgb:0,0,0;--hero-gradient-start:#007aff;--hero-gradient-middle:#39f;--hero-gradient-end:#2193b0;--project-gradient-1-start:#007aff;--project-gradient-1-end:#2193b0;--project-gradient-2-start:#3a1c71;--project-gradient-2-middle:#d76d77;--project-gradient-2-end:#ffaf7b;--project-gradient-3-start:#f9d423;--project-gradient-3-end:#ff4e50;--project-gradient-4-start:#1d976c;--project-gradient-4-end:#93f9b9;--project-gradient-5-start:#4776e6;--project-gradient-5-end:#8e54e9;--project-gradient-6-start:#fc5c7d;--project-gradient-6-end:#6a82fb;--glass-bg-hover:rgba(245,250,255,.98);--transition-bezier:cubic-bezier(0.34,1.56,0.64,1)}body,html{margin:0;font-family:Inter,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-color);color:var(--text-color);scroll-behavior:smooth;overflow-x:hidden;transition:background-color .6s ease,color .3s ease}a,a:hover{color:var(--accent-color);text-decoration:none}.container{max-width:1200px;margin:0 auto;padding:0 20px}nav{position:fixed;top:0;left:0;width:100%;z-index:1000;background-color:transparent;backdrop-filter:blur(0);transition:background-color .3s ease,backdrop-filter .3s ease;padding:20px 0}nav.scrolled{background-color:var(--glass-bg);backdrop-filter:blur(var(--blur-amount));border-bottom:1px solid var(--glass-border)}.nav-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 20px;position:relative}.nav-right-content{display:flex;align-items:center;flex-wrap:nowrap}.logo{font-size:1.8rem;font-weight:700;color:var(--text-color);letter-spacing:-.05em;transition:color .2s ease}.logo:hover{text-decoration:none;cursor:pointer;color:var(--accent-color)}.nav-links{list-style:none;margin:0;padding:0;align-self:center}.nav-links,.nav-links li{display:flex;align-items:center}.nav-links li{margin-left:30px}.nav-links li a{color:var(--text-dimmed-color);font-weight:500;font-size:1.05rem;transition:color .2s ease;position:relative;padding-bottom:5px}.nav-links li a:hover{color:var(--accent-color);text-decoration:none}.nav-links li a:after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background-color:var(--accent-color);transition:width .3s ease}.nav-links li a:hover:after{width:100%}.menu-icon{display:none;font-size:1.8rem;z-index:1001}.menu-icon,.theme-toggle{color:var(--text-color);cursor:pointer}.theme-toggle{margin-left:30px;padding:10px;border-radius:8px;transition:color .2s ease,background-color .3s ease;display:flex;align-items:center;justify-content:center;align-self:center;font-size:1.5rem}.theme-toggle:hover{color:var(--accent-color)}.theme-toggle img{width:1.5rem;height:1.5rem;vertical-align:middle}.hero-section{position:relative;height:100vh;display:flex;flex-direction:column;justify-content:center;text-align:center;padding-top:5vh;background-color:var(--bg-color);background-size:cover;transition:background-color .6s ease}.hero-content{z-index:10;position:relative;margin-top:-15vh}.hero-content,.hero-content h1{transition:transform .1s linear,opacity .1s linear}.hero-content h1{font-size:4.8rem;font-weight:700;line-height:1.2;margin-bottom:20px;letter-spacing:-.06em;min-height:4.8rem}.hero-content .gradient-text{background:linear-gradient(90deg,var(--hero-gradient-start),var(--hero-gradient-middle),var(--hero-gradient-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-content p{font-size:1.3rem;color:var(--text-color);margin-bottom:40px;line-height:1.6;transition:transform .1s linear,opacity .1s linear}.hero-content .cta-button{background-color:var(--accent-color);color:#fff;padding:14px 30px;border:none;border-radius:35px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .5s cubic-bezier(.25,.8,.25,1);box-shadow:0 8px 20px rgba(var(--accent-color-rgb),.4)}.hero-content .cta-button:hover{background-color:var(--secondary-accent-color,#006ee6);box-shadow:0 15px 30px rgba(var(--accent-color-rgb),.6);transform:translateY(-8px) scale(1.05)}.hero-content .cta-button a{color:inherit;text-decoration:none}@keyframes pulse{0%{transform:scale(1) translateX(-50%);opacity:.7}to{transform:scale(1.05) translateX(-50%);opacity:.85}}section{position:relative;padding:120px 0;transition:background-color .6s ease}section:before{display:none!important}h2{font-size:3.5rem;font-weight:700;margin-bottom:60px;letter-spacing:-.04em;position:relative;display:inline-block;color:var(--text-color)}h2:after{content:"";position:absolute;left:50%;bottom:-15px;transform:translateX(-50%);width:80px;height:4px;background-color:var(--accent-color);border-radius:2px}p{font-size:1.15rem;line-height:1.8;color:var(--text-dimmed-color)}.about-section{background:var(--bg-color);padding:100px 0 80px 0;text-align:center}.about-content{max-width:600px;margin:0 auto;background:var(--glass-bg);box-shadow:0 8px 32px 0 rgba(var(--shadow-color-rgb),.1);border-radius:20px;padding:48px 32px 36px 32px;backdrop-filter:blur(var(--blur-amount));position:relative;border:1px solid var(--glass-border)}.about-avatar{width:96px;height:96px;border-radius:50%;margin-bottom:24px;box-shadow:0 4px 16px rgba(var(--shadow-color-rgb),.1);-o-object-fit:cover;object-fit:cover}.about-intro{font-size:1.25rem;color:var(--text-color);margin-bottom:32px;margin-top:10px}.about-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 32px;justify-content:center;margin-top:18px}.about-info-item{text-align:left}@media (max-width:600px){.about-content{padding:32px 10px 24px 10px}.about-info-grid{grid-template-columns:1fr;gap:12px 0}}.expertise-section{background-color:var(--secondary-bg-color);padding:25vh 0}.expertise-section .expertise-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;max-width:1000px;margin:0 auto}.expertise-section .expertise-card{background:var(--glass-bg);box-shadow:0 8px 32px 0 rgba(var(--shadow-color-rgb),.18);backdrop-filter:blur(var(--blur-amount));border-radius:18px;padding:40px 30px;text-align:center;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;border:1px solid var(--glass-border);will-change:transform,box-shadow,background-color}.expertise-section .expertise-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px rgba(var(--shadow-color-rgb),.16);background:var(--glass-bg-hover,hsla(0,0%,100%,.85));border-color:var(--accent-color)}.expertise-section .expertise-card i{font-size:3.5rem;color:var(--accent-color);margin-bottom:25px;display:block}.expertise-section .expertise-card h3{font-size:2.1rem;color:var(--text-color);margin-bottom:15px}.expertise-section .expertise-card p{font-size:1rem;color:var(--text-dimmed-color)}.skills-section{background-color:var(--bg-color);padding:25vh 0}.skills-section .skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px;max-width:1000px;margin:0 auto}.skills-section .skill-category{background:var(--glass-bg);box-shadow:0 8px 32px 0 rgba(var(--shadow-color-rgb),.18);backdrop-filter:blur(var(--blur-amount));border-radius:15px;padding:35px;text-align:left;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;border:1px solid var(--glass-border);will-change:transform,box-shadow,background-color}.skills-section .skill-category:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px rgba(var(--shadow-color-rgb),.16);background:var(--glass-bg-hover,hsla(0,0%,100%,.85));border-color:var(--accent-color)}.skills-section .skill-category h3{font-size:1.8rem;color:var(--text-color);margin-bottom:25px;position:relative;padding-bottom:10px}.skills-section .skill-category h3:after{content:"";position:absolute;left:0;bottom:0;width:50px;height:3px;background-color:var(--accent-color);border-radius:1.5px}.skills-section .skill-category ul{list-style:none;padding:0;margin:0}.skills-section .skill-category ul li{display:inline-block;margin:5px}.skills-section .skill-category ul li .skill-tag{display:inline-block;background-color:var(--secondary-bg-color);color:var(--text-color);padding:7px 14px;border-radius:18px;font-size:.98rem;font-weight:500;border:1px solid var(--border-color);transition:all .4s ease-out;box-shadow:0 2px 5px rgba(var(--shadow-color-rgb),.05)}.skills-section .skill-category ul li .skill-tag:hover{background-color:rgba(var(--accent-color-rgb),.1);border-color:var(--accent-color);box-shadow:0 3px 8px rgba(var(--shadow-color-rgb),.1);transform:translateY(-2px)}.skills-section .skill-category ul li img{display:none}.skills-section .skill-category ul li:last-child{margin-bottom:0}.projects-section{background-color:var(--secondary-bg-color)}.project-filter-buttons{text-align:center;margin-bottom:40px}.project-filter-buttons button{background-color:var(--secondary-bg-color);color:var(--text-color);border:1px solid var(--border-color);padding:10px 20px;margin:0 10px;border-radius:20px;cursor:pointer;font-size:1.05rem;transition:all .3s ease}.project-filter-buttons button:hover{background-color:rgba(var(--accent-color-rgb),.1);border-color:var(--accent-color);color:var(--accent-color)}.project-filter-buttons button.active{background-color:var(--accent-color);color:#fff;border-color:var(--accent-color)}.projects-section .projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:40px;max-width:1200px;margin:0 auto;transition:opacity .5s ease}.projects-section .project-card{background:var(--glass-bg);box-shadow:0 8px 32px 0 rgba(var(--shadow-color-rgb),.18);backdrop-filter:blur(var(--blur-amount));border-radius:20px;overflow:hidden;text-align:left;transition:all .4s cubic-bezier(.34,1.56,.64,1);position:relative;border:1px solid var(--glass-border);will-change:transform,box-shadow,background-color}.projects-section .project-card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px rgba(var(--shadow-color-rgb),.16);background:var(--glass-bg-hover,hsla(0,0%,100%,.85));border-color:var(--accent-color)}.projects-section .project-card .project-visual{width:100%;height:220px;border-bottom:1px solid var(--border-color);display:flex;justify-content:center;align-items:center;font-size:5rem;color:#fff;background-size:cover;background-position:50%;position:relative;overflow:hidden}.projects-section .project-visual.visual-gradient-1{background:linear-gradient(135deg,var(--project-gradient-1-start) 0,var(--project-gradient-1-end) 100%)}.projects-section .project-visual.visual-gradient-2{background:radial-gradient(circle at center,var(--project-gradient-2-start) 0,var(--project-gradient-2-middle) 50%,var(--project-gradient-2-end) 100%)}.projects-section .project-visual.visual-gradient-3{background:linear-gradient(45deg,var(--project-gradient-3-start) 0,var(--project-gradient-3-end) 100%)}.projects-section .project-visual.visual-gradient-4{background:linear-gradient(135deg,var(--project-gradient-4-start) 0,var(--project-gradient-4-end) 100%)}.projects-section .project-visual.visual-gradient-5{background:linear-gradient(45deg,var(--project-gradient-5-start) 0,var(--project-gradient-5-end) 100%)}.projects-section .project-visual.visual-gradient-6{background:linear-gradient(135deg,var(--project-gradient-6-start) 0,var(--project-gradient-6-end) 100%)}.projects-section .project-card .project-info{padding:30px}.projects-section .project-card .project-info h3{font-size:1.9rem;color:var(--text-color);margin-top:0;margin-bottom:15px}.projects-section .project-card .project-info p{font-size:1rem;color:var(--text-dimmed-color);margin-bottom:20px}.projects-section .project-card .project-info .project-tech{margin-bottom:20px}.projects-section .project-card .project-info .project-tech span{display:inline-block;background-color:rgba(var(--accent-color-rgb),.1);color:var(--accent-color);padding:6px 12px;border-radius:16px;font-size:.9rem;margin-right:8px;margin-bottom:8px;border:1px solid rgba(var(--accent-color-rgb),.3)}.projects-section .project-card .project-info .project-link{display:inline-flex;align-items:center;color:var(--accent-color);font-weight:600;font-size:1.05rem}.projects-section .project-card .project-info .project-link i{margin-left:8px;transition:transform .2s ease}.projects-section .project-card .project-info .project-link:hover i{transform:translateX(5px)}.projects-section .project-card .project-info .project-link:hover{color:var(--accent-color)}.no-projects-message{text-align:center;color:var(--text-dimmed-color);font-size:1.1rem;margin-top:30px;grid-column:1/-1}.blog-section{background-color:var(--bg-color)}.blog-section .blog-intro{max-width:800px;margin:0 auto 60px}.blog-section .blog-posts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:35px;max-width:1200px;margin:0 auto 60px}.blog-section .blog-post-card{background-color:var(--glass-bg);border:1px solid var(--glass-border);border-radius:18px;padding:30px;text-align:left;backdrop-filter:blur(calc(var(--blur-amount)/2));transition:transform .4s cubic-bezier(.2,.8,.2,1),box-shadow .4s ease,opacity .5s ease;color:var(--text-color)}.blog-section .blog-post-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 15px 30px rgba(var(--shadow-color-rgb),.35)}.blog-section .blog-post-card h3{font-size:1.6rem;color:var(--text-color);margin-top:0;margin-bottom:10px;line-height:1.4}.blog-section .blog-post-card .post-meta{font-size:.95rem;color:var(--text-dimmed-color);margin-bottom:15px}.blog-section .blog-post-card p{font-size:1rem;color:var(--text-dimmed-color);margin-bottom:25px}.blog-section .blog-post-card .read-more{display:inline-flex;align-items:center;color:var(--accent-color);font-weight:600;font-size:1rem}.blog-section .blog-post-card .read-more i{margin-left:8px;transition:transform .2s ease}.blog-section .blog-post-card .read-more:hover i{transform:translateX(5px)}.blog-section .blog-cta{margin-top:40px}.contact-section{background-color:var(--bg-color)}.contact-section .contact-intro{max-width:800px;margin:0 auto 50px}.contact-section .contact-details{display:flex;justify-content:center;flex-wrap:wrap;gap:40px;margin-bottom:60px}.contact-section .contact-item{display:flex;align-items:center;font-size:1.2rem;color:var(--text-dimmed-color);transition:color .2s ease}.contact-section .contact-item i{font-size:1.6rem;margin-right:15px;color:var(--accent-color)}.contact-section .contact-item a{color:var(--text-dimmed-color)}.contact-section .contact-item a:hover{color:var(--accent-color);text-decoration:none}.contact-section .contact-item:hover{color:var(--accent-color);cursor:pointer}.contact-section .contact-form{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:25px}.contact-section .contact-form input,.contact-section .contact-form textarea{padding:18px 25px;border:1px solid var(--border-color);background-color:var(--glass-bg);border-radius:12px;font-size:1.1rem;color:var(--text-color);outline:none;transition:border-color .3s ease,box-shadow .3s ease,background-color .3s ease,color .3s ease}.contact-section .contact-form input:focus,.contact-section .contact-form textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 4px rgba(var(--accent-color-rgb),.2)}.contact-section .contact-form input::-moz-placeholder,.contact-section .contact-form textarea::-moz-placeholder{color:var(--text-dimmed-color);opacity:1}.contact-section .contact-form input::placeholder,.contact-section .contact-form textarea::placeholder{color:var(--text-dimmed-color);opacity:1}.contact-section .contact-form textarea{resize:vertical;min-height:150px}.contact-section .contact-form .submit-button{background-color:var(--accent-color);color:#fff;padding:18px 30px;border:none;border-radius:12px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 15px rgba(var(--accent-color-rgb),.4)}.contact-section .contact-form .submit-button:hover{background-color:var(--secondary-accent-color,#006ee6);box-shadow:0 8px 20px rgba(var(--accent-color-rgb),.6);transform:translateY(-3px)}.contact-section .contact-form .submit-button:active{transform:translateY(0)}footer{padding:40px 0;text-align:center;background-color:var(--bg-color);transition:background-color .3s ease}footer:hover{cursor:default}footer p{font-size:.95rem;margin:0}footer p,footer p a{color:var(--text-dimmed-color)}footer p a{text-decoration:none;transition:color .2s ease}footer p a:hover{color:var(--text-color)}@media (max-width:992px){.nav-content{flex-direction:row;justify-content:space-between;align-items:center}.nav-links{display:none;flex-direction:column;position:absolute;top:100%;left:0;width:100%;background-color:var(--secondary-bg-color);border-top:1px solid var(--border-color);box-shadow:0 5px 15px rgba(var(--shadow-color-rgb),.3);padding:20px 0;animation:slideDown .3s ease-out forwards}.nav-links.mobile-menu-open{display:flex}.nav-links li{margin:10px 0;text-align:center}.nav-links li a{padding:10px 20px;display:block}.menu-icon{display:block}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.hero-section .hero-content h1{font-size:3.5rem}.hero-section .hero-content p{font-size:1.2rem}h2{font-size:2.8rem}.blog-posts-grid,.expertise-grid,.projects-grid,.skills-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.stats-grid{flex-direction:column;gap:30px}}@media (max-width:768px){.hero-section .hero-content h1{font-size:3.2rem;margin-bottom:0}.hero-section{font-size:1rem;margin-bottom:28px}.hero-content p{font-size:1rem;margin-bottom:40px;margin-top:0}h2{font-size:2.2rem}section{padding:80px 0}.blog-posts-grid,.expertise-grid,.projects-grid,.skills-grid{grid-template-columns:1fr}.contact-details{flex-direction:column;align-items:center}}@media (max-width:480px){.main-view .hero-content h1{font-size:2.8rem!important;margin-bottom:10px!important}.main-view .hero-content p{font-size:1rem!important;margin-bottom:18px!important;margin-top:0!important}.main-view .hero-content .cta-button{margin-top:0!important;padding:10px 20px!important}.nav-links li a{font-size:.9rem}.stats-grid .stat-item .stat-number{font-size:2.5rem}.hero-content p{font-size:1rem!important}}.logo-img{width:40px;height:40px;border-radius:10px;vertical-align:middle;box-shadow:0 4px 16px rgba(var(--shadow-color-rgb),.1)}.blog-list-item,.expertise-card,.modern-tool-card,.project-card,.skill-category{background:var(--glass-bg);box-shadow:0 8px 32px 0 rgba(var(--shadow-color-rgb),.12);backdrop-filter:blur(var(--blur-amount));border-radius:18px;transition:all .4s cubic-bezier(.34,1.56,.64,1);border:1px solid var(--glass-border);will-change:transform,box-shadow,background-color}.blog-list-item:hover,.expertise-card:hover,.modern-tool-card:hover,.project-card:hover,.skill-category:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px rgba(var(--shadow-color-rgb),.16);background:var(--glass-bg-hover,hsla(0,0%,100%,.85));border-color:var(--accent-color)}.cta-button{background:linear-gradient(90deg,var(--accent-color) 0,var(--hero-gradient-end) 100%);color:#fff;box-shadow:0 8px 20px rgba(var(--accent-color-rgb),.4);border-radius:35px;font-weight:600;transition:all .5s cubic-bezier(.25,.8,.25,1)}.cta-button:hover{background:linear-gradient(90deg,var(--secondary-accent-color,#006ee6) 0,var(--hero-gradient-end) 100%);box-shadow:0 15px 30px rgba(var(--accent-color-rgb),.6);transform:translateY(-8px) scale(1.05)}section.expertise-section{background:var(--secondary-bg-color)}section.skills-section{background:var(--bg-color)}section.projects-section{background:var(--secondary-bg-color)}section.blog-section,section.contact-section{background:var(--bg-color)}.about-content.no-card{background:none;box-shadow:none;border-radius:0;padding:0;max-width:600px;margin:0 auto;border:none}.about-info-list{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:18px}.about-info-item{font-size:1.08rem;color:var(--text-dimmed-color);text-align:center}.about-info-item .label{color:var(--accent-color);font-weight:600;margin-right:6px}.main-view{position:relative;overflow-x:hidden;overflow-y:auto;background-color:var(--bg-color);transition:background-color .6s ease}.toast-notification{position:fixed;bottom:50px;left:50%;transform:translateX(-50%);background-color:rgba(0,0,0,.7);color:#fff;padding:12px 20px;border-radius:8px;z-index:2000;opacity:0;pointer-events:none}.toast-notification,.toast-notification.v-enter-active,.toast-notification.v-leave-active{transition:opacity .3s ease-in-out}.toast-notification.v-enter-from,.toast-notification.v-leave-to{opacity:0}.toast-notification.v-enter-to,.toast-notification.v-leave-from{opacity:1}.site-footer{text-align:center;color:#666;font-size:1.1rem;padding:32px 0 16px 0;background:#fafafa}.footer-row{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 16px}.footer-row span{white-space:nowrap}@media (max-width:480px){.footer-row{flex-direction:column;gap:2px 0}.footer-row span{white-space:normal}}.footer{display:flex;flex-direction:row;justify-content:center;align-items:center;flex-wrap:wrap;gap:0 8px;text-align:center;font-size:.85rem;color:#888;margin:32px 0 12px 0;line-height:1.7;letter-spacing:.01em}@media (max-width:480px){.footer{flex-direction:column;gap:2px 0;font-size:.92rem}}.dark-mode{--glass-bg-hover:rgba(40,50,70,.927)}.smart-tools-modern[data-v-34e9c722]{min-height:100vh;background:linear-gradient(120deg,#e0e7ef,#f7fafd);padding-bottom:60px;box-sizing:border-box}.modern-header[data-v-34e9c722]{text-align:center;padding:70px 0 36px 0}.modern-header h1[data-v-34e9c722]{font-size:3.2rem;font-weight:800;letter-spacing:-.04em;color:#1a2233;margin-bottom:12px;text-shadow:0 2px 24px #fff8,0 1px 0 #fff}.subtitle[data-v-34e9c722]{color:#7b8ca7;font-size:1.18rem;font-weight:400;margin-bottom:0;letter-spacing:.01em;text-decoration:none}.modern-tools-grid[data-v-34e9c722]{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:38px;max-width:1280px;margin:0 auto;padding:24px 24px 0 24px}.modern-tool-card[data-v-34e9c722]{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:38px 22px 28px 22px;border-radius:36px;min-height:270px;background:hsla(0,0%,100%,.55);box-shadow:0 8px 32px 0 rgba(31,38,135,.1),0 1.5px 8px 0 #fff6;border:1.5px solid hsla(0,0%,100%,.35);backdrop-filter:blur(22px) saturate(1.3);transition:transform .28s cubic-bezier(.4,0,.2,1),box-shadow .28s,background .28s;cursor:pointer;outline:none;position:relative;overflow:hidden;animation:modernCardIn-34e9c722 .7s cubic-bezier(.4,0,.2,1) both}@keyframes modernCardIn-34e9c722{0%{opacity:0;transform:translateY(60px) scale(.97)}to{opacity:1;transform:none}}.modern-tool-card[data-v-34e9c722]:focus,.modern-tool-card[data-v-34e9c722]:hover{transform:translateY(-10px) scale(1.045);box-shadow:0 20px 60px 0 rgba(31,38,135,.18),0 2px 16px 0 #fff8;background:hsla(0,0%,100%,.82)}.app-style-bg[data-v-34e9c722]{width:72px;height:72px;margin-bottom:22px;margin-top:22px;display:flex;align-items:center;justify-content:center;border-radius:22px;box-shadow:0 2px 16px #e3e9f7cc,0 0 0 #fff8;font-size:2.5rem;color:#fff;overflow:hidden;transition:box-shadow .2s;background:linear-gradient(135deg,#43e97b,#38f9d7);position:relative}.app-style-bg img[data-v-34e9c722]{width:44px;height:44px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 2px 8px #fff8)}.app-style-bg i[data-v-34e9c722]{font-size:2.3rem;color:#fff;filter:drop-shadow(0 2px 8px #fff8)}.modern-tool-info[data-v-34e9c722]{text-align:center}.modern-tool-info h2[data-v-34e9c722]{font-size:1.8rem;font-weight:700;color:#1a2233;margin-bottom:10px;letter-spacing:-.01em;text-decoration:none}.modern-tool-info h2[data-v-34e9c722]:after,h2[data-v-34e9c722]:after{display:none!important;content:none!important;border:none!important;background:none!important;height:0!important;width:0!important;margin:0!important;padding:0!important}.modern-tool-info p[data-v-34e9c722]{color:#7b8ca7;font-size:.9rem;margin:0;line-height:1.6;font-weight:400;text-decoration:none}a[data-v-34e9c722],a[data-v-34e9c722]:active,a[data-v-34e9c722]:hover,a[data-v-34e9c722]:visited{text-decoration:none!important}@media (max-width:900px){.modern-header[data-v-34e9c722]{padding:38px 0 18px 0}.modern-header h1[data-v-34e9c722]{font-size:2.1rem}.modern-tools-grid[data-v-34e9c722]{gap:18px;padding:10px 6px 0 6px}.modern-tool-card[data-v-34e9c722]{padding:22px 8px 16px 8px;min-height:170px;border-radius:18px}.app-style-bg[data-v-34e9c722]{width:44px;height:44px;border-radius:12px}.app-style-bg img[data-v-34e9c722]{width:28px;height:28px}.modern-tool-info h2[data-v-34e9c722]{font-size:1.01rem}.modern-tool-info p[data-v-34e9c722]{font-size:.92rem}}.tool-modal-bg[data-v-34e9c722]{position:fixed;z-index:1002;left:0;top:0;right:0;bottom:0;background:rgba(220,225,235,0);backdrop-filter:blur(0) saturate(1.2);opacity:0;transition:background .45s cubic-bezier(.4,0,.2,1),opacity .45s cubic-bezier(.4,0,.2,1),backdrop-filter .45s cubic-bezier(.4,0,.2,1);pointer-events:none}.tool-modal-bg.show[data-v-34e9c722]{background:rgba(220,225,235,.55);backdrop-filter:blur(16px) saturate(1.2);opacity:1;pointer-events:auto}.tool-modal-anim[data-v-34e9c722]{background:hsla(0,0%,100%,.97);box-shadow:0 12px 48px 0 rgba(31,38,135,.18),0 2px 16px 0 #fff8;position:fixed;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:48px 36px 36px 36px;overflow:auto;will-change:left,top,width,height,border-radius,opacity}.tool-modal-close[data-v-34e9c722]{position:absolute;top:18px;right:24px;font-size:2.2rem;background:none;border:none;color:#7b8ca7;cursor:pointer;transition:color .2s;z-index:10}.tool-modal-close[data-v-34e9c722]:hover{color:#1a2233}.tool-modal-placeholder[data-v-34e9c722]{text-align:center;color:#7b8ca7;margin-top:40px}.tool-modal-placeholder h2[data-v-34e9c722]{font-size:2rem;color:#1a2233;margin-bottom:18px}.tool-modal-fade-enter-active[data-v-34e9c722],.tool-modal-fade-leave-active[data-v-34e9c722]{transition:opacity .35s cubic-bezier(.4,0,.2,1)}.tool-modal-fade-enter-from[data-v-34e9c722],.tool-modal-fade-leave-to[data-v-34e9c722]{opacity:0}.tool-modal-fade-enter-to[data-v-34e9c722],.tool-modal-fade-leave-from[data-v-34e9c722]{opacity:1}.tool-modal-zoom-enter-active[data-v-34e9c722],.tool-modal-zoom-leave-active[data-v-34e9c722]{transition:transform .38s cubic-bezier(.4,0,.2,1),opacity .38s cubic-bezier(.4,0,.2,1)}.tool-modal-zoom-enter-from[data-v-34e9c722]{transform:scale(.7) translateY(60px);opacity:0}.tool-modal-zoom-enter-to[data-v-34e9c722],.tool-modal-zoom-leave-from[data-v-34e9c722]{transform:scale(1) translateY(0);opacity:1}.tool-modal-zoom-leave-to[data-v-34e9c722]{transform:scale(.7) translateY(60px);opacity:0}.tool-card-hidden[data-v-34e9c722]{opacity:0!important;pointer-events:none!important;transition:opacity .18s cubic-bezier(.4,0,.2,1)}.about-view[data-v-1286100f]{background-color:var(--bg-color);color:var(--text-color);transition:background-color .6s ease,color .3s ease;min-height:100vh;padding-top:80px}.about-section[data-v-1286100f]{position:relative}@media (max-width:768px){.about-background-emoji[data-v-1286100f]{font-size:200px;bottom:0;right:0;transform:rotate(5deg)}}section[data-v-1286100f]{padding:100px 0;text-align:center}section[data-v-1286100f]:nth-of-type(2n){background-color:var(--secondary-bg-color)}.container[data-v-1286100f]{max-width:1200px;margin:0 auto;padding:0 20px}h2[data-v-1286100f]{font-size:3.5rem;font-weight:700;margin-bottom:60px;letter-spacing:-.04em;position:relative;display:inline-block;color:var(--text-color)}h2[data-v-1286100f]:after{content:"";position:absolute;left:50%;bottom:-15px;transform:translateX(-50%);width:80px;height:4px;background-color:var(--accent-color);border-radius:2px}h3[data-v-1286100f]{font-size:2.1rem;color:var(--text-color);margin-top:40px;margin-bottom:20px;text-align:center}.about-content-markdown p[data-v-1286100f]{font-size:1.15rem;line-height:1.8;color:var(--text-dimmed-color);margin-bottom:20px;text-align:left;max-width:800px;margin-left:auto;margin-right:auto}@media (max-width:992px){h2[data-v-1286100f]{font-size:2.8rem}}@media (max-width:768px){h2[data-v-1286100f]{font-size:2.2rem}section[data-v-1286100f]{padding:80px 0}h3[data-v-1286100f]{font-size:1.8rem}.about-content-markdown p[data-v-1286100f]{font-size:1rem}}@media (max-width:480px){h2[data-v-1286100f]{font-size:2rem}h3[data-v-1286100f]{font-size:1.6rem}}.about-view.dark-mode[data-v-1286100f]{background-color:var(--bg-color);color:var(--text-color);transition:background-color .6s ease,color .3s ease}.about-view.dark-mode h2[data-v-1286100f],.about-view.dark-mode h3[data-v-1286100f]{color:var(--text-color)}.about-view.dark-mode h2[data-v-1286100f]:after,.about-view.dark-mode h3[data-v-1286100f]:after{background-color:var(--accent-color)}.about-view.dark-mode .about-content-markdown p[data-v-1286100f]{color:var(--text-dimmed-color)}.about-view.dark-mode .about-content-markdown p strong[data-v-1286100f]{color:var(--text-color)}.about-view.dark-mode[data-v-1286100f]{--bg-color:#0a0f1a;--secondary-bg-color:#070b14;--text-color:#e8e8e8;--text-dimmed-color:#b0b0b0;--accent-color:#007aff;--accent-color-rgb:0,122,255;--glass-bg:hsla(0,0%,100%,.05);--glass-border:hsla(0,0%,100%,.1);--border-color:#2a3b4c;--blur-amount:15px;--shadow-color-rgb:31,38,135}[data-v-3e083578]:root{--bg-color:#f8f8f8;--secondary-bg-color:#fff;--text-color:#1a1a1a;--text-dimmed-color:#555;--accent-color:#007aff;--accent-color-rgb:0,122,255;--glass-bg:hsla(0,0%,100%,.7);--glass-border:hsla(0,0%,86%,.5);--border-color:#ccc;--blur-amount:8px;--shadow-color-rgb:0,0,0}.blog-view[data-v-3e083578]{background-color:var(--bg-color);min-height:100vh;padding-top:80px}.blog-view[data-v-3e083578],section[data-v-3e083578]{position:relative;transition:background-color .6s ease}section[data-v-3e083578]{padding:100px 0}section[data-v-3e083578]:nth-of-type(2n){background-color:var(--secondary-bg-color)}.container[data-v-3e083578]{max-width:1200px;margin:0 auto;padding:0 20px}h2[data-v-3e083578]{font-size:3.5rem;font-weight:700;margin-bottom:60px;letter-spacing:-.04em;position:relative;display:inline-block;color:var(--text-color)}h2[data-v-3e083578]:after{content:"";position:absolute;left:50%;bottom:-15px;transform:translateX(-50%);width:80px;height:4px;background-color:var(--accent-color);border-radius:2px}p[data-v-3e083578]{font-size:1.15rem;line-height:1.8;color:var(--text-dimmed-color)}.blog-list-section[data-v-3e083578]{background-color:var(--bg-color)}.blog-list[data-v-3e083578]{display:flex;flex-direction:column;gap:32px}.blog-list-item[data-v-3e083578]{display:flex;align-items:stretch;background:var(--glass-bg);box-shadow:0 4px 24px 0 rgba(var(--shadow-color-rgb),.1);border-radius:20px;border:1px solid var(--glass-border);padding:28px 36px 22px 0;position:relative;transition:box-shadow .35s,transform .35s;overflow:hidden;min-height:120px}.blog-list-item[data-v-3e083578]:hover{box-shadow:0 16px 40px rgba(var(--shadow-color-rgb),.22);transform:translateY(-6px) scale(1.012)}.blog-list-bar[data-v-3e083578]{width:7px;min-width:7px;border-radius:8px;background:var(--accent-color);margin-right:28px;margin-top:0;margin-bottom:0;box-shadow:0 2px 8px rgba(var(--accent-color-rgb),.1)}.blog-list-content[data-v-3e083578]{flex:1;display:flex;flex-direction:column;justify-content:space-between}.blog-list-header[data-v-3e083578]{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.blog-list-title[data-v-3e083578]{font-size:1.45rem;font-weight:800;color:var(--text-color);margin:0;line-height:1.3;letter-spacing:-.01em;position:relative;transition:color .2s;cursor:pointer}.blog-list-title[data-v-3e083578]:hover{color:var(--accent-color)}.blog-list-title[data-v-3e083578]:after{content:"";display:block;width:0;height:3px;background:var(--accent-color);border-radius:2px;transition:width .3s;margin-top:2px}.blog-list-title[data-v-3e083578]:hover:after{width:60%}.blog-list-date[data-v-3e083578]{font-size:.98rem;color:var(--text-dimmed-color);font-weight:400;margin-left:18px;margin-top:2px;white-space:nowrap}.blog-list-desc[data-v-3e083578]{font-size:1.08rem;color:#a0a0a0;margin:8px 0 18px 0;line-height:1.8;font-weight:400;text-align:left}.blog-list-footer[data-v-3e083578]{display:flex;align-items:center;justify-content:flex-start;margin-top:auto;gap:12px;position:relative;min-height:36px;z-index:1}.blog-tag[data-v-3e083578]{display:inline-block;background:#007aff;color:#fff;font-size:.98rem;font-weight:600;border-radius:10px;padding:3px 16px 3px 14px;margin-right:10px;letter-spacing:.02em;box-shadow:0 1px 4px rgba(0,122,255,.1);transition:background .25s,color .25s,box-shadow .25s;cursor:pointer;position:relative;z-index:1}.blog-tag[data-v-3e083578]:hover{background:#0056c7;color:#fff;box-shadow:0 2px 8px rgba(0,122,255,.18)}.blog-tag[data-tag=\524D\7AEF][data-v-3e083578]{background:#007aff}.blog-tag[data-tag=\540E\7AEF][data-v-3e083578]{background:#22b573}.blog-tag[data-tag=\968F\7B14][data-v-3e083578]{background:#888}.read-more[data-v-3e083578]{color:var(--accent-color);font-weight:600;font-size:1rem;display:inline-flex;align-items:center;transition:color .2s;background:none;border:none;outline:none;cursor:pointer;padding:0}.read-more i[data-v-3e083578]{margin-left:7px;transition:transform .2s}.read-more[data-v-3e083578]:hover{color:#ffb300}.read-more:hover i[data-v-3e083578]{transform:translateX(4px)}@media (max-width:992px){h2[data-v-3e083578]{font-size:2.8rem}}@media (max-width:768px){h2[data-v-3e083578]{font-size:2.2rem}section[data-v-3e083578]{padding:80px 0}.blog-list-item[data-v-3e083578]{flex-direction:column;padding:18px 10px 14px 0;min-height:80px}.blog-list-bar[data-v-3e083578]{margin:0 0 10px 0;width:100%;height:5px;min-width:0;border-radius:6px}.blog-list-header[data-v-3e083578]{flex-direction:column;align-items:flex-start;gap:2px}.blog-list-title[data-v-3e083578]{font-size:1.1rem}.blog-list-date[data-v-3e083578]{font-size:.88rem;margin-left:0;margin-top:2px}.blog-list-footer[data-v-3e083578]{flex-direction:column;align-items:flex-start;gap:6px}}@media (max-width:480px){h2[data-v-3e083578]{font-size:2rem}}.blog-view.dark-mode .blog-list-item[data-v-3e083578]{background:var(--glass-bg);border:1px solid var(--glass-border)}.blog-error-tip[data-v-3e083578]{display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(122,143,166,.08);border-radius:18px;padding:48px 18px 44px 18px;margin:60px auto 80px auto;max-width:420px;box-shadow:0 2px 16px 0 rgba(122,143,166,.08);color:#7a8fa6;font-size:1.18rem;font-weight:500;letter-spacing:.01em;line-height:2.1;text-align:center;transition:background .3s,color .3s}.blog-error-tip .emoji[data-v-3e083578]{font-size:2.2rem;margin-bottom:12px}.article-view[data-v-c72ec8fa]{max-width:1100px;margin:100px auto 60px auto;padding:56px 38px 48px 38px;font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Arial,sans-serif;min-height:60vh;position:relative}.article-block[data-v-c72ec8fa]{margin-bottom:48px}.article-main-title[data-v-c72ec8fa]{font-size:2.8rem;font-weight:900;margin:0 0 1.2em 0;letter-spacing:-.01em;line-height:1.15;background:#007aff;-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Arial,sans-serif}.article-header[data-v-c72ec8fa]{margin-bottom:2.2em;gap:1.5em}.article-date[data-v-c72ec8fa]{font-size:1.08rem;font-family:inherit;letter-spacing:.01em}.article-tags[data-v-c72ec8fa]{gap:.7em}.article-tag[data-v-c72ec8fa]:hover{background:#0056c7}.article-content[data-v-c72ec8fa]{text-align:left;color:#23272f;font-size:1.18rem;font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Arial,sans-serif;letter-spacing:.01em;word-break:break-word;padding:2.8rem 0;margin-top:.5em;font-weight:600;background:none!important}.article-content h1[data-v-c72ec8fa],.article-content h2[data-v-c72ec8fa],.article-content h3[data-v-c72ec8fa]{font-weight:700;margin-top:1.8em;margin-bottom:.7em;color:#1a1a1a;border-left:4px solid #007aff;padding-left:.5em;background:#f3f7fa;border-radius:3px;font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Arial,sans-serif}.article-content h1[data-v-c72ec8fa]{font-size:2rem}.article-content h2[data-v-c72ec8fa]{font-size:1.5rem}.article-content h3[data-v-c72ec8fa]{font-size:1.2rem}.article-content ol[data-v-c72ec8fa],.article-content ul[data-v-c72ec8fa]{margin:1em 0 1em 2em}.article-content blockquote[data-v-c72ec8fa]{border-left:4px solid #22b573;background:#f9f9f9;color:#666;margin:1em 0;padding:.5em 1em;border-radius:4px;font-style:italic}.article-content pre[data-v-c72ec8fa]{background:#23272f;color:#fff;padding:1.1em;border-radius:8px;overflow-x:auto;margin:1em 0;font-size:1.02em}.article-content code[data-v-c72ec8fa]{background:#f4f4f4;color:#c7254e;padding:.22em .45em;border-radius:3px;font-size:1em;font-family:Fira Mono,Consolas,Menlo,monospace}.article-content img[data-v-c72ec8fa]{max-width:100%;border-radius:6px;margin:1em 0;box-shadow:0 2px 8px rgba(60,60,60,.06)}@media (max-width:900px){.article-view[data-v-c72ec8fa]{padding:24px 6px;max-width:98vw}.article-content[data-v-c72ec8fa]{padding:1.2rem .7rem}.article-main-title[data-v-c72ec8fa]{font-size:2rem}}[data-v-c72ec8fa] .article-content a,[data-v-c72ec8fa] .article-content blockquote,[data-v-c72ec8fa] .article-content code,[data-v-c72ec8fa] .article-content div,[data-v-c72ec8fa] .article-content em,[data-v-c72ec8fa] .article-content h1,[data-v-c72ec8fa] .article-content h2,[data-v-c72ec8fa] .article-content h3,[data-v-c72ec8fa] .article-content img,[data-v-c72ec8fa] .article-content li,[data-v-c72ec8fa] .article-content ol,[data-v-c72ec8fa] .article-content p,[data-v-c72ec8fa] .article-content pre,[data-v-c72ec8fa] .article-content span,[data-v-c72ec8fa] .article-content strong,[data-v-c72ec8fa] .article-content table,[data-v-c72ec8fa] .article-content td,[data-v-c72ec8fa] .article-content th,[data-v-c72ec8fa] .article-content tr,[data-v-c72ec8fa] .article-content ul{all:unset;display:revert;color:#333;font-size:1.1rem;line-height:1.8;box-sizing:border-box}[data-v-c72ec8fa] .article-content h1{font-size:2.2rem;font-weight:800;margin:1.5em 0 1em 0;color:#181818;letter-spacing:.01em}[data-v-c72ec8fa] .article-content h2{font-size:1.6rem;font-weight:700;margin:1.2em 0 .8em 0;color:#23272f;border-left:4px solid #42b983;padding-left:.5em;background:#f3f7fa;border-radius:3px}[data-v-c72ec8fa] .article-content h3{font-size:1.25rem;font-weight:600;margin:1em 0 .6em 0;color:#2d3748}[data-v-c72ec8fa] .article-content p{margin:.7em 0;line-height:1.85}[data-v-c72ec8fa] .article-content ol,[data-v-c72ec8fa] .article-content ul{margin:1em 0 1em 2em}[data-v-c72ec8fa] .article-content li{margin-bottom:.3em}[data-v-c72ec8fa] .article-content blockquote{border-left:4px solid #42b983;background:#f9f9f9;color:#666;margin:1em 0;padding:.5em 1em;border-radius:4px;font-style:italic}[data-v-c72ec8fa] .article-content pre{background:#23272f;color:#fff;padding:1.1em;border-radius:8px;overflow-x:auto;margin:1em 0;font-size:1.02em}[data-v-c72ec8fa] .article-content code{background:#f4f4f4;color:#c7254e;padding:.22em .45em;border-radius:3px;font-size:1em;font-family:Fira Mono,Consolas,Menlo,monospace}[data-v-c72ec8fa] .article-content img{max-width:100%;border-radius:6px;margin:1em 0;box-shadow:0 2px 8px rgba(60,60,60,.06)}.article-header[data-v-c72ec8fa]{margin-bottom:1.5em;display:flex;flex-wrap:wrap;align-items:center;gap:1.2em}.article-date[data-v-c72ec8fa]{font-size:.98rem;font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Helvetica Neue,Arial,sans-serif;margin-right:1em}.article-tags[data-v-c72ec8fa]{display:flex;flex-wrap:wrap;gap:.5em}.article-tag[data-v-c72ec8fa]{font-size:.95rem;font-weight:500}.article-main-title[data-v-c72ec8fa]{font-size:2.3rem;font-weight:800;margin:1.2em 0 .7em 0;color:#23272f;letter-spacing:.01em;line-height:1.2;font-family:Inter,Segoe UI,PingFang SC,Hiragino Sans GB,Helvetica Neue,Arial,sans-serif;text-align:left}.article-view.dark-mode[data-v-c72ec8fa]{background:none}.article-view.dark-mode .article-main-title[data-v-c72ec8fa]{color:#298fd8;-webkit-text-fill-color:#298fd8}.article-view.dark-mode .article-date[data-v-c72ec8fa]{background:rgba(60,70,90,.7);border-radius:8px}.article-view.dark-mode .article-tag[data-v-c72ec8fa]{background:rgba(30,80,180,.7);color:#fff;border-radius:16px}.article-view.dark-mode .article-content blockquote[data-v-c72ec8fa]{background:rgba(40,50,70,.7);color:#b8c7d9;border-left:4px solid #22b573}.article-view.dark-mode .article-content pre[data-v-c72ec8fa]{background:#232b3a;color:#fff}.article-view.dark-mode .article-content code[data-v-c72ec8fa]{background:#232b3a;color:#4db3fa}.article-view.dark-mode .article-content a[data-v-c72ec8fa]{color:#4db3fa;text-decoration:underline}.article-view.dark-mode .article-content div[data-v-c72ec8fa],.article-view.dark-mode .article-content em[data-v-c72ec8fa],.article-view.dark-mode .article-content li[data-v-c72ec8fa],.article-view.dark-mode .article-content p[data-v-c72ec8fa],.article-view.dark-mode .article-content span[data-v-c72ec8fa],.article-view.dark-mode .article-content strong[data-v-c72ec8fa],.article-view.dark-mode .article-content[data-v-c72ec8fa],.article-view.dark-mode[data-v-c72ec8fa] .article-content,.article-view.dark-mode[data-v-c72ec8fa] .article-content div,.article-view.dark-mode[data-v-c72ec8fa] .article-content em,.article-view.dark-mode[data-v-c72ec8fa] .article-content li,.article-view.dark-mode[data-v-c72ec8fa] .article-content p,.article-view.dark-mode[data-v-c72ec8fa] .article-content span,.article-view.dark-mode[data-v-c72ec8fa] .article-content strong{color:#f6f8fa!important}.article-view.dark-mode .article-content h1[data-v-c72ec8fa],.article-view.dark-mode .article-content h2[data-v-c72ec8fa],.article-view.dark-mode .article-content h3[data-v-c72ec8fa],.article-view.dark-mode[data-v-c72ec8fa] .article-content h1,.article-view.dark-mode[data-v-c72ec8fa] .article-content h2,.article-view.dark-mode[data-v-c72ec8fa] .article-content h3{color:#4db3fa!important}.article-tag[data-v-c72ec8fa]{background:#e6f4ea;color:#21996f;font-weight:600;border-radius:12px;padding:.18em .9em;font-family:inherit;display:inline-block;line-height:1.6;box-shadow:0 1px 2px rgba(60,60,60,.04);margin-right:.5em;margin-bottom:.3em;transition:background .22s,color .22s}.article-date[data-v-c72ec8fa]{background:#f3f6fa;color:#8a9299;border-radius:8px;padding:.22em 1.1em;font-weight:500;margin-right:1.2em}.article-view.dark-mode .article-tag[data-v-c72ec8fa]{background:#22304a;color:#7ed6fb;box-shadow:none}.article-view.dark-mode .article-tag[data-v-c72ec8fa]:hover{background:#4db3fa;color:#fff}.article-view.dark-mode .article-date[data-v-c72ec8fa]{background:#22304a;color:#b8c7d9}.article-view.dark-mode .article-content div[data-v-c72ec8fa],.article-view.dark-mode .article-content em[data-v-c72ec8fa],.article-view.dark-mode .article-content li[data-v-c72ec8fa],.article-view.dark-mode .article-content p[data-v-c72ec8fa],.article-view.dark-mode .article-content span[data-v-c72ec8fa],.article-view.dark-mode .article-content strong[data-v-c72ec8fa],.article-view.dark-mode .article-content[data-v-c72ec8fa]{color:#eaf6ff}.article-view.dark-mode .article-content h1[data-v-c72ec8fa],.article-view.dark-mode .article-content h2[data-v-c72ec8fa],.article-view.dark-mode .article-content h3[data-v-c72ec8fa]{color:#4db3fa;background:#1a2233;border-left:4px solid #4db3fa}.article-view.dark-mode .article-main-title[data-v-c72ec8fa]{color:#4db3fa;background:none;-webkit-text-fill-color:#4db3fa}pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}
/*!
  Theme: GitHub
  Description: Light theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-light
  Current colors taken from GitHub's CSS
*/.hljs{color:#24292e;background:#fff}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#d73a49}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#6f42c1}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id,.hljs-variable{color:#005cc5}.hljs-meta .hljs-string,.hljs-regexp,.hljs-string{color:#032f62}.hljs-built_in,.hljs-symbol{color:#e36209}.hljs-code,.hljs-comment,.hljs-formula{color:#6a737d}.hljs-name,.hljs-quote,.hljs-selector-pseudo,.hljs-selector-tag{color:#22863a}.hljs-subst{color:#24292e}.hljs-section{color:#005cc5;font-weight:700}.hljs-bullet{color:#735c0f}.hljs-emphasis{color:#24292e;font-style:italic}.hljs-strong{color:#24292e;font-weight:700}.hljs-addition{color:#22863a;background-color:#f0fff4}.hljs-deletion{color:#b31d28;background-color:#ffeef0}.chengmd-root[data-v-a9e84b1e]{height:100vh;display:flex;flex-direction:column;background:#f3f2f1}.chengmd-dark-theme.chengmd-root[data-v-a9e84b1e]{background:#232323}.chengmd-topbar[data-v-a9e84b1e]{display:flex;align-items:center;position:relative;background:#efeeee;border-radius:16px;margin:12px 12px 0 12px;padding:0 24px;height:48px;font-size:18px;font-weight:600;box-sizing:border-box;transition:background .2s}.chengmd-dark-theme .chengmd-topbar[data-v-a9e84b1e]{background:#232323;color:#e6e6e6;border:1px solid #2d2d2d;box-shadow:0 2px 8px #18181844}.chengmd-tool-title[data-v-a9e84b1e]{flex:0 0 auto;font-size:22px;font-weight:700;margin-right:32px;color:#222}.chengmd-dark-theme .chengmd-tool-title[data-v-a9e84b1e]{color:#e6e6e6}.chengmd-toolbar[data-v-a9e84b1e]{display:flex;gap:32px;flex:1 1 auto}.chengmd-toolbar-btn-wrap[data-v-a9e84b1e]{position:relative;display:inline-block}.chengmd-toolbar-btn[data-v-a9e84b1e]{background:none;border:none;font-size:18px;font-weight:500;color:#222;cursor:pointer;padding:0 8px;border-radius:8px;transition:background .2s,color .2s}.chengmd-toolbar-btn[data-v-a9e84b1e]:hover{background:#e0dfde}.chengmd-dark-theme .chengmd-toolbar-btn[data-v-a9e84b1e]{color:#e6e6e6}.chengmd-dark-theme .chengmd-toolbar-btn[data-v-a9e84b1e]:hover{background:#29292b}.chengmd-dropdown[data-v-a9e84b1e]{position:absolute;top:100%;left:0;background:#fff;border-radius:18px;box-shadow:0 4px 16px rgba(0,0,0,.12);min-width:180px;z-index:10;padding:18px 0;margin-top:8px;display:flex;flex-direction:column;align-items:stretch;border:1px solid #e0dfde}.chengmd-dropdown-item[data-v-a9e84b1e]{padding:14px 0;font-size:18px;color:#222;cursor:pointer;transition:background .2s,color .2s;text-align:center;font-weight:500;border:none;background:none}.chengmd-dropdown-item[data-v-a9e84b1e]:hover{background:#f3f2f1}.chengmd-dark-theme .chengmd-dropdown[data-v-a9e84b1e]{background:#29292b;box-shadow:0 4px 16px #1118;border:1px solid #333}.chengmd-dark-theme .chengmd-dropdown-item[data-v-a9e84b1e]{color:#e6e6e6}.chengmd-dark-theme .chengmd-dropdown-item[data-v-a9e84b1e]:hover{background:#232323}.chengmd-main-area[data-v-a9e84b1e]{flex:1 1 0;display:flex;gap:16px;margin:12px;min-height:0}.chengmd-editor-area[data-v-a9e84b1e],.chengmd-preview-area[data-v-a9e84b1e]{flex:1 1 0;background:#fff;border-radius:16px;box-shadow:0 2px 8px rgba(0,0,0,.04);padding:24px;min-width:0;min-height:0;display:flex;flex-direction:column;transition:background .2s,color .2s,border .2s;border:1.5px solid #ececec}.chengmd-dark-theme .chengmd-editor-area[data-v-a9e84b1e],.chengmd-dark-theme .chengmd-preview-area[data-v-a9e84b1e]{background:#3b3c40;color:#e6e6e6;border:1.5px solid #2d2d2d;box-shadow:0 2px 8px #18181844}.chengmd-editor[data-v-a9e84b1e]{width:100%;height:100%;border:none;outline:none;resize:none;font-size:20px;font-family:Menlo,Monaco,Consolas,monospace;background:transparent;color:#222;transition:background .2s,color .2s}.chengmd-dark-theme .chengmd-editor[data-v-a9e84b1e]{color:#e6e6e6;background:transparent}.chengmd-editor[data-v-a9e84b1e]::-moz-placeholder{color:#888;opacity:1}.chengmd-editor[data-v-a9e84b1e]::placeholder{color:#888;opacity:1}.chengmd-dark-theme .chengmd-editor[data-v-a9e84b1e]::-moz-placeholder{color:#aaa;opacity:1}.chengmd-dark-theme .chengmd-editor[data-v-a9e84b1e]::placeholder{color:#aaa;opacity:1}.chengmd-preview-area[data-v-a9e84b1e]{overflow-y:auto;font-size:20px;color:#222}.chengmd-dark-theme .chengmd-preview-area[data-v-a9e84b1e]{color:#e6e6e6}.chengmd-preview-area[data-v-a9e84b1e]::-webkit-scrollbar{width:8px;background:#f3f2f1}.chengmd-dark-theme .chengmd-preview-area[data-v-a9e84b1e]::-webkit-scrollbar{background:#232323}.chengmd-preview-area[data-v-a9e84b1e]::-webkit-scrollbar-thumb{background:#e0dfde;border-radius:4px}.chengmd-dark-theme .chengmd-preview-area[data-v-a9e84b1e]::-webkit-scrollbar-thumb{background:#444}[data-v-a9e84b1e] .chengmd-preview-area blockquote,[data-v-a9e84b1e] .chengmd-preview-area code,[data-v-a9e84b1e] .chengmd-preview-area em,[data-v-a9e84b1e] .chengmd-preview-area h1,[data-v-a9e84b1e] .chengmd-preview-area h2,[data-v-a9e84b1e] .chengmd-preview-area h3,[data-v-a9e84b1e] .chengmd-preview-area h4,[data-v-a9e84b1e] .chengmd-preview-area h5,[data-v-a9e84b1e] .chengmd-preview-area h6,[data-v-a9e84b1e] .chengmd-preview-area li,[data-v-a9e84b1e] .chengmd-preview-area ol,[data-v-a9e84b1e] .chengmd-preview-area p,[data-v-a9e84b1e] .chengmd-preview-area pre,[data-v-a9e84b1e] .chengmd-preview-area strong,[data-v-a9e84b1e] .chengmd-preview-area table,[data-v-a9e84b1e] .chengmd-preview-area td,[data-v-a9e84b1e] .chengmd-preview-area th,[data-v-a9e84b1e] .chengmd-preview-area ul{all:unset;display:revert;box-sizing:border-box;color:#222;font-family:inherit;text-align:left}.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area blockquote,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area code,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area em,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area h1,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area h2,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area h3,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area h4,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area h5,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area h6,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area li,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area ol,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area p,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area pre,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area strong,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area table,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area td,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area th,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area ul{color:#e6e6e6}[data-v-a9e84b1e] .chengmd-preview-area{text-align:left}[data-v-a9e84b1e] .chengmd-preview-area h1{font-size:1.7em;font-weight:700;margin:.7em 0 .3em 0}[data-v-a9e84b1e] .chengmd-preview-area h2{font-size:1.4em;font-weight:700;margin:.6em 0 .3em 0}[data-v-a9e84b1e] .chengmd-preview-area h3{font-size:1.15em;font-weight:700;margin:.5em 0 .2em 0}[data-v-a9e84b1e] .chengmd-preview-area h4,[data-v-a9e84b1e] .chengmd-preview-area h5,[data-v-a9e84b1e] .chengmd-preview-area h6{font-size:1em;font-weight:700;margin:.4em 0 .2em 0}[data-v-a9e84b1e] .chengmd-preview-area p{margin:.2em 0;line-height:1.7}[data-v-a9e84b1e] .chengmd-preview-area ol,[data-v-a9e84b1e] .chengmd-preview-area ul{margin:.3em 0 .3em 2em;padding-left:1.2em}[data-v-a9e84b1e] .chengmd-preview-area li{margin-bottom:.1em;line-height:1.6}[data-v-a9e84b1e] .chengmd-preview-area pre{background:#f5f5f5;color:#222;padding:1em;border-radius:6px;overflow-x:auto;overflow-y:auto;max-height:320px;white-space:pre;word-break:break-all;margin:.5em 0;font-size:.98em;font-family:Menlo,Monaco,Consolas,monospace}.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area pre{background:#3b3c40;color:#e6e6e6}[data-v-a9e84b1e] .chengmd-preview-area code{background:#f0f0f0;color:#c7254e;padding:.12em .3em;border-radius:3px;font-size:.98em;font-family:Menlo,Monaco,Consolas,monospace}.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area code{background:#333;color:#ffb3b3}[data-v-a9e84b1e] .chengmd-preview-area blockquote{border-left:4px solid #bbb;background:#fafafa;color:#666;margin:.5em 0;padding:.3em 1em;border-radius:4px;font-style:italic}.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area blockquote{background:#232323;color:#aaa;border-left:4px solid #444}[data-v-a9e84b1e] .chengmd-preview-area table{border-collapse:collapse;margin:.5em 0;width:100%}[data-v-a9e84b1e] .chengmd-preview-area td,[data-v-a9e84b1e] .chengmd-preview-area th{border:1px solid #ddd;padding:6px;text-align:left}.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area td,.chengmd-dark-theme[data-v-a9e84b1e] .chengmd-preview-area th{border:1px solid #444}[data-v-a9e84b1e] .chengmd-preview-area em{font-style:italic}[data-v-a9e84b1e] .chengmd-preview-area strong{font-weight:700}.chengmd-bottombar[data-v-a9e84b1e]{display:flex;justify-content:space-between;align-items:center;background:#efeeee;border-radius:12px;margin:0 12px 12px 12px;height:40px;padding:0 24px;font-size:16px;color:#222;box-sizing:border-box}.chengmd-dark-theme .chengmd-bottombar[data-v-a9e84b1e]{background:#232323;color:#e6e6e6}.chengmd-filename[data-v-a9e84b1e]{font-weight:500}.chengmd-charcount[data-v-a9e84b1e]{font-family:monospace}.chengmd-toolbar-icons[data-v-a9e84b1e]{margin-left:auto;display:flex;align-items:center;gap:8px}.chengmd-icon-btn[data-v-a9e84b1e]{background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:8px;transition:background .2s;display:flex;align-items:center}.chengmd-icon-btn[data-v-a9e84b1e]:hover{background:#e0dfde}.chengmd-dark-theme .chengmd-icon-btn[data-v-a9e84b1e]:hover{background:#29292b}.chengmd-icon[data-v-a9e84b1e]{display:flex;align-items:center;color:inherit}.chengmd-dark-theme .chengmd-icon[data-v-a9e84b1e]{color:#fff!important}.chengmd-modal-fade-enter-active[data-v-a9e84b1e],.chengmd-modal-fade-leave-active[data-v-a9e84b1e]{transition:opacity .3s}.chengmd-modal-fade-enter[data-v-a9e84b1e],.chengmd-modal-fade-leave-to[data-v-a9e84b1e]{opacity:0}.chengmd-modal-mask[data-v-a9e84b1e]{position:fixed;z-index:1000;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,.18);display:flex;align-items:center;justify-content:center}.chengmd-modal[data-v-a9e84b1e]{background:#fff;border-radius:18px;box-shadow:0 8px 32px rgba(0,0,0,.18);min-width:320px;max-width:90vw;padding:32px 28px 22px 28px;display:flex;flex-direction:column;align-items:stretch;animation:chengmd-modal-pop-a9e84b1e .3s}@keyframes chengmd-modal-pop-a9e84b1e{0%{transform:scale(.95);opacity:.5}to{transform:scale(1);opacity:1}}.chengmd-dark-theme .chengmd-modal[data-v-a9e84b1e]{background:#29292b;color:#e6e6e6;box-shadow:0 8px 32px #111a}.chengmd-modal-title[data-v-a9e84b1e]{font-size:20px;font-weight:700;margin-bottom:18px;text-align:center}.chengmd-modal-content[data-v-a9e84b1e]{margin-bottom:18px}.chengmd-modal-row[data-v-a9e84b1e]{display:flex;align-items:center;gap:12px;margin-bottom:10px}.chengmd-modal-select[data-v-a9e84b1e]{font-size:16px;padding:4px 12px;border-radius:6px;border:1px solid #ccc;outline:none}.chengmd-dark-theme .chengmd-modal-select[data-v-a9e84b1e]{background:#232323;color:#e6e6e6;border:1px solid #444}.chengmd-modal-actions[data-v-a9e84b1e]{display:flex;justify-content:flex-end;gap:16px}.chengmd-modal-btn[data-v-a9e84b1e]{font-size:16px;padding:6px 22px;border-radius:8px;border:none;background:#e0dfde;color:#222;cursor:pointer;transition:background .2s}.chengmd-modal-btn[data-v-a9e84b1e]:disabled{opacity:.7;cursor:not-allowed}.chengmd-modal-btn-primary[data-v-a9e84b1e]{background:#4f8cff;color:#fff}.chengmd-modal-btn-primary[data-v-a9e84b1e]:disabled{background:#4f8cffcc}.chengmd-dark-theme .chengmd-modal-btn[data-v-a9e84b1e]{background:#29292b;color:#e6e6e6;border:1px solid #444}.chengmd-dark-theme .chengmd-modal-btn-primary[data-v-a9e84b1e]{background:#4f8cff;color:#fff;border:none}.chengmd-modal-loading[data-v-a9e84b1e]{display:inline-block;width:18px;height:18px;border:2.5px solid #fff;border-radius:50%;animation:chengmd-spin-a9e84b1e .7s linear infinite;vertical-align:middle}@keyframes chengmd-spin-a9e84b1e{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.about-view[data-v-db71f1a6]{background-color:var(--bg-color);color:var(--text-color);transition:background-color .6s ease,color .3s ease;min-height:100vh;padding-top:80px}.about-section[data-v-db71f1a6]{position:relative}@media (max-width:768px){.about-background-emoji[data-v-db71f1a6]{font-size:200px;bottom:0;right:0;transform:rotate(5deg)}}section[data-v-db71f1a6]{padding:100px 0;text-align:center}section[data-v-db71f1a6]:nth-of-type(2n){background-color:var(--secondary-bg-color)}.container[data-v-db71f1a6]{max-width:1200px;margin:0 auto;padding:0 20px}h2[data-v-db71f1a6]{font-size:3.5rem;font-weight:700;margin-bottom:60px;letter-spacing:-.04em;position:relative;display:inline-block;color:var(--text-color)}h2[data-v-db71f1a6]:after{content:"";position:absolute;left:50%;bottom:-15px;transform:translateX(-50%);width:80px;height:4px;background-color:var(--accent-color);border-radius:2px}h3[data-v-db71f1a6]{font-size:2.1rem;color:var(--text-color);margin-top:40px;margin-bottom:20px;text-align:center}.about-content-markdown[data-v-db71f1a6]{text-align:left;max-width:1100px;margin-left:auto;margin-right:auto}.project-item[data-v-db71f1a6]{position:relative;margin-bottom:60px;padding:36px 40px;border-radius:20px;background:var(--glass-bg);border:1.5px solid var(--glass-border);backdrop-filter:blur(var(--blur-amount));text-align:left;box-shadow:0 8px 32px 0 rgba(var(--shadow-color-rgb),.12);transition:all .4s cubic-bezier(.34,1.56,.64,1);will-change:transform,box-shadow,background-color;animation:card-fade-in-up-db71f1a6 .7s cubic-bezier(.4,2,.6,1);opacity:1;overflow:visible}.project-item[data-v-db71f1a6]:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 48px rgba(var(--shadow-color-rgb),.16);background:var(--glass-bg-hover,hsla(0,0%,100%,.98));border-color:var(--accent-color)}@keyframes card-fade-in-up-db71f1a6{0%{opacity:0;transform:translateY(40px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.project-item h3[data-v-db71f1a6]{color:var(--text-color);font-size:2rem;margin-bottom:18px;text-align:left;font-weight:700}.project-meta[data-v-db71f1a6]{display:flex;gap:28px;margin-bottom:22px;color:var(--accent-color);font-size:1.08rem;text-align:left}.project-role[data-v-db71f1a6],.project-time[data-v-db71f1a6]{font-weight:500}.project-item p[data-v-db71f1a6]{text-align:left;margin-bottom:12px;font-size:1.13rem}.project-item ul[data-v-db71f1a6]{list-style-type:none;padding-left:20px;margin:10px 0 22px 0}.project-item ul li[data-v-db71f1a6]{position:relative;padding-left:20px;margin-bottom:10px;color:var(--text-dimmed-color);text-align:left;font-size:1.08rem}.project-item ul li[data-v-db71f1a6]:before{content:"•";position:absolute;left:0;color:var(--accent-color)}.project-emoji[data-v-db71f1a6]{position:absolute;right:-18px;bottom:-18px;font-size:4.5rem;color:var(--accent-color,#007aff);opacity:.13;transform:rotate(-18deg);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:opacity .3s;z-index:2}.project-item:hover .project-emoji[data-v-db71f1a6]{opacity:.22}@media (max-width:1100px){.about-content-markdown[data-v-db71f1a6]{max-width:98vw;padding:0 5px}.project-item[data-v-db71f1a6]{padding:18px 8px}}@media (max-width:768px){.about-content-markdown[data-v-db71f1a6]{padding:0 5px}.project-item[data-v-db71f1a6]{padding:18px 14px;border-radius:14px;margin-bottom:28px}.project-item h3[data-v-db71f1a6]{font-size:1.15rem}.project-meta[data-v-db71f1a6]{font-size:1.01rem;gap:8px}.project-item p[data-v-db71f1a6],.project-item ul li[data-v-db71f1a6]{font-size:1.01rem}}@media (max-width:992px){h2[data-v-db71f1a6]{font-size:2.8rem}}@media (max-width:480px){h2[data-v-db71f1a6]{font-size:2rem}h3[data-v-db71f1a6]{font-size:1.6rem}}.about-view.dark-mode[data-v-db71f1a6]{background-color:var(--bg-color);color:var(--text-color);transition:background-color .6s ease,color .3s ease}.about-view.dark-mode h2[data-v-db71f1a6],.about-view.dark-mode h3[data-v-db71f1a6]{color:var(--text-color)}.about-view.dark-mode h2[data-v-db71f1a6]:after,.about-view.dark-mode h3[data-v-db71f1a6]:after{background-color:var(--accent-color)}.about-view.dark-mode .about-content-markdown p[data-v-db71f1a6]{color:var(--text-dimmed-color)}.about-view.dark-mode .about-content-markdown p strong[data-v-db71f1a6]{color:var(--text-color)}.about-view.dark-mode[data-v-db71f1a6]{--bg-color:#0a0f1a;--secondary-bg-color:#070b14;--text-color:#e8e8e8;--text-dimmed-color:#b0b0b0;--accent-color:#007aff;--accent-color-rgb:0,122,255;--glass-bg:hsla(0,0%,100%,.05);--glass-border:hsla(0,0%,100%,.1);--border-color:#2a3b4c;--blur-amount:15px;--shadow-color-rgb:31,38,135}.project-tags[data-v-db71f1a6]{margin-bottom:10px;display:flex;flex-wrap:wrap;gap:8px}.tag[data-v-db71f1a6]{display:inline-block;padding:2px 10px;border-radius:12px;font-size:.98rem;font-weight:500;margin-right:4px;margin-bottom:4px;background:#f2f3f7;color:#333;box-shadow:0 1px 4px rgba(0,0,0,.04);letter-spacing:.01em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.tag-date[data-v-db71f1a6]{background:#e3f0ff;color:#1976d2}.tag-role[data-v-db71f1a6],.tag-tech.tag-spring[data-v-db71f1a6]{background:#e8f5e9;color:#388e3c}.tag-tech.tag-mysql[data-v-db71f1a6]{background:#fff3e0;color:#f57c00}.tag-tech.tag-neo4j[data-v-db71f1a6]{background:#e0f7fa;color:#00838f}.tag-tech.tag-redis[data-v-db71f1a6]{background:#ffebee;color:#d32f2f}.tag-tech.tag-maven[data-v-db71f1a6]{background:#f3e5f5;color:#7b1fa2}.tag-tech.tag-vue[data-v-db71f1a6]{background:#e8f5e9;color:#43a047}.tag-tech.tag-html[data-v-db71f1a6]{background:#ffe0b2;color:#e65100}.tag-tech.tag-css[data-v-db71f1a6]{background:#e3f2fd;color:#1565c0}.tag-tech.tag-js[data-v-db71f1a6]{background:#fffde7;color:#fbc02d}.tag-tech.tag-axios[data-v-db71f1a6]{background:#ede7f6;color:#512da8}.tag-tech.tag-websocket[data-v-db71f1a6]{background:#e1f5fe;color:#0277bd}.tag-tech.tag-netty[data-v-db71f1a6]{background:#fce4ec;color:#c2185b}.tag-tech.tag-mybatis[data-v-db71f1a6]{background:#f9fbe7;color:#827717}.tag-tech.tag-marked[data-v-db71f1a6]{background:#f1f8e9;color:#689f38}.tag-tech.tag-hljs[data-v-db71f1a6]{background:#e0f2f1;color:#00695c}.tag-tech.tag-html2pdf[data-v-db71f1a6]{background:#fbe9e7;color:#d84315}.tag-tech.tag-python[data-v-db71f1a6]{background:#e0f7fa;color:#0277bd}.tag-tech.tag-pytorch[data-v-db71f1a6]{background:#fff3e0;color:#e64a19}.tag-tech.tag-hf[data-v-db71f1a6]{background:#f3e5f5;color:#512da8}.tag-tech.tag-numpy[data-v-db71f1a6]{background:#f1f8e9;color:#689f38}.tag-tech.tag-sklearn[data-v-db71f1a6]{background:#ede7f6;color:#1976d2}.tag-tech.tag-opencv[data-v-db71f1a6]{background:#e8f5e9;color:#388e3c}.tag-tech.tag-cv[data-v-db71f1a6]{background:#fbe9e7;color:#d84315}.tag-tech.tag-dl[data-v-db71f1a6]{background:#fffde7;color:#fbc02d}@media (max-width:768px){.tag[data-v-db71f1a6]{font-size:.89rem;padding:2px 8px}.project-tags[data-v-db71f1a6]{gap:5px}}.project-list-desktop[data-v-db71f1a6]{display:block}@media (max-width:768px){.project-list-desktop[data-v-db71f1a6]{display:none!important}}.mobile-projects-slider[data-v-db71f1a6]{display:none}@media (max-width:768px){.mobile-projects-slider[data-v-db71f1a6]{display:flex;flex-direction:column;gap:14px;padding:8px 0 18px 0;margin-bottom:10px;overflow-x:unset;scroll-snap-type:none}.mobile-project-card[data-v-db71f1a6],.mobile-project-detail[data-v-db71f1a6],.mobile-project-main[data-v-db71f1a6]{box-sizing:border-box}.mobile-project-card[data-v-db71f1a6]{width:100%;margin-bottom:0;border-radius:18px;box-shadow:0 2px 12px rgba(var(--shadow-color-rgb),.1);overflow:hidden;background:none;border:1.5px solid var(--glass-border);transition:box-shadow .35s,transform .35s,background .35s}.mobile-project-card[data-v-db71f1a6]:active,.mobile-project-card[data-v-db71f1a6]:hover{box-shadow:0 8px 32px rgba(var(--shadow-color-rgb),.18);transform:translateY(-4px) scale(1.01);background:#f0f4ff}.mobile-project-detail[data-v-db71f1a6],.mobile-project-main[data-v-db71f1a6]{width:100%;padding-left:16px;padding-right:16px}.mobile-project-main[data-v-db71f1a6]{background:#f5f7ff;padding-top:16px;padding-bottom:16px;display:flex;flex-direction:row;align-items:center;gap:16px}.mobile-project-detail[data-v-db71f1a6]{background:#f7fafd;border-radius:0;box-shadow:none;margin-top:0;padding-top:16px;padding-bottom:12px;border-top:none;text-align:left;word-break:break-all;overflow-wrap:break-word}.mobile-project-logo[data-v-db71f1a6]{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff;box-shadow:0 2px 8px #e3e9f7cc;background:#2193b0;flex-shrink:0;margin-bottom:0}.mobile-project-card.visual-gradient-1 .mobile-project-logo[data-v-db71f1a6]{background:linear-gradient(135deg,var(--project-gradient-1-start),var(--project-gradient-1-end))}.mobile-project-card.visual-gradient-2 .mobile-project-logo[data-v-db71f1a6]{background:radial-gradient(circle at center,var(--project-gradient-2-start) 0,var(--project-gradient-2-middle) 50%,var(--project-gradient-2-end) 100%)}.mobile-project-card.visual-gradient-3 .mobile-project-logo[data-v-db71f1a6]{background:linear-gradient(45deg,var(--project-gradient-3-start),var(--project-gradient-3-end))}.mobile-project-card.visual-gradient-4 .mobile-project-logo[data-v-db71f1a6]{background:linear-gradient(135deg,var(--project-gradient-4-start),var(--project-gradient-4-end))}.mobile-project-card.visual-gradient-5 .mobile-project-logo[data-v-db71f1a6]{background:linear-gradient(45deg,var(--project-gradient-5-start),var(--project-gradient-5-end))}.mobile-project-card.visual-gradient-6 .mobile-project-logo[data-v-db71f1a6]{background:linear-gradient(135deg,var(--project-gradient-6-start),var(--project-gradient-6-end))}.mobile-project-info[data-v-db71f1a6]{flex:1;text-align:left;display:flex;flex-direction:column;justify-content:center;gap:2px}.mobile-project-title[data-v-db71f1a6]{font-size:1.08rem;font-weight:700;color:var(--text-color);margin-bottom:2px;line-height:1.2}.mobile-project-desc[data-v-db71f1a6]{font-size:.92rem;color:var(--text-dimmed-color);line-height:1.5;margin-bottom:0}.mobile-project-detail .project-tags[data-v-db71f1a6]{margin-bottom:4px}.mobile-project-detail .tag[data-v-db71f1a6]{font-size:.82rem;margin-right:4px;margin-bottom:2px;padding:2px 7px}.mobile-project-detail .mobile-project-intro[data-v-db71f1a6]{margin-bottom:4px;color:var(--text-color);font-size:.89rem}.mobile-project-detail .mobile-project-tech[data-v-db71f1a6]{margin-bottom:4px}.mobile-project-detail .mobile-project-tech .tag[data-v-db71f1a6]{background:#f2f3f7;color:#333;border-radius:10px;border:none}.mobile-project-detail .mobile-project-result[data-v-db71f1a6]{margin:0 0 2px 0;padding-left:18px;color:var(--text-dimmed-color);font-size:.92rem}.mobile-project-detail .mobile-project-result li[data-v-db71f1a6]{margin-bottom:2px}.expand-enter-active[data-v-db71f1a6],.expand-leave-active[data-v-db71f1a6]{transition:max-height .3s cubic-bezier(.4,0,.2,1),opacity .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.expand-enter-from[data-v-db71f1a6],.expand-leave-to[data-v-db71f1a6]{max-height:0;opacity:0}.expand-enter-to[data-v-db71f1a6],.expand-leave-from[data-v-db71f1a6]{max-height:400px;opacity:1}.card-fade-in-up-enter-active[data-v-db71f1a6]{transition:opacity .45s cubic-bezier(.4,2,.6,1),transform .45s cubic-bezier(.4,2,.6,1)}.card-fade-in-up-enter-from[data-v-db71f1a6]{opacity:0;transform:translateY(60px) scale(.95)}.card-fade-in-up-enter-to[data-v-db71f1a6]{opacity:1;transform:translateY(0) scale(1)}}.not-found-view[data-v-7b19ea5d]{min-height:100vh;display:flex;flex-direction:column;background-color:var(--bg-color);color:var(--text-color)}.not-found-container[data-v-7b19ea5d]{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:transparent}.not-found-content[data-v-7b19ea5d]{text-align:center;max-width:500px;padding:2rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.text-content[data-v-7b19ea5d]{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.error-title[data-v-7b19ea5d]{font-size:3rem;font-weight:700;background:linear-gradient(135deg,var(--accent-color),#2193b0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2;margin:0}.error-description[data-v-7b19ea5d]{font-size:1.1rem;color:var(--text-dimmed-color);line-height:1.6;margin:0;max-width:1400px}@media (max-width:768px){.error-title[data-v-7b19ea5d]{font-size:2.2rem}.error-description[data-v-7b19ea5d]{font-size:1rem;padding:0 1rem}}.agent-view[data-v-4b0afde4]{min-height:100vh;background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:var(--text-color);display:flex;flex-direction:column}.agent-emoji-big[data-v-4b0afde4]{font-size:4rem;margin-top:40vh;text-align:center;animation:float-4b0afde4 6s ease-in-out infinite}.chat-container[data-v-4b0afde4]{position:fixed;left:0;right:0;bottom:60px;display:flex;flex-direction:column;align-items:center;gap:20px;pointer-events:none;z-index:10}.agent-bottom-bar[data-v-4b0afde4],.latest-message[data-v-4b0afde4]{max-width:90vh;width:92vw;min-width:0;margin:0 auto;border-radius:28px;box-shadow:0 6px 32px rgba(31,38,135,.13);pointer-events:auto}.latest-message[data-v-4b0afde4]{font-size:1.08rem;padding:16px 18px;margin-bottom:8px}.agent-bottom-bar[data-v-4b0afde4]{padding:12px 14px;margin-bottom:0;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.95);backdrop-filter:blur(10px);transition:all .3s ease}.agent-bottom-bar input[type=text][data-v-4b0afde4]{flex:1;border:2px solid #e0e0e0;border-radius:20px;padding:12px 14px;font-size:1.08rem;outline:none;background:hsla(0,0%,97%,.8);color:#2c3e50;transition:all .3s ease;margin-right:10px}.agent-bottom-bar button[data-v-4b0afde4]{border-radius:20px;padding:12px 22px;font-size:1.08rem}.agent-bottom-bar button[data-v-4b0afde4]:hover{background:#007aff;color:#fff;box-shadow:0 4px 12px rgba(0,122,255,.2);transition:all .3s ease;cursor:pointer}@keyframes float-4b0afde4{0%{transform:translateY(0)}50%{transform:translateY(-20px)}to{transform:translateY(0)}}@media (max-width:768px){.chat-container[data-v-4b0afde4]{bottom:90px;gap:10px}.agent-bottom-bar[data-v-4b0afde4],.latest-message[data-v-4b0afde4]{max-width:90vh;width:90vw;border-radius:22px;margin:0 auto;box-shadow:0 2px 12px rgba(31,38,135,.1)}.latest-message[data-v-4b0afde4]{font-size:1.05rem;padding:13px 6px}.agent-bottom-bar[data-v-4b0afde4]{padding:8px 6px}.agent-bottom-bar input[type=text][data-v-4b0afde4]{font-size:1.05rem;padding:10px 10px;border-radius:16px;margin-right:6px}.agent-bottom-bar button[data-v-4b0afde4]{padding:10px 16px;font-size:1.05rem;border-radius:16px}.input-tip[data-v-4b0afde4]{font-size:.82rem;margin-top:7px;font-weight:800;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif}}.msg-pop-enter-active[data-v-4b0afde4],.msg-pop-leave-active[data-v-4b0afde4]{transition:all .35s cubic-bezier(.68,-.55,.27,1.55)}.msg-pop-enter-from[data-v-4b0afde4]{opacity:0;transform:scale(.7) translateY(30px)}.msg-pop-enter-to[data-v-4b0afde4],.msg-pop-leave-from[data-v-4b0afde4]{opacity:1;transform:scale(1) translateY(0)}.msg-pop-leave-to[data-v-4b0afde4]{opacity:0;transform:scale(.7) translateY(-30px)}.input-tip[data-v-4b0afde4]{margin-top:8px;text-align:center;font-size:.82rem;color:#b0b8c9;letter-spacing:.02em;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;font-weight:500}body{--bg-color:#f8f8f8;--secondary-bg-color:#fff;--text-color:#1a1a1a;--text-dimmed-color:#555;--accent-color:#007aff;--accent-color-rgb:0,122,255;--glass-bg:hsla(0,0%,100%,.7);--glass-border:hsla(0,0%,86%,.5);--border-color:#ccc;--blur-amount:8px;--shadow-color-rgb:0,0,0}body.dark-mode{--bg-color:#0a0f1a;--secondary-bg-color:#070b14;--text-color:#e8e8e8;--text-dimmed-color:#b0b0b0;--accent-color:#007aff;--accent-color-rgb:0,122,255;--glass-bg:hsla(0,0%,100%,.05);--glass-border:hsla(0,0%,100%,.1);--border-color:#2a3b4c;--blur-amount:15px;--shadow-color-rgb:31,38,135}