/* CTA v12 — dual panel: copy vs accent field */

.cta-v12 {
  padding: 0;
  overflow: hidden;
}

.cta-v12 .cta-v12__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  min-height: min(280px, 50vw);
  max-width: 64rem;
  margin: 0 auto;
}

.cta-v12 .cta-v12__left {
  padding: clamp(1.75rem, 4vw, 2.75rem) clamp(1.25rem, 4vw, 2.5rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  background: linear-gradient(165deg, color-mix(in srgb, var(--cta-accent) 12%, var(--cta-bg)) 0%, var(--cta-bg) 100%);
  border-right: 1px solid color-mix(in srgb, var(--cta-accent) 18%, transparent);
}

.cta-v12 .cta-v12__right {
  background:
    linear-gradient(160deg, transparent 0%, color-mix(in srgb, var(--cta-accent) 8%, transparent) 100%),
    radial-gradient(ellipse 80% 60% at 70% 40%, color-mix(in srgb, var(--cta-accent) 22%, transparent), transparent 65%),
    color-mix(in srgb, #000 25%, var(--cta-bg));
}

.cta-v12 .cta-v12__title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.3rem, 3.2vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.cta-v12 .cta-v12__sub {
  margin: 0 0 1.25rem;
  font-size: clamp(0.88rem, 2vw, 1.02rem);
  line-height: 1.5;
  opacity: 0.88;
}

.cta-v12 .cta-v12__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

@media (max-width: 640px) {
  .cta-v12 .cta-v12__grid {
    grid-template-columns: 1fr;
  }

  .cta-v12 .cta-v12__right {
    min-height: 120px;
  }

  .cta-v12 .cta-v12__left {
    border-right: none;
    border-bottom: 1px solid color-mix(in srgb, var(--cta-accent) 18%, transparent);
  }
}
