/*
 * Clarity Component: cta-closing
 * BEM-prefixed; only applies inside .cv-cta-closing.
 * Depends on: ../_shared/tokens.css for design tokens.
 *
 * Layout: two-column at ≥768px (content left, illustration right);
 * stacks on narrow viewports. Theme color comes from --cv-color-accent
 * so wrapping the section (or any ancestor) in .cv-theme-* swaps the
 * accent automatically.
 *
 * No JavaScript needed.
 */

.cv-cta-closing {
  font-family: var(--cv-font-family);
  color: var(--cv-color-text);
  padding: var(--cv-space-12, 60px) 0 var(--cv-space-16, 75px);
}

.cv-cta-closing__container {
  max-width: 1230px;
  margin: 0 auto;
  padding: 0 var(--cv-space-4, 15px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--cv-space-8, 32px);
}

.cv-cta-closing__content {
  flex: 1 1 480px;
  min-width: 0;
}

.cv-cta-closing__eyebrow {
  display: block;
  margin: 0 0 var(--cv-space-3, 12px);
  color: var(--cv-color-accent-hover);
  font-size: var(--cv-font-size-xs, 0.75rem);
  font-weight: var(--cv-font-weight-semibold, 600);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.cv-cta-closing__heading {
  margin: 0 0 var(--cv-space-5, 20px);
  color: var(--cv-color-text-strong);
  font-size: 1.875rem;
  line-height: 1.05;
  font-weight: var(--cv-font-weight-medium, 500);
}

@media (min-width: 768px) {
  .cv-cta-closing__heading { font-size: 2.8rem; }
}

.cv-cta-closing__body {
  margin: 0 0 var(--cv-space-7, 28px);
  font-size: var(--cv-font-size-lg, 1.125rem);
  line-height: var(--cv-line-height-snug, 1.5);
  color: var(--cv-color-text);
}

.cv-cta-closing__body > * + * {
  margin-top: var(--cv-space-4, 16px);
}

.cv-cta-closing__body p {
  margin: 0;
}

.cv-cta-closing__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cv-space-4, 16px);
  align-items: center;
}

.cv-cta-closing__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--cv-space-3, 12px) var(--cv-space-6, 24px);
  border-radius: var(--cv-radius-md, 10px);
  border: 2px solid transparent;
  font-size: 1.0625rem;
  font-weight: var(--cv-font-weight-medium, 500);
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color var(--cv-motion-base, .15s) var(--cv-motion-easing, ease),
              border-color var(--cv-motion-base, .15s) var(--cv-motion-easing, ease),
              color var(--cv-motion-base, .15s) var(--cv-motion-easing, ease);
}

.cv-cta-closing__button--primary {
  background: var(--cv-color-accent);
  color: var(--cv-color-text-on-accent);
}

.cv-cta-closing__button--primary:hover,
.cv-cta-closing__button--primary:focus-visible {
  background: var(--cv-color-bg);
  color: var(--cv-color-accent-hover);
  border-color: var(--cv-color-accent-hover);
}

.cv-cta-closing__button--secondary {
  background: var(--cv-color-bg);
  color: var(--cv-color-text-strong);
  border-color: var(--cv-color-border);
}

.cv-cta-closing__button--secondary:hover,
.cv-cta-closing__button--secondary:focus-visible {
  background: var(--cv-color-bg-mint-pale, #ECFDF5);
  border-color: var(--cv-color-accent-hover);
  color: var(--cv-color-accent-hover);
}

.cv-cta-closing__button:focus-visible {
  outline: 3px solid var(--cv-color-focus-ring, currentColor);
  outline-offset: 2px;
}

/* ── Illustration column ────────────────────────────────────────── */

.cv-cta-closing__illustration {
  flex: 1 1 320px;
  display: flex;
  justify-content: center;
}

.cv-cta-closing__illustration img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* ── Mobile stack ───────────────────────────────────────────────── */

@media (max-width: 767px) {
  .cv-cta-closing__container { gap: var(--cv-space-6, 24px); }
  .cv-cta-closing__actions { flex-direction: column; align-items: stretch; }
  .cv-cta-closing__button { width: 100%; }
}

/* ── Reduced motion ─────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .cv-cta-closing__button { transition: none; }
}
