/* ===============================
   ProtoLab – CTA & Lead Blocks
   Frontend Styles
   =============================== */

/* Basis-CTA-Button */
.taas-cta-btn,
.taas-lead-btn {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  border: 2px solid transparent;
  cursor: pointer;
  line-height: 1.2;
  transition:
    background-color 0.15s ease,
    color 0.15s ease,
    border-color 0.15s ease,
    transform 0.08s ease;
}

/* Hover-/Active-States (leicht generisch) */
.taas-cta-btn:hover,
.taas-lead-btn:hover {
  transform: translateY(-1px);
}

.taas-cta-btn:active,
.taas-lead-btn:active {
  transform: translateY(0);
}

/* Full-Width (Block-Variante) */
.taas-cta-btn--block,
.taas-lead-btn--block,
.taas-cta-btn--fullwidth,
.taas-lead-btn--fullwidth {
  display: block;
  width: 100%;
  text-align: center;
}

/* Farben (Preset) */
.taas-cta-btn--primary,
.taas-lead-btn--primary {
  background: #2563eb;
  color: #ffffff;
}

.taas-cta-btn--secondary,
.taas-lead-btn--secondary {
  background: #64748b;
  color: #ffffff;
}

.taas-cta-btn--accent,
.taas-lead-btn--accent {
  background: #f97316;
  color: #ffffff;
}

/* Custom Button Color (via CSS-Variable, HEX im Editor gesetzt) */
.taas-cta-btn--custom-color,
.taas-lead-btn--custom-color {
  background-color: var(--taas-custom-button-color, #2563eb);
  border-color: transparent;
  color: #ffffff;
}

/* Hover für Presets */
.taas-cta-btn--primary:hover,
.taas-lead-btn--primary:hover {
  background: #1d4ed8;
}

.taas-cta-btn--secondary:hover,
.taas-lead-btn--secondary:hover {
  background: #4b5563;
}

.taas-cta-btn--accent:hover,
.taas-lead-btn--accent:hover {
  background: #ea580c;
}

.taas-cta-btn--custom-color:hover,
.taas-lead-btn--custom-color:hover {
  filter: brightness(0.92);
}

/* Größen */
.taas-cta-btn--sm,
.taas-lead-btn--sm {
  font-size: 0.85rem;
  padding: 0.5rem 1.1rem;
}

.taas-cta-btn--md,
.taas-lead-btn--md {
  font-size: 1rem;
  padding: 0.75rem 1.5rem;
}

.taas-cta-btn--lg,
.taas-lead-btn--lg {
  font-size: 1.1rem;
  padding: 1rem 2rem;
}

/* Styles: Solid / Outline / Ghost */

/* Solid ist Default – nutzt Background aus Preset oder Gutenberg Color */

.taas-cta-btn--style-outline,
.taas-lead-btn--style-outline {
  background: transparent;
  color: inherit;
  border-color: currentColor;
}

.taas-cta-btn--style-ghost,
.taas-lead-btn--style-ghost {
  background: transparent;
  color: inherit;
  border-color: transparent;
}

/* Falls Custom Color + Outline */
.taas-cta-btn--custom-color.taas-cta-btn--style-outline,
.taas-lead-btn--custom-color.taas-lead-btn--style-outline {
  background: transparent;
  color: var(--taas-custom-button-color, #2563eb);
  border-color: var(--taas-custom-button-color, #2563eb);
}

/* Falls Custom Color + Ghost */
.taas-cta-btn--custom-color.taas-cta-btn--style-ghost,
.taas-lead-btn--custom-color.taas-lead-btn--style-ghost {
  background: transparent;
  color: var(--taas-custom-button-color, #2563eb);
  border-color: transparent;
}

/* Sicherheit, falls Gutenberg-Background gesetzt wurde (has-*-background-color etc.) */
.taas-cta-btn.has-background,
.taas-lead-btn.has-background {
  border-color: transparent;
}

/* LEAD FORM – Layout */

.taas-lead-form {
  max-width: 500px;
}

/* Zeile: Input + Button nebeneinander */
.taas-lead-row {
  display: flex;
  gap: 0.5rem;
  align-items: stretch;
}

/* Input-Feld */
.taas-lead-row input[type="email"] {
  flex: 1 1 auto;
  padding: 0.6rem 0.8rem;
  border-radius: 0.5rem;
  border: 1px solid #d1d5db;
  font-size: 0.95rem;
  line-height: 1.2;
}

.taas-lead-row input[type="email"]:focus {
  outline: none;
  border-color: #2563eb;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, 0.2);
}

/* Consent-Label */
.taas-consent {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-top: 0.5rem;
  font-size: 0.85rem;
  color: #374151;
}

.taas-consent input[type="checkbox"] {
  margin-top: 0.2rem;
}

/* Kleine Description (wird ggf. im Editor angezeigt, im Frontend aber optional) */
.taas-lead-form .description {
  font-size: 0.8rem;
  color: #6b7280;
  margin-top: 0.35rem;
}

/* Accessiblity/States */
.taas-lead-form input[aria-invalid="true"] {
  border-color: #dc2626;
}

/* Optionale generische Utility für dunklen Hintergrund */
.taas-lead-form.has-dark-background,
.taas-cta-btn.has-dark-background-color {
  color: #ffffff;
}

/* Kleinere Anpassungen für mobile */
@media (max-width: 480px) {
  .taas-lead-row {
    flex-direction: column;
  }

  .taas-cta-btn--block,
  .taas-lead-btn--block,
  .taas-cta-btn--fullwidth,
  .taas-lead-btn--fullwidth {
    width: 100%;
  }
}
