:root{font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff}a{text-decoration:none;color:inherit}button{border:none;background:none;cursor:pointer;font:inherit}@font-face{font-family:spectral;src:url(/assets/Spectral-Regular-BiWA11A8.ttf);font-weight:400;font-style:normal}@font-face{font-family:spectral;src:url(/assets/Spectral-Bold-D306sxdK.ttf);font-weight:700;font-style:normal}@font-face{font-family:spectral;src:url(/src/fonts/spectral/Spectral-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:normal}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:italic}*{margin:0;padding:0;box-sizing:border-box}#root{width:100%;min-height:100vh}html{scroll-behavior:smooth}body{font-family:Inconsolata,monospace;line-height:1.6;color:#333;background-color:#fff}#home{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding-top:50px}@font-face{font-family:spectral;src:url(/assets/Spectral-Regular-BiWA11A8.ttf);font-weight:400;font-style:normal}@font-face{font-family:spectral;src:url(/assets/Spectral-Bold-D306sxdK.ttf);font-weight:700;font-style:normal}@font-face{font-family:spectral;src:url(/src/fonts/spectral/Spectral-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:normal}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:italic}.navigation{position:fixed;top:0;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;border-bottom:1px solid rgba(0,0,0,.1)}.nav-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem}.nav-logo{display:flex;align-items:center}.nav-logo .nav-logo-img{height:14px;width:auto;display:block}.nav-menu{display:flex;gap:2rem}@media (max-width: 768px){.nav-menu.active{display:flex;position:absolute;top:100%;left:0;right:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-direction:column;padding:1rem 2rem;border-bottom:1px solid rgba(0,0,0,.1);box-shadow:0 2px 10px #0000001a}}.nav-link{background:none;border:none;font-family:Inconsolata,monospace;font-size:1rem;font-weight:500;color:#2c3e50;cursor:pointer;transition:color .3s ease;padding:.5rem 0}.nav-link:hover{color:#667eea}.nav-toggle{display:none;flex-direction:column;cursor:pointer}.nav-toggle span{width:25px;height:3px;background:#2c3e50;margin:3px 0;transition:.3s}@media (max-width: 768px){.nav-toggle{display:flex}}@media (max-width: 768px){.nav-menu{display:none}.nav-container{padding:1rem}}@font-face{font-family:spectral;src:url(/assets/Spectral-Regular-BiWA11A8.ttf);font-weight:400;font-style:normal}@font-face{font-family:spectral;src:url(/assets/Spectral-Bold-D306sxdK.ttf);font-weight:700;font-style:normal}@font-face{font-family:spectral;src:url(/src/fonts/spectral/Spectral-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:normal}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:italic}.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center}.hero-content{max-width:800px;animation:fadeInUp 1s ease-out}.hero-title{font-family:Spectral,serif;font-size:3.5rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-family:Inconsolata,monospace;margin-bottom:1.5rem;opacity:.9}.hero-description{font-family:Inconsolata,monospace;font-size:1.1rem;line-height:1.6;margin-bottom:2.5rem;opacity:.8}.headshot{border-radius:50%;object-fit:cover;display:block;margin-left:auto;margin-right:auto;max-width:500px;width:80%}@media (min-width: 760px){.headshot{width:400px;height:400px}}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn{display:inline-block;padding:.8rem 2rem;border-radius:25px;text-decoration:none;font-family:Inconsolata,monospace;font-weight:500;transition:all .3s ease;cursor:pointer;border:2px solid transparent}.btn-primary{background:#fff3;color:#fff;border-color:#ffffff4d}.btn-primary:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 5px 15px #0003}.btn-secondary{background:transparent;color:#fff;border-color:#ffffff80}.btn-secondary:hover{background:#ffffff1a;transform:translateY(-2px);box-shadow:0 5px 15px #0003}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.2rem}.hero-description{font-size:1rem}.hero-actions{flex-direction:column;align-items:center}.btn{width:100%;max-width:250px}}@font-face{font-family:spectral;src:url(/assets/Spectral-Regular-BiWA11A8.ttf);font-weight:400;font-style:normal}@font-face{font-family:spectral;src:url(/assets/Spectral-Bold-D306sxdK.ttf);font-weight:700;font-style:normal}@font-face{font-family:spectral;src:url(/src/fonts/spectral/Spectral-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:normal}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:italic}.about{padding:5rem 0;background-color:#fff}.about-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.section-title{font-family:Spectral,serif;font-size:2.5rem;font-weight:700;margin-bottom:2rem;color:#2c3e50}.about-description{font-family:Inconsolata,monospace;font-size:1.1rem;line-height:1.7;color:#555;margin-bottom:1.5rem}.skills-title{font-family:Spectral,serif;font-size:1.8rem;font-weight:600;margin-bottom:2rem;color:#2c3e50}.skills-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1.5rem;margin-top:1rem}.skill-item{display:flex;flex-direction:column;align-items:center;padding:1.5rem;background:#f8f9fa;border-radius:12px;transition:all .3s ease;cursor:pointer}.skill-item:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001a;background:linear-gradient(135deg,#667eea10,#764ba210)}.skill-item .skill-icon{width:50px;height:50px;margin-bottom:.8rem;display:flex;align-items:center;justify-content:center}.skill-item .skill-icon img{width:100%;height:100%;object-fit:contain}.skill-item .skill-name{font-family:Inconsolata,monospace;font-weight:500;color:#2c3e50;text-align:center;font-size:.9rem}@media (max-width: 768px){.about-content{grid-template-columns:1fr;gap:2rem}.section-title{font-size:2rem}.about-description{font-size:1rem}.skills-title{font-size:1.5rem}.skills-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.skill-item{padding:1rem}.skill-item .skill-icon{width:40px;height:40px}.skill-item .skill-name{font-size:.8rem}.container{padding:0 1rem}}@font-face{font-family:spectral;src:url(/assets/Spectral-Regular-BiWA11A8.ttf);font-weight:400;font-style:normal}@font-face{font-family:spectral;src:url(/assets/Spectral-Bold-D306sxdK.ttf);font-weight:700;font-style:normal}@font-face{font-family:spectral;src:url(/src/fonts/spectral/Spectral-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:normal}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:italic}.projects{padding:5rem 0;background-color:#f8f9fa}.projects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem}.project-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.project-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.project-image{position:relative;overflow:hidden;max-height:600px;object-fit:contain}.project-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-image:hover img{transform:scale(1.05)}.project-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.project-card:hover .project-overlay{opacity:1}.project-links{display:flex;gap:1rem}.project-link{padding:.5rem 1rem;background:#667eea;color:#fff;text-decoration:none;border-radius:5px;font-family:Inconsolata,monospace;font-weight:500;transition:background-color .3s ease}.project-link:hover{background:#5a6fd8}.project-content{padding:1.5rem}.project-title{font-family:Spectral,serif;font-size:1.3rem;font-weight:600;margin-bottom:.8rem;color:#2c3e50}.project-description{font-family:Inconsolata,monospace;font-size:.9rem;line-height:1.5;color:#666;margin-bottom:1rem}.project-technologies{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background:#e9ecef;color:#495057;padding:.3rem .8rem;border-radius:15px;font-size:.8rem;font-family:Inconsolata,monospace;font-weight:500}@media (max-width: 768px){.projects-grid{grid-template-columns:1fr}.section-title{font-size:2rem}.container{padding:0 1rem}}@font-face{font-family:spectral;src:url(/assets/Spectral-Regular-BiWA11A8.ttf);font-weight:400;font-style:normal}@font-face{font-family:spectral;src:url(/assets/Spectral-Bold-D306sxdK.ttf);font-weight:700;font-style:normal}@font-face{font-family:spectral;src:url(/src/fonts/spectral/Spectral-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:normal}@font-face{font-family:Inconsolata;src:url(/assets/Inconsolata-VariableFont_wdth_wght-Dy3FmpuR.ttf) format("truetype");font-weight:400 900;font-style:italic}.contact{padding:5rem 0;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.section-title{font-family:Spectral,serif;font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:3rem;color:#2c3e50}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}.contact-subtitle{font-family:Spectral,serif;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;color:#2c3e50}.contact-description{font-family:Inconsolata,monospace;font-size:1.1rem;line-height:1.6;color:#555;margin-bottom:2rem}.contact-links{display:flex;flex-direction:column;gap:1rem}.contact-link{display:flex;align-items:center;gap:.8rem;font-family:Inconsolata,monospace;font-size:1rem;color:#667eea;text-decoration:none;transition:color .3s ease}.contact-link:hover{color:#5a6fd8}.contact-icon{font-size:1.2rem}.contact-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-family:Inconsolata,monospace;font-weight:500;color:#2c3e50;margin-bottom:.5rem}.form-group input,.form-group textarea{width:100%;padding:.8rem;border:2px solid #e9ecef;border-radius:8px;font-family:Inconsolata,monospace;font-size:1rem;transition:border-color .3s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:120px}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-family:Inconsolata,monospace;font-size:1rem;font-weight:500;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.form-status{margin:.5rem 0 1rem;font-family:Inconsolata,monospace;font-size:.95rem}.form-status.success{color:#2e7d32}.form-status.error{color:#c62828}@media (max-width: 768px){.contact-content{grid-template-columns:1fr;gap:2rem}.section-title{font-size:2rem}.contact-subtitle{font-size:1.5rem}.contact-description{font-size:1rem}.contact-form{padding:1.5rem}.container{padding:0 1rem}}
