:root {
  --ink: #17302d;
  --muted: #62706d;
  --paper: #fbf7ef;
  --paper-strong: #fffdf8;
  --jade: #0e534f;
  --jade-soft: #d8ebe7;
  --gold: #c79044;
  --rose: #a94d4b;
  --shadow: 0 24px 70px rgba(25, 45, 43, .18);
  --radius: 24px;
  --max: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--ink);
  background: var(--paper);
  line-height: 1.65;
}
img { max-width: 100%; display: block; }
a { color: inherit; }
.container { width: min(calc(100% - 40px), var(--max)); margin-inline: auto; }
.skip-link { position:absolute; left:-999px; top: 16px; background:#fff; padding:10px 14px; z-index: 999; }
.skip-link:focus { left:16px; }

.site-header {
  position: fixed; inset: 0 0 auto 0; height: 76px; z-index: 20;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding: 0 clamp(20px, 5vw, 58px);
  transition: background .25s ease, box-shadow .25s ease;
  color: #fff;
  background-color: #17302d;
}
.site-header.scrolled { background: rgba(251,247,239,.92); color: var(--ink); box-shadow: 0 10px 40px rgba(32, 47, 43, .1); backdrop-filter: blur(14px); }
.brand { display:flex; align-items:center; gap:12px; text-decoration:none; font-weight:700; letter-spacing:.02em; }
.brand-mark { display:grid; place-items:center; width:42px; height:42px; border:1px solid currentColor; border-radius: 999px; font-size:.78rem; }
.site-nav { display:flex; align-items:center; gap:22px; font-size:.95rem; }
.site-nav a { text-decoration:none; opacity:.9; }
.site-nav a:hover { opacity:1; }
.nav-cta { border:1px solid currentColor; border-radius:999px; padding:8px 14px; }
.nav-toggle { display:none; background:transparent; border:0; width:42px; height:42px; padding:8px; }
.nav-toggle span { display:block; height:2px; background:currentColor; margin:6px 0; }

.hero { min-height: 92vh; position:relative; overflow:hidden; display:grid; align-items:center; color:#fff; padding: 120px 0 80px; }
.hero-art, .hero-overlay { position:absolute; inset:0; }
.hero-art img { width:100%; height:100%; object-fit:cover; transform:scale(1.04); }
.hero-overlay { background: linear-gradient(90deg, rgba(16, 45, 42, .88) 0%, rgba(16, 45, 42, .64) 45%, rgba(16, 45, 42, .18) 100%), radial-gradient(circle at 76% 25%, rgba(199,144,68,.35), transparent 34%); }
.hero-content { position:relative; z-index:2; max-width: 760px; margin-left: max(20px, calc((100vw - var(--max)) / 2)); }
.eyebrow, .section-kicker { text-transform:uppercase; letter-spacing:.18em; font-size:.78rem; font-weight:800; color: var(--gold); margin:0 0 14px; }
h1, h2, h3 { line-height:1.05; margin:0; }
h1 { font-family: Georgia, "Times New Roman", serif; font-size: clamp(3rem, 8vw, 7.8rem); max-width: 880px; letter-spacing:-.055em; }
h2 { font-family: Georgia, "Times New Roman", serif; font-size: clamp(2rem, 4.8vw, 4.4rem); letter-spacing:-.04em; }
h3 { font-size: 1.1rem; letter-spacing:-.01em; }
.hero-copy { font-size: clamp(1.08rem, 2vw, 1.34rem); max-width: 680px; margin:24px 0 34px; color: rgba(255,255,255,.88); }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; }
.button { display:inline-flex; align-items:center; justify-content:center; min-height:48px; border-radius:999px; padding:0 20px; text-decoration:none; font-weight:800; }
.button-primary { background:#fff; color:var(--jade); }
.button-secondary { border:1px solid rgba(255,255,255,.65); color:#fff; }
.floating-card { position:absolute; z-index:3; width: min(210px, 22vw); padding:10px; background:rgba(255,255,255,.84); border-radius:20px; box-shadow: var(--shadow); backdrop-filter: blur(8px); }
.floating-card img { aspect-ratio: 4/3; object-fit:cover; border-radius:14px; }
.floating-card-one { right: 8vw; bottom: 13vh; transform: rotate(4deg); }
.floating-card-two { right: 24vw; top: 18vh; transform: rotate(-6deg); }

.intro { display:grid; grid-template-columns: .9fr 1.1fr; gap:60px; padding: 92px 0 62px; align-items:end; }
.intro p:last-child { font-size:1.2rem; color:var(--muted); margin:0; }

.gallery-section { padding: 58px 0 96px; background: linear-gradient(180deg, rgba(216,235,231,.55), rgba(251,247,239,0)); }
.section-heading { max-width: 760px; margin-bottom: 32px; }
.section-heading.centered { text-align:center; margin-inline:auto; }
.section-heading p:not(.section-kicker) { color: var(--muted); font-size:1.1rem; }
.filter-bar { display:flex; flex-wrap:wrap; gap:10px; margin-bottom: 28px; }
.filter { border:1px solid rgba(23,48,45,.16); background:rgba(255,255,255,.66); color:var(--ink); border-radius:999px; padding:10px 16px; cursor:pointer; font-weight:800; }
.filter.active, .filter:hover { background:var(--jade); color:#fff; }
.gallery-grid { display:grid; grid-template-columns: repeat(3, 1fr); grid-auto-flow:dense; gap:20px; }
.art-card { background:var(--paper-strong); border-radius: var(--radius); overflow:hidden; box-shadow: 0 16px 44px rgba(33, 57, 55, .09); border:1px solid rgba(23,48,45,.08); transition: transform .2s ease, opacity .2s ease; }
.art-card:hover { transform: translateY(-4px); }
.art-card.wide { grid-column: span 2; }
.art-card.tall { grid-row: span 2; }
.art-card.hidden { display:none; }
.art-image { display:block; padding:0; border:0; width:100%; background:transparent; cursor:zoom-in; }
.art-image img { width:100%; height:310px; object-fit:cover; }
.art-card.tall .art-image img { height:560px; }
.art-meta { padding:20px; }
.art-meta p { color:var(--muted); margin:.5rem 0 0; }
.gallery-footer { margin-top:24px; }
.text-link { color:var(--jade); font-weight:800; text-decoration-thickness: 2px; text-underline-offset: 5px; }

.story-section { display:grid; grid-template-columns: .85fr 1.15fr; gap:64px; align-items:center; padding: 95px 0; }
.story-image img { border-radius: 34px; box-shadow: var(--shadow); min-height: 520px; object-fit:cover; }
.story-copy p { color:var(--muted); font-size:1.05rem; }
.timeline { display:grid; grid-template-columns: repeat(2, 1fr); gap:14px; margin-top:28px; }
.timeline div { background:#fff; border:1px solid rgba(23,48,45,.08); border-radius:20px; padding:18px; }
.timeline span { display:block; font-weight:900; color:var(--jade); margin-bottom:6px; }
.timeline p { margin:0; font-size:.96rem; }

.recognition-section { padding: 92px 0; background: #112f2b; color:#fff; }
.recognition-section .section-heading p:not(.section-kicker) { color: rgba(255,255,255,.72); }
.recognition-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:18px; }
.recognition-card { padding:24px; border-radius:24px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.13); min-height: 280px; }
.card-number { display:inline-grid; place-items:center; width:44px; height:44px; border-radius:999px; background:rgba(255,255,255,.12); color:var(--gold); font-weight:900; margin-bottom:36px; }
.recognition-card p { color:rgba(255,255,255,.74); margin-bottom:0; }

.press-section { padding: 96px 0; }
.press-list { display:grid; gap:14px; }
.press-item { display:grid; grid-template-columns: 1.15fr 1.65fr auto; gap:24px; align-items:center; background:#fff; border:1px solid rgba(23,48,45,.08); border-radius:22px; padding:22px; box-shadow: 0 14px 38px rgba(33,57,55,.06); }
.press-year { display:inline-block; color:var(--rose); font-weight:900; letter-spacing:.08em; text-transform:uppercase; font-size:.72rem; margin-bottom:6px; }
.press-item p { margin:0; color:var(--muted); }
.press-item a { color:var(--jade); font-weight:900; white-space:nowrap; }

.gift-section { background: linear-gradient(135deg, var(--jade-soft), #f8ecda); padding: 88px 0; }
.gift-layout { display:grid; grid-template-columns: 1.1fr .9fr; gap:48px; align-items:center; }
.gift-layout p { font-size:1.12rem; color:var(--muted); }
.gift-card { background:rgba(255,255,255,.72); border:1px solid rgba(23,48,45,.08); border-radius:28px; padding:28px; box-shadow: var(--shadow); }
.gift-card ul { padding-left: 1.2rem; margin-bottom:0; color:var(--muted); }

.photo-strip { display:grid; grid-template-columns: repeat(4, 1fr); }
.photo-strip img { width:100%; height:310px; object-fit:cover; }
.site-footer { padding: 42px 0; background:#0b2421; color:#fff; }
.footer-layout { display:flex; align-items:center; justify-content:space-between; gap:24px; }
.site-footer h2 { font-size:1.6rem; letter-spacing:-.02em; }
.site-footer p { margin:.35rem 0 0; color:rgba(255,255,255,.7); }
.footer-links { display:flex; gap:18px; flex-wrap:wrap; }
.footer-links a { color:rgba(255,255,255,.8); text-decoration:none; }
.footer-links a:hover { color:#fff; }

.lightbox { border:0; padding:0; max-width:min(92vw, 1100px); max-height:90vh; background:transparent; }
.lightbox::backdrop { background:rgba(7, 25, 23, .82); backdrop-filter: blur(6px); }
.lightbox img { max-height:80vh; border-radius:22px; box-shadow: var(--shadow); }
.lightbox p { color:#fff; text-align:center; font-weight:800; }
.lightbox-close { position:fixed; top:22px; right:22px; width:44px; height:44px; border:0; border-radius:999px; background:#fff; font-size:28px; cursor:pointer; }

@media (max-width: 960px) {
  .site-nav { position:fixed; inset:76px 16px auto 16px; padding:18px; border-radius:20px; background:rgba(251,247,239,.96); color:var(--ink); box-shadow:var(--shadow); display:none; flex-direction:column; align-items:flex-start; }
  .site-nav.open { display:flex; }
  .nav-toggle { display:block; color:currentColor; }
  .floating-card { display:none; }
  .intro, .story-section, .gift-layout { grid-template-columns:1fr; gap:32px; }
  .gallery-grid, .recognition-grid { grid-template-columns: repeat(2, 1fr); }
  .press-item { grid-template-columns:1fr; gap:10px; }
  .photo-strip { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .site-header { height:68px; padding-inline:16px; }
  .brand-text { display:none; }
  .hero { min-height: 86vh; padding-top:110px; }
  h1 { font-size: clamp(3rem, 17vw, 4.8rem); }
  .gallery-grid { grid-template-columns: 1fr; }
  .art-card.wide, .art-card.tall { grid-column: span 1; grid-row: span 1; }
  .art-image img, .art-card.tall .art-image img { height: 330px; }
  .timeline, .recognition-grid { grid-template-columns:1fr; }
  .photo-strip { grid-template-columns:1fr; }
  .footer-layout { align-items:flex-start; flex-direction:column; }
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior:auto !important; transition:none !important; animation:none !important; }
}

/* Biography page */
.site-nav a[aria-current="page"] {
  opacity: 1;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-thickness: 2px;
}
.bio-page .site-header { color: #fff; }
.bio-hero {
  position: relative;
  overflow: hidden;
  min-height: 82vh;
  color: #fff;
  display: grid;
  align-items: center;
  padding: 126px 0 72px;
}
.bio-hero-art,
.bio-hero-overlay { position: absolute; inset: 0; }
.bio-hero-art img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); filter: saturate(1.06); }
.bio-hero-overlay {
  background:
    linear-gradient(90deg, rgba(14, 50, 47, .92), rgba(14, 50, 47, .72) 45%, rgba(14, 50, 47, .26)),
    radial-gradient(circle at 78% 28%, rgba(199, 144, 68, .42), transparent 34%);
}
.bio-hero-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.1fr .72fr;
  gap: clamp(34px, 6vw, 78px);
  align-items: center;
}
.bio-subtitle {
  max-width: 710px;
  color: rgba(255,255,255,.86);
  font-size: clamp(1.1rem, 2vw, 1.38rem);
  margin: 24px 0 34px;
}
.bio-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.bio-portrait-card {
  margin: 0;
  padding: 12px;
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(255,255,255,.55);
  border-radius: 30px;
  box-shadow: var(--shadow);
  transform: rotate(2deg);
}
.bio-portrait-card img {
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 22px;
}
.bio-portrait-card figcaption {
  color: var(--ink);
  font-weight: 900;
  text-align: center;
  padding: 14px 8px 6px;
  font-size: .94rem;
}
.bio-intro {
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 58px;
  padding: 88px 0 64px;
  align-items: start;
}
.bio-lede-card {
  position: sticky;
  top: 108px;
}
.bio-lede-copy {
  background: #fff;
  border: 1px solid rgba(23,48,45,.08);
  border-radius: 28px;
  padding: clamp(26px, 4vw, 46px);
  box-shadow: 0 16px 48px rgba(33,57,55,.07);
}
.bio-lede-copy p {
  color: var(--muted);
  font-size: 1.12rem;
}
.bio-lede-copy p:first-child::first-letter {
  float: left;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 4.5rem;
  line-height: .82;
  padding: .12rem .5rem 0 0;
  color: var(--gold);
}
.bio-highlights {
  padding: 30px 0 82px;
}
.highlight-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.highlight-grid article {
  background: linear-gradient(180deg, #fff, #fff8ec);
  border: 1px solid rgba(23,48,45,.08);
  border-radius: 24px;
  padding: 24px;
  box-shadow: 0 14px 40px rgba(33,57,55,.06);
}
.highlight-grid span {
  display: inline-grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: var(--jade-soft);
  color: var(--jade);
  font-weight: 950;
  margin-bottom: 24px;
}
.highlight-grid p { color: var(--muted); margin-bottom: 0; }
.bio-section { padding: 84px 0; }
.bio-section-heading {
  max-width: 880px;
  margin-bottom: 34px;
}
.bio-section-heading > p:not(.section-kicker),
.muted-copy { color: var(--muted); font-size: 1.05rem; }
.statement-card {
  position: relative;
  background: #112f2b;
  color: #fff;
  border-radius: 34px;
  padding: clamp(28px, 5vw, 58px);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.statement-card::before {
  content: "“";
  position: absolute;
  top: -32px;
  right: 34px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 12rem;
  line-height: 1;
  color: rgba(255,255,255,.08);
}
.statement-card p {
  color: rgba(255,255,255,.82);
  font-size: clamp(1.05rem, 1.8vw, 1.25rem);
  max-width: 900px;
}
.cv-layout {
  display: grid;
  grid-template-columns: 250px 1fr;
  gap: 28px;
  align-items: start;
}
.cv-nav {
  position: sticky;
  top: 106px;
  display: grid;
  gap: 8px;
  background: rgba(255,255,255,.7);
  border: 1px solid rgba(23,48,45,.08);
  border-radius: 24px;
  padding: 14px;
  box-shadow: 0 14px 36px rgba(33,57,55,.06);
}
.cv-nav a {
  text-decoration: none;
  color: var(--ink);
  font-weight: 850;
  border-radius: 16px;
  padding: 10px 12px;
}
.cv-nav a:hover,
.cv-nav a:focus { background: var(--jade-soft); color: var(--jade); }
.cv-content { display: grid; gap: 18px; }
.cv-panel {
  background: #fff;
  border: 1px solid rgba(23,48,45,.08);
  border-radius: 28px;
  padding: clamp(24px, 4vw, 40px);
  box-shadow: 0 14px 38px rgba(33,57,55,.055);
  scroll-margin-top: 104px;
}
.cv-panel h3 {
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(1.5rem, 2.4vw, 2.2rem);
  margin-bottom: 18px;
}
.elegant-list,
.year-stack ul {
  padding-left: 1.2rem;
  margin: 0;
  color: var(--muted);
}
.elegant-list li,
.year-stack li { margin: 0 0 .68rem; }
.two-column-list {
  columns: 2;
  column-gap: 36px;
}
.year-stack { display: grid; gap: 12px; }
.year-stack details {
  border: 1px solid rgba(23,48,45,.09);
  border-radius: 18px;
  padding: 0;
  overflow: hidden;
  background: #fffdf8;
}
.year-stack summary {
  cursor: pointer;
  list-style: none;
  padding: 16px 18px;
  font-weight: 950;
  color: var(--jade);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.year-stack summary::-webkit-details-marker { display: none; }
.year-stack summary::after {
  content: "+";
  display: inline-grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--jade-soft);
}
.year-stack details[open] summary::after { content: "–"; }
.year-stack details ul { padding: 0 22px 18px 38px; }
.tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.tag-cloud span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  border-radius: 999px;
  background: var(--jade-soft);
  color: var(--jade);
  padding: 6px 14px;
  font-weight: 850;
  font-size: .92rem;
}
.bio-closing {
  padding: 92px 0;
  background: linear-gradient(135deg, #112f2b, #0e534f);
  color: #fff;
}
.closing-grid {
  display: grid;
  grid-template-columns: .8fr 1.2fr;
  gap: 52px;
  align-items: center;
}
.closing-grid img {
  border-radius: 34px;
  box-shadow: var(--shadow);
  min-height: 420px;
  object-fit: cover;
}
.closing-grid p:not(.section-kicker) {
  color: rgba(255,255,255,.78);
  font-size: 1.14rem;
  max-width: 620px;
}

@media (max-width: 960px) {
  .bio-hero-grid,
  .bio-intro,
  .cv-layout,
  .closing-grid { grid-template-columns: 1fr; }
  .bio-lede-card,
  .cv-nav { position: static; }
  .highlight-grid { grid-template-columns: repeat(2, 1fr); }
  .cv-nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .bio-portrait-card { transform: none; max-width: 520px; }
}
@media (max-width: 640px) {
  .bio-hero { min-height: auto; padding-top: 110px; }
  .highlight-grid,
  .cv-nav { grid-template-columns: 1fr; }
  .two-column-list { columns: 1; }
  .bio-section { padding: 62px 0; }
}
