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}:root{--primary-color:#0070f3;--secondary-color:#0070f3;--text-color:#333;--text-light:#666;--background-color:#fff;--light-gray:#f5f5f5;--border-color:#eaeaea;--transition-speed:0.3s;--section-spacing:5rem;--muted-accent:#0070f314}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background-color:#fff;background-color:var(--background-color);color:#333;color:var(--text-color);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;line-height:1.6}.app{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}.app.visible{opacity:1;transform:translateY(0)}section{margin:0 auto 5rem;margin:0 auto var(--section-spacing);max-width:1100px;padding:0 2rem}header{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#fffffff2;border-bottom:1px solid #eaeaea;border-bottom:1px solid var(--border-color);margin-bottom:3rem;padding:1.5rem 2rem;position:sticky;top:0;z-index:100}.header-content{max-width:1200px;padding:1rem 2rem;width:100%}.logo-title{flex-shrink:0}.nav-links nav{align-items:center;display:flex;gap:1.25rem}.cv-button{border:1px solid #333;border:1px solid var(--text-color);border-radius:4px;color:#333;color:var(--text-color);font-weight:500;margin-left:.5rem;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s,color .3s;white-space:nowrap}.cv-button:hover{background-color:#333;background-color:var(--text-color);color:#fff}.contact-button{background-color:#007bff;border-radius:4px;color:#fff;margin-left:.5rem;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s;white-space:nowrap}.contact-button:hover{background-color:#0056b3}nav{display:flex;gap:1.5rem}nav a{color:#333;color:var(--text-color);font-weight:500;text-decoration:none;transition:color .3s;transition:color var(--transition-speed);white-space:nowrap}nav a:hover{color:#0070f3;color:var(--primary-color)}h1{font-size:2rem;font-weight:700}h2{font-size:1.8rem;letter-spacing:-.5px;margin-bottom:1rem}h2,h3{font-weight:600}h3{color:#333;color:var(--text-color);font-size:1.2rem;margin-bottom:.5rem}.title{color:#666;color:var(--text-light);font-size:1.1rem}.hero{margin-bottom:5rem;margin-bottom:var(--section-spacing)}.value-proposition{max-width:800px}.value-proposition h2{color:#222;font-size:2.2rem;font-weight:700;line-height:1.3;margin-bottom:.5rem}.value-proposition p{color:#666;color:var(--text-light);font-size:1.2rem;max-width:65ch}.about-content{display:flex;gap:2rem}.about-text{max-width:800px}.about-text p{margin-bottom:1rem;max-width:65ch}.about-text p:last-child{margin-bottom:0}.project-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.project-card{background-color:#f5f5f5;background-color:var(--light-gray);border:1px solid #0000000d;border-radius:8px;box-shadow:0 2px 10px #00000005;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.project-card h3{margin-bottom:0}.project-description{color:#666;color:var(--text-light);margin:0}.project-tech{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag{background-color:#0070f314;background-color:var(--muted-accent);border-radius:12px;color:#0070f3;color:var(--primary-color);font-size:.8rem;font-weight:500;padding:.2rem .6rem}.project-lenses{flex-direction:column;font-size:.9rem}.lens,.project-lenses{display:flex;gap:.5rem}.lens-label{color:#333;color:var(--text-color);flex-shrink:0;font-weight:500}.lens-text{color:#666;color:var(--text-light)}.project-links{display:flex;gap:.75rem;margin-top:auto;padding-top:.5rem}.project-link{color:#0070f3;color:var(--primary-color);font-size:.9rem;font-weight:500;text-decoration:none;transition:opacity .3s;transition:opacity var(--transition-speed)}.project-link:hover{opacity:.8}.project-link.live{color:#16a34a}.project-link.live:before{background-color:#16a34a;border-radius:50%;content:"";display:inline-block;height:6px;margin-right:.4rem;vertical-align:middle;width:6px}.tech-categories{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.tech-category{background-color:#f5f5f5;background-color:var(--light-gray);border:1px solid #0000000d;border-radius:8px;box-shadow:0 2px 10px #00000005;padding:1.5rem}.tech-category h3{color:#0070f3;color:var(--primary-color)}.tech-list{gap:.8rem}.tech-item,.tech-list{display:flex;flex-direction:column}.tech-item{gap:.2rem}.tech-name{font-weight:500}.tech-context{color:#666;color:var(--text-light);font-size:.85rem}.timeline{margin:0 auto;max-width:800px;padding-left:30px;position:relative}.timeline:before{background-color:#0070f3;background-color:var(--primary-color);content:"";height:calc(100% - 10px);left:0;position:absolute;top:10px;width:2px}.timeline-item{margin-bottom:2.5rem;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-marker{background-color:#fff;background-color:var(--background-color);border:2px solid #0070f3;border:2px solid var(--primary-color);border-radius:50%;box-shadow:0 0 0 4px #fff;height:12px;left:-34px;position:absolute;top:10px;width:12px}.timeline-header{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:.3rem}.timeline-period{color:#666;color:var(--text-light);font-size:.9rem}.timeline-company{color:#0070f3;color:var(--primary-color);font-weight:500;margin-bottom:.5rem}.timeline-tools{margin-top:1rem}.tools-label{color:#666;font-weight:500;margin-right:.5rem}.tools-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tool-tag{background-color:#f0f0f0;border-radius:15px;color:#333;font-size:.9rem;padding:.25rem .75rem}.blog-posts{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.blog-card{background-color:#f5f5f5;background-color:var(--light-gray);border:1px solid #0000000d;border-radius:8px;box-shadow:0 2px 10px #00000005;color:#333;color:var(--text-color);display:flex;flex-direction:column;height:100%;padding:1.5rem;text-decoration:none;transition:transform .3s,box-shadow .3s;transition:transform var(--transition-speed),box-shadow var(--transition-speed)}.blog-card:hover{box-shadow:0 10px 20px #0000000d;transform:translateY(-5px)}.blog-meta{color:#666;color:var(--text-light);display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:.8rem}.blog-card h3{line-height:1.4;margin-bottom:.8rem}.blog-card p{color:#666;color:var(--text-light);flex-grow:1;margin-bottom:1rem;max-width:65ch}.read-more{align-self:flex-start;color:#0070f3;color:var(--primary-color);font-weight:500}.blog-placeholder{color:#666;color:var(--text-light);font-style:italic}.contact-section{margin-bottom:4rem}.contact-layout{grid-gap:3rem;align-items:start;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.hidden-field{display:none}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{color:#333;color:var(--text-color);font-size:.9rem;font-weight:500}.form-input,.form-textarea{background-color:#fff;background-color:var(--background-color);border:1px solid #eaeaea;border:1px solid var(--border-color);border-radius:4px;color:#333;color:var(--text-color);font-family:inherit;font-size:.95rem;padding:.6rem .75rem;transition:border-color .2s}.form-input:focus,.form-textarea:focus{border-color:#0070f3;border-color:var(--primary-color);box-shadow:0 0 0 2px #0070f326;outline:none}.form-textarea{min-height:120px;resize:vertical}.form-submit{align-self:flex-start;background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:500;padding:.6rem 1.5rem;transition:background-color .3s}.form-submit:hover{background-color:#0056b3}.form-success{background-color:#f5f5f5;background-color:var(--light-gray);border-radius:8px;padding:2rem;text-align:center}.form-success p{color:#333;color:var(--text-color);font-size:1.05rem}.contact-details{display:flex;flex-direction:column;gap:1.5rem;padding-top:.5rem}footer{border-top:1px solid #eaeaea;border-top:1px solid var(--border-color);color:#666;color:var(--text-light);padding:2rem;text-align:center}@media (max-width:768px){:root{--section-spacing:4rem}header{padding:1rem}.header-content{align-items:flex-start;flex-direction:column;gap:1rem}nav{flex-wrap:wrap;gap:1rem}section{padding:0 1.5rem}.value-proposition h2{font-size:1.8rem}.blog-posts,.contact-layout,.project-grid,.tech-categories{grid-template-columns:1fr}.contact-layout{gap:2rem}}html{scroll-padding-top:100px}.header-contact{margin-left:1.5rem}.header-contact-button{background-color:#0070f3;background-color:var(--primary-color);border-radius:4px;color:#fff;display:inline-block;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:background-color .3s;transition:background-color var(--transition-speed)}.header-contact-button:hover{background-color:#005bbf}.header-content{align-items:center;display:flex;height:60px;justify-content:space-between;margin:0 auto;max-width:1100px}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;height:auto}.nav-container{align-items:center;display:flex;justify-content:space-between;width:100%}.header-contact{margin-left:0}html{scroll-padding-top:140px}}section h2{display:inline-block;padding-bottom:.5rem;position:relative}section h2:after{background-color:#0070f3;background-color:var(--primary-color);bottom:0;content:"";height:3px;left:0;position:absolute;width:2rem}.blog-meta,.tech-category h3,.timeline-header{margin-bottom:.75rem}.tech-item,.timeline-item{padding:.25rem 0}a:focus,button:focus{outline:2px solid #0070f3;outline:2px solid var(--primary-color);outline-offset:2px}.contact-info{display:flex;flex-direction:column;gap:1rem}.contact-item{align-items:center;color:#666;display:flex;font-size:.9rem;gap:.5rem}.contact-item svg{color:#0070f3;color:var(--primary-color)}.contact-item a{color:#666;font-family:monospace;letter-spacing:.5px;text-decoration:none;transition:color .2s ease}.contact-item a:hover{color:#0070f3;color:var(--primary-color)}.contact-item span{font-family:monospace;letter-spacing:.5px}.menu-toggle{display:none}.hamburger{background-color:#333;display:block;height:2px;position:relative;width:24px}.hamburger:after,.hamburger:before{background-color:#333;content:"";height:2px;left:0;position:absolute;transition:all .3s;width:24px}.hamburger:before{top:-8px}.hamburger:after{bottom:-8px}@media (max-width:768px){.menu-toggle{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;padding:.5rem;position:absolute;right:1rem;top:50%;transform:translateY(-50%);width:40px}.hamburger.open{background-color:initial}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{bottom:0;transform:rotate(-45deg)}.nav-links{background:#fff;box-shadow:0 2px 5px #0000001a;display:none;left:0;padding:1rem;position:absolute;top:100%;width:100%}.nav-links.open{display:block}.nav-links nav{align-items:center;flex-direction:column;gap:1rem}.header-content{flex-wrap:wrap;padding:1rem}.logo-title{margin-right:3rem}.logo-title h1{font-size:1.25rem}.logo-title .title{font-size:.8rem}}
/*# sourceMappingURL=main.406d7d3b.css.map*/