*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{color:#111;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.container{width:90%;max-width:1100px;margin:auto}.nav{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-bottom:1px solid #eee;padding:16px 0;position:sticky;top:0}.nav-bar{flex-flow:wrap;justify-content:space-between;align-items:center;gap:1rem 1.5rem;display:flex}.nav-logo-link{flex-shrink:0;align-items:center;margin-right:auto;text-decoration:none;display:flex}.nav-logo{object-fit:contain;object-position:left center;width:auto;max-width:min(200px,45vw);height:44px;display:block}.nav-links{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:.5rem 1.5rem;display:flex}.nav-links a{color:#0ab8c4;font-size:.95rem;font-weight:500;text-decoration:none}.nav-links a[aria-current=page]{text-underline-offset:.2em;font-weight:700;text-decoration:underline}.hero{text-align:center;background-color:#e8eef0;background-image:linear-gradient(#ffffffd1,#ffffffd1),url("/images/Couple Portraits-6.jpg");background-position:50%;background-repeat:no-repeat;background-size:cover;padding:72px 0 28px;scroll-margin-top:88px;position:relative}.hero-inner{z-index:1;position:relative}.hero-name{letter-spacing:-.02em;color:#0dceda;margin-bottom:.5rem;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700}.hero-tagline{color:#0dceda;margin-bottom:1.25rem;font-size:clamp(1.1rem,2.5vw,1.35rem);font-weight:500}.hero-lead{color:#555;max-width:36rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;font-size:clamp(1rem,2vw,1.125rem)}.hero-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;display:flex}.btn{color:#fff;font:inherit;cursor:pointer;text-align:center;background:#0dceda;border:none;border-radius:6px;padding:12px 24px;font-size:.9375rem;font-weight:600;text-decoration:none;display:inline-block}.section{padding:72px 0}#aboutme.section{padding-top:32px;scroll-margin-top:88px}#projects,#roles,#publishing{scroll-margin-top:88px}.about-greeting{text-align:center;letter-spacing:-.02em;color:#0dceda;margin-bottom:1rem;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:700}.section-title{letter-spacing:-.02em;color:#0dceda;margin-bottom:.75rem;font-size:clamp(1.5rem,3vw,1.85rem);font-weight:700}.section-subtitle{color:#555;max-width:40rem;margin-bottom:2.5rem;font-size:1rem}.about-intro{color:#333;text-align:center;max-width:75ch;margin-bottom:3rem;margin-left:auto;margin-right:auto}.section-projects{background:#f7f7f8;border-top:1px solid #eee;border-bottom:1px solid #eee}.what-i-do-grid{grid-template-columns:repeat(5,1fr);align-items:stretch;gap:1rem;display:grid}.what-i-do-card{background:#fff;border:1px solid #0dceda;border-radius:8px;flex-direction:column;min-height:100%;padding:1.25rem 1rem;display:flex}.what-i-do-card-title{margin-bottom:.5rem;font-size:.95rem;font-weight:700;line-height:1.3}.what-i-do-card p{color:#444;flex:1;font-size:.875rem;line-height:1.5}.card{border:1px solid #eee;border-radius:8px;padding:20px}.projects-list{flex-direction:column;gap:1.5rem;display:flex}.project-card{background:#fff;border:1px solid #e5e5e7;border-radius:12px;flex-flow:row;align-items:stretch;gap:clamp(1.25rem,3vw,2.5rem);padding:clamp(1.25rem,3vw,2rem);display:flex;box-shadow:0 1px 2px #0000000a}.project-card-reverse{flex-direction:row-reverse}.project-card-media{background:#f0f0f2;border-radius:8px;flex:0 42%;align-self:stretch;min-width:0;overflow:hidden}.project-card-placeholder{background:linear-gradient(145deg,#0dceda24,#0dceda52);justify-content:center;align-items:center;min-height:200px;display:flex}.project-card-placeholder-label{color:#0dceda;letter-spacing:.06em;text-transform:uppercase;font-size:clamp(1.15rem,2.8vw,1.65rem);font-weight:800}.project-card-img{object-fit:cover;width:100%;height:100%;min-height:200px;max-height:320px;display:block}.project-card-body{flex-direction:column;flex:58%;align-items:flex-start;min-width:0;padding:.25rem 0;display:flex}.project-card-title{letter-spacing:-.02em;margin-bottom:.65rem;font-size:clamp(1.2rem,2.5vw,1.5rem);font-weight:700}.project-card-desc{color:#444;max-width:48ch;margin-bottom:0;font-size:1rem;line-height:1.65}.project-tags{flex-wrap:wrap;gap:.5rem;margin:1.25rem 0 0;padding:0;list-style:none;display:flex}.project-tags li,.role-pill{letter-spacing:.06em;text-transform:uppercase;color:#333;background:#fafafa;border:1px solid #d8d8dc;border-radius:999px;padding:.35rem .75rem;font-size:.7rem;font-weight:600}.buy-btn{margin-top:1.25rem}.roles-card{background:#fff;border:1px solid #e5e5e7;border-radius:12px;box-shadow:0 1px 2px #0000000a}.roles-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem;margin:0;padding:0;list-style:none;display:grid}.role-pill{text-align:center;justify-content:center;align-items:center;min-height:2.25rem;display:flex}a:not(.btn):link,a:not(.btn):visited{color:#111;text-align:inherit;text-underline-offset:2px;background-color:#0000;border:none;padding:0;text-decoration:underline;display:inline}a:not(.btn):hover,a:not(.btn):active{color:#0dceda}.resume-inline-link{text-underline-offset:.2em;font-weight:600;text-decoration:underline}.resume-page{max-width:75ch;margin-left:auto;margin-right:auto}.resume-section-title-spaced{margin-top:2.5rem}.resume-card-prose{background:#fff;border:1px solid #e5e5e7;border-radius:8px;padding:1.25rem 1.5rem;box-shadow:0 1px 2px #0000000a}.resume-prose{color:#333;margin:0;line-height:1.65}.resume-prose-tight{font-size:1rem}.resume-ul{margin:0 0 1rem 1.25rem;padding:0}.resume-ul-tight li{color:#444;margin-bottom:.4rem;line-height:1.55}.footer{text-align:center;color:#555;border-top:1px solid #eee;padding:32px 0;font-size:.9rem}@media (max-width:1024px){.what-i-do-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:720px){.what-i-do-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:700px){.project-card,.project-card-reverse{flex-direction:column}.project-card-media{flex-basis:auto;width:100%}.project-card-img{max-height:240px}.roles-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:420px){.what-i-do-grid{grid-template-columns:1fr}}
