.navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:initial;height:100px;padding:0 20px;position:fixed;top:0;width:100%;z-index:11}.navbar-container{box-sizing:border-box;height:100%;justify-content:space-between;margin:0 auto;max-width:1600px;padding:0 50px;width:100%}.logo,.navbar-container{align-items:center;display:flex}.logo{color:var(--green);font-family:Courier New,Courier,monospace;font-size:30px;font-weight:700;justify-content:center;padding:10px 20px;text-decoration:none;transition:all .25s ease}.logo:hover{transform:rotate(-5deg) scale(1.1)}.active-logo,.logo:hover{color:var(--lightest-slate);text-shadow:2px 2px 4px #0003}.nav-links{gap:24px}.nav-links,.nav-links ol{align-items:center;display:flex}.nav-links ol{justify-content:space-between;list-style:none;margin:0;padding:0}.nav-links ol li{counter-increment:item 1;font-size:18px;margin:0 5px;position:relative}.nav-links ol li a{color:var(--lightest-slate);padding:10px;text-decoration:none;transition:color .25s ease}.nav-links ol li a:hover{color:var(--green)}.active-link{border-bottom:2px solid var(--green);color:var (--green);font-weight:700}.nav-links ol li a span{font-size:12px;margin-right:5px}.nav-links ol li a span,.resume-button{color:var(--green);font-family:var(--font-mono)}.resume-button{background-color:initial;border:1px solid var(--green);border-radius:4px;cursor:pointer;font-size:16px;line-height:1;padding:.75rem 1rem;text-decoration:none;transition:all .25s ease}.resume-button:hover{background-color:#64ffda1a}.menu-icon{color:var(--lightest-slate);cursor:pointer;display:none}@media (max-width:700px){.navbar-container{padding:0 25px}.nav-links{background-color:#0a192ff2;display:none;flex-direction:column;padding:20px;position:absolute;right:0;top:100px;width:100%}.nav-links.open{display:flex}.nav-links ol{flex-direction:column;gap:20px}.resume-button{text-align:center;width:100%}.menu-icon{display:block;margin-right:10px}.navbar-container{justify-content:space-between}}.home{align-items:center;background-attachment:fixed;background-image:linear-gradient(to bottom left,hsla(0,3%,6%,.678),rgba(12,10,22,.863)),url(/static/media/bg.9667f5aff07232520a72.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;justify-content:center;min-height:100vh;padding:0 150px;position:relative}.home-content{align-items:flex-start;display:flex;flex-direction:column;max-width:1000px}.home-content h1{color:var(--green);font-family:var(--font-mono);font-size:clamp(14px,5vw,16px);font-weight:400;margin:0 0 30px 4px}.big-heading{font-size:clamp(40px,8vw,80px);font-weight:600;line-height:1.1;margin:0}.home-content h2{color:var(--lightest-slate)}.home-content h3{color:var(--slate);margin-top:10px}.home-content p{color:var (--slate);font-size:clamp(16px,5vw,20px);line-height:1.5;margin:20px 0 0;max-width:540px}.home-content p a{color:var(--green);position:relative;text-decoration:none}.home-content p a:hover{text-decoration:underline}.button-container{margin-top:50px}.styled-button{background-color:initial;border:1px solid var(--green);border-radius:4px;color:var(--green);cursor:pointer;font-family:var(--font-mono);font-size:16px;line-height:1;padding:.75rem 1rem;text-decoration:none;transition:all .25s ease}.styled-button:hover{background-color:#64ffda1a}@media (max-width:768px){.home{padding:0 50px}.styled-button{font-size:14px;padding:.5rem .75rem}}@media (max-width:480px){.home{padding:0 25px}.styled-button{font-size:12px;padding:.5rem .75rem}.connect-links-container{background-color:initial;border:none;margin-top:20px;padding:0;position:static;transform:none}.connect-links{flex-direction:row;flex-wrap:wrap;justify-content:center}.connect-links a{margin:5px 10px}}.connect-links-container{background-color:#fff;border:1px solid var(--lightest-slate);border-radius:8px;padding:10px;position:fixed;right:0;top:48%;transform:translateY(-50%)}.connect-links{align-items:center;display:flex;flex-direction:column}.connect-links a{color:var(--white);font-size:18px;margin:10px 0;text-decoration:none;transition:color .25s ease}.connect-links a:hover{color:var(--green)}.about{margin:10px auto 0;max-width:1200px;padding:100px 0}.about-container{display:flex;flex-wrap:wrap;gap:20px;padding:0 25px}.about-card{flex:0 1 auto;padding:1.5rem 1.25rem}.about-card,.skills-card{background:var(--light-navy);border-radius:4px;box-shadow:0 4px 6px #0000001a;height:auto;transition:transform .2s ease}.skills-card{flex:1 1;padding:2rem 1.75rem}.about-card:hover,.skills-card:hover{transform:translateY(-5px)}.about-card h2,.skills-card h2{color:var(--white);font-size:28px;margin-bottom:15px}.skill-category h3{align-items:center;color:var(--white);display:flex;font-size:20px;gap:10px;margin-bottom:5px}.skill-category p{color:var(--light-slate);font-size:16px;line-height:1.6;margin-bottom:20px}@media (max-width:768px){.about-container{flex-direction:column}}:root{--green:#64ffda}.projects-section{align-items:flex-start;background-attachment:fixed;background-image:linear-gradient(to bottom left,hsla(0,3%,6%,.678),rgba(12,10,22,.863)),url(/static/media/bg.9667f5aff07232520a72.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;display:flex;justify-content:center;min-height:100vh;padding:100px 20px}.projects-container{margin:0 auto;max-width:1200px;text-align:center;width:100%}.projects-heading{color:#ccd6f6;color:var(--lightest-slate);display:inline-block;font-size:clamp(26px,5vw,32px);font-weight:700;margin-bottom:1rem;position:relative}.projects-subheading{color:#8892b0;color:var(--slate);font-size:1.1rem;margin-bottom:4rem;margin-left:auto;margin-right:auto;max-width:600px}.projects-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));width:100%}.project-card{background-color:#112240;background-color:var(--light-navy);border-radius:8px;box-shadow:0 10px 30px -15px #020c1bb3;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{box-shadow:0 20px 30px -15px #020c1bb3;transform:translateY(-7px)}.project-image-container{background-color:#233554;background-color:var(--lightest-navy);padding-top:56.25%;position:relative;width:100%}.project-image{height:100%;left:0;object-fit:cover;position:absolute;top:0;width:100%}.project-content{display:flex;flex-direction:column;flex-grow:1;padding:1.5rem;text-align:left}.project-header{margin-bottom:1rem}.project-title{color:#ccd6f6;color:var(--lightest-slate);font-size:1.4rem;font-weight:600;margin:0}.project-description{color:#a8b2d1;color:var(--light-slate);flex-grow:1;font-size:1rem;line-height:1.5;margin-bottom:1.5rem}.project-tech-list{display:flex;flex-wrap:wrap;font-family:var(--font-mono);gap:.5rem;list-style:none;margin:0;padding:0}.project-tech-list li{background-color:#233554;background-color:var(--lightest-navy);border-radius:15px;color:#64ffda;color:var(--green);font-size:.8rem;font-weight:500;line-height:1;padding:.4em .8em;white-space:nowrap}.modal-backdrop{align-items:center;animation:fadeIn .3s forwards;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#0a192fd9;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{animation:slideIn .3s forwards;background-color:#112240;background-color:var(--light-navy);border-radius:8px;box-shadow:0 20px 40px #0006;max-height:90vh;max-width:700px;overflow-y:auto;padding:2rem;transform:scale(.95);width:90%}@keyframes fadeIn{to{opacity:1}}@keyframes slideIn{to{transform:scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #233554;border-bottom:1px solid var(--lightest-navy);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.modal-title{color:#ccd6f6;color:var(--lightest-slate);font-size:1.8rem;margin:0}.modal-close-button{background:none;border:none;color:#8892b0;color:var(--slate);cursor:pointer;font-size:1.5rem;transition:color .3s ease}.modal-close-button:hover{color:#64ffda;color:var(--green)}.modal-image{border-radius:6px;margin-bottom:1.5rem;width:100%}.modal-description{color:#a8b2d1;color:var(--light-slate);font-size:1.1rem;line-height:1.6;margin-bottom:1.5rem}.modal-footer{border-top:1px solid #233554;border-top:1px solid var(--lightest-navy);display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.modal-link-button{align-items:center;background-color:initial;border:1px solid #64ffda;border:1px solid var(--green);border-radius:4px;color:#64ffda;color:var(--green);display:flex;font-family:var(--font-mono);font-size:1rem;gap:.5rem;padding:.6rem 1.2rem;text-decoration:none;transition:all .25s ease}.modal-link-button:hover{background-color:#64ffda1a}@media (max-width:768px){.projects-heading{font-size:2rem}.projects-grid{grid-template-columns:1fr}.modal-content{padding:1.5rem}.modal-title{font-size:1.5rem}}body.modal-open{overflow:hidden}.contact{margin:0 auto;max-width:800px;padding:100px 30px}.contact-container{align-items:center;display:flex;flex-direction:column}.heading{align-self:flex-start;color:var(--lightest-slate);font-size:2rem;font-weight:700;margin-bottom:1rem}.contact-content{align-items:flex-start;display:flex;justify-content:space-between;width:100%}.contact-text{flex:1 1;margin-bottom:20px}.contact-text p{color:var(--slate);font-size:20px;line-height:1.6;margin-bottom:50px}.contact-info{display:flex;flex-direction:column;gap:1rem;margin-top:1.5rem}.contact-item{align-items:center;color:#fff;display:flex;font-size:1rem;gap:.75rem}.contact-item a{color:#fff;text-decoration:underline;transition:color .3s ease}.contact-item a:hover{color:#fc0}.social-links{align-items:flex-start;display:flex;flex-direction:column;gap:20px;margin-left:50px}.social-item{align-items:center;display:flex;gap:10px}.social-item a{color:var(--lightest-slate);font-size:larger;text-decoration:none;transition:color .2s ease}.social-item a:hover{color:var(--green)}@media (max-width:768px){.contact{padding:100px 20px}.contact-content{align-items:center;flex-direction:column}.contact-text p{font-size:16px}.social-links{flex-direction:row;justify-content:center;margin-left:0}}:root{--navy:#0a192f;--light-navy:#112240;--lightest-navy:#233554;--slate:#8892b0;--light-slate:#a8b2d1;--lightest-slate:#ccd6f6;--white:#e6f1ff;--green:#34c759;--font-sans:"Jura","Inter","San Francisco","SF Pro Text",-apple-system,system-ui,sans-serif;--font-mono:"Jura","Fira Code","Fira Mono","Roboto Mono",monospace}body{background-attachment:fixed;background-image:linear-gradient(to bottom left,hsla(0,3%,6%,.678),rgba(12,10,22,.863)),url(/static/media/bg.9667f5aff07232520a72.jpg);background-position:50%;background-repeat:no-repeat;background-size:cover;color:#8892b0;color:var(--slate);font-family:Jura,Inter,San Francisco,SF Pro Text,-apple-system,system-ui,sans-serif;font-family:var(--font-sans)}.App{min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:0 20px}.numbered-heading{align-items:center;color:#ccd6f6;color:var(--lightest-slate);display:flex;font-size:clamp(26px,5vw,32px);margin:10px 0 40px;position:relative;width:100%}.numbered-heading:before{color:#34c759;color:var(--green);content:"0" counter(section) ".";counter-increment:section;font-family:Jura,Fira Code,Fira Mono,Roboto Mono,monospace;font-family:var(--font-mono);font-size:clamp(16px,3vw,20px);font-weight:400;margin-right:10px;position:relative}.numbered-heading:after{background-color:#233554;background-color:var(--lightest-navy);content:"";display:block;height:1px;margin-left:20px;position:relative;width:300px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
/*# sourceMappingURL=main.9a0ad122.css.map*/