.button{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;background-color:transparent;font-family:var(--font-family-primary);font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease-in-out;min-height:44px;min-width:44px}.button:focus{outline:2px solid var(--color-primary);outline-offset:2px}.button:disabled,.button[aria-disabled=true]{opacity:.4;cursor:not-allowed;pointer-events:none;filter:grayscale(50%)}.button--primary{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-text-primary)}.button--primary:hover:not(:disabled){background-color:transparent;color:var(--color-primary)}.button--secondary{background-color:transparent;border-color:var(--color-text-secondary);color:var(--color-text-secondary)}.button--secondary:hover:not(:disabled){border-color:var(--color-text-primary);color:var(--color-text-primary)}.button--outline{background-color:transparent;color:var(--color-text-primary);border-color:var(--color-primary)}.button--outline:hover:not(:disabled){background-color:var(--color-primary);color:var(--color-background)}.button--ghost{background-color:transparent;border-color:transparent;color:var(--color-text-secondary)}.button--ghost:hover:not(:disabled){background-color:#abb2bf1a;color:var(--color-text-primary)}.button--demo{background:linear-gradient(135deg,#c778dd1a,#c778dd0d);border:1px solid rgba(199,120,221,.3);color:var(--color-primary);position:relative;overflow:hidden;font-weight:600;text-transform:uppercase;letter-spacing:.5px;transition:all .3s cubic-bezier(.4,0,.2,1)}.button--demo:before{content:"▶";margin-right:6px;font-size:10px;animation:playPulse 2s ease-in-out infinite}.button--demo:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.2),transparent);transition:left .6s ease}.button--demo:hover:after{left:100%}.button--demo:hover:not(:disabled){background:linear-gradient(135deg,#c778dd33,#c778dd1a);border-color:var(--color-primary);color:var(--color-text-primary);transform:translateY(-2px);box-shadow:0 8px 25px #c778dd4d}.button--demo:active{transform:translateY(0);box-shadow:0 4px 15px #c778dd33}@keyframes playPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.button--sm{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm)}.button--md{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base)}.button--lg{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-lg)}@media (max-width: 767px){.button{min-height:48px;min-width:48px}.button--sm{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base)}.button--md{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.button--lg{padding:var(--spacing-lg) var(--spacing-2xl);font-size:var(--font-size-xl)}}.card{background-color:var(--color-background);transition:all .2s ease-in-out}.card--default,.card--elevated{border:1px solid var(--color-border)}.card--elevated:hover{border-color:var(--color-primary)}.card--outlined{border:1px solid var(--color-border)}.card--padding-sm{padding:var(--spacing-sm)}.card--padding-md{padding:var(--spacing-md)}.card--padding-lg{padding:var(--spacing-lg)}.code-animation{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:3;opacity:0;animation:codeAnimationFadeIn 1s ease-out .5s forwards}@keyframes codeAnimationFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.code-window{background:#282c33f2;border:1px solid rgba(171,178,191,.2);border-radius:8px;box-shadow:0 20px 40px #0000004d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);min-width:480px;max-width:600px;width:90vw;max-height:70vh;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.code-window:hover{transform:translateY(-5px);box-shadow:0 25px 50px #0006;border-color:#c778dd4d}.code-header{background:#1e2127cc;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(171,178,191,.1)}.window-controls{display:flex;gap:8px}.control{width:12px;height:12px;border-radius:50%;transition:all .2s ease}.control--close{background:#ff5f57}.control--minimize{background:#ffbd2e}.control--maximize{background:#28ca42}.control:hover{transform:scale(1.1);filter:brightness(1.2)}.code-title{display:flex;align-items:center;gap:8px;font-family:Fira Code,SF Mono,Monaco,monospace;font-size:12px;font-weight:600}.language-name{transition:color .3s ease}.typing-indicator{color:var(--color-primary);animation:typingPulse 1s ease-in-out infinite}@keyframes typingPulse{0%,to{opacity:1}50%{opacity:.3}}.code-content{padding:20px;background:#282c33e6;min-height:300px;max-height:400px;overflow-y:auto;overflow-x:hidden}.code-block{font-family:Fira Code,SF Mono,Monaco,monospace;font-size:14px;line-height:1.6;color:#abb2bf;margin:0;white-space:pre-wrap;word-wrap:break-word}.cursor{color:var(--color-primary);animation:cursorBlink 1s ease-in-out infinite;font-weight:100}@keyframes cursorBlink{0%,50%{opacity:1}51%,to{opacity:0}}.code-block{background:linear-gradient(135deg,#282c33f2,#23272ef2)}.code-window:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,#c778dd1a,#c778dd0d,#c778dd1a);border-radius:10px;z-index:-1;opacity:0;transition:opacity .3s ease}.code-window:hover:before{opacity:1}@media (max-width: 767px){.code-animation{position:relative;top:auto;left:50%;transform:translate(-50%);margin:20px 0;display:flex;justify-content:center;width:100%}.code-window{min-width:320px;max-width:95vw;width:95vw;margin:0 auto}.code-content{padding:16px;min-height:200px;max-height:250px;text-align:center}.code-block{font-size:12px;line-height:1.4;text-align:left;display:inline-block}}@media (max-width: 320px){.code-window{min-width:280px;margin:0 auto}.code-content{padding:12px;min-height:180px;max-height:220px;text-align:center}.code-block{font-size:11px;text-align:left;display:inline-block}}.image{position:relative;overflow:hidden;background:transparent;will-change:transform;contain:layout style paint}.image__placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:transparent;pointer-events:none;transform:translateZ(0)}.image__placeholder-img{width:100%;height:100%;object-fit:cover;opacity:.5;transform:translateZ(0)}.image__main{width:100%;height:100%;object-fit:cover;transition:opacity .2s ease-out;transform:translateZ(0);backface-visibility:hidden}.image--loading .image__main{opacity:0}.image--loaded .image__main{opacity:1}.image--loaded .image__placeholder{opacity:0;visibility:hidden}.image__error{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-secondary, #f0f0f0);color:var(--color-text-secondary, #666);font-size:var(--font-size-sm, 14px)}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.image__main,.image__placeholder-img{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}@media (prefers-reduced-motion: reduce){.image{will-change:auto}.image__main{transition:none}}.image__main,.image__placeholder{backface-visibility:hidden;perspective:1000px}.icon{display:inline-block;background-size:contain;background-repeat:no-repeat;background-position:center;flex-shrink:0}.icon--github{background-image:url(/assets/icons/github.svg)}.icon--dribbble{background-image:url(/assets/icons/dribbble.svg)}.icon--figma{background-image:url(/assets/icons/figma.svg)}.icon--discord{background-image:url(/assets/icons/discord.svg)}.icon--email{background-image:url(/assets/icons/email.svg)}.icon--logo{background-image:url(/assets/icons/logo.svg)}.icon--dots{background-image:url(/assets/images/dots-pattern.svg)}.mobile-nav__toggle{display:none;flex-direction:column;justify-content:center;align-items:center;width:44px;height:44px;background:transparent;border:none;cursor:pointer;padding:var(--spacing-xs);border-radius:8px;transition:all .3s var(--ease-premium);position:relative;z-index:10000}.mobile-nav__toggle:hover{background:#c778dd33}.mobile-nav__line{width:24px;height:3px;background:var(--color-text-primary);margin:3px 0;transition:all .3s var(--ease-premium);transform-origin:center;border-radius:1px}.mobile-nav__toggle--open .mobile-nav__line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.mobile-nav__toggle--open .mobile-nav__line:nth-child(2){opacity:0;transform:scale(0)}.mobile-nav__toggle--open .mobile-nav__line:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.mobile-nav__overlay{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--color-background);border-left:1px solid rgba(199,120,221,.3);z-index:9999;transition:right .4s var(--ease-premium);overflow-y:auto;box-shadow:-5px 0 20px #00000080}.mobile-nav__overlay--open{right:0}.mobile-nav__menu{display:flex;flex-direction:column;height:100%;padding:var(--spacing-xl) var(--spacing-lg)}.mobile-nav__header{padding:var(--spacing-xl) 0 var(--spacing-lg) 0;border-bottom:1px solid rgba(199,120,221,.3);margin-bottom:var(--spacing-lg)}.mobile-nav__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary);display:flex;align-items:center}.mobile-nav__title:before{content:"#";margin-right:var(--spacing-xs)}.mobile-nav__list{list-style:none;margin:0;padding:0;flex:1}.mobile-nav__item{margin-bottom:var(--spacing-sm)}.mobile-nav__link{display:flex;align-items:center;text-decoration:none;font-size:var(--font-size-base);font-weight:500;color:var(--color-text-primary);padding:var(--spacing-md) var(--spacing-sm);border-radius:8px;transition:all .3s var(--ease-premium);min-height:48px;position:relative;overflow:hidden;background:transparent}.mobile-nav__link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.1),transparent);transition:left .6s var(--ease-smooth)}.mobile-nav__link:hover:before{left:100%}.mobile-nav__link:hover,.mobile-nav__link--active{color:var(--color-text-primary);background:#c778dd33;transform:translate(8px)}.mobile-nav__link--active{color:var(--color-primary);background:#c778dd40;box-shadow:0 0 20px #c778dd66}.mobile-nav__link .nav-hash{color:var(--color-primary);margin-right:var(--spacing-xs);font-weight:600}.mobile-nav__footer{padding-top:var(--spacing-lg);border-top:1px solid rgba(199,120,221,.3);display:flex;justify-content:center}.mobile-nav__footer .language-switcher{padding:var(--spacing-sm) var(--spacing-md);background:#c778dd33;border-radius:8px;border:1px solid rgba(199,120,221,.3);color:var(--color-text-primary);font-weight:500}.mobile-nav__backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;z-index:9998;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 767px){.mobile-nav__toggle{display:flex}.navigation{display:none!important}}@media (min-width: 768px){.mobile-nav__toggle,.mobile-nav__overlay,.mobile-nav__backdrop{display:none!important}}.mobile-nav__link{animation:slideInRight .3s ease-out forwards;opacity:0;transform:translate(30px)}.mobile-nav__overlay--open .mobile-nav__link{opacity:1!important;color:var(--color-text-primary)!important}.mobile-nav__overlay--open .mobile-nav__link:nth-child(1){animation-delay:.1s}.mobile-nav__overlay--open .mobile-nav__link:nth-child(2){animation-delay:.15s}.mobile-nav__overlay--open .mobile-nav__link:nth-child(3){animation-delay:.2s}.mobile-nav__overlay--open .mobile-nav__link:nth-child(4){animation-delay:.25s}.mobile-nav__overlay--open .mobile-nav__link:nth-child(5){animation-delay:.3s}.mobile-nav__overlay--open .mobile-nav__link:nth-child(6){animation-delay:.35s}@keyframes slideInRight{to{opacity:1;transform:translate(0)}}.mobile-nav__toggle:focus{outline:2px solid var(--color-primary);outline-offset:2px}.mobile-nav__link:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion: reduce){.mobile-nav__toggle,.mobile-nav__overlay,.mobile-nav__link{transition:none!important;animation:none!important}}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:48px;padding:16px 0}.pagination__button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);font-family:var(--font-family-primary);font-size:16px;font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.pagination__button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.1),transparent);transition:left .6s ease}.pagination__button:hover:before{left:100%}.pagination__button:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #c778dd33}.pagination__button:active:not(:disabled){transform:translateY(0)}.pagination__button:disabled{opacity:.3;cursor:not-allowed}.pagination__arrow{font-size:18px;font-weight:600}.pagination__pages{display:flex;align-items:center;gap:4px;margin:0 8px}.pagination__page{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;background:transparent;border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-secondary);font-family:var(--font-family-primary);font-size:16px;font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.pagination__page:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.1),transparent);transition:left .6s ease}.pagination__page:hover:before{left:100%}.pagination__page:hover:not(:disabled):not(.pagination__page--active){border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #c778dd33}.pagination__page--active{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-background);font-weight:600;box-shadow:0 4px 12px #c778dd4d}.pagination__page--active:hover{transform:none;cursor:default}.pagination__page--ellipsis{border:none;cursor:default;color:var(--color-text-secondary);opacity:.5}.pagination__page--ellipsis:hover{transform:none;box-shadow:none;border:none}@media (max-width: 767px){.pagination{gap:4px;margin-top:32px}.pagination__button,.pagination__page{width:44px;height:44px;min-width:44px;font-size:14px}.pagination__pages{gap:2px;margin:0 4px}.pagination__arrow{font-size:16px}}@media (max-width: 320px){.pagination__button,.pagination__page{width:40px;height:40px;min-width:40px;font-size:13px;padding:0 8px}}.skill-icon{display:inline-block;transition:all .3s cubic-bezier(.4,0,.2,1);filter:grayscale(.3) opacity(.8)}.skill-icon:hover{filter:grayscale(0) opacity(1);transform:scale(1.1)}.skill-tag-with-icon{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#abb2bf1a;border:1px solid rgba(171,178,191,.2);border-radius:4px;transition:all .3s cubic-bezier(.4,0,.2,1)}.skill-tag-with-icon:hover{background:#abb2bf26;border-color:#abb2bf4d;transform:translateY(-2px)}.skill-tag-with-icon .skill-tag-text{font-size:var(--font-size-base);color:var(--color-text-secondary);font-weight:500}.skill-tag-with-icon:hover .skill-tag-text{color:var(--color-text-primary)}.page-animation-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:-1;overflow:hidden}.floating-orb{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(199,120,221,.3) 0%,rgba(199,120,221,.1) 50%,transparent 100%);animation:floatOrb 20s ease-in-out infinite;filter:blur(1px)}.floating-orb:nth-child(1){width:200px;height:200px;top:10%;left:10%;animation-delay:0s;animation-duration:25s}.floating-orb:nth-child(2){width:150px;height:150px;top:60%;right:15%;animation-delay:-5s;animation-duration:30s}.floating-orb:nth-child(3){width:100px;height:100px;bottom:20%;left:20%;animation-delay:-10s;animation-duration:20s}.floating-orb:nth-child(4){width:80px;height:80px;top:30%;right:40%;animation-delay:-15s;animation-duration:35s}@keyframes floatOrb{0%,to{transform:translate(0) scale(1);opacity:.6}25%{transform:translate(30px,-20px) scale(1.1);opacity:.8}50%{transform:translate(-20px,30px) scale(.9);opacity:.4}75%{transform:translate(40px,10px) scale(1.05);opacity:.7}}.page-enter{animation:pageSlideIn .6s ease-out}@keyframes pageSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.floating-orb{filter:blur(2px)}.floating-orb:nth-child(1){width:120px;height:120px}.floating-orb:nth-child(2){width:100px;height:100px}.floating-orb:nth-child(3){width:80px;height:80px}.floating-orb:nth-child(4){width:60px;height:60px}}@media (prefers-reduced-motion: reduce){.floating-orb,.page-enter{animation:none}}.cv-tabs{width:100%}.cv-tabs__navigation{display:flex;justify-content:center;gap:var(--spacing-xs);margin-bottom:var(--spacing-2xl);padding:var(--spacing-xs);background:#282c33e6;border:1px solid rgba(171,178,191,.1);border-radius:12px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.cv-tabs__navigation::-webkit-scrollbar{display:none}.cv-tab{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:transparent;border:none;border-radius:8px;color:var(--color-text-secondary);font-family:var(--font-family-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;min-height:44px}.cv-tab__icon{width:20px;height:20px;opacity:.7;transition:opacity .2s ease}.cv-tab__label{transition:color .2s ease}.cv-tab:hover{color:var(--color-text-primary);background:#c778dd1a}.cv-tab:hover .cv-tab__icon{opacity:1}.cv-tab--active{color:#fff;background:var(--color-primary)}.cv-tab--active .cv-tab__icon{opacity:1;filter:brightness(0) invert(1)}.cv-tabs__content{animation:tabSlide .3s ease-out}@keyframes tabSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1023px){.cv-tabs__navigation{justify-content:flex-start}}@media (max-width: 767px){.cv-tabs__navigation{gap:4px;padding:4px;margin-bottom:var(--spacing-lg)}.cv-tab{flex-direction:column;gap:4px;padding:var(--spacing-sm);min-width:64px}.cv-tab__icon{width:24px;height:24px}.cv-tab__label{font-size:10px}}@media (max-width: 320px){.cv-tab__label{display:none}.cv-tab{min-width:48px;padding:var(--spacing-sm)}.cv-tab__icon{width:28px;height:28px}}@media (prefers-reduced-motion: reduce){.cv-tabs__content,.cv-tab{animation:none;transition:none}}.cv-content{width:100%;max-width:900px;margin:0 auto;background:linear-gradient(180deg,#282c33fa,#1e2127fc);border:1px solid rgba(199,120,221,.15);border-radius:12px;box-shadow:0 30px 60px -15px #00000080,0 0 1px #c778dd4d;animation:cvFadeIn .4s ease-out}@keyframes cvFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cv-header{padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);text-align:center;border-bottom:1px solid rgba(199,120,221,.15);background:linear-gradient(180deg,rgba(199,120,221,.08) 0%,transparent 100%)}.cv-name{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--spacing-xs);letter-spacing:-.01em}.cv-role{font-size:clamp(1rem,2.5vw,1.25rem);font-weight:600;color:var(--color-primary);margin:0 0 var(--spacing-lg)}.cv-contact-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);font-size:var(--font-size-sm)}.cv-contact-item{display:inline-flex;align-items:center;gap:6px;color:var(--color-text-secondary);text-decoration:none;transition:color .2s ease}.cv-contact-item:hover{color:var(--color-primary)}.cv-icon{width:16px;height:16px;flex-shrink:0}.cv-divider{color:var(--color-primary);opacity:.5}.cv-links-row{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:var(--spacing-md)}.cv-links-row a{display:inline-flex;align-items:center;gap:6px;color:var(--color-primary);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;padding:var(--spacing-xs) var(--spacing-sm);border-radius:6px;transition:all .2s ease}.cv-links-row a:hover{background:#c778dd1a}.cv-link-icon{width:16px;height:16px}.cv-section{padding:var(--spacing-xl) var(--spacing-2xl);border-bottom:1px solid rgba(171,178,191,.08)}.cv-section:last-of-type{border-bottom:none}.cv-section-title{font-size:var(--font-size-lg);font-weight:700;color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:2px solid var(--color-primary);display:inline-block}.cv-summary{font-size:var(--font-size-base);line-height:1.75;color:var(--color-text-secondary);margin:0}.cv-skills-grid{display:grid;gap:var(--spacing-lg)}.cv-skill-group{display:grid;grid-template-columns:200px 1fr;gap:var(--spacing-md);align-items:baseline}.cv-skill-group-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);margin:0}.cv-skill-items{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;margin:0}.cv-experience-item{margin-bottom:var(--spacing-xl)}.cv-experience-item:last-child{margin-bottom:0}.cv-experience-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.cv-experience-role{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0}.cv-experience-period{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.cv-experience-company{font-size:var(--font-size-sm);color:var(--color-primary);margin:0 0 var(--spacing-sm)}.cv-list{list-style:none;padding:0;margin:0}.cv-list li{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-xs);padding-left:var(--spacing-lg);position:relative}.cv-list li:before{content:"•";position:absolute;left:0;color:var(--color-primary)}.cv-projects-list{display:grid;gap:var(--spacing-lg)}.cv-project-item{padding:var(--spacing-md);background:#abb2bf08;border-radius:8px;border-left:3px solid var(--color-primary)}.cv-project-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.cv-project-name{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0}.cv-project-company{font-size:var(--font-size-sm);color:var(--color-primary);font-style:italic}.cv-education-item{padding:var(--spacing-md);background:#abb2bf08;border-radius:8px;border-left:3px solid var(--color-primary)}.cv-education-header{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.cv-education-item h4{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin:0}.cv-education-period{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.cv-education-school{font-size:var(--font-size-sm);color:var(--color-primary);margin:0 0 var(--spacing-xs)}.cv-education-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6;margin:0}.cv-certifications-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.cv-cert-item{display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#c778dd0d;border:1px solid rgba(199,120,221,.15);border-radius:8px;transition:all .2s ease}.cv-cert-item:hover{background:#c778dd1a;border-color:#c778dd4d}.cv-cert-icon{width:24px;height:24px;color:var(--color-primary);flex-shrink:0;margin-top:2px}.cv-cert-name{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.cv-cert-issuer{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.cv-actions{padding:var(--spacing-xl) var(--spacing-2xl);display:flex;justify-content:center}.cv-download-btn{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);background:var(--color-primary);border:none;border-radius:8px;color:#fff;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all .2s ease;min-height:44px}.cv-download-btn svg{width:18px;height:18px}.cv-download-btn:hover{background:#b366d9;transform:translateY(-2px);box-shadow:0 4px 12px #c778dd66}@media (max-width: 767px){.cv-content{margin:0 var(--spacing-md);border-radius:8px}.cv-header{padding:var(--spacing-xl) var(--spacing-lg)}.cv-section{padding:var(--spacing-lg)}.cv-contact-row{flex-direction:column;gap:var(--spacing-xs)}.cv-divider{display:none}.cv-skill-group{grid-template-columns:1fr;gap:var(--spacing-xs)}.cv-experience-header,.cv-project-header,.cv-education-header{flex-direction:column;gap:var(--spacing-xs)}.cv-certifications-grid{grid-template-columns:1fr}}@media (max-width: 320px){.cv-header{padding:var(--spacing-lg) var(--spacing-md)}.cv-section{padding:var(--spacing-md)}.cv-links-row{flex-direction:column;gap:var(--spacing-xs)}}.binary-rain{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:-2;opacity:.6;background:transparent}@media (max-width: 767px){.binary-rain{opacity:.3}}@media (prefers-reduced-motion: reduce){.binary-rain{display:none}}.binary-rain{will-change:transform;transform:translateZ(0)}:root{--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--breakpoint-sm: 320px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1440px;--font-family-primary: "Fira Code", "SF Mono", "Monaco", "Inconsolata", "Roboto Mono", monospace;--font-size-sm: 14px;--font-size-base: 16px;--font-size-lg: 18px;--font-size-xl: 20px;--font-size-2xl: 24px;--font-size-3xl: 32px;--font-size-4xl: 40px;--color-primary: #C778DD;--color-secondary: #ABB2BF;--color-background: #282C33;--color-surface: #282C33;--color-text-primary: #FFFFFF;--color-text-secondary: #ABB2BF;--color-border: #ABB2BF;--color-accent: #C778DD;--ease-premium: cubic-bezier(.23, 1, .32, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--glow-primary: 0 0 20px rgba(199, 120, 221, .4);--glow-intense: 0 0 40px rgba(199, 120, 221, .6)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family-primary);font-size:var(--font-size-base);line-height:1.6;color:var(--color-text-primary);background:linear-gradient(135deg,var(--color-background) 0%,#1a1d23 100%);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"liga" 1,"kern" 1;cursor:none}*,*:before,*:after{cursor:none!important}img{max-width:100%;height:auto;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;content-visibility:auto;contain-intrinsic-size:300px 200px}.cursor{position:fixed;top:0;left:0;width:50px;height:30px;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);will-change:transform;backface-visibility:hidden;perspective:1000px}.cursor:before{content:"{}";position:absolute;top:50%;left:50%;font-size:18px;font-family:Fira Code,SF Mono,Monaco,monospace;font-weight:600;color:var(--color-primary);transform:translate(-50%,-50%);transition:all .2s cubic-bezier(.68,-.55,.265,1.55);animation:codeBlink 2s ease-in-out infinite;text-shadow:0 0 10px rgba(199,120,221,.6);letter-spacing:0px;will-change:transform,opacity;backface-visibility:hidden}.cursor:after{content:"";position:absolute;top:50%;left:50%;width:40px;height:20px;background:radial-gradient(ellipse,rgba(199,120,221,.2) 0%,rgba(199,120,221,.1) 50%,transparent 100%);border-radius:50%;transform:translate(-50%,-50%);animation:codeGlow 1.5s ease-in-out infinite alternate;will-change:transform,opacity;backface-visibility:hidden}@keyframes codeBlink{0%,80%{opacity:1;transform:translate(-50%,-50%) scaleZ(1);color:var(--color-primary);text-shadow:0 0 10px rgba(199,120,221,.6)}90%{opacity:.7;transform:translate(-50%,-50%) scale3d(1.05,1.05,1);color:var(--color-accent);text-shadow:0 0 15px rgba(199,120,221,.8)}to{opacity:1;transform:translate(-50%,-50%) scaleZ(1);color:var(--color-primary);text-shadow:0 0 10px rgba(199,120,221,.6)}}@keyframes codeGlow{0%{transform:translate(-50%,-50%) scaleZ(1);opacity:.3}to{transform:translate(-50%,-50%) scale3d(1.2,1.2,1);opacity:.1}}.cursor.hover:before{content:"{ code }";font-size:16px;letter-spacing:1px;animation:codeExpand .6s ease-out;color:#0f8;text-shadow:0 0 15px rgba(0,255,136,.8)}.cursor.hover:after{width:60px;height:25px;background:radial-gradient(ellipse,rgba(0,255,136,.3) 0%,rgba(0,255,136,.1) 50%,transparent 100%);animation:codeExpandGlow .6s ease-out}@keyframes codeExpand{0%{transform:translate(-50%,-50%) scale3d(.8,.8,1);letter-spacing:2px}50%{transform:translate(-50%,-50%) scale3d(1.1,1.1,1);letter-spacing:0px}to{transform:translate(-50%,-50%) scaleZ(1);letter-spacing:1px}}@keyframes codeExpandGlow{0%{transform:translate(-50%,-50%) scale3d(.8,.8,1);opacity:.1}50%{transform:translate(-50%,-50%) scale3d(1.3,1.3,1);opacity:.4}to{transform:translate(-50%,-50%) scale3d(1.2,1.2,1);opacity:.2}}.cursor.click:before{content:"{ ✓ }";font-size:18px;animation:codeExecute .5s ease-out;color:#ff0;text-shadow:0 0 20px rgba(255,255,0,1)}.cursor.click:after{width:50px;height:30px;background:radial-gradient(ellipse,rgba(255,255,0,.4) 0%,rgba(255,165,0,.2) 50%,transparent 100%);animation:codeExecuteGlow .5s ease-out}.header__logo{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:inherit}.footer{margin-top:var(--spacing-3xl);padding:var(--spacing-xl) 0;position:relative;overflow:hidden}.portfolio{min-height:100vh;position:relative;background-color:var(--color-background)}.header{position:fixed;top:0;left:0;right:0;background:#282c33cc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(199,120,221,.1);z-index:100;padding:var(--spacing-md) 0;transition:all .3s var(--ease-smooth)}.header:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);opacity:0;transition:opacity .3s var(--ease-smooth)}.header:hover:before{opacity:1}.header__content{max-width:1366px;margin:0 auto;padding-left:60px;padding-right:var(--spacing-lg);display:flex;align-items:center;justify-content:space-between}.header__logo{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-text{font-weight:700;font-size:var(--font-size-base);color:var(--color-text-primary)}.navigation{display:flex;align-items:center;gap:var(--spacing-xl)}.nav-link{display:flex;align-items:center;text-decoration:none;font-weight:500;font-size:var(--font-size-base);color:var(--color-text-secondary);padding:8px 16px;border-radius:8px;position:relative;overflow:hidden;transition:all .3s var(--ease-premium)}.nav-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.1),transparent);transition:left .6s var(--ease-smooth)}.nav-link:hover:before{left:100%}.nav-link:hover{color:var(--color-text-primary);background:#c778dd1a;transform:translateY(-2px);box-shadow:var(--glow-primary)}.nav-link--active{color:var(--color-primary);background:#c778dd26;box-shadow:var(--glow-primary)}.nav-hash{color:var(--color-primary);margin-right:2px}.language-switcher{display:flex;align-items:center;gap:var(--spacing-xs);color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:600}.dropdown-arrow{width:10px;height:5px;background-color:var(--color-text-secondary);clip-path:polygon(0 0,100% 0,50% 100%)}.hero__text{flex:1;max-width:600px;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;padding-top:62px}.hero__title{font-size:32px;font-weight:600;line-height:42px;margin-bottom:32px;color:var(--color-text-primary);letter-spacing:0;font-family:var(--font-family-primary);position:relative;overflow:hidden}.hero__title:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--color-background);animation:textReveal 1.5s var(--ease-premium) .5s forwards}.hero__subtitle{font-size:16px;color:var(--color-text-secondary);margin-bottom:24px;line-height:25px;font-weight:400}.hero__cta{margin-top:0;align-self:flex-start}.hero__visual{position:relative;flex:0 0 457px;max-width:457px;height:386px;overflow:visible}.hero__decorations{position:absolute;inset:0;pointer-events:none}.hero__decorations .decoration{position:absolute;border:1px solid var(--color-border);background:transparent;box-sizing:border-box}.hero__decorations .decoration--rect-1{width:155px;height:155px;top:37px;left:-77px;z-index:1}.hero__decorations .decoration--rect-2{width:91px;height:91px;top:107px;left:-36px;z-index:1}.hero__decorations .decoration--rect-3{width:63px;height:63px;bottom:0;left:-26px;z-index:1}.hero__decorations .decoration--rect-4{width:63px;height:63px;top:0;right:-33px;z-index:1}.hero__decorations .decoration--rect-5{width:52px;height:52px;top:127px;right:-52px;z-index:1}.hero__image{position:relative;z-index:2;width:457px;height:400px;overflow:hidden}.hero__image img{width:100%;height:120%;object-fit:cover;object-position:center center;background:transparent}.hero__logo{display:none}.logo-large{border-radius:var(--spacing-sm)}.status-indicator{position:absolute;bottom:-37px;right:0;display:flex;align-items:center;gap:10px;background-color:var(--color-background);border:1px solid var(--color-border);padding:8px;font-size:16px;color:var(--color-text-secondary);white-space:nowrap;z-index:4}.status-dot{width:16px;height:16px;background-color:var(--color-primary);border-radius:2px}.quote{margin:112px 0;display:flex;justify-content:center;padding:0 var(--spacing-lg);position:relative;opacity:0;transform:translateY(30px);animation:fadeInUp .8s ease-out .3s forwards}.quote__card{position:relative;max-width:712px;width:100%;background:transparent;border:none;padding:var(--spacing-2xl) 0;cursor:pointer;transition:all .4s cubic-bezier(.4,0,.2,1)}.quote__card:hover{transform:translateY(-8px)}.quote__card:before{content:'"';position:absolute;top:0;left:0;font-size:100px;color:var(--color-primary);font-family:Georgia,serif;line-height:.8;z-index:1;opacity:.8;transition:all .4s cubic-bezier(.4,0,.2,1);animation:pulseGlow 3s ease-in-out infinite}.quote__card:after{content:'"';position:absolute;bottom:0;right:0;font-size:100px;color:var(--color-primary);font-family:Georgia,serif;line-height:.8;z-index:1;opacity:.8;transition:all .4s cubic-bezier(.4,0,.2,1);animation:pulseGlow 3s ease-in-out infinite 1.5s}.quote__card:hover:before,.quote__card:hover:after{transform:scale(1.1);color:var(--color-accent)}.quote__text{font-size:var(--font-size-2xl);font-weight:500;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0;text-align:center;line-height:1.4;border:1px solid var(--color-border);padding:var(--spacing-2xl);position:relative;background-color:var(--color-background);z-index:2;font-style:italic;transition:all .4s cubic-bezier(.4,0,.2,1);overflow:hidden}.quote__text:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.1),transparent);transition:left .6s ease}.quote__card:hover .quote__text:before{left:100%}.quote__card:hover .quote__text{border-color:var(--color-primary);box-shadow:0 0 30px #c778dd33}.quote__author{display:block;text-align:right;font-size:var(--font-size-lg);color:var(--color-text-secondary);border:1px solid var(--color-border);border-top:none;padding:var(--spacing-md);margin:0;width:100%;font-weight:400;position:relative;background-color:var(--color-background);z-index:2;font-style:normal}.section-header{display:flex;align-items:center;gap:16px;margin-bottom:48px}.section-title{display:flex;align-items:center;font-size:32px;font-weight:500;color:var(--color-text-primary);white-space:nowrap;line-height:42px}.section-hash{color:var(--color-primary);margin-right:0}.section-line{flex:1;height:1px;background-color:var(--color-primary);margin-left:16px}.view-all-link{font-size:16px;font-weight:500;color:var(--color-text-primary);text-decoration:none;white-space:nowrap;margin-left:16px}.projects{margin-bottom:112px}.projects__grid{display:grid;grid-template-columns:repeat(3,380px);gap:20px;max-width:1200px;justify-content:flex-start}.project-card{border:1px solid var(--color-border);background:transparent;overflow:hidden;width:380px;min-height:520px}.project-image{height:320px;border-bottom:1px solid var(--color-border);overflow:hidden;background:transparent}.project-image img{width:100%;height:100%;object-fit:cover;background:transparent;border:none}.project-tech{display:flex;flex-wrap:wrap;gap:8px;padding:8px;border-bottom:1px solid var(--color-border)}.tech-tag{font-size:16px;color:var(--color-text-secondary);font-weight:400}.project-content{padding:20px;display:flex;flex-direction:column;gap:16px;flex:1}.project-title{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:16px;line-height:31px}.project-description{font-size:16px;color:var(--color-text-secondary);line-height:1.5;flex:1;min-height:60px}.project-actions{display:flex;gap:16px}.skills{margin-bottom:112px;position:relative}.skills:before{content:"";position:absolute;top:-50px;left:50%;transform:translate(-50%);width:200px;height:2px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);animation:skillsLineGlow 2s ease-in-out infinite alternate}.skills__content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:start}.skills__content--full{display:block;max-width:1024px}.skills__visual{position:relative;height:280px}.skill-shapes{position:absolute;inset:0}.skill-shape{position:absolute;border:1px solid var(--color-border)}.skill-shape--1{width:63px;height:63px;top:38px;left:34px;background-image:url(/assets/images/dots-pattern.svg);background-size:contain;border:none}.skill-shape--2{width:63px;height:63px;top:143px;right:36px;background-image:url(/assets/images/dots-pattern.svg);background-size:contain;border:none}.skill-shape--3{width:52px;height:52px;top:193px;right:2px}.logo-watermark{position:absolute;bottom:0;left:49px;width:113px;height:113px;background-image:url(/assets/icons/logo-large.svg);background-size:contain;background-repeat:no-repeat;opacity:.1}.skills__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.skill-category{border:1px solid var(--color-border);padding:0;background:linear-gradient(135deg,var(--color-background) 0%,rgba(40,44,51,.8) 100%);position:relative;overflow:hidden;transition:all .4s var(--ease-premium);opacity:0;transform:translateY(30px);animation:fadeInUp .6s var(--ease-premium) forwards}.skill-category:nth-child(1){animation-delay:.1s}.skill-category:nth-child(2){animation-delay:.2s}.skill-category:nth-child(3){animation-delay:.3s}.skill-category:nth-child(4){animation-delay:.4s}.skill-category:nth-child(5){animation-delay:.5s}.skill-category:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(199,120,221,.1),transparent);transition:left .8s var(--ease-smooth)}.skill-category:hover:before{left:100%}.skill-category:hover{transform:translateY(-5px);border-color:var(--color-primary);box-shadow:var(--glow-primary)}.skill-category__title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);padding:var(--spacing-sm)}.skill-category__divider{height:1px;background-color:var(--color-border)}.skill-tags{padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-sm)}.skill-tag{font-size:var(--font-size-base);color:var(--color-text-secondary)}.skill-tags .skill-tag-with-icon{width:100%;justify-content:flex-start}.about{margin-bottom:112px}.about__content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:start}.about__description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-xl)}.about__visual{position:relative;display:flex;justify-content:center;align-items:center}.about__image{position:relative;z-index:2}.about__image .image-placeholder{width:400px;height:600px}.about__decorations{position:absolute;inset:0;pointer-events:none}.about__decorations .decoration{position:absolute;border:1px solid var(--color-border)}.about__decorations .decoration--1{width:84px;height:84px;top:-20px;left:-40px;z-index:1}.about__decorations .decoration--2{width:52px;height:52px;bottom:-30px;right:-30px;z-index:1}.contact{margin-bottom:112px}.contact__content{display:grid;grid-template-columns:1fr auto;gap:var(--spacing-3xl);align-items:start}.contact__description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;max-width:505px}.contact-card{border:1px solid var(--color-border);padding:var(--spacing-md);background-color:var(--color-background);min-width:204px}.contact-card__title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.contact-methods{display:flex;flex-direction:column;gap:var(--spacing-sm)}.contact-method{display:flex;align-items:center;gap:var(--spacing-xs);text-decoration:none;color:var(--color-text-secondary);font-size:var(--font-size-base)}.contact-method:hover{color:var(--color-text-primary)}.footer{margin-top:var(--spacing-3xl);padding:var(--spacing-xl) 0}.footer__divider{height:1px;background-color:var(--color-border);margin-bottom:var(--spacing-xl)}.footer__content{max-width:1366px;margin:0 auto;padding-left:171px;padding-right:var(--spacing-lg);display:flex;justify-content:space-between;align-items:start;margin-bottom:var(--spacing-2xl)}.footer__brand{display:flex;flex-direction:column;gap:var(--spacing-md)}.footer__logo{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:nowrap}.footer__email{color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-base);margin-left:var(--spacing-sm);display:inline-flex;align-items:center;white-space:nowrap}.footer__email:hover{color:var(--color-text-primary)}.footer__tagline{font-size:var(--font-size-base);color:var(--color-text-primary);margin-top:var(--spacing-md)}.footer__social-title{font-size:var(--font-size-2xl);font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.footer__social-icons{display:flex;gap:var(--spacing-sm)}.footer__copyright{text-align:center;font-size:var(--font-size-base);color:var(--color-text-secondary)}.page-title{padding:var(--spacing-2xl) 0 var(--spacing-xl) 0}.page-title__content{max-width:1024px}.page-title__heading{font-size:var(--font-size-3xl);font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-md);display:flex;align-items:center}.page-title__description{font-size:var(--font-size-base);color:var(--color-text-secondary)}.page-loader{display:flex;justify-content:center;align-items:center;height:200px}.loader-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.projects-complete,.projects-small{margin-bottom:112px}.projects__grid--full,.projects__grid--small{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);max-width:1024px}.project-card--small{height:auto}.project-image--small{height:320px}.about-full{margin-bottom:112px}.skills__grid--full{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md);max-width:1024px}.fun-facts{margin-bottom:112px}.fun-facts__content{display:grid;grid-template-columns:1fr auto;gap:var(--spacing-3xl);align-items:start;max-width:1024px}.fun-facts__list{display:flex;flex-direction:column;gap:var(--spacing-md)}.fun-fact{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-base);color:var(--color-text-secondary)}.fun-fact:before{content:"▶";color:var(--color-primary);font-size:var(--font-size-sm)}.fun-facts__visual{display:flex;align-items:center;justify-content:center}.fun-facts__logo{opacity:.1}.contact-full{margin-bottom:112px}.contact__cards{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.social-media{margin-bottom:112px}.social-media__links{display:flex;gap:var(--spacing-lg);flex-wrap:wrap}.social-media__link{display:flex;align-items:center;gap:var(--spacing-sm);text-decoration:none;color:var(--color-text-secondary);font-size:var(--font-size-base);transition:color .2s ease}.social-media__link:hover{color:var(--color-text-primary)}:root{--ease-premium: cubic-bezier(.23, 1, .32, 1);--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55);--ease-smooth: cubic-bezier(.4, 0, .2, 1);--glow-primary: 0 0 20px rgba(199, 120, 221, .4);--glow-intense: 0 0 40px rgba(199, 120, 221, .6)}@keyframes codeBlink{0%,80%{opacity:1;transform:translate(-50%,-50%) scale(1);color:var(--color-primary);text-shadow:0 0 10px rgba(199,120,221,.6)}90%{opacity:.7;transform:translate(-50%,-50%) scale(1.05);color:var(--color-accent);text-shadow:0 0 15px rgba(199,120,221,.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1);color:var(--color-primary);text-shadow:0 0 10px rgba(199,120,221,.6)}}@keyframes codeGlow{0%{transform:translate(-50%,-50%) scale(1);opacity:.3}to{transform:translate(-50%,-50%) scale(1.2);opacity:.1}}@keyframes codeExpand{0%{transform:translate(-50%,-50%) scale(.8);letter-spacing:2px}50%{transform:translate(-50%,-50%) scale(1.1);letter-spacing:0px}to{transform:translate(-50%,-50%) scale(1);letter-spacing:1px}}@keyframes codeExpandGlow{0%{transform:translate(-50%,-50%) scale(.8);opacity:.1}50%{transform:translate(-50%,-50%) scale(1.3);opacity:.4}to{transform:translate(-50%,-50%) scale(1.2);opacity:.2}}@keyframes codeExecute{0%{transform:translate(-50%,-50%) scale(1)}30%{transform:translate(-50%,-50%) scale(1.2)}60%{transform:translate(-50%,-50%) scale(.9)}to{transform:translate(-50%,-50%) scale(1)}}@keyframes codeExecuteGlow{0%{transform:translate(-50%,-50%) scale(1);opacity:.2}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.6}to{transform:translate(-50%,-50%) scale(1.2);opacity:0}}@keyframes codeTrailFade{0%{transform:scale(1);opacity:.8;background:#c778dd99}to{transform:scale(0);opacity:0;background:transparent}}@keyframes particleFloat{0%{transform:translate(0)}to{transform:translate(-200px,-200px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes glow{0%,to{box-shadow:0 0 5px #c778dd4d}50%{box-shadow:0 0 20px #c778dd99}}@keyframes textReveal{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes textGlow{0%{text-shadow:0 0 10px rgba(199,120,221,.5)}to{text-shadow:0 0 20px rgba(199,120,221,.8),0 0 30px rgba(199,120,221,.4)}}@keyframes skillsLineGlow{0%{opacity:.5;width:200px}to{opacity:1;width:300px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%,to{opacity:.8;filter:drop-shadow(0 0 5px rgba(199,120,221,.3))}50%{opacity:1;filter:drop-shadow(0 0 15px rgba(199,120,221,.6))}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes dividerPulse{0%,to{opacity:.5;transform:translate(-50%) scaleX(1)}50%{opacity:1;transform:translate(-50%) scaleX(1.5)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes statusPulse{0%,to{transform:scale(1);box-shadow:0 0 #c778ddb3}50%{transform:scale(1.1);box-shadow:0 0 0 10px #c778dd00}}@keyframes codeGlitch{0%,90%,to{transform:translate(0);filter:hue-rotate(0deg)}10%{transform:translate(-2px,2px);filter:hue-rotate(90deg)}20%{transform:translate(2px,-2px);filter:hue-rotate(180deg)}30%{transform:translate(-2px,-2px);filter:hue-rotate(270deg)}40%{transform:translate(2px,2px);filter:hue-rotate(360deg)}}@keyframes decorationFloat{0%,to{transform:translateY(0) rotate(0);border-color:var(--color-border)}25%{transform:translateY(-10px) rotate(90deg);border-color:var(--color-primary)}50%{transform:translateY(-20px) rotate(180deg);border-color:var(--color-accent)}75%{transform:translateY(-10px) rotate(270deg);border-color:var(--color-primary)}}@keyframes dotsRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes footerGlow{0%,to{opacity:.3}50%{opacity:1}}@keyframes rainbowBackground{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}@keyframes buttonShine{0%{left:-100%}to{left:100%}}@keyframes cardHover{0%{transform:translateY(0) scale(1)}to{transform:translateY(-10px) scale(1.02)}}@keyframes iconBounce{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-5px) scale(1.1)}}.social-sidebar{position:fixed;left:var(--spacing-md);top:0;display:flex;flex-direction:column;align-items:center;z-index:50;transition:all .3s var(--ease-smooth)}.social-line{width:1px;height:191px;background-color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.social-icons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.social-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--color-text-secondary);transition:all .3s var(--ease-premium);border-radius:4px;position:relative}.social-icon:hover{color:var(--color-text-primary);background:#c778dd1a;transform:translate(2px)}@media (max-width: 320px){.social-sidebar{display:none}}@media (min-width: 321px) and (max-width: 767px){.social-sidebar{display:none}}@media (min-width: 768px) and (max-width: 1023px){.social-sidebar{left:var(--spacing-sm)}.social-icon{width:36px;height:36px}.header__content,.main{padding-left:40px}}@media (min-width: 1024px){.social-sidebar{left:var(--spacing-md)}.social-icon{width:32px;height:32px}}.main{margin-top:61px;max-width:1366px;margin-left:auto;margin-right:auto;padding-left:60px;padding-right:var(--spacing-lg)}@media (max-width: 767px){.main{padding-left:var(--spacing-md);padding-right:var(--spacing-md);margin-bottom:0}.header__content{padding-left:var(--spacing-md);padding-right:var(--spacing-md)}}.hero{padding:63px 0 112px;margin-bottom:0}.hero__content{display:flex;justify-content:space-between;align-items:flex-start;gap:30px}@media (max-width: 767px){.hero{padding:var(--spacing-xl) 0 var(--spacing-3xl) 0}.hero__content{flex-direction:column;gap:var(--spacing-xl);text-align:center}.hero__visual{flex:none;max-width:100%;align-self:center}.hero__text{max-width:100%;padding-top:0;align-items:center}.hero__title{font-size:var(--font-size-2xl);text-align:center}}@media (min-width: 768px) and (max-width: 1023px){.hero__content{gap:var(--spacing-lg)}.hero__visual{flex:0 0 350px;max-width:350px}}@media (max-width: 767px){html,body{overflow-x:hidden;width:100%}.main{width:100%;padding-left:var(--spacing-md);padding-right:var(--spacing-md);margin-left:0;margin-right:0;margin-bottom:0;text-align:center;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.header{width:100%}.header__content{width:100%;padding-left:var(--spacing-md);padding-right:var(--spacing-md);margin:0;box-sizing:border-box}.hero{width:100%;padding-left:0;padding-right:0;text-align:center}.navigation{display:none}pre,code,.code-snippet,.code-block-container{text-align:center;margin:0 auto;display:block}pre code,.code-block{text-align:left;display:inline-block}.hero__content,.skills__content,.about__content,.contact__content,.fun-facts__content{grid-template-columns:1fr;gap:var(--spacing-lg)}.projects__grid,.projects__grid--full,.projects__grid--small,.skills__grid,.skills__grid--full{grid-template-columns:1fr}.footer__content{flex-direction:column;gap:var(--spacing-lg);text-align:center;padding-left:var(--spacing-md);padding-right:var(--spacing-md)}.contact__cards,.social-media__links{flex-direction:column}.not-found__content{grid-template-columns:1fr;gap:var(--spacing-xl);text-align:center}.not-found__visual{height:300px;order:2}.not-found__code{font-size:80px}.not-found__text{order:1}.not-found__actions{justify-content:center}.not-found__links{align-items:center}}@media (min-width: 768px) and (max-width: 1023px){.projects__grid,.projects__grid--full,.projects__grid--small,.skills__grid,.skills__grid--full{grid-template-columns:repeat(2,1fr)}.not-found__code{font-size:100px}.not-found__visual{height:350px}}@media (min-width: 1024px){.hero__title{font-size:32px}.projects__grid{grid-template-columns:repeat(3,1fr)}.skills__grid{grid-template-columns:repeat(2,1fr)}.projects__grid--full,.projects__grid--small,.skills__grid--full{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1440px){.main,.header__content{padding-left:60px;padding-right:var(--spacing-lg)}.footer__content{padding-left:171px;padding-right:var(--spacing-lg)}}body:after{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(2px 2px at 20px 30px,rgba(199,120,221,.3),transparent),radial-gradient(2px 2px at 40px 70px,rgba(199,120,221,.2),transparent),radial-gradient(1px 1px at 90px 40px,rgba(199,120,221,.4),transparent),radial-gradient(1px 1px at 130px 80px,rgba(199,120,221,.2),transparent);background-repeat:repeat;background-size:200px 200px;animation:particleFloat 20s linear infinite;pointer-events:none;z-index:-1}.bg-decorations{position:fixed;inset:0;pointer-events:none;z-index:-1}.bg-decoration{position:absolute;border:1px solid var(--color-border)}.bg-decoration--1{width:155px;height:155px;top:2125px;left:-77px}.bg-decoration--2{width:155px;height:155px;top:1160px;right:68px}.bg-decoration--3{width:91px;height:91px;top:672px;right:82px}.bg-decoration--dots-1{width:103px;height:103px;top:2294px;right:80px;background-image:url(/assets/images/dots-pattern.svg);background-size:contain;border:none}.bg-decoration--dots-2{width:103px;height:103px;top:2705px;left:-51px;background-image:url(/assets/images/dots-pattern.svg);background-size:contain;border:none}.bg-decoration--dots-3{width:84px;height:84px;top:955px;left:-46px;background-image:url(/assets/images/dots-pattern.svg);background-size:contain;border:none}.dots-pattern{position:absolute}.dots-pattern--hero{top:150px;right:-15px;z-index:1;width:84px;height:84px}.dots-pattern--skills{top:20px;left:20px;z-index:1}.dots-pattern--about{top:20px;right:20px;z-index:1}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--color-primary),var(--color-accent));border-radius:4px;transition:all .3s ease}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--color-accent),var(--color-primary));box-shadow:0 0 10px #c778dd80}.hero__decorations .decoration{transition:all .4s var(--ease-bounce)}.hero__decorations .decoration:hover{transform:rotate(45deg) scale(1.1);border-color:var(--color-primary);box-shadow:var(--glow-primary)}.hero__image:after{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent 30%,rgba(199,120,221,.1) 50%,transparent 70%);transform:translate(-100%);animation:shimmer 2s ease-in-out infinite}.section-header:after{content:"";position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:50px;height:2px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);animation:dividerPulse 2s ease-in-out infinite}.text-primary{color:var(--color-primary);position:relative;text-shadow:0 0 10px rgba(199,120,221,.5);animation:textGlow 3s ease-in-out infinite alternate}.text-secondary{color:var(--color-text-secondary)}.text-white{color:var(--color-text-primary)}.fade-in{opacity:0;transform:translateY(20px);animation:fadeIn .8s ease-out forwards}.slide-in-left{opacity:0;transform:translate(-30px);animation:slideInLeft .6s ease-out forwards}.slide-in-right{opacity:0;transform:translate(30px);animation:slideInRight .6s ease-out forwards}.fade-in-up{opacity:0;transform:translateY(30px);animation:fadeInUp .8s ease-out forwards}.mb-xs{margin-bottom:var(--spacing-xs)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.mb-2xl{margin-bottom:var(--spacing-2xl)}.mb-3xl{margin-bottom:var(--spacing-3xl)}.mt-xs{margin-top:var(--spacing-xs)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mt-2xl{margin-top:var(--spacing-2xl)}.mt-3xl{margin-top:var(--spacing-3xl)}.p-xs{padding:var(--spacing-xs)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.p-xl{padding:var(--spacing-xl)}.p-2xl{padding:var(--spacing-2xl)}.p-3xl{padding:var(--spacing-3xl)}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.glow-primary{box-shadow:var(--glow-primary)}.glow-intense{box-shadow:var(--glow-intense)}.hover-glow:hover{box-shadow:var(--glow-primary);transition:box-shadow .3s var(--ease-smooth)}.cursor-trail{position:fixed;width:6px;height:6px;border-radius:2px;pointer-events:none;z-index:9998;background:linear-gradient(45deg,rgba(199,120,221,.8),rgba(199,120,221,.4),transparent);animation:codeTrailFade .6s ease-out forwards;font-family:Fira Code,monospace}.hero__image,.project-image img,.about__image{will-change:transform}.nav-link,.social-icon,.project-card{will-change:transform,box-shadow}.cv-tabs__content{contain:layout style paint}.cv-content{contain:layout style}.layout{contain:layout style;will-change:auto}button,[role=button],a{touch-action:manipulation;-webkit-tap-highlight-color:transparent}input,textarea,select{will-change:auto}.cv-projects-list,.cv-certifications-grid,.cv-skills-grid{contain:layout style}.cv-tab,.cv-project-item,.cv-cert-item{will-change:transform;backface-visibility:hidden}.cv-tab:not(:hover),.cv-project-item:not(:hover),.cv-cert-item:not(:hover){will-change:auto}img{content-visibility:auto;contain-intrinsic-size:300px 200px;max-width:100%;height:auto;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}.preload-hint{font-display:swap}.page-container{contain:layout style paint}::selection{background:#c778dd4d;color:var(--color-text-primary)}::-moz-selection{background:#c778dd4d;color:var(--color-text-primary)}*:focus{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.cursor:before,.cursor:after{animation:none!important}.loader-spinner{animation:none}.binary-rain{animation:none!important}.not-found__code,.not-found__decorations .decoration,.dots-pattern--404{animation:none}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){body{-webkit-font-smoothing:subpixel-antialiased}}body.konami-active{animation:rainbowBackground 2s ease-in-out}.hero__cta,.about__cta{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.hero__cta:before,.about__cta:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);transition:left .6s ease}.hero__cta:hover:before,.about__cta:hover:before{left:100%}.hero__cta:hover,.about__cta:hover{transform:translateY(-2px);box-shadow:0 8px 25px #c778dd4d}.contact-card{position:relative;overflow:hidden;transition:all .4s var(--ease-premium)}.contact-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));transform:scaleX(0);transition:transform .4s var(--ease-premium)}.contact-card:hover:before{transform:scaleX(1)}.contact-card:hover{transform:translateY(-5px);box-shadow:var(--glow-intense)}.footer{position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);animation:footerGlow 3s ease-in-out infinite}.not-found{margin-bottom:112px;min-height:60vh;display:flex;flex-direction:column;justify-content:center}.not-found__content{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-3xl);align-items:center;max-width:1024px;margin:0 auto}.not-found__visual{position:relative;display:flex;align-items:center;justify-content:center;height:400px}.not-found__code{font-size:120px;font-weight:700;color:var(--color-primary);text-shadow:0 0 30px rgba(199,120,221,.5);animation:codeGlitch 3s ease-in-out infinite;position:relative;z-index:2}.not-found__decorations{position:absolute;inset:0;pointer-events:none}.not-found__decorations .decoration{position:absolute;border:1px solid var(--color-border);background:transparent;animation:decorationFloat 4s ease-in-out infinite}.not-found__decorations .decoration--1{width:80px;height:80px;top:20%;left:10%;animation-delay:0s}.not-found__decorations .decoration--2{width:60px;height:60px;top:60%;right:15%;animation-delay:1s}.not-found__decorations .decoration--3{width:40px;height:40px;bottom:20%;left:20%;animation-delay:2s}.dots-pattern--404{position:absolute;top:10%;right:10%;z-index:1;opacity:.3;animation:dotsRotate 8s linear infinite}.not-found__text{display:flex;flex-direction:column;gap:var(--spacing-lg)}.not-found__title{font-size:var(--font-size-3xl);font-weight:600;color:var(--color-text-primary);margin:0;display:flex;align-items:center}.not-found__description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin:0}.not-found__actions{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.not-found__suggestions{margin-top:var(--spacing-lg)}.not-found__suggestions h3{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.not-found__links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.not-found__link{display:flex;align-items:center;text-decoration:none;font-size:var(--font-size-base);color:var(--color-text-secondary);padding:var(--spacing-xs) 0;transition:all .2s ease;position:relative}.not-found__link:before{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--color-primary);transition:width .3s ease}.not-found__link:hover{color:var(--color-text-primary);transform:translate(5px)}.not-found__link:hover:before{width:100%}.not-found__link .nav-hash{color:var(--color-primary);margin-right:4px}*:focus{outline:2px solid #2563eb;outline-offset:2px}.skip-link{position:absolute;top:-40px;left:6px;background:#2563eb;color:#fff;padding:8px;text-decoration:none;border-radius:4px;z-index:1000}.skip-link:focus{top:6px}button,a,input,select,textarea{min-height:44px;min-width:44px}html{scroll-behavior:smooth}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
