/**
 * BigCat Codeworks CTA Block Component
 * Generic call-to-action component for newsletter signup
 * 
 * Import order: tokens.css → base.css → layout.css → components/cta-block.css
 */

/* ===== CTA BLOCK CONTAINER ===== */

.cta-block {
  background: linear-gradient(135deg, var(--color-bg-secondary) 0%, var(--color-bg-tertiary) 100%);
  padding: var(--spacing-16) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* ===== CTA CONTENT ===== */

.cta-block__content {
  max-width: var(--container-md);
  margin: 0 auto;
  padding: 0 var(--spacing-4);
  position: relative;
  z-index: 2;
}

.cta-block__header {
  margin-bottom: var(--spacing-8);
}

.cta-block__title {
  font-family: var(--font-hero);
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-4);
  text-shadow: 0 0 20px rgba(255, 0, 255, 0.3);
}

.cta-block__copy {
  font-family: var(--font-body);
  font-size: var(--font-size-lg);
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-8);
  line-height: var(--line-height-relaxed);
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
}

.cta-block__action {
  margin-bottom: var(--spacing-6);
}

/* ===== CTA FALLBACK ===== */

.cta-block__fallback {
  margin-top: var(--spacing-6);
  padding: var(--spacing-4);
  background: var(--color-bg-tertiary);
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-lg);
}

.cta-block__fallback-text {
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  margin: 0;
  font-style: italic;
}

/* ===== RESPONSIVE DESIGN ===== */

@media (max-width: 767px) {
  .cta-block {
    padding: var(--spacing-12) 0;
  }
  
  .cta-block__title {
    font-size: var(--font-size-2xl);
  }
  
  .cta-block__copy {
    font-size: var(--font-size-base);
  }
  
  .cta-block__content {
    padding: 0 var(--spacing-3);
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .cta-block {
    padding: var(--spacing-14) 0;
  }
}

@media (min-width: 1024px) {
  .cta-block {
    padding: var(--spacing-16) 0;
  }
  
  .cta-block__title {
    font-size: var(--font-size-4xl);
  }
  
  .cta-block__copy {
    font-size: var(--font-size-xl);
  }
}

/* ===== ACCESSIBILITY ===== */

@media (prefers-reduced-motion: reduce) {
  .cta-block__title {
    text-shadow: none;
  }
}

/* ===== HIGH CONTRAST MODE ===== */

@media (prefers-contrast: high) {
  .cta-block {
    background: var(--color-bg-primary);
    border: 2px solid var(--color-text-primary);
  }
  
  .cta-block__title {
    color: var(--color-text-primary);
    text-shadow: none;
  }
  
  .cta-block__copy {
    color: var(--color-text-primary);
  }
}

/* ===== PRINT STYLES ===== */

@media print {
  .cta-block {
    background: none;
    border: 1px solid var(--color-text-primary);
    padding: var(--spacing-8) 0;
  }
  
  .cta-block__action {
    display: none;
  }
}
