@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;position:relative;background:var(--primary-white)}.hero-content{max-width:800px;text-align:center;padding:0 2rem}.hero-location{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--secondary-white);border:1px solid var(--gray-light);font-size:.9rem;margin-bottom:2rem;color:var(--gray-dark)}.hero-location svg{color:var(--primary-black)}.hero-title{font-size:4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}@media (max-width: 768px){.hero-title{font-size:3rem}}@media (max-width: 480px){.hero-title{font-size:2.5rem}}.hero-subtitle{font-size:1.25rem;color:var(--gray-dark);margin-bottom:1rem;font-weight:400}.hero-description{font-size:1.1rem;color:var(--gray-medium);margin-bottom:2.5rem;max-width:500px;margin-left:auto;margin-right:auto}.hero-cta{display:flex;gap:1rem;justify-content:center}@media (max-width: 480px){.hero-cta{flex-direction:column;gap:.75rem}}.cta-primary,.cta-secondary{padding:.875rem 2rem;text-decoration:none;font-weight:500;transition:all .3s ease;font-size:.95rem}.cta-primary{background:var(--primary-black);color:var(--primary-white);border:1px solid var(--primary-black)}.cta-primary:hover{background:transparent;color:var(--primary-black)}.cta-secondary{border:1px solid var(--primary-black);color:var(--primary-black);background:transparent}.cta-secondary:hover{background:var(--primary-black);color:var(--primary-white)}.hero-scroll{position:absolute;bottom:2rem;left:50%;transform:translate(-50%)}.hero-scroll a{color:var(--gray-medium);font-size:1.25rem;display:block;transition:color .3s ease}.hero-scroll a:hover{color:var(--primary-black)}.about{background:var(--primary-white)}.about-content{max-width:800px;margin:0 auto}.about-text{font-size:1.1rem;line-height:1.8;color:var(--gray-dark);margin-bottom:1.5rem}@media (max-width: 768px){.about-text{font-size:1rem}}.about-highlight{display:flex;justify-content:space-around;margin-top:3rem;padding:2rem 0;border-top:1px solid var(--gray-light);border-bottom:1px solid var(--gray-light)}@media (max-width: 480px){.about-highlight{flex-direction:column;gap:1.5rem;align-items:center}}.highlight-item{text-align:center}.highlight-number{display:block;font-size:2rem;font-weight:700;color:var(--primary-black);margin-bottom:.25rem}.highlight-label{font-size:.9rem;color:var(--gray-medium)}.projects{background:var(--secondary-white)}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}@media (max-width: 1024px){.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.projects-grid{grid-template-columns:1fr}}.project-card{background:var(--primary-white);border:1px solid var(--gray-light);cursor:pointer;transition:all .3s ease;overflow:hidden}.project-card:hover{border-color:var(--primary-black)}.project-image{position:relative;overflow:hidden;aspect-ratio:16/10}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.project-card:hover .project-image img{transform:scale(1.05)}.project-overlay{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:#fff;display:flex;justify-content:space-between;transform:translateY(100%);transition:transform .3s ease}.project-card:hover .project-overlay{transform:translateY(0)}.project-category,.project-year{font-size:.85rem;font-weight:500}.project-info{padding:1.5rem}.project-title{font-size:1.2rem;font-weight:600;margin-bottom:.5rem;letter-spacing:-.02em}.project-description{font-size:.95rem;color:var(--gray-dark);margin-bottom:1rem;line-height:1.5}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{padding:.2rem .6rem;background:var(--secondary-white);border:1px solid var(--gray-light);font-size:.8rem;color:var(--gray-dark)}.project-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);z-index:1000;display:flex;justify-content:center;align-items:center;padding:2rem}.modal-content{background:var(--primary-white);max-width:600px;width:100%;max-height:80vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:1rem;right:1rem;background:var(--primary-white);border:1px solid var(--gray-light);width:2rem;height:2rem;border-radius:50%;font-size:1.5rem;cursor:pointer;color:var(--primary-black);display:flex;align-items:center;justify-content:center;z-index:10}.modal-close:hover{background:var(--primary-black);color:var(--primary-white)}.modal-image{width:100%;height:250px;object-fit:cover}.modal-title{font-size:1.5rem;font-weight:700;margin:1.5rem 1.5rem .5rem;letter-spacing:-.02em}.modal-description{margin:0 1.5rem 1.5rem;color:var(--gray-dark);line-height:1.6}.modal-section{margin:0 1.5rem 1.5rem}.modal-section h4{font-size:1rem;font-weight:600;margin-bottom:.75rem}.modal-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.modal-features{padding-left:1.2rem}.modal-features li{margin-bottom:.4rem;color:var(--gray-dark);font-size:.95rem}.modal-meta{margin:1.5rem;padding-top:1rem;border-top:1px solid var(--gray-light);display:flex;gap:1rem;font-size:.9rem;color:var(--gray-dark)}.skills{padding:6rem 0;background:var(--primary-white);overflow:hidden;position:relative;min-height:100vh;opacity:1;visibility:visible}.skills-container{max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width: 768px){.skills{padding:4rem 0;min-height:auto}.skills-container{padding:0 1.5rem}}.skills-description{max-width:800px;margin:0 auto 3rem;text-align:center}.skills-description p{font-size:1.1rem;line-height:1.8;color:var(--gray-dark)}@media (max-width: 768px){.skills-description p{font-size:1rem}}.skills-category{margin:3rem 0 2rem}.category-title{display:flex;align-items:center;gap:1rem;font-size:1.3rem;font-weight:600;color:var(--primary-black);letter-spacing:-.02em;position:relative;overflow:hidden}.title-text{position:relative;display:inline-block;animation:slideInTitle .8s ease forwards}.title-line{flex:1;height:2px;background:linear-gradient(90deg,var(--primary-black),transparent);animation:expandLine 1s ease forwards;transform-origin:left}@keyframes slideInTitle{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes expandLine{0%{transform:scaleX(0)}to{transform:scaleX(1)}}.marquee-wrapper{position:relative;width:100%;margin:2rem 0 3rem;opacity:1}.marquee{width:100%;overflow:hidden;position:relative}.marquee-track{display:flex;gap:4rem;width:max-content;align-items:center;will-change:transform;transform:translateZ(0);backface-visibility:hidden;-webkit-font-smoothing:antialiased}.marquee-right-to-left{animation:scrollRightToLeft 60s linear infinite}.marquee-left-to-right{animation:scrollLeftToRight 65s linear infinite}@keyframes scrollRightToLeft{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scrollLeftToRight{0%{transform:translate(-50%)}to{transform:translate(0)}}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-gradient{position:absolute;top:0;bottom:0;width:150px;z-index:2;pointer-events:none}.marquee-gradient.left{left:0;background:linear-gradient(to right,var(--primary-white),transparent)}.marquee-gradient.right{right:0;background:linear-gradient(to left,var(--primary-white),transparent)}@media (max-width: 768px){.marquee-gradient{width:80px}.marquee-track{gap:3rem}}.skill-item{position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer}.skill-logo{width:48px;height:48px;opacity:.8;transition:all .3s cubic-bezier(.175,.885,.32,1.275);filter:grayscale(20%);display:block}.skill-item:hover .skill-logo{opacity:1;filter:grayscale(0%)}@media (max-width: 768px){.skill-logo{width:40px;height:40px}}.skill-tooltip{position:absolute;bottom:-2.5rem;left:50%;transform:translate(-50%);background:var(--primary-black);color:var(--primary-white);padding:.4rem 1rem;font-size:.8rem;font-weight:500;white-space:nowrap;border-radius:4px;opacity:0;visibility:hidden;transition:all .2s ease;pointer-events:none;z-index:10;box-shadow:0 4px 10px #0000001a;letter-spacing:.02em}.skill-tooltip:before{content:"";position:absolute;top:-4px;left:50%;transform:translate(-50%);border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid var(--primary-black)}.skill-item:hover .skill-tooltip{opacity:1;visibility:visible;bottom:-3rem}.skill-logo[style*="invert(1)"]{filter:invert(1) grayscale(20%)}.skill-item:hover .skill-logo[style*="invert(1)"]{filter:invert(1) grayscale(0%)}.skills-footer{text-align:center;margin-top:4rem}.skills-footer p{font-size:.95rem;color:var(--gray-medium);position:relative;display:inline-block;padding:0 1rem;animation:fadeInPulse 2s ease infinite}.skills-footer p:before,.skills-footer p:after{content:"";position:absolute;top:50%;width:30px;height:1px;background:var(--gray-light);animation:expandLine .8s ease forwards}.skills-footer p:before{right:100%}.skills-footer p:after{left:100%}@keyframes fadeInPulse{0%,to{opacity:.8}50%{opacity:1}}@media (max-width: 768px){.skills-footer p:before,.skills-footer p:after{width:20px}}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:.8;transform:scale(1)}}.skill-logo{animation:fadeIn .5s ease forwards}.marquee-track{-webkit-backface-visibility:hidden;-webkit-perspective:1000;-webkit-transform:translateZ(0);backface-visibility:hidden;perspective:1000;transform:translateZ(0)}.skills,.skills *{opacity:1!important;visibility:visible!important}@supports not (animation: scrollRightToLeft 60s linear infinite){.marquee-track{animation:none}}.contact{background:var(--secondary-white);padding:5rem 0}.contact-container{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:900px;margin:0 auto}@media (max-width: 768px){.contact-container{grid-template-columns:1fr;gap:2rem}}.contact-info{padding-right:2rem}@media (max-width: 768px){.contact-info{padding-right:0}}.info-title{font-size:1.5rem;font-weight:600;margin-bottom:1rem;color:var(--primary-black)}.info-description{color:var(--gray-dark);margin-bottom:2rem;line-height:1.6}.social-links{display:flex;flex-direction:column;gap:1rem}.social-link{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--primary-white);border:1px solid var(--gray-light);text-decoration:none;color:var(--primary-black);transition:all .3s ease}.social-link:hover{border-color:var(--primary-black)}.social-icon{font-size:1.5rem;color:var(--primary-black)}.social-detail{display:flex;flex-direction:column}.social-label{font-size:.85rem;color:var(--gray-dark)}.social-username{font-weight:500}.contact-form{background:var(--primary-white);padding:2rem;border:1px solid var(--gray-light)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem;color:var(--primary-black)}.form-input,.form-textarea{width:100%;padding:.875rem;background:var(--secondary-white);border:1px solid var(--gray-light);font-family:Inter,sans-serif;font-size:.95rem;transition:all .3s ease}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary-black);background:var(--primary-white)}.submit-btn{width:100%;padding:.875rem;background:var(--primary-black);color:var(--primary-white);border:1px solid var(--primary-black);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.submit-btn:hover{background:transparent;color:var(--primary-black)}.footer{background:var(--primary-black);color:var(--primary-white);padding:4rem 2rem 2rem;position:relative;overflow:hidden}.footer:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--primary-white),transparent)}.footer-container{max-width:1200px;margin:0 auto}.footer-top{display:grid;grid-template-columns:1.5fr 1fr;gap:4rem;margin-bottom:3rem}@media (max-width: 768px){.footer-top{grid-template-columns:1fr;gap:2rem}}.footer-brand{max-width:400px}.footer-logo{font-size:2rem;font-weight:800;letter-spacing:-.02em;margin-bottom:1rem;color:var(--primary-white);position:relative;display:inline-block}.footer-logo:after{content:"";position:absolute;bottom:-5px;left:0;width:40px;height:3px;background:var(--primary-white)}.footer-tagline{font-size:1rem;line-height:1.6;color:var(--gray-medium);margin-bottom:1.5rem}.footer-contact{display:flex;flex-direction:column;gap:.75rem}.footer-contact-item{display:flex;align-items:center;gap:.75rem;font-size:.95rem;color:var(--gray-medium)}.footer-contact-item svg{font-size:1.1rem;color:var(--primary-white)}.footer-contact-item a{color:var(--gray-medium);text-decoration:none;transition:color .3s ease}.footer-contact-item a:hover{color:var(--primary-white)}.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media (max-width: 480px){.footer-links{grid-template-columns:1fr;gap:1.5rem}}.footer-links-title{font-size:1.1rem;font-weight:700;margin-bottom:1.5rem;color:var(--primary-white);letter-spacing:-.02em;position:relative;display:inline-block}.footer-links-title:after{content:"";position:absolute;bottom:-5px;left:0;width:30px;height:2px;background:var(--primary-white)}.footer-links-list{list-style:none;padding:0}.footer-links-list li{margin-bottom:.75rem}.footer-links-list a{color:var(--gray-medium);text-decoration:none;font-size:.95rem;transition:all .3s ease;display:inline-block}.footer-links-list a:hover{color:var(--primary-white);transform:translate(5px)}.footer-social{display:flex;flex-direction:column;gap:.75rem}.footer-social-link{display:flex;align-items:center;gap:.75rem;color:var(--gray-medium);text-decoration:none;font-size:.95rem;transition:all .3s ease}.footer-social-link:hover{color:var(--primary-white);transform:translate(5px)}.footer-social-link svg{font-size:1.2rem}.footer-bottom{padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}@media (max-width: 768px){.footer-bottom{flex-direction:column;text-align:center}}.footer-copyright{color:var(--gray-medium);font-size:.9rem}.footer-made-with{display:flex;align-items:center;gap:.25rem;margin-top:.25rem}.footer-made-with svg{color:var(--primary-white);animation:heartbeat 1.5s ease infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.footer-back-to-top{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:transparent;border:1px solid var(--gray-medium);color:var(--primary-white);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease}.footer-back-to-top:hover{background:var(--primary-white);color:var(--primary-black);border-color:var(--primary-white)}.footer-back-to-top svg{font-size:1.1rem}.navigation{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .3s ease;background:transparent}.navigation.scrolled{background:var(--primary-white);box-shadow:0 2px 10px #0000001a}.navigation.hidden{pointer-events:none}.nav-container{max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center}@media (max-width: 768px){.nav-container{padding:1rem 1.5rem}}.nav-logo a{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;text-decoration:none;color:var(--primary-black);position:relative;padding:.5rem 0}.nav-logo a:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:2px;background:var(--primary-black);transform:scaleX(0);transform-origin:right;transition:transform .3s ease}.nav-logo a:hover:after{transform:scaleX(1);transform-origin:left}.nav-menu{display:flex;gap:2rem}@media (max-width: 768px){.nav-menu{display:none}}.nav-link{text-decoration:none;color:var(--primary-black);font-weight:500;font-size:1rem;position:relative;padding:.5rem 0}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:1px;background:var(--primary-black);transform:scaleX(0);transform-origin:right;transition:transform .3s ease}.nav-link:hover:after{transform:scaleX(1);transform-origin:left}.nav-toggle{display:none;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--primary-black);z-index:200;padding:.5rem;transition:transform .3s ease}.nav-toggle:hover{transform:scale(1.1)}@media (max-width: 768px){.nav-toggle{display:block}}.menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:149;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:320px;background:var(--primary-white);z-index:150;display:flex;flex-direction:column;box-shadow:-10px 0 30px #00000026;border-left:1px solid var(--gray-light)}@media (max-width: 480px){.mobile-menu{width:100%;max-width:none}}.mobile-menu-header{padding:1.5rem;border-bottom:1px solid var(--gray-light);display:flex;align-items:center;justify-content:space-between}.mobile-close-btn{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--gray-light);padding:.5rem 1rem;cursor:pointer;color:var(--primary-black);font-size:.9rem;font-weight:500;transition:all .3s ease}.mobile-close-btn:hover{background:var(--primary-black);color:var(--primary-white);border-color:var(--primary-black)}.mobile-close-btn svg{font-size:1.2rem}.mobile-logo{font-size:1.3rem;font-weight:800;letter-spacing:-.02em;color:var(--primary-black)}.mobile-menu-items{flex:1;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:.5rem}.mobile-nav-link{display:flex;align-items:center;gap:1rem;text-decoration:none;color:var(--primary-black);font-size:1.1rem;font-weight:500;padding:1rem;border-radius:0;transition:all .3s ease;position:relative;overflow:hidden;border-bottom:1px solid var(--gray-light)}.mobile-nav-link:last-child{border-bottom:none}.mobile-nav-link:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary-black);transform:translate(-100%);transition:transform .3s ease}.mobile-nav-link:hover{background:var(--secondary-white);padding-left:1.5rem}.mobile-nav-link:hover:before{transform:translate(0)}.link-number{font-size:.8rem;color:var(--gray-medium);font-weight:400;min-width:30px}.link-name{font-weight:600}.mobile-menu-footer{padding:1.5rem;border-top:1px solid var(--gray-light);background:var(--secondary-white)}.mobile-email{font-size:.9rem;color:var(--primary-black);font-weight:500;margin-bottom:.3rem}.mobile-location{font-size:.8rem;color:var(--gray-medium);display:flex;align-items:center;gap:.3rem}.nav-link.active{font-weight:700}.nav-link.active:after{transform:scaleX(1)}html{scroll-padding-top:80px}@media (max-width: 768px){html{scroll-padding-top:60px}}body.menu-open{overflow:hidden}.app{position:relative;min-height:100vh}.progress-bar{position:fixed;top:0;left:0;right:0;height:2px;background:var(--primary-black);transform-origin:0%;z-index:1000}main{max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width: 768px){main{padding:0 1.5rem}}@media (max-width: 480px){main{padding:0 1rem}}section{padding:5rem 0;position:relative}@media (max-width: 768px){section{padding:4rem 0}}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:3rem;letter-spacing:-.02em;position:relative}@media (max-width: 768px){.section-title{font-size:2rem;margin-bottom:2rem}}.section-title:after{content:"";position:absolute;bottom:-8px;left:0;width:50px;height:2px;background:var(--primary-black)}.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}.reveal-visible{opacity:1;transform:translateY(0)}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-black: #000000;--secondary-black: #111111;--light-black: #222222;--primary-white: #ffffff;--secondary-white: #f8f8f8;--gray-light: #eaeaea;--gray-medium: #a0a0a0;--gray-dark: #666666}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background-color:var(--primary-white);color:var(--primary-black);overflow-x:hidden;line-height:1.6}::selection{background:var(--primary-black);color:var(--primary-white)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--secondary-white)}::-webkit-scrollbar-thumb{background:var(--primary-black)}
