/**
 * WooCommerce Dark Theme — Joe's Italian-American Wonders
 * Paleta: fondo #0E1520 · card #1A212C · input #242B38
 *         texto #ffffff / #B8BFC9 · acento #e46142 · borde rgba(255,255,255,0.1)
 * Tipografía: Montserrat (títulos) · Inter (cuerpo)
 * Cargado solo en páginas WooCommerce vía joes_woocommerce_dark_styles()
 */

/* =========================================================
   0. VARIABLES (custom properties reutilizables)
   ========================================================= */
:root {
  --joes-bg:         #0E1520;
  --joes-card:       #1A212C;
  --joes-input:      #242B38;
  --joes-deep:       #0A1018;
  --joes-text:       #F3F4F6;
  --joes-muted:      #B8BFC9;
  --joes-orange:     #e46142;
  --joes-border:     rgba(243, 244, 246, 0.12);
  --joes-border-hov: rgba(243, 244, 246, 0.30);
}

/* =========================================================
   1. BODY / WRAPPER — todas las páginas WC
   ========================================================= */
body.woocommerce-cart,
body.woocommerce-checkout,
body.woocommerce-order-received,
body.woocommerce-account {
  background-color: var(--joes-bg);
  color: var(--joes-muted);
  font-family: 'Inter', sans-serif;
}

/* Overrides genéricos de Bootstrap/Bootscore que interfieren */
body.woocommerce-cart .site,
body.woocommerce-checkout .site,
body.woocommerce-order-received .site,
body.woocommerce-account .site {
  background-color: var(--joes-bg);
}

body.woocommerce-cart #page,
body.woocommerce-checkout #page,
body.woocommerce-order-received #page,
body.woocommerce-account #page {
  background-color: var(--joes-bg);
}

/* Contenedor principal de contenido */
body.woocommerce-cart .entry-content,
body.woocommerce-checkout .entry-content,
body.woocommerce-order-received .entry-content,
body.woocommerce-account .entry-content,
body.woocommerce-cart .woocommerce,
body.woocommerce-checkout .woocommerce,
body.woocommerce-order-received .woocommerce,
body.woocommerce-account .woocommerce {
  background-color: transparent;
  color: var(--joes-muted);
}

/* =========================================================
   2. TIPOGRAFÍA — headings en Montserrat en páginas WC
   ========================================================= */
body.woocommerce-cart h1,
body.woocommerce-cart h2,
body.woocommerce-cart h3,
body.woocommerce-cart h4,
body.woocommerce-checkout h1,
body.woocommerce-checkout h2,
body.woocommerce-checkout h3,
body.woocommerce-checkout h4,
body.woocommerce-order-received h1,
body.woocommerce-order-received h2,
body.woocommerce-order-received h3,
body.woocommerce-order-received h4,
body.woocommerce-account h1,
body.woocommerce-account h2,
body.woocommerce-account h3,
body.woocommerce-account h4 {
  font-family: 'Montserrat', sans-serif;
  color: var(--joes-text);
}

/* =========================================================
   3. MENSAJES / NOTICES
   ========================================================= */
.woocommerce-notices-wrapper {
  background-color: transparent;
}

.woocommerce-message,
.woocommerce-info {
  background-color: #1a3d55 !important;
  border-top-color: var(--joes-orange) !important;
  border-left: 4px solid var(--joes-orange) !important;
  color: var(--joes-text) !important;
  border-radius: 8px;
  padding: 1rem 1.25rem;
}

.woocommerce-message::before,
.woocommerce-info::before {
  color: var(--joes-orange) !important;
}

.woocommerce-message a,
.woocommerce-info a {
  color: var(--joes-orange);
}

.woocommerce-error {
  background-color: #3d1a1a !important;
  border-top-color: #e44242 !important;
  border-left: 4px solid #e44242 !important;
  color: var(--joes-text) !important;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  list-style: none;
}

.woocommerce-error li {
  padding: 0.25rem 0;
}

.woocommerce-error a {
  color: #ff8080;
}

/* =========================================================
   4. CART PAGE  (body.woocommerce-cart)
   ========================================================= */

/* --- 4.1 Tabla del carrito --- */
body.woocommerce-cart .woocommerce-cart-form {
  background-color: transparent;
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table {
  background-color: var(--joes-card);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--joes-border);
  color: var(--joes-muted);
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table th {
  background-color: var(--joes-deep);
  color: var(--joes-text);
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--joes-border);
  padding: 0.875rem 1rem;
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table td {
  border-bottom: 1px solid var(--joes-border);
  padding: 1rem;
  vertical-align: middle;
  color: var(--joes-muted);
}

/* Filas alternas */
body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr:nth-child(even) td {
  background-color: var(--joes-input);
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr:nth-child(odd) td {
  background-color: var(--joes-card);
}

body.woocommerce-cart .woocommerce-cart-form table.shop_table tbody tr:hover td {
  background-color: rgba(228, 97, 66, 0.06);
}

/* --- 4.2 Nombres de producto y precios --- */
body.woocommerce-cart .woocommerce-cart-form .cart_item .product-name a {
  color: var(--joes-text);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s ease;
}

body.woocommerce-cart .woocommerce-cart-form .cart_item .product-name a:hover {
  color: var(--joes-orange);
}

body.woocommerce-cart .woocommerce-cart-form .cart_item .product-price,
body.woocommerce-cart .woocommerce-cart-form .cart_item .product-subtotal {
  color: var(--joes-text);
  font-weight: 500;
}

body.woocommerce-cart .woocommerce-cart-form .cart_item .product-price .amount,
body.woocommerce-cart .woocommerce-cart-form .cart_item .product-subtotal .amount {
  color: var(--joes-text);
}

/* --- 4.3 Input cantidad --- */
body.woocommerce-cart input.qty,
body.woocommerce-cart .quantity input.qty {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 6px;
  padding: 0.375rem 0.5rem;
  width: 68px;
  text-align: center;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

body.woocommerce-cart input.qty:focus {
  border-color: var(--joes-orange) !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.2) !important;
  outline: none !important;
}

/* Fila "acciones" debajo de la tabla */
body.woocommerce-cart .woocommerce-cart-form .actions td {
  background-color: var(--joes-deep) !important;
}

/* --- 4.4 Botones del carrito --- */
/* Actualizar carrito */
body.woocommerce-cart .woocommerce-cart-form .button[name="update_cart"] {
  background-color: transparent !important;
  color: var(--joes-orange) !important;
  border: 2px solid var(--joes-orange) !important;
  border-radius: 8px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  padding: 0.5rem 1.25rem;
  transition: background-color 0.2s ease, color 0.2s ease;
}

body.woocommerce-cart .woocommerce-cart-form .button[name="update_cart"]:hover:not(:disabled) {
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
}

body.woocommerce-cart .woocommerce-cart-form .button[name="update_cart"]:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

/* Aplicar cupón */
body.woocommerce-cart .woocommerce-cart-form .coupon .button {
  background-color: transparent !important;
  color: var(--joes-muted) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 8px;
  font-family: 'Inter', sans-serif;
  padding: 0.5rem 1rem;
  transition: border-color 0.2s ease, color 0.2s ease;
}

body.woocommerce-cart .woocommerce-cart-form .coupon .button:hover {
  border-color: var(--joes-orange) !important;
  color: var(--joes-orange) !important;
}

body.woocommerce-cart .woocommerce-cart-form .coupon input#coupon_code {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 6px;
  padding: 0.5rem 0.75rem;
}

body.woocommerce-cart .woocommerce-cart-form .coupon input#coupon_code:focus {
  border-color: var(--joes-orange) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.2) !important;
}

body.woocommerce-cart .woocommerce-cart-form .coupon input#coupon_code::placeholder {
  color: #7a8a94;
}

/* --- 4.5 Totales del carrito (cart_totals) --- */
body.woocommerce-cart .cart_totals {
  background-color: var(--joes-card);
  border-radius: 12px;
  padding: 1.5rem;
  border: 1px solid var(--joes-border);
}

body.woocommerce-cart .cart_totals h2 {
  font-family: 'Montserrat', sans-serif;
  color: var(--joes-text);
  margin-bottom: 1.25rem;
  font-size: 1.15rem;
  font-weight: 700;
}

body.woocommerce-cart .cart_totals table.shop_table {
  background-color: transparent;
  border: none;
  width: 100%;
}

body.woocommerce-cart .cart_totals table.shop_table th,
body.woocommerce-cart .cart_totals table.shop_table td {
  border-bottom: 1px solid var(--joes-border);
  padding: 0.75rem 0;
  color: var(--joes-muted);
  background-color: transparent !important;
}

body.woocommerce-cart .cart_totals table.shop_table th {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--joes-text);
  width: 40%;
}

body.woocommerce-cart .cart_totals .cart-subtotal,
body.woocommerce-cart .cart_totals .order-total {
  background-color: transparent !important;
}

body.woocommerce-cart .cart_totals .cart-subtotal th,
body.woocommerce-cart .cart_totals .cart-subtotal td {
  color: var(--joes-text);
}

body.woocommerce-cart .cart_totals .order-total {
  background-color: var(--joes-deep) !important;
}

body.woocommerce-cart .cart_totals .order-total th,
body.woocommerce-cart .cart_totals .order-total td {
  background-color: var(--joes-deep) !important;
  color: var(--joes-text);
  font-weight: 700;
}

body.woocommerce-cart .cart_totals .order-total .amount {
  color: var(--joes-orange) !important;
  font-size: 1.35rem;
  font-weight: 700;
  font-family: 'Montserrat', sans-serif;
}

/* Bloque shipping */
body.woocommerce-cart .cart_totals .shipping-calculator-button {
  color: var(--joes-orange);
}

body.woocommerce-cart .cart_totals .shipping select,
body.woocommerce-cart .cart_totals .shipping input {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 6px;
}

/* --- 4.6 Botón "Ir al pago" --- */
body.woocommerce-cart .wc-proceed-to-checkout {
  padding: 1rem 0 0.5rem;
  text-align: center;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
body.woocommerce-cart .checkout-button {
  display: block;
  width: 100%;
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
  border: none !important;
  border-radius: 10px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  padding: 0.875rem 1.5rem !important;
  min-height: 52px;
  text-align: center;
  text-decoration: none !important;
  letter-spacing: 0.03em;
  transition: filter 0.2s ease, transform 0.1s ease;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover,
body.woocommerce-cart .checkout-button:hover {
  filter: brightness(1.12);
  transform: translateY(-1px);
  color: var(--joes-text) !important;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button:active {
  transform: translateY(0);
  filter: brightness(0.95);
}

/* Scrollbar de la tabla del carrito */
body.woocommerce-cart .woocommerce-cart-form {
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--joes-orange) var(--joes-deep);
}

body.woocommerce-cart .woocommerce-cart-form::-webkit-scrollbar {
  height: 6px;
}

body.woocommerce-cart .woocommerce-cart-form::-webkit-scrollbar-track {
  background: var(--joes-deep);
  border-radius: 3px;
}

body.woocommerce-cart .woocommerce-cart-form::-webkit-scrollbar-thumb {
  background: var(--joes-orange);
  border-radius: 3px;
}

/* =========================================================
   5. CHECKOUT PAGE  (body.woocommerce-checkout)
   ========================================================= */

/* --- 5.1 Columnas principales --- */
body.woocommerce-checkout #customer_details,
body.woocommerce-checkout #order_review {
  background-color: var(--joes-card);
  border-radius: 12px;
  padding: 1.75rem;
  border: 1px solid var(--joes-border);
  margin-bottom: 1.5rem;
}

body.woocommerce-checkout #customer_details h3,
body.woocommerce-checkout #order_review h3,
body.woocommerce-checkout .woocommerce-checkout h3 {
  font-family: 'Montserrat', sans-serif;
  color: var(--joes-text);
  font-weight: 700;
  font-size: 1.05rem;
  margin-bottom: 1.25rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--joes-border);
}

/* --- 5.2 Labels --- */
body.woocommerce-checkout label,
body.woocommerce-checkout .woocommerce-checkout label {
  color: var(--joes-muted);
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 0.35rem;
}

body.woocommerce-checkout .required {
  color: var(--joes-orange);
}

/* --- 5.3 Inputs, selects, textareas --- */
body.woocommerce-checkout input[type="text"],
body.woocommerce-checkout input[type="email"],
body.woocommerce-checkout input[type="tel"],
body.woocommerce-checkout input[type="password"],
body.woocommerce-checkout input[type="number"],
body.woocommerce-checkout select,
body.woocommerce-checkout textarea,
body.woocommerce-checkout .select2-container--default .select2-selection--single {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 8px !important;
  padding: 0.6rem 0.875rem !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  width: 100%;
  font-family: 'Inter', sans-serif;
  font-size: 0.9rem;
}

body.woocommerce-checkout input[type="text"]:focus,
body.woocommerce-checkout input[type="email"]:focus,
body.woocommerce-checkout input[type="tel"]:focus,
body.woocommerce-checkout input[type="password"]:focus,
body.woocommerce-checkout input[type="number"]:focus,
body.woocommerce-checkout select:focus,
body.woocommerce-checkout textarea:focus {
  border-color: var(--joes-orange) !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.2) !important;
  outline: none !important;
}

body.woocommerce-checkout input[type="text"]::placeholder,
body.woocommerce-checkout input[type="email"]::placeholder,
body.woocommerce-checkout input[type="tel"]::placeholder,
body.woocommerce-checkout input[type="password"]::placeholder,
body.woocommerce-checkout textarea::placeholder {
  color: #7a8a94;
}

body.woocommerce-checkout select option {
  background-color: var(--joes-input);
  color: var(--joes-text);
}

/* Select2 styling (WooCommerce lo usa para países/estados) */
body.woocommerce-checkout .select2-container--default .select2-selection--single {
  height: auto !important;
  line-height: 1.5 !important;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--joes-text) !important;
  padding-left: 0 !important;
  line-height: 1.5 !important;
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%);
}

body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-top-color: var(--joes-muted) !important;
}

body.woocommerce-checkout .select2-dropdown {
  background-color: var(--joes-input) !important;
  border: 1px solid var(--joes-border) !important;
  color: var(--joes-text) !important;
}

body.woocommerce-checkout .select2-container--default .select2-results__option {
  color: var(--joes-muted);
  padding: 0.5rem 0.875rem;
}

body.woocommerce-checkout .select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
}

body.woocommerce-checkout .select2-search--dropdown .select2-search__field {
  background-color: var(--joes-deep) !important;
  color: var(--joes-text) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 4px;
}

/* --- 5.4 Radio / Checkbox --- */
body.woocommerce-checkout input[type="radio"],
body.woocommerce-checkout input[type="checkbox"] {
  accent-color: var(--joes-orange);
  width: 1rem;
  height: 1rem;
  cursor: pointer;
}

/* --- 5.5 Sección de pago (#payment) --- */
body.woocommerce-checkout .woocommerce-checkout-payment,
body.woocommerce-checkout #payment {
  background-color: var(--joes-deep) !important;
  border-radius: 10px;
  padding: 1.25rem;
  border: 1px solid var(--joes-border);
}

body.woocommerce-checkout #payment .payment_methods {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem;
}

body.woocommerce-checkout #payment .payment_methods li {
  background-color: var(--joes-card) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 8px;
  padding: 0.875rem 1rem;
  margin-bottom: 0.625rem;
  transition: border-color 0.2s ease;
}

body.woocommerce-checkout #payment .payment_methods li:hover {
  border-color: var(--joes-border-hov) !important;
}

body.woocommerce-checkout #payment .payment_methods li label {
  color: var(--joes-text);
  font-weight: 500;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

body.woocommerce-checkout #payment .payment_methods input[type="radio"]:checked + label {
  color: var(--joes-orange) !important;
}

body.woocommerce-checkout #payment .payment_box {
  background-color: var(--joes-input) !important;
  border-radius: 6px;
  padding: 0.75rem 1rem;
  margin-top: 0.5rem;
  color: var(--joes-muted);
  font-size: 0.875rem;
}

/* Términos y condiciones */
body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
  color: var(--joes-muted);
  font-size: 0.85rem;
  margin-bottom: 1rem;
}

body.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper a {
  color: var(--joes-orange) !important;
  text-decoration: underline;
}

/* --- 5.6 Botón "Realizar pedido" (#place_order) --- */
body.woocommerce-checkout #place_order {
  display: block !important;
  width: 100% !important;
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
  border: none !important;
  border-radius: 10px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 1.05rem !important;
  min-height: 52px;
  padding: 0.875rem 1.5rem !important;
  letter-spacing: 0.03em;
  text-transform: none;
  transition: filter 0.2s ease, transform 0.1s ease;
  cursor: pointer;
}

body.woocommerce-checkout #place_order:hover {
  filter: brightness(1.12);
  transform: translateY(-1px);
  color: var(--joes-text) !important;
}

body.woocommerce-checkout #place_order:active {
  filter: brightness(0.95);
  transform: translateY(0);
}

/* --- 5.7 Tabla review de orden (lado derecho) --- */
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table {
  background-color: var(--joes-deep);
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--joes-border);
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table th,
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table td {
  border-bottom: 1px solid var(--joes-border);
  padding: 0.75rem 1rem;
  color: var(--joes-muted);
  background-color: transparent;
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table thead th {
  color: var(--joes-text);
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  background-color: var(--joes-card);
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .product-name {
  color: var(--joes-text);
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .product-total .amount {
  color: var(--joes-text);
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .cart-subtotal th,
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .cart-subtotal td,
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .order-total th,
body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .order-total td {
  color: var(--joes-text);
}

body.woocommerce-checkout .shop_table.woocommerce-checkout-review-order-table .order-total .amount {
  color: var(--joes-orange) !important;
  font-size: 1.25rem;
  font-weight: 700;
  font-family: 'Montserrat', sans-serif;
}

/* =========================================================
   6. THANK YOU / ORDER RECEIVED  (body.woocommerce-order-received)
   ========================================================= */

body.woocommerce-order-received .woocommerce-order {
  background-color: var(--joes-card);
  border-radius: 14px;
  padding: 2rem;
  border: 1px solid var(--joes-border);
}

body.woocommerce-order-received .woocommerce-thankyou-order-received {
  font-family: 'Montserrat', sans-serif;
  color: var(--joes-text) !important;
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 1.25rem;
}

/* ── Order overview cards ──────────────────────────────────────────────────── */
/* Kill WC font icons that appear as stray glyphs before/after the list */
body.woocommerce-order-received ul.woocommerce-order-overview::before,
body.woocommerce-order-received ul.woocommerce-order-overview::after,
body.woocommerce-order-received ul.woocommerce-order-overview li::before,
body.woocommerce-order-received ul.woocommerce-order-overview li::after {
  display: none !important;
  content: none !important;
}

body.woocommerce-order-received ul.woocommerce-order-overview {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 1.5rem !important;
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)) !important;
  gap: 0.75rem !important;
}

body.woocommerce-order-received ul.woocommerce-order-overview li {
  background-color: var(--joes-input) !important;
  border: 1px solid var(--joes-border) !important;
  border-left: 3px solid var(--joes-orange) !important;
  border-radius: 0 8px 8px 0 !important;
  padding: 0.875rem 1rem !important;
  color: var(--joes-text) !important;
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  line-height: 1.3 !important;
  /* Reset any WC float/inline styles */
  float: none !important;
  width: auto !important;
  margin: 0 !important;
}

/* Label (the non-bold text before <strong>) */
body.woocommerce-order-received ul.woocommerce-order-overview li {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

body.woocommerce-order-received ul.woocommerce-order-overview li strong {
  display: block !important;
  color: var(--joes-text) !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  order: 2 !important;           /* value below label */
}

/* The label text node — rendered as inline text before <strong> */
/* We can't target text nodes directly; instead style the li color for the label */
body.woocommerce-order-received ul.woocommerce-order-overview li {
  color: var(--joes-muted) !important;
  font-size: 0.72rem !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
}

/* ── Tabla de detalles de la orden ─────────────────────────────────────────── */
body.woocommerce-order-received .woocommerce-table--order-details {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--joes-border);
  margin-bottom: 1.5rem;
  table-layout: fixed;   /* prevents runaway columns */
}

body.woocommerce-order-received .woocommerce-table--order-details th,
body.woocommerce-order-received .woocommerce-table--order-details td {
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--joes-border);
  color: var(--joes-muted);
  background-color: var(--joes-card);
  word-break: break-word;
  vertical-align: top;
}

/* thead */
body.woocommerce-order-received .woocommerce-table--order-details thead th {
  background-color: var(--joes-deep);
  color: var(--joes-text);
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Column widths (fixed layout): product 72%, total 28% */
body.woocommerce-order-received .woocommerce-table--order-details .product-name,
body.woocommerce-order-received .woocommerce-table--order-details .woocommerce-table__product-name {
  width: 72% !important;
}
body.woocommerce-order-received .woocommerce-table--order-details .product-total,
body.woocommerce-order-received .woocommerce-table--order-details .woocommerce-table__product-table {
  width: 28% !important;
  text-align: right !important;
}

/* tbody product name / meta */
body.woocommerce-order-received .woocommerce-table--order-details .woocommerce-table__product-name a {
  color: var(--joes-text) !important;
  text-decoration: none !important;
  font-weight: 600 !important;
}
body.woocommerce-order-received .woocommerce-table--order-details .woocommerce-table__product-name {
  color: var(--joes-text) !important;
}
body.woocommerce-order-received .woocommerce-table--order-details td.product-total,
body.woocommerce-order-received .woocommerce-table--order-details td.woocommerce-table__product-table {
  color: var(--joes-text) !important;
  text-align: right !important;
}

/* tfoot totals */
body.woocommerce-order-received .woocommerce-table--order-details tfoot th,
body.woocommerce-order-received .woocommerce-table--order-details tfoot td {
  background-color: var(--joes-deep);
  color: var(--joes-text);
}
body.woocommerce-order-received .woocommerce-table--order-details tfoot th[scope="row"] {
  text-align: left;
  font-weight: 500;
  color: var(--joes-muted);
}
body.woocommerce-order-received .woocommerce-table--order-details tfoot td {
  text-align: right;
}
/* Highlight order total row */
body.woocommerce-order-received .woocommerce-table--order-details tfoot .order-total th,
body.woocommerce-order-received .woocommerce-table--order-details tfoot .order-total td {
  font-weight: 700;
  color: var(--joes-text);
  border-top: 2px solid var(--joes-border) !important;
}
body.woocommerce-order-received .woocommerce-table--order-details tfoot .order-total .amount {
  color: var(--joes-orange) !important;
  font-size: 1.1rem;
  font-family: 'Montserrat', sans-serif;
}

/* Mobile: stack the overview cards in 2 columns */
@media (max-width: 575px) {
  body.woocommerce-order-received ul.woocommerce-order-overview {
    grid-template-columns: 1fr 1fr !important;
  }
  /* Make table font smaller on very small screens */
  body.woocommerce-order-received .woocommerce-table--order-details th,
  body.woocommerce-order-received .woocommerce-table--order-details td {
    padding: 0.65rem 0.65rem;
    font-size: 0.85rem;
  }
}

/* Delivery info box shown after order table */
.joes-delivery-summary {
  background-color: var(--joes-card);
  border: 1px solid var(--joes-border);
  border-radius: 10px;
  padding: 1.25rem 1.5rem;
  margin-bottom: 1.5rem;
}
.joes-delivery-summary__title {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--joes-muted);
  margin-bottom: 0.75rem;
}
.joes-delivery-summary__row {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.joes-delivery-summary__item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.joes-delivery-summary__label {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--joes-muted);
}
.joes-delivery-summary__value {
  font-weight: 600;
  color: var(--joes-text);
  font-size: 0.95rem;
}

/* Dirección de cliente */
body.woocommerce-order-received .woocommerce-columns--addresses address {
  color: var(--joes-muted);
  font-style: normal;
}

body.woocommerce-order-received .woocommerce-column__title {
  color: var(--joes-text);
  font-family: 'Montserrat', sans-serif;
}

/* =========================================================
   7. MY ACCOUNT  (body.woocommerce-account)
   ========================================================= */

/* --- 7.1 Navegación lateral --- */
body.woocommerce-account .woocommerce-MyAccount-navigation {
  background-color: var(--joes-card);
  border-radius: 12px;
  padding: 1rem;
  border: 1px solid var(--joes-border);
  margin-bottom: 1.25rem;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--joes-border);
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child {
  border-bottom: none;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 0.75rem 1rem;
  color: var(--joes-muted) !important;
  text-decoration: none;
  font-size: 0.9rem;
  border-radius: 6px;
  transition: color 0.2s ease, background-color 0.2s ease;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--joes-orange) !important;
  background-color: rgba(228, 97, 66, 0.08);
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
body.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--active a {
  color: var(--joes-orange) !important;
  background-color: rgba(228, 97, 66, 0.12);
  font-weight: 600;
}

/* --- 7.2 Contenido principal --- */
body.woocommerce-account .woocommerce-MyAccount-content {
  background-color: var(--joes-card);
  border-radius: 12px;
  padding: 1.75rem;
  border: 1px solid var(--joes-border);
  color: var(--joes-muted);
}

body.woocommerce-account .woocommerce-MyAccount-content h2,
body.woocommerce-account .woocommerce-MyAccount-content h3 {
  color: var(--joes-text);
  font-family: 'Montserrat', sans-serif;
}

body.woocommerce-account .woocommerce-MyAccount-content p {
  color: var(--joes-muted);
}

/* --- 7.3 Tabla de órdenes --- */
body.woocommerce-account .woocommerce-orders-table,
body.woocommerce-account table.woocommerce-MyAccount-orders {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--joes-border);
}

body.woocommerce-account .woocommerce-orders-table th,
body.woocommerce-account table.woocommerce-MyAccount-orders th {
  background-color: var(--joes-deep);
  color: var(--joes-text);
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--joes-border);
}

body.woocommerce-account .woocommerce-orders-table td,
body.woocommerce-account table.woocommerce-MyAccount-orders td {
  background-color: var(--joes-card);
  color: var(--joes-muted);
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--joes-border);
}

body.woocommerce-account .woocommerce-orders-table tbody tr:nth-child(even) td,
body.woocommerce-account table.woocommerce-MyAccount-orders tbody tr:nth-child(even) td {
  background-color: var(--joes-input);
}

body.woocommerce-account .woocommerce-orders-table tbody tr:hover td,
body.woocommerce-account table.woocommerce-MyAccount-orders tbody tr:hover td {
  background-color: rgba(228, 97, 66, 0.05);
}

/* Scrollbar tabla órdenes */
body.woocommerce-account .woocommerce-MyAccount-content {
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--joes-orange) var(--joes-deep);
}

body.woocommerce-account .woocommerce-MyAccount-content::-webkit-scrollbar {
  height: 6px;
}

body.woocommerce-account .woocommerce-MyAccount-content::-webkit-scrollbar-track {
  background: var(--joes-deep);
  border-radius: 3px;
}

body.woocommerce-account .woocommerce-MyAccount-content::-webkit-scrollbar-thumb {
  background: var(--joes-orange);
  border-radius: 3px;
}

/* Botones en tabla órdenes — outline naranja */
body.woocommerce-account .woocommerce-orders-table .woocommerce-button,
body.woocommerce-account table.woocommerce-MyAccount-orders .button,
body.woocommerce-account .woocommerce-MyAccount-content .button {
  background-color: transparent !important;
  color: var(--joes-orange) !important;
  border: 1px solid var(--joes-orange) !important;
  border-radius: 6px;
  padding: 0.35rem 0.875rem;
  font-family: 'Inter', sans-serif;
  font-size: 0.825rem;
  font-weight: 500;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease;
  display: inline-block;
}

body.woocommerce-account .woocommerce-orders-table .woocommerce-button:hover,
body.woocommerce-account table.woocommerce-MyAccount-orders .button:hover,
body.woocommerce-account .woocommerce-MyAccount-content .button:hover {
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
}

/* --- 7.4 Formularios en My Account (editar info, cambiar pass) --- */
body.woocommerce-account .woocommerce-MyAccount-content input[type="text"],
body.woocommerce-account .woocommerce-MyAccount-content input[type="email"],
body.woocommerce-account .woocommerce-MyAccount-content input[type="tel"],
body.woocommerce-account .woocommerce-MyAccount-content input[type="password"],
body.woocommerce-account .woocommerce-MyAccount-content select,
body.woocommerce-account .woocommerce-MyAccount-content textarea {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 8px !important;
  padding: 0.6rem 0.875rem !important;
  width: 100%;
  font-family: 'Inter', sans-serif;
}

body.woocommerce-account .woocommerce-MyAccount-content input:focus,
body.woocommerce-account .woocommerce-MyAccount-content select:focus,
body.woocommerce-account .woocommerce-MyAccount-content textarea:focus {
  border-color: var(--joes-orange) !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.2) !important;
  outline: none !important;
}

body.woocommerce-account .woocommerce-MyAccount-content label {
  color: var(--joes-muted);
  font-size: 0.875rem;
}

/* Botón guardar cambios en My Account */
body.woocommerce-account .woocommerce-MyAccount-content [type="submit"],
body.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button {
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  padding: 0.6rem 1.5rem !important;
  transition: filter 0.2s ease;
}

body.woocommerce-account .woocommerce-MyAccount-content [type="submit"]:hover,
body.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button:hover {
  filter: brightness(1.12);
  color: var(--joes-text) !important;
}

/* =========================================================
   8. GUTENBERG BLOCKS (wc-block-components-*)
   ========================================================= */

/* Si WooCommerce usa Blocks en vez de shortcodes */
.wc-block-components-order-summary {
  background-color: var(--joes-card) !important;
  border-radius: 12px;
  border: 1px solid var(--joes-border) !important;
  color: var(--joes-muted) !important;
}

.wc-block-components-order-summary-item__description,
.wc-block-components-order-summary-item__individual-prices {
  color: var(--joes-muted) !important;
}

.wc-block-components-totals-wrapper {
  background-color: var(--joes-deep) !important;
  border-radius: 10px;
  border: 1px solid var(--joes-border) !important;
}

.wc-block-components-totals-item {
  color: var(--joes-muted) !important;
  border-bottom: 1px solid var(--joes-border) !important;
}

.wc-block-components-totals-item__label {
  color: var(--joes-text) !important;
}

.wc-block-components-totals-item--total .wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
  color: var(--joes-orange) !important;
  font-size: 1.25rem;
  font-weight: 700;
  font-family: 'Montserrat', sans-serif;
}

.wc-block-components-text-input input,
.wc-block-components-address-form input,
.wc-block-components-country-input input,
.wc-block-components-state-input input {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 8px !important;
}

.wc-block-components-text-input input:focus,
.wc-block-components-address-form input:focus {
  border-color: var(--joes-orange) !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.2) !important;
  outline: none !important;
}

.wc-block-components-text-input label,
.wc-block-components-address-form label {
  color: var(--joes-muted) !important;
}

.wc-block-components-checkout-place-order-button,
.wc-block-checkout__actions_row .wc-block-components-button {
  background-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
  border: none !important;
  border-radius: 10px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  min-height: 52px;
  width: 100%;
  transition: filter 0.2s ease;
}

.wc-block-components-checkout-place-order-button:hover,
.wc-block-checkout__actions_row .wc-block-components-button:hover {
  filter: brightness(1.12);
  color: var(--joes-text) !important;
}

.wc-block-components-payment-method-label {
  color: var(--joes-text) !important;
}

.wc-block-components-radio-control-accordion-content {
  background-color: var(--joes-input) !important;
  color: var(--joes-muted) !important;
}

/* =========================================================
   9. RESPONSIVE
   ========================================================= */
@media (max-width: 767.98px) {
  body.woocommerce-checkout #customer_details,
  body.woocommerce-checkout #order_review {
    padding: 1.25rem;
  }

  body.woocommerce-cart .cart_totals {
    padding: 1.25rem;
  }

  body.woocommerce-order-received .woocommerce-order {
    padding: 1.25rem;
  }

  body.woocommerce-account .woocommerce-MyAccount-content {
    padding: 1.25rem;
  }

  body.woocommerce-order-received ul.woocommerce-order-overview {
    grid-template-columns: 1fr 1fr !important;
    gap: 0.5rem !important;
  }
}

/* =========================================================
   10. FIXES DE TEMPLATES — clases reemplazadas en PHP
   ========================================================= */

/* thead de tablas del carrito y checkout (reemplazó bg-brown / bg-white) */
.joes-table-head {
  background-color: #0A1018 !important;
  color: #ffffff !important;
}
.joes-table-head th {
  color: #ffffff !important;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 0.8rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.85rem 1rem !important;
  border-bottom: 1px solid rgba(255,255,255,0.1) !important;
}

/* Imagen del producto en el carrito: contener el placeholder */
.woocommerce-cart .product-thumbnail img,
.woocommerce-cart td.product-thumbnail img {
  width: 72px !important;
  height: 72px !important;
  object-fit: cover;
  border-radius: 8px;
  display: block;
}

/* Evitar que la imagen placeholder ocupe toda la pantalla */
.woocommerce-cart .product-thumbnail .woocommerce-placeholder,
.woocommerce-cart .product-thumbnail img[src*="placeholder"] {
  width: 72px !important;
  height: 72px !important;
  max-width: 72px !important;
  object-fit: contain;
  border-radius: 8px;
  background-color: #242B38;
}

/* Filas alternas del carrito en dark */
body.woocommerce-cart .shop_table.cart tbody tr:nth-child(odd) {
  background-color: #1A212C !important;
}
body.woocommerce-cart .shop_table.cart tbody tr:nth-child(even) {
  background-color: #242B38 !important;
}

/* td del carrito */
body.woocommerce-cart .shop_table td {
  color: #B8BFC9 !important;
  border-color: rgba(255,255,255,0.07) !important;
  vertical-align: middle !important;
}

/* Precios en naranja */
body.woocommerce-cart .product-price .woocommerce-Price-amount,
body.woocommerce-cart .product-subtotal .woocommerce-Price-amount {
  color: #e46142 !important;
  font-weight: 600;
}

/* Meta data (addons PVE) */
body.woocommerce-cart .wc-item-meta,
body.woocommerce-cart .wc-item-meta *,
body.woocommerce-cart dl.variation,
body.woocommerce-cart dl.variation dt,
body.woocommerce-cart dl.variation dd {
  color: #B8BFC9 !important;
  font-size: 0.85rem;
}

/* Inputs de cantidad */
body.woocommerce-cart .quantity input.qty {
  background-color: #242B38 !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  border-radius: 6px;
  text-align: center;
  min-width: 3.5rem;
}
body.woocommerce-cart .quantity input.qty:focus {
  border-color: #e46142 !important;
  outline: none;
  box-shadow: 0 0 0 2px rgba(228,97,66,0.25) !important;
}

/* =========================================================
   11. OVERRIDES !important — style.css hardcodes con !important
       Solo en páginas WC para no afectar el resto del sitio
   ========================================================= */

/* Título de página (h1 dentro de .entry-header) — style.css lo pone #33271f !important */
body.woocommerce-cart .entry-header h1,
body.woocommerce-checkout .entry-header h1,
body.woocommerce-order-received .entry-header h1,
body.woocommerce-account .entry-header h1 {
  color: #ffffff !important;
  font-family: 'Montserrat', sans-serif !important;
}

/* Payment box — style.css lo fuerza blanco */
body.woocommerce-checkout .woocommerce-checkout-payment,
body.woocommerce-checkout #payment,
.woocommerce-checkout #payment {
  background-color: #0A1018 !important;
  border-color: rgba(255,255,255,0.1) !important;
}
body.woocommerce-checkout #payment div.payment_box,
.woocommerce-checkout #payment div.payment_box,
#add_payment_method #payment div.payment_box {
  background-color: #242B38 !important;
  color: #B8BFC9 !important;
}
body.woocommerce-checkout #payment div.payment_box::before,
.woocommerce-checkout #payment div.payment_box::before {
  border-bottom-color: #242B38 !important;
  border-right-color: transparent !important;
  border-left-color: transparent !important;
  border-top-color: transparent !important;
}

/* Labels del checkout — style.css los pone negro */
body.woocommerce-checkout .control-label,
body.woocommerce-checkout .woocommerce-checkout .control-label {
  color: #B8BFC9 !important;
}

/* Botones qty +/- en el carrito WooCommerce (default WC template) */
body.woocommerce-cart .quantity .qty,
body.woocommerce-cart .woocommerce-cart-form .quantity input {
  background-color: #242B38 !important;
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
  border-radius: 6px !important;
  text-align: center !important;
  width: 70px !important;
  height: 40px !important;
}
body.woocommerce-cart .quantity .qty:focus,
body.woocommerce-cart .woocommerce-cart-form .quantity input:focus {
  border-color: #e46142 !important;
  box-shadow: 0 0 0 2px rgba(228,97,66,0.25) !important;
  outline: none !important;
}

/* Botones +/- si el tema los agrega (via JS hooks) */
body.woocommerce-cart .quantity .plus,
body.woocommerce-cart .quantity .minus,
body.woocommerce-cart .quantity button.plus,
body.woocommerce-cart .quantity button.minus {
  background-color: #242B38 !important;
  border-color: rgba(255,255,255,0.2) !important;
  color: #e46142 !important;
  font-weight: 700 !important;
}
body.woocommerce-cart .quantity .plus:hover,
body.woocommerce-cart .quantity .minus:hover {
  background-color: #e46142 !important;
  border-color: #e46142 !important;
  color: #ffffff !important;
}

/* Botón "Actualizar carrito" — override del pill naranja con estilo consistente */
body.woocommerce-cart button[name="update_cart"],
body.woocommerce-cart .btn[name="update_cart"] {
  background-color: transparent !important;
  border: 1.5px solid #e46142 !important;
  color: #e46142 !important;
  border-radius: 8px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.05em !important;
  padding: 10px 24px !important;
  transition: background-color 0.2s ease, color 0.2s ease !important;
}
body.woocommerce-cart button[name="update_cart"]:hover {
  background-color: #e46142 !important;
  color: #ffffff !important;
}

/* "Finalizar Compra" — consistente con el resto de botones primarios */
body.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
body.woocommerce-cart a.checkout-button {
  display: block !important;
  background-color: #e46142 !important;
  border: none !important;
  color: #ffffff !important;
  border-radius: 8px !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 14px 32px !important;
  text-align: center !important;
  transition: filter 0.2s ease !important;
}
body.woocommerce-cart a.checkout-button:hover {
  filter: brightness(1.12) !important;
  color: #ffffff !important;
}

/* ============================================================
   SECTION 12 — Plugin custom checkout fields (dark overrides)
   Targets fields injected dynamically by wc-joes-customs
   (class-checkout-fields.php + class-delivery-options.php)
   Zero plugin changes — CSS overrides only.
   ============================================================ */

/* --- 12.1 Fecha / Hora wrappers — side by side layout ------ */
/* Plugin wraps each field in its own block div, so we float them */
#wc_joes_fecha_wrapper {
  float: left !important;
  width: 47% !important;
  box-sizing: border-box !important;
  padding-right: 12px !important;
}
#wc_joes_hora_wrapper {
  float: right !important;
  width: 47% !important;
  box-sizing: border-box !important;
  padding-left: 12px !important;
}
/* Clear the floats before the standard billing fields start */
#wc_joes_hora_wrapper + div,
#wc_joes_hora_wrapper + p {
  clear: both !important;
}
/* Inner <p> must not float on its own (WC gives form-row-first a float) */
#fecha_delivery_pickup_field,
#hora_delivery_pickup_field {
  float: none !important;
  width: 100% !important;
  margin-bottom: 1rem !important;
}

#fecha_delivery_pickup_field label,
#hora_delivery_pickup_field label {
  color: var(--joes-muted) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
  display: block !important;
}

/* abbr required asterisk */
#fecha_delivery_pickup_field label abbr,
#hora_delivery_pickup_field label abbr {
  color: var(--joes-orange) !important;
  text-decoration: none !important;
}

/* --- 12.2 Date text input ----------------------------------- */
#fecha_delivery_pickup {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-size: 0.95rem !important;
  width: 100% !important;
  transition: border-color 0.15s ease !important;
}
#fecha_delivery_pickup::placeholder {
  color: var(--joes-muted) !important;
}
#fecha_delivery_pickup:focus {
  outline: none !important;
  border-color: var(--joes-orange) !important;
  background-color: var(--joes-input) !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.18) !important;
}

/* --- 12.3 Time select --------------------------------------- */
#hora_delivery_pickup {
  background-color: var(--joes-input) !important;
  color: var(--joes-text) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-size: 0.95rem !important;
  width: 100% !important;
  cursor: pointer !important;
  -webkit-appearance: none !important;
  appearance: none !important;
  /* arrow icon */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23B8BFC9' d='M6 8L0 0h12z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  background-size: 10px !important;
  padding-right: 36px !important;
  transition: border-color 0.15s ease !important;
}
#hora_delivery_pickup option {
  background-color: var(--joes-card) !important;
  color: var(--joes-text) !important;
}
#hora_delivery_pickup:focus {
  outline: none !important;
  border-color: var(--joes-orange) !important;
  box-shadow: 0 0 0 3px rgba(228, 97, 66, 0.18) !important;
}

/* WooCommerce validation warning icon on hora field */
#hora_delivery_pickup_field.woocommerce-invalid #hora_delivery_pickup,
#fecha_delivery_pickup_field.woocommerce-invalid #fecha_delivery_pickup {
  border-color: #e46142 !important;
}

/* --- 12.4 jQuery UI Datepicker (calendar popup) ------------ */
.ui-datepicker {
  background-color: var(--joes-card) !important;
  border: 1px solid var(--joes-border) !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
  padding: 12px !important;
  font-family: inherit !important;
  z-index: 9999 !important;
}
.ui-datepicker .ui-datepicker-header {
  background-color: var(--joes-deep) !important;
  color: var(--joes-text) !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 6px 0 !important;
  font-weight: 600 !important;
}
.ui-datepicker .ui-datepicker-title {
  color: var(--joes-text) !important;
}
.ui-datepicker .ui-datepicker-prev,
.ui-datepicker .ui-datepicker-next {
  cursor: pointer !important;
  top: 6px !important;
}
.ui-datepicker .ui-datepicker-prev span,
.ui-datepicker .ui-datepicker-next span {
  background-image: none !important;
}
.ui-datepicker .ui-datepicker-prev::before {
  content: "‹" !important;
  color: var(--joes-muted) !important;
  font-size: 1.4rem !important;
  line-height: 1 !important;
}
.ui-datepicker .ui-datepicker-next::before {
  content: "›" !important;
  color: var(--joes-muted) !important;
  font-size: 1.4rem !important;
  line-height: 1 !important;
}
.ui-datepicker .ui-datepicker-prev:hover,
.ui-datepicker .ui-datepicker-next:hover {
  background: transparent !important;
  border: none !important;
}
.ui-datepicker .ui-datepicker-calendar thead th {
  color: var(--joes-muted) !important;
  font-weight: 600 !important;
  font-size: 0.78rem !important;
  padding: 6px 4px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
}
.ui-datepicker .ui-datepicker-calendar td {
  padding: 2px !important;
}
.ui-datepicker .ui-datepicker-calendar td a,
.ui-datepicker .ui-datepicker-calendar td span {
  background: transparent !important;
  color: var(--joes-text) !important;
  border: 1px solid transparent !important;
  border-radius: 4px !important;
  text-align: center !important;
  padding: 5px 4px !important;
  display: block !important;
  transition: background 0.15s ease !important;
}
.ui-datepicker .ui-datepicker-calendar td a:hover {
  background-color: rgba(228, 97, 66, 0.2) !important;
  border-color: var(--joes-orange) !important;
  color: var(--joes-text) !important;
  text-decoration: none !important;
}
.ui-datepicker .ui-datepicker-calendar .ui-datepicker-today a,
.ui-datepicker .ui-datepicker-calendar .ui-datepicker-today span {
  background-color: rgba(228, 97, 66, 0.15) !important;
  border-color: rgba(228, 97, 66, 0.4) !important;
  font-weight: 700 !important;
}
.ui-datepicker .ui-datepicker-calendar .ui-state-active,
.ui-datepicker .ui-datepicker-calendar .ui-state-highlight {
  background-color: var(--joes-orange) !important;
  color: #fff !important;
  border-color: var(--joes-orange) !important;
  font-weight: 700 !important;
}
.ui-datepicker .ui-datepicker-calendar .ui-datepicker-other-month td a,
.ui-datepicker .ui-datepicker-calendar .ui-datepicker-other-month td span {
  color: var(--joes-muted) !important;
  opacity: 0.4 !important;
}
.ui-datepicker .ui-datepicker-calendar td.ui-datepicker-unselectable span {
  color: var(--joes-muted) !important;
  opacity: 0.3 !important;
}

/* --- 12.5 Delivery method display field -------------------- */
/* The custom 'joes_delivery_modal' type field rendered by plugin */
#city_sector_field,
#billing_city_sector_field {
  margin-bottom: 1.25rem !important;
}

#city_sector_field > label,
#billing_city_sector_field > label {
  color: var(--joes-muted) !important;
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px !important;
  display: block !important;
}
#city_sector_field > label abbr,
#billing_city_sector_field > label abbr {
  color: var(--joes-orange) !important;
  text-decoration: none !important;
}

.joes-delivery-display-field {
  background: var(--joes-input) !important;
  border: 1.5px solid var(--joes-border) !important;
  color: var(--joes-text) !important;
  border-radius: 8px !important;
  transition: border-color 0.2s ease, background-color 0.2s ease !important;
}
.joes-delivery-display-field:hover {
  border-color: var(--joes-border-hov) !important;
  background: var(--joes-input) !important;
}
.joes-delivery-display-field.has-selection {
  border-color: var(--joes-orange) !important;
  background: rgba(228, 97, 66, 0.06) !important;
}
.joes-delivery-selected-text {
  color: var(--joes-text) !important;
}
.joes-delivery-selected-cost {
  color: #5fdb8e !important;
}
.joes-delivery-placeholder {
  color: var(--joes-muted) !important;
}
.joes-delivery-arrow {
  color: var(--joes-muted) !important;
}

/* Description under the field */
#city_sector_field .description,
#billing_city_sector_field .description {
  color: var(--joes-muted) !important;
  font-size: 0.82rem !important;
}

/* --- 12.6 Delivery method modal (Bootstrap modal) ---------- */
.joes-delivery-modal .modal-content {
  background-color: var(--joes-card) !important;
  border: 1px solid var(--joes-border) !important;
  color: var(--joes-text) !important;
  border-radius: 12px !important;
}
.joes-delivery-modal .modal-header {
  background: linear-gradient(135deg, #1f2d3d 0%, var(--joes-deep) 100%) !important;
  color: var(--joes-text) !important;
  border-bottom: 1px solid var(--joes-border) !important;
  border-radius: 12px 12px 0 0 !important;
}
.joes-delivery-modal .modal-title {
  color: var(--joes-text) !important;
}
.joes-delivery-modal .modal-footer {
  border-top: 1px solid var(--joes-border) !important;
  background-color: var(--joes-card) !important;
  border-radius: 0 0 12px 12px !important;
}
.joes-delivery-modal .modal-body {
  background-color: var(--joes-card) !important;
}

/* Option cards */
.joes-delivery-option-card {
  background: var(--joes-input) !important;
  border: 2px solid var(--joes-border) !important;
  color: var(--joes-text) !important;
}
.joes-delivery-option-card:hover {
  border-color: var(--joes-border-hov) !important;
  background: rgba(255, 255, 255, 0.06) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.35) !important;
}
.joes-delivery-option-card.selected {
  border-color: var(--joes-orange) !important;
  background: rgba(228, 97, 66, 0.1) !important;
  box-shadow: 0 4px 15px rgba(228, 97, 66, 0.2) !important;
}
.joes-delivery-option-label {
  color: var(--joes-text) !important;
}
.joes-delivery-option-type {
  color: var(--joes-muted) !important;
}
.joes-delivery-option-cost {
  color: #5fdb8e !important;
}
.joes-delivery-option-cost.free {
  color: #5fdb8e !important;
}

/* Radio circles */
.joes-delivery-option-radio-custom {
  border-color: var(--joes-border-hov) !important;
  background: transparent !important;
}
.joes-delivery-option-card.selected .joes-delivery-option-radio-custom {
  border-color: var(--joes-orange) !important;
  background: var(--joes-orange) !important;
}

/* Icon backgrounds (dine-in / pickup / delivery) */
.joes-delivery-option-icon.dine-in {
  background: rgba(255, 234, 167, 0.15) !important;
  color: #e46142 !important;
}
.joes-delivery-option-icon.pickup {
  background: rgba(167, 229, 255, 0.12) !important;
  color: #5bc0de !important;
}
.joes-delivery-option-icon.delivery {
  background: rgba(95, 219, 142, 0.12) !important;
  color: #5fdb8e !important;
}

/* Modal buttons */
.joes-delivery-modal .btn-primary {
  background: var(--joes-orange) !important;
  border: none !important;
  color: #fff !important;
}
.joes-delivery-modal .btn-primary:hover {
  filter: brightness(1.12) !important;
  transform: none !important;
  box-shadow: none !important;
}
.joes-delivery-modal .btn-secondary {
  background: transparent !important;
  border: 1px solid var(--joes-border-hov) !important;
  color: var(--joes-muted) !important;
}
.joes-delivery-modal .btn-secondary:hover {
  background: rgba(255,255,255,0.06) !important;
  color: var(--joes-text) !important;
}

/* --- 12.7 Dine-in options panel ---------------------------- */
.joes-dine-in-options {
  background: rgba(95, 219, 142, 0.06) !important;
  border: 1px solid rgba(95, 219, 142, 0.25) !important;
  color: var(--joes-text) !important;
}
.joes-dine-in-options .woocommerce-form__label-text {
  color: #5fdb8e !important;
}
.joes-dine-in-options label {
  color: var(--joes-text) !important;
}

/* --- 12.8 Print receipt button ----------------------------- */
.joes-print-receipt-btn {
  background: var(--joes-orange) !important;
  border: none !important;
  color: #fff !important;
}
.joes-print-receipt-btn:hover {
  filter: brightness(1.1) !important;
  background: var(--joes-orange) !important;
}
/* ============================================================ */
