:root{color:#17211d;font-synthesis:none;text-rendering:optimizelegibility;background:#f6f7f3;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{scroll-behavior:smooth}body{background:linear-gradient(#e3ebe6b8,#0000 420px),#f6f7f3;min-width:320px;margin:0}a{color:inherit;text-decoration:none}button,a{-webkit-tap-highlight-color:transparent}.navbar{z-index:10;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#f6f7f3e6;border-bottom:1px solid #17211d14;justify-content:space-between;align-items:center;gap:1.5rem;padding:1rem clamp(1rem,5vw,5rem);display:flex;position:sticky;top:0}.logo{gap:.08rem;font-weight:800;display:grid}.logo span{line-height:1}.logo small{color:#53705f;letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;font-weight:700}.nav-links{flex-wrap:wrap;justify-content:flex-end;gap:.4rem;font-size:.9rem;display:flex}.nav-links a{color:#4c5f55;border-radius:999px;padding:.45rem .75rem;transition:background .18s,color .18s,transform .18s}.nav-links a:hover,.nav-links a:focus-visible{color:#1f4c36;background:#2d5e461a;transform:translateY(-1px)}.hero{background:radial-gradient(circle at 100% 0,#d9ead3,#0000 35%),linear-gradient(135deg,#f7f4ed 0%,#eef6ee 100%);justify-content:space-between;align-items:center;gap:3rem;min-height:78vh;padding:6rem 7%;display:flex}.hero-content{max-width:960px}.eyebrow{color:#557366;letter-spacing:.16em;text-transform:uppercase;margin:0 0 .95rem;font-size:.76rem;font-weight:800}h1,h2,h3,p{overflow-wrap:anywhere}h1{letter-spacing:-.055em;overflow-wrap:break-word;max-width:11ch;margin:1rem 0;font-size:clamp(2.35rem,9vw,6.5rem);line-height:.95}h2{color:#17211d;letter-spacing:0;margin:0;font-size:clamp(2rem,4vw,3.6rem);line-height:1.02}h3{color:#17211d;margin:0;font-size:1.12rem;line-height:1.25}.hero h2{color:#2f654d;max-width:15ch}.hero-text{color:#394d44;max-width:780px;margin:1.4rem 0 0;font-size:clamp(1.05rem,2vw,1.28rem);line-height:1.75}.hero-actions{flex-wrap:wrap;gap:.8rem;margin-top:2rem;display:flex}.btn{border:1px solid #28543e;border-radius:999px;justify-content:center;align-items:center;min-height:2.9rem;padding:.82rem 1.2rem;font-weight:800;transition:background .18s,box-shadow .18s,color .18s,transform .18s;display:inline-flex}.btn.primary{color:#fff;background:#28543e;box-shadow:0 16px 28px #28543e2e}.btn.secondary{color:#28543e;background:#ffffff80}.btn:hover,.btn:focus-visible{transform:translateY(-2px)}.btn.primary:hover,.btn.primary:focus-visible{background:#1f4432}.hero-profile-card{background:#ffffffb8;border:1px solid #17211d1a;border-radius:1.2rem;align-self:center;gap:1rem;width:min(340px,100%);padding:1rem;display:grid;box-shadow:0 24px 70px #17211d1a}.profile-photo-wrap{aspect-ratio:4/5;background:#dfe8e1;border-radius:.85rem;overflow:hidden}.profile-photo{object-fit:cover;width:100%;height:100%;display:block}.hero-panel{grid-template-columns:repeat(3,minmax(4.8rem,1fr));gap:.6rem;width:100%;display:grid;overflow:visible}.hero-panel div{text-align:center;background:#ffffffbf;border-radius:.75rem;align-content:center;place-items:center;gap:.24rem;min-width:0;padding:.7rem .45rem;display:grid}.hero-panel div+div{border-left:none}.hero-panel .metric{color:#284b34;font-size:clamp(1.1rem,2vw,1.45rem);font-weight:800;line-height:1}.hero-panel span:last-child{color:#596b62;text-transform:uppercase;letter-spacing:.05em;white-space:normal;overflow-wrap:break-word;max-width:100%;font-size:clamp(.62rem,1.4vw,.7rem);font-weight:700;line-height:1.35}.metric{color:#1e4f38;margin-bottom:.12rem;font-size:clamp(1.2rem,2vw,1.6rem);font-weight:800;line-height:1;display:block}.metric+span{text-transform:uppercase;letter-spacing:.08em;color:#5a6b61;font-size:.68rem;line-height:1.35;display:block}.section{padding:clamp(4rem,8vw,6.5rem) clamp(1rem,5vw,5rem)}.section-heading{max-width:900px;margin-bottom:2rem}.section-heading.split{grid-template-columns:minmax(0,.8fr) minmax(260px,.7fr);align-items:end;gap:1.5rem;max-width:none;display:grid}.section-heading p:not(.eyebrow),.section>p,.contact-section p{color:#45574f;max-width:760px;margin:0;font-size:1.02rem;line-height:1.75}.muted{background:#edf2ed}.card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.publication-grid,.skills-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.card{background:#ffffffe6;border:1px solid #17211d17;border-radius:.9rem;flex-direction:column;gap:1rem;min-height:100%;padding:1.35rem;transition:border-color .18s,box-shadow .18s,transform .18s;display:flex;box-shadow:0 16px 46px #17211d0f}.card:hover{border-color:#28543e47;transform:translateY(-4px);box-shadow:0 22px 58px #17211d1a}.focus-card{min-height:220px}.project-card{min-height:280px}.publication-card,.tutorial-card,.skill-card{min-height:235px}.card-header{color:#718177;justify-content:space-between;align-items:center;gap:.55rem;min-height:1.3rem;display:flex}.card-label,.card-header span{color:#557366;letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:.72rem;font-weight:850;line-height:1.35}.card-header span{color:#7b8d83;letter-spacing:.08em;text-align:right}.card p{color:#506158;margin:0;line-height:1.68}.tag-list{flex-wrap:wrap;gap:.5rem;margin-top:auto;display:flex}.tag-list span{color:#2e6048;background:#edf5ef;border:1px solid #28543e1a;border-radius:999px;padding:.42rem .62rem;font-size:.78rem;font-weight:760}.feature-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.feature-row article{border-top:1px solid #17211d29;padding-top:1.1rem}.feature-row span{color:#557366;margin-bottom:.75rem;font-weight:850;display:inline-block}.feature-row p{color:#52645b;margin:.75rem 0 0;line-height:1.65}.contact-section{color:#fff;background:#173025}.contact-section h2,.contact-section .eyebrow{color:#fff}.contact-section p{color:#ffffffc7;margin:1rem 0 2rem}.contact-section .btn.primary{color:#173025;background:#fff;border-color:#fff;max-width:100%}.footer{color:#ffffffad;background:#101815;border-top:1px solid #ffffff14;padding:1.7rem clamp(1rem,5vw,5rem)}.footer p{margin:0}.publication-card{flex-direction:column;gap:.6rem;display:flex}.pub-header{color:#4a5a4d;gap:.6rem;font-size:.85rem;display:flex}.pub-year{font-weight:600}.pub-journal{opacity:.7}.pub-role{color:#2f6f4f;font-size:.9rem;font-weight:500}.text-link{color:#2e6048;text-underline-offset:2px;font-size:.9rem;font-weight:700;-webkit-text-decoration:underline #2e604859;text-decoration:underline #2e604859;transition:color .18s}.text-link:hover,.text-link:focus-visible{color:#1f4432}.cookie-banner{z-index:50;background:#fff;border:1px solid #12201a1f;border-radius:1.25rem;justify-content:space-between;gap:1rem;max-width:980px;margin:0 auto;padding:1rem;display:flex;position:fixed;bottom:1rem;left:1rem;right:1rem;box-shadow:0 20px 60px #12201a2e}.cookie-banner p{color:#4b5f55;margin:.35rem 0 0;line-height:1.5}.cookie-actions{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.cookie-actions button{cursor:pointer}@media (width>=900px){.hero-panel div{text-align:center;justify-content:center}}@media (width<=700px){.cookie-banner{flex-direction:column}.cookie-actions{flex-wrap:wrap}}@media (width<=980px){.hero{flex-direction:column;align-items:center;min-height:auto}.hero-content{width:100%}.hero-photo-card,.hero-profile-card{margin-inline:auto}.hero-profile-card{width:min(520px,100%);max-width:520px}.profile-photo-wrap{aspect-ratio:16/11}.hero-panel{grid-template-columns:1fr}.hero-panel div{text-align:left;grid-template-columns:auto minmax(0,1fr);justify-items:start;gap:.75rem;padding-inline:.85rem}.card-grid,.project-grid,.feature-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=720px){.navbar{flex-direction:column;align-items:flex-start}.nav-links{justify-content:flex-start}.nav-links a{padding-left:0}.profile-photo-wrap{aspect-ratio:4/5;max-height:420px}.profile-photo{object-fit:cover;object-position:center top}h1{font-size:clamp(3rem,17vw,4.6rem)}.hero{padding-top:3.5rem}.hero-profile-card,.section-heading.split,.card-grid,.project-grid,.feature-row{grid-template-columns:1fr}.hero-panel{grid-template-columns:1fr;gap:.5rem}.hero-panel div{text-align:left;grid-template-columns:auto minmax(0,1fr);place-items:center start;gap:.75rem;min-height:0;padding:.75rem .85rem}.hero-panel div+div{border-top:1px solid #17211d14;border-left:0}.btn{width:100%}.card{border-radius:.8rem}}@media (width<=850px){.hero{flex-direction:column;align-items:center}.nav-links{flex-wrap:wrap}.card-grid,.project-grid,.feature-row{grid-template-columns:1fr}}@media (width<=520px){h1{letter-spacing:-.035em;max-width:100%;font-size:clamp(2rem,13vw,3.2rem)}.hero-text{font-size:1rem}.hero-profile-card{gap:.8rem;padding:.85rem}}
