/* ============================================================
   Store Andina — assets/css/main.css
   Estilos custom adicionales (complementan Tailwind v2 CDN)
   ============================================================ */

/* ── Variables CSS ─────────────────────────────────────────── */
:root {
  --color-primary:    #273647;
  --color-secondary:  #446084;
  --color-bg:         #ffffff;
  --color-surface:    #ffffff;
  --color-border:     #e5e7eb;
  --color-accent:     #10b981;
  --color-accent-dk:  #065f46;
  --color-accent-md:  #064e3b;
  --color-text:       #111827;
  --color-text-muted: #6b7280;
}

/* ── Reset y base ──────────────────────────────────────────── */
body {
  font-family: 'Nunito', sans-serif;
  background-color: var(--color-bg);
  color: var(--color-text);
}

/* ── Scrollbar discreta ────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #f3f4f6; }
::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 3px; }

/* ── Hero ──────────────────────────────────────────────────── */
.hero-bg {
  background-color: #f0f4ff;
  background-image: url('../img/hero-bg.jpg');
  background-size: cover;
  background-position: center;
  position: relative;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    rgba(39,54,71,0.72) 0%,
    rgba(68,96,132,0.55) 50%,
    rgba(255,255,255,0.15) 100%
  );
  pointer-events: none;
  z-index: 0;
}

.dot-grid {
  background-color: #1e1e1eba;
  background-image: radial-gradient(rgba(0,0,0,0.06) 1px, transparent 1px);
  background-size: 28px 28px;
}


/* ── Tarjetas de producto ──────────────────────────────────── */
.product-card {
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
.product-card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 1px rgba(16,185,129,0.2), 0 8px 32px rgba(16,185,129,0.06);
}

/* ── Feature card oscura ──────────────────────────────────── */
.feature-main {
  background: linear-gradient(135deg, #065f46 0%, #064e3b 100%);
}

/* ── Botones ───────────────────────────────────────────────── */
.btn-primary {
  background-color: var(--color-primary);
  color: #fff;
  transition: background-color 0.2s ease, transform 0.1s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.btn-primary:hover {
  background-color: var(--color-secondary);
  transform: translateY(-1px);
}
.btn-primary:active { transform: translateY(0); }

.btn-outline {
  border: 1px solid var(--color-primary);
  color: var(--color-primary);
  background: transparent;
  transition: border-color 0.2s ease, background-color 0.2s ease, color 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.btn-outline:hover {
  background-color: var(--color-primary);
  color: #fff;
}

/* ── Input ─────────────────────────────────────────────────── */
.input-ring:focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--color-accent);
}

/* ── Tabs ──────────────────────────────────────────────────── */
.tab-active {
  background-color: var(--color-primary);
  color: #fff;
}
.tab-inactive {
  background-color: transparent;
  color: #4b5563;
}
.tab-inactive:hover {
  background-color: #f3f4f6;
  color: var(--color-primary);
}

/* ── Badge ─────────────────────────────────────────────────── */
.badge {
  background-color: #f3f4f6;
  color: #4b5563;
  border: 1px solid #e5e7eb;
}

/* ── Paginación ────────────────────────────────────────────── */
.dot-active  { background-color: var(--color-primary); }
.dot-inactive { background-color: rgba(0,0,0,0.2); }

/* ── Forms — clase custom .form-input ──────────────────────── */
.form-input {
  width: 100%;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
  font-family: 'Nunito', sans-serif;
  color: #111827;
  background-color: #ffffff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
}
.form-input:focus {
  outline: none;
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.15);
}
.form-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.375rem;
}

/* ── WooCommerce quantity input ────────────────────────────── */
.woocommerce input.qty,
.woocommerce input[type="number"] {
  width: 4rem;
  border: 1px solid #e5e7eb;
  border-radius: 0.5rem;
  padding: 0.375rem 0.5rem;
  font-size: 0.875rem;
  text-align: center;
  color: #111827;
}

/* ── WooCommerce notices ───────────────────────────────────── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-radius: 0.75rem;
  padding: 0.875rem 1.25rem;
  font-size: 0.875rem;
  margin-bottom: 1rem;
  border-left: 4px solid;
}
.woocommerce-message { background: #f0fdf4; border-color: #10b981; color: #065f46; }
.woocommerce-info    { background: #eff6ff; border-color: #3b82f6; color: #1e40af; }
.woocommerce-error   { background: #fef2f2; border-color: #ef4444; color: #991b1b; }

/* ── WooCommerce totales ───────────────────────────────────── */
.cart-collaterals .cart_totals h2,
.woocommerce-checkout-review-order-table th {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #374151;
}

/* ── WooCommerce botón submit ──────────────────────────────── */
.woocommerce #payment #place_order,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce button.button.alt {
  background-color: var(--color-primary) !important;
  color: #ffffff !important;
  border-radius: 0.75rem;
  font-weight: 700;
  font-size: 0.875rem;
  padding: 0.75rem 1.5rem;
  width: 100%;
  transition: background-color 0.2s ease;
}
.woocommerce #payment #place_order:hover,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce button.button.alt:hover {
  background-color: var(--color-secondary) !important;
}

/* ── Galería thumbnails ────────────────────────────────────── */
.thumb {
  cursor: pointer;
  flex-shrink: 0;
}
.thumb.active,
.thumb:focus {
  border-color: var(--color-primary) !important;
}

/* ── Instrucción card (thank you) ──────────────────────────── */
.instruction-card {
  background-color: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  padding: 1.25rem;
  text-align: center;
}

/* ── Animacion de exito ────────────────────────────────────── */
.success-icon {
  animation: pop-in 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
}
@keyframes pop-in {
  0%   { transform: scale(0); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}

/* ── Filtros del sidebar ───────────────────────────────────── */
.filter-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  color: #374151;
  cursor: pointer;
}
.filter-label input {
  accent-color: #10b981;
  width: 0.875rem;
  height: 0.875rem;
}

/* ── Paginacion de paginas ─────────────────────────────────── */
.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.5rem;
  border-radius: 0.5rem;
  font-size: 0.75rem;
  font-weight: 500;
  border: 1px solid #e5e7eb;
  color: #4b5563;
  background-color: #ffffff;
  margin: 0 0.125rem;
  transition: all 0.2s ease;
}
.page-numbers:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
}
.page-numbers.current {
  background-color: var(--color-primary);
  color: #ffffff;
  border-color: var(--color-primary);
}

/* ── Mi cuenta — navegación ────────────────────────────────── */
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce-MyAccount-navigation li a {
  display: block;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  color: #4b5563;
  border-radius: 0.5rem;
  transition: all 0.2s ease;
}
.woocommerce-MyAccount-navigation li a:hover,
.woocommerce-MyAccount-navigation li.is-active a {
  background-color: rgba(16,185,129,0.1);
  color: #065f46;
  font-weight: 600;
}

/* ── Modal ─────────────────────────────────────────────────── */
#sa-modal-login.hidden {
  display: none !important;
}

/* ── Cookie banner ─────────────────────────────────────────── */
/* sobre el header (9000), bajo los modales (99999) */
#sa-cookie-notice {
  z-index: 9500;
}
#sa-cookie-notice.visible {
  display: block;
}

/* ── Mini carrito en dropdown ──────────────────────────────── */
/* Ocultar markup nativo de WC que no usamos */
.woocommerce-mini-cart__empty-message,
.woocommerce-mini-cart__buttons { display: none !important; }
/* Scrollbar dentro del inner */
#sa-cart-dropdown-inner::-webkit-scrollbar { width: 4px; }
#sa-cart-dropdown-inner::-webkit-scrollbar-track { background: transparent; }
#sa-cart-dropdown-inner::-webkit-scrollbar-thumb { background: #e5e7eb; border-radius: 2px; }

/* ── Badge contador del carrito — círculo verde perfectamente redondo ── */
#cart-count { display: inline-flex !important; align-items: center !important; justify-content: center !important; min-width: 18px; height: 18px; padding: 0 3px; border-radius: 9999px; background-color: #10b981; color: #fff; font-size: 10px; font-weight: 700; line-height: 1; box-sizing: border-box; transition: opacity 0.2s ease, transform 0.2s ease; }
#cart-count.hidden { display: none !important; }

/* ── Responsive WooCommerce ────────────────────────────────── */
@media (max-width: 640px) {
  .woocommerce table.shop_table {
    font-size: 0.75rem;
  }
  .woocommerce-checkout #payment {
    padding: 1rem;
  }
}

/* ============================================================
   FORM ELEMENTS GLOBALES — input, select, textarea
   Cubre campos de WooCommerce, payment gateways y cualquier
   form dentro del theme que no tenga clases custom.
   ============================================================ */

/* Base compartida para todos los campos de texto / select */
.woocommerce input[type="text"],
.woocommerce input[type="email"],
.woocommerce input[type="tel"],
.woocommerce input[type="number"],
.woocommerce input[type="password"],
.woocommerce input[type="search"],
.woocommerce input[type="url"],
.woocommerce input[type="date"],
.woocommerce textarea,
.woocommerce select,
.woocommerce-page input[type="text"],
.woocommerce-page input[type="email"],
.woocommerce-page input[type="tel"],
.woocommerce-page input[type="number"],
.woocommerce-page input[type="password"],
.woocommerce-page input[type="search"],
.woocommerce-page input[type="url"],
.woocommerce-page input[type="date"],
.woocommerce-page textarea,
.woocommerce-page select {
  width: 100%;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
  font-family: 'Nunito', sans-serif;
  color: #111827;
  background-color: #ffffff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
}

.woocommerce input[type="text"]:focus,
.woocommerce input[type="email"]:focus,
.woocommerce input[type="tel"]:focus,
.woocommerce input[type="number"]:focus,
.woocommerce input[type="password"]:focus,
.woocommerce input[type="search"]:focus,
.woocommerce input[type="url"]:focus,
.woocommerce input[type="date"]:focus,
.woocommerce textarea:focus,
.woocommerce select:focus,
.woocommerce-page input[type="text"]:focus,
.woocommerce-page input[type="email"]:focus,
.woocommerce-page input[type="tel"]:focus,
.woocommerce-page input[type="number"]:focus,
.woocommerce-page input[type="password"]:focus,
.woocommerce-page input[type="search"]:focus,
.woocommerce-page input[type="url"]:focus,
.woocommerce-page input[type="date"]:focus,
.woocommerce-page textarea:focus,
.woocommerce-page select:focus {
  outline: none;
  border-color: #10b981;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.15);
}

/* Flecha custom para selects */
.woocommerce select,
.woocommerce-page select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 1rem;
  padding-right: 2.5rem;
  cursor: pointer;
}

/* Textarea — altura mínima */
.woocommerce textarea,
.woocommerce-page textarea {
  min-height: 6rem;
  resize: vertical;
}

/* Checkbox y radio — color accent */
.woocommerce input[type="checkbox"],
.woocommerce input[type="radio"],
.woocommerce-page input[type="checkbox"],
.woocommerce-page input[type="radio"] {
  width: auto;
  accent-color: #10b981;
  cursor: pointer;
  border-radius: 0.25rem;
}

/* Labels */
.woocommerce label,
.woocommerce-page label {
  font-size: 0.75rem;
  font-weight: 600;
  color: #374151;
}

/* ── Select2 (dropdown WooCommerce) ───────────────────────── */
.woocommerce .select2-container .select2-selection--single,
.woocommerce-page .select2-container .select2-selection--single {
  height: 42px !important;
  border: 1px solid #d1d5db !important;
  border-radius: 0.5rem !important;
  background-color: #ffffff !important;
  display: flex !important;
  align-items: center !important;
}
.woocommerce .select2-container .select2-selection--single:focus,
.woocommerce-page .select2-container .select2-selection--single:focus {
  border-color: #10b981 !important;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.15) !important;
  outline: none !important;
}
.woocommerce .select2-container .select2-selection--single .select2-selection__rendered,
.woocommerce-page .select2-container .select2-selection--single .select2-selection__rendered {
  font-size: 0.875rem !important;
  font-family: 'Nunito', sans-serif !important;
  color: #111827 !important;
  line-height: 1 !important;
  padding: 0 2.5rem 0 0.875rem !important;
}
.woocommerce .select2-container .select2-selection--single .select2-selection__arrow,
.woocommerce-page .select2-container .select2-selection--single .select2-selection__arrow {
  height: 100% !important;
  top: 0 !important;
  right: 0.75rem !important;
}
.woocommerce .select2-container--open .select2-selection--single,
.woocommerce-page .select2-container--open .select2-selection--single {
  border-color: #10b981 !important;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.15) !important;
}
.select2-dropdown {
  border: 1px solid #d1d5db !important;
  border-radius: 0.5rem !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.08) !important;
  font-family: 'Nunito', sans-serif !important;
  font-size: 0.875rem !important;
}
.select2-results__option {
  padding: 0.5rem 0.875rem !important;
  color: #374151 !important;
}
.select2-results__option--highlighted,
.select2-results__option[aria-selected="true"] {
  background-color: #10b981 !important;
  color: #ffffff !important;
}
.select2-search--dropdown .select2-search__field {
  border: 1px solid #d1d5db !important;
  border-radius: 0.375rem !important;
  padding: 0.375rem 0.75rem !important;
  font-size: 0.875rem !important;
  font-family: 'Nunito', sans-serif !important;
}
.select2-search--dropdown .select2-search__field:focus {
  outline: none !important;
  border-color: #10b981 !important;
}

/* ── Ordenamiento del catálogo ────────────────────────────── */
.ordering-wrapper form.woocommerce-ordering {
  margin: 0;
}
.ordering-wrapper select.orderby {
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem;
  font-size: 0.75rem;
  font-family: 'Nunito', sans-serif;
  color: #374151;
  background-color: #ffffff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%236b7280'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.5rem center;
  background-size: 0.875rem;
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  transition: border-color 0.15s ease;
}
.ordering-wrapper select.orderby:focus {
  outline: none;
  border-color: #10b981;
  box-shadow: 0 0 0 2px rgba(16,185,129,0.15);
}

/* ── WooCommerce p.form-row layout ───────────────────────── */
.woocommerce .form-row,
.woocommerce-page .form-row {
  margin-bottom: 1rem;
}
.woocommerce .form-row label,
.woocommerce-page .form-row label {
  display: block;
  margin-bottom: 0.375rem;
}
.woocommerce .form-row.form-row-first,
.woocommerce .form-row.form-row-last {
  width: calc(50% - 0.5rem);
  display: inline-block;
  vertical-align: top;
}
.woocommerce .form-row.form-row-first { margin-right: 1rem; }

@media (max-width: 480px) {
  .woocommerce .form-row.form-row-first,
  .woocommerce .form-row.form-row-last {
    width: 100%;
    display: block;
    margin-right: 0;
  }
}

/* ── WooCommerce result count ─────────────────────────────────────────────── */
.woocommerce-result-count {
  font-size: 0.75rem;
  color: #6b7280;
  margin: 0;
}

/* ── Skeleton pulse (catálogo AJAX) ─────────────────────────────────────── */
@keyframes sa-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}
.animate-pulse {
  animation: sa-pulse 1.5s cubic-bezier(0.4, 0, 0.6, 1) infinite;
}

/* ── Bounce del carrito (add-to-cart) ────────────────────────────────────── */
@keyframes sa-cart-bounce {
  0%   { transform: scale(1) rotate(0deg); }
  25%  { transform: scale(1.3) rotate(-8deg); }
  50%  { transform: scale(1.3) rotate(8deg); }
  75%  { transform: scale(1.1) rotate(-4deg); }
  100% { transform: scale(1) rotate(0deg); }
}
.sa-cart-bounce {
  animation: sa-cart-bounce 0.6s ease-in-out;
}

/* ── Avatar dropdown ─────────────────────────────────────────────────────── */
#sa-avatar-dropdown {
  min-width: 13rem;
}
#sa-avatar-dropdown a,
#sa-avatar-dropdown button {
  border-radius: 0.5rem;
  width: 100%;
}

/* ── Modal confirmación logout ────────────────────────────────────────────── */
#sa-logout-modal {
  animation: sa-logout-fade 0.18s ease both;
}
@keyframes sa-logout-fade {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.sa-logout-card {
  background: #fff;
  border-radius: 1.25rem;
  box-shadow: 0 20px 60px rgba(0,0,0,0.18), 0 4px 16px rgba(0,0,0,0.08);
  padding: 2rem 1.75rem 1.75rem;
  width: 100%;
  max-width: 22rem;
  text-align: center;
  animation: sa-logout-slide 0.22s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes sa-logout-slide {
  from { opacity: 0; transform: translateY(12px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.sa-logout-icon-wrap {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: #fef2f2;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
}
.sa-logout-icon {
  font-size: 1.25rem;
  color: #ef4444;
}
.sa-logout-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #111827;
  margin-bottom: 0.4rem;
}
.sa-logout-subtitle {
  font-size: 0.8125rem;
  color: #6b7280;
  line-height: 1.5;
  margin-bottom: 1.5rem;
}
.sa-logout-actions {
  display: flex;
  gap: 0.625rem;
}
.sa-logout-btn-cancel {
  flex: 1;
  padding: 0.625rem 0;
  border-radius: 0.75rem;
  border: 1.5px solid #e5e7eb;
  background: #fff;
  color: #374151;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sa-logout-btn-cancel:hover {
  background: #f9fafb;
  border-color: #d1d5db;
}
.sa-logout-btn-confirm {
  flex: 1;
  padding: 0.625rem 0;
  border-radius: 0.75rem;
  background: #ef4444;
  color: #fff;
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, transform 0.1s;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.sa-logout-btn-confirm:hover {
  background: #dc2626;
  transform: translateY(-1px);
}
.sa-logout-btn-confirm:active {
  transform: translateY(0);
}

/* ── Sidebar filtros mobile — animación slide-down ───────────────────────── */
#sidebar-filters {
  transition: max-height 0.3s ease, opacity 0.3s ease;
}
@media (max-width: 767px) {
  #sidebar-filters:not(.hidden) {
    display: block;
    animation: sa-slide-down 0.25s ease forwards;
  }
}
@keyframes sa-slide-down {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Mini-carrito dropdown — no salirse en mobile ────────────────────────── */
@media (max-width: 400px) {
  #sa-cart-dropdown {
    right: -3rem;
    width: calc(100vw - 2rem);
    max-width: 20rem;
  }
}

/* ── Saludo junto al avatar (desktop) ────────────────────────────────────── */
#sa-avatar-wrapper .flex {
  cursor: pointer;
}

/* ── Resultado count + ordering: stack en mobile ─────────────────────────── */
@media (max-width: 640px) {
  .catalog-grid-wrapper > div:first-child {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
}

/* ============================================================
   CHECKOUT — Payment section
   ============================================================ */

/* Reset del bloque de pago de WooCommerce */
.woocommerce-checkout #payment {
  background: transparent;
  border: none;
  padding: 0;
  border-radius: 0;
}
.woocommerce-checkout #payment ul.payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
  border: none;
}
.woocommerce-checkout #payment ul.payment_methods li {
  padding: 0;
  border: none;
  margin-bottom: 0.5rem;
}

/* Label de método de pago */
.woocommerce-checkout #payment .wc_payment_method label {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.875rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  background-color: #ffffff;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}
.woocommerce-checkout #payment .wc_payment_method label:hover {
  border-color: #10b981;
  background-color: #f0fdf4;
}
.woocommerce-checkout #payment .wc_payment_method input[type="radio"] {
  accent-color: #10b981;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}
.woocommerce-checkout #payment .wc_payment_method img {
  max-height: 24px;
  width: auto;
  vertical-align: middle;
}

/* Panel de cada método de pago */
.woocommerce-checkout #payment .payment_box {
  background-color: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  padding: 1rem;
  margin-top: 0.5rem;
  font-size: 0.875rem;
  color: #374151;
}
.woocommerce-checkout #payment .payment_box p {
  margin: 0;
  font-size: 0.8125rem;
  color: #6b7280;
}

/* Botón confirmar compra */
.woocommerce-checkout #payment #place_order {
  background-color: #111827 !important;
  color: #ffffff !important;
  border: none;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  font-weight: 700;
  padding: 0.875rem 1.5rem;
  width: 100%;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.1s ease;
  font-family: 'Nunito', sans-serif;
}
.woocommerce-checkout #payment #place_order:hover {
  background-color: #374151 !important;
  transform: translateY(-1px);
}
.woocommerce-checkout #payment #place_order:active {
  transform: translateY(0);
}

/* Terms & conditions en checkout */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  margin-bottom: 1rem;
}
.woocommerce-checkout .woocommerce-privacy-policy-text p {
  font-size: 0.75rem;
  color: #6b7280;
  margin-bottom: 0.5rem;
}

/* ============================================================
   MI CUENTA — Content area
   ============================================================ */

/* Reset del área de contenido nativa de WooCommerce */
.woocommerce-account .woocommerce {
  padding: 0;
  margin: 0;
}
.woocommerce-account .woocommerce-MyAccount-content {
  padding: 0;
}

/* Tabla de órdenes — modernizada */
.woocommerce-orders-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}
.woocommerce-orders-table th {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6b7280;
  background-color: #f9fafb;
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
}
.woocommerce-orders-table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #f3f4f6;
  color: #374151;
  vertical-align: middle;
}
.woocommerce-orders-table tbody tr:last-child td {
  border-bottom: none;
}
.woocommerce-orders-table tbody tr:hover td {
  background-color: #f9fafb;
}
/* Botones de acción en tabla de órdenes */
.woocommerce-orders-table .button,
.woocommerce-orders-table a.button {
  border: 1px solid #111827;
  color: #111827;
  background: transparent;
  border-radius: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.25rem 0.75rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: background-color 0.2s ease, color 0.2s ease;
  font-family: 'Nunito', sans-serif;
}
.woocommerce-orders-table .button:hover,
.woocommerce-orders-table a.button:hover {
  background-color: #111827;
  color: #ffffff;
}

/* Downloads table */
.woocommerce-MyAccount-downloads-table td,
.woocommerce-MyAccount-downloads-table th {
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
}
.woocommerce-MyAccount-downloads-table th {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6b7280;
  background-color: #f9fafb;
}

/* Formularios de edición de cuenta */
.woocommerce-EditAccountForm fieldset {
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  padding: 1.25rem;
  margin-bottom: 1.5rem;
}
.woocommerce-EditAccountForm fieldset legend {
  font-size: 0.875rem;
  font-weight: 700;
  color: #111827;
  padding: 0 0.5rem;
}

/* ── Carrito — qty-btn custom ─────────────────────────────────────────────── */
.qty-btn {
  width: 1.75rem;
  height: 1.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #e5e7eb;
  border-radius: 0.375rem;
  font-size: 0.875rem;
  color: #374151;
  background-color: #ffffff;
  transition: background-color 0.15s ease, border-color 0.15s ease;
  cursor: pointer;
}
.qty-btn:hover {
  background-color: #f3f4f6;
  border-color: #9ca3af;
}

/* ── Modal — estilos ─────────────────────────────────────────────────────── */

/* Entrada del contenedor */
@keyframes modal-slide-up {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.sa-modal-content {
  animation: modal-slide-up 0.22s ease both;
}

/* Tab switcher pill */
.sa-modal-tab-active {
  background: #ffffff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.1);
  color: #111827;
  font-weight: 600;
}
.sa-modal-tab-inactive {
  color: #6b7280;
  background: transparent;
}
.sa-modal-tab-inactive:hover { color: #374151; }

/* Paneles con transición suave */
.sa-panel {
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.sa-panel.sa-panel-exit {
  opacity: 0;
  transform: translateY(6px);
  pointer-events: none;
}
.sa-panel.sa-panel-enter {
  opacity: 0;
  transform: translateY(-6px);
}
.sa-panel.sa-panel-enter-active {
  opacity: 1;
  transform: translateY(0);
}

/* Inputs con ícono izquierdo — el ícono NO solapa el texto */
.modal-input-wrapper {
  position: relative;
}
/* Input con ícono izquierdo */
.form-input.modal-has-icon {
  padding-left: 2.625rem; /* 42px — ícono a 14px + ~13px del ícono + 6px gap */
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}
/* Input con ícono derecho (toggle pass) */
.form-input.modal-has-icon-right {
  padding-right: 2.625rem;
}
.modal-input-icon {
  position: absolute;
  left: 0.875rem;
  top: 50%;
  transform: translateY(-50%);
  color: #9ca3af;
  font-size: 0.8125rem;
  pointer-events: none;
  z-index: 1;
  line-height: 1;
}
/* Botón toggle mostrar/ocultar contraseña */
.modal-toggle-pass {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: #9ca3af;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  line-height: 1;
  z-index: 2;
}
.modal-toggle-pass:hover { color: #6b7280; }

/* Botón submit del modal */
.modal-btn-submit {
  background: linear-gradient(to right, #10b981, #059669);
  color: #ffffff;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.1s ease;
  display: block;
  text-align: center;
}
.modal-btn-submit:hover { opacity: 0.92; transform: translateY(-1px); }
.modal-btn-submit:active { transform: translateY(0); }
.modal-btn-submit:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }

/* Botones OAuth */
.modal-oauth-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1rem;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  color: #374151;
  background: #ffffff;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease;
  width: 100%;
}
.modal-oauth-btn:hover { background: #f9fafb; border-color: #d1d5db; }

/* Mobile full screen */
@media (max-width: 639px) {
  #sa-modal-login .sa-modal-content {
    border-radius: 0;
    min-height: 100dvh;
  }
}

/* ── Single Product ─────────────────────────────────────────── */

/* Thumbnail activo — borde verde */
.sa-thumb.sa-thumb-active {
  border-color: #10b981 !important;
}

/* ── Precio en la página de producto single ─────────────────────────────── */
.sa-product-price {
  margin-bottom: 25px;
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex-wrap: wrap;
}
/* Precio tachado */
.sa-product-price del {
  text-decoration: none;
  color: #9ca3af;
}
.sa-product-price del .woocommerce-Price-amount,
.sa-product-price del .woocommerce-Price-amount bdi,
.sa-product-price del span {
  font-size: 1rem !important;
  font-weight: 500 !important;
  color: #9ca3af !important;
  text-decoration: line-through !important;
}
/* Precio de oferta */
.sa-product-price ins {
  text-decoration: none !important;
}
.sa-product-price ins .woocommerce-Price-amount,
.sa-product-price ins .woocommerce-Price-amount bdi,
.sa-product-price ins span {
  font-size: 1.8rem !important;
  font-weight: bold !important;
  color: var(--color-primary) !important;
  text-decoration: none !important;
  line-height: 1;
}
/* Precio normal (sin oferta) */
.sa-product-price > .woocommerce-Price-amount,
.sa-product-price > .woocommerce-Price-amount bdi,
.sa-product-price > span.woocommerce-Price-amount {
  font-size: 1.8rem !important;
  font-weight: bold !important;
  color: var(--color-primary) !important;
  line-height: 1;
}

/* Precio WooCommerce (legacy — summary nativo) */
.woocommerce-product-summary .price {
  margin-bottom: 1rem;
  display: flex;
  align-items: baseline;
  gap: 0.625rem;
  flex-wrap: wrap;
}
/* Precio tachado (precio original) */
.woocommerce-product-summary .price del {
  color: #9ca3af;
  font-size: 1rem;
  font-weight: 500;
  text-decoration: line-through;
}
.woocommerce-product-summary .price del .woocommerce-Price-amount {
  font-size: 1rem;
  font-weight: 500;
  color: #9ca3af;
}
/* Precio actual (ins) */
.woocommerce-product-summary .price ins {
  text-decoration: none;
}
.woocommerce-product-summary .price ins .woocommerce-Price-amount {
  font-size: 1.75rem;
  font-weight: 800;
  color: #10b981;
}
/* Precio sin descuento (sin del/ins) */
.woocommerce-product-summary .price > .woocommerce-Price-amount {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--color-primary);
}

/* Formulario add-to-cart */
.woocommerce-product-summary form.cart {
  margin-top: 1.25rem;
}
.woocommerce-product-summary .single_add_to_cart_button {
  width: 100%;
  padding: 0.875rem 1.5rem;
  border-radius: 0.75rem;
  font-size: 0.875rem;
  font-weight: 700;
  margin-top: 0.75rem;
  /* Transición suave para el cambio de estado (spinner → verde) */
  transition: background-color 0.3s ease, color 0.2s ease, border-color 0.3s ease, opacity 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.woocommerce-product-summary .quantity {
  margin-bottom: 0.75rem;
}

/* Tab panels — espaciado de contenido */
#tab-descripcion p,
#tab-docs p,
#tab-requisitos p {
  margin-bottom: 1rem;
}
#tab-descripcion ul li,
#tab-docs ul li,
#tab-requisitos ul li {
  margin-bottom: 0.625rem;
}
#tab-descripcion h2,
#tab-descripcion h3,
#tab-docs h2,
#tab-docs h3 {
  margin-bottom: 0.75rem;
  margin-top: 1.25rem;
  font-weight: 700;
}
.prose p    { margin-bottom: 1rem; }
.prose li   { margin-bottom: 0.5rem; }
.prose h2,
.prose h3   { margin-top: 1.5rem; margin-bottom: 0.75rem; }

/* Tab panels — visibilidad controlada por JS */
.product-tab-panel { display: none; }
.product-tab-panel.panel-active { display: block; }

/* Descripción corta WooCommerce */
.woocommerce-product-details__short-description {
  color: #4b5563;
  font-size: 0.875rem;
  line-height: 1.625;
  margin-bottom: 1.25rem;
}
.woocommerce-product-details__short-description p { margin-bottom: 0.75rem; }

/* Ocultar h1 nativo de WooCommerce (usamos el nuestro) */
.woocommerce-product-summary .product_title {
  display: none;
}

/* product_meta — categorías y etiquetas */
.product_meta {
  font-size: 0.75rem;
  color: #9ca3af;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #f3f4f6;
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
}
.product_meta span { display: block; }
.product_meta a {
  color: #6b7280;
  text-decoration: none;
  transition: color 0.15s;
}
.product_meta a:hover { color: #10b981; }

/* Thumbnails galería: cursor pointer, sin zoom */
.sa-thumb { cursor: pointer; }

/* ── Carrito — animación eliminación de item ─────────────────────────────── */
.cart-item {
  transition: opacity 0.3s ease, max-height 0.4s ease;
  max-height: 200px;
}
.cart-item.removing {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  pointer-events: none;
}

/* ── WooCommerce notices — toasts flotantes ──────────────────────────────── */
.woocommerce-notices-wrapper {
  position: fixed;
  top: 5rem;
  right: 1.25rem;
  left: auto;
  transform: none;
  z-index: 99000;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  width: 320px;
  max-width: calc(100vw - 2rem);
  pointer-events: none;
}
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  padding: 0.75rem 0.875rem 0.75rem 1rem;
  border-radius: 0.875rem;
  font-size: 0.8125rem;
  font-weight: 500;
  line-height: 1.4;
  list-style: none;
  pointer-events: all;
  box-shadow: 0 4px 20px rgba(0,0,0,0.12);
  animation: sa-toast-in 0.22s ease;
  width: 100%;
  box-sizing: border-box;
  word-break: break-word;
}
@keyframes sa-toast-in {
  from { opacity: 0; transform: translateY(-10px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1);    }
}
.sa-toast-out {
  animation: sa-toast-fade 0.28s ease forwards !important;
}
@keyframes sa-toast-fade {
  to { opacity: 0; transform: translateY(-6px); }
}
.woocommerce-message { background:#f0fdf4; border:1px solid #bbf7d0; color:#065f46; }
.woocommerce-error   { background:#fef2f2; border:1px solid #fecaca; color:#991b1b; }
.woocommerce-info    { background:#eff6ff; border:1px solid #bfdbfe; color:#1e40af; }

/* Icono tipo */
.woocommerce-message::before { content:'✓'; font-weight:700; flex-shrink:0; }
.woocommerce-error::before   { content:'✕'; font-weight:700; flex-shrink:0; }
.woocommerce-info::before    { content:'i'; font-weight:700; flex-shrink:0; font-style:italic; }

/* Texto del toast ocupa el espacio disponible */
.sa-toast-text { flex:1; min-width:0; }

/* Links inline */
.woocommerce-message a,
.woocommerce-error a,
.woocommerce-info a { font-weight:600; text-decoration:underline; opacity:0.8; }
.woocommerce-message a:hover,
.woocommerce-error a:hover,
.woocommerce-info a:hover { opacity:1; }

/* Botón × cerrar */
.sa-toast-close {
  flex-shrink: 0;
  margin-left: 0.5rem;
  width: 1.25rem;
  height: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: transparent;
  border: none;
  cursor: pointer;
  opacity: 0.45;
  font-size: 0.75rem;
  line-height: 1;
  transition: opacity 0.15s, background 0.15s;
  color: inherit;
}
.sa-toast-close:hover { opacity: 1; background: rgba(0,0,0,0.08); }

/* ul.woocommerce-error contiene <li> */
ul.woocommerce-error { flex-direction:column; align-items:flex-start; gap:0.25rem; }
ul.woocommerce-error li { list-style:none; }

/* ── Cart summary — normalizar precios WooCommerce ───────────────────────── */
.woocommerce-Price-amount {
  display: inline;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
}
.woocommerce-Price-amount bdi { display: inline; }
.woocommerce-Price-currencySymbol { margin-right: 1px; }

/* Botón checkout ancho completo */
.sa-wc-main .btn-primary.w-full { width: 100%; }

/* ── Checkout a medida — campos ──────────────────────────────────────────── */
.form-input,
.woocommerce-checkout .woocommerce-input-wrapper input[type="text"],
.woocommerce-checkout .woocommerce-input-wrapper input[type="email"],
.woocommerce-checkout .woocommerce-input-wrapper input[type="tel"],
.woocommerce-checkout .woocommerce-input-wrapper input[type="number"],
.woocommerce-checkout .woocommerce-input-wrapper input[type="password"],
.woocommerce-checkout .woocommerce-input-wrapper select,
.woocommerce-checkout .woocommerce-input-wrapper textarea {
  width: 100%;
  border: 1px solid #e5e7eb;
  border-radius: 0.5rem;
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
  color: #111827;
  background-color: #ffffff;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  appearance: auto;
}
.form-input:focus,
.woocommerce-checkout .woocommerce-input-wrapper input:focus,
.woocommerce-checkout .woocommerce-input-wrapper select:focus,
.woocommerce-checkout .woocommerce-input-wrapper textarea:focus {
  outline: none;
  border-color: #10b981;
  box-shadow: 0 0 0 2px rgba(16,185,129,0.15);
}

.form-label,
.woocommerce-checkout .form-row label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: #374151;
  margin-bottom: 0.375rem;
}

.woocommerce-checkout .form-row {
  margin-bottom: 1rem;
  padding: 0;
}
.woocommerce-checkout .form-row .required { color: #f87171; margin-left: 2px; }
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  width: 100%;
  float: none;
}

/* Grid 2 columnas en desktop para first/last */
@media (min-width: 640px) {
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last {
    display: inline-block;
    width: calc(50% - 0.5rem);
  }
  .woocommerce-checkout .form-row-first { margin-right: 1rem; }
}

/* Secciones card del formulario */
.form-section {
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  background-color: #ffffff;
}
.form-section-title {
  font-size: 0.875rem;
  font-weight: 700;
  color: #111827;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid #f3f4f6;
}

/* ── Ocultar el h1.page-title que woocommerce_content() genera */
.sa-wc-main h1.page-title { display: none; }

/* ============================================================
   MI CUENTA — Rediseño completo (mobile-first)
   ============================================================ */

/* ── Layout contenedor ────────────────────────────────────── */
.sa-myaccount-wrap {
  min-height: calc(100vh - 64px - 200px); /* nav ~64px, footer ~200px */
}

/* ── Sidebar: ancho fijo en desktop, full en mobile ─────── */
@media (min-width: 1024px) {
  .sa-myaccount-sidebar {
    position: sticky;
    top: calc(64px + 1.5rem); /* sticky bajo el navbar */
  }
}

/* ── Sidebar: avatar gradient ───────────────────────────── */
.sa-myaccount-sidebar .woocommerce-MyAccount-navigation {
  padding: 0;
}

/* ── Título de sección del contenido ───────────────────── */
.sa-myaccount-content h2.sa-section-title {
  font-size: 1rem;
  font-weight: 700;
  color: #111827;
  margin-bottom: 1.25rem;
}

/* ── Formularios de edición: layout dos columnas ──────── */
.woocommerce-account .woocommerce-address-fields__field-wrapper,
.woocommerce-account .woocommerce-EditAccountForm .form-row-wide {
  display: block;
}

/* form-row first/last dentro de Mi Cuenta: columnas en desktop */
@media (min-width: 640px) {
  .woocommerce-account .woocommerce-address-fields__field-wrapper .form-row-first,
  .woocommerce-account .woocommerce-address-fields__field-wrapper .form-row-last {
    display: inline-block;
    width: calc(50% - 0.5rem);
    vertical-align: top;
  }
  .woocommerce-account .woocommerce-address-fields__field-wrapper .form-row-first {
    margin-right: 1rem;
  }
}

/* Una columna en mobile */
@media (max-width: 639px) {
  .woocommerce-account .woocommerce-address-fields__field-wrapper .form-row-first,
  .woocommerce-account .woocommerce-address-fields__field-wrapper .form-row-last {
    width: 100%;
    display: block;
    margin-right: 0;
  }
}

/* ── Sección de formulario (edit-account, edit-address) ── */
.sa-form-section {
  border: 1px solid #f3f4f6;
  border-radius: 1rem;
  padding: 1.25rem;
  background-color: #fafafa;
}
.sa-form-section + .sa-form-section {
  margin-top: 1.25rem;
}
.sa-form-section-header {
  padding-bottom: 0.75rem;
  border-bottom: 1px solid #e5e7eb;
  margin-bottom: 1rem;
}

/* ── Tabla view-order ─────────────────────────────────── */
.woocommerce-account .woocommerce-order-details table,
.woocommerce-account .shop_table {
  width: 100%;
  border-collapse: collapse;
}
.woocommerce-account .woocommerce-order-details table th,
.woocommerce-account .shop_table th {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #6b7280;
  background-color: #f9fafb;
  padding: 0.75rem 1rem;
  text-align: left;
  border-bottom: 1px solid #e5e7eb;
}
.woocommerce-account .woocommerce-order-details table td,
.woocommerce-account .shop_table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #f3f4f6;
  color: #374151;
  vertical-align: middle;
}

/* ── Suprimir breadcrumb de WC dentro del content area ── */
/* El breadcrumb lo maneja my-account.php directamente */
.sa-myaccount-content .woocommerce-breadcrumb {
  display: none !important;
}

/* ── Suprimir h1.page-title duplicado en Mi Cuenta ──── */
.sa-myaccount-content .woocommerce > h1.page-title,
.sa-myaccount-content h1.page-title {
  display: none !important;
}

/* ── my-address: cards de dirección ──────────────────── */
.woocommerce-account .woocommerce-Addresses {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}
@media (min-width: 640px) {
  .woocommerce-account .woocommerce-Addresses {
    grid-template-columns: 1fr 1fr;
  }
}
.woocommerce-account .woocommerce-Address {
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  padding: 1.25rem;
  background-color: #fff;
}
.woocommerce-account .woocommerce-Address-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.75rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid #f3f4f6;
}
.woocommerce-account .woocommerce-Address-title h2 {
  font-size: 0.875rem;
  font-weight: 700;
  color: #111827;
  margin: 0;
}
.woocommerce-account .woocommerce-Address-title a.edit {
  font-size: 0.75rem;
  color: #10b981;
  font-weight: 600;
  transition: color 0.15s;
}
.woocommerce-account .woocommerce-Address-title a.edit:hover {
  color: #065f46;
}
.woocommerce-account .woocommerce-Address address {
  font-size: 0.875rem;
  color: #6b7280;
  line-height: 1.7;
  font-style: normal;
}

/* ── Botón Salir en sidebar: estilo rojo sutil ───────── */
.sa-logout-trigger {
  background: none;
  border: none;
  font-family: 'Nunito', sans-serif;
  cursor: pointer;
}
.sa-logout-trigger:hover {
  color: #b91c1c;
}

/* ── Navigation: ítem activo con barra lateral ───────── */
.woocommerce-MyAccount-navigation li.is-active > a,
.woocommerce-MyAccount-navigation li.is-active > button {
  position: relative;
}
.woocommerce-MyAccount-navigation li.is-active > a::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 60%;
  background-color: #10b981;
  border-radius: 0 2px 2px 0;
}

/* ── View-order: mark tags del status text de WC ─────── */
.woocommerce-account mark.order-number,
.woocommerce-account mark.order-date,
.woocommerce-account mark.order-status {
  background: none;
  font-weight: 700;
  color: #10b981;
}

/* ── Responsive: sidebar stack en mobile ─────────────── */
@media (max-width: 1023px) {
  .sa-myaccount-layout {
    flex-direction: column;
  }
  .sa-myaccount-sidebar {
    width: 100%;
  }
}

/* ============================================================
   MOBILE — Sidebar menu, cart drawer, misc
   ============================================================ */

/* ── Mobile menu sidebar ──────────��─────────────────────────��── */
/* El sidebar ya lleva transition en el style inline.            */
/* Estado abierto: JS agrega clase .is-open                      */
#mobile-menu.is-open {
  transform: translateX(0) !important;
}
#mobile-menu-overlay.is-open {
  opacity: 1 !important;
  pointer-events: all !important;
}

/* ── Cart: drawer lateral en mobile ───────────��─────────────── */
/* En desktop se mantiene el dropdown flotante posicionado por JS */
/* En mobile (<768px) el dropdown se convierte en panel lateral  */
/* ── Cart drawer en mobile: panel lateral derecho ───────────── */
/* El drawer usa translate en lugar de display:none para animar.  */
/* .hidden sigue controlando si se ve o no (via JS openCart/closeCart) */
@media (max-width: 767px) {
  /* Drawer cerrado: fuera de pantalla a la derecha */
  #sa-cart-dropdown.hidden {
    display: flex !important;          /* mantener en layout para animar */
    transform: translateX(110%) !important;
    pointer-events: none !important;
    visibility: hidden;
  }
  /* Drawer abierto: desliza desde la derecha */
  #sa-cart-dropdown:not(.hidden) {
    transform: translateX(0) !important;
    pointer-events: all !important;
    visibility: visible;
  }
  /* Geometría del panel */
  #sa-cart-dropdown {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    bottom: 0 !important;
    width: 85vw !important;
    max-width: 22rem !important;
    height: 100% !important;
    border-radius: 0 !important;
    border: none !important;
    border-left: 1px solid #e5e7eb !important;
    overflow: hidden;
    display: flex !important;
    flex-direction: column !important;
    transition: transform 0.28s cubic-bezier(0.4,0,0.2,1), visibility 0.28s !important;
    box-shadow: -4px 0 24px rgba(0,0,0,0.12);
  }
  #sa-cart-empty-state { flex: 1; }
  #sa-cart-dropdown-inner { flex: 1; max-height: none !important; }
}

/* Overlay del cart drawer — siempre invisible hasta que JS lo activa */
#sa-cart-overlay {
  position: fixed;
  inset: 0;
  z-index: 99499;
  background: rgba(0,0,0,0.45);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

/* ── Suprimir toasts WooCommerce (notices de "añadido al carrito") ── */
/* Solo en mobile: ya tenemos el dropdown/drawer que confirma visualmente */
@media (max-width: 767px) {
  .woocommerce-notices-wrapper {
    display: none !important;
  }
}
/* En desktop también los suprimimos — el dropdown del carrito es suficiente */
.woocommerce-notices-wrapper .woocommerce-message[data-sa-toast] {
  display: none !important;
}

/* ── Checkout mobile — reducir padding excesivo ──────────────── */
@media (max-width: 767px) {
  .sa-checkout-wrap {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .form-section {
    padding: 1rem;
    border-radius: 0.75rem;
    margin-bottom: 1rem;
  }
  .woocommerce-checkout #payment {
    padding: 0 !important;
  }
}

/* ── Footer mobile — centrar columnas ───────────────────────── */
@media (max-width: 639px) {
  footer .grid {
    text-align: center;
  }
  footer .grid > div {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  footer ul {
    align-items: center;
  }
  footer .flex.items-center.space-x-3 {
    justify-content: center;
  }
  /* Logo centrado */
  footer a.flex.items-center {
    justify-content: center;
  }
  /* Copyright centrado */
  footer .py-6.border-t {
    text-align: center;
    flex-direction: column;
    gap: 0.5rem;
  }
}

/* ── Mi cuenta — sidebar accordion mobile ─── */
@media (max-width: 1023px) {
  #sa-account-nav-menu {
    overflow: hidden;
    max-height: 0;
    transition: max-height 0.3s ease;
  }
  #sa-account-nav-menu.is-open {
    max-height: 400px;
  }
}

/* ── Mi cuenta — tablas responsive mobile ─── */
@media (max-width: 639px) {
  .woocommerce-orders-table,
  .woocommerce-MyAccount-downloads-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    font-size: 0.75rem;
  }
  .woocommerce-orders-table td,
  .woocommerce-orders-table th,
  .woocommerce-MyAccount-downloads-table td,
  .woocommerce-MyAccount-downloads-table th {
    padding: 0.5rem 0.625rem;
    white-space: nowrap;
  }
  /* Contenido del área principal: menos padding en mobile */
  .sa-myaccount-content .bg-white {
    padding: 1rem !important;
    border-radius: 0.75rem !important;
  }
  .sa-myaccount-wrap {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
    padding-top: 1.25rem !important;
  }
}

/* ── Mini-carrito — subtotal sticky al fondo del inner ─── */
.sa-minicart-subtotal {
  position: sticky;
  bottom: 0;
  background: #fff;
  border-top: 1px solid #f3f4f6;
  padding: 0.625rem 0.75rem 0.25rem;
  margin: 0 -0.75rem -0.75rem;
}

/* ════════════════════════════════════════════════════════════════
   KRYPTON / IZIPAY — skin del tema
   DOM real del SDK:
     .kr-field-element
       .kr-field-wrapper          ← tiene .kr-label Y .kr-field-component
         .kr-label > label        ← label DENTRO del borde
         .kr-field-component
           .kr-iframe-wrapper
             iframe (height:100% — necesita altura fija en el wrapper)
   Estrategia: .kr-field-wrapper es flex-column, el label queda
   arriba del iframe dentro del mismo contenedor bordeado,
   igual a como se ve en el espejo visualmente.
   La altura del campo viene del padding del iframe-wrapper.
════════════════════════════════════════════════════════════════ */

/* Wrappers raíz: limpiar estilos del plugin */
#sa-krypton-form,
#sa-krypton-form .micuentaweb_rest_wrapper,
#sa-krypton-form #micuentawebstd_rest_wrapper,
.micuentaweb_rest_wrapper,
#micuentawebstd_rest_wrapper {
  width: 100% !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Form card: flex-wrap en lugar de grid — evita que el SDK sobreescriba
   grid-template-rows vía Vue.js. Expiry+CVV: width 50% para quedar en fila. */
#sa-krypton-form .kr-card-form.kr-embedded,
#micuentawebstd_rest_wrapper .kr-card-form.kr-embedded,
.kr-card-form.kr-embedded {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.875rem !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  align-items: flex-start !important;
}

/* PAN, Nombre, cuotas, errores: full width */
.kr-card-form.kr-embedded .kr-field-element.kr-pan,
.kr-card-form.kr-embedded .kr-field-element.kr-card-holder-name,
.kr-card-form.kr-embedded .kr-field-element.kr-installment-number,
.kr-card-form.kr-embedded .kr-field-element.kr-first-installment-delay,
.kr-card-form.kr-embedded .kr-form-error,
.kr-card-form.kr-embedded .kr-payment-button {
  width: 100% !important;
  flex: 0 0 100% !important;
}

/* Expiry + CVV: mitad del ancho cada uno (con gap de 0.875rem entre ellos) */
.kr-card-form.kr-embedded .kr-field-element.kr-expiry,
.kr-card-form.kr-embedded .kr-field-element.kr-security-code {
  flex: 0 0 calc(50% - 0.4375rem) !important;
  min-width: 0 !important;
}

/* Representaciones ocultas: sin espacio */
.kr-card-form.kr-embedded .krFieldRepresentation,
.kr-card-form.kr-embedded .krFieldRepresentationError,
.kr-card-form.kr-embedded .krFieldRepresentationDisabled,
.kr-card-form.kr-embedded > div[style*="display: none"],
.kr-card-form.kr-embedded > div[style*="display:none"] {
  display: none !important;
}

/* Cada campo: flex-column — label queda encima del wrapper bordeado */
.kr-field-element {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  height: auto !important;
  min-height: 0 !important;
}

/* Ocultar campos que no deben mostrarse.
   Cuotas/plazos: ocultar si solo tienen 1 opción (kr-read-only = sin opciones reales) */
.kr-field-element.kr-card-holder-mail,
.kr-field-element.kr-identity-document-type,
.kr-field-element.kr-identity-document-number,
.kr-field-element.kr-checkbox.kr-do-register,
.kr-field-element.kr-installment-number.kr-read-only,
.kr-field-element.kr-first-installment-delay.kr-read-only {
  display: none !important;
}

/* ── FIELD WRAPPER ──
   El SDK bloquea 'border' con sus propias reglas. Usamos box-shadow inset
   para simular el borde (no puede ser bloqueado). El wrapper es flex-column
   para que el label quede arriba y el iframe abajo dentro del mismo contenedor. */
#sa-krypton-form .kr-field-wrapper,
#sa-krypton-form .kr-field-wrapper-pan,
#sa-krypton-form .kr-field-wrapper-expiryDate,
#sa-krypton-form .kr-field-wrapper-securityCode,
#sa-krypton-form .kr-field-wrapper-cardHolderName,
#sa-krypton-form .kr-text-wrapper,
#sa-krypton-form .kr-select-wrapper {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  border: none !important;
  box-shadow: inset 0 0 0 1px #d1d5db !important;
  border-radius: 0.5rem !important;
  background: #ffffff !important;
  overflow: hidden !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: 0.625rem 0.875rem 0.375rem !important;
  min-height: 2.625rem !important;
  height: auto !important;
  flex-shrink: 0 !important;
  transition: box-shadow 0.15s ease !important;
}

/* Focus: anillo verde */
#sa-krypton-form .kr-field-wrapper.kr-focus,
#sa-krypton-form .kr-field-wrapper-pan.kr-focus,
#sa-krypton-form .kr-field-wrapper-expiryDate.kr-focus,
#sa-krypton-form .kr-field-wrapper-securityCode.kr-focus,
#sa-krypton-form .kr-field-wrapper-cardHolderName.kr-focus,
#sa-krypton-form .kr-text-wrapper.kr-focus,
#sa-krypton-form .kr-select-wrapper.kr-focus {
  box-shadow: inset 0 0 0 1px #10b981, 0 0 0 3px rgba(16,185,129,0.15) !important;
}

/* Error: solo tras interacción */
#sa-krypton-form .kr-field-wrapper.kr-error:not(.kr-focus),
#sa-krypton-form .kr-field-wrapper-pan.kr-error:not(.kr-focus),
#sa-krypton-form .kr-field-wrapper-expiryDate.kr-error:not(.kr-focus),
#sa-krypton-form .kr-field-wrapper-securityCode.kr-error:not(.kr-focus),
#sa-krypton-form .kr-field-wrapper-cardHolderName.kr-error:not(.kr-focus),
#sa-krypton-form .kr-text-wrapper.kr-error:not(.kr-focus) {
  box-shadow: inset 0 0 0 1px #f87171, 0 0 0 3px rgba(248,113,113,0.1) !important;
}

/* ── LABEL — dentro del wrapper (flex-column arriba) ── */
#sa-krypton-form .kr-label {
  display: block !important;
  height: auto !important;
  min-height: 0 !important;
  font-size: 0.75rem !important;
  line-height: 1 !important;
  font-weight: 600 !important;
  color: #374151 !important;
  margin: 0 0 0.25rem 0 !important;
  font-family: 'Nunito', sans-serif !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  flex-shrink: 0 !important;
  width: 100% !important;
}
#sa-krypton-form .kr-label label {
  display: block !important;
  height: auto !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  color: #374151 !important;
  font-family: 'Nunito', sans-serif !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 1 !important;
  cursor: default !important;
}
#sa-krypton-form .kr-label.kr-error label { color: #dc2626 !important; }

/* ── Fila input (iframe + botón ojo) — dentro del wrapper-column ── */
#sa-krypton-form .kr-field-component,
#sa-krypton-form .kr-field-component.visible,
#sa-krypton-form .kr-field-element.kr-error .kr-field-component,
#sa-krypton-form .kr-field-wrapper.kr-error .kr-field-component {
  flex: 1 !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  border: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  overflow: visible !important;
}
#sa-krypton-form .kr-iframe-wrapper {
  flex: 1 !important;
  height: 1.875rem !important;
  min-height: 1.875rem !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
  border: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
  overflow: visible !important;
}
#sa-krypton-form .kr-iframe-wrapper iframe {
  width: 100% !important;
  height: 1.875rem !important;
  display: block !important;
  border: none !important;
}
/* El SDK inyecta margin-top:-7px en .kr-field-relative-wrapper vía style inline.
   Compensamos aquí para que el iframe no se desplace hacia abajo. */
#sa-krypton-form .kr-field-relative-wrapper {
  margin-top: 0 !important;
}
#sa-krypton-form .kr-input-relative-wrapper {
  margin-top: 0 !important;
}
/* Botón ojo CVV: absoluto dentro del .kr-field-element (position:relative).
   El SDK inyecta width:100% inline en kr-iframe-wrapper, bloqueando flex row.
   No usar .kr-field-wrapper como contenedor — rompería el label position:absolute. */
#sa-krypton-form .kr-visibility-button {
  position: absolute !important;
  right: 0.875rem !important;
  bottom: 0.375rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 1.25rem !important;
  height: 1.25rem !important;
  cursor: pointer !important;
  z-index: 2 !important;
}
#sa-krypton-form .kr-visibility-button svg {
  width: 1rem !important;
  height: 1rem !important;
  fill: #6b7280 !important;
  display: block !important;
}
/* Botón ayuda: sin espacio */
#sa-krypton-form .kr-help-button-wrapper {
  flex-shrink: 0 !important;
}

/* Input real (cardHolderName). El wrapper pone el padding; el input llena el espacio. */
#sa-krypton-form .kr-input-field {
  width: 100% !important;
  border: none !important;
  outline: none !important;
  padding: 0 !important;
  height: auto !important;
  min-height: 1.875rem !important;
  font-size: 0.875rem !important;
  font-family: 'Nunito', sans-serif !important;
  color: #111827 !important;
  background: transparent !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  box-sizing: border-box !important;
  flex: 1 !important;
}
#sa-krypton-form .kr-input-field::placeholder { color: #9ca3af !important; }

/* Iconos decorativos y botón ayuda CVV: todos ocultos sin excepción */
.kr-icon-wrapper-root,
.kr-icon-wrapper-root.kr-legacy,
.kr-brand-selector,
.kr-icon-arrow,
#sa-krypton-form .kr-help-button-wrapper,
#sa-krypton-form .kr-help-button-wrapper.kr-visible,
#sa-krypton-form .kr-help-button-wrapper.kr-inner,
#sa-krypton-form .kr-help-button-wrapper.kr-legacy,
#sa-krypton-form .kr-help-button-wrapper.kr-visible.kr-inner,
#sa-krypton-form .kr-help-button-wrapper.kr-legacy.kr-visible.kr-inner {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
/* Neutralizar también cualquier borde/sombra que el SDK inyecte en el botón ayuda */
#sa-krypton-form .kr-help-icon-wrapper,
#sa-krypton-form .kr-help-icon-wrapper.kr-error {
  display: none !important;
  border: none !important;
  border-bottom: none !important;
}
#sa-krypton-form .kr-help-button { display: none !important; }

/* Select cuotas/diferido ─────────────────────────────────────────────
   El wrapper comparte el bloque #sa-krypton-form .kr-field-wrapper (overflow:hidden).
   Sobreescribimos overflow aquí con ID para mantener la misma especificidad. */
#sa-krypton-form .kr-select-wrapper {
  overflow: visible !important;
  position: relative !important;
}

/* Fila select (campo cerrado): texto seleccionado + caret */
#sa-krypton-form .kr-select {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 !important;
  height: auto !important;
  min-height: 1.875rem !important;
  width: 100% !important;
  font-size: 0.875rem !important;
  font-family: 'Nunito', sans-serif !important;
  color: #111827 !important;
  border: none !important;
  background: transparent !important;
  cursor: pointer !important;
  gap: 0.5rem !important;
}
#sa-krypton-form .kr-selected-option {
  flex: 1 !important;
  font-size: 0.875rem !important;
  font-family: 'Nunito', sans-serif !important;
  color: #374151 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
#sa-krypton-form .kr-selected-option.kr-placeholder {
  color: #6b7280 !important;
}
#sa-krypton-form .kr-select-caret {
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  height: auto !important;
}
#sa-krypton-form .kr-select-caret svg {
  width: 0.625rem !important;
  height: 0.625rem !important;
  fill: #6b7280 !important;
  display: block !important;
}

/* Listbox flotante (estado abierto) */
#sa-krypton-form .kr-options {
  position: absolute !important;
  top: calc(100% + 0.25rem) !important;
  left: -0.875rem !important;
  right: -0.875rem !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 0.5rem !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.1) !important;
  background: #fff !important;
  z-index: 9999 !important;
  overflow: hidden !important;
  padding: 0.25rem 0 !important;
}
#sa-krypton-form .kr-option {
  padding: 0.5625rem 0.875rem !important;
  font-size: 0.875rem !important;
  font-family: 'Nunito', sans-serif !important;
  color: #374151 !important;
  cursor: pointer !important;
  transition: background 0.1s ease !important;
}
#sa-krypton-form .kr-option:hover {
  background: #f0fdf4 !important;
  color: #065f46 !important;
}
#sa-krypton-form .kr-active-option {
  background: #f0fdf4 !important;
  color: #065f46 !important;
  font-weight: 600 !important;
}

/* Panel de descuento: oculto */
.kr-discount-panel-wrapper { display: none !important; }

/* Error del formulario */
.kr-form-error {
  display: none;
  font-size: 0.7rem !important;
  color: #dc2626 !important;
  font-family: 'Nunito', sans-serif !important;
  padding: 0.5rem 0.75rem !important;
  background: #fef2f2 !important;
  border: 1px solid #fecaca !important;
  border-radius: 0.5rem !important;
  margin-top: 0.75rem !important;
  grid-column: 1 / -1 !important;
}
.kr-form-error[style*="display: block"],
.kr-form-error[style*="display:block"] {
  display: block !important;
}

/* Botón nativo: colapsado, el JS lo dispara al submit */
.kr-payment-button {
  display: block !important;
  visibility: hidden !important;
  height: 0 !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  min-height: 0 !important;
  grid-column: 1 / -1 !important;
}

/* Color primario del SDK */
.kr-card-form { --kr-global-color-primary: #10b981; }
