:root{font-family:"Source Serif 4",serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#000814;background-color:#fffdf7;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.source-serif-4-font{font-family:"Source Serif 4",serif;font-optical-sizing:auto;font-weight:200;font-style:normal}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--bg-color: #fffdf7;--main-font-color: #000814;--secondary-font-color: #444444;--secondary-color: #333533;--card-bg-color: white;--card-hover-color: #e3f2fd}#root{width:100%;top:0;margin:0 auto;background-color:var(--bg-color);font-size:18px;color:var(--main-font-color)}.nav{position:sticky;top:0;width:100%;box-sizing:border-box;z-index:10;display:flex;justify-content:space-around;align-items:center;gap:2rem;padding:0 .75rem;line-height:1.2;max-height:min-content;border-bottom:solid #343434;background-color:var(--bg-color)}.nav ul{padding:0;margin:0;list-style:none;display:flex;gap:1.3rem}.nav a{color:inherit;text-decoration:none;height:100%;display:flex;align-items:center}.nav ul a:hover{text-decoration:underline #fae588 2px;text-underline-offset:5px}.nav-socials a:hover,.logo:hover{color:#0077b6}.logo{font-size:20px}.nav img{max-height:20px}section{padding:120px 12%}#contact{padding-bottom:50px}.section-title{text-align:left;font-size:36px}#intro{display:flex;justify-content:center}.intro-container{min-height:calc(100vh - 450px);display:flex;align-items:center;padding:0}.intro-content{display:flex;justify-content:space-between;align-items:center;gap:4rem;width:100%;max-width:1200px;margin:0 auto;padding:0 110px}.intro-text{flex:1;text-align:left}.intro-greeting{font-size:3.5rem;font-weight:700;margin-bottom:1.5rem;line-height:1.2}.intro-description{font-size:1.3rem;line-height:1.8;margin-bottom:2rem;color:var(--secondary-font-color);max-width:600px}.intro-image{flex:0 0 auto}.intro-image .pfp{max-height:350px;border-radius:20px;box-shadow:0 10px 10px #0000001a}@media(max-width:768px){.intro-content{flex-direction:column-reverse;text-align:center;padding:0 2rem}.intro-text{text-align:center}.intro-greeting{font-size:2rem}.intro-cta{justify-content:center}.intro-image .pfp{max-height:300px}}#about ul{list-style-position:inside}#about div{text-align:left}.tech-stack-container{display:flex;gap:2rem;max-width:1000px;margin:0 auto;padding:0 15%}.tech-stack-card{flex:1;background-color:#6798c0;border:1.5px solid #4780ae;border-radius:15px;padding:1.5rem;text-align:center;transition-duration:.3s}.tech-stack-card:hover{background-color:#4780ae;transform:translateY(-8px);box-shadow:5px 5px 10px #e9eaec}.tech-stack-card h4{margin-top:0;margin-bottom:1.5rem;font-size:1.25rem;text-align:center}.tech-badges{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem}.tech-badge{display:flex;align-items:center;gap:.4rem;background-color:var(--card-bg-color);border:1px solid #d0d1d3;border-radius:25px;padding:.4rem 1rem;font-family:"Source Serif 4",serif;font-size:.9rem}.tech-badge img{width:24px;height:24px}.tech-badge:hover{background-color:#e9eaec}@media(max-width:768px){.tech-stack-container{flex-direction:column}}.vertical-timeline:before{background:#6798c0!important;width:4px!important}.vertical-timeline-element-content{background:var(--card-bg-color)!important;border:1px solid #6798c0!important;border-radius:15px!important;box-shadow:none!important;transition-duration:.3s}.vertical-timeline-element-content h4,.vertical-timeline-element-content p{color:var(--secondary-font-color)}.vertical-timeline--two-columns .vertical-timeline-element-content:hover{background-color:var(--card-hover-color)!important;box-shadow:5px 5px 10px #e9eaec!important}.vertical-timeline--two-columns .vertical-timeline-element:nth-child(odd) .vertical-timeline-element-content:hover{transform:translate(-8px)}.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n) .vertical-timeline-element-content:hover{transform:translate(8px)}.vertical-timeline-element-content-arrow{border-right:0px solid transparent!important}.vertical-timeline-element-icon{background:var(--bg-color)!important;align-items:center;justify-content:center}.projects-grid{display:flex}.project-card{font-size:16px;border:.8px solid #6798C0;background-color:var(--card-bg-color);border-radius:5px;padding:10px;max-width:280px;height:418px;overflow:hidden;transition-duration:.3s;display:flex;flex-direction:column;margin:12px}.project-card:hover{transform:translateY(-8px);background-color:var(--card-hover-color);box-shadow:5px 5px 10px #e9eaec}.project-card img{width:100%;height:150px;flex-shrink:0;object-fit:cover;border-radius:4px}.project-card p{margin:10px 0;color:var(--secondary-font-color)}.project-card h3{margin:10px 0}.project-links-div{padding:10px;gap:.3rem;display:flex;justify-content:right;margin-top:auto}p{font-size:18px}.misc-collage{display:grid;grid-template-columns:repeat(6,1fr);gap:2rem;width:92%;margin:60px auto 0}.misc-photo-frame{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;touch-action:manipulation;aspect-ratio:2/3}.misc-collage img{width:100%;height:100%;object-fit:cover;display:block}.collage-caption{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;background:#444444b3;color:#fff;padding:.75rem;font-size:.9rem;opacity:0;transition:opacity .3s ease}.collage-caption a{color:inherit;text-decoration:underline}.misc-photo-frame:hover .collage-caption{opacity:1}@media(max-width:1024px){.misc-collage{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.misc-collage{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.misc-collage{grid-template-columns:repeat(2,1fr)}}.contact-div{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.contact-message{max-width:600px;display:flex;flex-direction:column;gap:1.5rem}.contact-message label{display:flex;flex-direction:column;gap:.5rem;font-family:"Source Serif 4",serif;font-size:1rem;text-align:left}.contact-message input,.contact-message textarea{color:#333533;background-color:#e7ecef;border:1px solid #d0d1d3;border-radius:8px;padding:.75rem 1rem;font-family:"Source Serif 4",serif;font-size:1rem;width:100%;box-sizing:border-box}.contact-message input:focus,.contact-message textarea:focus{outline:none;border-color:#6096ba}.contact-div input:-webkit-autofill,.contact-div input:-webkit-autofill:hover,.contact-div input:-webkit-autofill:focus,.contact-div textarea:-webkit-autofill,.contact-div textarea:-webkit-autofill:hover,.contact-div textarea:-webkit-autofill:focus{-webkit-box-shadow:0 0 0px 1000px #e7ecef inset!important;-webkit-text-fill-color:black!important;border:1px solid #d0d1d3!important;transition:background-color 5000s ease-in-out 0s}.contact-message textarea{min-height:150px;resize:vertical}.contact-message button{background-color:#99d6ea;color:#fff;border:none;border-radius:8px;padding:.875rem 1rem;font-family:"Source Serif 4",serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;align-self:flex-start;margin-top:-1rem}.contact-message button:hover{background-color:#6798c0}.contact-links{margin-top:20px;max-width:600px;display:flex;justify-content:center;align-items:center;gap:1.5rem}.contact-links a{color:inherit;text-decoration:none}.contact-links button{border:none;border-radius:8px;padding:.875rem 1rem;font-family:"Source Serif 4",serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;align-self:flex-start;margin-top:-1rem}.linkedin-button{background-color:#6798c0;color:#fff}.linkedin-button:hover{background-color:#00509d}.email-button{background-color:#00509d;color:#fff}.email-button:hover{background-color:#11296b}footer{text-align:center;padding-bottom:8px}footer p{font-size:16px;margin:2px;color:var(--secondary-font-color)}.vertical-timeline *{box-sizing:border-box}.vertical-timeline{width:95%;max-width:1170px;margin:0 auto;position:relative;padding:2em 0}.vertical-timeline:after{content:"";display:table;clear:both}.vertical-timeline:before{content:"";position:absolute;top:0;left:18px;height:100%;width:4px;background:var(--line-color)}.vertical-timeline.vertical-timeline--one-column-right:before{right:18px;left:unset}@media only screen and (min-width:1170px){.vertical-timeline.vertical-timeline--two-columns{width:90%}.vertical-timeline.vertical-timeline--two-columns:before{left:50%;margin-left:-2px}}.vertical-timeline-element{position:relative;margin:2em 0}.vertical-timeline-element>div{min-height:1px}.vertical-timeline-element:after{content:"";display:table;clear:both}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}@media only screen and (min-width:1170px){.vertical-timeline-element{margin:4em 0}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}}.vertical-timeline-element-icon{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:50%}.vertical-timeline-element-icon.shadow-size-small{box-shadow:0 0 0 2px #fff,inset 0 1px #00000014,0 2px 0 4px #0000000d}.vertical-timeline-element-icon.shadow-size-medium{box-shadow:0 0 0 3px #fff,inset 0 2px #00000014,0 3px 0 5px #0000000d}.vertical-timeline-element-icon.shadow-size-large{box-shadow:0 0 0 4px #fff,inset 0 2px #00000014,0 4px 0 6px #0000000d}.vertical-timeline--one-column-right .vertical-timeline-element-icon{right:0;left:unset}.vertical-timeline-element-icon svg{display:block;width:24px;height:24px;position:relative;left:50%;top:50%;margin-left:-12px;margin-top:-12px}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-icon{width:60px;height:60px;left:50%;margin-left:-30px}}.vertical-timeline-element-icon{-webkit-transform:translateZ(0);-webkit-backface-visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.bounce-in{visibility:visible;-webkit-animation:cd-bounce-1 .6s;-moz-animation:cd-bounce-1 .6s;animation:cd-bounce-1 .6s}@-webkit-keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2)}to{-webkit-transform:scale(1)}}@-moz-keyframes cd-bounce-1{0%{opacity:0;-moz-transform:scale(.5)}60%{opacity:1;-moz-transform:scale(1.2)}to{-moz-transform:scale(1)}}@keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5);-moz-transform:scale(.5);-ms-transform:scale(.5);-o-transform:scale(.5);transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2);-moz-transform:scale(1.2);-ms-transform:scale(1.2);-o-transform:scale(1.2);transform:scale(1.2)}to{-webkit-transform:scale(1);-moz-transform:scale(1);-ms-transform:scale(1);-o-transform:scale(1);transform:scale(1)}}.vertical-timeline-element-content{position:relative;margin-left:60px;background:#fff;border-radius:.25em;padding:1em;box-shadow:0 3px #ddd}.vertical-timeline--one-column-right .vertical-timeline-element-content{margin-right:60px;margin-left:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content{background:0 0;box-shadow:none}.vertical-timeline-element-content:after{content:"";display:table;clear:both}.vertical-timeline-element-content h2{color:#303e49}.vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline-element-content p{font-size:13px;font-size:.8125rem;font-weight:500}.vertical-timeline-element-content .vertical-timeline-element-date{display:inline-block}.vertical-timeline-element-content p{margin:1em 0 0;line-height:1.6}.vertical-timeline-element-title,.vertical-timeline-element-subtitle{margin:0}.vertical-timeline-element-content .vertical-timeline-element-date{float:left;padding:.8em 0;opacity:.7}.vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:100%;height:0;width:0;border:7px solid transparent;border-right:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:unset;left:100%;height:0;width:0;border:7px solid transparent;border-left:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content:before{left:100%;border-left:7px solid #fff;border-right:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content:before{display:none}.vertical-timeline-element--no-children .vertical-timeline-element-content-arrow{display:none}@media only screen and (min-width:768px){.vertical-timeline-element-content h2{font-size:20px;font-size:1.25rem}.vertical-timeline-element-content p{font-size:16px;font-size:1rem}.vertical-timeline-element-content .vertical-timeline-element-date{font-size:14px;font-size:.875rem}}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-content{margin-left:0;padding:1.5em;width:44%}.vertical-timeline--two-columns .vertical-timeline-element-content-arrow{top:24px;left:100%;transform:rotate(180deg)}.vertical-timeline--two-columns .vertical-timeline-element-content .vertical-timeline-element-date{position:absolute;width:100%;left:124%;top:6px;font-size:16px;font-size:1rem}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content{float:right}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:auto;right:100%;transform:rotate(0)}.vertical-timeline--one-column-right .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--one-column-right .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:100%;right:auto;transform:rotate(0)}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content .vertical-timeline-element-date{left:auto;right:124%;text-align:right}}.vertical-timeline--animate .vertical-timeline-element-content.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2 .6s;-moz-animation:cd-bounce-2 .6s;animation:cd-bounce-2 .6s}@media only screen and (min-width:1170px){.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content.bounce-in,.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@media only screen and (max-width:1169px){.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@-webkit-keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px)}60%{opacity:1;-webkit-transform:translateX(20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2{0%{opacity:0;-moz-transform:translateX(-100px)}60%{opacity:1;-moz-transform:translateX(20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px);-moz-transform:translateX(-100px);-ms-transform:translateX(-100px);-o-transform:translateX(-100px);transform:translate(-100px)}60%{opacity:1;-webkit-transform:translateX(20px);-moz-transform:translateX(20px);-ms-transform:translateX(20px);-o-transform:translateX(20px);transform:translate(20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}@-webkit-keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px)}60%{opacity:1;-webkit-transform:translateX(-20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2-inverse{0%{opacity:0;-moz-transform:translateX(100px)}60%{opacity:1;-moz-transform:translateX(-20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px);-moz-transform:translateX(100px);-ms-transform:translateX(100px);-o-transform:translateX(100px);transform:translate(100px)}60%{opacity:1;-webkit-transform:translateX(-20px);-moz-transform:translateX(-20px);-ms-transform:translateX(-20px);-o-transform:translateX(-20px);transform:translate(-20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}
