@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&family=Noto+Sans+SC:wght@300;400;500;700;900&display=swap";:root{--bg-deep:#03050a;--bg-dark:#080d18;--bg-card:#0a101eb3;--cyan:#00e5ff;--purple:#b44dff;--blue:#3b82f6;--pink:#ff2d95;--green:#0f8;--text:#e8edf5;--text-dim:#7b89a0;--border:#6482aa1f;--glow-cyan:0 0 20px #00e5ff40, 0 0 60px #00e5ff14;--glow-purple:0 0 20px #b44dff40, 0 0 60px #b44dff14;--glow-pink:0 0 20px #ff2d9540, 0 0 60px #ff2d9514;--font-display:"Space Grotesk", "Noto Sans SC", system-ui, sans-serif;--font-body:"Noto Sans SC", "Space Grotesk", system-ui, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}#bg-canvas{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0}body:after{content:"";pointer-events:none;z-index:0;background:repeating-linear-gradient(0deg,#00e5ff03 0,#0000 1px 50px,#00e5ff03 51px),repeating-linear-gradient(90deg,#00e5ff03 0,#0000 1px 50px,#00e5ff03 51px);position:fixed;inset:0}#root{z-index:1;position:relative}.container{max-width:920px;margin:0 auto;padding:0 28px}.section-tag{font-family:var(--font-display);letter-spacing:.18em;color:var(--cyan);text-transform:uppercase;text-shadow:0 0 12px #00e5ff66;align-items:center;gap:10px;margin-bottom:16px;font-size:.7rem;font-weight:600;display:inline-flex}.section-tag:before{content:"";background:var(--cyan);width:6px;height:6px;box-shadow:0 0 10px var(--cyan), 0 0 20px var(--cyan);border-radius:50%;display:inline-block}.section-title{font-family:var(--font-display);letter-spacing:-.5px;background:linear-gradient(135deg,#fff 0%,#89b 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2.5rem;font-weight:700}.section-sub{color:var(--text-dim);margin-bottom:48px;font-size:.95rem;font-weight:300}nav{z-index:100;-webkit-backdrop-filter:blur(20px)saturate(150%);backdrop-filter:blur(20px)saturate(150%);border-bottom:1px solid var(--border);background:#03050ac7;position:fixed;top:0;left:0;right:0}.nav-inner{justify-content:space-between;align-items:center;max-width:920px;margin:0 auto;padding:16px 28px;display:flex}.nav-logo{font-family:var(--font-display);background:linear-gradient(135deg, var(--cyan), var(--purple));-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 8px #00e5ff66);-webkit-background-clip:text;background-clip:text;font-size:1.3rem;font-weight:700}.nav-links{gap:30px;list-style:none;display:flex}.nav-links a{color:var(--text-dim);font-family:var(--font-display);font-size:.85rem;font-weight:500;text-decoration:none;transition:all .25s;position:relative}.nav-links a:after{content:"";background:var(--cyan);width:0;height:2px;box-shadow:0 0 8px var(--cyan);border-radius:1px;transition:width .25s;position:absolute;bottom:-4px;left:0}.nav-links a:hover{color:#fff}.nav-links a:hover:after{width:100%}.hero-section{align-items:center;min-height:100vh;padding-top:80px;display:flex;position:relative}.hero-avatar{background:linear-gradient(135deg, var(--cyan), var(--purple), var(--pink));width:100px;height:100px;font-family:var(--font-display);color:#fff;box-shadow:var(--glow-purple);border-radius:50%;justify-content:center;align-items:center;margin-bottom:32px;font-size:2.6rem;font-weight:700;animation:3s ease-in-out infinite avatarPulse;display:flex;position:relative}@keyframes avatarPulse{0%,to{box-shadow:var(--glow-purple)}50%{box-shadow:0 0 30px #b44dff66,0 0 80px #b44dff26}}.hero-section h1{font-family:var(--font-display);letter-spacing:-1.5px;margin-bottom:16px;font-size:3.8rem;font-weight:700;line-height:1.12}.hero-section h1 .wave{animation:2s ease-in-out infinite wave;display:inline-block}@keyframes wave{0%,to{transform:rotate(0)}25%{transform:rotate(14deg)}50%{transform:rotate(-6deg)}75%{transform:rotate(10deg)}}.hero-role{color:var(--text-dim);margin-bottom:20px;font-size:1.15rem;font-weight:400}.hero-role em{background:linear-gradient(135deg, var(--cyan), var(--purple));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal;font-weight:600}.hero-desc{max-width:540px;color:var(--text-dim);margin-bottom:32px;font-size:.98rem;font-weight:300;line-height:1.8}.tag-row{flex-wrap:wrap;gap:10px;display:flex}.tag{font-family:var(--font-display);color:var(--cyan);cursor:default;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);text-shadow:0 0 6px #00e5ff4d;background:#0a101e99;border:1px solid #00e5ff33;border-radius:24px;padding:7px 18px;font-size:.78rem;font-weight:500;transition:all .3s}.tag:hover{border-color:var(--cyan);background:#00e5ff14;transform:translateY(-2px);box-shadow:0 0 20px #00e5ff26}section.section{padding:100px 0;position:relative}section.alt{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#080d1880}.card-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;display:grid}.card{background:var(--bg-card);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;padding:30px 28px;transition:all .35s;position:relative;overflow:hidden}.card:before{content:"";background:linear-gradient(90deg, transparent, var(--cyan), transparent);opacity:0;height:2px;transition:opacity .35s;position:absolute;top:0;left:0;right:0}.card:hover:before{opacity:1}.card:hover{box-shadow:0 8px 32px #0000004d, var(--glow-cyan);border-color:#00e5ff40;transform:translateY(-3px)}.card-icon{border-radius:12px;justify-content:center;align-items:center;width:46px;height:46px;margin-bottom:18px;font-size:1.4rem;display:flex}.card h3{font-family:var(--font-display);color:#fff;margin-bottom:10px;font-size:1.05rem;font-weight:600}.card p{color:var(--text-dim);font-size:.88rem;line-height:1.7}.timeline{padding-left:30px;position:relative}.timeline:before{content:"";background:linear-gradient(180deg, var(--cyan), var(--purple), var(--pink));border-radius:1px;width:1px;position:absolute;top:8px;bottom:8px;left:7px;box-shadow:0 0 8px #00e5ff33}.timeline-item{margin-bottom:36px;position:relative}.timeline-item:before{content:"";background:var(--bg-deep);border:2px solid var(--cyan);border-radius:50%;width:11px;height:11px;transition:all .3s;position:absolute;top:7px;left:-26px;box-shadow:0 0 12px #00e5ff80}.timeline-item:hover:before{background:var(--cyan);box-shadow:0 0 20px #00e5ffcc}.timeline-year{font-family:var(--font-display);color:var(--cyan);letter-spacing:.06em;margin-bottom:6px;font-size:.75rem;font-weight:600}.timeline-item h4{font-family:var(--font-display);margin-bottom:6px;font-size:1.05rem;font-weight:600}.timeline-item p{color:var(--text-dim);font-size:.9rem;line-height:1.7}.hobby-grid{flex-wrap:wrap;gap:14px;display:flex}.hobby{background:var(--bg-card);border:1px solid var(--border);font-family:var(--font-display);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:default;border-radius:12px;align-items:center;gap:10px;padding:14px 24px;font-size:.95rem;font-weight:500;transition:all .3s;display:flex}.hobby:hover{border-color:var(--purple);box-shadow:var(--glow-purple);transform:translateY(-2px)}.hobby .emoji{font-size:1.4rem}.contact-box{background:var(--bg-card);border:1px solid var(--border);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:20px;padding:48px;position:relative;overflow:hidden}.contact-box:before{content:"";background:linear-gradient(90deg, transparent, var(--cyan), var(--purple), var(--pink), transparent);height:2px;position:absolute;top:0;left:0;right:0}.contact-box h3{font-family:var(--font-display);margin-bottom:10px;font-size:1.5rem}.contact-box p{color:var(--text-dim);margin-bottom:28px}.btn{background:linear-gradient(135deg, var(--cyan), var(--purple));color:#fff;font-family:var(--font-display);letter-spacing:.02em;cursor:pointer;box-shadow:var(--glow-purple);border:none;border-radius:30px;padding:14px 40px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .3s;display:inline-block}.btn:hover{transform:translateY(-2px);box-shadow:0 0 30px #b44dff73,0 0 60px #b44dff26}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#03050ad9;justify-content:center;align-items:center;padding:20px;animation:.25s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-box{background:var(--bg-card);text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;max-width:380px;box-shadow:0 20px 60px #00000080, var(--glow-cyan);border:1px solid #00e5ff2e;border-radius:24px;padding:44px 36px 36px;animation:.35s modalUp;position:relative}.modal-box:before{content:"";background:linear-gradient(90deg, transparent, var(--cyan), var(--purple), var(--pink), transparent);border-radius:2px 2px 0 0;height:2px;position:absolute;top:0;left:0;right:0}.modal-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:1.2rem;transition:color .2s;display:flex;position:absolute;top:14px;right:16px}.modal-close:hover{color:#fff;background:#ffffff0f}.modal-icon{margin-bottom:12px;font-size:2.8rem}.modal-box h2{font-family:var(--font-display);margin-bottom:6px;font-size:1.4rem;font-weight:700}.modal-sub{color:var(--text-dim);margin-bottom:24px;font-size:.85rem}.qr-wrapper{margin-bottom:24px;display:inline-block;position:relative}.qr-img{z-index:1;background:#fff;border:2px solid #00e5ff40;border-radius:14px;width:180px;height:180px;display:block;position:relative}.qr-glow{z-index:0;background:0 0;border-radius:20px;position:absolute;inset:-8px;box-shadow:0 0 30px #00e5ff33,0 0 60px #00e5ff14}.wechat-id-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;display:flex}.wechat-label{color:var(--text-dim);font-size:.8rem;font-weight:500}.wechat-id{font-family:var(--font-display);color:var(--cyan);letter-spacing:.03em;text-shadow:0 0 8px #00e5ff4d;background:#00e5ff0f;border:1px solid #00e5ff26;border-radius:8px;padding:6px 16px;font-size:1.1rem;font-weight:600}.copy-btn{font-family:var(--font-display);color:var(--cyan);cursor:pointer;background:#00e5ff1a;border:1px solid #00e5ff40;border-radius:20px;padding:7px 18px;font-size:.8rem;font-weight:600;transition:all .25s}.copy-btn:hover{background:#00e5ff2e;box-shadow:0 0 14px #00e5ff33}footer{text-align:center;color:var(--text-dim);border-top:1px solid var(--border);padding:40px 24px;font-size:.82rem}@media (width<=640px){.hero-section h1{font-size:2.4rem}.nav-links{display:none}section.section{padding:64px 0}.section-title{font-size:1.8rem}.card-grid{grid-template-columns:1fr}.contact-box{padding:32px 20px}}.reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(30px)}.reveal.visible{opacity:1;transform:translateY(0)}
