/* Template: account-page
 *
 * Mobile-first (80% del tráfico). Reglas críticas:
 *   - Tap targets ≥44px (botones, links de nav, inputs, checkboxes).
 *   - Inputs con font-size ≥16px (evita zoom iOS al focus).
 *   - Tabs de WooCommerce: scroll horizontal en mobile, wrap en desktop.
 *   - Tablas de pedidos: stack a cards en mobile usando data-title de WC.
 *   - Login/Registro y Direcciones: grid 2 col en desktop, stack en mobile.
 *
 * Solo CSS in-scope. El template.php renderiza [woocommerce_my_account],
 * por lo que la mayoría de selectores apuntan al markup nativo de Woo.
 */

/* === Wrapper de página ==============================================
 * No tocamos el padding horizontal: lo aporta .pf-riojano-container
 * (gutter responsive 16→32px). Solo añadimos espacio vertical.
 * =================================================================== */
.pf-riojano-account {
  padding-top: var(--pf-riojano-space-5);
  padding-bottom: var(--pf-riojano-space-8);
}
.pf-riojano-account__head { text-align: center; margin-bottom: var(--pf-riojano-space-5); }
.pf-riojano-account__title { font-family: var(--pf-riojano-font-display); margin: 0; }

/* === Navegación lateral de WooCommerce =============================
 * Mobile: scroll horizontal con snap, tap target 44px, sin wrap.
 * Desktop (≥768px): wrap normal con borde inferior continuo.
 * =================================================================== */
.pf-riojano-account .woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--pf-riojano-space-4);
  display: flex;
  flex-wrap: nowrap;
  gap: var(--pf-riojano-space-2);
  border-bottom: var(--pf-riojano-border-soft);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
}
.pf-riojano-account .woocommerce-MyAccount-navigation ul::-webkit-scrollbar { height: 3px; }
.pf-riojano-account .woocommerce-MyAccount-navigation li {
  flex: 0 0 auto;
  scroll-snap-align: start;
}
.pf-riojano-account .woocommerce-MyAccount-navigation li a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: var(--pf-riojano-space-2) var(--pf-riojano-space-3);
  text-decoration: none;
  color: var(--pf-riojano-brand-primary-soft);
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-sm);
}
.pf-riojano-account .woocommerce-MyAccount-navigation li.is-active a,
.pf-riojano-account .woocommerce-MyAccount-navigation li a:hover,
.pf-riojano-account .woocommerce-MyAccount-navigation li a:focus-visible {
  color: var(--pf-riojano-brand-primary);
  border-bottom-color: var(--pf-riojano-brand-accent-strong);
}
@media (min-width: 768px) {
  .pf-riojano-account .woocommerce-MyAccount-navigation ul {
    flex-wrap: wrap;
    overflow-x: visible;
  }
}

/* === Contenido de la sección activa ================================ */
.pf-riojano-account .woocommerce-MyAccount-content {
  background: var(--pf-riojano-neutral-white);
  border: var(--pf-riojano-border-soft);
  border-radius: var(--pf-riojano-radius-lg);
  padding: var(--pf-riojano-space-4);
}
.pf-riojano-account .woocommerce-MyAccount-content h2,
.pf-riojano-account .woocommerce-MyAccount-content h3 {
  font-family: var(--pf-riojano-font-display);
  margin: 0 0 var(--pf-riojano-space-3);
}
.pf-riojano-account .woocommerce-MyAccount-content h2:not(:first-child),
.pf-riojano-account .woocommerce-MyAccount-content h3:not(:first-child) {
  margin-top: var(--pf-riojano-space-5);
}
.pf-riojano-account .woocommerce-MyAccount-content p { margin: 0 0 var(--pf-riojano-space-3); }
.pf-riojano-account .woocommerce-MyAccount-content address {
  font-style: normal;
  line-height: 1.6;
}

/* === Formularios (login, registro, datos, dirección) =============== */
.pf-riojano-account form input[type="text"],
.pf-riojano-account form input[type="email"],
.pf-riojano-account form input[type="password"],
.pf-riojano-account form input[type="tel"],
.pf-riojano-account form input[type="number"],
.pf-riojano-account form select,
.pf-riojano-account form textarea {
  width: 100%;
  min-height: 44px;
  padding: var(--pf-riojano-space-2) var(--pf-riojano-space-3);
  border: var(--pf-riojano-border-soft);
  border-radius: var(--pf-riojano-radius-md);
  font-family: var(--pf-riojano-font-body);
  /* 16px evita el zoom automático de iOS al hacer focus en un input. */
  font-size: 16px;
  background: var(--pf-riojano-neutral-white);
  color: var(--pf-riojano-brand-primary);
}
.pf-riojano-account form input:focus-visible,
.pf-riojano-account form select:focus-visible,
.pf-riojano-account form textarea:focus-visible {
  outline: 2px solid var(--pf-riojano-brand-accent);
  outline-offset: 1px;
  border-color: transparent;
}
.pf-riojano-account form label {
  display: block;
  margin: 0 0 var(--pf-riojano-space-1);
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-sm);
  color: var(--pf-riojano-brand-primary-soft);
}
.pf-riojano-account form .form-row,
.pf-riojano-account form p.form-row {
  margin: 0 0 var(--pf-riojano-space-3);
}
.pf-riojano-account .woocommerce-form__label-for-checkbox,
.pf-riojano-account label.checkbox {
  display: inline-flex;
  align-items: center;
  gap: var(--pf-riojano-space-2);
  min-height: 44px;
  font-family: var(--pf-riojano-font-body);
  font-size: var(--pf-riojano-fs-base);
  color: var(--pf-riojano-brand-primary);
}
.pf-riojano-account form .password-input { position: relative; }
.pf-riojano-account form .show-password-input {
  position: absolute;
  right: var(--pf-riojano-space-3);
  top: 50%;
  transform: translateY(-50%);
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

/* === Botones — tap target ≥44px, full-width en mobile ============== */
.pf-riojano-account button[type="submit"],
.pf-riojano-account .woocommerce-Button,
.pf-riojano-account .button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: var(--pf-riojano-space-2) var(--pf-riojano-space-4);
  background: var(--pf-riojano-cta-bg);
  color: var(--pf-riojano-cta-fg);
  border: 0;
  border-radius: var(--pf-riojano-radius-md);
  cursor: pointer;
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-sm);
  text-decoration: none;
  transition: background var(--pf-riojano-transition-fast);
}
.pf-riojano-account button[type="submit"]:hover,
.pf-riojano-account .woocommerce-Button:hover,
.pf-riojano-account .button:hover {
  background: var(--pf-riojano-cta-bg-hover);
}
@media (max-width: 600px) {
  .pf-riojano-account button[type="submit"],
  .pf-riojano-account .woocommerce-Button {
    width: 100%;
  }
}

/* === Login / Registro: 2 columnas desktop, stack mobile ============
 * WC envuelve en .u-columns con .u-column1 / .u-column2 que llevan
 * width:47% inline. Sobreescribimos con grid.
 * =================================================================== */
.pf-riojano-account .u-columns {
  display: grid;
  gap: var(--pf-riojano-space-5);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .pf-riojano-account .u-columns { grid-template-columns: 1fr 1fr; }
}
.pf-riojano-account .u-columns::before,
.pf-riojano-account .u-columns::after { display: none; }
.pf-riojano-account .u-column1,
.pf-riojano-account .u-column2 {
  width: 100% !important;
  float: none !important;
}
.pf-riojano-account .woocommerce-form-login,
.pf-riojano-account .woocommerce-form-register {
  border: var(--pf-riojano-border-soft);
  border-radius: var(--pf-riojano-radius-lg);
  padding: var(--pf-riojano-space-4);
}
.pf-riojano-account .woocommerce-LostPassword {
  margin-top: var(--pf-riojano-space-3);
  font-size: var(--pf-riojano-fs-sm);
}
.pf-riojano-account .woocommerce-LostPassword a {
  color: var(--pf-riojano-brand-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* === Dashboard (escritorio de la cuenta) =========================== */
.pf-riojano-account .woocommerce-MyAccount-content > p:first-of-type {
  font-size: var(--pf-riojano-fs-md);
}

/* === Tabla de pedidos / descargas — responsive cards en mobile ====
 * WC pone data-title en cada <td>. Lo usamos como label vía ::before.
 * Desktop ≥601px: tabla normal con borde inferior por fila.
 * =================================================================== */
.pf-riojano-account .woocommerce-orders-table,
.pf-riojano-account .shop_table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 var(--pf-riojano-space-4);
}
.pf-riojano-account .woocommerce-orders-table th,
.pf-riojano-account .shop_table th {
  text-align: left;
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-sm);
  font-weight: 600;
  padding: var(--pf-riojano-space-2) var(--pf-riojano-space-3);
  border-bottom: var(--pf-riojano-border-soft);
  color: var(--pf-riojano-brand-primary-soft);
}
.pf-riojano-account .woocommerce-orders-table td,
.pf-riojano-account .shop_table td {
  padding: var(--pf-riojano-space-3);
  border-bottom: var(--pf-riojano-border-soft);
  vertical-align: middle;
  font-size: var(--pf-riojano-fs-base);
}
.pf-riojano-account .woocommerce-orders-table .button,
.pf-riojano-account .shop_table .button {
  margin: var(--pf-riojano-space-1) var(--pf-riojano-space-1) var(--pf-riojano-space-1) 0;
}

/* Chip discreto de estado de pedido */
.pf-riojano-account .woocommerce-orders-table__cell-order-status {
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-sm);
}
.pf-riojano-account .woocommerce-orders-table__cell-order-status::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--pf-riojano-brand-accent);
  margin-right: var(--pf-riojano-space-2);
  vertical-align: 1px;
}

@media (max-width: 600px) {
  .pf-riojano-account .woocommerce-orders-table,
  .pf-riojano-account .shop_table { border: 0; }
  /* thead oculto accesiblemente; los labels los aporta data-title. */
  .pf-riojano-account .woocommerce-orders-table thead,
  .pf-riojano-account .shop_table thead {
    position: absolute;
    width: 1px; height: 1px;
    overflow: hidden;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    white-space: nowrap;
  }
  .pf-riojano-account .woocommerce-orders-table tr,
  .pf-riojano-account .shop_table tr {
    display: block;
    border: var(--pf-riojano-border-soft);
    border-radius: var(--pf-riojano-radius-md);
    padding: var(--pf-riojano-space-2);
    margin: 0 0 var(--pf-riojano-space-3);
    background: var(--pf-riojano-neutral-white);
  }
  .pf-riojano-account .woocommerce-orders-table td,
  .pf-riojano-account .shop_table td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--pf-riojano-space-3);
    padding: var(--pf-riojano-space-2) var(--pf-riojano-space-1);
    border-bottom: 1px dashed rgba(31, 32, 105, 0.08);
    text-align: right;
  }
  .pf-riojano-account .woocommerce-orders-table td:last-child,
  .pf-riojano-account .shop_table td:last-child { border-bottom: 0; }
  .pf-riojano-account .woocommerce-orders-table td::before,
  .pf-riojano-account .shop_table td::before {
    content: attr(data-title);
    font-family: var(--pf-riojano-font-display);
    font-size: var(--pf-riojano-fs-sm);
    font-weight: 600;
    color: var(--pf-riojano-brand-primary-soft);
    text-align: left;
    flex: 0 0 40%;
  }
  .pf-riojano-account .woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions,
  .pf-riojano-account .shop_table td.actions {
    flex-wrap: wrap;
    justify-content: flex-end;
  }
  .pf-riojano-account .woocommerce-orders-table td.woocommerce-orders-table__cell-order-actions::before,
  .pf-riojano-account .shop_table td.actions::before {
    flex: 0 0 100%;
    margin-bottom: var(--pf-riojano-space-1);
  }
  .pf-riojano-account .woocommerce-orders-table .button,
  .pf-riojano-account .shop_table .button { width: 100%; }
}

/* Paginación de pedidos */
.pf-riojano-account .woocommerce-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pf-riojano-space-1);
  margin: var(--pf-riojano-space-4) 0;
}
.pf-riojano-account .woocommerce-pagination a,
.pf-riojano-account .woocommerce-pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0 var(--pf-riojano-space-2);
  border: var(--pf-riojano-border-soft);
  border-radius: var(--pf-riojano-radius-md);
  color: var(--pf-riojano-brand-primary-soft);
  text-decoration: none;
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-sm);
}
.pf-riojano-account .woocommerce-pagination .current {
  background: var(--pf-riojano-brand-primary);
  color: var(--pf-riojano-cta-fg);
  border-color: transparent;
}

/* === Direcciones (lista y edición) ================================= */
.pf-riojano-account .woocommerce-Addresses,
.pf-riojano-account .u-columns.addresses {
  display: grid;
  gap: var(--pf-riojano-space-4);
  grid-template-columns: 1fr;
  margin: 0 0 var(--pf-riojano-space-5);
}
@media (min-width: 768px) {
  .pf-riojano-account .woocommerce-Addresses,
  .pf-riojano-account .u-columns.addresses {
    grid-template-columns: 1fr 1fr;
  }
}
.pf-riojano-account .woocommerce-Address {
  border: var(--pf-riojano-border-soft);
  border-radius: var(--pf-riojano-radius-md);
  padding: var(--pf-riojano-space-3);
}
.pf-riojano-account .woocommerce-Address-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--pf-riojano-space-2);
  margin: 0 0 var(--pf-riojano-space-2);
}
.pf-riojano-account .woocommerce-Address-title h2,
.pf-riojano-account .woocommerce-Address-title h3 {
  margin: 0;
  font-family: var(--pf-riojano-font-display);
  font-size: var(--pf-riojano-fs-md);
}
.pf-riojano-account .woocommerce-Address-title .edit {
  font-size: var(--pf-riojano-fs-sm);
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* === Pedido individual (vista detalle) ============================= */
.pf-riojano-account .woocommerce-order-details,
.pf-riojano-account .woocommerce-customer-details {
  margin: 0 0 var(--pf-riojano-space-5);
}
.pf-riojano-account .woocommerce-order-details__title,
.pf-riojano-account .woocommerce-customer-details h2,
.pf-riojano-account .woocommerce-column__title {
  font-family: var(--pf-riojano-font-display);
}
@media (min-width: 768px) {
  .pf-riojano-account .woocommerce-customer-details .col2-set {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--pf-riojano-space-4);
  }
  .pf-riojano-account .woocommerce-customer-details .col-1,
  .pf-riojano-account .woocommerce-customer-details .col-2 {
    width: 100% !important;
    float: none !important;
  }
}

/* === Notices WC =================================================== */
.pf-riojano-account .woocommerce-notices-wrapper { margin: 0 0 var(--pf-riojano-space-4); }
.pf-riojano-account .woocommerce-message,
.pf-riojano-account .woocommerce-info,
.pf-riojano-account .woocommerce-error {
  padding: var(--pf-riojano-space-3);
  border-radius: var(--pf-riojano-radius-md);
  border: var(--pf-riojano-border-soft);
  background: var(--pf-riojano-neutral-cream);
  list-style: none;
}
