@import url(https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap);@font-face{font-family:Calibre;font-style:normal;font-weight:400;src:local("Calibre"),local("Arial"),local("Helvetica")}@font-face{font-family:Calibre;font-style:normal;font-weight:700;src:local("Calibre Bold"),local("Arial Bold"),local("Helvetica Bold")}@font-face{font-family:SF Mono;font-style:normal;font-weight:400;src:local("SF Mono"),local("Monaco"),local("Consolas"),local("Courier New")}@font-face{font-family:SF Mono;font-style:normal;font-weight:700;src:local("SF Mono Bold"),local("Monaco"),local("Consolas"),local("Courier New")}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#001333;color:#a0a3bd;font-family:Calibre,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden}code{font-family:SF Mono,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:#001333}::-webkit-scrollbar-thumb{background:#8de9ff;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#6dc5dd}::-moz-selection{background-color:#8de9ff;color:#001333}.header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#001333f2;display:flex;justify-content:space-between;left:0;padding:32px 48px;position:fixed;right:0;top:0;z-index:1000}.logo{height:48px;position:relative;width:48px}.logo-hexagon{position:relative}.logo-hexagon,.logo-hexagon svg{height:100%;width:100%}.logo-text{color:var(--accent);font-family:var(--font-poppins);font-size:24px;font-weight:400;left:50%;letter-spacing:1px;line-height:32px;position:absolute;top:50%;transform:translate(-50%,-50%)}.navbar{gap:32px}.nav-menu,.navbar{align-items:center;display:flex}.nav-menu{gap:16px}.nav-item{align-items:center;color:var(--text-light);display:flex;font-family:var(--font-mono);font-size:14px;font-weight:700;gap:4px;letter-spacing:.25px;padding:18px 10px;text-decoration:none;transition:color .3s ease}.nav-item:hover,.nav-number{color:var(--accent)}@media (max-width:768px){.header{padding:24px}.navbar{display:none}}.hero{display:flex;flex-direction:column;justify-content:center;margin:0 auto;max-width:1440px;min-height:100vh;padding:112px 158px 0}.hero-intro{color:var(--accent);font-family:var(--font-mono);font-size:16px;font-weight:700;letter-spacing:.5px;line-height:22px;margin-bottom:24px}.hero-title{color:var(--text-light);margin:0}.hero-subtitle,.hero-title{font-family:var(--font-heading);font-size:80px;font-weight:700;letter-spacing:1px;line-height:100px}.hero-subtitle{color:var(--text-gray);display:inline-block;isolation:isolate;margin:0 0 32px;position:relative}.hero-subtitle:before{animation:sweepHighlight 1.5s ease-in-out .8s forwards;background-color:#8de9ff;content:"";height:100%;left:0;position:absolute;top:0;width:0;z-index:-1}.hero-subtitle:after{animation:sweepTextReveal 1.5s ease-in-out .8s forwards;color:#001333;content:"I build things for the web.";left:0;overflow:hidden;position:absolute;top:0;white-space:nowrap;width:0}@keyframes sweepHighlight{0%{width:0}to{width:100%}}@keyframes sweepTextReveal{0%{width:0}to{width:100%}}.hero-description{color:var(--text-gray);font-family:var(--font-heading);font-size:24px;font-weight:500;letter-spacing:.25px;line-height:1.5;margin-bottom:48px;max-width:672px}@media (max-width:1024px){.hero-subtitle,.hero-title{font-size:60px;line-height:70px}}@media (max-width:768px){.hero{padding:96px 24px 0}.hero-subtitle,.hero-title{word-wrap:break-word;max-width:100%;overflow-wrap:break-word}.hero-subtitle,.hero-subtitle:after,.hero-title{font-size:40px;line-height:50px}.hero-description{font-size:18px}}@media (max-width:480px){.hero-subtitle,.hero-subtitle:after,.hero-title{font-size:20px;line-height:28px}.hero-description{font-size:16px}}@media (max-width:390px){.hero-subtitle,.hero-subtitle:after,.hero-title{font-size:18px;line-height:26px}}@media (max-width:360px){.hero-subtitle,.hero-subtitle:after,.hero-title{font-size:17px;line-height:24px}}.about-content{align-items:flex-start;display:flex;gap:126px}.about-text{flex:1 1;max-width:804px}.about-text p{color:var(--text-gray);font-family:var(--font-heading);font-size:24px;font-weight:500;letter-spacing:.25px;line-height:1.6;margin-bottom:24px}.tech-list{display:flex;gap:56px;margin-top:24px}.tech-column{display:flex;flex-direction:column;gap:16px}.tech-item{align-items:center;color:var(--text-gray);display:flex;font-family:var(--font-mono);font-size:14px;font-weight:500;gap:16px;letter-spacing:.5px}.about-image{height:338px;position:relative;width:338px}.image-wrapper{height:100%;position:relative;width:100%}.profile-image{height:318px;left:0;object-fit:cover;position:absolute;top:0;transition:transform .3s ease;width:318px;z-index:1}.image-wrapper:hover .profile-image{transform:translate(5px,5px)}.image-border{border:3px solid var(--accent);bottom:0;left:20px;position:absolute;right:0;top:20px;transition:transform .3s ease;z-index:3}.image-wrapper:hover .image-border{transform:translate(-5px,-5px)}.image-overlay{background-color:#006effb2;height:318px;left:0;opacity:.7;position:absolute;top:0;transition:opacity .3s ease,transform .3s ease;width:318px;z-index:2}.image-wrapper:hover .image-overlay{opacity:0;transform:translate(5px,5px)}@media (max-width:1024px){.about-content{gap:60px}}@media (max-width:768px){.about-content{flex-direction:column;gap:40px}.about-text p{font-size:18px}.tech-list{gap:32px}.tech-item{font-size:13px}}@media (max-width:480px){.about-text p{font-size:16px}.tech-list{gap:24px}.tech-item{font-size:12px}.about-image{height:280px;width:280px}.image-overlay,.profile-image{height:260px;width:260px}}.experience-container{display:flex;gap:34px}.experience-tabs{border-left:2px solid var(--text-gray);display:flex;flex-direction:column}.tab-section-label{color:var(--accent);font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.5px;margin-top:16px;padding:12px 24px 8px;text-transform:uppercase}.tab-section-label:first-child{margin-top:0}.tab-button{background:#0000;border:none;border-left:2px solid var(--text-gray);color:var(--text-gray);cursor:pointer;font-family:var(--font-mono);font-size:14px;font-weight:500;letter-spacing:.25px;line-height:1.5;margin-left:-2px;padding:16px 24px;text-align:left;transition:all .3s ease}.tab-button.active,.tab-button:hover{background-color:#8de9ff0d;border-left-color:var(--accent);color:var(--accent)}.experience-content{animation:fadeIn .5s ease-in;flex:1 1}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.job-title{color:var(--text-light);font-size:18px;font-weight:700;letter-spacing:.25px;margin-bottom:8px}.at-symbol,.job-title{font-family:var(--font-heading)}.at-symbol{color:var(--accent);font-size:24px;font-weight:900;margin:0 8px}.job-date{color:var(--text-gray);font-family:var(--font-mono);font-size:14px;font-weight:500;letter-spacing:.25px;margin-bottom:24px}.job-responsibilities{display:flex;flex-direction:column;gap:16px;list-style:none}.job-responsibilities li{color:var(--text-gray);font-family:var(--font-heading);font-size:16px;font-weight:500;letter-spacing:.25px;line-height:1.5;padding-left:26px;position:relative}.job-responsibilities li:before{color:var(--accent);content:"▸";font-size:10px;left:0;position:absolute}.role-section{margin-bottom:32px}.role-section:last-child{margin-bottom:0}.role-divider{background-color:#8de9ff1a;height:1px;margin:32px 0}.company-link{text-decoration:none;transition:all .3s ease}.company-link:hover{text-decoration:underline}.tech-stack-section{margin-top:24px}.tech-stack-label{color:var(--text-light);font-family:var(--font-heading);font-size:16px;font-weight:600;letter-spacing:.25px;margin-bottom:12px}.tech-stack-list{display:flex;flex-wrap:wrap;gap:8px 16px}.tech-stack-item{color:var(--text-gray);font-family:var(--font-mono);font-size:13px;font-weight:500;letter-spacing:.5px}@media (max-width:768px){.experience-container{flex-direction:column}}.featured-project{display:grid;grid-template-columns:repeat(12,1fr);margin-bottom:112px;position:relative}.project-image{background:var(--bg-dark);border:.5px solid var(--accent);grid-column:1/8;grid-row:1;height:351px;overflow:hidden;position:relative}.project-image img{display:block;height:100%;object-fit:cover;width:100%}.project-image:after{background-color:#006effb2;content:"";inset:0;opacity:.7;position:absolute}.project-content{align-items:flex-end;display:flex;flex-direction:column;grid-column:7/-1;grid-row:1;justify-content:center;text-align:right;z-index:1}.featured-project-reverse .project-image{grid-column:6/-1}.featured-project-reverse .project-content{align-items:flex-start;grid-column:1/8;text-align:left}.featured-project:last-child{margin-bottom:0}.project-label{color:var(--accent);font-family:var(--font-mono);font-size:14px;margin-bottom:8px}.project-label,.project-title{font-weight:600;letter-spacing:.25px}.project-title{color:var(--text-light);font-family:var(--font-heading);font-size:32px;margin-bottom:24px}.project-description{background-color:var(--bg-card);box-shadow:0 10px 30px #0000004d;margin-bottom:24px;padding:32px 24px}.project-description p{color:var(--text-gray);font-family:var(--font-heading);font-size:18px;font-weight:500;letter-spacing:.25px;line-height:1.5;margin-bottom:16px}.project-description p:last-child{margin-bottom:0}.project-tech{color:var(--text-gray);display:flex;font-family:var(--font-mono);font-size:14px;font-weight:600;gap:16px;letter-spacing:.25px;list-style:none;margin-bottom:8px}.project-links{display:flex;gap:24px;margin-top:16px}.project-links a{color:var(--text-gray);transition:color .3s ease,transform .3s ease}.project-links a:hover{color:var(--accent);transform:translateY(-2px)}.other-projects{align-items:center;display:flex;flex-direction:column;margin-top:100px}.other-projects-title{color:var(--text-light);font-family:var(--font-heading);font-size:40px;font-weight:700;letter-spacing:1px;margin-bottom:16px;text-align:center}.view-archive{color:var(--accent);font-family:var(--font-mono);font-size:14px;font-weight:600;letter-spacing:.25px;margin-bottom:64px;text-decoration:none;transition:opacity .3s ease}.view-archive:hover{opacity:.8;text-decoration:underline}.projects-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:104px;width:100%}.project-card{background-color:var(--bg-card);border-radius:4px;display:flex;flex-direction:column;min-height:350px;padding:36px 24px;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{box-shadow:0 20px 40px #0006;transform:translateY(-8px)}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:30px}.folder-icon{color:var(--accent)}.card-links{display:flex;gap:16px}.card-link{color:var(--text-gray);transition:color .3s ease}.card-link:hover{color:var(--accent)}.card-title{color:var(--text-light);font-size:24px;font-weight:600;line-height:1.3;margin-bottom:10px}.card-description,.card-title{font-family:var(--font-heading);letter-spacing:.25px}.card-description{color:var(--text-gray);flex-grow:1;font-size:18px;font-weight:500;line-height:1.5;margin-bottom:auto}.card-tech{color:var(--text-gray);display:flex;flex-wrap:wrap;font-family:var(--font-mono);font-size:14px;font-weight:600;gap:10px;letter-spacing:.25px;list-style:none;margin-top:24px}.show-more{margin-top:40px}@media (max-width:1024px){.featured-project{display:block}.project-content,.project-image{grid-column:unset;grid-row:unset}.project-content{margin-top:-80px;padding:0 24px}.projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.projects-grid{grid-template-columns:1fr}.project-image{height:280px}.project-image img{object-fit:contain;object-position:center}.project-content{margin-top:24px;padding:0 16px;position:relative;z-index:2}.featured-project-reverse .project-content,.project-content{align-items:flex-start;text-align:left}.project-tech{flex-wrap:wrap;font-size:12px;gap:12px}.project-title{font-size:24px}.project-description{padding:20px 16px}.project-description p{font-size:14px;line-height:1.6}}@media (max-width:480px){.project-image{height:220px}.project-content{margin-top:20px}.project-tech{font-size:11px;gap:8px}.project-title{font-size:20px}.project-description{padding:16px 12px}.project-description p{font-size:13px;line-height:1.5}}.contact-section{align-items:center;display:flex;flex-direction:column;gap:24px;padding:200px 48px;text-align:center}.contact-number{color:var(--accent);font-family:var(--font-mono);font-size:16px;font-weight:700;letter-spacing:.25px}.contact-title{color:var(--text-light);font-family:var(--font-heading);font-size:60px;font-weight:600;letter-spacing:1px;line-height:100px;margin:0}.contact-description{color:var(--text-gray);font-family:var(--font-heading);font-size:24px;font-weight:500;letter-spacing:.25px;line-height:1.5;margin-bottom:32px;max-width:728px}.contact-social{display:flex;gap:24px;margin-top:24px}.contact-social a{color:var(--text-gray);transition:all .3s ease}.contact-social a:hover{color:var(--accent);transform:translateY(-3px)}.contact-social svg{height:28px;width:28px}@media (max-width:768px){.contact-title{font-size:40px;line-height:60px}.contact-social svg{height:24px;width:24px}}.footer{align-items:center;display:flex;flex-direction:column;gap:16px;padding:48px}.footer-credit{color:var(--text-gray);font-family:var(--font-mono);font-size:16px;font-weight:500;letter-spacing:.25px;line-height:1.5;text-align:center}.footer-stats{display:flex;gap:24px}.stat{align-items:flex-end;display:flex;font-family:var(--font-mono);font-size:16px;font-weight:500;gap:8px;letter-spacing:.25px}.stat,.stat svg{color:var(--text-gray)}.stat svg{height:20px;width:20px}:root{--bg-dark:#001333;--bg-card:#001a47;--accent:#8de9ff;--text-light:#d9dbe9;--text-gray:#a0a3bd;--font-heading:"Calibre",-apple-system,system-ui,sans-serif;--font-mono:"SF Mono","Monaco","Inconsolata",monospace;--font-poppins:"Poppins",sans-serif}*{box-sizing:border-box;margin:0;padding:0}.portfolio{background-color:#001333;background-color:var(--bg-dark);color:#a0a3bd;color:var(--text-gray);min-height:100vh;overflow-x:hidden}.highlight{color:#8de9ff;color:var(--accent)}a.highlight{text-decoration:none;transition:all .3s ease}a.highlight:hover{text-decoration:underline}.btn-outline{border:2px solid #8de9ff;border:2px solid var(--accent);border-radius:4px;color:#8de9ff;color:var(--accent);display:inline-block;font-family:SF Mono,Monaco,Inconsolata,monospace;font-family:var(--font-mono);font-size:16px;font-weight:700;letter-spacing:.5px;padding:10px 16px;text-decoration:none;transition:all .3s ease}.btn-outline:hover{background-color:#8de9ff1a;transform:translateY(-2px)}.btn-large{font-size:16px;padding:18px 32px}.section{margin:0 auto;max-width:1440px;padding:80px 148px}.section-header{align-items:center;display:flex;gap:19px;margin-bottom:48px}.section-title{align-items:flex-end;color:#d9dbe9;color:var(--text-light);display:flex;font-family:Calibre,-apple-system,system-ui,sans-serif;font-family:var(--font-heading);font-size:40px;font-weight:700;gap:8px;letter-spacing:1px;white-space:nowrap}.section-number{color:#8de9ff;color:var(--accent);font-family:SF Mono,Monaco,Inconsolata,monospace;font-family:var(--font-mono);font-size:24px;font-weight:700;letter-spacing:.5px;line-height:22px}.section-line{background:linear-gradient(90deg,#8de9ff,#0000);background:linear-gradient(to right,var(--accent),#0000);flex-grow:1;height:1px;max-width:264px}html{scroll-behavior:smooth}::selection{background-color:#8de9ff;background-color:var(--accent);color:#001333;color:var(--bg-dark)}.decorative-flowers-left{bottom:-150px;height:350px;opacity:.8;position:fixed;right:-180px;width:350px;z-index:5}.decorative-flowers-left img{height:100%;object-fit:contain;width:100%}.decorative-flowers-right{bottom:-150px;height:350px;left:-180px;opacity:.8;position:fixed;width:350px;z-index:5}.decorative-flowers-right img{height:100%;object-fit:contain;width:100%}@media (max-width:768px){.section{padding:80px 24px}.section-title{flex-wrap:wrap;font-size:26px;overflow-wrap:break-word;white-space:normal;word-break:break-word}.section-number{flex-shrink:0;font-size:20px}.decorative-flowers-left,.decorative-flowers-right,.section-line{display:none}}@media (max-width:480px){.section-title{font-size:22px}.section-number{font-size:18px}}@media (max-width:360px){.section-title{font-size:20px}.section-number{font-size:16px}}
/*# sourceMappingURL=main.a2b21c46.css.map*/