
  :root {
    --reunion-green: #08623E;
    --reunion-red: #B00020;
    --reunion-gold: #F7F1E3;
    --reunion-border: #1f6b3d;
    --reunion-text: #222;
  }

  .reunion-home,
  .reunion-home * {
    box-sizing: border-box;
  }

  .reunion-home {
    width: min(100%, 1180px);
    margin: 0 auto;
    padding: clamp(16px, 3vw, 36px);
    color: var(--reunion-text);
    font-family: Montserrat, Arial, Helvetica, sans-serif;
    line-height: 1.55;
  }

  .reunion-home a:link,
  .reunion-home a:visited {
    color: var(--reunion-green);
    text-decoration: none;
    font-weight: 700;
    overflow-wrap: anywhere;
  }

  .reunion-home a:hover,
  .reunion-home a:focus {
    color: #E81216;
    text-decoration: underline;
  }

  .reunion-hero {
    text-align: center;
    margin: 0 auto clamp(20px, 4vw, 40px);
  }

  .reunion-hero h1 {
    margin: 0 0 .45em;
    font-size: clamp(1.75rem, 5vw, 3.25rem);
    line-height: 1.08;
    color: var(--reunion-green);
  }

  .reunion-hero h2,
  .reunion-hero h3 {
    margin: .25em 0;
    font-size: clamp(1.05rem, 2.8vw, 1.55rem);
    line-height: 1.25;
  }

  .reunion-intro {
    max-width: 920px;
    margin: 0 auto clamp(18px, 3vw, 28px);
    font-weight: 700;
    font-size: clamp(1rem, 2.2vw, 1.12rem);
  }

  .reunion-callout {
    width: min(100%, 920px);
    margin: 0 auto clamp(24px, 4vw, 36px);
    padding: clamp(14px, 3vw, 24px);
    border: 3px solid var(--reunion-red);
    background: #fff;
    text-align: center;
    font-size: clamp(1rem, 2.3vw, 1.2rem);
    font-weight: 700;
  }

  .reunion-card {
    width: 100%;
    margin: 0 auto clamp(24px, 4vw, 40px);
    padding: clamp(16px, 3vw, 28px);
    border: 3px solid var(--reunion-border);
    background: #fff;
  }

  .reunion-donation {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: clamp(16px, 4vw, 34px);
    align-items: center;
  }

  .reunion-donation h2 {
    margin: 0 0 .35em;
    text-align: center;
    font-size: clamp(1.7rem, 5vw, 3rem);
    line-height: 1.05;
    color: var(--reunion-red);
  }

  .reunion-donation p {
    margin: .7em 0;
    font-weight: 700;
  }

  .reunion-qr {
    text-align: center;
  }

  .reunion-qr img {
    display: block;
    width: min(200px, 42vw);
    height: auto;
    margin: 0 auto;
  }

  .reunion-feature {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 420px);
    gap: clamp(18px, 4vw, 36px);
    align-items: center;
    margin: 0 auto clamp(24px, 4vw, 42px);
  }

  .reunion-feature p {
    margin: 0;
    font-weight: 700;
    font-size: clamp(1rem, 2.2vw, 1.1rem);
  }

  .reunion-feature img,
  .reunion-logo img {
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
  }

  .reunion-media-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(16px, 3vw, 28px);
    margin: 0 auto clamp(28px, 5vw, 48px);
  }

  .reunion-video-card {
    text-align: center;
  }

  .reunion-video-card video {
    display: block;
    width: 100%;
    max-width: 360px;
    aspect-ratio: 16 / 9;
    height: auto;
    margin: 0 auto;
    background: #000;
  }

  .reunion-video-card p {
    margin: .75em auto 0;
    font-weight: 700;
    font-size: clamp(.95rem, 2vw, 1rem);
  }

  .reunion-logo {
    text-align: center;
    margin: clamp(18px, 4vw, 40px) auto 0;
  }

  .reunion-logo img {
    width: min(500px, 90vw);
  }

  @media (max-width: 820px) {
    .reunion-donation,
    .reunion-feature,
    .reunion-media-grid {
      grid-template-columns: 1fr;
    }

    .reunion-feature {
      text-align: center;
    }

    .reunion-donation {
      text-align: center;
    }
  }

  @media (max-width: 520px) {
    .reunion-home {
      padding-left: 12px;
      padding-right: 12px;
    }

    .reunion-card,
    .reunion-callout {
      border-width: 2px;
    }
  