/**
 * Estilos para el sistema de tabs de Mis Pedidos y Mis Cupones
 * VeneGift Order Notes Manager
 */

/* Contenedor de tabs */
.tab-container {
  display: flex;
  margin-bottom: 20px;
  border-bottom: 2px solid #e0e0e0;
}

.tab {
  padding: 12px 20px;
  cursor: pointer;
  background-color: #f0f0f0;
  border: 1px solid #ccc;
  border-bottom: none;
  margin-right: 5px;
  transition: all 0.3s ease;
  border-radius: 4px 4px 0 0;
  font-weight: 500;
}

.tab:hover {
  background-color: #e8e8e8;
}

.tab.active {
  background-color: #ffffff;
  border-bottom: 2px solid #ffffff;
  margin-bottom: -2px;
}

/* Contenido de tabs */
.tab-content {
  display: none;
  animation: fadeIn 0.3s ease-in-out;
}

.tab-content.show {
  display: block;
}

.tab-content h3 {
  font-weight: bold;
  margin-bottom: 15px;
}

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

/* Badges de notificaciones */
.header-notification-badge {
    position: absolute;
    top: -18px;
    right: -25px;
    background-color: #ff5722;
    color: white;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    font-size: 12px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    z-index: 100;
}

.notification-badge {
    position: absolute;
    top: -8px;
    right: -8px;
    background-color: #ff5722;
    color: white;
    border-radius: 50%;
    width: 20px;
    height: 20px;
    font-size: 12px;
    font-weight: bold;
    display: flex;
    justify-content: center;
    align-items: center;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

/* Contador de cupones */
#coupon-count {
  font-size: 0.9em;
  color: #666;
  font-weight: normal;
}

/* ============================
   BADGES DE ESTADO DE PEDIDOS
   ============================ */

.order-status-badge {
  display: inline-block;
  padding: 6px 12px;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  white-space: nowrap;
  line-height: 1.2;
  transition: all 0.2s ease;
}

/* Estados estándar de WooCommerce */
.order-status-badge.status-pending {
  background-color: #f8dda7 !important;
  color: #94660c !important;
}

.order-status-badge.status-processing {
  background-color: #c8d7e1 !important;
  color: #2e4453 !important;
}

.order-status-badge.status-on-hold {
  background-color: #f8dda7 !important;
  color: #94660c !important;
}

.order-status-badge.status-completed {
  background-color: #c6e1c6 !important;
  color: #5b841b !important;
}

.order-status-badge.status-cancelled {
  background-color: #e5e5e5 !important;
  color: #777 !important;
}

.order-status-badge.status-refunded {
  background-color: #e5e5e5 !important;
  color: #777 !important;
}

.order-status-badge.status-failed {
  background-color: #eba3a3 !important;
  color: #761919 !important;
}

/* Estados personalizados de Venegift */
.order-status-badge.status-under-review {
  background-color: #fff4ce !important;
  color: #8a6d3b !important;
}

.order-status-badge.status-pago-erroneo {
  background-color: #ffd9b3 !important;
  color: #cc5200 !important;
}

.order-status-badge.status-verifying-info {
  background-color: #e8e8e8 !important;
  color: #555 !important;
}

/* Efecto hover para todos los badges */
.order-status-badge:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 4px rgba(0,0,0,0.1);
}

/* ============================
   RESUMEN DEL PEDIDO (Ver Detalles)
   ============================ */

/* Títulos de sección */
.vg-section-title {
  font-size: var(--vg-font-md);
  font-weight: var(--vg-font-semibold);
  color: var(--vg-text-primary);
  margin: 0 0 var(--vg-space-3) 0;
  padding-bottom: var(--vg-space-2);
  border-bottom: var(--vg-border-thin) solid var(--vg-border-normal);
}

/* Contenedor del resumen */
.vg-order-summary {
  margin-bottom: var(--vg-space-4);
  padding: var(--vg-space-4);
  background-color: var(--vg-bg-white);
  border: var(--vg-border-thin) solid var(--vg-border-light);
  border-radius: var(--vg-radius-lg);
}

/* Items del pedido */
.vg-order-item {
  padding: var(--vg-space-3) 0;
  border-bottom: var(--vg-border-thin) solid var(--vg-border-light);
}

.vg-order-item:last-child {
  border-bottom: none;
}

.vg-item-name {
  font-weight: var(--vg-font-semibold);
  color: var(--vg-text-primary);
  font-size: var(--vg-font-base);
  margin-bottom: var(--vg-space-1);
}

.vg-item-qty {
  font-size: var(--vg-font-sm);
  color: var(--vg-text-secondary);
  margin-bottom: var(--vg-space-1);
}

/* Meta data del item */
.vg-item-meta {
  margin: var(--vg-space-2) 0;
  padding-left: var(--vg-space-3);
}

.vg-meta-row {
  font-size: var(--vg-font-sm);
  color: var(--vg-text-secondary);
  margin-bottom: var(--vg-space-1);
  line-height: var(--vg-line-height-normal);
}

.vg-meta-label {
  font-weight: var(--vg-font-medium);
  color: var(--vg-text-primary);
}

.vg-meta-value {
  color: var(--vg-text-secondary);
}

/* Subtotal del item */
.vg-item-total {
  font-size: var(--vg-font-sm);
  color: var(--vg-text-primary);
  text-align: right;
  margin-top: var(--vg-space-1);
}

/* Total del pedido */
.vg-order-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--vg-space-3);
  padding-top: var(--vg-space-3);
  border-top: var(--vg-border-normal) solid var(--vg-border-normal);
}

.vg-total-label {
  font-size: var(--vg-font-md);
  font-weight: var(--vg-font-bold);
  color: var(--vg-text-primary);
}

.vg-total-amount {
  font-size: var(--vg-font-md);
  font-weight: var(--vg-font-bold);
  color: var(--vg-text-primary);
}

/* Precio */
.vg-price {
  white-space: nowrap;
}

.vg-currency-symbol {
  margin-right: 2px;
}

/* Sección de comunicaciones */
.vg-communications {
  padding: var(--vg-space-4);
  background-color: var(--vg-bg-light);
  border: var(--vg-border-thin) solid var(--vg-border-light);
  border-radius: var(--vg-radius-lg);
}

.vg-no-notes {
  color: var(--vg-text-muted);
  font-size: var(--vg-font-base);
  margin: 0;
}

/* Responsive */
@media (max-width: 768px) {
  .vg-order-summary,
  .vg-communications {
    padding: var(--vg-space-3);
  }

  .vg-item-meta {
    padding-left: var(--vg-space-2);
  }

  .vg-order-total {
    flex-direction: column;
    align-items: flex-end;
    gap: var(--vg-space-1);
  }
}

/* ============================
   CONTADOR DE PEDIDOS
   ============================ */

.vg-orders-counter {
  color: var(--vg-text-secondary);
  font-size: var(--vg-font-sm);
  margin-bottom: var(--vg-space-2);
}

/* ============================
   PAGINACIÓN INTELIGENTE
   ============================ */

.vg-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--vg-space-1);
  flex-wrap: wrap;
  margin-top: var(--vg-space-5);
}

.vg-pagination a,
.vg-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: var(--vg-space-1) var(--vg-space-2);
  border: var(--vg-border-thin) solid var(--vg-border-normal);
  border-radius: var(--vg-radius-sm);
  text-decoration: none;
  color: var(--vg-text-primary);
  font-size: var(--vg-font-sm);
  cursor: pointer;
  transition: var(--vg-transition-fast);
}

.vg-pagination a:hover {
  background-color: var(--vg-bg-medium);
  border-color: var(--vg-border-dark);
}

.vg-pagination .vg-page-current {
  background-color: var(--vg-primary);
  color: var(--vg-text-white);
  border-color: var(--vg-primary);
  cursor: default;
  font-weight: var(--vg-font-semibold);
}

.vg-pagination .vg-page-ellipsis {
  border: none;
  cursor: default;
  min-width: auto;
  padding: var(--vg-space-1);
  color: var(--vg-text-muted);
}

.vg-pagination .vg-page-ellipsis:hover {
  background-color: transparent;
}

.vg-pagination .vg-page-disabled {
  color: var(--vg-text-muted);
  border-color: var(--vg-border-light);
  cursor: default;
  opacity: 0.5;
}

.vg-pagination .vg-page-disabled:hover {
  background-color: transparent;
}

.vg-pagination .vg-page-prev,
.vg-pagination .vg-page-next {
  font-weight: var(--vg-font-medium);
  padding: var(--vg-space-1) var(--vg-space-3);
}

@media (max-width: 768px) {
  .vg-pagination {
    gap: var(--vg-space-1);
  }

  .vg-pagination a,
  .vg-pagination span {
    min-width: 32px;
    height: 32px;
    font-size: var(--vg-font-xs);
    padding: var(--vg-space-1);
  }

  .vg-pagination .vg-page-prev,
  .vg-pagination .vg-page-next {
    padding: var(--vg-space-1) var(--vg-space-2);
  }
}
