/* ==========================================================================
   RN.MATES. Mi cuenta (WooCommerce)
   Layout de cuenta: navegación lateral + contenido, tablas de pedidos,
   formularios (login/registro/edición), direcciones y estados de pedido.
   Reutiliza tokens y clases rn-* de theme.css. NO modifica theme.css.
   ========================================================================== */

/* ----------------------------------------------------------------------------
   1. Layout general (nav lateral + contenido)
   WooCommerce envuelve todo en .woocommerce-account .woocommerce con
   navigation.php + my-account.php (content). Lo convertimos en grilla.
   ---------------------------------------------------------------------------- */
.woocommerce-account .woocommerce {
  display: grid;
  gap: clamp(1.5rem, 4vw, 2.75rem);
  align-items: start;
}

@media (min-width: 880px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 260px minmax(0, 1fr);
  }
}

/* En login (sin sesión) el contenido va a ancho completo. */
.woocommerce-account:not(.logged-in) .woocommerce {
  display: block;
}

/* ----------------------------------------------------------------------------
   2. Navegación lateral
   ---------------------------------------------------------------------------- */
.rn-account__nav {
  position: sticky;
  top: calc(var(--header-h) + 1rem);
}

.rn-account__nav-list {
  list-style: none;
  margin: 0;
  padding: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: var(--c-crema);
  border: 1px solid var(--c-linea);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
}

.rn-account__nav-link {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.7rem 0.85rem;
  border-radius: var(--r-md);
  color: var(--c-tinta-2);
  font-size: var(--fs-sm);
  font-weight: 500;
  line-height: 1.2;
  transition: background var(--tr), color var(--tr);
}

.rn-account__nav-link:hover {
  background: var(--c-crema-2);
  color: var(--c-verde-700);
}

.rn-account__nav-ico {
  display: grid;
  place-items: center;
  flex: none;
  width: 22px;
  height: 22px;
  color: var(--c-cuero-600);
  transition: color var(--tr);
}

.rn-account__nav-ico svg {
  width: 20px;
  height: 20px;
  stroke-width: 1.75;
}

/* Ítem activo: WooCommerce agrega .is-active al <li>. */
.woocommerce-MyAccount-navigation-link.is-active > .rn-account__nav-link {
  background: var(--c-verde-600);
  color: var(--c-crema);
}

.woocommerce-MyAccount-navigation-link.is-active > .rn-account__nav-link .rn-account__nav-ico {
  color: var(--c-crema);
}

/* Logout: matiz cálido para diferenciar. */
.woocommerce-MyAccount-navigation-link--customer-logout > .rn-account__nav-link:hover {
  color: var(--c-acento-700);
}

/* ----------------------------------------------------------------------------
   3. Contenido
   ---------------------------------------------------------------------------- */
.rn-account__content {
  min-width: 0;
}

.rn-account__content > h2,
.rn-account__panel-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--c-verde-900);
  margin-bottom: var(--sp-4);
}

.rn-account__content p {
  max-width: 70ch;
}

/* ----------------------------------------------------------------------------
   4. Dashboard
   ---------------------------------------------------------------------------- */
.rn-account__greeting {
  margin-bottom: var(--sp-6);
}

.rn-account__hello {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  color: var(--c-verde-900);
  line-height: var(--lh-tight);
}

.rn-account__sub {
  margin-top: var(--sp-2);
}

.rn-account__shortcuts {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.rn-account__shortcut {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-4);
  padding: var(--sp-5);
  color: var(--c-tinta);
  transition: transform var(--tr), box-shadow var(--tr), border-color var(--tr);
}

.rn-account__shortcut:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-md);
  border-color: var(--c-verde-300);
  color: var(--c-tinta);
}

.rn-account__shortcut-ico {
  display: grid;
  place-items: center;
  flex: none;
  width: 46px;
  height: 46px;
  border-radius: var(--r-md);
  background: var(--c-verde-50);
  color: var(--c-verde-600);
}

.rn-account__shortcut-ico svg {
  width: 24px;
  height: 24px;
  stroke-width: 1.75;
}

.rn-account__shortcut-text b {
  display: block;
  font-weight: 500;
  color: var(--c-verde-900);
  margin-bottom: 0.15rem;
}

.rn-account__shortcut-text .text-muted {
  font-size: var(--fs-sm);
}

/* ----------------------------------------------------------------------------
   5. Tablas de pedidos
   ---------------------------------------------------------------------------- */
.rn-account__table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  border: 1px solid var(--c-linea);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-crema);
}

.rn-account__table thead th {
  text-align: left;
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--c-tinta-3);
  background: var(--c-crema-2);
  padding: 0.85rem 1rem;
  border-bottom: 1px solid var(--c-linea);
}

.rn-account__table tbody td {
  padding: 0.95rem 1rem;
  border-bottom: 1px solid var(--c-linea);
  color: var(--c-tinta-2);
  vertical-align: middle;
}

.rn-account__table tbody tr:last-child td {
  border-bottom: none;
}

.rn-account__table tbody tr:hover {
  background: var(--c-crema-2);
}

.rn-account__table a:not(.rn-btn) {
  color: var(--c-verde-700);
  font-weight: 500;
}

.rn-account__table .woocommerce-orders-table__cell-order-actions,
.rn-account__table .order-actions {
  text-align: right;
  white-space: nowrap;
}

.rn-account__table .rn-btn {
  margin: 0.15rem 0 0.15rem 0.4rem;
}

/* Responsive: tarjetas apiladas en mobile (WC usa shop_table_responsive). */
@media (max-width: 600px) {
  .rn-account__table,
  .rn-account__table thead,
  .rn-account__table tbody,
  .rn-account__table tr,
  .rn-account__table td {
    display: block;
    width: 100%;
  }

  .rn-account__table thead {
    position: absolute;
    left: -9999px;
  }

  .rn-account__table tr {
    border: 1px solid var(--c-linea);
    border-radius: var(--r-md);
    margin-bottom: var(--sp-3);
    padding: 0.4rem 0.2rem;
    background: var(--c-crema);
  }

  .rn-account__table tbody td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    text-align: right;
    border-bottom: 1px dashed var(--c-linea);
  }

  .rn-account__table tbody tr td:last-child {
    border-bottom: none;
  }

  .rn-account__table tbody td::before {
    content: attr(data-title);
    font-size: var(--fs-xs);
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--c-tinta-3);
    text-align: left;
  }

  .rn-account__table .woocommerce-orders-table__cell-order-actions,
  .rn-account__table .order-actions {
    text-align: right;
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  .rn-account__table .order-actions::before {
    display: none;
  }
}

/* ----------------------------------------------------------------------------
   6. Estados de pedido (badge)
   ---------------------------------------------------------------------------- */
.rn-account__status {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 0.28rem 0.65rem;
  border-radius: var(--r-pill);
  background: var(--c-crema-2);
  color: var(--c-tinta-2);
  border: 1px solid var(--c-linea);
  white-space: nowrap;
}

mark.rn-account__status {
  background: var(--c-crema-2);
}

.rn-account__status--completed {
  background: var(--c-verde-100);
  color: var(--c-verde-800);
  border-color: transparent;
}

.rn-account__status--processing,
.rn-account__status--on-hold {
  background: var(--c-acento-50);
  color: var(--c-acento-700);
  border-color: transparent;
}

.rn-account__status--pending {
  background: #f5ecd4;
  color: #7a5510;
  border-color: transparent;
}

.rn-account__status--cancelled,
.rn-account__status--failed,
.rn-account__status--refunded {
  background: #f3dedb;
  color: var(--c-error);
  border-color: transparent;
}

/* ----------------------------------------------------------------------------
   7. Paginación de pedidos
   ---------------------------------------------------------------------------- */
.rn-account__pagination {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
}

.rn-account__pagination .woocommerce-button--next {
  margin-left: auto;
}

/* ----------------------------------------------------------------------------
   8. Estado vacío (sin pedidos)
   ---------------------------------------------------------------------------- */
.rn-account__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-4);
  padding: clamp(2rem, 6vw, 3.5rem);
}

.rn-account__empty-ico {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: var(--r-pill);
  background: var(--c-verde-50);
  color: var(--c-verde-600);
}

.rn-account__empty-ico svg {
  width: 28px;
  height: 28px;
  stroke-width: 1.75;
}

.rn-account__empty p {
  margin: 0;
  color: var(--c-tinta-2);
}

/* ----------------------------------------------------------------------------
   9. Detalle de pedido (view-order)
   ---------------------------------------------------------------------------- */
.rn-account__order-meta {
  background: var(--c-crema-2);
  border: 1px solid var(--c-linea);
  border-radius: var(--r-md);
  padding: 0.9rem 1.1rem;
  font-size: var(--fs-sm);
  color: var(--c-tinta-2);
  margin-bottom: var(--sp-5);
  max-width: none;
}

.rn-account__order-meta mark {
  background: none;
  color: var(--c-verde-800);
  font-weight: 600;
}

.rn-account__order-meta mark.rn-account__status {
  font-weight: 500;
}

/* Detalle de items: WooCommerce imprime .woocommerce-table--order-details. */
.woocommerce-order-details,
.woocommerce-customer-details {
  margin-top: var(--sp-6);
}

.woocommerce-order-details__title,
.woocommerce-column__title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--c-verde-900);
  margin-bottom: var(--sp-3);
}

.woocommerce-table--order-details,
.shop_table.order_details {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
  border: 1px solid var(--c-linea);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--c-crema);
}

.woocommerce-table--order-details th,
.woocommerce-table--order-details td,
.shop_table.order_details th,
.shop_table.order_details td {
  padding: 0.8rem 1rem;
  border-bottom: 1px solid var(--c-linea);
  text-align: left;
  vertical-align: top;
}

.woocommerce-table--order-details tfoot th,
.shop_table.order_details tfoot th {
  text-align: right;
  color: var(--c-tinta-2);
  font-weight: 500;
}

.woocommerce-table--order-details tfoot tr:last-child th,
.woocommerce-table--order-details tfoot tr:last-child td {
  font-size: var(--fs-body);
  color: var(--c-verde-900);
  font-weight: 600;
  border-bottom: none;
}

.woocommerce-table--order-details .product-total,
.shop_table.order_details td.product-total {
  text-align: right;
  white-space: nowrap;
}

.rn-account__notes {
  list-style: none;
  padding: 0;
  margin: var(--sp-3) 0 var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.rn-account__note {
  background: var(--c-crema);
  border: 1px solid var(--c-linea);
  border-left: 3px solid var(--c-verde-600);
  border-radius: var(--r-md);
  padding: 0.9rem 1.1rem;
}

.rn-account__note .meta {
  font-size: var(--fs-xs);
  color: var(--c-tinta-3);
  margin-bottom: 0.3rem;
}

/* ----------------------------------------------------------------------------
   10. Formularios (login / registro / edición)
   ---------------------------------------------------------------------------- */
.rn-account__form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.rn-account__form .rn-field {
  margin: 0;
}

.rn-account__form-grid {
  display: grid;
  gap: var(--sp-4);
}

@media (min-width: 560px) {
  .rn-account__form-grid {
    grid-template-columns: 1fr 1fr;
  }
}

.rn-account__form-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
}

.rn-account__remember {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: var(--fs-sm);
  color: var(--c-tinta-2);
  margin: 0;
  cursor: pointer;
}

.rn-account__remember input {
  width: 1.05rem;
  height: 1.05rem;
  accent-color: var(--c-verde-600);
}

.rn-account__lost {
  margin: 0;
  font-size: var(--fs-sm);
}

.rn-account__hint {
  font-size: var(--fs-sm);
  margin-top: 0.2rem;
}

.required {
  color: var(--c-acento-700);
  border: none;
}

/* Fieldset (cambio de contraseña) */
.rn-account__fieldset {
  border: 1px solid var(--c-linea);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin: 0;
}

.rn-account__legend {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--c-verde-800);
  padding: 0 0.5rem;
}

.rn-account__panel {
  padding: clamp(1.25rem, 4vw, 2rem);
}

/* ----------------------------------------------------------------------------
   11. Login / Registro (cards en dos columnas)
   ---------------------------------------------------------------------------- */
.rn-account__auth {
  display: grid;
  gap: clamp(1.25rem, 4vw, 2rem);
  max-width: 520px;
  margin-inline: auto;
}

.rn-account__auth--two {
  max-width: var(--container);
}

@media (min-width: 760px) {
  .rn-account__auth--two {
    grid-template-columns: 1fr 1fr;
    align-items: start;
  }
}

.rn-account__auth-card {
  padding: clamp(1.5rem, 4vw, 2.25rem);
  height: 100%;
}

.rn-account__auth-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--c-verde-900);
  margin-bottom: var(--sp-5);
}

/* ----------------------------------------------------------------------------
   12. Direcciones
   ---------------------------------------------------------------------------- */
.rn-account__intro {
  margin-bottom: var(--sp-5);
}

.rn-account__addresses {
  display: grid;
  gap: var(--sp-5);
}

@media (min-width: 620px) {
  .rn-account__addresses {
    grid-template-columns: 1fr 1fr;
  }
}

.rn-account__address-card {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.rn-account__address-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
}

.rn-account__address-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  color: var(--c-verde-900);
  margin: 0;
}

.rn-account__address-edit {
  font-size: var(--fs-sm);
  font-weight: 500;
  flex: none;
}

.rn-account__address-card address {
  font-style: normal;
  line-height: var(--lh-body);
  color: var(--c-tinta-2);
  font-size: var(--fs-sm);
}

/* Grilla de campos del formulario de dirección (WooCommerce los imprime
   con .form-row-first / .form-row-last / .form-row-wide). */
.rn-account__address-grid {
  display: grid;
  gap: var(--sp-4);
}

@media (min-width: 560px) {
  .rn-account__address-grid {
    grid-template-columns: 1fr 1fr;
  }
  .rn-account__address-grid .form-row-wide,
  .rn-account__address-grid .form-row-first,
  .rn-account__address-grid .form-row-last {
    grid-column: span 2;
  }
}

/* WooCommerce imprime sus campos con .woocommerce-input-wrapper + <label>.
   Los alineamos al estilo label-arriba del design system. */
.rn-account__address-grid .form-row {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin: 0;
}

.rn-account__address-grid label {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--c-tinta-2);
}

.rn-account__address-grid input.input-text,
.rn-account__address-grid select,
.rn-account__address-grid .select2-container .select2-selection {
  width: 100%;
  padding: 0.7rem 0.9rem;
  background: var(--c-crema);
  color: var(--c-tinta);
  border: 1px solid var(--c-arena-2);
  border-radius: var(--r-md);
  transition: border-color var(--tr), box-shadow var(--tr);
}

.rn-account__address-grid input.input-text:focus,
.rn-account__address-grid select:focus {
  outline: none;
  border-color: var(--c-verde-600);
  box-shadow: 0 0 0 3px var(--c-verde-100);
}

/* select2 (país/provincia): alto coherente. */
.rn-account__address-grid .select2-container .select2-selection--single {
  height: auto;
  min-height: 44px;
  display: flex;
  align-items: center;
}

/* ----------------------------------------------------------------------------
   13. Avisos de WooCommerce dentro de cuenta (mensajes/errores)
   ---------------------------------------------------------------------------- */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-error,
.woocommerce-account .woocommerce-info {
  font-size: var(--fs-sm);
}

/* Mantiene legible el subrayado de enlaces dentro de avisos. */
.rn-account__content .woocommerce-Message a,
.rn-account__content .woocommerce-info a {
  font-weight: 500;
}
