.nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);background:transparent;transition:all var(--duration-normal) var(--ease-smooth);animation:fadeInDown .6s var(--ease-expo) both}.nav.scrolled{background:var(--bg-nav);backdrop-filter:blur(24px) saturate(1.5);-webkit-backdrop-filter:blur(24px) saturate(1.5);border-bottom:1px solid var(--border-subtle);box-shadow:var(--shadow-md)}@media (min-width:768px){.nav{padding:0 var(--space-xl)}}.nav__logo{font-family:var(--font-display);font-size:24px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary);transition:color var(--duration-fast);display:inline-block;transform-style:preserve-3d;animation:logo3dEntry 1.2s var(--ease-expo) both,logoFloat3d 6s var(--ease-smooth) 1.2s infinite;will-change:transform}.nav__logo span{color:var(--accent);display:inline-block;animation:logoDotPulse 3s var(--ease-smooth) infinite}.nav__logo:hover{color:var(--accent);animation:logo3dEntry .5s var(--ease-expo) both,logoFloat3d 3s var(--ease-smooth) .5s infinite}.nav__tabs{display:none;align-items:center;gap:0}@media (min-width:768px){.nav__tabs{display:flex}}.nav__tab{padding:8px 18px;font-family:var(--font-mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-tertiary);background:transparent;border:none;position:relative;transition:color var(--duration-normal) var(--ease-out);cursor:pointer;white-space:nowrap;text-decoration:none}.nav__tab:after{content:"";position:absolute;bottom:0;left:50%;width:0;height:1px;background:var(--accent);transition:all var(--duration-normal) var(--ease-out);transform:translateX(-50%)}.nav__tab:hover{color:var(--text-primary)}.nav__tab:hover:after{width:100%}.nav__tab--active{color:var(--accent)!important}.nav__tab--active:after{width:100%!important;background:var(--accent)!important}.nav__cta{display:none;padding:10px 24px;border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-family:var(--font-mono);font-size:10px;font-weight:600;border:1px solid var(--accent);text-transform:uppercase;letter-spacing:2px;transition:all var(--duration-normal) var(--ease-out)}.nav__cta:hover{background:var(--accent);color:var(--text-inverse);transform:translateY(-1px);box-shadow:var(--shadow-glow)}@media (min-width:768px){.nav__cta{display:block}}.nav__actions,.nav__icon-btn{display:flex;align-items:center;gap:4px}.nav__icon-btn{padding:8px;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);border:1px solid transparent;transition:all var(--duration-fast);cursor:pointer;font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:1px}.nav__icon-btn:hover{color:var(--accent);border-color:var(--border-default);background:var(--accent-subtle)}.lang-selector{position:relative}.lang-selector__current{font-size:10px}.lang-selector__dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-sm);padding:4px;display:flex;flex-direction:column;gap:2px;min-width:60px;box-shadow:var(--shadow-md);animation:fadeIn .15s var(--ease-out);z-index:200}.lang-selector__option{padding:6px 12px;border:none;border-radius:var(--radius-xs);background:transparent;color:var(--text-secondary);font-family:var(--font-mono);font-size:11px;font-weight:500;cursor:pointer;transition:all var(--duration-fast);text-align:center}.lang-selector__option--active,.lang-selector__option:hover{background:var(--accent-subtle);color:var(--accent)}.hamburger{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;cursor:pointer;padding:10px;z-index:200;background:none;border:1px solid var(--border-default);border-radius:var(--radius-sm,8px);width:44px;height:44px;transition:border-color var(--duration-normal) var(--ease-out),background var(--duration-normal) var(--ease-out)}.hamburger:hover{border-color:var(--accent);background:var(--accent-subtle)}.hamburger__line{width:24px;height:1.5px;background:var(--text-primary);border-radius:1px;transition:all var(--duration-normal) var(--ease-out);transform-origin:center}.hamburger__line:nth-child(2){width:16px;margin-left:auto}.hamburger.open .hamburger__line:first-child{transform:rotate(45deg) translate(5.5px,5.5px)}.hamburger.open .hamburger__line:nth-child(2){opacity:0;width:24px}.hamburger.open .hamburger__line:nth-child(3){transform:rotate(-45deg) translate(5.5px,-5.5px)}@media (min-width:768px){.hamburger{display:none}}.nav__mobile{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;height:100dvh;z-index:150;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;animation:fadeIn .25s var(--ease-out);overflow:hidden}.nav__mobile:before{top:10%;right:-15%;width:350px;height:350px;border-radius:50%;filter:blur(160px);opacity:.08;pointer-events:none}.nav__mobile:after,.nav__mobile:before{content:"";position:absolute;background:var(--accent)}.nav__mobile:after{bottom:48px;left:50%;transform:translateX(-50%);width:40px;height:1px;opacity:.3}.nav__mobile-link{font-family:var(--font-display);font-size:36px;font-weight:600;color:var(--text-secondary);padding:10px 48px;transition:all var(--duration-normal) var(--ease-expo);text-decoration:none;animation:fadeInUp .4s var(--ease-expo) both;position:relative}.nav__mobile-link:after{content:"";position:absolute;bottom:6px;left:48px;width:0;height:1px;background:var(--accent);transition:width var(--duration-normal)}.nav__mobile-link:hover{color:var(--accent)}.nav__mobile-link:hover:after{width:calc(100% - 96px)}.nav__mobile-link:first-child{animation-delay:.05s}.nav__mobile-link:nth-child(2){animation-delay:.1s}.nav__mobile-link:nth-child(3){animation-delay:.15s}.nav__mobile-link:nth-child(4){animation-delay:.2s}.nav__mobile-link:nth-child(5){animation-delay:.25s}.nav__mobile-link--active{color:var(--accent);font-style:italic}.nav__mobile-link--active:after{width:calc(100% - 96px)}.nav__mobile-actions{display:flex;align-items:center;gap:8px;margin-top:24px;animation:fadeInUp .4s var(--ease-expo) .28s both}.nav__mobile-cta{margin-top:32px;padding:16px 48px;border-radius:var(--radius-sm);background:transparent;color:var(--accent);font-family:var(--font-mono);font-weight:600;font-size:11px;letter-spacing:3px;text-transform:uppercase;border:1px solid var(--accent);animation:fadeInUp .4s var(--ease-expo) .3s both;transition:all var(--duration-normal)}.nav__mobile-cta:hover{background:var(--accent);color:var(--text-inverse)}.hero{min-height:100vh;display:flex;align-items:center;position:relative;overflow:hidden;padding-top:var(--nav-height)}.hero__blob{position:absolute;border-radius:50%;filter:blur(120px);pointer-events:none;opacity:.18}.hero__blob--1{width:600px;height:600px;background:var(--accent);top:-15%;right:-10%;animation:blob 14s ease-in-out infinite}.hero__blob--2{width:400px;height:400px;background:var(--secondary);bottom:0;left:-12%;animation:blob 11s ease-in-out infinite reverse}.hero__blob--3{width:250px;height:250px;background:var(--accent-dim);top:45%;left:35%;animation:float 10s ease-in-out infinite;opacity:.08}.hero:after{content:"";position:absolute;top:50%;right:5%;width:200px;height:200px;border:1px solid var(--border-subtle);transform:rotate(45deg) translateY(-50%);pointer-events:none;opacity:.4}.hero__inner{width:100%;max-width:var(--max-width);margin:0 auto;padding:80px var(--space-lg) 48px;display:flex;flex-direction:column-reverse;align-items:center;gap:var(--space-xl);position:relative;z-index:1}@media (min-width:768px){.hero__inner{flex-direction:row;justify-content:space-between;padding:100px var(--space-xl) 72px;gap:var(--space-2xl)}}.hero__content{text-align:center;max-width:580px}@media (min-width:768px){.hero__content{text-align:left}}.hero__badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-accent);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:var(--space-xl);animation:fadeInUp .6s var(--ease-expo) .1s both}.hero__badge-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 2.5s infinite;box-shadow:0 0 8px var(--accent-glow)}.hero__heading{font-family:var(--font-display);font-size:clamp(40px,7vw,76px);font-weight:700;letter-spacing:-1.5px;line-height:1.05;margin-bottom:var(--space-lg);animation:fadeInUp .6s var(--ease-expo) .2s both}.hero__sub{font-size:clamp(15px,2vw,18px);color:var(--text-secondary);line-height:1.7;margin-bottom:var(--space-xl);max-width:460px;animation:fadeInUp .6s var(--ease-expo) .35s both}@media (min-width:768px){.hero__sub{margin-left:0;margin-right:auto}}.hero__actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;animation:fadeInUp .6s var(--ease-expo) .45s both}@media (min-width:768px){.hero__actions{justify-content:flex-start}}.hero__socials{display:flex;gap:12px;margin-top:var(--space-xl);justify-content:center;animation:fadeInUp .6s var(--ease-expo) .55s both}@media (min-width:768px){.hero__socials{justify-content:flex-start}}.hero__social{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-default);transition:all var(--duration-normal) var(--ease-out)}.hero__social img{width:18px;height:18px;opacity:.6;transition:opacity var(--duration-fast)}.hero__social:hover{border-color:var(--accent);background:var(--accent-subtle);transform:translateY(-3px);box-shadow:var(--shadow-glow)}.hero__social:hover img{opacity:1}.hero__photo-container{position:relative;flex-shrink:0;animation:popIn .8s var(--ease-expo) .3s both}.hero__photo-ring{position:absolute;inset:-8px;border:1px solid var(--accent);opacity:.3;transition:all var(--duration-slow)}.hero__photo-container:hover .hero__photo-ring{inset:-12px;opacity:.5}.hero__photo{width:240px;height:240px;object-fit:cover;border:2px solid var(--border-default);position:relative;z-index:1;filter:grayscale(.15);transition:all var(--duration-normal) var(--ease-out)}.hero__photo-container:hover .hero__photo{filter:grayscale(0);border-color:var(--accent)}@media (min-width:768px){.hero__photo{width:320px;height:320px}.hero__photo-ring{border-radius:0}}@media (min-width:1200px){.hero__photo{width:380px;height:380px}}.marquee{overflow:hidden;padding:24px 0;position:relative;background:var(--bg-secondary);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle)}.marquee:after,.marquee:before{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}.marquee:before{left:0;background:linear-gradient(to right,var(--bg-secondary),transparent)}.marquee:after{right:0;background:linear-gradient(to left,var(--bg-secondary),transparent)}.marquee__track{display:flex;gap:48px;width:max-content;animation:marquee 30s linear infinite}.marquee:hover .marquee__track{animation-play-state:paused}.marquee__item{display:flex;flex-direction:column;align-items:center;gap:10px;flex-shrink:0;padding:14px 24px;border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease-out);cursor:default}.marquee__item:hover{transform:translateY(-4px);background:var(--accent-subtle)}.marquee__item img{width:40px;height:40px;transition:all var(--duration-normal);filter:grayscale(.6) brightness(.7);opacity:.6}.marquee__item:hover img{filter:grayscale(0) brightness(1);opacity:1}.marquee__label{font-family:var(--font-mono);font-size:9px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:2px;opacity:0;transform:translateY(4px);transition:all var(--duration-fast) var(--ease-out)}.marquee__item:hover .marquee__label{opacity:1;transform:translateY(0);color:var(--accent)}.about{padding:var(--space-3xl) 0}.about__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);display:grid;grid-template-columns:1fr;grid-gap:var(--space-2xl);gap:var(--space-2xl)}@media (min-width:768px){.about__inner{grid-template-columns:300px 1fr;padding:0 var(--space-xl);gap:var(--space-2xl)}}.about__sidebar{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.about__photo-wrap{position:relative;transform-style:preserve-3d;animation:card3dIdle 10s var(--ease-smooth) infinite}.about__photo-wrap:before{content:"";position:absolute;bottom:-10px;right:-10px;width:100%;height:100%;border:1px solid var(--accent);opacity:.25;z-index:0;transition:all var(--duration-slow) var(--ease-out)}.about__photo-wrap:hover:before{bottom:-6px;right:-6px;opacity:.5}.about__photo-wrap:hover{animation-play-state:paused;transform:perspective(800px) rotateY(5deg) rotateX(-3deg) translateZ(15px)}.about__photo{width:260px;height:320px;object-fit:cover;border:1px solid var(--border-default);position:relative;z-index:1;filter:grayscale(.1);transition:all var(--duration-normal) var(--ease-out)}.about__photo-wrap:hover .about__photo{filter:grayscale(0);border-color:var(--accent);box-shadow:var(--shadow-glow)}.about__download{width:100%;max-width:260px;justify-content:center}.about__label{margin-bottom:var(--space-sm)}.about__heading{font-family:var(--font-display);font-size:clamp(28px,4.5vw,42px);font-weight:700;letter-spacing:-.5px;line-height:1.15;margin-bottom:var(--space-lg)}.about__text{font-size:15px;line-height:1.85;color:var(--text-secondary);margin-bottom:var(--space-md)}@media (min-width:768px){.about__text{font-size:16px}}.about__highlight{color:var(--accent);font-weight:600;font-style:italic}.about__skills{display:flex;flex-wrap:wrap;gap:8px;margin-top:var(--space-xl)}.about__skill{padding:6px 16px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.5px;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-accent);transition:all var(--duration-fast) var(--ease-out)}.about__skill:hover{transform:perspective(400px) rotateX(-3deg) rotateY(5deg) translateY(-2px) translateZ(8px);background:var(--accent);color:var(--text-inverse);box-shadow:var(--shadow-glow)}.about__stats{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-xl);padding-top:var(--space-xl);border-top:1px solid var(--border-subtle)}@media (min-width:480px){.about__stats{grid-template-columns:repeat(4,1fr)}}.about__stat{text-align:center;padding:var(--space-md) 0;transform-style:preserve-3d;transition:transform var(--duration-normal) var(--ease-out)}.about__stat:hover{transform:perspective(600px) rotateX(-5deg) rotateY(5deg) translateZ(10px)}.about__stat-number{font-family:var(--font-display);font-size:36px;font-weight:700;color:var(--accent);line-height:1}.about__stat-label{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:2px;margin-top:6px}.skills{padding:var(--space-3xl) 0;background:var(--bg-secondary);position:relative}.skills:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-default),transparent)}.skills__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}@media (min-width:768px){.skills__inner{padding:0 var(--space-xl)}}.skills__subtitle{font-size:16px;color:var(--text-secondary);max-width:480px;margin-bottom:var(--space-2xl);line-height:1.7}.skills__grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-lg);gap:var(--space-lg)}@media (min-width:640px){.skills__grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:960px){.skills__grid{grid-template-columns:repeat(3,1fr)}}.skills__card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl) var(--space-lg);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden;transform-style:preserve-3d;animation:card3dIdle 9s var(--ease-smooth) infinite;animation-delay:calc(var(--card-index, 0) * 1s)}.skills__card:before{content:"";position:absolute;top:0;left:0;width:3px;height:0;background:var(--accent);transition:height var(--duration-slow) var(--ease-out)}.skills__card:hover{border-color:var(--border-hover);transform:perspective(800px) rotateX(-3deg) rotateY(3deg) translateY(-6px) translateZ(12px);box-shadow:var(--shadow-glow-lg)}.skills__card:hover:before{height:100%}.skills__card-header{display:flex;align-items:center;gap:14px;margin-bottom:var(--space-xl)}.skills__card-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-subtle);color:var(--accent);flex-shrink:0}.skills__card-title{font-family:var(--font-display);font-size:20px;font-weight:600}.skills__bars{display:flex;flex-direction:column;gap:16px}.skills__bar-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.skills__bar-name{font-size:13px;font-weight:500;color:var(--text-primary)}.skills__bar-pct{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--accent)}.skills__bar-track{width:100%;height:3px;background:var(--border-subtle);border-radius:var(--radius-xs);overflow:hidden}.skills__bar-fill{height:100%;width:0;background:var(--accent);border-radius:var(--radius-xs);transition:width 1.2s var(--ease-expo)}.skills__card.reveal-scale.visible .skills__bar-fill{width:var(--bar-width)}.experience{padding:var(--space-3xl) 0}.experience__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}@media (min-width:768px){.experience__inner{padding:0 var(--space-xl)}}.experience__timeline{position:relative;margin-top:var(--space-2xl);padding-left:32px}.experience__timeline:before{content:"";position:absolute;left:7px;top:0;bottom:0;width:1px;background:linear-gradient(180deg,var(--accent),var(--border-default) 50%,transparent)}.experience__item{position:relative;margin-bottom:var(--space-xl)}.experience__item:last-child{margin-bottom:0}.experience__dot{position:absolute;left:-28px;top:22px;width:10px;height:10px;background:var(--accent);z-index:1;transform:rotate(45deg);transition:all var(--duration-normal)}.experience__item:hover .experience__dot{transform:rotate(45deg) scale(1.2);box-shadow:0 0 12px var(--accent-glow)}.experience__card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--duration-normal) var(--ease-out);position:relative;transform-style:preserve-3d}.experience__card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent),transparent);opacity:0;transition:opacity var(--duration-normal)}.experience__card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow);transform:perspective(800px) rotateX(-2deg) rotateY(2deg) translateY(-4px) translateZ(10px)}.experience__card:hover:before{opacity:1}.experience__card-top{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}@media (min-width:640px){.experience__card-top{flex-direction:row;justify-content:space-between;align-items:flex-start}}.experience__role{font-family:var(--font-display);font-size:18px;font-weight:600}.experience__company{font-family:var(--font-mono);font-size:12px;color:var(--accent);font-weight:500;letter-spacing:.5px}.experience__meta{display:flex;flex-direction:column;gap:2px;text-align:left}@media (min-width:640px){.experience__meta{text-align:right}}.experience__period{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);font-weight:500}.experience__location{font-size:12px;color:var(--text-tertiary);font-style:italic}.experience__desc{font-size:14px;line-height:1.85;color:var(--text-secondary);margin-bottom:14px}.experience__tags{display:flex;flex-wrap:wrap;gap:6px}.experience__tag{padding:4px 12px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.5px;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-accent)}.experience__edu-section{margin-top:var(--space-3xl);padding-top:var(--space-2xl);border-top:1px solid var(--border-subtle)}.experience__edu-heading{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-size:22px;font-weight:600;margin-bottom:var(--space-xl);color:var(--text-primary)}.experience__edu-heading svg{color:var(--accent)}.experience__edu-grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-md);gap:var(--space-md)}@media (min-width:640px){.experience__edu-grid{grid-template-columns:repeat(2,1fr)}}.experience__edu-card{padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out);position:relative;transform-style:preserve-3d;animation:card3dIdle 10s var(--ease-smooth) infinite;animation-delay:calc(var(--card-index, 0) * 1.5s)}.experience__edu-card:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width var(--duration-normal) var(--ease-out)}.experience__edu-card:hover{border-color:var(--border-hover);transform:perspective(800px) rotateX(-2deg) rotateY(3deg) translateY(-4px) translateZ(8px);box-shadow:var(--shadow-glow)}.experience__edu-card:hover:after{width:100%}.experience__edu-title{font-size:14px;font-weight:600;margin-bottom:4px}.experience__edu-inst{font-family:var(--font-mono);font-size:12px;color:var(--accent);font-weight:500;margin-bottom:8px}.experience__edu-detail{font-size:13px;color:var(--text-tertiary);line-height:1.6}.experience__langs{margin-top:var(--space-2xl);padding-top:var(--space-2xl);border-top:1px solid var(--border-subtle)}.experience__langs-heading{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-size:22px;font-weight:600;margin-bottom:var(--space-lg);color:var(--text-primary)}.experience__langs-heading svg{color:var(--accent)}.experience__langs-list{display:flex;flex-wrap:wrap;gap:var(--space-md)}.experience__lang{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);transition:all var(--duration-normal) var(--ease-out)}.experience__lang:hover{border-color:var(--border-hover);transform:perspective(600px) rotateX(-3deg) rotateY(4deg) translateY(-3px) translateZ(8px);box-shadow:var(--shadow-glow)}.experience__lang-name{font-size:14px;font-weight:600}.experience__lang-level{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--accent);padding:3px 12px;background:var(--accent-subtle);border:1px solid var(--border-accent);border-radius:var(--radius-xs)}.projects{padding:var(--space-3xl) 0;background:var(--bg-secondary);position:relative}.projects:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-default),transparent)}.projects__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}@media (min-width:768px){.projects__inner{padding:0 var(--space-xl)}}.projects__header{margin-bottom:var(--space-xl)}.projects__grid{display:grid;grid-template-columns:1fr;grid-gap:20px;gap:20px}@media (min-width:768px){.projects__grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1200px){.projects__grid{grid-template-columns:repeat(3,1fr);gap:24px}}.project__card{display:flex;flex-direction:column;padding:28px;cursor:pointer;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);min-height:260px;position:relative;overflow:hidden;transform-style:preserve-3d}.project__card,.project__card:before{transition:all var(--duration-normal) var(--ease-out)}.project__card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--border-subtle)}.project__card:hover:before{background:var(--accent);box-shadow:0 2px 12px var(--accent-glow)}.project__card:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,var(--accent-subtle),transparent);transition:left var(--duration-slow);pointer-events:none}.project__card:hover:after{left:100%}.project__card:hover{transform:perspective(800px) rotateX(-3deg) rotateY(3deg) translateY(-8px) translateZ(15px);border-color:var(--border-hover);box-shadow:var(--shadow-lg),var(--shadow-glow-lg)}.project__card--featured:before{background:var(--accent)!important;height:2px}.project__card--featured{border-color:var(--border-accent)}.project__card_number{position:absolute;top:14px;right:18px;font-family:var(--font-display);font-size:56px;font-weight:700;color:var(--border-subtle);line-height:1;transition:color var(--duration-fast);pointer-events:none}.project__card:hover .project__card_number{color:var(--accent-subtle)}.project__card_header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.project__card_icon{flex-shrink:0;transition:all var(--duration-normal) var(--ease-out)}.project__card:hover .project__card_icon{transform:rotate(-6deg) scale(1.08);filter:drop-shadow(0 2px 8px var(--accent-glow))}.project__card_featured{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-accent);padding:3px 10px;border-radius:var(--radius-xs);margin-bottom:12px}.project__card_title{font-family:var(--font-display);font-size:clamp(20px,3vw,26px);font-weight:600;color:var(--text-primary);margin-bottom:10px;transition:color var(--duration-fast)}.project__card:hover .project__card_title{color:var(--accent)}.project__card_category{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:10px}.project__card_text{font-size:14px;color:var(--text-secondary);line-height:1.75;margin-bottom:16px;flex-grow:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.project__card_techs{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.project__card_tech{padding:3px 10px;border-radius:var(--radius-xs);font-family:var(--font-mono);font-size:10px;font-weight:500;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-accent);transition:all var(--duration-fast)}.project__card:hover .project__card_tech{background:var(--accent-subtle);border-color:var(--border-accent)}.project__card--portfolio{border-color:var(--secondary);cursor:default;background:linear-gradient(135deg,var(--bg-card) 0,rgba(62,207,180,.04) 100%)}.project__card--portfolio:before{background:var(--secondary)!important;height:2px}.project__card--portfolio:hover{transform:none;border-color:var(--secondary);box-shadow:0 0 24px rgba(62,207,180,.08)}.project__card--portfolio:hover:after{left:-100%}.project__card--portfolio:hover .project__card_title{color:var(--secondary)}.project__card--portfolio:hover .project__card_number{color:rgba(62,207,180,.08)}.project__card_featured--portfolio{color:var(--secondary)!important;background:rgba(62,207,180,.08)!important;border-color:rgba(62,207,180,.2)!important}.project__card_portfolio-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:1px;color:var(--secondary);margin-bottom:12px;opacity:.8}.project__card_portfolio-links{display:flex;gap:8px;margin-top:auto}.project__card_portfolio-link{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-xs);font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--secondary);background:rgba(62,207,180,.08);border:1px solid rgba(62,207,180,.2);text-decoration:none;transition:all var(--duration-fast)}.project__card_portfolio-link:hover{background:rgba(62,207,180,.15);border-color:var(--secondary)}.project__card--skeleton{pointer-events:none;min-height:260px;display:flex;flex-direction:column;gap:16px;justify-content:center}.skeleton-line{height:14px;border-radius:var(--radius-xs);background:linear-gradient(90deg,var(--border-subtle) 25%,var(--bg-card) 50%,var(--border-subtle) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skeleton-line--short{width:40%}.skeleton-line--medium{width:70%}.skeleton-line--long{width:90%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.projects__error{text-align:center;color:var(--text-secondary);font-size:16px;padding:var(--space-xl) 0}.modal__overlay{position:fixed;inset:0;z-index:1000;background:var(--bg-overlay);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:fadeIn .2s var(--ease-out)}.modal__window{position:fixed;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:10px;animation:popIn .35s var(--ease-expo);box-shadow:var(--shadow-lg),var(--shadow-glow-lg);display:flex;flex-direction:column;overflow:hidden}.modal__window--max{border-radius:0!important;box-shadow:none}.modal__resize{position:absolute;z-index:10}.modal__resize--n{top:-3px;left:10px;right:10px;height:6px;cursor:n-resize}.modal__resize--s{bottom:-3px;left:10px;right:10px;height:6px;cursor:s-resize}.modal__resize--e{right:-3px;top:10px;bottom:10px;width:6px;cursor:e-resize}.modal__resize--w{left:-3px;top:10px;bottom:10px;width:6px;cursor:w-resize}.modal__resize--ne{top:-3px;right:-3px;width:14px;height:14px;cursor:ne-resize}.modal__resize--nw{top:-3px;left:-3px;width:14px;height:14px;cursor:nw-resize}.modal__resize--se{bottom:-3px;right:-3px;width:14px;height:14px;cursor:se-resize}.modal__resize--sw{bottom:-3px;left:-3px;width:14px;height:14px;cursor:sw-resize}.modal__tab-bar{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border-bottom:1px solid var(--border-subtle);border-radius:10px 10px 0 0;flex-shrink:0;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.modal__tab-bar:active{cursor:-webkit-grabbing;cursor:grabbing}.modal__window--max .modal__tab-bar{border-radius:0;cursor:default}.modal__tab-dots{display:flex;gap:7px;flex-shrink:0}.modal__dot{width:12px;height:12px;border-radius:50%;border:none;cursor:pointer;transition:opacity var(--duration-fast)}.modal__dot:hover{opacity:.8}.modal__dot--red{background:#FF5F57}.modal__dot--yellow{background:#FEBC2E;cursor:default}.modal__dot--green{background:#28C840;cursor:default}.modal__tab-back{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-default);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast);flex-shrink:0}.modal__tab-back:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-subtle)}.modal__tab-active{display:flex;align-items:center;gap:8px;flex:1 1;min-width:0;padding:6px 14px;border-radius:8px 8px 0 0;background:var(--bg-elevated);border-bottom:1px solid var(--border-subtle);border:1px solid var(--border-subtle);border-bottom-color:var(--bg-elevated);margin-bottom:-1px}.modal__tab-icon{color:var(--accent);flex-shrink:0}.modal__tab-title{font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal__tab-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;transition:all var(--duration-fast);flex-shrink:0}.modal__tab-close:hover{color:var(--text-primary);background:var(--accent-subtle)}.modal__url-bar{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--bg-secondary);border-bottom:1px solid var(--border-subtle);flex-shrink:0}.modal__url-lock{color:var(--text-tertiary);flex-shrink:0;display:flex}.modal__url-text{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal__url-go{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-xs);background:var(--accent-subtle);border:1px solid var(--border-accent);color:var(--accent);cursor:pointer;transition:all var(--duration-fast);flex-shrink:0}.modal__url-go:hover{background:var(--accent);color:var(--text-inverse)}.modal__url-external{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-xs);color:var(--text-tertiary);flex-shrink:0;transition:color var(--duration-fast)}.modal__url-external:hover{color:var(--accent)}.modal__body{padding:32px;overflow-y:auto;flex:1 1}.modal__browser{flex:1 1;position:relative;min-height:400px;background:#fff}.modal__iframe{width:100%;height:100%;border:none;position:absolute;inset:0}.modal__iframe-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);z-index:1}.modal__iframe-spinner{width:32px;height:32px;border:2px solid var(--border-default);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.modal__iframe--hidden{visibility:hidden}.modal__iframe-blocked{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);z-index:2;gap:16px;padding:40px;text-align:center}.modal__blocked-icon{color:var(--text-tertiary);opacity:.5;margin-bottom:8px}.modal__blocked-title{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--text-primary)}.modal__blocked-text{font-size:14px;color:var(--text-secondary);line-height:1.6;max-width:360px}.modal__blocked-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius-sm);background:var(--accent);color:var(--text-inverse);border:1px solid var(--accent);font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;text-decoration:none;transition:all var(--duration-normal) var(--ease-out);margin-top:8px}.modal__blocked-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-3px);box-shadow:var(--shadow-glow)}.modal__meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.modal__meta-tag{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:var(--radius-xs);border:1px solid var(--border-default);color:var(--text-secondary)}.modal__meta-tag--accent{color:var(--accent);border-color:var(--border-accent);background:var(--accent-subtle)}.modal__title{font-family:var(--font-display);font-size:clamp(24px,5vw,32px);font-weight:700;color:var(--text-primary);margin-bottom:8px}.modal__description{font-size:15px;color:var(--text-secondary);line-height:1.85;margin-bottom:24px}.modal__techs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}.modal__tech{padding:4px 12px;border-radius:var(--radius-xs);font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-accent)}.modal__btns{display:flex;gap:12px;flex-wrap:wrap}.modal__btn{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:var(--radius-sm);text-decoration:none;font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;flex:1 1;justify-content:center;min-width:140px;transition:all var(--duration-normal) var(--ease-out)}.modal__btn--site{background:var(--accent);color:var(--text-inverse);border:1px solid var(--accent)}.modal__btn--site:hover{background:var(--accent-hover);border-color:var(--accent-hover);transform:translateY(-3px);box-shadow:var(--shadow-glow)}.modal__btn--repo{background:transparent;color:var(--text-primary);border:1px solid var(--border-default)}.modal__btn--repo:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-3px)}.contact{padding:var(--space-3xl) 0}.contact__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);display:grid;grid-template-columns:1fr;grid-gap:var(--space-2xl);gap:var(--space-2xl)}@media (min-width:768px){.contact__inner{grid-template-columns:1fr 1fr;padding:0 var(--space-xl);gap:var(--space-3xl);align-items:start}}.contact__desc{font-size:16px;line-height:1.8;color:var(--text-secondary);margin-bottom:var(--space-xl)}.contact__details{display:flex;flex-direction:column;gap:var(--space-lg)}.contact__detail{display:flex;align-items:flex-start;gap:16px}.contact__detail-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-subtle);border:1px solid var(--border-accent);color:var(--accent);flex-shrink:0}.contact__detail-label{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--text-tertiary);margin-bottom:4px}.contact__detail-value{font-size:14px;color:var(--text-primary);font-weight:500;transition:color var(--duration-fast)}a.contact__detail-value:hover{color:var(--accent)}.contact__form{display:flex;flex-direction:column;gap:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-xl);position:relative;transform-style:preserve-3d;animation:card3dIdle 12s var(--ease-smooth) infinite;transition:all var(--duration-normal) var(--ease-out)}.contact__form:hover{animation-play-state:paused;transform:perspective(800px) rotateX(-1deg) rotateY(2deg) translateZ(5px);box-shadow:var(--shadow-glow-lg);border-color:var(--border-hover)}.contact__form:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,var(--accent),transparent)}.contact__row{display:grid;grid-template-columns:1fr;grid-gap:var(--space-lg);gap:var(--space-lg)}@media (min-width:480px){.contact__row{grid-template-columns:1fr 1fr}}.contact__field{display:flex;flex-direction:column;gap:8px}.contact__label{font-family:var(--font-mono);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--text-secondary)}.contact__input{width:100%;padding:14px 16px;border-radius:var(--radius-sm);background:var(--bg-primary);border:1px solid var(--border-default);color:var(--text-primary);font-family:var(--font-body);font-size:14px;transition:all var(--duration-fast);outline:none}.contact__input::placeholder{color:var(--text-tertiary)}.contact__input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-glow)}.contact__textarea{resize:vertical;min-height:130px;line-height:1.7}.contact__submit{width:100%;justify-content:center}.contact__submit:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.contact__spinner{width:16px;height:16px;border:2px solid rgba(0,0,0,.2);border-top:2px solid var(--text-inverse);border-radius:50%;animation:spin .6s linear infinite}.contact__toast{display:flex;align-items:center;gap:10px;padding:14px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;animation:fadeInUp .3s var(--ease-expo)}.contact__toast--success{background:var(--color-success-bg);border:1px solid var(--color-success-border);color:var(--color-success)}.contact__toast--error{background:var(--color-error-bg);border:1px solid var(--color-error-border);color:var(--color-error)}.footer{padding:var(--space-2xl) 0 var(--space-xl);border-top:1px solid var(--border-subtle);position:relative}.footer:before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:48px;height:1px;background:var(--accent)}.footer__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);text-align:center}@media (min-width:768px){.footer__inner{flex-direction:row;justify-content:space-between;padding:0 var(--space-xl);text-align:left}}.footer__brand{display:flex;flex-direction:column;gap:6px}.footer__name{font-family:var(--font-display);font-size:20px;font-weight:700;letter-spacing:-.5px}.footer__name span{color:var(--accent)}.footer__tagline{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:2px}.footer__links{display:flex;flex-wrap:wrap;justify-content:center;gap:16px 24px}@media (min-width:768px){.footer__links{gap:28px}}.footer__link{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--text-tertiary);transition:color var(--duration-fast);position:relative}.footer__link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--duration-normal)}.footer__link:hover{color:var(--accent)}.footer__link:hover:after{width:100%}.footer__socials{display:flex;gap:10px}.footer__social{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-default);transition:all var(--duration-normal) var(--ease-out)}.footer__social img{width:16px;height:16px;opacity:.5;transition:opacity var(--duration-fast)}.footer__social:hover{transform:translateY(-3px);border-color:var(--accent);background:var(--accent);box-shadow:var(--shadow-glow)}.footer__social:hover img{opacity:1;filter:brightness(10) invert(0)}.footer__bottom{width:100%;max-width:var(--max-width);margin:0 auto;padding:var(--space-lg) var(--space-lg) 0;margin-top:var(--space-lg);border-top:1px solid var(--border-subtle);text-align:center}.footer__copy{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);letter-spacing:1px}.page-header{padding-top:calc(var(--nav-height) + var(--space-3xl));padding-bottom:var(--space-xl);position:relative;overflow:hidden;perspective:1000px}.page-header:before{top:-30%;right:-10%;width:500px;height:500px;background:var(--accent);border-radius:50%;filter:blur(160px);opacity:.06;animation:glowPulse 6s var(--ease-smooth) infinite}.page-header:after,.page-header:before{content:"";position:absolute;pointer-events:none}.page-header:after{top:calc(var(--nav-height) + 24px);right:10%;width:100px;height:100px;border-right:1px solid var(--border-subtle);border-top:1px solid var(--border-subtle);opacity:.5;animation:drift3d 10s var(--ease-smooth) infinite}.page-header__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg);text-align:center;animation:pageHeader3dIn 1s var(--ease-expo) both;transform-style:preserve-3d}@media (min-width:768px){.page-header__inner{padding:0 var(--space-xl)}}.page-header__title{font-family:var(--font-display);font-size:clamp(36px,7vw,64px);font-weight:700;letter-spacing:-1px;line-height:1.1;margin-bottom:var(--space-md);animation:pageHeader3dIn 1s var(--ease-expo) .1s both}.page-header__sub{font-size:clamp(14px,2vw,17px);color:var(--text-secondary);line-height:1.7;max-width:520px;margin:0 auto;animation:pageHeader3dIn 1s var(--ease-expo) .2s both}.home-cards{padding:var(--space-2xl) 0 var(--space-3xl)}.home-cards__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}@media (min-width:768px){.home-cards__inner{padding:0 var(--space-xl)}}.home-cards__grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-md);gap:var(--space-md)}@media (min-width:600px){.home-cards__grid{grid-template-columns:1fr 1fr}}@media (min-width:1024px){.home-cards__grid{grid-template-columns:repeat(4,1fr)}}.home-card{display:flex;flex-direction:column;padding:var(--space-lg);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden;transform-style:preserve-3d;animation:card3dIdle 8s var(--ease-smooth) infinite;animation-delay:calc(var(--card-index, 0) * .5s)}.home-card:before{content:"";position:absolute;top:0;left:0;width:0;height:100%;background:var(--accent);transition:width var(--duration-normal) var(--ease-out);z-index:0;opacity:.05}.home-card:hover{transform:perspective(800px) rotateX(-3deg) rotateY(3deg) translateY(-8px) translateZ(10px);border-color:var(--border-hover);box-shadow:var(--shadow-glow-lg);animation-play-state:paused}.home-card:hover:before{width:100%}.home-card__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-subtle);border:1px solid var(--border-accent);color:var(--accent);margin-bottom:var(--space-md);position:relative;z-index:1}.home-card__title{font-family:var(--font-display);font-size:18px;font-weight:600;margin-bottom:var(--space-xs);position:relative;z-index:1}.home-card__desc{font-size:13px;color:var(--text-secondary);line-height:1.6;flex:1 1;position:relative;z-index:1}.home-card__arrow{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:transparent;border:1px solid var(--border-default);color:var(--text-tertiary);margin-top:var(--space-md);align-self:flex-end;position:relative;z-index:1;transition:all var(--duration-normal) var(--ease-out)}.home-card:hover .home-card__arrow{background:var(--accent);border-color:var(--accent);color:var(--text-inverse);transform:translateX(3px)}.home-preview{padding:var(--space-2xl) 0}.home-preview--alt{background:var(--bg-secondary);position:relative}.home-preview--alt:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--border-default),transparent)}.home-preview__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}@media (min-width:768px){.home-preview__inner{padding:0 var(--space-xl)}}.home-preview__more{display:inline-flex;align-items:center;gap:10px;margin-top:var(--space-xl);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:1px;text-transform:uppercase;color:var(--accent);transition:all var(--duration-normal) var(--ease-out);position:relative}.home-preview__more:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:1px;background:var(--accent);transition:width var(--duration-normal)}.home-preview__more:hover{gap:14px}.home-preview__more:hover:after{width:100%}.home-preview__about{display:flex;flex-direction:column;gap:var(--space-xl);margin-top:var(--space-lg)}@media (min-width:768px){.home-preview__about{flex-direction:row;align-items:center}}.home-preview__about-text{flex:1 1}.home-preview__about-text p{font-size:15px;color:var(--text-secondary);line-height:1.75}.home-preview__stats{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-md);gap:var(--space-md);flex-shrink:0}@media (min-width:768px){.home-preview__stats{width:280px}}.home-preview__stat{display:flex;flex-direction:column;align-items:center;padding:var(--space-lg) var(--space-md);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);transition:border-color var(--duration-fast)}.home-preview__stat:hover{border-color:var(--border-hover)}.home-preview__stat-num{font-family:var(--font-display);font-size:32px;font-weight:700;color:var(--accent);line-height:1}.home-preview__stat-label{font-family:var(--font-mono);font-size:9px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:2px;margin-top:6px}.home-preview__pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:var(--space-lg)}.home-preview__pill{padding:8px 20px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--text-secondary);transition:all var(--duration-normal) var(--ease-out)}.home-preview__pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.home-preview__exp-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-lg)}.home-preview__exp{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.home-preview__exp:before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:transparent;transition:background var(--duration-normal)}.home-preview__exp:hover{border-color:var(--border-hover);transform:translateX(4px)}.home-preview__exp:hover:before{background:var(--accent)}.home-preview__exp-left{display:flex;align-items:center;gap:var(--space-sm)}.home-preview__exp-role{font-size:14px;font-weight:600}.home-preview__exp-company{font-family:var(--font-mono);font-size:12px;color:var(--accent);font-weight:500}.home-preview__exp-period{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);font-weight:500;white-space:nowrap}@media (max-width:599px){.home-preview__exp{flex-direction:column;align-items:flex-start;gap:4px}}.home-preview__projects{display:grid;grid-template-columns:1fr;grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-lg)}@media (min-width:768px){.home-preview__projects{grid-template-columns:repeat(3,1fr)}}.home-preview__project{padding:var(--space-lg);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);transition:all var(--duration-normal) var(--ease-out);display:flex;flex-direction:column;position:relative;overflow:hidden}.home-preview__project:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:transparent;transition:background var(--duration-normal)}.home-preview__project:hover{transform:perspective(800px) rotateX(-2deg) rotateY(3deg) translateY(-8px) translateZ(15px);border-color:var(--border-hover);box-shadow:var(--shadow-glow-lg)}.home-preview__project:hover:before{background:var(--accent)}.home-preview__project-name{font-family:var(--font-display);font-size:18px;font-weight:600;margin-bottom:var(--space-xs)}.home-preview__project-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;flex:1 1}.home-preview__project-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:var(--space-md)}.home-preview__project-tag{font-family:var(--font-mono);font-size:10px;font-weight:500;padding:3px 10px;border-radius:var(--radius-xs);background:var(--accent-subtle);border:1px solid var(--border-accent);color:var(--accent)}.contact-extra{padding:var(--space-2xl) 0 var(--space-3xl)}.contact-extra__inner{max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}@media (min-width:768px){.contact-extra__inner{padding:0 var(--space-xl)}}.contact-extra__grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-md);gap:var(--space-md);margin-bottom:var(--space-2xl)}@media (min-width:600px){.contact-extra__grid{grid-template-columns:1fr 1fr}}@media (min-width:1024px){.contact-extra__grid{grid-template-columns:repeat(4,1fr)}}.contact-extra__card{padding:var(--space-lg);border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border-subtle);text-align:center;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden}.contact-extra__card:after{content:"";position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--accent);transition:width var(--duration-normal)}.contact-extra__card:hover{transform:perspective(800px) rotateX(-3deg) rotateY(2deg) translateY(-6px) translateZ(10px);border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.contact-extra__card:hover:after{width:100%}.contact-extra__icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--accent-subtle);border:1px solid var(--border-accent);color:var(--accent);margin:0 auto var(--space-md)}.contact-extra__title{font-family:var(--font-display);font-size:17px;font-weight:600;margin-bottom:var(--space-xs)}.contact-extra__text{font-size:13px;color:var(--text-secondary);line-height:1.6}.contact-extra__socials{text-align:center}.contact-extra__socials-title{font-family:var(--font-mono);font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:3px;margin-bottom:var(--space-lg)}.contact-extra__socials-grid{display:flex;justify-content:center;flex-wrap:wrap;gap:var(--space-md)}.contact-extra__social{display:flex;align-items:center;gap:10px;padding:12px 24px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-subtle);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.5px;color:var(--text-secondary);transition:all var(--duration-normal) var(--ease-out)}.contact-extra__social img,.contact-extra__social svg{width:18px;height:18px;opacity:.6;transition:opacity var(--duration-fast)}.contact-extra__social:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-glow)}.contact-extra__social:hover img,.contact-extra__social:hover svg{opacity:1}