/* ============================
   Buttons + CTA strip
   ============================ */

/* Buttons */
.cm-btn-primary,
.cm-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--cm-radius-pill);
  padding: .6rem 1.4rem;
  font-size: .9rem;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid transparent;
  transition: all .15s ease;
  white-space: nowrap;
}

.cm-btn-primary {
  background: var(--cm-brand-primary);
  color: #fff;
  box-shadow: 0 12px 30px rgba(62,121,209,0.35);
}

.cm-btn-primary:hover {
  background: var(--cm-brand-primary-strong);
  color: #fff;
  text-decoration: none;
  transform: translateY(-1px);
}

.cm-btn-secondary {
  background: #fff;
  color: #111827;
  border-color: rgba(15,23,42,0.16);
}

.cm-btn-secondary:hover {
  background: var(--cm-surface-soft);
  border-color: rgba(15,23,42,0.28);
}

/* Gradient CTA strip */
.cm-cta-strip {
  border-radius: 1.2rem;
  background: linear-gradient(135deg, var(--cm-brand-primary), #4f46e5);
  color: #e5e7eb;
  padding: 1.8rem 1.7rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}

@media (min-width: 768px) {
  .cm-cta-strip {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 2rem 2.3rem;
  }
}

.cm-cta-strip h3 {
  font-size: 1.25rem;
  margin: 0 0 .25rem;
  color: #f9fafb;
}

.cm-cta-strip p {
  margin: 0;
  font-size: .86rem;
  max-width: 24rem;
}

.cm-cta-strip-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
