:root{--color-primary: #8B4513;--color-primary-dark: #6B3410;--color-primary-light: #A0522D;--color-secondary: #CD853F;--color-accent: #DEB887;--color-accent-light: #F5DEB3;--color-logo: #1a1a2e;--color-logo-hover: #16213e;--color-logo-accent: #B8860B;--color-white: #FFFFFF;--color-off-white: #FAFAFA;--color-light-gray: #F5F5F5;--color-gray: #E0E0E0;--color-dark-gray: #666666;--color-text: #333333;--color-text-light: #777777;--font-heading: "Playfair Display", Georgia, serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--section-padding: 120px;--container-width: 1200px;--transition-fast: .2s ease;--transition-medium: .4s ease;--transition-slow: .6s ease;--transition-bounce: .6s cubic-bezier(.68, -.55, .265, 1.55)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);color:var(--color-text);background-color:var(--color-white);line-height:1.6;overflow-x:hidden;cursor:none}a{text-decoration:none;color:inherit;cursor:none}button{cursor:none;border:none;background:none;font-family:inherit}ul{list-style:none}img{max-width:100%;height:auto}.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}.section{position:relative;padding:var(--section-padding) 0;overflow:hidden}.cursor-pointer{position:fixed;pointer-events:none;z-index:9999;color:var(--color-primary);filter:drop-shadow(0 2px 4px rgba(139,69,19,.3));transition:transform .15s ease,color .2s ease}.cursor-icon{width:24px;height:24px;transform:translate(-3px,-2px)}.cursor-pointer.hover{color:var(--color-secondary);transform:scale(1.1)}.cursor-pointer.hover .cursor-icon{animation:cursorBounce .4s ease}@keyframes cursorBounce{0%,to{transform:translate(-3px,-2px) scale(1)}50%{transform:translate(-3px,-2px) scale(1.15)}}.cursor-circle-ring{position:fixed;width:44px;height:44px;border:1.5px solid var(--color-primary);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;transition:width .3s ease,height .3s ease,border-color .2s ease,opacity .2s ease}.cursor-circle-ring.hover{width:60px;height:60px;border-color:var(--color-secondary);border-width:2px;opacity:.8;animation:ringPulse 1s ease-in-out infinite}@keyframes ringPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.8}50%{transform:translate(-50%,-50%) scale(1.08);opacity:.5}}.cursor-trail-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9997}.cursor-trail-dot{position:absolute;width:6px;height:6px;background:var(--color-primary);border-radius:50%;transform:translate(-50%,-50%);opacity:0;pointer-events:none;transition:opacity .1s ease}.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:all var(--transition-medium)}.navbar.scrolled{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 2px 30px #8b45131a;padding:15px 0}.nav-container{max-width:var(--container-width);margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.nav-logo{position:relative;z-index:1001}.logo-wrapper{display:flex;align-items:center;gap:12px}.logo-svg,.logo-img{width:48px;height:48px;object-fit:contain;transition:transform var(--transition-medium),filter var(--transition-fast);filter:sepia(1) saturate(3) hue-rotate(-15deg) brightness(.7)}.nav-logo:hover .logo-svg,.nav-logo:hover .logo-img{transform:scale(1.08)}.logo-text-sub{font-family:var(--font-heading);font-size:18px;font-weight:600;color:var(--color-text);letter-spacing:0;transition:color var(--transition-fast)}.nav-logo:hover .logo-text-sub{color:var(--color-primary)}@media(max-width:1100px){.logo-text-sub{display:none}}@media(max-width:768px){.logo-svg,.logo-img{width:42px;height:42px}}.nav-menu{display:flex;gap:40px}.nav-link{font-size:14px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--color-text);position:relative;padding:5px 0;transition:color var(--transition-fast)}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-primary);transition:width var(--transition-medium)}.nav-link:hover,.nav-link.active{color:var(--color-primary)}.nav-link:hover:after,.nav-link.active:after{width:100%}.nav-toggle{display:none;flex-direction:column;gap:6px;cursor:none;z-index:1001}.nav-toggle span{width:25px;height:2px;background:var(--color-text);transition:all var(--transition-fast)}.hero{min-height:100vh;display:flex;align-items:center;position:relative;background:linear-gradient(135deg,var(--color-white) 0%,var(--color-off-white) 100%);overflow:hidden}.hero-parallax-bg{position:absolute;inset:-50% -25%;will-change:transform;pointer-events:none}.hero-parallax-bg.layer-1{background:radial-gradient(ellipse 800px 800px at 20% 30%,rgba(139,69,19,.08) 0%,transparent 70%),radial-gradient(ellipse 600px 600px at 80% 70%,rgba(205,133,63,.06) 0%,transparent 70%)}.hero-parallax-bg.layer-2{background:radial-gradient(ellipse 500px 500px at 60% 20%,rgba(222,184,135,.1) 0%,transparent 60%),radial-gradient(ellipse 400px 400px at 30% 80%,rgba(139,69,19,.05) 0%,transparent 60%)}.hero-parallax-bg.layer-3{background:radial-gradient(ellipse 300px 300px at 70% 50%,rgba(205,133,63,.12) 0%,transparent 50%),radial-gradient(ellipse 250px 250px at 20% 60%,rgba(222,184,135,.08) 0%,transparent 50%)}.hero-content{max-width:var(--container-width);margin:0 auto;padding:100px 24px 0;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}.hero-text{position:relative;z-index:2}.hero-greeting{font-size:18px;color:var(--color-primary);font-weight:500;letter-spacing:3px;text-transform:uppercase;margin-bottom:16px}.hero-name{font-family:var(--font-heading);font-size:clamp(48px,6vw,72px);font-weight:700;white-space:nowrap;color:var(--color-text);line-height:1.1;margin-bottom:20px}.hero-title-wrapper{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.hero-title{font-size:20px;color:var(--color-primary-light);font-weight:500}.hero-divider{color:var(--color-gray);font-weight:300}.hero-description{font-size:18px;color:var(--color-text-light);line-height:1.8;max-width:500px;margin-bottom:40px}.hero-cta{display:flex;gap:20px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 36px;font-size:14px;font-weight:600;letter-spacing:1px;text-transform:uppercase;border-radius:50px;transition:all var(--transition-medium);position:relative;overflow:hidden}.btn-primary{background:var(--color-primary);color:var(--color-white);border:2px solid var(--color-primary)}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);transform:translateY(-3px);box-shadow:0 10px 30px #8b45134d}.btn-primary:hover:before{left:100%}.btn-secondary{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-secondary:hover{background:var(--color-primary);color:var(--color-white);transform:translateY(-3px);box-shadow:0 10px 30px #8b451333}.btn-scholar{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary);padding:10px 20px;font-size:12px;gap:8px}.btn-scholar .btn-scholar-icon{width:18px;height:18px;flex-shrink:0}.btn-scholar:hover{background:var(--color-primary);color:var(--color-white);transform:translateY(-3px);box-shadow:0 10px 30px #8b451333}.btn-scholar .hero-cta-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-8px);padding:8px 12px;background:var(--color-text);color:var(--color-white);font-size:12px;font-weight:500;white-space:nowrap;border-radius:8px;opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast),transform var(--transition-fast);pointer-events:none;box-shadow:0 4px 12px #00000026}.btn-scholar .hero-cta-tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-6px;border:6px solid transparent;border-top-color:var(--color-text)}.btn-scholar:hover .hero-cta-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(-12px)}.hero-image{position:relative;display:flex;justify-content:center;align-items:center}.hero-image-wrapper{position:relative;width:400px;height:480px}.hero-image-bg{position:absolute;top:20px;left:20px;width:100%;height:100%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:20px;opacity:.3}.hero-profile-image{position:relative;width:100%;height:100%;object-fit:cover;object-position:center top;border-radius:20px;box-shadow:0 30px 60px #8b451333}.hero-floating-card{position:absolute;background:var(--color-white);padding:16px 24px;border-radius:12px;box-shadow:0 10px 40px #8b451326;display:flex;align-items:center;gap:12px;animation:float 6s ease-in-out infinite,glow 3s ease-in-out infinite alternate;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(139,69,19,.1);transition:box-shadow .3s ease}.hero-floating-card:hover{box-shadow:0 20px 60px #8b451340}.hero-floating-card.card-1{top:40px;right:-30px;animation-delay:0s,0s}.hero-floating-card.card-2{bottom:60px;left:-40px;animation-delay:3s,1.5s}.hero-floating-card.card-3{bottom:60px;right:-30px;animation-delay:1.5s,2s}@keyframes glow{0%{box-shadow:0 10px 40px #8b451326}to{box-shadow:0 15px 50px #8b451340}}.card-icon{font-size:24px}.card-text-wrap{display:flex;flex-direction:column;gap:2px;align-items:flex-start}.card-text{font-size:14px;font-weight:600;color:var(--color-text)}.card-text-sub{font-size:.85em;font-weight:500;color:var(--color-text-light)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.hero-scroll-indicator{position:absolute;bottom:40px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--color-text-light);font-size:12px;letter-spacing:2px;text-transform:uppercase}.scroll-line{width:1px;height:60px;background:linear-gradient(to bottom,var(--color-primary),transparent);animation:scrollLine 2s ease-in-out infinite}@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform:scaleY(1);transform-origin:bottom}to{transform:scaleY(0);transform-origin:bottom}}.animate-fade-up{opacity:0;transform:translateY(40px);animation:fadeUp .8s ease forwards}.animate-fade-left{opacity:0;transform:translate(40px);animation:fadeLeft .8s ease forwards}.delay-1{animation-delay:.2s}.delay-2{animation-delay:.4s}.delay-3{animation-delay:.6s}.delay-4{animation-delay:.8s}@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}@keyframes fadeLeft{to{opacity:1;transform:translate(0)}}.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}.animate-on-scroll.animated{opacity:1;transform:translateY(0)}.section-header{text-align:center;margin-bottom:80px}.section-tag{display:inline-block;font-size:14px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--color-primary);margin-bottom:16px;position:relative}.section-tag:before,.section-tag:after{content:"";position:absolute;top:50%;width:40px;height:1px;background:var(--color-primary)}.section-tag:before{left:-60px}.section-tag:after{right:-60px}.section-title{font-family:var(--font-heading);font-size:clamp(36px,5vw,52px);font-weight:600;color:var(--color-text)}.about{background:var(--color-white)}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.about-lead{font-size:22px;font-weight:500;color:var(--color-text);line-height:1.6;margin-bottom:20px}.about-text p{color:var(--color-text-light);margin-bottom:20px;line-height:1.8}.about-details{display:flex;flex-direction:column;gap:16px;margin-top:30px;padding-top:30px;border-top:1px solid var(--color-gray)}.detail-item{display:flex;gap:16px}.detail-label{font-size:14px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:1px;min-width:100px}.detail-value{color:var(--color-text)}.skills-title{font-family:var(--font-heading);font-size:28px;margin-bottom:30px;color:var(--color-text)}.skills-grid{display:flex;flex-direction:column;gap:30px}.skill-category h4{font-size:14px;text-transform:uppercase;letter-spacing:2px;color:var(--color-primary);margin-bottom:16px}.skill-tags{display:flex;flex-wrap:wrap;gap:10px}.skill-tag{background:var(--color-light-gray);color:var(--color-text);padding:10px 20px;border-radius:50px;font-size:14px;font-weight:500;transition:all var(--transition-fast)}.skill-tag:hover{background:var(--color-primary);color:var(--color-white);transform:translateY(-2px)}.experience{background:var(--color-off-white);position:relative}.experience-bg{position:absolute;inset:0;background:radial-gradient(circle at 0% 50%,rgba(139,69,19,.03) 0%,transparent 50%),radial-gradient(circle at 100% 50%,rgba(205,133,63,.05) 0%,transparent 50%);will-change:transform}.timeline{position:relative;padding-left:40px}.timeline:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--color-primary),var(--color-secondary))}.timeline-item{position:relative;padding-bottom:60px}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-46px;top:0;width:14px;height:14px;background:var(--color-white);border:3px solid var(--color-primary);border-radius:50%;transition:all var(--transition-fast)}.timeline-item:hover .timeline-marker{background:var(--color-primary);transform:scale(1.3)}.timeline-content{background:var(--color-white);padding:40px;border-radius:16px;box-shadow:0 10px 40px #8b451314;transition:all var(--transition-medium)}.timeline-content:hover{transform:translate(10px);box-shadow:0 20px 60px #8b45131f}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}.timeline-date{font-size:14px;font-weight:600;color:var(--color-primary);letter-spacing:1px}.timeline-location{font-size:14px;color:var(--color-text-light)}.timeline-company-row{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.company-logo-wrapper{flex-shrink:0;width:64px;height:64px;border-radius:14px;overflow:hidden;background:linear-gradient(135deg,var(--color-white) 0%,var(--color-light-gray) 100%);box-shadow:0 4px 20px #8b45131f;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;border:2px solid var(--color-gray);position:relative}.company-logo-wrapper:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);opacity:0;transition:opacity var(--transition-fast);border-radius:12px}.company-logo-wrapper:hover{transform:scale(1.1) rotate(-3deg);box-shadow:0 10px 35px #8b451340;border-color:var(--color-primary)}.company-logo-wrapper:hover:before{opacity:.08}.company-logo{width:100%;height:100%;object-fit:contain;padding:10px;position:relative;z-index:1}.company-logo-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--color-white);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%)}.timeline-titles{flex:1}.timeline-title{font-family:var(--font-heading);font-size:24px;color:var(--color-text);margin-bottom:4px}.timeline-company{font-size:16px;color:var(--color-secondary);font-weight:500}.timeline-description{color:var(--color-text-light);line-height:1.8;margin-bottom:20px}.timeline-tags{display:flex;flex-wrap:wrap;gap:10px}.timeline-tags span{font-size:12px;padding:6px 14px;background:var(--color-accent-light);color:var(--color-primary-dark);border-radius:20px;font-weight:500}.projects{background:var(--color-white)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:40px}.project-card{background:var(--color-white);border-radius:20px;overflow:hidden;box-shadow:0 10px 40px #8b451314;transition:all var(--transition-medium);display:flex;flex-direction:column}.project-card:hover{box-shadow:0 30px 60px #8b451326}.project-card.featured{grid-column:span 1}.project-image{position:relative;height:200px;background:linear-gradient(135deg,var(--color-accent-light) 0%,var(--color-accent) 100%);overflow:hidden}.project-img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-medium)}.project-card:hover .project-img{transform:scale(1.1)}.project-card.featured .project-image{height:200px}.project-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#8b4513b3,#cd853fb3);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-medium)}.project-card:hover .project-overlay{opacity:1}.project-year{font-family:var(--font-heading);font-size:48px;color:var(--color-white);font-weight:700}.project-content{padding:30px;display:flex;flex-direction:column;flex:1}.project-title{font-family:var(--font-heading);font-size:22px;color:var(--color-text);margin-bottom:16px;transition:color var(--transition-fast)}.project-card:hover .project-title{color:var(--color-primary)}.project-affiliation{display:inline-block;font-size:12px;font-weight:600;color:var(--color-primary);letter-spacing:.5px;margin-bottom:10px}.project-description{color:var(--color-text-light);line-height:1.7;margin-bottom:20px}.project-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.project-tags span{font-size:12px;padding:6px 12px;background:var(--color-light-gray);color:var(--color-text);border-radius:20px}.project-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:auto}.project-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:1px}.project-link .arrow{transition:transform var(--transition-fast)}.project-link:hover .arrow{transform:translate(5px)}.project-github-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;color:var(--color-white);background:var(--color-text);border-radius:20px;transition:all var(--transition-fast)}.project-github-btn:hover{background:var(--color-primary);transform:translateY(-2px)}.project-github-btn svg{flex-shrink:0}.project-modal-backdrop{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:backdropFadeIn .3s cubic-bezier(.4,0,.2,1) forwards}.project-modal-backdrop.closing{animation:backdropFadeOut .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes backdropFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}}@keyframes backdropFadeOut{0%{opacity:1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}to{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}.project-modal{background:var(--color-white);border-radius:24px;max-width:720px;width:100%;max-height:90vh;overflow:hidden;position:relative;box-shadow:0 30px 100px #0006;animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1) forwards}.project-modal.closing{animation:modalSlideOut .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(60px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalSlideOut{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(40px) scale(.95)}}.modal-close{position:absolute;top:16px;right:16px;width:44px;height:44px;background:var(--color-white);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:none;z-index:10;box-shadow:0 4px 20px #00000026;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.modal-close:hover{background:var(--color-primary);color:var(--color-white);transform:rotate(90deg) scale(1.1);box-shadow:0 6px 25px #8b45134d}.modal-image{position:relative;height:280px;overflow:hidden}.modal-image img{width:100%;height:100%;object-fit:cover}.modal-image-overlay{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,rgba(0,0,0,.7),transparent)}.modal-year{position:absolute;bottom:20px;left:24px;font-family:var(--font-heading);font-size:64px;font-weight:700;color:var(--color-white);text-shadow:0 4px 20px rgba(0,0,0,.5);line-height:1}.modal-content{padding:32px;max-height:calc(90vh - 280px);overflow-y:auto}.modal-title{font-family:var(--font-heading);font-size:28px;color:var(--color-text);margin-bottom:16px;line-height:1.3}.modal-affiliation{display:inline-block;font-size:13px;font-weight:600;color:var(--color-primary);letter-spacing:.5px;margin-bottom:12px}.modal-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:24px}.modal-tag{font-size:13px;padding:8px 16px;background:var(--color-accent-light);color:var(--color-primary-dark);border-radius:20px;font-weight:500}.modal-stats{display:flex;flex-wrap:wrap;gap:16px;padding:20px;background:var(--color-light-gray);border-radius:16px;margin-bottom:28px}.modal-stat{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--color-text);font-weight:500}.modal-stat svg{color:var(--color-primary);flex-shrink:0}.modal-section{margin-bottom:24px}.modal-section-title{font-family:var(--font-heading);font-size:18px;color:var(--color-text);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--color-accent-light)}.modal-description{font-size:16px;color:var(--color-text-light);line-height:1.8}.modal-tech-tags{display:flex;flex-wrap:wrap;gap:10px}.modal-tech-tag{font-size:13px;padding:10px 18px;background:var(--color-primary);color:var(--color-white);border-radius:25px;font-weight:500;transition:all var(--transition-fast)}.modal-tech-tag:hover{background:var(--color-primary-dark);transform:translateY(-2px)}.modal-link{display:inline-flex;align-items:center;gap:10px;margin-top:8px}.modal-link svg{transition:transform var(--transition-fast)}.modal-link:hover svg{transform:scale(1.1)}@media(max-width:768px){.project-modal-backdrop{padding:0;align-items:flex-end}.project-modal{max-height:90vh;border-radius:24px 24px 0 0;animation:modalSlideInMobile .4s cubic-bezier(.34,1.56,.64,1) forwards}.project-modal.closing{animation:modalSlideOutMobile .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes modalSlideInMobile{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes modalSlideOutMobile{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}.modal-image{height:200px}.modal-year{font-size:48px;bottom:16px;left:20px}.modal-content{padding:24px;max-height:calc(90vh - 200px)}.modal-title{font-size:22px}.modal-stats{padding:16px;gap:12px}.modal-stat{font-size:13px}.modal-section-title{font-size:16px}.modal-description{font-size:15px}.modal-close{top:12px;right:12px;width:40px;height:40px}.modal-tech-tag{padding:8px 14px;font-size:12px}}.github-contributions{background:var(--color-off-white);position:relative}.contributions-container{background:var(--color-white);border-radius:24px;padding:40px;box-shadow:0 10px 50px #8b451314}.contributions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.contributions-year{font-family:var(--font-heading);font-size:32px;font-weight:700;color:var(--color-text)}.github-profile-link{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--color-text);color:var(--color-white);border-radius:30px;font-size:14px;font-weight:600;transition:all var(--transition-fast)}.github-profile-link:hover{background:var(--color-primary);transform:translateY(-2px);box-shadow:0 8px 25px #8b451340}.contributions-stats{display:flex;gap:40px;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid var(--color-light-gray)}.stat-item{display:flex;flex-direction:column}.stat-value{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--color-primary)}.stat-label{font-size:14px;color:var(--color-text-light);margin-top:4px}.contributions-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:16px;color:var(--color-text-light)}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-light-gray);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.contributions-graph{overflow-x:auto;padding-bottom:8px}.graph-months{display:grid;grid-template-columns:30px repeat(53,1fr);margin-bottom:8px;font-size:12px;color:var(--color-text-light)}.month-label{white-space:nowrap}.graph-wrapper{display:flex;gap:8px}.graph-days{display:flex;flex-direction:column;gap:3px;font-size:11px;color:var(--color-text-light);padding-top:2px}.day-label{height:13px;line-height:13px}.graph-grid{display:flex;gap:3px}.graph-week{display:flex;flex-direction:column;gap:3px}.graph-day{width:13px;height:13px;border-radius:3px;transition:all var(--transition-fast)}.graph-day:hover{transform:scale(1.3);box-shadow:0 2px 8px #8b45134d}.graph-day.outside{visibility:hidden}.graph-day.future{background:var(--color-light-gray);opacity:.3}.graph-day.level-0{background:var(--color-light-gray)}.graph-day.level-1{background:wheat}.graph-day.level-2{background:#deb887}.graph-day.level-3{background:peru}.graph-day.level-4{background:#8b4513}.graph-legend{display:flex;align-items:center;justify-content:flex-end;gap:8px;margin-top:16px;font-size:12px;color:var(--color-text-light)}.legend-colors{display:flex;gap:3px}.legend-colors .graph-day{cursor:default}.legend-colors .graph-day:hover{transform:none;box-shadow:none}@media(max-width:768px){.contributions-container{padding:24px;border-radius:20px}.contributions-header{flex-direction:column;gap:16px;align-items:flex-start}.contributions-year{font-size:24px}.github-profile-link{padding:8px 16px;font-size:13px}.contributions-stats{flex-wrap:wrap;gap:24px}.stat-value{font-size:22px}.stat-label{font-size:12px}.graph-days{display:none}.graph-day{width:10px;height:10px;border-radius:2px}.graph-months{font-size:10px}.graph-legend{justify-content:center}}@media(max-width:480px){.contributions-container{padding:20px}.graph-day{width:8px;height:8px}.graph-week,.graph-grid{gap:2px}}.publications{background:var(--color-off-white);position:relative}.publications-bg{position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(139,69,19,.04) 0%,transparent 50%),radial-gradient(circle at 20% 80%,rgba(205,133,63,.05) 0%,transparent 50%);will-change:transform}.publications-list{display:flex;flex-direction:column;gap:24px}.publication-card{background:var(--color-white);padding:40px;border-radius:16px;display:flex;gap:40px;align-items:flex-start;box-shadow:0 10px 40px #8b45130f;transition:all var(--transition-medium);position:relative;overflow:hidden}.publication-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-primary);transform:scaleY(0);transition:transform var(--transition-medium)}.publication-card:hover{transform:translate(10px);box-shadow:0 20px 60px #8b45131a}.publication-card:hover:before{transform:scaleY(1)}.publication-number{font-family:var(--font-heading);font-size:48px;font-weight:700;color:var(--color-accent);line-height:1;min-width:80px;transition:all var(--transition-fast)}.publication-content{flex:1}.publication-title{font-family:var(--font-heading);font-size:20px;color:var(--color-text);margin-bottom:12px;line-height:1.4}.publication-journal{font-size:14px;color:var(--color-text-light);margin-bottom:16px}.publication-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:1px}.publication-link .arrow{transition:transform var(--transition-fast)}.publication-link:hover .arrow{transform:translate(5px)}.education{background:var(--color-off-white)}.education-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:32px}.education-card{background:var(--color-white);padding:32px;border-radius:16px;display:flex;flex-direction:column;gap:24px;box-shadow:0 10px 40px #8b451314;transition:all var(--transition-medium);position:relative;overflow:hidden}.education-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--color-primary);transform:scaleY(0);transition:transform var(--transition-medium)}.education-card:hover{transform:translate(10px);box-shadow:0 20px 60px #8b45131f}.education-card:hover:before{transform:scaleY(1)}.education-header{display:flex;align-items:center;gap:20px;flex-shrink:0;padding-bottom:20px;border-bottom:1px solid var(--color-gray)}.education-header-info{display:flex;flex-direction:column;gap:6px;min-width:0;flex:1}.education-logo-wrapper{display:flex;align-items:center;justify-content:center;width:64px;height:64px;min-width:64px;min-height:64px;border-radius:14px;background:var(--color-light-gray);overflow:hidden;transition:box-shadow var(--transition-fast),background var(--transition-fast)}.education-logo-wrapper:hover{box-shadow:0 6px 20px #8b45131f;background:var(--color-white)}.education-logo{width:100%;height:100%;object-fit:contain;padding:10px;box-sizing:border-box}.education-logo-fallback{display:flex;width:100%;height:100%;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:var(--color-primary);background:var(--color-light-gray)}.education-meta{display:flex;flex-direction:column;gap:2px}.education-school{font-family:var(--font-heading);font-size:19px;font-weight:600;color:var(--color-text);margin:0;line-height:1.3;letter-spacing:.02em}.education-date{font-size:13px;font-weight:600;color:var(--color-primary);letter-spacing:.5px}.education-location{font-size:13px;color:var(--color-text-light)}.education-content{display:flex;flex-direction:column;gap:16px;flex:1}.education-degree{font-family:var(--font-heading);font-size:20px;color:var(--color-text);margin:0;line-height:1.4;font-weight:600}.education-details{display:none}.education-activities{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}.education-activities span{font-size:12px;padding:6px 12px;background:var(--color-light-gray);color:var(--color-primary-dark);border-radius:20px;font-weight:500}.contact{background:var(--color-off-white);position:relative}.contact-bg{position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(139,69,19,.05) 0%,transparent 50%),radial-gradient(circle at 0% 100%,rgba(205,133,63,.06) 0%,transparent 50%);will-change:transform}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}.contact-info .contact-text{font-size:18px;color:var(--color-text-light);line-height:1.8;margin-bottom:40px}.contact-details{display:flex;flex-direction:column;gap:24px;margin-bottom:40px}.contact-item{display:flex;align-items:center;gap:20px;transition:transform var(--transition-fast)}.contact-item:hover{transform:translate(10px)}.contact-icon{width:56px;height:56px;background:var(--color-primary);border-radius:16px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.contact-item:hover .contact-icon{background:var(--color-primary-dark)}.contact-icon svg{width:24px;height:24px;color:var(--color-white)}.contact-label{font-size:12px;text-transform:uppercase;letter-spacing:2px;color:var(--color-text-light);display:block;margin-bottom:4px}.contact-value{font-size:16px;font-weight:500;color:var(--color-text)}.social-links{display:flex;gap:16px}.social-link{width:50px;height:50px;background:var(--color-white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #8b45131a;transition:all var(--transition-fast)}.social-link:hover{background:var(--color-primary);transform:translateY(-5px);box-shadow:0 10px 30px #8b451333}.social-link svg{width:22px;height:22px;fill:var(--color-primary);transition:fill var(--transition-fast)}.social-link:hover svg{fill:var(--color-white)}.contact-form{background:var(--color-white);padding:50px;border-radius:20px;box-shadow:0 20px 60px #8b45131a}.form-group{position:relative;margin-bottom:30px}.form-group input,.form-group textarea{width:100%;padding:16px 0;font-size:16px;font-family:var(--font-body);color:var(--color-text);border:none;border-bottom:2px solid var(--color-gray);background:transparent;transition:border-color var(--transition-fast);outline:none}.form-group textarea{resize:none}.form-group label{position:absolute;left:0;top:16px;font-size:16px;color:var(--color-text-light);pointer-events:none;transition:all var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary)}.form-group input:focus+label,.form-group input:valid+label,.form-group textarea:focus+label,.form-group textarea:valid+label{top:-10px;font-size:12px;color:var(--color-primary);letter-spacing:1px;text-transform:uppercase}.btn-submit{width:100%;padding:20px}.btn-submit svg{width:20px;height:20px}.btn-submit.success{background:#27ae60;border-color:#27ae60}.btn-submit.error{background:#e74c3c;border-color:#e74c3c}.btn-submit:disabled{opacity:.7;cursor:not-allowed}.footer{background:var(--color-text);padding:0;position:relative}.footer-divider{height:1px;background:linear-gradient(90deg,transparent 0%,rgba(222,184,135,.25) 20%,rgba(222,184,135,.4) 50%,rgba(222,184,135,.25) 80%,transparent 100%)}.footer .container{padding-top:48px;padding-bottom:32px}.footer-main{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px;margin-bottom:32px;padding-bottom:28px;border-bottom:1px solid rgba(255,255,255,.08)}.footer-nav-list{display:flex;flex-wrap:wrap;gap:8px 28px}.footer-nav-link{color:var(--color-gray);font-size:14px;font-weight:500;letter-spacing:.02em;transition:color var(--transition-fast)}.footer-nav-link:hover{color:var(--color-accent)}.footer-social{display:flex;gap:12px}.footer-social-link{width:42px;height:42px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:var(--color-gray);transition:all var(--transition-fast)}.footer-social-link:hover{background:var(--color-accent);color:var(--color-text);border-color:var(--color-accent);transform:translateY(-2px)}.footer-social-link svg{width:18px;height:18px}.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.footer-copyright{color:var(--color-gray);font-size:13px;font-weight:400;letter-spacing:.01em}.footer-credit{color:#deb887e6;font-size:13px;font-weight:500;letter-spacing:.02em}.parallax-bg{position:absolute;inset:-30% -15%;will-change:transform;pointer-events:none;transition:transform .1s cubic-bezier(.25,.46,.45,.94)}.experience-bg{background:radial-gradient(ellipse 600px 600px at 0% 30%,rgba(139,69,19,.06) 0%,transparent 60%),radial-gradient(ellipse 500px 500px at 100% 70%,rgba(205,133,63,.08) 0%,transparent 60%),radial-gradient(ellipse 300px 300px at 50% 50%,rgba(222,184,135,.04) 0%,transparent 50%)}.publications-bg{background:radial-gradient(ellipse 700px 700px at 80% 10%,rgba(139,69,19,.07) 0%,transparent 60%),radial-gradient(ellipse 400px 400px at 20% 90%,rgba(205,133,63,.09) 0%,transparent 60%)}.contact-bg{background:radial-gradient(ellipse 800px 800px at 50% 0%,rgba(139,69,19,.08) 0%,transparent 60%),radial-gradient(ellipse 500px 500px at 0% 100%,rgba(205,133,63,.1) 0%,transparent 60%),radial-gradient(ellipse 400px 400px at 100% 50%,rgba(222,184,135,.06) 0%,transparent 50%)}@media(max-width:1024px){.hero-content{grid-template-columns:1fr;text-align:center;gap:60px}.hero-description{margin-left:auto;margin-right:auto}.hero-cta{justify-content:center}.hero-image{order:-1}.hero-image-wrapper{width:300px;height:360px}.hero-floating-card.card-1{right:0}.hero-floating-card.card-2{left:0}.hero-floating-card.card-3{right:0}.about-content,.contact-content{grid-template-columns:1fr;gap:60px}.project-card.featured{grid-column:span 1}}@media(max-width:768px){:root{--section-padding: 80px}.cursor-pointer,.cursor-circle-ring,.cursor-trail-container{display:none!important}body{cursor:auto}a,button{cursor:pointer}.nav-menu{position:fixed;top:0;right:-100%;width:100%;height:100vh;height:100dvh;background:var(--color-white);flex-direction:column;justify-content:center;align-items:center;gap:32px;transition:right var(--transition-medium);z-index:999}.nav-menu.active{right:0}.nav-link{font-size:28px;font-weight:500}.nav-toggle{display:flex}.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,6px)}.nav-toggle.active span:nth-child(2){opacity:0}.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-6px)}.hero{min-height:100vh;min-height:100dvh;padding-top:80px}.hero-content{padding-top:40px;gap:40px}.hero-text{padding:0 8px}.hero-greeting{font-size:14px;letter-spacing:2px}.hero-name{font-size:clamp(28px,7vw,36px);margin-bottom:16px;white-space:nowrap}.hero-title-wrapper{flex-direction:column;gap:8px}.hero-title{font-size:16px}.hero-divider{display:none}.hero-description{font-size:15px;line-height:1.7;margin-bottom:32px}.hero-cta{flex-direction:column;gap:16px}.hero-cta .btn{width:100%;justify-content:center}.hero-floating-card{display:flex;padding:10px 16px;border-radius:10px;animation:float 6s ease-in-out infinite;box-shadow:0 8px 24px #8b451326}.hero-floating-card.card-1{top:-10px;right:-10px;animation-delay:0s}.hero-floating-card.card-2{bottom:20px;left:-10px;animation-delay:3s}.hero-floating-card.card-3{bottom:20px;right:-10px;animation-delay:1.5s}.card-icon{font-size:18px}.card-text{font-size:12px}.hero-image-wrapper{width:220px;height:280px}.hero-profile-image{border-radius:16px}.hero-image-bg{top:12px;left:12px}.hero-scroll-indicator{display:none}.hero-parallax-bg{top:-20%;bottom:-20%}.hero-parallax-bg.layer-3{display:none}.parallax-bg{top:-15%;bottom:-15%}.section-header{margin-bottom:48px}.section-title{font-size:clamp(28px,7vw,36px)}.about-lead{font-size:18px}.about-text p{font-size:15px}.about-details{gap:12px}.detail-item{flex-direction:column;gap:4px}.skills-title{font-size:24px;margin-bottom:24px}.skill-category h4{font-size:13px}.skill-tag{padding:8px 16px;font-size:13px}.timeline{padding-left:24px}.timeline:before{left:0}.timeline-marker{left:-30px;width:12px;height:12px}.timeline-item{padding-bottom:40px}.timeline-content{padding:24px;border-radius:12px}.timeline-content:hover{transform:none}.timeline-header{flex-direction:column;align-items:flex-start;gap:4px}.timeline-date,.timeline-location{font-size:13px}.timeline-company-row{gap:12px}.company-logo-wrapper{width:48px;height:48px;border-radius:10px}.company-logo{padding:6px}.company-logo-fallback{font-size:20px}.timeline-title{font-size:18px}.timeline-company{font-size:14px}.timeline-description{font-size:14px;line-height:1.7}.timeline-tags{gap:8px}.timeline-tags span{font-size:11px;padding:5px 12px}.projects-grid{grid-template-columns:1fr;gap:24px}.project-card{border-radius:16px}.project-card:hover{transform:none}.project-card.featured .project-image,.project-image{height:180px}.project-overlay{opacity:1;background:linear-gradient(135deg,#8b451399,#cd853f99)}.project-year{font-size:36px}.project-content{padding:24px}.project-title{font-size:20px}.project-description{font-size:14px;line-height:1.6}.project-tags{gap:6px}.project-tags span{font-size:11px;padding:5px 10px}.publications-list{gap:16px}.publication-card{flex-direction:column;gap:16px;padding:24px;border-radius:12px}.publication-card:hover{transform:none}.publication-number{font-size:36px;min-width:auto}.publication-title{font-size:17px;line-height:1.5}.publication-journal{font-size:13px}.education-grid{grid-template-columns:1fr;gap:24px}.education-card{gap:20px;padding:24px;border-radius:12px}.education-card:hover{transform:none}.education-header{padding-bottom:16px}.education-logo-wrapper{width:56px;height:56px;min-width:56px;min-height:56px;border-radius:12px}.education-logo-fallback{font-size:22px}.education-school{font-size:17px}.education-degree{font-size:18px}.education-activities{gap:6px}.education-activities span{font-size:11px;padding:5px 12px}.contact-content{gap:48px}.contact-info .contact-text{font-size:16px}.contact-details{gap:20px}.contact-item{gap:16px}.contact-item:hover{transform:none}.contact-icon{width:48px;height:48px;border-radius:12px}.contact-icon svg{width:20px;height:20px}.contact-label{font-size:11px}.contact-value{font-size:14px}.social-links{gap:12px;justify-content:flex-start}.social-link{width:46px;height:46px}.social-link:hover{transform:none}.social-link svg{width:20px;height:20px}.contact-form{padding:28px;border-radius:16px}.form-group{margin-bottom:24px}.form-group input,.form-group textarea{font-size:16px;padding:14px 0}.form-group label{font-size:15px}.btn-submit{padding:18px;font-size:14px}.footer .container{padding-top:36px;padding-bottom:24px}.footer-main{flex-direction:column;align-items:center;text-align:center;gap:20px;margin-bottom:24px;padding-bottom:24px}.footer-nav-list{justify-content:center}.footer-bottom{flex-direction:column;text-align:center}.footer-copyright,.footer-credit{font-size:12px}.animate-on-scroll{transform:translateY(20px)}.animate-fade-up{transform:translateY(30px)}.btn:active{transform:scale(.98)}.project-card:active,.publication-card:active,.education-card:active,.timeline-content:active{transform:scale(.99);transition:transform .1s ease}.skill-tag:active{transform:scale(.95)}.social-link:active{transform:scale(.9)}}@media(max-width:480px){:root{--section-padding: 60px}.container{padding:0 16px}.hero-content{padding-top:24px}.hero-name{font-size:clamp(24px,6.5vw,32px);white-space:nowrap}.hero-title,.hero-description{font-size:14px}.hero-image-wrapper{width:180px;height:230px}.hero-profile-image{border-radius:14px}.hero-image-bg{top:10px;left:10px}.hero-floating-card{padding:8px 12px;border-radius:8px}.hero-floating-card.card-1{top:-5px;right:-5px}.hero-floating-card.card-2{bottom:15px;left:-5px}.hero-floating-card.card-3{bottom:15px;right:-5px}.card-icon{font-size:14px}.card-text{font-size:10px}.btn{padding:14px 24px;font-size:13px}.section-tag{font-size:12px;letter-spacing:2px}.section-tag:before,.section-tag:after{width:20px}.section-tag:before{left:-30px}.section-tag:after{right:-30px}.section-title{font-size:clamp(24px,6vw,32px)}.section-header{margin-bottom:40px}.timeline{padding-left:20px}.timeline-marker{left:-26px;width:10px;height:10px}.timeline-content{padding:20px}.timeline-title{font-size:18px}.project-content,.publication-card,.education-card,.contact-form{padding:20px}.project-title,.publication-title,.education-degree{font-size:17px}.form-group input,.form-group textarea{padding:12px 0}.btn-submit{padding:16px}.nav-link{font-size:24px}.nav-menu{gap:28px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.animate-fade-up,.animate-fade-left,.animate-on-scroll{opacity:1;transform:none}.hero-floating-card,.scroll-line{animation:none}.parallax-bg,.hero-parallax-bg{transform:none!important}}@media(max-width:896px)and (orientation:landscape){.hero{min-height:auto;padding:100px 0 60px}.hero-content{grid-template-columns:1fr 1fr;gap:40px;padding-top:0}.hero-image{order:0}.hero-image-wrapper{width:200px;height:250px}.hero-scroll-indicator{display:none}.nav-menu{padding:20px;gap:20px}.nav-link{font-size:20px}}@media(hover:none)and (pointer:coarse){.btn:hover,.project-card:hover,.publication-card:hover,.education-card:hover,.timeline-content:hover,.contact-item:hover,.social-link:hover,.skill-tag:hover{transform:none;box-shadow:inherit}.project-card:hover .project-overlay{opacity:1}.project-card:hover .project-title,.timeline-item:hover .timeline-marker{color:inherit;background:inherit;transform:none}}
