:root{
  --paper:#FBF9F5;
  --ink:#211B22;
  --ink-soft:#4D434E;
  --line:#E4DDD4;
  --ember:#D96B3B;
  --dusk:#8A4A52;
  --lilac:#8E8BC0;
  --gold:#E0A24A;
  --haze:#F2EBE2;
  --max:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:'Archivo',sans-serif;
  font-weight:300;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--ember);outline-offset:3px}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ---------- dot field (signature motif) ---------- */
.dotfield{display:flex;gap:10px;align-items:center}
.dotfield i{width:9px;height:9px;border-radius:50%;filter:blur(.4px);opacity:.9}
.dotfield i:nth-child(1){background:var(--gold)}
.dotfield i:nth-child(2){background:var(--ember)}
.dotfield i:nth-child(3){background:var(--dusk)}
.dotfield i:nth-child(4){background:var(--lilac)}
.dotfield i:nth-child(5){background:var(--ink)}

/* ---------- nav ---------- */
nav{
  position:sticky;top:0;z-index:50;
  background:rgba(251,249,245,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;padding:18px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
}
.nav-name{
  font-family:'Instrument Serif',serif;font-size:22px;letter-spacing:.01em;
}
.nav-links{display:flex;gap:28px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:400}
.nav-links a{color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--ember)}
@media(max-width:680px){.nav-links{gap:16px;font-size:11px}}

/* ---------- hero ---------- */
header.hero{padding:80px 0 0;border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:6fr 5fr;gap:64px;align-items:end;padding-bottom:48px}
@media(max-width:860px){.hero-grid{grid-template-columns:1fr;gap:44px;align-items:start}}
.hero-title{
  font-family:'Instrument Serif',serif;
  font-size:clamp(48px,6.6vw,92px);
  line-height:.98;letter-spacing:-.01em;font-weight:400;
}
.hero-title em{font-style:italic;color:var(--dusk)}
.hero-sub{
  margin-top:26px;display:flex;flex-wrap:wrap;align-items:center;gap:18px;
  font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:400;
}
.hero-art img{width:100%;height:auto;background:var(--haze)}
.hero-caption{
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding-top:12px;font-size:13px;color:var(--ink-soft);
}
.hero-caption strong{font-weight:500;color:var(--ink)}

/* ---------- sections ---------- */
section{padding:96px 0 0}
.eyebrow{
  display:flex;align-items:center;gap:16px;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);font-weight:500;
  margin-bottom:36px;
}
.eyebrow::after{content:"";flex:1;height:1px;background:var(--line)}
h2{
  font-family:'Instrument Serif',serif;font-weight:400;
  font-size:clamp(32px,4.4vw,52px);line-height:1.1;margin-bottom:28px;
}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:5fr 7fr;gap:64px;align-items:start}
@media(max-width:820px){.about-grid{grid-template-columns:1fr;gap:40px}}
.about-grid figure img{width:100%;height:auto}
.about-grid figcaption{margin-top:10px;font-size:12.5px;color:var(--ink-soft)}
.about-copy p{margin-bottom:20px;max-width:58ch}
.about-copy p:last-child{margin-bottom:0}
.pull{
  font-family:'Instrument Serif',serif;font-style:italic;
  font-size:clamp(21px,2.5vw,27px);line-height:1.4;color:var(--dusk);
  margin:8px 0 28px;max-width:30ch;
}

/* ---------- works ---------- */
.works-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 36px;margin-bottom:56px}
@media(max-width:900px){.works-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.works-grid{grid-template-columns:1fr}}
.work img{width:100%;height:auto;background:var(--haze)}
.work-caption{
  display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin-top:12px;font-size:13.5px;color:var(--ink-soft);
}
.work-caption strong{font-weight:500;color:var(--ink)}
.works-note{font-size:14px;color:var(--ink-soft);max-width:54ch}
.works-note a{border-bottom:1px solid var(--ember);color:var(--ink)}

/* ---------- family ---------- */
.family-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px 56px}
@media(max-width:900px){.family-grid{grid-template-columns:1fr}}
.family-card{border-top:2px solid var(--ink);padding-top:22px}
.family-card h3{font-family:'Instrument Serif',serif;font-weight:400;font-size:26px;margin-bottom:4px}
.family-role{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ember);font-weight:500;margin-bottom:14px}
.family-card p{font-size:14.5px;color:var(--ink-soft);margin-bottom:14px}
.family-links{font-size:13px}
.family-links a{color:var(--ink);border-bottom:1px solid var(--ember)}
.family-links a:hover{color:var(--ember)}

/* ---------- cv ---------- */
.cv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px}
@media(max-width:900px){.cv-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.cv-grid{grid-template-columns:1fr}}
.cv-col h3{
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;
  margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--line);
}
.cv-col ul{list-style:none;font-size:14.5px}
.cv-col li{margin-bottom:11px;display:flex;gap:14px}
.cv-col .yr{color:var(--ember);font-weight:400;min-width:38px;font-variant-numeric:tabular-nums}
.cv-foot{margin-top:48px;font-size:14px;color:var(--ink-soft)}
.cv-foot a{border-bottom:1px solid var(--ember);color:var(--ink)}

/* ---------- faq ---------- */
.faq-list details{border-bottom:1px solid var(--line)}
.faq-list summary{
  cursor:pointer;list-style:none;padding:20px 0;
  font-family:'Instrument Serif',serif;font-size:21px;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";color:var(--ember);font-size:24px;font-family:'Archivo',sans-serif;font-weight:300}
.faq-list details[open] summary::after{content:"−"}
.faq-list details p{padding:0 0 24px;max-width:68ch;font-size:15px;color:var(--ink-soft)}

/* ---------- contact ---------- */
.contact{
  margin-top:110px;background:var(--ink);color:var(--paper);
  padding:88px 0 64px;position:relative;overflow:hidden;
}
.contact::before{
  content:"";position:absolute;inset:auto 0 0 0;height:120px;pointer-events:none;opacity:.5;
  background:
    radial-gradient(circle 7px at 4% 70%, var(--ember) 60%, transparent 62%),
    radial-gradient(circle 6px at 12% 40%, var(--lilac) 60%, transparent 62%),
    radial-gradient(circle 8px at 21% 80%, var(--dusk) 60%, transparent 62%),
    radial-gradient(circle 6px at 30% 35%, var(--gold) 60%, transparent 62%),
    radial-gradient(circle 7px at 39% 70%, var(--ember) 60%, transparent 62%),
    radial-gradient(circle 6px at 49% 45%, var(--lilac) 60%, transparent 62%),
    radial-gradient(circle 8px at 58% 78%, var(--gold) 60%, transparent 62%),
    radial-gradient(circle 6px at 67% 38%, var(--dusk) 60%, transparent 62%),
    radial-gradient(circle 7px at 76% 72%, var(--ember) 60%, transparent 62%),
    radial-gradient(circle 6px at 85% 42%, var(--gold) 60%, transparent 62%),
    radial-gradient(circle 8px at 94% 75%, var(--lilac) 60%, transparent 62%);
  filter:blur(1px);
}
.contact h2{color:var(--paper)}
.contact p{max-width:52ch;color:#CFC8C4;margin-bottom:30px}
.contact .eyebrow{color:#A99FA0}
.contact .eyebrow::after{background:#3A323B}
.btn{
  display:inline-block;padding:14px 30px;border:1px solid var(--ember);
  color:var(--paper);font-size:13px;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  transition:background .2s,color .2s;
}
.btn:hover{background:var(--ember);color:var(--ink)}
footer{
  background:var(--ink);color:#8E8487;font-size:12.5px;
  padding:28px 0 36px;border-top:1px solid #3A323B;
}
.foot-inner{
  max-width:var(--max);margin:0 auto;padding:0 24px;
  display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
}

/* gentle reveal */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
