*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{scroll-behavior:smooth}body{margin:0;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}:root{--bg: #f6f8fa;--bg-card: #ffffff;--bg-elevated: #eaeef2;--border: #d0d7de;--text: #1f2328;--text-muted: #656d76;--accent: #0969da;--accent-dim: #0550ae;--success: #1a7f37;--max-width: min(1120px, 96vw);--intro-bg-overlay: .92}body{background:var(--bg)}.portfolio{background:transparent;color:var(--text);min-height:100vh}.header{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffe6;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 20px #00000014}.header-inner{max-width:var(--max-width);margin:0 auto;padding:1.5rem clamp(.5rem,4vw,1.25rem);display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2.5rem}.logo{justify-self:start;margin-left:-.4rem;margin-right:1rem;font-family:Plus Jakarta Sans,system-ui,sans-serif;font-weight:800;font-size:1.35rem;letter-spacing:.04em}.header .btn-header-cta{justify-self:end;margin-left:1rem;margin-right:-.4rem;padding:.55rem 1rem;font-size:.8rem!important;font-weight:700!important}.logo-accent{color:var(--accent)}.nav{justify-self:center;display:flex;gap:.5rem;align-items:center}.nav button{font-family:Plus Jakarta Sans,system-ui,sans-serif;font-weight:700;background:transparent;border:none;color:var(--text-muted);padding:.5rem .75rem;font-size:.8rem;cursor:pointer;border-radius:6px;transition:color .2s,background .2s}.nav button:hover{color:var(--text);background:var(--bg-elevated)}.hero{min-height:100vh;padding:clamp(5rem,12vw,8rem) clamp(1rem,4vw,1.5rem) clamp(4rem,10vw,6rem);text-align:center;max-width:var(--max-width);margin:0 auto}.hero-location{display:inline-block;color:var(--text-muted);font-size:.95rem;font-weight:500;margin-bottom:1.5rem;padding:.4rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:999px;letter-spacing:.04em;transition:border-color .2s,color .2s,box-shadow .2s}.hero-location:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 4px 12px #0969da33}.hero h1{font-size:clamp(4.25rem,11vw,6.25rem);font-weight:700;margin:0 0 .75rem;letter-spacing:-.03em;line-height:1.15}.hero-name-accent{color:var(--accent)}.hero h2.hero-title{font-size:2.35rem;font-weight:600;color:var(--text);margin:0 0 1.35rem}.hero-tagline{font-size:1.5rem;color:var(--accent);margin:0 0 1.35rem}.hero-desc{font-size:1.2rem;line-height:1.65;color:var(--text-muted);max-width:752px;margin:0 auto 2.5rem}.hero-stats{margin:0 auto;margin-top:1.25rem;margin-bottom:4.25rem}.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem}.hero-cta .btn{padding:1rem 3rem;font-size:1.15rem;transition:background .2s,color .2s,border-color .2s,transform .2s ease}.hero-cta .btn-arrow{margin-left:.35rem}.hero-cta .btn:hover{transform:scale(1.06)}.btn{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;border:none;transition:background .2s,color .2s,border-color .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dim)}.btn-outline{background:transparent;color:var(--accent);border:1px solid var(--accent)}.btn-outline:hover{background:#0969da14}.btn-small,.btn-text{padding:.5rem 1rem;font-size:.9rem;background:transparent;color:var(--accent)}.btn-text{padding-left:0}.btn-small:hover,.btn-text:hover{text-decoration:underline}.section{max-width:var(--max-width);margin:0 auto;padding:clamp(2.5rem,6vw,4rem) clamp(1rem,4vw,1.5rem)}section{position:relative;z-index:0}section:before{content:"";position:absolute;left:50%;margin-left:-50vw;width:100vw;top:0;bottom:0;z-index:-1;pointer-events:none}section:nth-of-type(odd):before{background:var(--bg)}section:nth-of-type(2n):before{background:var(--bg-card)}section:nth-of-type(2n) .about-me-box,section:nth-of-type(2n) .skill-group,section:nth-of-type(2n) .cert-card,section:nth-of-type(2n) .additional-expertise,section:nth-of-type(2n) .testimonial-card{background:var(--bg)}section:nth-of-type(2n) .about-me-picture{background-color:var(--bg);background-image:var(--hero-bg-url)}.hero-bg{position:absolute;left:50%;margin-left:-50vw;width:100vw;top:0;bottom:0;z-index:-1;pointer-events:none;background-image:linear-gradient(to bottom,rgba(246,248,250,var(--intro-bg-overlay)),rgba(246,248,250,var(--intro-bg-overlay))),var(--hero-bg-url);background-size:cover;background-position:center;background-repeat:no-repeat}.hero:before{background:transparent}.experience.section,.projects.section,.certifications.section,.news.section,.who-i-am.section,.skills.section,.contact.section{max-width:min(1280px,98vw)}.section-title{text-align:center;font-size:calc(2.75rem + 4px);font-weight:700;margin:0 0 .75rem;letter-spacing:-.02em;padding-bottom:.75rem}.section-title:after{content:"";display:block;width:100px;height:3px;background:var(--accent);margin:.5rem auto 0}.section-subtitle{text-align:center;color:var(--text-muted);margin:0 0 2rem;font-size:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,190px);gap:1.5rem;justify-content:center}.stat-card{width:190px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;text-align:center;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.stat-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #0969da33}.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:.25rem}.stat-label{font-size:.9rem;color:var(--text-muted)}.about-me-layout{display:grid;grid-template-columns:minmax(280px,420px) 1fr;gap:2rem;align-items:stretch}@media(max-width:768px){.about-me-layout{grid-template-columns:1fr}}.about-me-picture{aspect-ratio:1;background-image:var(--hero-bg-url);background-size:cover;background-position:center;background-repeat:no-repeat;border:1px solid var(--border);border-radius:12px;width:100%;min-height:280px;cursor:pointer;transition:border-color .2s,box-shadow .2s}.about-me-picture:hover{border-color:var(--accent);box-shadow:0 4px 12px #0969da33}.about-me-boxes{display:flex;flex-direction:column;gap:1.5rem}.about-me-box{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:border-color .2s,box-shadow .2s;cursor:pointer}.about-me-box:hover{border-color:var(--accent);box-shadow:0 4px 12px #0969da33}.bio{line-height:1.7;margin:0;color:var(--text-muted)}.expertise-block h3{margin:0 0 .75rem;font-size:1.1rem}.expertise-block p{color:var(--text-muted);margin:0 0 1rem;line-height:1.6}.expertise-block p:last-of-type{margin-bottom:0}.expertise-badge{display:inline-block;background:var(--accent);color:#fff;padding:.35rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500}.title-accent{color:var(--accent)}.job-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.75rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000000f;transition:border-color .2s,box-shadow .2s}.job-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #0969da33}.job-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1rem}.job-header h3{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:var(--text)}.company{color:var(--accent);font-size:1.1rem;font-weight:700;margin:0}.job-meta{text-align:right;font-size:.95rem;color:var(--text-muted)}.job-meta-item{display:block;margin-bottom:.2rem}.job-meta-item:last-child{margin-bottom:0}.job-bullets{margin:0;padding-left:1rem;list-style:none;color:var(--text-muted);font-size:1.04rem;line-height:1.85}.job-bullets li{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.55rem}.job-bullets li:last-child{margin-bottom:0}.job-bullets li:before{content:"• ";color:var(--accent);font-weight:700;font-size:1.75em;line-height:1;flex-shrink:0;margin-top:.1em}.skills-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:640px){.skills-grid{grid-template-columns:1fr}}.skill-group{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2.25rem 6rem 2.25rem 2.25rem;transition:border-color .2s,box-shadow .2s;cursor:pointer}.skill-group:hover{border-color:var(--accent);box-shadow:0 4px 12px #0969da33}.skill-group-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.skill-group-icon{flex-shrink:0;font-size:1.65rem;line-height:1;color:var(--accent);font-weight:400}.skill-group h4{margin:0;font-size:1.35rem;font-weight:700;color:var(--text)}.skill-group .tags{margin:0;gap:.6rem}.tags{display:flex;flex-wrap:wrap;gap:.5rem}.tag{background:var(--bg-card);color:var(--text);padding:.4rem .75rem;border-radius:999px;font-size:.9rem;border:1px solid rgba(9,105,218,.25);box-shadow:0 0 0 1px #0969da0f;transition:border-color .2s,box-shadow .2s,background .2s}.tag:hover{border-color:var(--accent);box-shadow:0 2px 8px #0969da40;background:#0969da0f}.projects-grid{display:grid;gap:1.5rem}.project-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.project-card:hover{border-color:var(--accent);box-shadow:0 4px 12px #0969da33}.project-card-top{display:grid;grid-template-columns:1fr 1fr;min-height:0;padding:12px;gap:12px}@media(max-width:768px){.project-card-top{grid-template-columns:1fr}}.project-card-media{position:relative;aspect-ratio:16 / 6;overflow:hidden;background:var(--bg-elevated);border-radius:12px}.project-card-media img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}.project-card-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--text-muted)}@media(max-width:768px){.project-card-media{aspect-ratio:16 / 5.5}}.project-card-body{padding:1rem 1.5rem;display:flex;flex-direction:column;justify-content:center;align-items:stretch}.project-case-study-btn{margin-top:.75rem;padding:.5rem 1rem;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;box-sizing:border-box}.project-btn-arrow{display:inline-block;font-size:.65em;line-height:1;transition:transform .2s ease}.project-case-study-btn.is-expanded .project-btn-arrow{transform:rotate(180deg)}.project-case-study-btn--disabled,.project-case-study-btn:disabled{opacity:.6;cursor:not-allowed;border-color:var(--border);color:var(--text-muted)}.project-case-study-btn--disabled:hover,.project-case-study-btn:disabled:hover{background:transparent;border-color:var(--border);color:var(--text-muted)}.project-category{position:absolute;top:10px;left:10px;z-index:1;display:inline-block;font-size:.7rem;font-weight:500;color:#fff;text-transform:capitalize;letter-spacing:.02em;padding:.3rem .55rem;background:var(--accent);border:none;border-radius:999px}.project-card h3{margin:0 0 .5rem;font-size:1.2rem}.project-desc{color:var(--text-muted);margin:0 0 .5rem;line-height:1.5}.project-meta{font-size:.9rem;color:var(--text-muted);margin:0}.case-study{margin:0;padding:1.5rem 2rem;border-top:1px solid var(--border);grid-column:1 / -1}.case-study h4{font-size:.95rem;margin:1rem 0 .5rem}.case-study h4:first-child{margin-top:0}.case-study p,.case-study ul{color:var(--text-muted);margin:0 0 .5rem;line-height:1.6}.case-study ul{padding-left:1.25rem}.case-study-two-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:.5rem}.case-study-two-cols h4{margin-top:0}@media(max-width:640px){.case-study-two-cols{grid-template-columns:1fr}}.certs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem;margin-bottom:2rem}.cert-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.35rem 1.5rem;position:relative;aspect-ratio:10 / 7;min-height:280px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center}.cert-badge-icon{font-size:2.5rem;line-height:1;color:var(--accent);margin-bottom:.6rem;width:3.25rem;height:3.25rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#0969da1a}.cert-name{margin:0 0 .4rem;font-size:1.25rem;font-weight:600;line-height:1.35}.cert-org{font-size:.9rem;color:var(--accent);font-weight:700;margin:0 0 .3rem;line-height:1.4}.cert-year{font-size:.8rem;color:var(--text-muted);margin:0 0 .5rem;line-height:1.4}.cert-desc{margin:0 0 .85rem;font-size:.82rem;color:var(--text-muted);line-height:1.6;flex:1;min-height:0}.cert-card .cert-badge{flex-shrink:0}.cert-badge{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;font-weight:600;color:#fff;background:var(--success);padding:.35rem .75rem;border-radius:999px}.cert-badge-check{font-size:.9em;line-height:1}.additional-expertise{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem}.additional-expertise-title{margin:0 0 1.25rem;font-size:1.5rem;font-weight:700;text-align:center}.expertise-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:640px){.expertise-grid{grid-template-columns:1fr}}.expertise-item{background:transparent;border:none;border-radius:0;padding:0}.expertise-item-title{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;margin:0 0 .35rem}.expertise-item-check{color:var(--success);font-size:1em;flex-shrink:0}.expertise-item p{margin:0 0 0 1.6rem;font-size:.9rem;color:var(--text-muted);line-height:1.5}.news-list{display:grid;gap:1.5rem}.news-card{display:grid;grid-template-columns:1fr;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden}.news-card-top{display:grid;grid-template-columns:minmax(160px,280px) 1fr;min-height:0}@media(max-width:768px){.news-card-top{grid-template-columns:1fr}}.news-card-media{position:relative;min-height:140px;background:var(--bg-elevated)}.news-card-media img{width:100%;height:100%;min-height:140px;object-fit:cover;display:block}.news-card-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:.9rem;background:var(--bg-elevated)}.news-card-body{padding:1.5rem;display:flex;flex-direction:column;align-items:flex-start}.news-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted);margin-bottom:.5rem}.news-type{color:var(--accent)}.news-card h3{margin:0 0 .5rem;font-size:1.1rem}.news-excerpt{margin:0 0 1rem;color:var(--text-muted);line-height:1.5;flex:1}.news-read-more{margin-top:auto;font-size:.85rem;font-weight:700;padding:.5rem 1rem}.news-card p{margin:0 0 .5rem;color:var(--text-muted);line-height:1.5}.news-full{margin:0;padding:1.5rem 2rem;border-top:1px solid var(--border);grid-column:1 / -1}.news-full p{margin-bottom:1rem}.news-no-article{color:var(--text-muted);font-style:italic;margin:0}.comments h4{margin:1rem 0 .5rem;font-size:.95rem}.comment{margin-bottom:1rem;padding:.75rem;background:var(--bg-elevated);border-radius:8px}.comment strong,.comment span{margin-right:.5rem}.comment-form input,.comment-form textarea{display:block;width:100%;margin-bottom:.75rem;padding:.5rem;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text);font-family:inherit}.testimonial-carousel{position:relative}.carousel-track{position:relative;overflow:hidden;margin-bottom:1.5rem;height:240px;min-height:240px}.carousel-controls{display:flex;align-items:center;justify-content:center;gap:1.5rem}.carousel-btn{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,color .2s}.carousel-btn:hover{background:var(--bg-elevated);border-color:var(--accent);color:var(--accent)}.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2rem;margin:0;border-left:4px solid var(--accent);position:absolute;left:0;right:0;top:0;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .35s ease,visibility .35s ease;text-align:center;box-shadow:0 2px 8px #0000000f,0 8px 24px #00000014}.testimonial-card.active{opacity:1;visibility:visible;pointer-events:auto}.testimonial-card p{font-size:1.1rem;line-height:1.65;margin:0 0 1rem;font-style:italic;color:var(--text-muted)}.testimonial-card footer{font-size:.9rem;text-align:center}.testimonial-card footer strong{display:block}.testimonial-card footer span{display:block;color:var(--text-muted)}.carousel-dots{display:flex;align-items:center;justify-content:center;gap:.5rem}.carousel-dot{height:6px;width:24px;border-radius:999px;border:none;background:var(--bg-elevated);cursor:pointer;transition:width .25s ease,background .2s}.carousel-dot:hover{background:var(--text-muted)}.carousel-dot.active{width:40px;background:var(--accent)}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}@media(max-width:700px){.contact-grid{grid-template-columns:1fr}}.contact-touch-title{margin:0 0 .75rem;font-size:1.5rem;font-weight:700}.contact-blurb{margin:0 0 1.5rem;font-size:1.1rem;color:var(--text-muted);line-height:1.65}.contact-info p{margin-bottom:1rem}.contact-info a{color:var(--accent);text-decoration:none}.contact-info a:hover{text-decoration:underline}.connect-social{margin-top:1.5rem!important;font-size:.9rem;color:var(--text-muted)}.contact-form input,.contact-form textarea{display:block;width:100%;margin-bottom:1rem;padding:.75rem;border-radius:8px;border:1px solid var(--border);background:var(--bg-card);color:var(--text);font-family:inherit}.contact-form textarea{resize:vertical;min-height:100px}.contact-form-status{margin:.75rem 0 0;font-size:.9rem}.contact-form-status--success{color:var(--accent)}.contact-form-status--error{color:#b91c1c}.footer{border-top:1px solid rgba(255,255,255,.12);padding:3rem clamp(1rem,4vw,1.5rem) 2rem;background:#111827;color:#ffffffe6}.footer-inner{max-width:min(1280px,98vw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:2rem 3rem;align-items:start}@media(max-width:768px){.footer-inner{grid-template-columns:1fr}}.footer .footer-logo{color:#fffffff2}.footer .logo-accent{color:var(--accent)}.footer-logo{display:inline-block;font-size:1.35rem;font-weight:700;letter-spacing:.02em;margin-bottom:.5rem}.footer-brand p{margin:0;font-size:.9rem;color:#ffffffb3;line-height:1.5}.footer-links h4,.footer-connect h4{margin:0 0 .75rem;font-size:.95rem;font-weight:600;color:#fffffff2}.footer-links button{display:block;background:none;border:none;color:#fff9;padding:.4rem 0;cursor:pointer;font-size:.9rem;text-align:left}.footer-links button:hover{color:var(--accent)}.footer-connect{text-align:left}.footer-social{display:flex;gap:1rem;justify-content:flex-start;align-items:center}.footer-social-link{color:#fff9;transition:color .2s}.footer-social-link:hover{color:var(--accent)}.footer-social-link svg{display:block;width:24px;height:24px}.footer-bottom{grid-column:1 / -1;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin:2rem 0 0;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12)}.footer-copy,.footer-built{margin:0;font-size:.85rem;color:#fff9}
