/* Page background + base type */
body {
  background: linear-gradient(180deg, #f6f9fc 0%, #eef3f8 100%);
  padding: 48px 12px;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
    "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji",
    "Segoe UI Symbol";
  color: #1c2a3a;
}

/* Card shell */
.donation-card {
  background: #fff;
  border: 0;
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(27, 39, 51, 0.08);
  max-width: 760px;
  margin: 0 auto;
  overflow: hidden;
}

/* Header (logo + title) */
.donation-header {
  background: radial-gradient(
      1200px 300px at 10% -10%,
      #e9f5ff 0%,
      transparent 60%
    ),
    radial-gradient(900px 260px at 110% 0%, #f9eefc 0%, transparent 60%),
    #ffffff;
  padding: 20px;
  padding-bottom: 0;
  text-align: center;
  border-bottom: 1px solid #eef2f7;
}

.logo {
  display: block;
  margin: 0 auto 10px;
  max-height: 50px;
  width: auto;
}

.banner {
  display: block;
  margin: 2px auto 2px;
  max-width: 100%;
  height: auto;
  border-radius: 12px;
}

.donation-title {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 6px 0 4px;
  color: #1c2a3a;
}

.secure-note {
  font-size: 0.9rem;
  color: #5b6b7b;
}

.secure-note .lock {
  margin-right: 6px;
}

/* Campaign copy */
.campaign {
  /* padding: 18px 28px 0; */
  padding: 5px 28px 0;
  color: #445567;
}

.divider {
  height: 1px;
  background: #eef2f7;
  margin: 18px 0;
}

/* Form area */
.px-4.pb-3 {
  padding-left: 28px !important;
  padding-right: 28px !important;
  padding-bottom: 22px !important;
}

.form-group label {
  font-weight: 600;
  color: #2b3b4e;
  margin-bottom: 6px;
}

.form-control {
  height: 46px;
  border-radius: 10px;
  border: 1px solid #d9e2ec;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-control:focus {
  border-color: #6aa7ff;
  box-shadow: 0 0 0 0.2rem rgba(38, 143, 255, 0.15);
}

textarea.form-control {
  height: auto;
  min-height: 100px;
  padding-top: 10px;
  padding-bottom: 10px;
}

/* Error styles */
.errorlist {
  color: #dc3545;
  font-size: 0.875rem;
  margin: 6px 0 0;
  padding: 0;
  list-style: none;
}

.has-error .form-control {
  border-color: #dc3545;
  box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.1);
}

.form-group input.is-invalid,
.form-group textarea.is-invalid,
.form-group select.is-invalid {
  border-color: #dc3545;
}

/* Buttons */
.btn-donate {
  font-weight: 700;
  letter-spacing: 0.2px;
  padding: 12px 18px;
  border-radius: 12px;
}

.btn-light {
  border: 1px solid #e1e7ef;
  color: #2b3b4e;
}

/* Step hint (optional, looks nice) */
.step-hint {
  font-size: 0.9rem;
  color: #6b7c8f;
  padding: 0 28px 6px;
}

/* Small screens */
@media (max-width: 480px) {
  .donation-title {
    font-size: 1.3rem;
  }

  .px-4.pb-3 {
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .campaign {
    padding-left: 18px;
    padding-right: 18px;
  }
}
