:root {
  --bg: #f7f4ee;
  --bg2: #efe9df;
  --ink: #1a1814;
  --muted: #5c574c;
  --line: #d4ccc0;
  --accent: #8b7355;
  --font-display: "Montserrat", "Georgia", serif;
  --font-body: "Open Sans", system-ui, sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.65;font-size:1.02rem}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block;border-radius:4px}
.container{max-width:1040px;margin:0 auto;padding:0 22px}
header{position:sticky;top:0;z-index:40;background:rgba(247,244,238,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 0;flex-wrap:wrap}
.brand{font-family:var(--font-display);font-weight:600;font-size:1.05rem;letter-spacing:-0.02em}
.brand span{opacity:.45;margin:0 .35em}
nav{display:flex;gap:1.25rem;flex-wrap:wrap;font-size:.88rem}
nav a{color:var(--muted)}
nav a:hover{color:var(--ink)}
.hero{padding:4.5rem 0 3rem}
.hero-kicker{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.75rem}
.hero h1{font-family:var(--font-display);font-weight:500;font-size:clamp(2.4rem,6vw,3.75rem);line-height:1.08;letter-spacing:-0.03em}
.hero .role{font-family:var(--font-display);font-size:clamp(1.15rem,2.5vw,1.45rem);color:var(--muted);margin-top:.35rem;font-weight:400}
.hero p.tagline{max-width:34rem;margin-top:1.35rem;color:var(--muted);font-size:1.05rem}
.hero .cta{margin-top:1.75rem;display:inline-block;padding:12px 26px;border:1px solid var(--ink);color:var(--ink);font-size:.9rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.hero .cta:hover{background:var(--ink);color:var(--bg);text-decoration:none}
section{padding:3.5rem 0}
section h2{font-family:var(--font-display);font-size:clamp(1.65rem,3vw,2.1rem);font-weight:500;margin-bottom:1.25rem}
.about-bio{max-width:40rem;color:var(--muted)}
.skills{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}
.skills span{font-size:.8rem;padding:.35rem .7rem;border:1px solid var(--line);border-radius:999px;color:var(--muted)}
.avail{margin-top:1.5rem;font-size:.92rem;color:var(--accent);font-weight:500}
.proj-list{display:grid;gap:1.25rem;margin-top:2rem}
.proj-card{display:grid;grid-template-columns:140px 1fr;gap:0;overflow:hidden;border:1px solid var(--line);border-radius:6px;background:#fff}
@media(max-width:700px){.proj-card{grid-template-columns:1fr}}
.proj-swatch{width:100%;min-height:100%;background:var(--pcolor,#ccc)}
.proj-swatch img{width:100%;height:100%;object-fit:cover;min-height:140px}
.proj-body{padding:1.25rem 1.35rem}
.proj-meta{display:flex;gap:.75rem;flex-wrap:wrap;align-items:baseline;font-size:.8rem;color:var(--muted);margin-bottom:.35rem}
.proj-meta .cat{font-weight:600;color:var(--ink)}
.proj-body h3{font-family:var(--font-display);font-size:1.2rem;font-weight:500;margin-bottom:.5rem}
.proj-body p{font-size:.92rem;color:var(--muted)}
.proj-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.75rem}
.proj-tags span{font-size:.68rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-top:2rem}
.svc{border:1px solid var(--line);border-radius:6px;padding:1.48rem;background:#fff}
.svc .ic{font-family:var(--font-display);font-size:1.5rem;margin-bottom:.65rem;color:var(--accent)}
.svc h3{font-family:var(--font-display);font-size:1.05rem;margin-bottom:.5rem}
.svc p{font-size:.9rem;color:var(--muted)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem}
@media(max-width:720px){.contact-grid{grid-template-columns:1fr}}
.contact-block p{margin-bottom:.65rem;font-size:.95rem}
.contact-block .lab{color:var(--muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}
.social-row{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem}
footer{padding:2.5rem 0 3rem;border-top:1px solid var(--line);margin-top:2rem;text-align:center;font-size:.85rem;color:var(--muted)}
footer p + p{margin-top:.5rem}
.fade-up{opacity:0;transform:translateY(14px);transition:opacity .55s ease,transform .55s ease}
.fade-up.visible{opacity:1;transform:none}
