/* Success overlay UI. JS owns behavior only. */
body.form-success-open { overflow: hidden; }

.form-success-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(16, 31, 23, 0.82);
  backdrop-filter: blur(8px);
}

.form-success-dialog {
  width: min(720px, 100%);
  padding: clamp(26px, 5vw, 46px);
  border-radius: 30px;
  color: var(--ink);
  background: linear-gradient(180deg, rgba(255, 252, 245, 0.98), rgba(255, 246, 225, 0.98));
  box-shadow: 0 34px 90px rgba(0, 0, 0, 0.34);
  text-align: center;
}

.form-success-mark {
  width: 76px;
  height: 76px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 50%;
  color: var(--gold-light);
  background: var(--green-dark);
  font-size: 2.4rem;
  font-weight: 700;
  box-shadow: 0 18px 36px rgba(29, 74, 49, 0.28);
}

.form-success-dialog h2 {
  margin: 0 0 14px;
  color: var(--green-dark);
  font-size: clamp(2rem, 5vw, 3rem);
}

.form-success-dialog p {
  max-width: 560px;
  margin: 0 auto;
  color: var(--muted);
  font-size: clamp(1rem, 2.5vw, 1.18rem);
  line-height: 1.65;
}

.form-success-actions {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 26px;
}

.form-success-close,
.form-success-call {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 22px;
  border-radius: 999px;
  font-weight: 700;
}

.form-success-close {
  border: 0;
  color: var(--gold-light);
  background: var(--green-dark);
  cursor: pointer;
}

.form-success-call {
  border: 1px solid rgba(150, 103, 8, 0.28);
  color: #74520d;
  background: rgba(255, 255, 255, 0.8);
}

.form-status:not(:empty) {
  padding: 14px 16px;
  border-radius: 16px;
  line-height: 1.55;
}

.form-status.is-success {
  color: var(--green-dark);
  background: rgba(46, 103, 69, 0.1);
  border: 1px solid rgba(46, 103, 69, 0.22);
}

.form-status.is-error {
  color: #aa2e29;
  background: rgba(170, 46, 41, 0.08);
  border: 1px solid rgba(170, 46, 41, 0.2);
}

@media (max-width: 520px) {
  .form-success-overlay { align-items: end; padding: 14px; }
  .form-success-dialog { border-radius: 26px 26px 20px 20px; }
  .form-success-actions { flex-direction: column; }
  .form-success-close,
  .form-success-call { width: 100%; }
}
