/* ============================================================
   Synergy Dynamics Balance — Componentes
   Botones · Cards · Formularios · Badges · Avisos
   ============================================================ */

/* ──────────── BOTONES ──────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-8);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: 600;
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  text-decoration: none;
  line-height: 1;
}

.btn-primary {
  background: var(--color-primary);
  color: #fff;
  border-color: var(--color-primary);
}
.btn-primary:hover {
  background: var(--color-primary-dark);
  border-color: var(--color-primary-dark);
  transform: translateY(-1px);
  box-shadow: var(--shadow);
  color: #fff;
}

.btn-secondary {
  background: transparent;
  color: var(--color-primary-darker);
  border-color: var(--color-primary);
}
.btn-secondary:hover { background: var(--color-primary-light); color: var(--color-primary-darker); }

.btn-ghost {
  background: transparent;
  color: var(--color-text);
  border-color: var(--color-border-strong);
}
.btn-ghost:hover { background: var(--color-bg-alt); color: var(--color-text); }

.btn-dark {
  background: var(--color-bg-dark);
  color: var(--color-text-inverse);
  border-color: var(--color-bg-dark);
}
.btn-dark:hover { background: #1a1a18; color: var(--color-text-inverse); }

.btn-amber {
  background: var(--color-secondary);
  color: #fff;
  border-color: var(--color-secondary);
}
.btn-amber:hover { background: var(--color-secondary-dark); border-color: var(--color-secondary-dark); color: #fff; transform: translateY(-1px); box-shadow: var(--shadow); }

.btn-white {
  background: #fff;
  color: var(--color-primary-darker);
  border-color: #fff;
}
.btn-white:hover { background: var(--color-primary-xlight); color: var(--color-primary-darker); transform: translateY(-1px); box-shadow: var(--shadow); }

.btn-lg { padding: var(--space-5) var(--space-10); font-size: var(--text-md); }
.btn-sm { padding: var(--space-2) var(--space-5); font-size: var(--text-sm); }
.btn-block { width: 100%; }

.btn .icon { width: 1.1em; height: 1.1em; }

/* ──────────── CARDS ──────────── */
.card {
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  transition: box-shadow var(--transition), transform var(--transition);
}
.card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }

.card-feature {
  background: var(--color-primary-xlight);
  border-color: var(--color-primary-light);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
}

.card-icon {
  width: 56px; height: 56px;
  display: grid; place-items: center;
  border-radius: var(--radius);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  margin-bottom: var(--space-5);
}
.card-icon svg { width: 28px; height: 28px; }

.card-title { font-size: var(--text-lg); margin-bottom: var(--space-3); }
.card-text { color: var(--color-text-muted); }

/* ──────────── BADGES ──────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border-radius: var(--radius-pill);
  background: var(--color-primary-light);
  color: var(--color-primary-darker);
}
.badge-amber  { background: var(--color-secondary-light); color: var(--color-secondary-dark); }
.badge-accent { background: var(--color-accent-light); color: var(--color-accent-dark); }
.badge-free   { background: var(--color-bg-dark); color: var(--color-text-inverse); }

/* ──────────── PRECIO ──────────── */
.price {
  font-family: var(--font-serif);
  font-weight: 700;
  color: var(--color-primary-darker);
}
.price-large { font-size: var(--text-2xl); }
.price-old { color: var(--color-text-subtle); text-decoration: line-through; font-weight: 400; font-size: 0.7em; margin-left: var(--space-2); }

/* ──────────── FORMULARIOS ──────────── */
.form { display: flex; flex-direction: column; gap: var(--space-4); }
.form-row { display: flex; flex-direction: column; gap: var(--space-2); }
.form-row label { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }

.input, .textarea, .select {
  width: 100%;
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-text);
  background: #fff;
  border: 1.5px solid var(--color-border-strong);
  border-radius: var(--radius);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.input::placeholder, .textarea::placeholder { color: var(--color-text-subtle); }
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}
.textarea { min-height: 140px; resize: vertical; }

.form-legal { font-size: var(--text-xs); color: var(--color-text-subtle); line-height: 1.5; }

/* Form inline (lead magnet en banda de color) */
.form-inline { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.form-inline .input { flex: 1 1 200px; }

/* Mensajes de estado del formulario */
.form-status { font-size: var(--text-sm); padding: var(--space-3) var(--space-4); border-radius: var(--radius); display: none; }
.form-status.is-visible { display: block; }
.form-status.is-success { background: var(--color-primary-light); color: var(--color-primary-darker); }
.form-status.is-error { background: #fbe7df; color: var(--color-error); }

/* ──────────── AVISO / DISCLAIMER ──────────── */
.disclaimer {
  border: 1px solid var(--color-secondary-light);
  background: var(--color-secondary-xlight);
  border-left: 4px solid var(--color-secondary);
  border-radius: var(--radius);
  padding: var(--space-6);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  line-height: 1.6;
}
.disclaimer strong { color: var(--color-secondary-dark); }

/* ──────────── PULL QUOTE / BLOCKQUOTE ──────────── */
.pull-quote {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--text-md);
  line-height: 1.6;
  color: var(--color-text);
  border-left: 3px solid var(--color-primary);
  padding-left: var(--space-6);
  margin: var(--space-6) 0;
}

.lead {
  font-size: var(--text-md);
  line-height: 1.6;
  color: var(--color-text-muted);
}

/* ──────────── LISTA CON CHECKS ──────────── */
.check-list { display: flex; flex-direction: column; gap: var(--space-3); }
.check-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  color: var(--color-text);
}
.check-list li::before {
  content: "";
  flex: 0 0 22px;
  width: 22px; height: 22px;
  margin-top: 3px;
  background: var(--color-primary-light);
  border-radius: var(--radius-pill);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230F6E56' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}

/* ──────────── DIVISOR ETIQUETA ──────────── */
.eyebrow {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-3);
  display: inline-block;
}
.eyebrow-amber { color: var(--color-secondary-dark); }
.eyebrow-accent { color: var(--color-accent); }
.eyebrow-light { color: var(--color-primary-light); }

/* ──────────── TOAST ──────────── */
.toast {
  position: fixed;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%) translateY(120%);
  background: var(--color-bg-dark);
  color: var(--color-text-inverse);
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-toast);
  transition: transform var(--transition-spring);
  font-size: var(--text-sm);
}
.toast.is-visible { transform: translateX(-50%) translateY(0); }
