:root {
  --lake: #5f8f97; --lake-dark: #2d4743; --cream: #f7f1e8; --paper: #fffaf3;
  --driftwood: #8a7867; --rust: #a95e3b; --gold: #d7a84b; --ink: #22302f;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--cream); font-family: Arial, Helvetica, sans-serif; line-height: 1.6; }
h1, h2, h3 { font-family: Georgia, "Times New Roman", serif; line-height: 1.05; }
h1 { font-size: clamp(3rem, 8vw, 6.8rem); margin: 0 0 1rem; }
h2 { font-size: clamp(2.2rem, 4vw, 4rem); color: var(--lake-dark); margin: 0 0 1rem; }
h3 { font-size: 1.6rem; color: var(--lake-dark); }
img { max-width: 100%; display: block; }
.site-header { position: sticky; top: 0; z-index: 10; background: rgba(255,250,243,.96); border-bottom: 4px solid var(--gold); display: flex; justify-content: space-between; align-items: center; padding: .8rem 6vw; box-shadow: 0 4px 18px rgba(0,0,0,.08); }
.brand { display: flex; align-items: center; gap: .8rem; color: var(--lake-dark); font-weight: 800; text-decoration: none; letter-spacing: .04em; }
.brand img { width: 54px; height: 54px; border-radius: 50%; object-fit: cover; border: 2px solid var(--lake); }
nav { display: flex; gap: 1.2rem; flex-wrap: wrap; justify-content: flex-end; }
nav a { color: var(--lake-dark); text-decoration: none; font-weight: 800; font-size: .95rem; }
nav a:hover { color: var(--rust); }
.hero { min-height: 78vh; display: flex; align-items: center; padding: 8rem 6vw; color: white; background: linear-gradient(90deg, rgba(27,49,49,.82), rgba(27,49,49,.52), rgba(27,49,49,.15)), url("images/wharf-sign-entry.jpg"); background-size: cover; background-position: center; }
.hero-content { max-width: 850px; }
.lead { font-size: clamp(1.25rem, 2.2vw, 2rem); max-width: 760px; }
.eyebrow { text-transform: uppercase; letter-spacing: .18em; color: var(--rust); font-weight: 900; font-size: .82rem; margin-bottom: .8rem; }
.hero .eyebrow { color: var(--gold); }
.button-row { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; }
.button { display: inline-block; padding: .9rem 1.3rem; border-radius: 4px; text-decoration: none; font-weight: 900; letter-spacing: .03em; }
.button.primary { color: white; background: var(--rust); box-shadow: 5px 5px 0 var(--gold); }
.button.secondary { color: var(--lake-dark); background: var(--paper); border: 2px solid var(--lake); }
.section { padding: 5rem 6vw; }
.split, .donate, .calendar-section { display: grid; grid-template-columns: 1.05fr .95fr; gap: 3rem; align-items: center; }
.story { background: var(--lake-dark); color: white; }
.story h2 { color: var(--gold); }
.story p { max-width: 900px; font-size: 1.2rem; }
.image-card { margin: 0; background: var(--paper); padding: .8rem; box-shadow: 0 18px 38px rgba(0,0,0,.16); transform: rotate(1deg); }
.image-card img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.image-card figcaption { font-size: .92rem; padding: .8rem .4rem .2rem; color: var(--driftwood); font-style: italic; }
.image-card.small img { aspect-ratio: 5 / 3; }
.card-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; margin-top: 2rem; }
.card { background: var(--paper); padding: 1.5rem; border-top: 8px solid var(--lake); box-shadow: 0 10px 25px rgba(0,0,0,.09); }
.calendar-section { background: #e7d8c2; }
.calendar-box { background: var(--paper); padding: 2rem; border-left: 10px solid var(--lake); }
.month { font-family: Georgia, "Times New Roman", serif; font-size: 2rem; color: var(--lake-dark); margin-top: 0; }
.calendar-box ul { list-style: none; padding: 0; }
.calendar-box li { margin: .8rem 0; }
.calendar-box span { display: inline-block; min-width: 86px; font-weight: 900; color: var(--rust); }
.donate { background: var(--lake); color: white; }
.donate h2 { color: white; }
.donate .eyebrow { color: var(--gold); }
.gallery { background: var(--paper); }
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .8rem; }
.gallery-grid img { width: 100%; height: 280px; object-fit: cover; }
.contact { text-align: center; background: linear-gradient(rgba(247,241,232,.92), rgba(247,241,232,.92)), url("images/wharf-front-door.jpg"); background-size: cover; background-position: center; }
.contact p { max-width: 700px; margin-left: auto; margin-right: auto; }
footer { background: var(--lake-dark); color: white; text-align: center; padding: 2rem 6vw; }
.fine-print { color: #d9e5e2; font-size: .9rem; }
@media (max-width: 850px) {
  .site-header, .split, .donate, .calendar-section { display: block; }
  nav { margin-top: 1rem; justify-content: flex-start; }
  .hero { min-height: 70vh; padding-top: 6rem; }
  .image-card { margin-top: 2rem; transform: none; }
  .card-grid, .gallery-grid { grid-template-columns: 1fr; }
  .gallery-grid img { height: auto; }
}

.mission-card {
  margin-top: 1.5rem;
  padding: 1.25rem;
  background: var(--paper);
  border-left: 8px solid var(--gold);
  box-shadow: 0 8px 22px rgba(0,0,0,.08);
}

.mission-card h3 {
  margin-top: 0;
  margin-bottom: .4rem;
}

.mission-card p {
  margin-bottom: 0;
  font-weight: 800;
  color: var(--lake-dark);
}
