:root{--primary-color:#282f35;--quaternary-color:#9fddff;--quinary-color:#dcdcdc;--marine-blue:#132139;--dark-grey:#373d43;--darker-grey:#232629;--quaternary-color-highlight:rgba(159,221,255,.2);--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-xxl:48px;--border-radius:12px}html{background-color:var(--marine-blue);box-sizing:border-box;scroll-padding-top:64px}*,:after,:before{box-sizing:inherit}body{margin:0;padding:0;width:100%}img{display:block;height:auto;max-width:100%}@font-face{font-display:swap;font-family:Roboto;font-style:normal;font-weight:400;src:url(public/fonts/roboto/roboto-regular.woff2) format("woff2"),url(public/fonts/roboto/roboto-regular.woff) format("woff")}@font-face{font-display:swap;font-family:Roboto;font-style:normal;font-weight:700;src:url(public/fonts/roboto/roboto-bold.woff2) format("woff2"),url(public/fonts/roboto/roboto-bold.woff) format("woff")}body,h1,h2,h3,h4,h5,h6{font-family:Roboto,sans-serif}h1,h2,h3,h4,h5,h6{margin-top:0}h1,h2{font-weight:700}h3,p{font-weight:400}p{font-family:Roboto,sans-serif;line-height:1.6}.fade-in-section{opacity:0;transform:translateY(20px);transition:opacity .6s ease-out,transform .6s ease-out;will-change:opacity,transform}.fade-in-section.is-visible{opacity:1;transform:none}.glass-nav{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:rgba(19,33,57,.85)!important;border-bottom:1px solid hsla(0,0%,100%,.1)}nav a.active{background-color:rgba(159,221,255,.1);color:var(--quaternary-color)!important;font-weight:700;position:relative}nav a.active:after{background-color:var(--quaternary-color);border-radius:2px;bottom:-4px;content:"";height:2px;left:12px;position:absolute;right:12px}.see-more-link{background-color:transparent;border:2px solid var(--primary-color);border-radius:12px;color:var(--primary-color);display:block;font-size:14px;font-weight:700;margin-top:10px;padding:4px;text-align:center;text-decoration:none;transition:all .3s ease}.see-more-link:hover{background-color:var(--primary-color);color:#fff;transform:translateY(-2px)}.download-button{align-items:center;background-color:transparent;border:1px solid transparent;border-radius:8px;color:#fff;display:inline-flex;font-size:1.15rem;font-weight:700;gap:8px;padding:8px 16px;text-decoration:none;transition:background-color .3s,transform .2s}.download-button:hover{background-color:var(--dark-grey);transform:translateY(-2px)}.download-icon{height:20px;width:20px}.copy-button{display:none}.js-enabled .copy-button{align-items:center;background:none;border:2px solid #fff;border-radius:12px;cursor:pointer;display:flex;justify-content:center;padding:10px;transition:all .3s ease}.copy-button:hover{background-color:var(--quaternary-color);border-color:var(--darker-grey);color:var(--darker-grey);transform:translateY(-2px)}.copy-button:hover .copy-icon{filter:invert(90%)}.copy-icon{height:auto;transition:filter .3s ease;width:min(4vw,1.4rem)}.card{background-color:var(--primary-color);border-radius:var(--border-radius);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:border-bottom .3s ease,background-color .3s ease,box-shadow .3s ease}.card:hover{border-bottom:6px solid #fff;box-shadow:0 4px 32px var(--quaternary-color-highlight);transform:translateY(-4px)}.card-head{align-items:center;background-color:var(--dark-grey);color:var(--quaternary-color);display:flex;padding:1rem;transition:background-color .3s ease,color .3s ease}.card:hover .card-head{background-color:var(--quaternary-color);color:var(--primary-color)}.card-img{height:24px;margin-right:1rem;transition:transform .3s;width:24px}.card:hover .card-img{transform:scale(1.2)}.card-title{font-size:1.2rem;font-weight:700;margin:0;transition:padding-left .3s}.card:hover .card-title{padding-left:6px}.card-body{background-color:var(--primary-color);color:var(--quinary-color);flex-grow:1;font-size:.9rem;overflow:hidden;padding:1rem;text-align:left;transition:background-color .3s ease,color .3s ease}.card:hover .card-body{background-color:var(--darker-grey)}.card-text{line-height:1.4;margin:0}.hover-card{display:none}.js-enabled .hover-card{background-color:#fff;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1);display:block;opacity:0;padding:1rem;pointer-events:none;position:absolute;transform:scale(.9) rotateX(20deg);transition:opacity .3s ease-out,transform .15s ease-out,box-shadow .3s ease-out;visibility:hidden;width:192px;z-index:100}.hover-card.visible{box-shadow:0 10px 25px rgba(0,0,0,.2);opacity:1;pointer-events:auto;transform:scale(1) rotateX(0deg);visibility:visible}.hover-card img{border-radius:6px;margin-bottom:8px;width:100%}.hover-card .description{color:#555;font-size:14px;margin-bottom:10px;text-align:left}header{background-color:var(--marine-blue);box-shadow:0 2px 8px rgba(0,0,0,.2);color:#fff;position:sticky;top:0;z-index:1000}header,nav{overflow:visible;width:100%}nav{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px;padding:1.25rem 1rem;position:relative}nav a{border-radius:8px;color:#fff;display:inline-block;padding:6px 12px;text-decoration:none;transition:color .3s ease,background-color .3s ease,border-color .3s ease}nav a:hover{color:var(--quaternary-color)}nav ul{display:flex;gap:1.5rem;list-style:none;margin:0;padding:0}.uncollapsible-menu{align-items:center;display:none;width:100%}.logo-container{align-items:center;display:flex;margin-right:2rem}.uncollapsible-menu ul{margin-right:auto}.logo-img{aspect-ratio:1/1;border-radius:50%;height:32px;object-fit:cover;width:32px}.contact-link{border:2px solid #fff;border-radius:25px;color:#fff;padding:8px 24px;text-decoration:none;transition:all .3s ease;white-space:nowrap}.contact-link:hover{background-color:#fff;border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.collapsible-menu{align-items:center;display:flex;justify-content:space-between;width:100%}.collapsible-menu input{display:none}.collapsible-menu label{background:url(img/OpenMenu.webp) no-repeat 0;background-size:24px 24px;color:#fff;cursor:pointer;display:block;padding:10px 0 10px 40px}.menu-content{backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);background-color:rgba(19,33,57,.98);box-shadow:0 10px 30px rgba(0,0,0,.5);display:block;left:0;margin-left:calc(-50vw + 50%);max-height:0;overflow-y:auto;padding:0;position:absolute;right:0;top:100%;transition:max-height .3s ease-out,padding .3s ease-out;width:100vw;z-index:999}.collapsible-menu input:checked~.menu-content{max-height:calc(100vh - 60px);padding:1rem 0}.collapsible-menu input:checked~label{background-image:url(img/CloseMenu.webp)}.menu-content ul{display:flex;flex-direction:column;gap:1rem;padding:1rem}.menu-content li a{display:block;padding:10px 16px!important}.menu-content .contact-link{display:block;margin:1.5rem 1rem;text-align:center;text-decoration:none!important}.contact-link.active:after,.contact-link:after,.menu-content .contact-link.active:after,.menu-content a.active:after{content:none!important;display:none!important}.contact-link.active,.contact-link.active:focus{background-color:transparent!important;border-color:#fff!important;color:#fff!important;font-weight:400!important;text-decoration:none!important}.contact-link.active:hover{background-color:#fff!important;border-color:var(--primary-color)!important;color:var(--primary-color)!important}@media (min-width:925px){.uncollapsible-menu{display:flex}.collapsible-menu{display:none}}.education-table-container,.experience-table-container{align-items:center;display:flex;justify-content:center;width:100%}.education-info-table,.experience-info-table{border-collapse:separate;max-width:1280px;position:relative;width:80%}.education-info-table tr:not(:first-child) td,.experience-info-table tr:not(:first-child) td{padding-top:16px}.education-info-table td:not(:first-child):not(:last-child){padding:0 12px}.experience-info-table td:not(:first-child):not(:last-child){padding-left:24px}.education-info-table .icon,.experience-info-table .icon{padding:0;position:relative;text-align:center;width:50px}.icon-holder{align-items:center;background-color:var(--quinary-color);border-radius:50%;color:#fff;display:flex;height:32px;justify-content:center;position:relative;width:32px;z-index:1}.education-info-table .icon-holder{margin-left:16px}.experience-info-table .icon-holder{align-items:flex-end;margin-right:12px}.icon:after,.icon:before{background-color:var(--quinary-color);content:"";position:absolute;width:4px;z-index:0}.education-info-table .icon:before{top:0}.education-info-table .icon:after,.education-info-table .icon:before{height:50%;left:46%;margin-left:8px}.experience-info-table .icon:before{height:50%;left:56%;top:0}.experience-info-table .icon:after{height:50%;left:56%}.icon-holder:after{background-color:var(--quinary-color);content:"";height:4px;position:absolute;top:50%;z-index:0}.education-info-table .icon-holder:after{left:95%;width:46px}.experience-info-table .icon-holder:after{right:95%;width:48px}tr:first-child .icon:before,tr:last-child .icon:after{content:none}.details{width:100%}.degree-info{background:var(--dark-grey);border:none;border-radius:12px;color:#fff;display:flex;flex-direction:column;justify-content:center;overflow:hidden;padding:16px;position:relative;transition:background-color .3s ease}.degree-info:before{background-color:var(--quinary-color);bottom:0;content:"";position:absolute;top:0;transition:width .3s ease;width:12px;z-index:0}.education-info-table .degree-info{padding-left:28px}.education-info-table .degree-info:before{left:0}.experience-info-table .degree-info{padding-right:28px}.experience-info-table .degree-info:before{right:0}.education-info-table tr:hover .degree-info,.experience-info-table tr:hover .degree-info{background:var(--darker-grey);border-bottom:none;box-shadow:none;cursor:pointer;transform:none}.education-info-table tr:hover .degree-info:before,.experience-info-table tr:hover .degree-info:before{width:24px}.degree-info h3{font-size:24px;font-weight:700;margin:0 0 8px;padding:0}.degree-info h3 a{color:var(--quaternary-color);text-decoration:none;transition:color .3s ease}.degree-info h3 a:hover{color:#fff}.degree-info h4{color:#fff;font-size:.9rem;margin:2px 8px}.timeframe{color:var(--quinary-color);font-size:.9rem;position:absolute;top:50%;transform:translateY(-50%)}.education-info-table .timeframe,.experience-info-table .timeframe{right:32px}@media (max-width:924px){.icon,.icon-holder,.line,.timeframe{display:none!important}.details{padding:0!important}td{display:block;width:100%}.degree-info{margin-bottom:16px}}@media (min-width:925px){.education-info-table .details{padding-left:16px}.experience-info-table .details{padding-right:16px}}#about,#contact,#education,#experience,#projects,#skills{contain-intrinsic-size:512px;content-visibility:auto}#profile{background-color:var(--primary-color);padding:var(--spacing-xxl) 0;text-align:center}.profile-container{display:flex;justify-content:center;margin-bottom:var(--spacing-lg)}.profile-img{aspect-ratio:1/1;border:4px solid var(--quaternary-color);border-radius:50%;box-shadow:0 4px 12px rgba(0,0,0,.3);height:20vw;max-height:150px;max-width:150px;object-fit:cover;width:20vw}#profile h2{color:#fff;margin:var(--spacing-lg) auto 0;max-width:800px;width:80%}#profile h2 .highlight{color:var(--quaternary-color)}#profile h3{margin:var(--spacing-sm) auto 0;max-width:800px;width:80%}#about,#profile h3{color:var(--quinary-color)}#about{align-items:center;background-color:var(--marine-blue);display:flex;flex-direction:column;padding:var(--spacing-xxl) 0}#about h2{color:#fff;margin:0}#about h2,#about h3{max-width:1280px;text-align:left;width:80%}#about h3{margin:var(--spacing-xs) 0 var(--spacing-lg) 12px}#about p{margin:12px 0 0;max-width:1280px;text-align:left;width:80%}#education{align-items:center;background-color:var(--marine-blue);display:flex;flex-direction:column;padding:var(--spacing-xxl) 0}#education h2{color:#fff;margin:0 0 36px;text-align:center;width:100%}#experience{background-color:var(--primary-color);padding:var(--spacing-xxl) 0}#experience h2{color:#fff;margin:0 0 36px;text-align:center}#skills{background-color:var(--marine-blue);display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:var(--spacing-xxl) 0;text-align:center}#skills h2{color:#fff;flex-basis:100%;margin:0 0 18px}.filter-input{opacity:0;pointer-events:none;position:absolute}.filter-controls{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:.5rem;width:100%}.filter-label{background-color:var(--primary-color);border:2px solid var(--primary-color);border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;margin:0;padding:.5rem 1rem;transition:all .3s ease}#filter-all:checked~.filter-controls label[for=filter-all],#filter-design:checked~.filter-controls label[for=filter-design],#filter-programming:checked~.filter-controls label[for=filter-programming]{background-color:var(--quinary-color);border-color:var(--quinary-color);color:#000}.skills-container{margin:0 auto;max-width:1280px;width:80%}.skills{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding:1rem}.skill-card{box-sizing:border-box;height:160px;width:300px}.skill-card,.skill-card-link{display:block;text-decoration:none}.skill-card-link{color:inherit;height:100%}#filter-all:checked~.skills-container .skills .skill-card{display:block}#filter-design:checked~.skills-container .skills .skill-card:not(.design),#filter-programming:checked~.skills-container .skills .skill-card:not(.programming){display:none}#projects{background-color:var(--primary-color);padding:var(--spacing-xxl) 0}#projects h2{color:#fff;margin:0 0 36px;text-align:center}.projects{align-items:center;width:100%}.projects,.projects-container{display:flex;justify-content:center}.projects-container{flex-wrap:wrap;gap:1.5rem;max-width:1280px;width:80%}.project-link{text-decoration:none}.project-card{background-color:var(--dark-grey);border-radius:12px;box-sizing:border-box;display:flex;flex-direction:column;height:320px;overflow:hidden;position:relative;transition:border-bottom .3s ease,transform .3s ease,box-shadow .3s ease;width:352px}.project-card:hover{border-bottom:6px solid #fff;box-shadow:0 4px 32px var(--quaternary-color-highlight);transform:translateY(-4px)}.project-image{flex-shrink:0;height:192px;overflow:hidden;position:relative;width:100%}.project-image img{height:100%;object-fit:cover;transition:transform .3s ease,filter .3s ease;width:100%}.project-card:hover .project-image img{filter:blur(1px);transform:scale(1.1)}.overlay{align-items:center;background:rgba(0,0,0,.5);bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transform:scale(1.1);transition:opacity .3s ease,transform .3s ease,visibility 0s linear .3s;visibility:hidden}.project-card:hover .overlay{opacity:1;transform:scale(1);transition-delay:0s;visibility:visible}.overlay h3{color:#fff;font-size:2rem;font-weight:700;text-align:center}.project-description{align-items:center;background-color:var(--dark-grey);border-bottom-left-radius:12px;border-bottom-right-radius:12px;display:flex;flex-grow:1;padding:1.5rem;transition:background-color .3s ease}.project-card:hover .project-description{background-color:var(--darker-grey)}.project-description p{color:#fff;font-size:1rem;margin:0;text-align:justify;transition:color .3s ease}#contact,.project-card:hover .project-description p{color:#fff}#contact{background-color:var(--primary-color);padding:var(--spacing-xxl) 0;text-align:center}#contact h2{color:#fff;margin:0 0 36px}.contact-details{align-items:center;display:flex;flex-direction:column;padding-bottom:10px}.contact-description{margin:0 auto;max-width:800px;width:80%}.email-container{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:var(--spacing-md) 0}.email-link{border:2px solid #fff;border-radius:12px;color:#fff;font-size:min(3vw,1.2rem);padding:10px;text-decoration:none;transition:all .3s ease}.email-link:hover{background-color:var(--quaternary-color);border-color:var(--darker-grey);color:var(--darker-grey)}.social-links{display:flex;gap:1rem;justify-content:center;margin:16px 0}.social-link{align-items:center;color:#fff;display:flex;font-size:1.3rem;padding:4px;text-decoration:none;transition:color .3s ease}.social-link:hover{color:var(--quaternary-color)}.social-icon{height:24px;margin-right:8px;width:24px}.cv-contact-details{margin-bottom:2px;margin-top:4px}.download-container{display:flex;justify-content:center;margin:var(--spacing-md) 0 0}.download-container,footer{text-align:center;width:100%}footer{background-color:var(--marine-blue);box-sizing:border-box;color:#fff;max-width:100vw;padding:1rem}