: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%}a:focus-visible,button:focus-visible,input:focus-visible,label:focus-visible{border-radius:8px;outline:3px solid var(--quaternary-color);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.fade-in-section{opacity:1!important;transform:none!important}}@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)}.see-more-link:focus-visible{background-color:var(--primary-color);color:#fff}.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-button:focus-visible{background-color:var(--dark-grey)}.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:focus-visible{background-color:var(--quaternary-color);border-color:var(--darker-grey)}.copy-button:hover .copy-icon{filter:invert(90%)}.copy-icon{height:auto;transition:filter .3s ease;width:min(4vw,1.4rem)}.card{background:linear-gradient(160deg,#3b434c,#313942);border:1px solid hsla(0,0%,100%,.08);border-radius:var(--border-radius);box-shadow:0 6px 18px rgba(0,0,0,.18);display:flex;flex-direction:column;height:100%;overflow:hidden;transition:background-color .3s ease,box-shadow .3s ease,border-color .3s ease,transform .25s ease}.card:hover{border-color:rgba(159,221,255,.35);box-shadow:0 10px 28px rgba(0,0,0,.24),0 0 0 1px rgba(159,221,255,.2);transform:translateY(-4px)}.card-head{align-items:center;background-color:hsla(0,0%,100%,.04);border-bottom:1px solid hsla(0,0%,100%,.08);color:var(--quaternary-color);display:flex;padding:1rem;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.card:hover .card-head{background-color:hsla(0,0%,100%,.07);border-bottom-color:rgba(159,221,255,.25)}.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:transparent;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:hsla(0,0%,100%,.02)}.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 a:focus-visible{background-color:rgba(159,221,255,.1);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}.collapsible-menu label:focus-visible{border-radius:8px;outline:3px solid var(--quaternary-color);outline-offset:2px}.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}}.timeline{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:1280px;padding-left:42px;width:80%}.timeline,.timeline-item{position:relative}.timeline-item:before{background-color:hsla(0,0%,86%,.9);bottom:-52px;content:"";left:-31px;position:absolute;top:36px;width:3px;z-index:0}.timeline-item:last-child:before{display:none}.timeline-marker{background-color:var(--marine-blue);border:3px solid var(--quinary-color);border-radius:50%;height:20px;left:-42px;position:absolute;top:26px;width:20px;z-index:2}.timeline-marker:after{background-color:hsla(0,0%,86%,.9);content:"";height:3px;left:100%;position:absolute;top:50%;transform:translateY(-50%);width:26px}.degree-info{background:linear-gradient(160deg,#3b434c,#313942);border:1px solid hsla(0,0%,100%,.08);border-left:8px solid hsla(0,0%,86%,.95);border-radius:12px;box-shadow:0 6px 18px rgba(0,0,0,.18);padding:18px 20px;transition:background-color .25s ease,border-color .25s ease,box-shadow .25s ease,transform .25s ease}.timeline-item:hover .degree-info{background:linear-gradient(160deg,#3f4852,#353d47);border-bottom-color:rgba(159,221,255,.35);border-left-color:var(--quaternary-color);border-right-color:rgba(159,221,255,.35);border-top-color:rgba(159,221,255,.35);box-shadow:0 10px 28px rgba(0,0,0,.24),0 0 0 1px rgba(159,221,255,.2);transform:translateY(-4px)}.timeline-head{align-items:flex-start;display:flex;gap:14px;justify-content:space-between}.degree-info h3{color:#fff;font-size:clamp(1.55rem,2.45vw,2.1rem);line-height:1.15;margin:0}.degree-info h3 a{color:var(--quaternary-color);text-decoration:none;transition:color .2s ease}.degree-info h3 a:hover{color:#fff}.timeframe{color:var(--quinary-color);font-size:1rem;margin:2px 0 0;text-align:right;white-space:nowrap}.degree-info h4{color:#fff;font-size:1.03rem;line-height:1.4;margin:8px 0 0}.degree-meta{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.inline-more-link{align-items:center;border:1px solid rgba(159,221,255,.45);border-radius:999px;color:var(--quaternary-color);display:inline-flex;font-size:.85rem;font-weight:700;justify-content:center;padding:4px 10px;text-decoration:none;transition:background-color .2s ease,color .2s ease,transform .2s ease}.inline-more-link:hover{background-color:var(--quaternary-color);color:var(--primary-color);transform:translateY(-1px)}@media (max-width:1000px){.timeline{padding-left:30px;width:88%}.timeline-marker{border-width:2px;height:16px;left:-30px;top:22px;width:16px}.timeline-marker:after{height:2px;width:16px}.timeline-item:before{bottom:-46px;left:-22px;top:30px;width:2px}.timeline-head{flex-direction:column;gap:4px}.timeframe{font-size:.95rem;text-align:left;white-space:normal}.degree-info{border-left-width:6px;padding:16px}.degree-info h3{font-size:1.85rem}}@media (max-width:640px){.timeline{padding-left:0;width:92%}.timeline-item:before,.timeline-marker,.timeline-marker:after{display:none}.degree-info{border-left-width:5px;padding:14px}.degree-info h3{font-size:1.55rem}.degree-info h4{font-size:.97rem}}#about,#contact,#education,#experience,#profile,#projects,#skills{contain-intrinsic-size:512px;content-visibility:auto}#profile{background:radial-gradient(circle at 20% 15%,rgba(159,221,255,.16),transparent 40%),linear-gradient(160deg,#2b343d,#29323a 45%,#242d35);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 h1{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem);margin:0 auto;max-width:900px;width:80%}#profile h1 .highlight{color:var(--quaternary-color)}.profile-tagline{font-size:clamp(.95rem,1.6vw,1.15rem);font-weight:400;letter-spacing:.04em;margin:var(--spacing-sm) auto 0}.profile-summary,.profile-tagline{color:var(--quinary-color);max-width:900px;width:80%}.profile-summary{margin:var(--spacing-md) auto 0;text-align:center}.profile-cta-group{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:var(--spacing-lg)}.profile-cta{border-radius:999px;font-weight:700;padding:10px 18px;text-decoration:none;transition:transform .2s ease,background-color .2s ease,color .2s ease,border-color .2s ease}.profile-cta-primary{background-color:var(--quaternary-color);border:2px solid var(--quaternary-color);color:var(--primary-color)}.profile-cta-primary:hover{background-color:#fff;border-color:#fff;transform:translateY(-2px)}.profile-cta-secondary{border:2px solid #fff;color:#fff}.profile-cta-secondary:hover{background-color:#fff;color:var(--primary-color);transform:translateY(-2px)}#about{align-items:center;background-color:var(--marine-blue);color:var(--quinary-color);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{color:var(--quaternary-color);margin:var(--spacing-xs) 0 var(--spacing-lg)}#about p{margin:0 0 12px;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(--marine-blue);padding:var(--spacing-xxl) 0}#experience h2{color:#fff;margin:0 0 36px;text-align:center}#skills{background-color:var(--primary-color);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:.75rem;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 8px;text-align:center}.projects-intro{color:var(--quinary-color);margin:0 auto 28px;max-width:920px;text-align:center;width:80%}.featured-projects{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));margin:0 auto 24px;max-width:1280px;width:80%}.featured-project-card{background:linear-gradient(160deg,#3b434c,#313942);border:1px solid hsla(0,0%,100%,.08);border-radius:14px;display:grid;gap:14px;grid-template-columns:1fr;padding:14px;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.featured-project-card:hover{border-color:rgba(159,221,255,.35);box-shadow:0 6px 24px rgba(0,0,0,.25);transform:translateY(-4px)}.featured-project-media{border-radius:10px;min-height:170px;overflow:hidden}.featured-project-media img{height:100%;object-fit:cover;width:100%}.featured-project-content h3{color:var(--quaternary-color);font-size:1.45rem;margin:2px 0 8px}.featured-project-content p{color:#fff;margin:0;text-align:left}.featured-project-list{margin:12px 0 0;padding-left:18px}.featured-project-list li{color:var(--quinary-color);font-size:.95rem;margin-bottom:5px}.projects{align-items:center;display:flex;justify-content:center;width:100%}.projects-container{display:grid;gap:1rem;grid-template-columns:repeat(3,minmax(0,1fr));max-width:1280px;width:80%}.project-link{display:block;text-decoration:none}.project-card{background:linear-gradient(160deg,#3b434c,#313942);border:1px solid hsla(0,0%,100%,.08);border-radius:12px;box-shadow:0 6px 18px rgba(0,0,0,.18);box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:320px;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;width:100%}.project-card:hover{border-color:rgba(159,221,255,.35);box-shadow:0 10px 28px rgba(0,0,0,.24),0 0 0 1px rgba(159,221,255,.2);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);display:flex;inset:0;justify-content:center;opacity:0;position:absolute;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:transparent;border-bottom-left-radius:12px;border-bottom-right-radius:12px;display:flex;flex-grow:1;padding:1.25rem;transition:background-color .3s ease}.project-card:hover .project-description{background-color:hsla(0,0%,100%,.02)}.project-description p{color:#fff;font-size:1rem;margin:0;text-align:left;transition:color .3s ease}@media (max-width:768px){.featured-projects,.projects-container{width:90%}.featured-project-card{padding:12px}.projects-container{grid-template-columns:1fr}}@media (max-width:1100px) and (min-width:769px){.projects-container{grid-template-columns:repeat(2,minmax(0,1fr))}}#contact{background-color:var(--primary-color);color:#fff;padding:var(--spacing-xxl) 0;text-align:center}#contact h2{color:#fff;margin:0 0 36px}.contact-details{align-items:center;background:linear-gradient(160deg,#3b434c,#313942);border:1px solid hsla(0,0%,100%,.08);border-radius:14px;box-shadow:0 6px 18px rgba(0,0,0,.18);display:flex;flex-direction:column;margin:20px auto 0;padding:20px 18px 10px;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;width:min(80%,820px)}.contact-details:hover{border-color:rgba(159,221,255,.35);box-shadow:0 10px 28px rgba(0,0,0,.24),0 0 0 1px rgba(159,221,255,.2);transform:translateY(-4px)}.contact-description{color:var(--quinary-color);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)}.email-link:focus-visible{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-link:focus-visible{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;text-align:center;width:100%}@media (max-width:768px){.contact-details{padding:16px 14px 14px;width:90%}}footer{background-color:var(--marine-blue);box-sizing:border-box;color:#fff;max-width:100vw;padding:1rem;text-align:center;width:100%}