/* CTA v14 — vertical accent rail + content */

.cta-v14 {
  padding-left: 0;
  padding-right: 0;
}

.cta-v14 .cta-v14__wrap {
  display: flex;
  align-items: stretch;
  max-width: 56rem;
  margin: 0 auto;
  min-height: min(220px, 40vw);
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--cta-accent) 22%, transparent);
  background: linear-gradient(105deg, color-mix(in srgb, var(--cta-accent) 8%, var(--cta-bg)), var(--cta-bg));
}

.cta-v14 .cta-v14__rail {
  flex: 0 0 clamp(6px, 1.2vw, 10px);
  background: linear-gradient(180deg, var(--cta-accent), color-mix(in srgb, var(--cta-accent) 45%, #000));
  box-shadow: 4px 0 24px color-mix(in srgb, var(--cta-accent) 25%, transparent);
}

.cta-v14 .cta-v14__body {
  flex: 1;
  padding: clamp(1.5rem, 4vw, 2.5rem) clamp(1.25rem, 4vw, 2.25rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cta-v14 .cta-v14__title {
  margin: 0 0 0.55rem;
  font-size: clamp(1.25rem, 3vw, 1.75rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.cta-v14 .cta-v14__sub {
  margin: 0 0 1.15rem;
  font-size: clamp(0.88rem, 2vw, 1.02rem);
  line-height: 1.5;
  opacity: 0.88;
  max-width: 36rem;
}

.cta-v14 .cta-v14__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
