/* GoedOnline — CTA + footer aesthetics. */

.section-cta {
  background: var(--color-slate-950);
  position: relative;
  overflow: hidden;
  padding-block: clamp(4.5rem, 9vw, 7rem);
}

.section-cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(80% 60% at 80% 100%, rgba(59, 98, 217, .15), transparent 60%);
  pointer-events: none;
}

.cta-split {
  --split-cols: 1fr 0.95fr;
  align-items: stretch;
  position: relative;
}

.cta-split__copy {
  --stack-space: var(--sp-5);
  max-width: 32rem;
}

.cta-split__lead {
  font-size: 1.0625rem;
  color: rgba(255, 255, 255, .72);
  line-height: var(--lh-relaxed);
  margin: 0;
}

.cta-split__usps {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin: var(--sp-2) 0 0;
  padding: 0;
  list-style: none;
  color: rgba(255, 255, 255, .65);
  font-size: 0.9375rem;
}

.cta-split__usps li {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.cta-split__usps li::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--color-cobalt-400);
  flex-shrink: 0;
}

.cta-form-card {
  position: relative;
  background:
    linear-gradient(165deg, #1A2845 0%, #131F38 50%, #0E1830 100%);
  color: #fff;
  border-radius: var(--r-2xl);
  padding: var(--sp-8) var(--sp-7) var(--sp-7);
  box-shadow:
    0 50px 100px -32px rgba(0, 0, 0, .65),
    inset 0 1px 0 rgba(255, 255, 255, .06);
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  isolation: isolate;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .06);
}

.cta-form-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(60% 50% at 30% 0%, rgba(59, 98, 217, .35), transparent 65%),
    radial-gradient(50% 60% at 100% 100%, rgba(110, 137, 230, .12), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

.cta-form-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255, 255, 255, .03) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255, 255, 255, .03) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse at 50% 0%, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 0%, #000 30%, transparent 75%);
  pointer-events: none;
  z-index: 0;
  opacity: .55;
}

.cta-form-card > * {
  position: relative;
  z-index: 1;
}

.cta-form-card__strip {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--color-cobalt-500) 0%, var(--color-cobalt-300) 50%, var(--color-cobalt-500) 100%);
  z-index: 2;
}

.cta-form-card__head {
  display: flex;
  gap: var(--sp-4);
  align-items: flex-start;
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.cta-form-card__icon {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, rgba(59, 98, 217, .35), rgba(59, 98, 217, .15));
  border: 1px solid rgba(110, 137, 230, .25);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.cta-form-card__title {
  margin: 0;
  font-size: 1.25rem;
  font-family: var(--font-display);
  letter-spacing: var(--tracking-tight);
  font-weight: var(--weight-bold);
  line-height: var(--lh-snug);
  color: #fff;
}

.cta-form-card__sub {
  font-size: 0.9375rem;
  color: rgba(255, 255, 255, .65);
  margin: 4px 0 0;
  line-height: var(--lh-relaxed);
}

.cta-form-card__legal {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 0.75rem;
  color: rgba(255, 255, 255, .6);
  line-height: var(--lh-snug);
}

.cta-form-card__legal::before {
  content: "";
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .08);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B5C4F0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='4' y='11' width='16' height='10' rx='2'/%3E%3Cpath d='M8 11V7a4 4 0 0 1 8 0v4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 9px;
  flex-shrink: 0;
}

/* Form fields op donkere card */
.cta-form-card .field label {
  font-size: 0.8125rem;
  font-weight: var(--weight-semibold);
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, .85);
  margin-bottom: var(--sp-1);
  display: inline-block;
}

.cta-form-card .field label .req {
  color: var(--color-cobalt-300);
}

.cta-form-card .input,
.cta-form-card input[type="text"],
.cta-form-card input[type="email"],
.cta-form-card textarea {
  background: rgba(255, 255, 255, .04);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: var(--r-md);
  padding: 0.85rem 1rem;
  font-size: 0.9375rem;
  color: #fff;
  transition: border-color var(--dur-2) var(--ease-out),
              background var(--dur-2) var(--ease-out),
              box-shadow var(--dur-2) var(--ease-out);
}

.cta-form-card .input::placeholder,
.cta-form-card input::placeholder,
.cta-form-card textarea::placeholder {
  color: rgba(255, 255, 255, .35);
}

.cta-form-card .input:hover,
.cta-form-card input:hover,
.cta-form-card textarea:hover {
  border-color: rgba(255, 255, 255, .2);
  background: rgba(255, 255, 255, .06);
}

.cta-form-card .input:focus,
.cta-form-card input:focus,
.cta-form-card textarea:focus {
  border-color: var(--color-cobalt-400);
  background: rgba(255, 255, 255, .08);
  box-shadow: 0 0 0 4px rgba(59, 98, 217, .22);
  outline: none;
}

.cta-form-card .field.has-error .input,
.cta-form-card .field.has-error input,
.cta-form-card .field.has-error textarea {
  border-color: rgba(226, 65, 90, .55);
  box-shadow: 0 0 0 3px rgba(226, 65, 90, .18);
}

.cta-form-card .field__error {
  color: #FFB4BD;
}

.cta-form-card .form {
  gap: var(--sp-4);
}

.cta-form-card .cluster--between {
  padding-top: var(--sp-4);
  border-top: 1px solid rgba(255, 255, 255, .08);
}

/* CTA-knop in de donkere card mag witter contrasteren */
.cta-form-card .btn--cta {
  --btn-bg: #fff;
  --btn-fg: var(--color-slate-900);
  --btn-bg-hover: var(--color-cream-50);
}

/* Feedback-blokken in donkere card */
.cta-form-card .form__feedback.is-success {
  background: rgba(31, 138, 92, .15);
  color: #B8F3D5;
  border-color: rgba(31, 138, 92, .35);
}

.cta-form-card .form__feedback.is-error {
  background: rgba(226, 65, 90, .15);
  color: #FFB4BD;
  border-color: rgba(226, 65, 90, .35);
}

@media (max-width: 720px) {
  .cta-form-card {
    padding: var(--sp-6) var(--sp-5);
  }
  .cta-form-card__head {
    padding-bottom: var(--sp-4);
  }
}

/* ============= Site footer ============= */

.site-footer {
  background: var(--color-slate-950);
  color: rgba(255, 255, 255, .65);
  padding-block: var(--sp-10) var(--sp-6);
  font-size: 0.9375rem;
  line-height: var(--lh-relaxed);
  border-top: 1px solid rgba(255, 255, 255, .04);
}

.site-footer__top {
  display: grid;
  gap: var(--sp-9);
  padding-bottom: var(--sp-7);
  border-bottom: 1px solid rgba(255, 255, 255, .06);
}

@media (min-width: 960px) {
  .site-footer__top {
    grid-template-columns: 1.1fr 2fr;
    align-items: start;
  }
}

.site-footer__brand {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  max-width: 26rem;
}

.site-footer__brand .site-logo,
.site-footer__brand .site-logo__wordmark,
.site-footer__brand .site-logo__svg {
  color: #fff;
}

.site-footer__brand .site-logo__wordmark i {
  color: var(--color-cobalt-400);
}

.site-footer__tagline {
  color: rgba(255, 255, 255, .55);
  font-size: 0.9375rem;
  line-height: var(--lh-relaxed);
  margin: 0;
}

.site-footer__social {
  display: flex;
  gap: var(--sp-2);
  margin-top: var(--sp-2);
}

.site-footer__social a {
  width: 36px;
  height: 36px;
  border-radius: var(--r-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, .04);
  color: rgba(255, 255, 255, .7);
  transition: background var(--dur-2) var(--ease-out),
              color var(--dur-2) var(--ease-out);
  border: 1px solid rgba(255, 255, 255, .06);
}

.site-footer__social a:hover {
  background: rgba(255, 255, 255, .08);
  color: #fff;
  border-color: rgba(255, 255, 255, .14);
}

.site-footer__cols {
  display: grid;
  gap: var(--sp-7);
}

@media (min-width: 720px) {
  .site-footer__cols {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1040px) {
  .site-footer__cols {
    grid-template-columns: repeat(4, 1fr);
  }
}

.site-footer__col h4 {
  color: #fff;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  margin: 0 0 var(--sp-4);
  font-weight: var(--weight-semibold);
}

.site-footer__col ul {
  display: grid;
  gap: var(--sp-2);
  margin: 0;
}

.site-footer__col a {
  color: rgba(255, 255, 255, .65);
  text-decoration: none;
  transition: color var(--dur-2) var(--ease-out);
}

.site-footer__col a:hover {
  color: #fff;
}

.site-footer__sub {
  color: rgba(255, 255, 255, .5);
  font-size: 0.8125rem;
  margin: 0 0 var(--sp-3);
  line-height: var(--lh-relaxed);
}

.site-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--sp-3);
  padding-top: var(--sp-6);
  color: rgba(255, 255, 255, .42);
  font-size: 0.8125rem;
}

.site-footer__bottom .payment-icons {
  color: rgba(255, 255, 255, .65);
  font-weight: var(--weight-medium);
}
