  /* =========== Donate page hero (dedicated /#donate view) =========== */
  .donate-hero {
    padding: 72px 0 88px;
    display: block;
    border-bottom: 0;
  }
  .donate-head {
    max-width: 920px;
    margin: 0 auto 56px;
    text-align: center;
  }
  .donate-head .eyebrow { justify-content: center; display: inline-flex; }
  .donate-head h2 {
    font-family: var(--display); font-weight: 600;
    font-size: clamp(46px, 5.4vw, 88px);
    line-height: 0.96;
    letter-spacing: -0.018em;
    text-transform: uppercase;
    text-wrap: balance;
    color: var(--navy-deep);
    margin: 22px auto 0;
    max-width: 16ch;
  }
  .donate-head h2 .gold-script {
    color: var(--accent);
    font-family: "Barlow"; font-style: italic; font-weight: 500;
    text-transform: lowercase; letter-spacing: -0.02em;
    font-size: 1.02em;
  }
  .donate-head .lede {
    margin: 32px auto 0;
    font-size: 17px; line-height: 1.65;
    color: var(--navy-500);
    max-width: 56ch;
  }
  .donate-meta {
    margin-top: 44px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    border-top: 1px solid var(--rule-strong);
    border-bottom: 1px solid var(--rule-strong);
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
  }
  .donate-meta > div {
    padding: 22px 18px;
    border-right: 1px solid var(--rule);
    text-align: center;
  }
  .donate-meta > div:last-child { border-right: 0; }
  .donate-meta .l {
    font-family: var(--mono); font-size: 9.5px;
    letter-spacing: 0.24em; text-transform: uppercase;
    color: var(--steel-deep);
  }
  .donate-meta .v {
    font-family: var(--display); font-weight: 500;
    font-size: 18px; line-height: 1.2;
    margin-top: 10px; color: var(--navy-deep);
    text-transform: uppercase; letter-spacing: -0.003em;
  }
  .donate-tax-note {
    max-width: 56ch;
    margin: 22px auto 0;
    text-align: center;
    font-size: 13px;
    line-height: 1.6;
    color: var(--steel-deep);
  }

  /* Donation widget */
  .donator {
    background: rgba(8,22,41,0.45);
    border: 1px solid rgba(169,183,206,0.2);
    border-radius: 2px;
    padding: 28px;
    backdrop-filter: blur(8px);
  }
  .roller-label {
    font-family: var(--mono); font-size: 10.5px;
    letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--steel);
  }
  .amount-display {
    margin-top: 8px;
    display: flex; align-items: baseline; gap: 4px;
    font-family: var(--display);
    line-height: 1;
    border-bottom: 1px solid rgba(169,183,206,0.18);
    padding-bottom: 18px;
  }
  .amount-display .dollar { font-size: 48px; color: var(--steel); font-weight: 500; }
  .amount-display .amt {
    font-size: 110px; color: var(--ivory); font-weight: 600;
    letter-spacing: -0.03em; min-width: 150px;
  }
  .amount-display .usd {
    font-family: var(--mono); font-size: 12px;
    color: var(--steel); letter-spacing: 0.2em;
    align-self: center; margin-left: 12px;
  }

  .preset-grid {
    margin-top: 20px;
    display: grid; grid-template-columns: repeat(3,1fr); gap: 8px;
  }
  .preset {
    appearance: none; cursor: pointer;
    border: 1px solid rgba(169,183,206,0.25);
    background: transparent; color: var(--ivory);
    font-family: var(--display); font-weight: 500;
    font-size: 26px; letter-spacing: -0.01em;
    padding: 14px 10px;
    border-radius: 2px;
    transition: all .18s;
    position: relative;
  }
  .preset .s {
    display: block;
    font-family: var(--mono); font-weight: 400;
    font-size: 8.5px; letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--steel); margin-top: 4px;
  }
  .preset:hover { border-color: var(--steel); background: rgba(169,183,206,0.06); }
  .preset.active { background: var(--accent); color: var(--navy-deep); border-color: var(--accent); }
  .preset.active .s { color: rgba(8,22,41,0.7); }

  .preset.other {
    grid-column: span 3;
    display: flex; align-items: center;
    padding: 14px 16px;
  }
  .preset.other .pfx { color: var(--steel); margin-right: 6px; font-size: 24px; }
  .preset.other input.custom {
    flex: 1;
    background: transparent; border: 0; outline: 0;
    font-family: var(--display); font-weight: 500;
    font-size: 24px; color: var(--ivory);
    padding: 0;
  }
  .preset.other input.custom::placeholder { color: rgba(169,183,206,0.55); }
  .preset.other.active input.custom { color: var(--navy-deep); }
  .preset.other.active input.custom::placeholder { color: rgba(8,22,41,0.5); }
  .preset.other.active .pfx { color: var(--navy-deep); }

  .freq-tabs {
    margin-top: 14px;
    background: rgba(8,22,41,0.35);
    border: 1px solid rgba(169,183,206,0.18);
    border-radius: 999px;
    padding: 4px;
    display: flex;
  }
  .freq {
    flex: 1; appearance: none; border: 0; background: transparent;
    color: var(--steel);
    font-family: var(--cond); font-weight: 600;
    font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase;
    padding: 10px;
    border-radius: 999px;
    cursor: pointer;
  }
  .freq.active { background: var(--ivory); color: var(--navy-deep); }

  .roller-note {
    margin-top: 14px;
    display: flex; justify-content: space-between;
    font-family: var(--mono); font-size: 10px;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--steel);
  }

  .donate-submit {
    margin-top: 18px; width: 100%;
    appearance: none; border: 0; cursor: pointer;
    background: var(--accent); color: var(--navy-deep);
    font-family: var(--cond); font-weight: 700;
    font-size: 14px; letter-spacing: 0.22em; text-transform: uppercase;
    padding: 20px;
    border-radius: 2px;
    display: flex; align-items: center; justify-content: center; gap: 12px;
    transition: background .2s, transform .15s;
  }
  .donate-submit:hover { background: var(--accent-bright); transform: translateY(-1px); }

  .stripe-line {
    margin-top: 14px;
    font-family: var(--mono); font-size: 9.5px;
    letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--steel-deep);
    text-align: center;
  }
  .stripe-line svg { vertical-align: middle; margin-right: 6px; }
