@font-face{font-family:Archivo;src:url(/assets/Archivo-Variable-B74ytzVH.woff2) format("woff2");font-weight:100 900;font-style:normal}@font-face{font-family:ArchivoItalic;src:url(/assets/Archivo-VariableItalic-D4YGNAeO.woff2) format("woff2");font-weight:100 900;font-style:italic}@font-face{font-family:ClashDisplay;src:url(/assets/ClashDisplay-Variable-Buk7cB_f.woff2) format("woff2");font-weight:100 900;font-style:normal}:root{font-size:16px;--font-title: "ClashDisplay", system-ui, sans-serif;--font-text: "Archivo", system-ui, sans-serif;--font-italic: "ArchivoItalic", system-ui, sans-serif;--negro: #000;--blanco: #fffef3;--negrolow: #0007;--blancolow: #fffee3;--grisclaro: #b0b0b0}*{margin:0;padding:0;border:0;box-sizing:border-box}*:before,*:after{box-sizing:border-box}body{font-family:var(--font-text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:transparent;color:var(--negro)}html{scroll-behavior:smooth}a{display:block}p a{display:inline}li{list-style-type:none}h1,h2,h3,h4,h5,h6,p,span,a,strong,blockquote,i,b,u,em{font-size:1em;font-weight:inherit;font-style:inherit;text-decoration:none;color:inherit}h1,h2,h3,h4,h5,h6{font-family:var(--font-title)}form,input,textarea,select,button,label{font-family:inherit;font-size:inherit;-webkit-hyphens:auto;hyphens:auto;background-color:transparent;display:flex;color:inherit}img,picture,video,iframe{max-width:100%;width:100%;display:flex;object-fit:cover;object-position:center center}.header__menu{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;height:60px;display:flex;justify-content:center;align-items:center;overflow:hidden;background-color:var(--menu-default-bg, var(--blancolow));transition:color .4s ease,background-color .4s ease}.header__menu:before{content:"";position:absolute;inset:0;background-color:var(--menu-bg);transform:translate(100%);transition:none;z-index:-1}.header__menu-active:before{animation:headerBgIn .6s ease-in-out forwards}.header__menu.header__menu-animating-out:before{animation:headerBgOut .4s ease-in-out forwards}.header__button{padding:1px 20px;display:inline-flex;align-items:center;font-family:var(--font-title);font-size:1.4em;font-weight:400;position:relative;transition:color .3s ease;z-index:1}.header__button:hover{font-weight:500}.header__button:after{content:"";position:absolute;bottom:-2px;width:100px;height:2px;left:50%;transform:translate(-50%);background-color:currentColor;transition:background-color .3s ease}.header__nav{position:fixed;inset:60px 0 0;z-index:999;display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:0;overflow-y:auto;-ms-overflow-style:none;scrollbar-width:none;opacity:0;transform:translate(60px);pointer-events:none;transition:background-color .4s ease,color .4s ease}.header__nav-active{opacity:1;transform:translate(0);pointer-events:auto;animation:menuIn .6s ease-in-out forwards}.header__nav::-webkit-scrollbar{display:none}.header__nav-list{width:100%;display:flex;flex-direction:column;align-items:center;gap:clamp(10px,2vh,20px);padding:60px 10px;text-align:end;margin:auto 0;flex:1;justify-content:center}.header__nav-item{width:min(85%,600px);position:relative}.header__nav-item:not(:last-child):after{content:"";position:absolute;bottom:-2px;left:50%;width:100%;height:2px;transform:translate(-50%);background-color:currentColor;transition:background-color .3s ease}.header__nav-link{padding-right:10px;font-family:var(--font-title);font-size:clamp(3em,6vw,5em);display:block}.header__nav-link:hover{font-weight:500}.header__footer{width:clamp(85%,90vw,95%);padding:20px clamp(15px,3vw,30px);margin-top:0;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-italic);font-weight:200;font-size:clamp(.8em,2vw,1.2em)}.header__footer-list{display:flex;margin-block-start:0em;margin-block-end:0em;padding-inline-start:0;align-items:center;gap:clamp(10px,2vw,20px)}.header__footer-link:hover{font-weight:400}@keyframes headerBgIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes headerBgOut{0%{transform:translate(0)}to{transform:translate(100%)}}.header__nav.header__nav-animating-out{animation:menuOut .4s ease-in-out forwards}@keyframes menuIn{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}@keyframes menuOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(60px)}}.header__nav-item{opacity:0;transform:translate(40px)}.header__nav-active .header__nav-item{animation:itemIn .6s ease-in-out forwards}.header__nav-active .header__nav-item:nth-child(1){animation-delay:.12s}.header__nav-active .header__nav-item:nth-child(2){animation-delay:.22s}.header__nav-active .header__nav-item:nth-child(3){animation-delay:.32s}.header__nav-active .header__nav-item:nth-child(4){animation-delay:.42s}@keyframes itemIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.header__nav.header__nav-animating-out .header__nav-item{animation:itemOut .3s ease-in-out forwards}@keyframes itemOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(40px)}}.header__nav-link{opacity:0}.header__nav-active .header__nav-link{animation:linkIn .6s ease-in-out forwards;animation-delay:.18s}@keyframes linkIn{0%{opacity:0}to{opacity:1}}.header__nav.header__nav-animating-out .header__nav-link{animation:linkOut .4s ease-in-out forwards}@keyframes linkOut{0%{opacity:1}to{opacity:0}}.header__footer{opacity:0;transform:translate(30px)}.header__nav-active .header__footer{animation:footerIn .6s ease-in-out forwards;animation-delay:.5s}@keyframes footerIn{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.header__nav.header__nav-animating-out .header__footer{animation:footerOut .4s ease-in-out forwards}@keyframes footerOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(30px)}}.home__container{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:clamp(40px,8vh,90px);padding:20px;background-color:var(--blancolow)}.home__title{width:min(95%,800px);text-align:center;opacity:0;transform:translateY(50px);transition:opacity .5s ease,transform .5s ease}.home__title--visible{opacity:1;transform:translateY(0)}.title__h1{margin-bottom:clamp(30px,5vh,50px);font-family:var(--font-title);font-size:clamp(2.5em,8vw,4.5em);line-height:.8;opacity:0;transform:translateY(50px);transition:opacity .5s ease,transform .5s ease;transition-delay:.1s}.title__h2{font-family:var(--font-title);font-weight:200;font-size:clamp(1.8em,5vw,3.2em);letter-spacing:4px;line-height:.8;opacity:0;transform:translateY(50px);transition:opacity .5s ease,transform .5s ease;transition-delay:.3s}.title__h2:last-of-type{letter-spacing:10px;transition-delay:.5s}.home__title--visible .title__h1,.home__title--visible .title__h2{opacity:1;transform:translateY(0)}.home__social{width:min(60%,600px);opacity:0;transform:translateY(50px);transition:opacity .5s ease,transform .5s ease}.home__social--visible{opacity:1;transform:translateY(0)}.social__list{display:flex;justify-content:center;gap:clamp(60px,10vw,130px)}.social__item{position:relative;opacity:0;transform:translateY(30px);transition:opacity .5s ease,transform .5s ease}.social__item:first-child{transition-delay:.6s}.social__item:last-child{transition-delay:.8s}.home__social--visible .social__item{opacity:1;transform:translateY(0)}.social__link{position:relative;padding:0 2px;font-family:var(--font-text);font-weight:200;font-size:clamp(1em,2vw,1.4em);color:var(--negro)}.social__link:before{content:attr(data-text);display:block;font-weight:400;height:0;overflow:hidden;visibility:hidden}.social__link:after{content:"";position:absolute;top:-2px;left:50%;width:70%;height:2px;background-color:var(--negro);transform:translate(-50%);transition:width .2s ease}.social__link:hover{font-weight:400}.social__link:hover:after{width:110%}@media(min-width:1440px){.home__container{gap:clamp(40px,10vh,120px)}.title__h1{margin-bottom:clamp(40px,6vh,60px)}}.logoloop{position:relative;overflow-x:hidden;--logoloop-gap: 32px;--logoloop-logoHeight: 28px;--logoloop-fadeColorAuto: #ffffff}.logoloop--scale-hover{padding-top:calc(var(--logoloop-logoHeight) * .1);padding-bottom:calc(var(--logoloop-logoHeight) * .1)}@media(prefers-color-scheme:dark){.logoloop{--logoloop-fadeColorAuto: #0b0b0b}}.logoloop__track{display:flex;width:max-content;will-change:transform;-webkit-user-select:none;user-select:none}.logoloop__list{display:flex;align-items:center}.logoloop__item{flex:0 0 auto;margin-right:var(--logoloop-gap);font-size:var(--logoloop-logoHeight);line-height:1}.logoloop__item:last-child{margin-right:var(--logoloop-gap)}.logoloop__node{display:inline-flex;align-items:center}.logoloop__item img{height:var(--logoloop-logoHeight);width:auto;display:block;object-fit:contain;image-rendering:-webkit-optimize-contrast;-webkit-user-drag:none;pointer-events:none;transition:transform .3s cubic-bezier(.4,0,.2,1)}.logoloop--scale-hover .logoloop__item{overflow:visible}.logoloop--scale-hover .logoloop__item:hover img,.logoloop--scale-hover .logoloop__item:hover .logoloop__node{transform:scale(1.2);transform-origin:center center}.logoloop--scale-hover .logoloop__node{transition:transform .3s cubic-bezier(.4,0,.2,1)}.logoloop__link{display:inline-flex;align-items:center;text-decoration:none;border-radius:4px;transition:opacity .2s ease}.logoloop__link:hover{opacity:.8}.logoloop__link:focus-visible{outline:2px solid currentColor;outline-offset:2px}.logoloop--fade:before,.logoloop--fade:after{content:"";position:absolute;top:0;bottom:0;width:clamp(24px,8%,120px);pointer-events:none;z-index:1}.logoloop--fade:before{left:0;background:linear-gradient(to right,var(--logoloop-fadeColor, var(--logoloop-fadeColorAuto)) 0%,rgba(0,0,0,0) 100%)}.logoloop--fade:after{right:0;background:linear-gradient(to left,var(--logoloop-fadeColor, var(--logoloop-fadeColorAuto)) 0%,rgba(0,0,0,0) 100%)}@media(prefers-reduced-motion:reduce){.logoloop__track{transform:translateZ(0)!important}.logoloop__item img,.logoloop__node{transition:none!important}}.projectCard__container{width:100%;max-width:330px;margin:0 auto;padding:1.5rem;color:var(--negro);background:var(--blancolow);border-radius:.375rem;transition:transform .3s ease,box-shadow .3s ease;overflow:hidden;font-family:var(--text);opacity:.9}.projectCard__container:hover{transform:translateY(-5px)}.projectCard__media{width:100%;height:185px;margin-bottom:.7rem;border-radius:3px;overflow:hidden;position:relative}.projectCard__media:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,transparent 60%,rgba(0,0,0,.35) 100%);pointer-events:none;z-index:1}.projectCard__image{width:100%;height:100%;object-fit:cover;filter:brightness(.85) contrast(1.05);transition:filter .3s ease}.projectCard__video{width:100%;height:100%;object-fit:cover}.projectCard__video.visible{display:block}.projectCard__video.hidden{display:none}.projectCard__title{font-family:var(--title);font-size:1.5rem;font-weight:300;margin-bottom:1rem;text-align:end}.projectCard__title:hover{font-weight:500}.projectCard__description{font-family:var(--text);font-size:.9rem;font-weight:400;line-height:1.5;margin-bottom:1.85rem;text-align:justify;height:6em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical}.projectCard__logoLoop{margin-bottom:40px}.projectCard__tech i{font-size:1.6rem;color:var(--negro);transition:all .3s ease}.projectCard__links{display:flex;align-items:center;justify-content:space-around}.projectCard__link{position:relative;padding:0 2px;font-weight:200;transition:font-weight .2s ease}.projectCard__link:before{content:attr(data-text);display:block;font-weight:400;height:0;overflow:hidden;visibility:hidden}.projectCard__link:after{content:"";position:absolute;top:-3px;left:50%;width:80%;height:1px;background-color:var(--negro);transform:translate(-50%);transition:width .2s ease}.projectCard__link:hover{font-weight:400}.projectCard__link:hover:after{width:110%}.projects__section{min-height:100dvh;padding:40px 20px;background-color:var(--negro);color:var(--blanco)}.projects__title{width:100%;padding-left:10%;margin-top:clamp(30px,5vh,60px);margin-bottom:clamp(80px,5vh,60px);font-size:clamp(2.5em,6vw,4em);text-align:left;opacity:0;transform:translate(-50px)}.projects__title--visible{animation:show-title .7s ease forwards}.projects__grid{width:80%;max-width:1000px;margin:0 auto;margin-top:3rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;justify-content:center;opacity:0;transform:translateY(50px)}.projects__grid--visible{animation:show-projects-content .7s ease forwards}@media(max-width:480px){.projects__grid{grid-template-columns:1fr}}@media(min-width:768px){.projects__title{padding-left:20%}}@media(min-width:1500px){.projects__title{padding-left:25%}}@keyframes show-projects-title{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes show-projects-content{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.about__section{min-height:100dvh;width:100%;padding:40px 20px;background-color:var(--negro);color:var(--blanco);overflow-x:hidden}.about__title{width:100%;padding-right:8%;margin-top:clamp(30px,5vh,60px);margin-bottom:clamp(80px,5vh,60px);font-size:clamp(2.5em,6vw,4em);text-align:right;opacity:0;transform:translate(50px)}.about__title--visible{animation:show-about-title .5s ease forwards}.about__container{width:min(90%,1000px);max-width:1400px;margin:0 auto;margin-top:3rem;display:flex;justify-content:center}.about__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-template-rows:auto auto auto;gap:2rem}.about__bio,.about__image-container{display:flex;align-items:center;opacity:0;transform:translateY(50px)}.about__bio--visible{animation:show-about-content .7s ease forwards}.about__image-container--visible{animation:show-about-content .7s ease forwards .1s}.about__image-container{justify-content:center;position:relative;overflow:hidden}.about__image-container:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;box-shadow:inset 0 0 50px #0009;pointer-events:none}.about__bio .about__text{font-size:1.3rem}.about__bio .about__text strong{font-weight:500}.about__image{max-width:100%;max-height:240px;width:auto;height:auto;object-fit:cover;transition:transform .3s ease,opacity .3s ease;opacity:.8;display:block;border-radius:2px;box-shadow:0 4px 8px #0000001a}.about__separator{grid-column:1 / -1;width:60%;height:2px;background-color:var(--blanco);margin:.5rem auto 0;opacity:.7;border-radius:1px}.about__skills{grid-column:1 / -1;display:flex;flex-direction:column;gap:2rem;margin-bottom:45px;margin-top:.8rem;opacity:0;transform:translateY(50px)}.about__skills--visible{animation:show-about-content .7s ease forwards .2s}.about__text{font-family:var(--font-title);font-size:1.1rem;font-weight:400;line-height:1.6;text-align:justify}.about__text strong{font-weight:600}.about__cv-download{grid-column:1 / -1;display:flex;justify-content:center;align-items:center;margin-bottom:70px;opacity:0;transform:translateY(30px)}.about__cv-download--visible{animation:show-about-content .7s ease forwards .1s}.about__download-button{background-color:var(--blancolow);color:var(--negro);padding:10px 20px;border-radius:2px;border:2px solid var(--blancolow)}.about__download-button:hover{background-color:var(--negro);color:var(--blanco)}@media(min-width:768px){.about__grid{width:70%}.about__image-container{justify-content:right}.about__title{padding-right:15%}}@media(min-width:1500px){.about__title{padding-right:25%}}@keyframes show-about-title{0%{opacity:0;transform:translate(50px)}to{opacity:1;transform:translate(0)}}@keyframes show-about-content{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.contact__section{min-height:100dvh;width:100%;padding:40px 20px;background-color:var(--blancolow);color:var(--negro);overflow-x:hidden}.contact__title{width:100%;padding-left:10%;margin-top:clamp(30px,5vh,60px);margin-bottom:clamp(80px,5vh,60px);font-size:clamp(2.5em,6vw,4em);text-align:left;opacity:0;transform:translate(-50px)}.contact__title--visible{animation:show-title .7s ease forwards}.contact__container{width:min(90%,1000px);margin:30px auto;display:flex;justify-content:center;align-items:center;width:100%}.contact__form{width:100%;max-width:600px;padding:10px;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:40px 40px 40px 1fr 50px;grid-template-areas:"subject subject" "name name" "email email" "message message" "button-container button-container";gap:30px;opacity:0;transform:translateY(50px)}.contact__form--visible{animation:show-contact-content 1s ease forwards}.contact__subject{grid-area:subject}.contact__name{grid-area:name}.contact__email{grid-area:email}.contact__message{grid-area:message;border-bottom:2px solid var(--negrolow);margin-bottom:3.6rem}.contact__char-counter{min-height:20px;margin-top:4px;margin-right:2px;display:flex;justify-content:flex-end;align-items:center;font-size:.85rem;color:var(--negrolow);font-family:var(--font-title);letter-spacing:.5px;-webkit-user-select:none;user-select:none}.contact__button-container{grid-area:button-container;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;margin-top:1rem}.contact__button{position:relative;padding:3px 15px;margin-top:20px;justify-content:center;align-items:center;justify-self:center;display:inline-block;min-height:40px;line-height:1.2;font-family:var(--font-title);font-size:2rem;letter-spacing:1.3px;background:transparent;border:none;color:var(--negro)}.contact__button:after{content:"";position:absolute;top:-2px;left:50%;width:65%;height:2px;background-color:var(--negro);transform:translate(-50%);transition:width .2s ease}.contact__button:hover{font-weight:500}.contact__button:hover:after{background-color:var(--negro)}.contact__button:hover:after{width:110%}.contact__button:active{background-color:var(--negro);color:var(--blancolow)}.contact__button:active:after{background-color:var(--blancolow)}.contact__subject,.contact__name,.contact__email{padding-left:10px;align-items:end;font-family:var(--font-title);border-bottom:2px solid var(--negrolow)}.contact__label{display:block;width:100%}.contact__label:focus-within{border-bottom:3px solid var(--negro)}.contact__form input{width:100%;font-size:1.2rem;letter-spacing:1px;outline:none;border:none;background:transparent}.contact__form textarea{width:100%;resize:none;max-height:200px;padding:10px;font-family:var(--font-title);font-size:1.2rem;outline:none;border:none;background:transparent}.contact__form input::placeholder,.contact__form textarea::placeholder{font-weight:300}.contact__form input:focus::placeholder,.contact__form textarea:focus::placeholder{color:transparent}.contact__notification{width:100%;max-width:400px;padding:12px;border-radius:4px;text-align:center;font-weight:500;animation:fadeIn .3s ease-in-out}.contact__notification--sucess,.contact__notification--error{background-color:var(--negro);color:var(--blanco)}@media(min-width:768px){.contact__title{padding-left:20%}}@media(min-width:1500px){.contact__title{padding-left:25%}}@keyframes show-title{0%{opacity:0;transform:translate(-50px)}to{opacity:1;transform:translate(0)}}@keyframes show-contact-content{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}body,a,button,input,i,textarea,select,[role=button],label{cursor:none}.custom-cursor{position:fixed;width:33px;height:33px;border-radius:50%;pointer-events:none;z-index:10000;mix-blend-mode:difference;background-color:var(--blancolow);transform:translate(-50%,-50%);transition:transform .1s ease,width .2s ease,height .2s ease}.custom-cursor.hover{width:60px;height:60px;mix-blend-mode:difference}.custom-cursor.over-media{mix-blend-mode:normal;background-color:#ffffff4d}
