.wechat-login[data-v-ea75224e]{position:relative}.login-button[data-v-ea75224e]{display:flex;align-items:center;gap:8px;padding:8px 16px;background-color:#0a84ff;color:#fff;border:none;border-radius:999px;cursor:pointer;font-size:14px;transition:all .2s ease}.login-button[data-v-ea75224e]:hover{background-color:#0056b3;transform:translateY(-1px);box-shadow:0 18px 45px #0f172a1f}.wechat-icon[data-v-ea75224e]{width:18px;height:18px}.qr-code-container[data-v-ea75224e]{position:fixed;top:750%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;display:flex;align-items:center;justify-content:center;z-index:1000;box-sizing:border-box}.qr-code-overlay[data-v-ea75224e]{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080}.qr-code-modal[data-v-ea75224e]{position:relative;width:320px;padding:24px;background-color:#ffffffe6;border-radius:16px;box-shadow:0 18px 45px #0f172a1f;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);margin:0;box-sizing:border-box;z-index:1001}.modal-header[data-v-ea75224e]{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3[data-v-ea75224e]{margin:0;font-size:18px;color:#1f2933}.close-button[data-v-ea75224e]{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-button[data-v-ea75224e]:hover{background-color:#0000000d;color:#1f2933}.loading[data-v-ea75224e]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 0}.loading-spinner[data-v-ea75224e]{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #0a84ff;border-radius:50%;animation:spin-ea75224e 1s linear infinite;margin-bottom:16px}.qr-code[data-v-ea75224e]{width:200px;height:200px;margin:0 auto 16px;background-color:#fff;display:flex;align-items:center;justify-content:center;border-radius:16px;padding:12px;overflow:hidden;box-sizing:border-box;position:relative}.qr-code img[data-v-ea75224e]{max-width:100%;max-height:100%;display:block}.qr-code-placeholder[data-v-ea75224e]{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:#6b7280;font-size:14px;background-color:#f9fafb;border-radius:8px}.login-tip[data-v-ea75224e]{text-align:center;color:#6b7280;font-size:14px;margin:0 0 8px;line-height:1.5}.countdown-tip[data-v-ea75224e],.expired-tip[data-v-ea75224e]{text-align:center;color:#ef4444;font-size:14px;margin:0;line-height:1.5;font-weight:500}.refresh-overlay[data-v-ea75224e]{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#00000080;cursor:pointer;border-radius:16px;transition:opacity .2s ease}.refresh-overlay[data-v-ea75224e]:hover{opacity:.8}.refresh-icon[data-v-ea75224e]{font-size:48px;color:#fff;animation:spin-ea75224e 2s linear infinite}@keyframes spin-ea75224e{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.navbar[data-v-761fa92e]{position:fixed;top:0;left:0;right:0;z-index:1000;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.navbar__inner[data-v-761fa92e]{max-width:1120px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;justify-content:space-between}@media (min-width: 768px){.navbar__inner[data-v-761fa92e]{padding:16px 32px}}@media (min-width: 1024px){.navbar__inner[data-v-761fa92e]{padding:16px 48px}}.navbar__actions[data-v-761fa92e]{display:flex;gap:12px;align-items:center}@media (min-width: 768px){.navbar__actions[data-v-761fa92e]{gap:16px}}.navbar__help-btn[data-v-761fa92e]{background:#0a84ff1a;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#0a84ff;transition:all .3s ease}@media (min-width: 768px){.navbar__help-btn[data-v-761fa92e]{width:36px;height:36px}}.navbar__help-btn svg[data-v-761fa92e]{width:18px;height:18px}@media (min-width: 768px){.navbar__help-btn svg[data-v-761fa92e]{width:20px;height:20px}}.navbar__help-btn[data-v-761fa92e]:hover{background:#0a84ff33;transform:scale(1.1)}.navbar__logo[data-v-761fa92e]{font-size:20px;font-weight:700;color:#0a84ff;position:relative;cursor:pointer;transition:all .3s ease;letter-spacing:.02em}@media (min-width: 768px){.navbar__logo[data-v-761fa92e]{font-size:24px}}.navbar__logo[data-v-761fa92e]:after{content:"";position:absolute;bottom:-4px;left:0;width:100%;height:2px;background-color:#0a84ff;transform:scaleX(0);transition:transform .3s ease}.navbar__logo[data-v-761fa92e]:hover{color:#0056b3;transform:translateY(-2px)}.navbar__logo[data-v-761fa92e]:hover:after{transform:scaleX(1)}.navbar__links[data-v-761fa92e]{display:none}@media (min-width: 768px){.navbar__links[data-v-761fa92e]{display:flex;align-items:center;gap:8px}}@media (min-width: 1024px){.navbar__links[data-v-761fa92e]{gap:16px}}.navbar__links a[data-v-761fa92e]{position:relative;color:#1f2933;text-decoration:none;transition:color .3s ease;padding:8px 0;font-size:14px;white-space:nowrap}@media (min-width: 1024px){.navbar__links a[data-v-761fa92e]{font-size:15px;padding:8px 4px}}.navbar__links a[data-v-761fa92e]:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background-color:#0a84ff;transform:scaleX(0);transition:transform .3s ease}.navbar__links a[data-v-761fa92e]:hover{color:#0a84ff}.navbar__links a[data-v-761fa92e]:hover:after{transform:scaleX(1)}.back-to-top[data-v-a55143d5]{position:fixed;bottom:68px;right:68px;width:48px;height:48px;border-radius:50%;background-color:#0a84ff;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0a84ff4d;transition:all .3s ease;z-index:999}.back-to-top[data-v-a55143d5]:hover{background-color:#0056b3;transform:translateY(-2px);box-shadow:0 6px 16px #0a84ff66}.back-to-top[data-v-a55143d5]:active{transform:translateY(0)}.guide-tour[data-v-f31c1655]{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:center;justify-content:center}.guide-overlay[data-v-f31c1655]{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.guide-content[data-v-f31c1655]{position:relative;background:linear-gradient(135deg,#fffffff2,#ffffffe6);border-radius:24px;padding:40px;max-width:600px;width:90%;box-shadow:0 20px 60px #0000004d;animation:slideUp-f31c1655 .4s ease-out;border:1px solid rgba(255,255,255,.2)}@keyframes slideUp-f31c1655{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.guide-close[data-v-f31c1655]{position:absolute;top:20px;right:20px;background:#0000000d;border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#666}.guide-close[data-v-f31c1655]:hover{background:#0000001a;color:#333}.guide-body[data-v-f31c1655]{margin-bottom:30px}.guide-image[data-v-f31c1655]{margin-bottom:24px;text-align:center;display:flex;align-items:center;justify-content:center;min-height:200px}.guide-image img[data-v-f31c1655]{max-width:100%;max-height:320px;width:auto;height:auto;border-radius:16px;box-shadow:0 8px 24px #0000001f;object-fit:contain;display:block;margin:0 auto;animation:imageZoomIn-f31c1655 .5s ease-out;transition:all .3s ease}.guide-image img[data-v-f31c1655]:hover{transform:scale(1.02);box-shadow:0 12px 32px #0000002e}@keyframes imageZoomIn-f31c1655{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.guide-image-placeholder[data-v-f31c1655]{font-size:80px;height:120px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;margin:0 auto;max-width:200px;animation:iconFloat-f31c1655 3s ease-in-out infinite;box-shadow:0 8px 24px #667eea4d}.guide-image-placeholder[data-v-f31c1655]:has(+.guide-text .guide-title:contains("💡")){background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 8px 24px #f5576c4d}@keyframes iconFloat-f31c1655{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.guide-text[data-v-f31c1655]{text-align:center}.guide-title[data-v-f31c1655]{font-size:24px;font-weight:600;color:#1a1a1a;margin:0 0 12px;animation:fadeInUp-f31c1655 .5s ease-out .1s both}.guide-description[data-v-f31c1655]{font-size:16px;line-height:1.6;color:#666;margin:0;animation:fadeInUp-f31c1655 .5s ease-out .2s both}@keyframes fadeInUp-f31c1655{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.guide-footer[data-v-f31c1655]{display:flex;flex-direction:column;gap:20px}.guide-progress[data-v-f31c1655]{display:flex;justify-content:center;gap:8px}.guide-dot[data-v-f31c1655]{width:8px;height:8px;border-radius:50%;background:#0003;cursor:pointer;transition:all .3s}.guide-dot.active[data-v-f31c1655]{background:linear-gradient(135deg,#667eea,#764ba2);width:24px;border-radius:4px}.guide-dot[data-v-f31c1655]:hover{background:#0006}.guide-actions[data-v-f31c1655]{display:flex;gap:12px;justify-content:center}.guide-btn[data-v-f31c1655]{padding:12px 32px;border-radius:12px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;border:none;min-width:120px}.guide-btn-primary[data-v-f31c1655]{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.guide-btn-primary[data-v-f31c1655]:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.guide-btn-secondary[data-v-f31c1655]{background:#0000000d;color:#666}.guide-btn-secondary[data-v-f31c1655]:hover:not(:disabled){background:#0000001a;color:#333}.guide-btn-secondary[data-v-f31c1655]:disabled{opacity:.3;cursor:not-allowed}.guide-skip[data-v-f31c1655]{margin-top:16px;text-align:center}.guide-skip label[data-v-f31c1655]{display:inline-flex;align-items:center;gap:6px;font-size:14px;color:#999;cursor:pointer}.guide-skip input[type=checkbox][data-v-f31c1655]{cursor:pointer}@media (max-width: 768px){.guide-content[data-v-f31c1655]{padding:30px 20px;width:95%}.guide-image[data-v-f31c1655]{min-height:160px}.guide-image img[data-v-f31c1655]{max-height:240px;border-radius:12px}.guide-title[data-v-f31c1655]{font-size:20px}.guide-description[data-v-f31c1655]{font-size:14px}.guide-image-placeholder[data-v-f31c1655]{font-size:60px;height:100px}.guide-btn[data-v-f31c1655]{padding:10px 24px;font-size:14px;min-width:100px}}.message-toast-container[data-v-8c9120a6]{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;width:320px;max-width:calc(100vw - 40px)}.message-toast[data-v-8c9120a6]{display:flex;align-items:flex-start;padding:16px;margin-bottom:12px;border-radius:8px;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation-duration:.3s;animation-fill-mode:forwards}.message-toast--success[data-v-8c9120a6]{background:#f6fff5f2;border:1px solid rgba(115,210,22,.3);color:#2d6a4f}.message-toast--error[data-v-8c9120a6]{background:#fff5f5f2;border:1px solid rgba(235,87,87,.3);color:#c0392b}.message-toast--warning[data-v-8c9120a6]{background:#fffcf5f2;border:1px solid rgba(243,156,18,.3);color:#d35400}.message-toast--info[data-v-8c9120a6]{background:#f5f9fff2;border:1px solid rgba(52,152,219,.3);color:#2980b9}.message-toast__icon[data-v-8c9120a6]{flex-shrink:0;margin-right:12px;display:flex;align-items:center;justify-content:center}.message-toast__content[data-v-8c9120a6]{flex:1;min-width:0}.message-toast__text[data-v-8c9120a6]{margin:0;font-size:14px;line-height:1.4;word-break:break-word}.message-toast__close[data-v-8c9120a6]{flex-shrink:0;margin-left:12px;background:transparent;border:none;cursor:pointer;padding:4px;border-radius:4px;opacity:.7;transition:all .2s}.message-toast__close[data-v-8c9120a6]:hover{opacity:1;background:#0000000d}.toast-enter-active[data-v-8c9120a6]{animation:toastSlideIn-8c9120a6 .3s ease-out}.toast-leave-active[data-v-8c9120a6]{animation:toastSlideOut-8c9120a6 .3s ease-in}@keyframes toastSlideIn-8c9120a6{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastSlideOut-8c9120a6{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media (max-width: 768px){.message-toast-container[data-v-8c9120a6]{width:calc(100vw - 40px);top:10px;right:10px}.message-toast[data-v-8c9120a6]{padding:12px}.message-toast__text[data-v-8c9120a6]{font-size:13px}}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,system-ui,-system-ui,Segoe UI,sans-serif;color:#1f2933;background:linear-gradient(180deg,#f7f8fb,#eceff7 40%,#fff);-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}ul{list-style:none}img{max-width:100%;display:block}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;padding-top:60px}@media (min-width: 768px){.app-main{padding-top:72px}}.section{padding:48px 16px}@media (min-width: 768px){.section{padding:64px 32px}}@media (min-width: 1024px){.section{padding:96px 48px}}.container{max-width:100%;margin:0 auto;width:100%}@media (min-width: 768px){.container{max-width:720px}}@media (min-width: 1024px){.container{max-width:1120px}}.section-title{font-size:24px;letter-spacing:.04em;margin-bottom:24px;font-weight:700}@media (min-width: 768px){.section-title{font-size:28px;margin-bottom:32px}}@media (min-width: 1024px){.section-title{font-size:32px;margin-bottom:40px}}.glass{background:#ffffffe6;border-radius:24px;border:1px solid rgba(15,23,42,.06);box-shadow:0 18px 45px #0f172a1f;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}.navbar{position:fixed;top:16px;left:0;right:0;z-index:10}.navbar__inner{max-width:1120px;margin:0 auto;padding:10px 16px;display:flex;align-items:center;justify-content:space-between}.navbar__logo{padding:6px 14px;border-radius:999px;background:#ffffff29;font-weight:600;letter-spacing:.08em;font-size:13px}.navbar__links{display:flex;gap:16px;font-size:14px}.navbar__links a{padding:6px 10px;border-radius:999px;color:#6b7280;transition:all .18s ease-out}.navbar__links a:hover{color:#1f2933;background:#ffffff1f}.hero__inner{padding:32px 20px 40px}@media (min-width: 768px){.hero__inner{padding:40px 32px 48px}}@media (min-width: 1024px){.hero__inner{padding:48px 40px 56px}}.hero__layout{display:grid;gap:24px;align-items:center}@media (min-width: 768px){.hero__layout{gap:32px}}.hero__header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:8px;flex-direction:column;gap:20px}@media (min-width: 768px){.hero__header{flex-direction:row;gap:0}}.hero__text-content{display:flex;flex-direction:column;gap:8px;text-align:center}@media (min-width: 768px){.hero__text-content{gap:12px;text-align:left}}.hero__avatar{display:flex;justify-content:center}.hero__avatar-ring{width:120px;height:120px;border-radius:50%;padding:4px;background:linear-gradient(135deg,#0a84ff66,#ff9ff366);display:flex;align-items:center;justify-content:center;animation:hero-avatar-float 4s ease-in-out infinite}@media (min-width: 768px){.hero__avatar-ring{width:144px;height:144px}}.hero__avatar-inner{width:100%;height:100%;border-radius:50%;background:#ffffffe6;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:600;color:#333;object-fit:cover}@media (min-width: 768px){.hero__avatar-inner{font-size:32px}}.hero__eyebrow{letter-spacing:.16em;text-transform:uppercase;color:#9ca3af;font-size:11px;margin-bottom:8px}@media (min-width: 768px){.hero__eyebrow{font-size:12px;margin-bottom:12px}}.hero__title{font-size:32px;letter-spacing:.02em;margin-bottom:8px;font-weight:700}@media (min-width: 768px){.hero__title{font-size:40px}}@media (min-width: 1024px){.hero__title{font-size:48px}}.hero__subtitle{color:#6b7280;margin-bottom:12px;font-size:14px}@media (min-width: 768px){.hero__subtitle{margin-bottom:16px;font-size:15px}}.hero__tagline{margin-bottom:12px;font-size:15px;line-height:1.6}@media (min-width: 768px){.hero__tagline{margin-bottom:16px;font-size:16px}}.hero__line{color:#6b7280;font-size:13px;line-height:1.6}@media (min-width: 768px){.hero__line{font-size:14px}}.hero__lines{display:grid;gap:4px;margin-bottom:16px}@media (min-width: 768px){.hero__lines{margin-bottom:20px}}.hero__actions{display:flex;gap:12px;justify-content:center}@media (min-width: 768px){.hero__actions{justify-content:flex-start}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:999px;font-size:14px;border:1px solid transparent;cursor:pointer;transition:all .18s ease-out;white-space:nowrap}@media (min-width: 768px){.btn{padding:12px 24px;font-size:15px}}.btn-primary{background:#0a84ff;color:#fff;box-shadow:0 14px 30px #0a84ff66}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 18px 40px #0a84ff8c}.education__list{display:grid;gap:12px}@media (min-width: 768px) and (max-width: 1023px){.education__list{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}@media (min-width: 1024px){.education__list{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}}.education__item{padding:18px 16px}@media (min-width: 768px){.education__item{padding:20px 20px 18px}}.education__period{font-size:12px;color:#9ca3af;margin-bottom:6px}@media (min-width: 768px){.education__period{font-size:13px}}.education__school{font-size:17px;margin-bottom:4px;font-weight:600}@media (min-width: 768px){.education__school{font-size:18px}}.education__meta{font-size:13px;color:#6b7280;margin-bottom:6px}@media (min-width: 768px){.education__meta{font-size:14px}}.education__description{font-size:13px;color:#6b7280;line-height:1.6}@media (min-width: 768px){.education__description{font-size:14px}}.projects__grid{display:grid;gap:12px}@media (min-width: 768px) and (max-width: 1023px){.projects__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}@media (min-width: 1024px){.projects__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}}.project-card{padding:18px 16px}@media (min-width: 768px){.project-card{padding:20px 20px 18px}}.project-card__title{font-size:17px;margin-bottom:2px;font-weight:600}@media (min-width: 768px){.project-card__title{font-size:18px}}.project-card__role{font-size:12px;color:#9ca3af;margin-bottom:8px}@media (min-width: 768px){.project-card__role{font-size:13px;margin-bottom:10px}}.project-card__intro{font-size:13px;color:#6b7280;margin-bottom:8px;line-height:1.6}@media (min-width: 768px){.project-card__intro{font-size:14px}}.project-card__list{font-size:13px;color:#6b7280;display:grid;gap:4px;margin-bottom:12px;line-height:1.6}@media (min-width: 768px){.project-card__list{font-size:14px}}.project-card__tags{display:flex;flex-wrap:wrap;gap:6px}.project-card__tag{padding:4px 10px;border-radius:999px;background:#ffffff1f;font-size:11px}@media (min-width: 768px){.project-card__tag{font-size:12px}}.skills__grid{display:grid;gap:12px}@media (min-width: 768px) and (max-width: 1023px){.skills__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}}@media (min-width: 1024px){.skills__grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}}.skills__group{padding:16px 14px}@media (min-width: 768px){.skills__group{padding:18px 18px 16px}}.skills__group-title{font-size:15px;margin-bottom:8px;font-weight:600}@media (min-width: 768px){.skills__group-title{font-size:16px}}.skills__list{font-size:13px;color:#6b7280;display:grid;gap:4px;line-height:1.6}@media (min-width: 768px){.skills__list{font-size:14px}}.contact__cards{display:grid}.social-card{padding:18px 16px}@media (min-width: 768px){.social-card{padding:20px 20px 18px}}.social-card__title{font-size:17px;margin-bottom:10px;font-weight:600}@media (min-width: 768px){.social-card__title{font-size:18px}}.social-card__list{display:grid;gap:8px;font-size:13px}@media (min-width: 768px){.social-card__list{font-size:14px}}.social-card__label{color:#1f2933;font-weight:500}.social-card__value{color:#6b7280;margin-left:8px}.footer{padding:20px 16px 28px}@media (min-width: 768px){.footer{padding:24px 32px 32px}}.footer__inner{max-width:1120px;margin:0 auto;font-size:11px;color:#9ca3af;display:flex;flex-direction:column;gap:4px;text-align:center}@media (min-width: 768px){.footer__inner{font-size:12px;text-align:left}}.footer__motto{color:#6b7280}@keyframes hero-avatar-float{0%{transform:translateY(0)}50%{transform:translateY(-6px)}to{transform:translateY(0)}}
