/* src/css/sections/cta.css */
.cta {
  background: var(--gradient-primary);
  padding: var(--space-2xl) 0;
  position: relative;
  overflow: hidden;
  text-align: center;
}

.cta::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: url('data:image/svg+xml;utf8,<svg width="100" height="100" viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="1" fill="rgba(255,255,255,0.2)"/></svg>') repeat;
  opacity: 0.5;
}

.cta-content {
  position: relative;
  z-index: 2;
  max-width: 600px;
  margin: 0 auto;
}

.cta-title {
  color: white;
  font-size: clamp(2rem, 4vw, 3rem);
  margin-bottom: var(--space-md);
}

.cta-desc {
  color: rgba(255, 255, 255, 0.9);
  font-size: 1.125rem;
  margin-bottom: var(--space-xl);
}

.cta-actions {
  display: flex;
  gap: var(--space-md);
  justify-content: center;
}

.cta .btn-secondary {
  border-color: rgba(255,255,255,0.3);
  color: white;
}

.cta .btn-secondary:hover {
  background: rgba(255,255,255,0.2);
}

.cta .btn-primary {
  background: white;
  color: var(--color-primary);
  box-shadow: 0 10px 30px rgba(0,0,0,0.2);
}

.cta .btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 15px 40px rgba(0,0,0,0.3);
}

.cta .btn-primary::before {
  background: rgba(255, 255, 255, 0.9);
}
