/**
 * Fullcarro — Mejoras de UX del checkout WooCommerce
 * Se carga en /checkout/ Y en /checkout/order-received/
 */

/* ═══════════════════════════════════════════════════════════
   THANK YOU PAGE — Rediseño más compacto y elegante
   Path: /checkout/order-received/{id}/
═══════════════════════════════════════════════════════════ */

/* Contenedor general — más compacto */
body .listivo-thank-you-container {
  max-width: 560px !important;
  margin: 0 auto !important;
  padding: 10px 20px 40px !important;
}

/* Header "Gracias por tu pedido #138709" — mucho más pequeño */
body .listivo-panel-head--v2 {
  padding: 30px 20px 20px !important;
  background: transparent !important;
}

body .listivo-panel-head--v2 .listivo-panel-head__label {
  margin: 0 auto !important;
  max-width: 560px !important;
}

body .listivo-panel-head--v2 .listivo-panel-head__label h1 {
  font-size: 26px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  color: #1E2D3D !important;
  margin: 0 !important;
  letter-spacing: -0.4px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 6px !important;
}

body .listivo-panel-head--v2 .listivo-panel-head__label h1 span {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: #F09965 !important;
  background: #FFF7F0 !important;
  padding: 5px 14px !important;
  border-radius: 999px !important;
  display: inline-block !important;
  letter-spacing: 0 !important;
}

/* Card del paquete */
body .listivo-panel-thank-you-package {
  background: #FFFFFF !important;
  border-radius: 16px !important;
  padding: 0 !important;
  margin: 20px auto 24px !important;
  max-width: 460px !important;
  overflow: hidden !important;
  box-shadow: 0 10px 30px rgba(30, 42, 58, 0.08), 0 2px 8px rgba(30, 42, 58, 0.04) !important;
  border: 1px solid #E2E8F0 !important;
}

/* Pill naranja "Plan Inicio (Gratis)" */
body .listivo-panel-thank-you-package__top {
  background: linear-gradient(135deg, #F09965, #E8874E) !important;
  color: #FFFFFF !important;
  padding: 14px 24px !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  text-align: center !important;
  letter-spacing: -0.1px !important;
}

/* Precio "$0" — más chico */
body .listivo-panel-thank-you-package__content {
  padding: 22px 24px !important;
  text-align: center !important;
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #1E2D3D !important;
  background: #FFFFFF !important;
}

body .listivo-panel-thank-you-package__content .amount,
body .listivo-panel-thank-you-package__content bdi {
  font-size: 24px !important;
  font-weight: 800 !important;
  color: #1E2D3D !important;
}

/* Icono de éxito arriba del header (agregado con ::before) */
body .listivo-panel-head--v2 .listivo-panel-head__label h1::before {
  content: "\f00c"; /* fa-check */
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  background: linear-gradient(135deg, #27AE60, #1E8449);
  color: #FFFFFF;
  font-size: 26px;
  margin-bottom: 10px;
  box-shadow: 0 8px 20px rgba(39, 174, 96, 0.3);
  animation: fcCheckBounce 0.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
}

@keyframes fcCheckBounce {
  0% { transform: scale(0); opacity: 0; }
  50% { transform: scale(1.15); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

/* Botón "Volver al Panel" más compacto y centrado */
body .listivo-thank-you-container__button {
  display: flex !important;
  justify-content: center !important;
  margin-top: 10px !important;
}

body .listivo-thank-you-container__button .listivo-button {
  height: 48px !important;
  padding: 0 28px !important;
  border-radius: 12px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: -0.1px !important;
  box-shadow: 0 6px 18px rgba(240, 153, 101, 0.3) !important;
  transition: all 0.2s ease !important;
}

body .listivo-thank-you-container__button .listivo-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 24px rgba(240, 153, 101, 0.4) !important;
}

/* Ocultar notice redundante de "Gracias. Tu pedido ha sido recibido" de WC */
body .woocommerce-notice.woocommerce-notice--success.woocommerce-thankyou-order-received {
  display: none !important;
}

/* Ocultar secciones WooCommerce default que aparecen después (detalles, facturación, etc.) */
body .woocommerce-order-details,
body .woocommerce-customer-details,
body .woocommerce-order-overview {
  display: none !important;
}

/* Responsive */
@media (max-width: 640px) {
  body .listivo-panel-head--v2 .listivo-panel-head__label h1 {
    font-size: 22px !important;
  }
  body .listivo-panel-head--v2 .listivo-panel-head__label h1 span {
    font-size: 14px !important;
  }
  body .listivo-panel-head--v2 .listivo-panel-head__label h1::before {
    width: 52px;
    height: 52px;
    font-size: 22px;
  }
  body .listivo-panel-thank-you-package__top {
    font-size: 13px !important;
    padding: 12px 18px !important;
  }
  body .listivo-panel-thank-you-package__content {
    font-size: 20px !important;
    padding: 18px 20px !important;
  }
}

/**
 * CHECKOUT FORM — resto del archivo
 */

/* ─────────────────────────────────────────────────────
   Campo con error — resaltado visual claro
───────────────────────────────────────────────────── */
body.woocommerce-checkout .form-row.fc-invalid,
body.woocommerce-checkout .form-row.woocommerce-invalid,
body.woocommerce-checkout .form-row.woocommerce-invalid-required-field {
  position: relative;
  margin-bottom: 24px !important;
}

/* Input/select/textarea con error */
body.woocommerce-checkout .form-row.fc-invalid input[type="text"],
body.woocommerce-checkout .form-row.fc-invalid input[type="tel"],
body.woocommerce-checkout .form-row.fc-invalid input[type="email"],
body.woocommerce-checkout .form-row.fc-invalid input[type="password"],
body.woocommerce-checkout .form-row.fc-invalid textarea,
body.woocommerce-checkout .form-row.fc-invalid select,
body.woocommerce-checkout .form-row.fc-invalid .select2-selection,
body.woocommerce-checkout .form-row.woocommerce-invalid input[type="text"],
body.woocommerce-checkout .form-row.woocommerce-invalid input[type="tel"],
body.woocommerce-checkout .form-row.woocommerce-invalid input[type="email"],
body.woocommerce-checkout .form-row.woocommerce-invalid input[type="password"],
body.woocommerce-checkout .form-row.woocommerce-invalid textarea,
body.woocommerce-checkout .form-row.woocommerce-invalid select,
body.woocommerce-checkout .form-row.woocommerce-invalid .select2-selection {
  border: 2px solid #E74C3C !important;
  background-color: #FFF5F5 !important;
  box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.12) !important;
  transition: all 0.2s ease;
}

/* Label con error */
body.woocommerce-checkout .form-row.fc-invalid label,
body.woocommerce-checkout .form-row.woocommerce-invalid label,
body.woocommerce-checkout .form-row.woocommerce-invalid-required-field label {
  color: #C0392B !important;
  font-weight: 700 !important;
}

/* Asterisco del label en rojo intenso */
body.woocommerce-checkout .form-row.fc-invalid label .required,
body.woocommerce-checkout .form-row.woocommerce-invalid label .required {
  color: #E74C3C !important;
  text-shadow: 0 0 0 #E74C3C;
}

/* Mensaje de error inline debajo del campo */
body.woocommerce-checkout .form-row.fc-invalid::after,
body.woocommerce-checkout .form-row.woocommerce-invalid::after {
  content: "⚠ " attr(data-fc-error-msg);
  display: block;
  margin-top: 6px;
  padding: 8px 12px;
  background: #FEE2E2;
  color: #C0392B;
  border-radius: 8px;
  font-size: 12.5px;
  font-weight: 700;
  line-height: 1.4;
  animation: fcErrorSlideIn 0.25s ease;
}

@keyframes fcErrorSlideIn {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Animación shake cuando se dispara el error */
body.woocommerce-checkout .form-row.fc-shake {
  animation: fcShake 0.4s ease;
}

@keyframes fcShake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}

/* Al enfocar el campo con error, la línea roja se suaviza (UX: ya vio el error) */
body.woocommerce-checkout .form-row.fc-invalid input:focus,
body.woocommerce-checkout .form-row.fc-invalid select:focus,
body.woocommerce-checkout .form-row.fc-invalid textarea:focus,
body.woocommerce-checkout .form-row.woocommerce-invalid input:focus,
body.woocommerce-checkout .form-row.woocommerce-invalid select:focus,
body.woocommerce-checkout .form-row.woocommerce-invalid textarea:focus {
  border-color: #F09965 !important;
  background-color: #FFFAF6 !important;
  box-shadow: 0 0 0 3px rgba(240, 153, 101, 0.18) !important;
}

/* ─────────────────────────────────────────────────────
   Banner de errores arriba del form
───────────────────────────────────────────────────── */
.fc-checkout-error-banner {
  margin: 0 0 22px;
  padding: 16px 20px;
  background: linear-gradient(135deg, #FFF5F5, #FEE2E2);
  border: 1.5px solid #FCA5A5;
  border-left: 5px solid #E74C3C;
  border-radius: 12px;
  color: #991B1B;
  font-family: inherit;
  font-size: 14px;
  font-weight: 600;
  box-shadow: 0 4px 14px rgba(231, 76, 60, 0.12);
  display: flex;
  align-items: flex-start;
  gap: 12px;
  animation: fcErrorSlideIn 0.3s ease;
}

.fc-checkout-error-banner__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #E74C3C;
  color: #FFFFFF;
  border-radius: 50%;
  font-size: 18px;
}

.fc-checkout-error-banner__body {
  flex: 1;
}

.fc-checkout-error-banner__title {
  font-size: 15px;
  font-weight: 800;
  color: #991B1B;
  margin-bottom: 4px;
}

.fc-checkout-error-banner__list {
  margin: 6px 0 0 0;
  padding: 0;
  list-style: none;
  font-size: 13px;
  font-weight: 600;
  color: #7F1D1D;
}

.fc-checkout-error-banner__list li {
  padding: 2px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.fc-checkout-error-banner__list li::before {
  content: "•";
  color: #E74C3C;
  font-weight: 800;
  font-size: 16px;
  line-height: 1;
}

.fc-checkout-error-banner__close {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border: none;
  background: rgba(231, 76, 60, 0.15);
  color: #991B1B;
  border-radius: 50%;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  font-family: inherit;
  transition: background 0.18s;
}

.fc-checkout-error-banner__close:hover {
  background: rgba(231, 76, 60, 0.3);
}

/* ─────────────────────────────────────────────────────
   Mejoras generales del form de checkout
───────────────────────────────────────────────────── */
body.woocommerce-checkout .woocommerce-checkout .form-row label {
  font-size: 12.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: #64748B;
  margin-bottom: 6px;
  display: block;
  transition: color 0.18s;
}

body.woocommerce-checkout .woocommerce-checkout .form-row input[type="text"],
body.woocommerce-checkout .woocommerce-checkout .form-row input[type="tel"],
body.woocommerce-checkout .woocommerce-checkout .form-row input[type="email"],
body.woocommerce-checkout .woocommerce-checkout .form-row textarea,
body.woocommerce-checkout .woocommerce-checkout .form-row select {
  border-radius: 10px;
  transition: all 0.18s ease;
}

body.woocommerce-checkout .woocommerce-checkout .form-row input[type="text"]:focus,
body.woocommerce-checkout .woocommerce-checkout .form-row input[type="tel"]:focus,
body.woocommerce-checkout .woocommerce-checkout .form-row input[type="email"]:focus,
body.woocommerce-checkout .woocommerce-checkout .form-row textarea:focus,
body.woocommerce-checkout .woocommerce-checkout .form-row select:focus {
  border-color: #F09965;
  box-shadow: 0 0 0 3px rgba(240, 153, 101, 0.15);
  outline: none;
}
