:root {
  --navy: #19395d;
  --navy-deep: #122844;
  --green: #4f7d3f;
  --green-dark: #3f6832;
  --text: #27323f;
  --muted: #5d6774;
  --paper: #f7f4ef;
  --paper-2: #faf8f4;
  --line: #dbe5ec;
  --shadow: 0 16px 34px rgba(17, 39, 63, 0.12);
  --card-shadow: 0 12px 28px rgba(24, 43, 62, 0.10);
  --radius: 18px;
  --max: 1160px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--text);
  background: var(--paper-2);
  font-family: "Inter", Arial, sans-serif;
  line-height: 1.55;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.container {
  width: min(calc(100% - 36px), var(--max));
  margin: 0 auto;
}
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  background: rgba(249, 247, 242, 0.94);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(25, 57, 93, 0.08);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 10px 0;
}
.brand img {
  width: 210px;
  max-width: 42vw;
}
.main-nav {
  display: flex;
  align-items: center;
  gap: 22px;
  font-size: 0.96rem;
  font-weight: 700;
  color: var(--navy);
}
.main-nav a:hover { color: #2f608d; }
.nav-donate {
  background: var(--green);
  color: #fff !important;
  padding: 11px 18px;
  border-radius: 999px;
  box-shadow: 0 8px 22px rgba(79, 125, 63, 0.28);
}
.nav-donate:hover { background: var(--green-dark); }

.hero {
  position: relative;
  overflow: hidden;
  min-height: 650px;
  background: linear-gradient(180deg, #d2dee8 0%, #f0f5f8 55%, var(--paper-2) 100%);
}
.hero-scene {
  position: absolute;
  inset: 0;
  background: url('assets/hero-scene.svg') center top / cover no-repeat;
  transform: scale(1.02);
}
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.22) 0%,
    rgba(0, 0, 0, 0.52) 38%,
    rgba(0, 0, 0, 0.60) 52%,
    rgba(0, 0, 0, 0.30) 100%
  );
  pointer-events: none;
}
.hero-content {
  position: relative;
  z-index:2;
  padding: 70px 0 150px;
  text-align: center;
}
.hero-copy {
  max-width: 900px;
  margin: 0 auto 32px;
  text-align: center;
  color: #fff;
  text-shadow: 0 3px 14px rgba(0,0,0,0.24);
}
.hero h1,
.why-section h2,
.focus-section h2,
.contact-section h2,
.why-section h3,
.focus-card h3 {
  font-family: "Cormorant Garamond", Georgia, serif;
}
.hero h1 {
  margin: 0 0 18px;
  font-size: clamp(2.7rem, 5vw, 4.7rem);
  line-height: 0.95;
  font-weight: 700;
}
.hero-copy p {
  margin: 0 auto 14px;
  max-width: 840px;
  font-size: clamp(1.05rem, 2vw, 1.4rem);
}
.hero-strong {
  font-weight: 800;
}
.signup-panel {
  max-width: 640px;
  margin: 28px auto 0;
  background: var(--green);
  color: #fff;
  border-radius: 16px;
  padding: 22px 22px 18px;
  box-shadow: 0 20px 35px rgba(35, 56, 25, 0.28);
}
.signup-panel h2 {
  margin: 0 0 14px;
  font-size: 2.05rem;
  line-height: 1;
  color: #fff;
}
.signup-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}
.signup-form input,
.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(18, 40, 68, 0.12);
  border-radius: 10px;
  padding: 16px 16px;
  font: inherit;
  color: var(--text);
  background: #fff;
}
.signup-form button,
.signup-form input[type=submit],
.contact-form button {
  border: 0;
  border-radius: 10px;
  background: #5b8b45;
  color: #fff;
  font: inherit;
  font-weight: 800;
  padding: 15px 28px;
  cursor: pointer;
}

.signup-form button:hover,
.signup-form input[type="submit"]:hover,
.contact-form button:hover {
  background: var(--green-dark);
}

/* Mailchimp-specific layout fixes */
.signup-form #mc_embed_signup_scroll {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.signup-form h2,
.signup-form .indicates-required,
.signup-form label,
.signup-form #mce-responses {
  grid-column: 1 / -1;
}

.signup-form .mc-field-group {
  margin: 0;
}

.signup-form .mc-field-group input {
  margin: 0;
}

.signup-form .clear {
  margin: 0;
}

.signup-form #mc-embedded-subscribe {
  width: auto;
  white-space: nowrap;
}

/* optional: hide label if you only want placeholder-style layout */
.signup-form .mc-field-group label {
  display: block;
  margin-bottom: 6px;
}

/* mobile stack */
@media (max-width: 640px) {
  .signup-form,
  .signup-form #mc_embed_signup_scroll {
    grid-template-columns: 1fr;
  }

  .signup-form #mc-embedded-subscribe {
    width: 100%;
  }
}

.signup-form .mc-field-group label {
  display: none;
}

.form-note {
  margin: 10px 0 0;
  font-size: 0.88rem;
  color: rgba(255,255,255,0.9);
}
.hero-curve {
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 138px;
  background: radial-gradient(160% 160% at 50% -35%, transparent 61%, var(--paper-2) 62%);
}

.section {
  padding: 62px 0;
}
.why-section {
  margin-top: -24px;
}
.why-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(260px, 0.7fr);
  gap: 32px;
  align-items: start;
}
.why-section h2,
.focus-section h2,
.contact-section h2 {
  margin: 0 0 20px;
  color: var(--navy);
  font-size: clamp(2.3rem, 4vw, 3.6rem);
  line-height: 0.98;
}
.why-copy > p,
.focus-intro p,
.focus-card p,
.contact-section p {
  font-size: 1.05rem;
}
.issue-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 26px;
  margin: 16px 0 14px;
}
.issue-columns h3 {
  margin: 0 0 10px;
  font-size: 1.35rem;
  color: var(--navy);
}
.issue-columns ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.issue-columns li {
  position: relative;
  margin-bottom: 12px;
  padding-left: 28px;
}
.issue-columns li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--green);
  font-weight: 900;
}
.spaced-top { margin-top: 39px; }
.highlight-line {
  margin: 18px 0 10px;
  color: var(--green);
  font-size: 1.22rem;
  font-weight: 800;
}
.why-logo-wrap {
  align-self: center;
}
.why-logo-wrap img {
  width: 100%;
  max-width: 330px;
  margin-left: auto;
}
.divider-wrap {
  margin-top: 28px;
}
.divider-wrap img {
  width: 100%;
  opacity: 0.9;
}

.focus-section {
  background: linear-gradient(180deg, #f3f1ee 0%, #f8f6f2 100%);
}
.focus-intro {
  max-width: 820px;
  text-align: center;
  margin-bottom: 28px;
}
.focus-intro p {
  margin: 0 auto;
  max-width: 720px;
}
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}
.focus-card {
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(25, 57, 93, 0.06);
  border-radius: 12px;
  padding: 24px 22px 22px;
  min-height: 230px;
  box-shadow: var(--card-shadow);
  text-align: center;
}
.card-img {
  width: 100%;
  height:55px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  color: var(--green);
  font-size: 1.35rem;
  font-weight: 800;
  margin-bottom: 14px;
}

.card-img img {
	height:55px;
	width: auto;
}

.focus-card h3 {
  margin: 0 0 10px;
  color: var(--navy);
  font-size: 1.9rem;
  line-height: 0.98;
}
.focus-card p { margin: 0; }
.who-block {
  max-width: 800px;
  text-align: center;
  margin-top: 36px;
  padding-top: 42px;
  border-top: 1px solid var(--line);
}

.donate-section {
  padding-top: 0;
  text-align: center;
}
.donate-inner {
  padding-top: 10px;
}
.donate-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: min(100%, 430px);
  padding: 18px 24px;
  border-radius: 12px;
  background: var(--green);
  color: #fff;
  font-size: 1.15rem;
  font-weight: 800;
  box-shadow: 0 18px 30px rgba(54, 93, 45, 0.2);
}
.donate-button:hover { background: var(--green-dark); }

.contact-section {
  padding-top: 34px;
}
.contact-inner {
  max-width: 860px;
  text-align: center;
}
.contact-form {
  margin-top: 24px;
}
.field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}
.contact-form textarea {
  resize: vertical;
  margin-bottom: 12px;
}
.contact-form button {
  min-width: 220px;
}
.contact-note {
  margin-top: 20px;
  color: var(--muted);
  font-size: 0.92rem;
}

@media (max-width: 900px) {
  .main-nav { display: none; }
  .hero-content { padding: 52px 0 118px; }
  .why-grid,
  .card-grid,
  .field-row {
    grid-template-columns: 1fr;
  }
  .issue-columns { grid-template-columns: 1fr; gap: 10px; }
  .spaced-top { margin-top: 0; }
  .why-logo-wrap img { margin: 0 auto; }
  .focus-card { min-height: auto; }
}

@media (max-width: 640px) {
  .container { width: min(calc(100% - 24px), var(--max)); }
  .brand img { width: 180px; }
  .hero h1 { font-size: 2.6rem; }
  .hero-copy p { font-size: 1.02rem; }
  .signup-panel { padding: 18px 14px 14px; }
  .signup-panel h2 { font-size: 1.75rem; }
  .signup-form { grid-template-columns: 1fr; }
  .signup-form button,
  .contact-form button,
  .donate-button { width: 100%; }
  .section { padding: 48px 0; }
  .focus-card h3 { font-size: 1.65rem; }
}
