*{margin:0;padding:0;box-sizing:border-box;overflow-wrap:break-word;font-family:Inter,sans-serif;line-height:calc(1em + .5rem);outline-offset:.35rem;outline-width:.125rem;outline-color:#1b1b1b}html{scroll-behavior:smooth;scrollbar-color:#3a3a3a #f5f5f5;scrollbar-width:thin}body,html{min-width:-moz-fit-content;min-width:fit-content}body::-webkit-scrollbar{width:.75rem}body::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#1b1b1b,#3a3a3a);border:1px solid #f5f5f5;border-radius:2rem}body::-webkit-scrollbar-track{background-color:#f5f5f5}a{text-decoration:none;display:block}a:focus-visible{outline-style:dashed}p{line-height:calc(1em + .75rem)}li{list-style-type:none}button{border:none;display:block}button *{pointer-events:none}button:focus-visible{outline-style:dashed}:after,:before{box-sizing:border-box}.about__inner-container,.education__inner-container,.footer__inner-container,.header__inner-container,.hero__inner-container,.projects__inner-container,.skills__inner-container,.timeline__inner-container{max-width:1250px;padding:0 4.5rem;margin:0 auto}@media only screen and (max-width:1040px){.about__inner-container,.education__inner-container,.footer__inner-container,.header__inner-container,.hero__inner-container,.projects__inner-container,.skills__inner-container,.timeline__inner-container{padding-inline:2.5rem}}@media only screen and (max-width:920px){.about__inner-container,.education__inner-container,.footer__inner-container,.header__inner-container,.hero__inner-container,.projects__inner-container,.skills__inner-container,.timeline__inner-container{padding-inline:0}}.about,.education,.footer,.header,.hero,.projects,.skills,.timeline{padding:0 2rem}@media only screen and (max-width:920px){.about,.education,.footer,.header,.hero,.projects,.skills,.timeline{padding:0 1.5rem}}.about__avatar-container:before,.about__avatar-img,.btn--download:before,.btn--show-more:before,.education__avatar-container:before,.education__avatar-img,.hero__avatar-container:before,.hero__avatar-img{width:100%;height:100%}.about__title,.education__title,.projects__title,.skills__title,.timeline__title{flex-shrink:0;font-weight:600;font-size:2.25rem;transition:color .35s,background-color .35s}@media only screen and (max-width:1040px){.about__title,.education__title,.projects__title,.skills__title,.timeline__title{font-size:2rem}}@media only screen and (max-width:640px){.about__title,.education__title,.projects__title,.skills__title,.timeline__title{flex-shrink:1;padding:0;margin:0 auto;text-align:center}}.navbar__list{display:flex;justify-content:center;align-items:center;gap:1.25rem}.navbar__list-item{flex-shrink:0;white-space:nowrap}.navbar__link{position:relative;padding:.25rem .5rem;color:#131313;font-weight:500}.navbar__link:after{content:"";position:absolute;top:95%;right:0;width:0;height:.125rem;border-radius:2rem;background:linear-gradient(90deg,transparent,#131313);transition:width .5s}.navbar__link:hover:after{width:100%;left:0}.navbar__link:focus-visible{outline-style:dashed}.navbar__link:focus-visible:after{width:100%;left:0}.btn--theme__dark-icon,.btn--theme__light-icon{opacity:0;width:1.25rem;height:1.25rem;animation:show-theme-icon .35s forwards}.btn{cursor:pointer;font-size:1rem;border-radius:.25rem;background-color:transparent;transition:fill .35s,box-shadow .35s,background-color .35s,color .35s,stroke .35s,border-color .35s}.btn--download{position:relative;outline-color:transparent}.btn--download__content{display:block;position:relative;background-color:#1b1b1b;color:#f5f5f5;border-radius:.25rem;border:1px solid transparent;transition:.35s;padding:.675rem .95rem;font-weight:500}.btn--download:before{content:"";position:absolute;left:0;top:0;background-color:#1b1b1b;border-radius:.25rem;transition:.35s}.btn--download:focus-visible .btn--download__content,.btn--download:hover .btn--download__content{background-color:#f5f5f5;color:#1b1b1b;border-color:#1b1b1b;transform:translate(-.3rem,-.3rem)}.btn--download:active .btn--download__content{transform:translate(0)}.btn--theme{display:flex;justify-content:center;align-items:center;gap:0;padding:.45rem;border-radius:50%;flex-shrink:0}.btn--theme--light{background-color:#131313}.btn--theme--dark{background-color:#f5f5f5}.btn--theme__light-icon{fill:#f5f5f5;stroke:#f5f5f5}.btn--theme__dark-icon{fill:#131313;stroke:#131313}.btn--show-more{position:relative;outline-color:transparent}.btn--show-more__content{display:block;position:relative;background-color:#1b1b1b;color:#f5f5f5;border-radius:.25rem;border:1px solid transparent;transition:.35s;display:flex;justify-content:center;align-items:center;gap:.25rem;padding:.675rem .5rem .676rem .95rem;font-weight:500}.btn--show-more:before{content:"";position:absolute;left:0;top:0;background-color:#1b1b1b;border-radius:.25rem;transition:.35s}.btn--show-more:focus-visible .btn--show-more__content,.btn--show-more:hover .btn--show-more__content{background-color:#f5f5f5;color:#1b1b1b;border-color:#1b1b1b;transform:translate(-.3rem,-.3rem)}.btn--show-more:active .btn--show-more__content{transform:translate(0)}.btn--show-more__icon{height:1.5rem;width:1.5rem;fill:#f5f5f5;transition:.35s}.btn--show-more:focus-visible .btn--show-more__icon,.btn--show-more:hover .btn--show-more__icon{fill:#1b1b1b}.btn--hamburger{padding:.5rem;display:none}@media only screen and (max-width:920px){.btn--hamburger{display:block}}.btn--hamburger:focus-visible,.btn--hamburger:hover{box-shadow:0 0 0 1px #131313}.btn--hamburger:focus-visible .btn--hamburger__bar:last-child,.btn--hamburger:focus-visible .btn--hamburger__bar:nth-child(2),.btn--hamburger:hover .btn--hamburger__bar:last-child,.btn--hamburger:hover .btn--hamburger__bar:nth-child(2){width:100%}.btn--hamburger__bars{display:flex;justify-content:center;align-items:flex-start;flex-direction:column;gap:.3rem}.btn--hamburger__bar{height:.125rem;width:2rem;flex-shrink:0;background-color:#131313;border-radius:1rem;transition:.35s}.btn--hamburger__bar:nth-child(2){width:75%}.btn--hamburger__bar:last-child{width:50%}.btn--hamburger--dark:focus-visible,.btn--hamburger--dark:hover{box-shadow:0 0 0 1px #f5f5f5}.btn--hamburger--dark:focus-visible{outline-color:#f5f5f5}.btn--scrolltop{display:flex;justify-content:center;align-items:center;gap:0;position:fixed;right:1.5rem;bottom:1.5rem;width:2.5rem;height:2.5rem;border:1px solid #f5f5f5;background:#131313;border-radius:50%;transform:translateY(calc(100% + 2.5rem));opacity:75%;transition:background-color .35s,border-color .35s,box-shadow .35s,opacity .35s,transform .5s}.btn--scrolltop:hover{opacity:100%}.btn--scrolltop--show{transform:translateY(0)}.btn--scrolltop__icon{fill:#f5f5f5;height:1.5rem;width:1.5rem;transition:fill .35s}@keyframes show-theme-icon{0%{opacity:0}to{opacity:100%}}.side-links{display:flex;justify-content:center;align-items:center;flex-direction:column-reverse;gap:1.25rem;position:absolute;left:0;top:100%;transform:translateY(-100%)}@media only screen and (max-width:920px){.side-links{display:none}}.side-links__bar{display:block;width:1px;height:6rem;background:#1b1b1b}.side-links__list{display:flex;justify-content:center;align-items:center;flex-direction:column-reverse;gap:2rem}.side-links__link{display:flex;transition:transform .35s}.side-links__link:focus-visible,.side-links__link:hover{transform:translateY(-20%) scale(1.2)}.side-links__icon{width:1.35rem;height:1.35rem;transition:fill .35s}.project{display:none}.project--visible{display:block}.project__skew{display:flex;justify-content:space-between;flex-direction:column;gap:1.5rem;height:100%;border-radius:.75rem;padding:1.5rem;transition:box-shadow .35s;box-shadow:.5rem .5rem 0 .125rem #1b1b1b,0 0 0 .125rem #1b1b1b,.5rem .5rem 1rem .25rem rgba(0,0,0,.22);overflow:hidden;position:relative}.project__skew:hover:after{left:150%;opacity:1;transition:left 1.25s ease-in-out}.project__skew:after{content:"";position:absolute;top:50%;left:-35%;height:125%;width:2rem;background-color:hsla(0,0%,100%,.9);filter:blur(70px);transform:translateY(-50%) rotate(15deg);opacity:0;pointer-events:none}.project__link-banner{max-height:268px;height:calc(10vw + 120px);border-radius:.5rem;overflow:hidden;border:1px solid rgba(27,27,27,.6);transition:border-color .35s}.project__link-banner:focus-visible .project__banner-img,.project__link-banner:hover .project__banner-img{transform:scale(1.1)}@media only screen and (max-width:920px){.project__link-banner{flex-shrink:0;max-height:none;height:auto}}.project__banner-img{width:100%;height:100%;object-position:top center;object-fit:cover;transform-origin:center top;transition:transform .35s}.project__content{display:flex;justify-content:center;align-items:flex-start;flex-direction:column;gap:.25rem}.project__link-title{position:relative;font-weight:600;color:#1b1b1b;font-size:1.75rem;text-decoration:underline;-webkit-text-decoration-color:transparent;text-decoration-color:transparent;transition:color .35s,-webkit-text-decoration-color .35s;transition:text-decoration-color .35s,color .35s;transition:text-decoration-color .35s,color .35s,-webkit-text-decoration-color .35s}.project__link-title:focus-visible,.project__link-title:hover{-webkit-text-decoration-color:#1b1b1b;text-decoration-color:#1b1b1b}@media only screen and (max-width:1040px){.project__link-title{font-size:1.5rem}}.project__description{color:#131313;margin-bottom:.5rem;transition:color .35s}.project__tech-list{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.project__tech-item{color:#3a3a3a;font-size:.75rem;font-weight:500;padding:.125rem .5rem;border-radius:.25rem;border:1px solid #929292;letter-spacing:1px;transition:color .35s,border-color .35s,font-weight .35s}.project__external-links{display:flex;align-items:center;gap:1rem}.project__ext-link{display:flex;justify-content:center;align-items:center;gap:0;padding:.5rem;border-radius:.25rem;transition:transform .35s,box-shadow .35s}.project__ext-link:focus-visible,.project__ext-link:hover{transform:scale(1.125);box-shadow:inset 0 0 0 1px #1b1b1b}.project__ext-icon{height:1.25rem;width:1.25rem;fill:#1b1b1b;transition:fill .35s}.project__ext-link--disabled{cursor:not-allowed;opacity:.6}.project__ext-icon--disabled{opacity:.6}.stacks{overflow:hidden}.stacks__tech-list{padding:1rem;display:grid;grid-template-rows:repeat(2,1fr);grid-gap:2rem;gap:2rem}.stacks__tech-list:hover .stacks__sub-list{animation-play-state:paused}.stacks__sub-list{display:flex;align-items:center;gap:2rem;animation:slide-left 30s linear infinite}.stacks__sub-list:last-child{animation:slide-right 30s linear infinite;transform:translateX(-127.5rem)}.stacks__tech-item{padding:1rem;border-radius:.5rem;height:6.5rem;width:6.5rem;background-color:#131313;box-shadow:.25rem .25rem .5rem rgba(0,0,0,.569);transition:.35s}.stacks__tech-item:focus-visible,.stacks__tech-item:hover{transform:scale(1.15);box-shadow:.25rem .25rem .75rem rgba(0,0,0,.569)}.stacks__tech-icon{width:100%;height:100%;pointer-events:none}@keyframes slide-left{to{transform:translateX(-127.5rem)}}@keyframes slide-right{to{transform:translateX(0)}}.title-marker{display:flex;justify-content:center;align-items:center;gap:1rem;position:relative;width:-moz-fit-content;width:fit-content;margin-bottom:1rem}@media only screen and (max-width:640px){.title-marker{margin:0 auto 1.5rem}}.title-marker__marker{display:block;border-radius:2rem;background-color:#fff;box-shadow:0 0 .25rem #fff;height:.125rem;width:4rem;transition:.35s}@media only screen and (max-width:640px){.title-marker__marker{position:absolute;left:0;top:calc(100% + .25rem);width:100%}}.title-marker__content{display:block;color:#fff;font-weight:500;font-size:1rem}.overlay{display:none;position:fixed;z-index:1;left:0;top:0;width:100vw;height:100vh;-webkit-backdrop-filter:blur(.125rem);backdrop-filter:blur(.125rem)}.overlay--open{display:none;opacity:100%}@media only screen and (max-width:920px){.overlay--open{display:block}}.marker--html{background-color:#e34f26;box-shadow:0 0 .25rem #e34f26}.marker--css{background-color:#4b84b3;box-shadow:0 0 .25rem #4b84b3}.marker--js{background-color:#f0db4f;box-shadow:0 0 .25rem #f0db4f}.marker--ts{background-color:#007acc;box-shadow:0 0 .25rem #007acc}.marker--sass{background-color:#cb6297;box-shadow:0 0 .25rem #cb6297}.marker--react{background-color:#00d8ff;box-shadow:0 0 .25rem #00d8ff}.marker--node{background-color:#8cc84b;box-shadow:0 0 .25rem #8cc84b}.marker--express{background-color:#c9c9c9;box-shadow:0 0 .25rem #c9c9c9}.marker--tailwind{background-color:#16a5be;box-shadow:0 0 .25rem #16a5be}.marker--next{background-color:#fff;box-shadow:0 0 .25rem #fff}.marker--git{background-color:#de3636;box-shadow:0 0 .25rem #de3636}.marker--github{background-color:#a8594e;box-shadow:0 0 .25rem #a8594e}.marker--webpack{background-color:#8ed6fb;box-shadow:0 0 .25rem #8ed6fb}.marker--mongodb{background-color:#59bd46;box-shadow:0 0 .25rem #59bd46}.marker--mysql{background-color:#fff;box-shadow:0 0 .25rem #fff}.brand{display:flex;justify-content:center;align-items:center;gap:0;flex-shrink:0;height:3.5rem;width:3.5rem;border-radius:50%;color:#fff;font-weight:600;font-size:1.25rem;transition:background-color .35s,border .35s}.header{position:fixed;z-index:2;width:100vw;-webkit-backdrop-filter:blur(.25rem);backdrop-filter:blur(.25rem);background-color:hsla(0,0%,96%,.8);transition:transform .35s,box-shadow .35s,background-color .35s}.header--shaded{box-shadow:0 1px .5rem hsla(0,0%,7%,.5)}.header--hidden{transform:translateY(-101%);box-shadow:none}.header__inner-container{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 0;transition:padding .35s}@media only screen and (max-width:920px){.header__inner-container{padding:.5rem 0}}.header__inner-container--thin{padding:.5rem 0}@media only screen and (max-width:920px){.header__nav-box{position:absolute;left:0;top:0;visibility:hidden;opacity:0;z-index:1;height:100vh;width:100%;padding:1.5rem;background:linear-gradient(180deg,rgba(27,27,27,.5),transparent);transition:visibility .5s,opacity .5s}}.header__nav-box--open{opacity:100%;visibility:visible}.header__navbar{flex-shrink:0}@media only screen and (max-width:920px){.header__navbar{box-shadow:.25rem .25rem .75rem rgba(0,0,0,.424);background-color:#1b1b1b;border-radius:.75rem;padding:.5rem;transform:translateY(-100%);transition:background-color .35s,transform .5s,padding .5s .35s}.header__navbar--open{padding:3rem .5rem .5rem;transform:translateY(0)}.header__nav-list{position:relative;flex-direction:column;background-color:#f5f5f5;transition:background-color .35s;border-radius:.75rem;padding:2rem}}.header__btn-close{position:absolute;left:calc(100% - 1.5rem);top:.6rem;display:none;transform:translateX(-50%)}.header__btn-close:focus-visible,.header__btn-close:hover{box-shadow:0 0 0 1px #f5f5f5;outline-color:#f5f5f5}@media only screen and (max-width:920px){.header__btn-close{display:flex}}.header__close-icon{fill:#f5f5f5;height:1.75rem;width:1.75rem;transition:.35s}.hero{background-color:#f5f5f5;transition:background-color .35s;height:100vh}@media only screen and (max-width:920px){.hero{height:auto;min-height:100vh}}.hero__inner-container{display:flex;justify-content:center;align-items:center;gap:0;position:relative;height:100%}@media only screen and (max-width:920px){.hero__inner-container{min-height:100vh}}.hero__content-wrapper{display:flex;justify-content:space-between;align-items:center;flex-direction:row-reverse;gap:2rem;width:100%;margin-inline:2rem}@media only screen and (max-width:1040px){.hero__content-wrapper{margin-inline:0}}@media only screen and (max-width:920px){.hero__content-wrapper{flex-direction:column;padding-bottom:4rem;padding-top:5.5rem}}@media only screen and (max-width:640px){.hero__content-wrapper{padding-bottom:3rem}}.hero__left-content{display:flex;justify-content:center;align-items:flex-start;flex-direction:column;gap:2rem}.hero__title{display:inline-block;font-weight:800;font-size:3.5rem;transition:color .35s}@media only screen and (max-width:1120px){.hero__title{font-size:3rem}}@media only screen and (max-width:920px){.hero__title{text-align:center}}@media only screen and (max-width:640px){.hero__title{font-size:2.5rem}}.hero__title--main{color:#1b1b1b}.hero__title--sub{color:#3a3a3a;font-size:2.75rem}@media only screen and (max-width:1120px){.hero__title--sub{font-size:2.25rem}}@media only screen and (max-width:640px){.hero__title--sub{font-size:2rem}}.hero__avatar-container{position:relative;max-height:22rem;max-width:22rem;width:28vw;height:28vw;border-radius:30% 70% 70% 30%/30% 30% 70% 70%}.hero__avatar-container:before{position:absolute;left:0;top:0;content:"";border-radius:30% 70% 70% 30%/30% 30% 70% 70%;background-color:#1b1b1b;transition:background-color .35s}.hero__avatar-container:hover .hero__avatar-img{transform:translate(-.35rem,-.35rem)}@media only screen and (max-width:1040px){.hero__avatar-container{width:19rem;height:19rem}}@media only screen and (max-width:640px){.hero__avatar-container{width:calc(12rem + 15vw);height:calc(12rem + 15vw)}}.hero__avatar-img{position:relative;object-fit:cover;object-position:0 20%;background-color:#1b1b1b;border:.125rem solid #1b1b1b;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;transition:transform .35s,border-color .35s,background-color .35s}@media only screen and (max-width:920px){.hero__btn{margin:0 auto}}.contact{background-color:#f5f5f5;transition:background-color .35s;padding:4rem 1rem}.contact__inner-container{width:100%;max-width:50rem;margin:0 auto}.contact__title-box{display:flex;flex-direction:column;align-items:center;gap:.75rem;text-align:center;margin-bottom:1rem}.contact__title{font-size:clamp(2.2rem,4vw,2.8rem);font-weight:700;letter-spacing:-.02em;color:#f5f5f5}.contact__text{max-width:36rem;font-size:1rem;font-weight:300;color:#3a3a3a;transition:color .35s}.contact__card{max-width:32rem;margin:0 auto;padding:1.75rem;border-radius:1.5rem;background-color:#131313;border:1px solid #1b1b1b;box-shadow:0 0 3.75rem -1rem rgba(27,27,27,.4);transition:background-color .35s,border-color .35s,box-shadow .35s}.contact__form{gap:1.25rem}.contact__field,.contact__form{display:flex;flex-direction:column}.contact__field{gap:.25rem}.contact__input,.contact__textarea{width:100%;padding:1rem 1.1rem;border-radius:.85rem;background-color:#1b1b1b;border:1px solid #3a3a3a;color:#eee;font-size:.95rem;transition:background-color .35s,border-color .35s,box-shadow .35s,color .35s}.contact__input::placeholder,.contact__textarea::placeholder{color:#3a3a3a}.contact__input:focus,.contact__textarea:focus{outline:none;border-color:#f5f5f5;box-shadow:0 0 0 .15rem #f5f5f5}.contact__textarea{resize:none;min-height:10rem}.contact__footer{display:flex;justify-content:space-between;align-items:center;margin-top:.25rem;font-size:.75rem;color:#3a3a3a;transition:color .35s}.contact__counter{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.contact__error{color:#ff5b5b;font-size:.75rem}.contact__button{margin-top:.75rem;padding:1rem;border-radius:.85rem;background-color:#f5f5f5;color:#1b1b1b;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:background-color .35s,color .35s,transform .2s}.contact__button:hover{transform:translateY(-1px)}.contact__button:disabled{opacity:.6;cursor:not-allowed;transform:none}.about{overflow:hidden;background-color:#1b1b1b}.about__inner-container{padding-bottom:5rem;padding-top:4rem}@media only screen and (max-width:640px){.about__inner-container{padding-block:3rem}}.about__title-box{display:flex;align-items:center;gap:1rem;position:relative;margin-bottom:3rem}@media only screen and (max-width:640px){.about__title-box{margin-bottom:2rem}}.about__title-box .about__title-line{height:1px;width:100%;background-color:hsla(0,0%,100%,.6);transition:background-color .35s}@media only screen and (max-width:640px){.about__title-box .about__title-line{display:none}}.about__title{color:#f5f5f5;background-color:#1b1b1b}.about__content-wrapper{display:flex;justify-content:space-between;align-items:flex-start;gap:4rem}@media only screen and (max-width:1040px){.about__content-wrapper{position:relative;flex-direction:column}}.about__avatar-container{position:relative;flex-shrink:0;align-self:stretch;width:28%}@media only screen and (max-width:1040px){.about__avatar-container{display:none}}.about__avatar-container:before{position:absolute;left:1rem;top:1.125rem;content:"";border:.125rem solid hsla(0,0%,100%,.6);border-radius:1rem;transition:.35s}@media only screen and (max-width:1040px){.about__avatar-container:before{display:none}}.about__avatar-container:hover:before{transform:translate(.3rem,.3rem);border-color:#fff}.about__avatar-container:hover .about__avatar-img{transform:translate(-.3rem,-.3rem);border-color:#fff}.about__avatar-img{position:relative;border-radius:1rem;object-fit:cover;object-position:top;border:.125rem solid hsla(0,0%,100%,.6);transition:.35s}.about__right-content{display:flex;justify-content:center;align-items:flex-start;flex-direction:column;gap:2rem}.about__content-division{padding:1.5rem;border-radius:.5rem;background-color:#131313;box-shadow:.25rem .25rem .5rem rgba(0,0,0,.569);width:100%}.about__text{color:#eee;font-weight:300}@media only screen and (max-width:640px){.about__text{text-align:center}}.about__marker{background-color:#ff5b5b;box-shadow:0 0 .25rem #ff5b5b}.about__social-wrapper{display:grid;grid-gap:2rem;gap:2rem;grid-template-columns:repeat(4,3.75rem)}@media only screen and (max-width:640px){.about__social-wrapper{justify-content:center}}@media only screen and (max-width:430px){.about__social-wrapper{grid-template-columns:repeat(2,3.75rem);grid-template-rows:repeat(2,3.75rem)}}.about__social-link{display:flex;justify-content:center;align-items:center;gap:0;position:relative;width:3.75rem;height:3.75rem;border-radius:.25rem;background-color:#131313;box-shadow:.25rem .25rem .5rem rgba(0,0,0,.569),inset 0 0 0 .125rem rgba(58,58,58,.25);transition:transform .35s,box-shadow .35s}.about__social-link:focus-visible{outline-color:#fff}.about__social-link:focus-visible,.about__social-link:hover{transform:translate(-.25rem,-.25rem);box-shadow:.5rem .5rem .75rem rgba(0,0,0,.569),inset 0 0 0 .125rem rgba(58,58,58,.25)}.about__social-link:focus-visible .about__social-icon,.about__social-link:hover .about__social-icon{fill:#ff5b5b}.about__social-icon{fill:#f5f5f5;height:42%;width:42%;transition:.35s}.education{overflow:hidden;background-color:#1b1b1b}.education__inner-container{padding-bottom:5rem;padding-top:4rem}@media only screen and (max-width:640px){.education__inner-container{padding-block:3rem}}.education__title-box{display:flex;align-items:center;gap:1rem;position:relative;margin-bottom:3rem}@media only screen and (max-width:640px){.education__title-box{margin-bottom:2rem}}.education__title-box .education__title-line{height:1px;width:100%;background-color:hsla(0,0%,100%,.6);transition:background-color .35s}@media only screen and (max-width:640px){.education__title-box .education__title-line{display:none}}.education__title{color:#f5f5f5;background-color:#1b1b1b}.education__content-wrapper{display:flex;justify-content:space-between;align-items:flex-start;gap:4rem}@media only screen and (max-width:1040px){.education__content-wrapper{position:relative;flex-direction:column}}.education__avatar-container{position:relative;flex-shrink:0;align-self:stretch;width:28%}@media only screen and (max-width:1040px){.education__avatar-container{display:none}}.education__avatar-container:before{position:absolute;left:1rem;top:1.125rem;content:"";border:.125rem solid hsla(0,0%,100%,.6);border-radius:1rem;transition:.35s}@media only screen and (max-width:1040px){.education__avatar-container:before{display:none}}.education__avatar-container:hover:before{transform:translate(.3rem,.3rem);border-color:#fff}.education__avatar-container:hover .education__avatar-img{transform:translate(-.3rem,-.3rem);border-color:#fff}.education__avatar-img{position:relative;border-radius:1rem;object-fit:cover;object-position:top;border:.125rem solid hsla(0,0%,100%,.6);transition:.35s}.education__right-content{display:flex;justify-content:center;align-items:flex-start;flex-direction:column;gap:2rem}.education__content-division{padding:1.5rem;border-radius:.5rem;background-color:#131313;box-shadow:.25rem .25rem .5rem rgba(0,0,0,.569);width:100%}.education__text{color:#eee;font-weight:300}@media only screen and (max-width:640px){.education__text{text-align:center}}.education__marker{background-color:#007bff;box-shadow:0 0 .5rem #007bff}.education__social-wrapper{display:grid;grid-gap:2rem;gap:2rem;grid-template-columns:repeat(4,3.75rem)}@media only screen and (max-width:640px){.education__social-wrapper{justify-content:center}}@media only screen and (max-width:430px){.education__social-wrapper{grid-template-columns:repeat(2,3.75rem);grid-template-rows:repeat(2,3.75rem)}}.education__social-link{display:flex;justify-content:center;align-items:center;gap:0;position:relative;width:3.75rem;height:3.75rem;border-radius:.25rem;background-color:#131313;box-shadow:.25rem .25rem .5rem rgba(0,0,0,.569),inset 0 0 0 .125rem rgba(58,58,58,.25);transition:transform .35s,box-shadow .35s}.education__social-link:focus-visible{outline-color:#fff}.education__social-link:focus-visible,.education__social-link:hover{transform:translate(-.25rem,-.25rem);box-shadow:.5rem .5rem .75rem rgba(0,0,0,.569),inset 0 0 0 .125rem rgba(58,58,58,.25)}.education__social-link:focus-visible .education__social-icon,.education__social-link:hover .education__social-icon{fill:#ff5b5b}.education__social-icon{fill:#f5f5f5;height:42%;width:42%;transition:.35s}.projects{overflow:hidden;background-color:#f5f5f5;transition:background-color .35s}.projects__inner-container{padding-block:4rem}@media only screen and (max-width:640px){.projects__inner-container{padding-block:3rem}}.projects__title-box{display:flex;align-items:center;gap:1rem;position:relative;margin-bottom:3rem}@media only screen and (max-width:640px){.projects__title-box{margin-bottom:2rem}}.projects__title-box .projects__title-line{height:1px;width:100%;background-color:rgba(27,27,27,.6);transition:background-color .35s}@media only screen and (max-width:640px){.projects__title-box .projects__title-line{display:none}}.projects__title{color:#1b1b1b;background-color:#f5f5f5}.projects__cards-wrapper{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:4rem;gap:4rem;margin-bottom:4rem}@media only screen and (max-width:920px){.projects__cards-wrapper{grid-template-columns:1fr;margin-bottom:3rem}}.projects__btn{margin:0 auto}.skills{overflow:hidden;background-color:#1b1b1b}.skills__inner-container{padding-block:4rem}@media only screen and (max-width:640px){.skills__inner-container{padding-block:3rem}}.skills__title-box{display:flex;align-items:center;gap:1rem;position:relative;margin-bottom:3rem}@media only screen and (max-width:640px){.skills__title-box{margin-bottom:2rem}}.skills__title-box .skills__title-line{height:1px;width:100%;background-color:hsla(0,0%,100%,.6);transition:background-color .35s}@media only screen and (max-width:640px){.skills__title-box .skills__title-line{display:none}}.skills__title{color:#f5f5f5;background-color:#1b1b1b}.skills__content{display:grid;grid-template-columns:42.5% auto;grid-gap:2rem;gap:2rem}@media only screen and (max-width:920px){.skills__content{grid-template-columns:1fr;gap:1rem}}.skills__description-box{display:flex;justify-content:center;align-items:flex-start;gap:0;overflow:hidden;background-color:#131313;padding:1.5rem;border-radius:.5rem;box-shadow:.25rem .25rem .5rem rgba(0,0,0,.569);grid-column:1/2;grid-row:1}@media only screen and (max-width:920px){.skills__description-box{grid-row:2;grid-column:1/3}}.skills__desc-wrapper{opacity:0;animation:show 1s forwards}.skills__tech-desc{color:#eee;font-weight:300}@media only screen and (max-width:640px){.skills__tech-desc{text-align:center}}.skills__draft-container{transform:translateY(100%);opacity:0;align-self:center;animation:slide-vertical 1s forwards}.skills__desc-draft{text-align:center;color:#eee}@media only screen and (max-width:920px){.skills__desc-draft{display:none}}.skills__desc-draft--mobile{display:none}@media only screen and (max-width:920px){.skills__desc-draft--mobile{display:block}}.skills__hover-icon{display:block;margin:1.5rem auto 0;fill:#f5f5f5;height:2.5rem;width:2.5rem;animation:bounce 1.5s ease-in-out infinite alternate;transform:translateY(.5rem);opacity:.5}.skills__stack-list{grid-column:2/3}@media only screen and (max-width:920px){.skills__stack-list{grid-column:1/3}}.timeline{margin-top:20px;padding:4rem 0;background-color:#f5f5f5;transition:background-color .35s}.timeline__inner-container{max-width:1200px;padding:0 1.5rem;margin-top:2rem}.timeline__title-box{display:flex;align-items:center;gap:1rem;position:relative;margin-bottom:3rem}@media only screen and (max-width:640px){.timeline__title-box{margin-bottom:2rem}}.timeline__title-box .timeline__title-line{height:1px;width:100%;background-color:rgba(27,27,27,.6);transition:background-color .35s}@media only screen and (max-width:640px){.timeline__title-box .timeline__title-line{display:none}}.timeline__title{font-size:2.5rem;font-weight:700;color:#1b1b1b;margin-bottom:1rem}.timeline__title-line{display:block;height:4px;width:4rem;background-color:#ff5b5b;border-radius:2px}.timeline__content-wrapper{display:flex;justify-content:center;align-items:center;flex-direction:column;gap:2rem}.timeline__container{padding:1rem 1rem 2rem;width:100%}.timeline__entries-container{position:relative;width:100%}.timeline__entries-container--dense{--entry-gap:2rem}.timeline__entries-container--comfortable{--entry-gap:3rem}.timeline__entries-container--loose{--entry-gap:4rem}.timeline__vertical-line{position:absolute;top:0;bottom:0;left:50%;transform:translateX(-50%);width:2px;background-color:#3a3a3a}@media(max-width:768px){.timeline__vertical-line{display:none}}.timeline__heading{width:100%;text-align:center;margin-bottom:var(--entry-gap);position:relative;z-index:10}.timeline__marker{padding:0 1rem}.timeline__marker,.timeline__subtitle{display:inline-block;background-color:#f5f5f5}.timeline__subtitle{padding:.25rem 1rem;color:#3a3a3a;font-size:.9rem}.timeline__entry{display:flex;justify-content:center;align-items:flex-start;gap:0;width:100%;margin-bottom:var(--entry-gap)}.timeline__entry-spacer{width:50%}.timeline__entry-icon-container{position:relative;z-index:10;padding:0 1rem}.timeline__entry-icon,.timeline__entry-icon-container{display:flex;justify-content:center;align-items:center;gap:0}.timeline__entry-icon{border-radius:50%;padding:.75rem;background-color:#ff5b5b;color:#fff;transition:background-color .35s}@media(max-width:768px){.timeline__entry-icon{display:none}}.timeline__entry-icon--blue{background-color:#3b82f6}.timeline__entry-icon--orange{background-color:#f97316}.timeline__entry-icon--red{background-color:#ff5b5b}.timeline__entry-icon--green{background-color:#22c55e}.timeline__entry-icon--purple{background-color:#6354f9}.timeline__icon-svg{width:1.25rem;height:1.25rem}.timeline__icon-svg--default{width:.5rem;height:.5rem;border-radius:50%;background-color:#fff}.timeline__entry-content{width:50%;position:relative;overflow:hidden;padding:1rem}.timeline__entry-content--left{padding-right:2rem;padding-left:2rem;text-align:right;border-radius:.75rem;box-shadow:.5rem .5rem 0 .125rem #1b1b1b,0 0 0 .125rem #1b1b1b,.5rem .5rem 1rem .25rem rgba(0,0,0,.22)}.timeline__entry-content--right{padding-right:2rem;padding-left:2rem;text-align:left;border-radius:.75rem;box-shadow:-.5rem .5rem 0 .125rem #1b1b1b,0 0 0 .125rem #1b1b1b,-.5rem .5rem 1rem .25rem rgba(0,0,0,.22)}.timeline__entry-title{font-size:1.25rem;font-weight:600;color:#1b1b1b;margin-bottom:.25rem}@media only screen and (max-width:640px){.timeline__entry-title{font-size:1rem;text-align:center;margin-right:2rem;margin-left:-2rem}}.timeline__entry-subtitle{font-size:.9rem;color:#3a3a3a;margin-bottom:1rem}@media only screen and (max-width:640px){.timeline__entry-subtitle{font-size:.85rem;text-align:center;margin-right:2rem;margin-left:-2rem}}.timeline__content{margin-top:1rem}.timeline__image-container{margin-bottom:1rem;border-radius:.5rem;overflow:hidden}.timeline__image{width:100%;height:auto;object-fit:cover;border-radius:.5rem}.timeline__text{color:#eee;line-height:1.6}.timeline__text-paragraph{margin-bottom:1rem;color:#292828}@media only screen and (max-width:640px){.timeline__text-paragraph{font-size:.85rem;text-align:justify;margin-right:2rem;margin-left:-2rem}}.timeline__link-container{margin-top:1rem}@media(max-width:768px){.timeline__vertical-line{left:2rem}.timeline__entry{flex-direction:column}.timeline__entry-spacer{display:none}.timeline__entry-content{width:100%;padding-left:4rem!important;text-align:left!important;padding-right:0!important}.timeline__entry-icon-container{position:absolute;left:0;top:0;padding:0}.timeline__heading{padding-left:4rem;text-align:left}}.timeline__skills-container{margin-top:1.25rem;margin-bottom:.5rem}.timeline__skills-title{font-size:.75rem;font-weight:700;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.05em;opacity:.7}.timeline__skills-list{display:flex;flex-wrap:wrap;gap:.5rem}.timeline__skills-list--left{justify-content:flex-end}@media(max-width:768px){.timeline__skills-list--left{justify-content:flex-start}}.timeline__skills-list--right{justify-content:flex-start}.timeline__skill-badge{font-size:.75rem;padding:.25rem .75rem;border-radius:9999px;font-weight:600;white-space:nowrap;transition:all .2s ease;cursor:default}.timeline__skill-badge--blue{background-color:rgba(59,130,246,.15);color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.timeline__skill-badge--blue:hover{background-color:rgba(59,130,246,.25);border-color:rgba(59,130,246,.4)}.timeline__skill-badge--green{background-color:rgba(16,185,129,.15);color:#10b981;border:1px solid rgba(16,185,129,.2)}.timeline__skill-badge--green:hover{background-color:rgba(16,185,129,.25);border-color:rgba(16,185,129,.4)}.timeline__skill-badge--purple{background-color:rgba(139,92,246,.15);color:#8b5cf6;border:1px solid rgba(139,92,246,.2)}.timeline__skill-badge--purple:hover{background-color:rgba(139,92,246,.25);border-color:rgba(139,92,246,.4)}.timeline__skill-badge--orange{background-color:rgba(249,115,22,.15);color:#f97316;border:1px solid rgba(249,115,22,.2)}.timeline__skill-badge--orange:hover{background-color:rgba(249,115,22,.25);border-color:rgba(249,115,22,.4)}.timeline__skill-badge--default{background-color:hsla(220,9%,46%,.15);color:#6b7280;border:1px solid hsla(220,9%,46%,.2)}.timeline__skill-badge--default:hover{background-color:hsla(220,9%,46%,.25);border-color:hsla(220,9%,46%,.4)}@keyframes slide-vertical{to{transform:translateY(0);opacity:100%}}@keyframes show{to{opacity:100%}}@keyframes bounce{to{transform:translateY(-.5rem);opacity:1}}.footer{background-color:#f5f5f5;transition:background-color .35s}.footer__inner-container{padding-top:1.75rem;padding-bottom:1.5rem}.footer__social{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem}@media only screen and (max-width:920px){.footer__social{flex-direction:column;text-align:center;margin-bottom:1rem}}.footer__social-wrapper{display:flex;align-items:center;gap:1rem}.footer__social-link{display:flex;transition:transform .35s}.footer__social-link:focus-visible,.footer__social-link:hover{transform:scale(1.2) translateY(-.25rem)}.footer__social-icon{height:1.35rem;width:1.35rem;fill:#3a3a3a;transition:fill .35s}.footer__mailto-link{text-decoration:underline;color:#131313;transition:color .35s}.footer__attributions{display:flex;justify-content:space-between;align-items:center;gap:1rem}@media only screen and (max-width:920px){.footer__attributions{flex-direction:column;text-align:center;gap:.125rem}}.footer__author,.footer__copyright,.footer__link-bottom{color:#131313;transition:color .35s}.footer__link-bottom{display:inline;position:relative;font-weight:600}.footer__link-bottom:focus-visible:after,.footer__link-bottom:hover:after{width:100%}.footer__link-bottom:after{content:"";position:absolute;left:0;top:100%;width:0;height:1px;background-color:#1b1b1b;transition:.35s}.hero__icon{display:inline-flex;align-items:center;justify-content:center;margin-top:1rem;color:#3b82f6;font-size:2rem}.contact{padding:6rem 1rem;text-align:center;background-color:#fff}.contact__container{max-width:600px;margin:0 auto}.contact__title{font-size:2.5rem;margin-bottom:1.5rem;color:#333}.contact__text{font-size:1.125rem;color:#666;margin-bottom:3rem;line-height:1.6}.contact__btn{display:inline-block;padding:1rem 2.5rem;border:2px solid #007acc;border-radius:4px;color:#007acc;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s ease-in-out}.contact__btn:hover{background-color:#007acc;color:#fff;transform:translateY(-3px);box-shadow:0 4px 6px rgba(0,122,204,.2)}.rotate-180{transform:rotate(180deg)}html.dark-mode{scrollbar-color:#929292 #131313}html.dark-mode *{outline-color:#f5f5f5}html.dark-mode body::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#3a3a3a,#929292);border:1px solid #131313}html.dark-mode body::-webkit-scrollbar-track{background-color:#131313}html.dark-mode .header--shaded{box-shadow:0 1px .5rem rgba(0,0,0,.75)}@media only screen and (max-width:920px){html.dark-mode .header__navbar{background-color:#f5f5f5}html.dark-mode .header__nav-list{background-color:#1b1b1b}}html.dark-mode .header__btn-close:focus-visible,html.dark-mode .header__btn-close:hover{box-shadow:0 0 0 1px #1b1b1b;outline-color:#1b1b1b}html.dark-mode .header__close-icon{fill:#1b1b1b}html.dark-mode .timeline__container,html.dark-mode .timeline__inner-container{background-color:#131313;color:#fff}html.dark-mode .timeline__title-box{display:flex;align-items:center;gap:1rem;position:relative;margin-bottom:3rem}@media only screen and (max-width:640px){html.dark-mode .timeline__title-box{margin-bottom:2rem}}html.dark-mode .timeline__title-box .timeline__title-line{height:1px;width:100%;background-color:hsla(0,0%,100%,.3);transition:background-color .35s}@media only screen and (max-width:640px){html.dark-mode .timeline__title-box .timeline__title-line{display:none}}html.dark-mode .timeline__title{color:#fff}html.dark-mode .timeline__vertical-line{background-color:#fff}html.dark-mode .timeline__marker,html.dark-mode .timeline__subtitle{background-color:#131313;color:#fff}html.dark-mode .timeline__entry-content--left{box-shadow:.5rem .5rem 0 .125rem #1b1b1b,0 0 0 .125rem #1b1b1b,.5rem .5rem 1rem .25rem hsla(0,10%,73%,.22)}.dark html.dark-mode .timeline__entry-content--left{box-shadow:.5rem .5rem 0 .125rem rgba(58,58,58,.2),0 0 0 .125rem rgba(58,58,58,.2),.5rem .5rem 1rem .25rem hsla(0,0%,100%,.05);background-color:#e8e8e8}html.dark-mode .timeline__entry-content--right{box-shadow:-.5rem .5rem 0 .125rem #1b1b1b,0 0 0 .125rem #1b1b1b,-.5rem .5rem 1rem .25rem hsla(0,10%,73%,.22)}.dark html.dark-mode .timeline__entry-content--right{box-shadow:-.5rem .5rem 0 .125rem rgba(58,58,58,.2),0 0 0 .125rem rgba(58,58,58,.2),-.5rem .5rem 1rem .25rem hsla(0,3%,78%,.05);background-color:#e8e8e8}html.dark-mode .timeline__entry-subtitle,html.dark-mode .timeline__entry-title,html.dark-mode .timeline__text,html.dark-mode .timeline__text-paragraph{color:#fff}html.dark-mode .hero{background-color:#131313}html.dark-mode .hero__title--main{color:#f5f5f5}html.dark-mode .hero__title--sub{color:hsla(0,0%,96%,.75)}html.dark-mode .hero__avatar-container:before{background-color:#f5f5f5}html.dark-mode .hero__avatar-img{background-color:#f5f5f5;border-color:#f5f5f5}html.dark-mode .projects{background-color:#131313;color:#fff}html.dark-mode .projects__title{background-color:#131313;color:#f5f5f5}html.dark-mode .projects__title-line{background-color:hsla(0,0%,100%,.6)}html.dark-mode .projects__link-title{color:#fff}html.dark-mode .footer{background-color:#131313}html.dark-mode .footer__social-icon{fill:#f5f5f5}html.dark-mode .footer__author,html.dark-mode .footer__copyright,html.dark-mode .footer__mailto-link{color:#f5f5f5;font-weight:300}html.dark-mode .footer__link-bottom{color:#f5f5f5}html.dark-mode .footer__link-bottom:after{background-color:#f5f5f5}html.dark-mode .navbar__link{color:#f5f5f5;font-weight:400}html.dark-mode .navbar__link:after{background:linear-gradient(90deg,transparent,#f5f5f5)}html.dark-mode .brand{border:.125rem solid #fff}html.dark-mode .btn--hamburger:focus-visible,html.dark-mode .btn--hamburger:hover{box-shadow:0 0 0 1px #f5f5f5}html.dark-mode .btn--hamburger__bar{background-color:#f5f5f5}html.dark-mode .btn--download,html.dark-mode .btn--show-more{outline-color:transparent}html.dark-mode .btn--download__content,html.dark-mode .btn--show-more__content{background-color:#131313;border-color:#f5f5f5}html.dark-mode .btn--download:before,html.dark-mode .btn--show-more:before{background-color:#f5f5f5}html.dark-mode .btn--download:focus-visible .btn--download__content,html.dark-mode .btn--download:focus-visible .btn--show-more__content,html.dark-mode .btn--download:hover .btn--download__content,html.dark-mode .btn--download:hover .btn--show-more__content,html.dark-mode .btn--show-more:focus-visible .btn--download__content,html.dark-mode .btn--show-more:focus-visible .btn--show-more__content,html.dark-mode .btn--show-more:hover .btn--download__content,html.dark-mode .btn--show-more:hover .btn--show-more__content{background-color:#131313;border-color:#f5f5f5;color:#f5f5f5}html.dark-mode .btn--download:focus-visible .btn--download__icon,html.dark-mode .btn--download:focus-visible .btn--show-more__icon,html.dark-mode .btn--download:hover .btn--download__icon,html.dark-mode .btn--download:hover .btn--show-more__icon,html.dark-mode .btn--show-more:focus-visible .btn--download__icon,html.dark-mode .btn--show-more:focus-visible .btn--show-more__icon,html.dark-mode .btn--show-more:hover .btn--download__icon,html.dark-mode .btn--show-more:hover .btn--show-more__icon{fill:#f5f5f5}html.dark-mode .btn--scrolltop{background-color:#f5f5f5;border-color:#131313;box-shadow:0 0 0 1px #f5f5f5}html.dark-mode .btn--scrolltop__icon{fill:#131313}html.dark-mode .side-links__link:focus-visible .side-links__icon{fill:#f5f5f5}html.dark-mode .side-links__icon{fill:#929292}html.dark-mode .side-links__icon:hover{fill:#f5f5f5}html.dark-mode .side-links__bar{background-color:#929292}html.dark-mode .project__skew{box-shadow:.5rem .5rem 0 .125rem #dcdcdc,0 0 0 .125rem #dcdcdc}html.dark-mode .project__skew:after{background-color:hsla(0,0%,100%,.25)}html.dark-mode .project__link-banner{border-color:#f5f5f5}html.dark-mode .project__link-title{color:#f5f5f5}html.dark-mode .project__link-title:focus-visible,html.dark-mode .project__link-title:hover{-webkit-text-decoration-color:#f5f5f5;text-decoration-color:#f5f5f5}html.dark-mode .project__description{color:#eee}html.dark-mode .project__tech-item{font-weight:300;color:hsla(0,0%,93%,.85);border-color:hsla(0,0%,93%,.85)}html.dark-mode .project__ext-link:focus-visible,html.dark-mode .project__ext-link:hover{box-shadow:inset 0 0 0 1px #f5f5f5}html.dark-mode .project__ext-icon{fill:#f5f5f5}html.dark-mode .contact{background-color:#131313}html.dark-mode .contact__title{color:#f5f5f5}html.dark-mode .contact__text{color:#fff}html.dark-mode .contact__card{border-color:#f5f5f5}html.dark-mode .contact__input,html.dark-mode .contact__textarea{border-color:hsla(0,0%,96%,.5)}html.dark-mode .contact__footer{color:#fff}