*{margin:0;padding:0;box-sizing:border-box;font-family:Moon Stars Kai HW,sans-serif;font-weight:400}html,body,#root{height:100%;cursor:none}::-webkit-scrollbar{display:none}.hero-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8f0);color:#333;overflow:hidden;position:relative}.hero-container:before{content:"";position:absolute;top:0;left:0;right:0;height:100vh;background:linear-gradient(45deg,#6c63ff1a,#ff63c31a);z-index:0}.hero-container .global-floating-elements{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.hero-container .floating-circle{position:absolute;border-radius:50%;filter:blur(40px);opacity:.4}.hero-container .floating-circle:nth-child(1){width:400px;height:400px;background:linear-gradient(45deg,#6c63ff33,#ff63c333);top:10%;left:5%;animation:floatSlow 25s infinite ease-in-out}.hero-container .floating-circle:nth-child(2){width:300px;height:300px;background:linear-gradient(45deg,#63ffa133,#63c6ff33);top:60%;right:10%;animation:floatSlow 20s infinite ease-in-out reverse}.hero-container .floating-circle:nth-child(3){width:250px;height:250px;background:linear-gradient(45deg,#ffbd6333,#ff636333);bottom:10%;left:20%;animation:floatSlow 30s infinite ease-in-out 5s}@keyframes floatSlow{0%{transform:translate(0) rotate(0)}33%{transform:translate(50px,50px) rotate(120deg)}66%{transform:translate(-30px,30px) rotate(240deg)}to{transform:translate(0) rotate(360deg)}}.hero-container .light-effect{position:fixed;width:100%;height:100%;top:0;left:0;background:radial-gradient(circle at 50% 50%,#fff0,#ffffff1a);pointer-events:none;z-index:2;opacity:.7}.hero-container .content-section{padding:100px 5%;min-height:100vh;position:relative;z-index:3;opacity:0}.hero-container .content-section:before{content:"";position:absolute;top:50px;left:2%;right:2%;bottom:50px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:30px;z-index:-1;box-shadow:0 20px 80px #0000000d}.hero-container .main-hero{height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:0 5%}.hero-container .main-hero:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:30vh;background:linear-gradient(to bottom,transparent,rgba(245,247,250,.5) 50%,#f5f7fa);pointer-events:none}.hero-container .main-hero .hero-title{font-size:clamp(3rem,8vw,8rem);font-weight:900;color:#333;text-transform:uppercase;letter-spacing:-2px;position:relative;z-index:2;text-wrap:nowrap}.hero-container .main-hero .hero-title:before{content:attr(data-text);position:absolute;left:2px;top:2px;color:#6c63ff66;z-index:-1}.hero-container .main-hero .hero-subtitle{margin-top:20px;font-size:clamp(1.2rem,2vw,1.8rem);color:#333c;font-weight:300;letter-spacing:1px}.hero-container .main-hero .hero-subtitle .typing-text{position:relative}.hero-container .main-hero .hero-subtitle .typing-text:after{content:"|";animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.hero-container .main-hero .hero-cta{margin-top:40px;display:flex;gap:20px;flex-wrap:wrap;justify-content:center}.hero-container .main-hero .hero-cta .cta-button{padding:12px 28px;border-radius:30px;font-size:1rem;font-weight:500;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;border:none}.hero-container .main-hero .hero-cta .cta-button:hover{transform:translateY(-3px);box-shadow:0 10px 20px #0000001a}.hero-container .main-hero .hero-cta .cta-button.primary{background:#6c63ff;color:#fff}.hero-container .main-hero .hero-cta .cta-button.primary:hover{background:#5048ff}.hero-container .main-hero .hero-cta .cta-button.secondary{background:#fffc;color:#333;border:1px solid rgba(108,99,255,.3)}.hero-container .main-hero .hero-cta .cta-button.secondary:hover{background:#fff}.hero-container .main-hero .scroll-indicator{position:absolute;bottom:40px;display:flex;flex-direction:column;align-items:center}.hero-container .main-hero .scroll-indicator .scroll-text{font-size:.9rem;color:#333333b3;margin-bottom:10px}.hero-container .main-hero .scroll-indicator .scroll-arrow{display:flex;flex-direction:column;align-items:center}.hero-container .main-hero .scroll-indicator .scroll-arrow span{display:block;width:20px;height:20px;border-bottom:2px solid rgba(108,99,255,.7);border-right:2px solid rgba(108,99,255,.7);transform:rotate(45deg);margin:-10px;animation:scrollArrow 2s infinite}.hero-container .main-hero .scroll-indicator .scroll-arrow span:nth-child(2){animation-delay:.2s}.hero-container .main-hero .scroll-indicator .scroll-arrow span:nth-child(3){animation-delay:.4s}@keyframes scrollArrow{0%{opacity:0;transform:rotate(45deg) translate(-10px,-10px)}50%{opacity:1}to{opacity:0;transform:rotate(45deg) translate(10px,10px)}}.hero-container .main-hero .floating-element{position:absolute;width:300px;height:300px;background:linear-gradient(45deg,#6c63ff33,#ff63c333);border-radius:50%;filter:blur(40px);animation:float 10s infinite ease-in-out}.hero-container .main-hero .floating-element:nth-child(1){top:20%;left:10%;animation-delay:0s}.hero-container .main-hero .floating-element:nth-child(2){bottom:20%;right:10%;animation-delay:-5s}@keyframes float{0%{transform:translate(0) rotate(0)}50%{transform:translate(30px,30px) rotate(180deg)}to{transform:translate(0) rotate(360deg)}}.hero-container .project-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;padding:20px 0}.hero-container .project-grid .skill-card{background:#fffc;padding:30px;border-radius:20px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .4s ease;position:relative;overflow:hidden;opacity:0;transform:translateY(50px)}.hero-container .project-grid .skill-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(45deg,transparent,rgba(108,99,255,.1));transform:translate(-100%);transition:transform .6s ease}.hero-container .project-grid .skill-card:hover{transform:translateY(-10px) scale(1.02);box-shadow:0 30px 60px #00000026}.hero-container .project-grid .skill-card:hover:before{transform:translate(0)}.hero-container .project-grid .skill-card .skill-icon{width:60px;height:60px;background:#6c63ff1a;border-radius:50%;margin-bottom:15px;display:flex;align-items:center;justify-content:center;overflow:hidden}.hero-container .project-grid .skill-card .skill-level{height:6px;background:#3333331a;border-radius:3px;margin:15px 0;overflow:hidden}.hero-container .project-grid .skill-card .skill-level .skill-progress{height:100%;background:#6c63ff;border-radius:3px}.hero-container .project-grid .team-member-image{width:100%;height:100%;object-fit:cover;border-radius:50%}.hero-container .horizontal-container{position:relative;overflow:hidden;padding:70px 5% 40px;-webkit-user-select:none;user-select:none;touch-action:pan-y}.hero-container .horizontal-container .horizontal-track{display:inline-flex;align-items:stretch;flex-wrap:nowrap;gap:24px;cursor:grab}.hero-container .horizontal-container .horizontal-track.dragging{cursor:grabbing}.hero-container .horizontal-container .horizontal-section{flex:0 0 clamp(260px,26vw,340px);display:flex;align-items:stretch;justify-content:center;padding:0;height:auto}.hero-container .horizontal-container .horizontal-section .project-card{background:#fffc;border-radius:20px;padding:28px 30px;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;transition:transform .4s ease,box-shadow .4s ease;margin-bottom:15px}.hero-container .horizontal-container .horizontal-section .project-card:hover{transform:translateY(-10px);box-shadow:0 30px 60px #00000026}.hero-container .horizontal-container .horizontal-section .project-card .project-image{width:100%;background:transparent;border-radius:10px;margin-bottom:20px;overflow:hidden;display:flex;align-items:center;justify-content:center;aspect-ratio:1/1;padding:0 2px}.hero-container .horizontal-container .horizontal-section .project-card .project-image img{width:100%;height:100%;object-fit:contain;border-radius:10px}.hero-container .horizontal-container .horizontal-section .project-card h3{font-size:1.8rem;margin-top:0;margin-bottom:10px}.hero-container .horizontal-container .horizontal-section .project-card p{color:#333c;margin-bottom:20px}.hero-container .horizontal-container .horizontal-section .project-card .project-tech{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.hero-container .horizontal-container .horizontal-section .project-card .project-tech .tech-tag{background:#6c63ff1a;color:#6c63ff;padding:5px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.hero-container .horizontal-container .horizontal-section .project-card .project-link{display:inline-block;background:#6c63ff;color:#fff;padding:10px 20px;border-radius:30px;text-decoration:none;font-weight:500;transition:background .3s ease}.hero-container .horizontal-container .horizontal-section .project-card .project-link:hover{background:#3c30ff}@keyframes project-marquee{0%{transform:translateZ(0)}to{transform:translate3d(calc(-1 * var(--marquee-distance, 100%)),0,0)}}@media (max-width: 768px){.hero-container .horizontal-container{padding:36px 14px 24px}.hero-container .horizontal-container .horizontal-track{gap:16px}.hero-container .horizontal-container .horizontal-section{flex-basis:82vw}.hero-container .horizontal-container .project-card{padding:20px 22px;margin-bottom:32px}.hero-container .horizontal-container .project-image{margin-bottom:14px;padding:0 2px}.hero-container .horizontal-container h3{margin-bottom:6px}.hero-container .horizontal-container p{margin-bottom:14px}.hero-container .horizontal-container .project-tech{gap:8px;margin-bottom:14px}.hero-container .horizontal-container .project-link{padding:10px 18px}}.hero-container .section-title{font-size:2.5rem;margin-bottom:2rem;color:#333;position:relative}.hero-container .section-title:after{content:"";position:absolute;bottom:-10px;left:0;width:60px;height:4px;background:#6c63ff}.hero-container .welcome-content{display:flex;flex-wrap:wrap;gap:40px;margin-top:40px}.hero-container .welcome-content .welcome-text{flex:1;min-width:300px}.hero-container .welcome-content .welcome-text .lead-text{font-size:1.3rem;line-height:1.6;margin-bottom:30px}.hero-container .welcome-content .welcome-text .stats-container{display:flex;flex-wrap:wrap;gap:20px;margin-top:30px}.hero-container .welcome-content .welcome-text .stats-container .stat-item{flex:1;min-width:100px;padding:20px;background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-radius:10px;text-align:center;transition:transform .3s ease}.hero-container .welcome-content .welcome-text .stats-container .stat-item:hover{transform:translateY(-5px)}.hero-container .welcome-content .welcome-text .stats-container .stat-item .stat-number{display:block;font-size:2.5rem;font-weight:700;color:#6c63ff;margin-bottom:5px}.hero-container .welcome-content .welcome-text .stats-container .stat-item .stat-label{font-size:.9rem;color:#333c}.hero-container .welcome-content .welcome-image{flex:1;min-width:300px}.hero-container .welcome-content .welcome-image .image-container{position:relative;width:100%;display:flex;justify-content:center;align-items:center}.hero-container .about-content{margin-top:40px}.hero-container .about-tabs{display:flex;margin-bottom:30px;flex-wrap:wrap;border-bottom:1px solid rgba(51,51,51,.1)}.hero-container .about-tabs .tab-button{background:none;border:none;padding:12px 20px;font-size:1rem;cursor:pointer;position:relative;color:#333333b3;transition:all .3s ease;display:flex;align-items:center;gap:8px}.hero-container .about-tabs .tab-button .tab-icon{font-size:1.2rem;opacity:.7;transition:transform .3s ease}.hero-container .about-tabs .tab-button:after{content:"";position:absolute;bottom:-1px;left:0;width:0;height:2px;background:#6c63ff;transition:width .3s ease}.hero-container .about-tabs .tab-button.active,.hero-container .about-tabs .tab-button:hover{color:#333}.hero-container .about-tabs .tab-button.active .tab-icon,.hero-container .about-tabs .tab-button:hover .tab-icon{transform:scale(1.2);opacity:1}.hero-container .about-tabs .tab-button.active:after,.hero-container .about-tabs .tab-button:hover:after{width:100%}.hero-container .tab-content{display:none}.hero-container .tab-content.active{display:block;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hero-container .timeline-achievements{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.hero-container .timeline-achievements .achievement-badge{background:#6c63ff1a;color:#6c63ff;padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:500}.hero-container .culture-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px}.hero-container .culture-grid .culture-item{background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:25px;border-radius:15px;display:flex;gap:20px;transition:transform .3s ease,box-shadow .3s ease}.hero-container .culture-grid .culture-item:hover{transform:translateY(-5px);box-shadow:0 15px 30px #0000001a}.hero-container .culture-grid .culture-item .culture-icon{font-size:2.5rem;color:#6c63ff}.hero-container .culture-grid .culture-item .culture-content{flex:1}.hero-container .culture-grid .culture-item .culture-content h3{margin-top:0;margin-bottom:10px;color:#333}.hero-container .culture-grid .culture-item .culture-content p{color:#333c;margin-bottom:15px}.hero-container .culture-grid .culture-item .culture-content .culture-quote{font-style:italic;color:#6c63ff;font-weight:500;padding-left:10px;border-left:3px solid #6c63ff}.hero-container .timeline{position:relative;padding-left:30px}.hero-container .timeline:before{content:"";position:absolute;top:0;left:0;width:2px;height:100%;background:#6c63ff4d}.hero-container .timeline .timeline-item{position:relative;margin-bottom:30px}.hero-container .timeline .timeline-item .timeline-dot{position:absolute;left:-34px;top:5px;width:12px;height:12px;border-radius:50%;background:#6c63ff;border:2px solid #fff}.hero-container .timeline .timeline-item .timeline-date{font-size:.9rem;color:#333333b3;margin-bottom:5px}.hero-container .timeline .timeline-item .timeline-content{background:#ffffff1a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:20px;border-radius:10px}.hero-container .timeline .timeline-item .timeline-content h3{margin-top:0;margin-bottom:10px}.hero-container .timeline .timeline-item .timeline-content p{margin:0}.hero-container .contact-container{display:flex;flex-direction:column;gap:24px}.hero-container .contact-container .contact-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.hero-container .contact-container .contact-info-grid .contact-info-card{background:#fffc;border-radius:15px;padding:25px;box-shadow:0 10px 30px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.hero-container .contact-container .contact-info-grid .contact-info-card:hover{transform:translateY(-10px);box-shadow:0 15px 40px #00000026}.hero-container .contact-container .contact-info-grid .contact-info-card .contact-icon{font-size:2.5rem;margin-bottom:15px;color:#6c63ff}.hero-container .contact-container .contact-info-grid .contact-info-card h3{margin-bottom:15px;color:#333}.hero-container .contact-container .contact-info-grid .contact-info-card p{margin:8px 0;color:#555}.hero-container .contact-container .feedback-form-container{background:#fffc;border-radius:15px;padding:30px;box-shadow:0 10px 30px #0000001a;flex:1}.hero-container .contact-container .feedback-form-container h3{margin-bottom:20px;color:#333;text-align:center}.hero-container .contact-container .feedback-form-container .contact-form{flex:1}.hero-container .contact-container .feedback-form-container .contact-form .form-group{margin-bottom:20px}.hero-container .contact-container .feedback-form-container .contact-form .form-group label{display:block;margin-bottom:8px;font-weight:500}.hero-container .contact-container .feedback-form-container .contact-form .form-group input,.hero-container .contact-container .feedback-form-container .contact-form .form-group textarea{width:100%;padding:12px 15px;border:1px solid rgba(51,51,51,.1);border-radius:8px;background:#ffffff80;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);font-family:inherit;font-size:1rem;transition:border-color .3s ease}.hero-container .contact-container .feedback-form-container .contact-form .form-group input:focus,.hero-container .contact-container .feedback-form-container .contact-form .form-group textarea:focus{outline:none;border-color:#6c63ff}.hero-container .contact-container .feedback-form-container .contact-form .submit-button{background:#6c63ff;color:#fff;border:none;padding:12px 25px;border-radius:30px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .3s ease}.hero-container .contact-container .feedback-form-container .contact-form .submit-button:hover{background:#3c30ff}.hero-container .contact-image{border-radius:15px;object-fit:cover}@media (max-width: 768px){.hero-container .feedback-form-container{padding:20px}}.beian-info{text-align:center;padding:0 0 20px;margin-top:-20px}.beian-info a{color:#666;font-size:14px;text-decoration:none;transition:color .3s ease}.beian-info a:hover{color:#6c63ff}.cursor{width:20px;height:20px;background:#ffffff80;border-radius:50%;position:fixed;pointer-events:none;z-index:9999;mix-blend-mode:difference;transition:width .3s,height .3s,background-color .3s;box-shadow:0 0 15px #ffffff4d}.cursor-follower{width:40px;height:40px;background:#7d7d7d33;border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transition:transform .3s ease-out,background-color .3s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.cursor,.cursor-follower{display:none}}
