/* ============================================================
   La Butique – Intranet Profesionales | Styles v1.0.0
   Autor: Tramma IT
   ============================================================ */

:root {
  --lbi-brand:        #1a1a1a;
  --lbi-accent:       #CEB790;   /* color botón primario */
  --lbi-accent-text:  #1a1a1a;   /* texto sobre el botón dorado */
  --lbi-bg:           #f8f7f5;
  --lbi-card-bg:      #ffffff;
  --lbi-border:       #d4d4d4;
  --lbi-border-focus: #1a1a1a;
  --lbi-text:         #1a1a1a;
  --lbi-muted:        #888;
  --lbi-radius:       4px;
  --lbi-shadow:       0 6px 40px rgba(0,0,0,.13);
  --lbi-transition:   .18s ease;
}

/* ============================================================
   WRAPPER — centra el card, anula ancho del tema
   ============================================================ */
.lbi-wrap {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 65vh !important;
  padding: 3rem 1rem !important;
  background: var(--lbi-bg) !important;
  margin-left:  calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
  box-sizing: border-box !important;
}

/* ============================================================
   CARD
   ============================================================ */
.lbi-card {
  background: var(--lbi-card-bg) !important;
  border: 1px solid #ebebeb !important;
  border-radius: 10px !important;
  box-shadow: var(--lbi-shadow) !important;
  padding: 2.5rem 2.25rem 2rem !important;
  width: 100% !important;
  max-width: 460px !important;
  box-sizing: border-box !important;
}

/* ============================================================
   LOGO
   ============================================================ */
.lbi-logo { text-align: center; margin-bottom: 1.25rem; }
.lbi-site-logo { max-height: 60px; width: auto; }

/* ============================================================
   INTRO
   ============================================================ */
.lbi-intro {
  font-size: .875rem !important;
  color: var(--lbi-muted) !important;
  text-align: center !important;
  margin: 0 0 1.75rem !important;
  line-height: 1.6 !important;
}

/* ============================================================
   TABS — reset total del tema + estilos propios
   ============================================================ */
.lbi-tabs {
  display: flex !important;
  gap: 1.5rem !important;
  margin: 0 0 1.75rem !important;
  padding: 0 !important;
  border: none !important;
  border-bottom: 1.5px solid var(--lbi-border) !important;
  background: none !important;
  list-style: none !important;
}

/* Reset nuclear para los tabs — anula TODO lo que el tema aplique a <button> */
.lbi-card button.lbi-tab {
  all: unset !important;
  display: inline-block !important;
  padding: 0 0 .65rem !important;
  margin-bottom: -1.5px !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: #aaa !important;
  cursor: pointer !important;
  position: relative !important;
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  line-height: 1.3 !important;
  transition: color var(--lbi-transition) !important;
}

.lbi-card button.lbi-tab::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2.5px !important;
  background: var(--lbi-brand) !important;
  border-radius: 2px 2px 0 0 !important;
  transform: scaleX(0) !important;
  transition: transform var(--lbi-transition) !important;
}

.lbi-card button.lbi-tab.lbi-tab--active {
  color: var(--lbi-brand) !important;
}
.lbi-card button.lbi-tab.lbi-tab--active::after {
  transform: scaleX(1) !important;
}

/* ============================================================
   PANELS
   ============================================================ */
.lbi-panel         { display: none !important; }
.lbi-panel--active { display: block !important; }

/* ============================================================
   FORMULARIO
   ============================================================ */
.lbi-form {
  display: flex !important;
  flex-direction: column !important;
  gap: 1.25rem !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Neutralizar columnas de WooCommerce dentro del card */
.lbi-card .u-columns,
.lbi-card .col2-set { display: block !important; }
.lbi-card .u-column1,
.lbi-card .u-column2 { width: 100% !important; float: none !important; }

.lbi-field {
  display: flex !important;
  flex-direction: column !important;
  gap: .3rem !important;
  padding: 0 !important;
  margin: 0 !important;
}

.lbi-field label {
  font-size: .75rem !important;
  font-weight: 600 !important;
  color: var(--lbi-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  margin: 0 !important;
  cursor: default !important;
}

.lbi-req { color: #e74c3c; margin-left: 2px; }

.lbi-field small { font-size: .78rem; color: var(--lbi-muted); }

/* Inputs — underline style, override del tema */
.lbi-form .input-text,
.lbi-form input[type="text"],
.lbi-form input[type="email"],
.lbi-form input[type="password"] {
  width: 100% !important;
  box-sizing: border-box !important;
  background: transparent !important;
  border: none !important;
  border-bottom: 1.5px solid var(--lbi-border) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: .5rem 0 !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--lbi-text) !important;
  outline: none !important;
  transition: border-color var(--lbi-transition) !important;
  -webkit-appearance: none !important;
}
.lbi-form .input-text:focus,
.lbi-form input[type="text"]:focus,
.lbi-form input[type="email"]:focus,
.lbi-form input[type="password"]:focus {
  border-bottom-color: var(--lbi-border-focus) !important;
  box-shadow: none !important;
  outline: none !important;
}

/* Password wrap */
.lbi-pw-wrap {
  display: flex !important;
  align-items: center !important;
  border-bottom: 1.5px solid var(--lbi-border) !important;
  transition: border-color var(--lbi-transition) !important;
  background: none !important;
  position: relative !important;
}
.lbi-pw-wrap:focus-within {
  border-bottom-color: var(--lbi-border-focus) !important;
}
.lbi-pw-wrap .input-text,
.lbi-pw-wrap input[type="password"],
.lbi-pw-wrap input[type="text"] {
  border: none !important;
  border-bottom: none !important;
  flex: 1 !important;
  width: auto !important;
  min-width: 0 !important;
  padding-right: 2rem !important;
  box-shadow: none !important;
}

/* Ocultar el toggle nativo de WooCommerce — usamos el nuestro */
.lbi-form .show-password-input,
.lbi-form .woocommerce-Input-showpassword,
.lbi-pw-wrap .show-password-input {
  display: none !important;
}

/* Reset total del botón toggle contraseña — pegado al extremo derecho */
.lbi-pw-wrap button.lbi-toggle-pw {
  all: unset !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 24px !important;
  height: 24px !important;
  cursor: pointer !important;
  color: var(--lbi-muted) !important;
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  flex-shrink: 0 !important;
  position: absolute !important;
  right: 0 !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  transition: color var(--lbi-transition) !important;
}
.lbi-pw-wrap button.lbi-toggle-pw:hover {
  color: var(--lbi-brand) !important;
  background: none !important;
}

/* Instagram prefix */
.lbi-prefix-wrap {
  display: flex !important;
  align-items: center !important;
  border-bottom: 1.5px solid var(--lbi-border) !important;
  transition: border-color var(--lbi-transition) !important;
}
.lbi-prefix-wrap:focus-within {
  border-bottom-color: var(--lbi-border-focus) !important;
}
.lbi-prefix {
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--lbi-muted) !important;
  padding: .5rem .15rem .5rem 0 !important;
  user-select: none !important;
}
.lbi-prefix-wrap .input-text,
.lbi-prefix-wrap input {
  border: none !important;
  border-bottom: none !important;
  flex: 1 !important;
  box-shadow: none !important;
}

/* Remember me */
.lbi-remember {
  margin: 0 !important;
  padding: 0 !important;
}
.lbi-remember label {
  display: flex !important;
  align-items: center !important;
  gap: .45rem !important;
  font-size: .875rem !important;
  color: var(--lbi-muted) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  cursor: pointer !important;
  font-weight: normal !important;
}
.lbi-remember input[type="checkbox"] {
  width: 15px !important;
  height: 15px !important;
  border: 1.5px solid var(--lbi-border) !important;
  border-radius: 3px !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  flex-shrink: 0 !important;
}

/* ============================================================
   BOTÓN PRINCIPAL — reset total + estilos propios
   ============================================================ */
.lbi-card a.lbi-btn,
.lbi-card button.lbi-btn {
  all: unset !important;
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: .85rem 1rem !important;
  border-radius: var(--lbi-radius) !important;
  font-size: .95rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  cursor: pointer !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  transition: opacity var(--lbi-transition), transform var(--lbi-transition) !important;
  margin-top: .25rem !important;
}
.lbi-card a.lbi-btn--primary,
.lbi-card button.lbi-btn--primary {
  background: var(--lbi-accent) !important;
  color: var(--lbi-accent-text) !important;
}
.lbi-card a.lbi-btn--primary:hover,
.lbi-card button.lbi-btn--primary:hover {
  opacity: .86 !important;
  transform: translateY(-1px) !important;
  color: var(--lbi-accent-text) !important;
}
.lbi-card a.lbi-btn--primary:active,
.lbi-card button.lbi-btn--primary:active {
  transform: translateY(0) !important;
  opacity: 1 !important;
}

/* ============================================================
   ¿OLVIDASTE TU CONTRASEÑA?
   ============================================================ */
.lbi-forgot { text-align: center; margin-top: .5rem; }
.lbi-forgot a {
  font-size: .85rem !important;
  color: var(--lbi-muted) !important;
  text-decoration: none !important;
}
.lbi-forgot a:hover {
  color: var(--lbi-brand) !important;
  text-decoration: underline !important;
}

/* ============================================================
   BADGE — "Exclusivo para profesionales" (página de producto)
   ============================================================ */
.lbi-pro-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: .4rem !important;
  margin: .1rem 0 .75rem !important;
  padding: .35rem .75rem .35rem .55rem !important;
  background: linear-gradient(135deg, rgba(206,183,144,.15) 0%, rgba(206,183,144,.08) 100%) !important;
  border: 1px solid rgba(206,183,144,.55) !important;
  border-radius: 20px !important;
  line-height: 1 !important;
}

.lbi-pro-badge__icon {
  display: flex !important;
  align-items: center !important;
  color: var(--lbi-accent) !important;
  flex-shrink: 0 !important;
}

.lbi-pro-badge__text {
  font-size: .78rem !important;
  font-weight: 700 !important;
  letter-spacing: .06em !important;
  text-transform: uppercase !important;
  color: #a07840 !important;
}

/* ============================================================
   MODAL OVERLAY — producto exclusivo
   ============================================================ */
/* Blur sobre el contenido de la página (precio, imágenes, descripción) */
body.lbi-locked > *:not(.lbi-overlay):not(#wpadminbar) {
  filter: blur(12px) !important;
  pointer-events: none !important;
  user-select: none !important;
  transition: filter .25s ease !important;
}

.lbi-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 99999 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 1rem !important;
  background: rgba(0, 0, 0, .72) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
  animation: lbi-fade-in .25s ease !important;
}

@keyframes lbi-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.lbi-modal {
  background: #fff !important;
  border-radius: 12px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.25) !important;
  padding: 2.5rem 2rem !important;
  width: 100% !important;
  max-width: 420px !important;
  text-align: center !important;
  animation: lbi-slide-up .28s ease !important;
  box-sizing: border-box !important;
}

@keyframes lbi-slide-up {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.lbi-modal__logo {
  max-height: 50px !important;
  width: auto !important;
  margin: 0 auto 1.25rem !important;
  display: block !important;
}

.lbi-modal__lock {
  color: #bbb !important;
  margin: 0 auto .75rem !important;
  display: flex !important;
  justify-content: center !important;
}

.lbi-modal__title {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: var(--lbi-brand) !important;
  margin: 0 0 .75rem !important;
  line-height: 1.3 !important;
}

.lbi-modal__text {
  font-size: .9rem !important;
  color: var(--lbi-muted) !important;
  line-height: 1.6 !important;
  margin: 0 0 1.75rem !important;
}

.lbi-modal__actions {
  display: flex !important;
  flex-direction: column !important;
  gap: .75rem !important;
}

/* Botones del modal — reset total */
a.lbi-modal__btn {
  all: unset !important;
  display: block !important;
  width: 100% !important;
  box-sizing: border-box !important;
  padding: .8rem 1rem !important;
  border-radius: var(--lbi-radius) !important;
  font-size: .9rem !important;
  font-weight: 700 !important;
  text-align: center !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: opacity var(--lbi-transition), transform var(--lbi-transition), background var(--lbi-transition) !important;
}
a.lbi-modal__btn--primary {
  background: var(--lbi-accent) !important;
  color: var(--lbi-accent-text) !important;
}
a.lbi-modal__btn--primary:hover {
  opacity: .86 !important;
  transform: translateY(-1px) !important;
  color: var(--lbi-accent-text) !important;
}
a.lbi-modal__btn--outline {
  background: transparent !important;
  color: var(--lbi-brand) !important;
  border: 1.5px solid var(--lbi-brand) !important;
}
a.lbi-modal__btn--outline:hover {
  background: var(--lbi-brand) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
}

/* ============================================================
   CATÁLOGO — header (bienvenida + cerrar sesión)
   ============================================================ */
.lbi-catalogo__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1.5px solid var(--lbi-border);
}
.lbi-catalogo__header-left { flex: 1; }
.lbi-catalogo__title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--lbi-brand);
  margin: 0 0 .2rem;
}
.lbi-catalogo__bienvenida {
  font-size: .9rem;
  color: var(--lbi-muted);
  margin: 0;
}
.lbi-logout {
  all: unset;
  display: inline-block;
  font-size: .85rem;
  color: var(--lbi-muted);
  text-decoration: none;
  border: 1px solid var(--lbi-border);
  padding: .35rem .75rem;
  border-radius: var(--lbi-radius);
  white-space: nowrap;
  cursor: pointer;
  transition: color var(--lbi-transition), border-color var(--lbi-transition);
}
.lbi-logout:hover { color: #c0392b; border-color: #e74c3c; }

.lbi-catalogo__empty {
  text-align: center;
  color: var(--lbi-muted);
  padding: 3rem 0;
}

/* ============================================================
   MI CUENTA — ocultar título de página
   ============================================================ */
.woocommerce-account .entry-title,
.woocommerce-account h1.entry-title,
.woocommerce-account h1.page-title {
  display: none !important;
}

/* ============================================================
   MI CUENTA — espaciado general
   ============================================================ */
.woocommerce-account .woocommerce {
  padding-top: 2.5rem !important;
  padding-bottom: 3rem !important;
}

/* ============================================================
   MI CUENTA — layout: nav a la izquierda, contenido a la derecha
   ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation {
  width: 100% !important;
  float: none !important;
}
.woocommerce-account .woocommerce-MyAccount-content {
  width: 100% !important;
  float: none !important;
}

/* ============================================================
   MI CUENTA — saludo "Hola, Nombre"
   ============================================================ */
.lbi-account-greeting {
  font-family: inherit !important;   /* toma la fuente h2 del tema */
  font-size: clamp(1.6rem, 3vw, 2.4rem) !important;
  font-weight: inherit !important;
  line-height: 1.2 !important;
  color: var(--lbi-brand) !important;
  margin: 0 0 1.5rem !important;
  padding: 0 !important;
}

.lbi-account-greeting__name {
  color: var(--lbi-accent) !important;
}

/* ============================================================
   NAV MI CUENTA — grid de botones grandes con icono
   ============================================================ */
.lbi-account-nav ul {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1rem !important;
  list-style: none !important;
  margin: 0 0 2.5rem !important;
  padding: 0 !important;
}

.lbi-account-nav li {
  margin: 0 !important;
  padding: 0 !important;
}

/* Botón nav: reset completo del tema + estilos propios */
a.lbi-nav-item {
  all: unset !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: .6rem !important;
  padding: 1.4rem 1rem 1.2rem !important;
  background: #fff !important;
  border: 1.5px solid var(--lbi-border) !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 10px rgba(0,0,0,.06) !important;
  text-align: center !important;
  cursor: pointer !important;
  text-decoration: none !important;
  transition:
    border-color var(--lbi-transition),
    box-shadow var(--lbi-transition),
    transform var(--lbi-transition),
    background var(--lbi-transition) !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

a.lbi-nav-item:hover {
  border-color: var(--lbi-accent) !important;
  box-shadow: 0 4px 18px rgba(206,183,144,.25) !important;
  transform: translateY(-2px) !important;
  background: #fdfaf6 !important;
  text-decoration: none !important;
  color: inherit !important;
}

a.lbi-nav-item:active {
  transform: translateY(0) !important;
}

/* Item activo (página actual) */
.woocommerce-MyAccount-navigation li.is-active a.lbi-nav-item,
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--active a.lbi-nav-item {
  background: var(--lbi-accent) !important;
  border-color: var(--lbi-accent) !important;
  box-shadow: 0 4px 16px rgba(206,183,144,.35) !important;
}

.woocommerce-MyAccount-navigation li.is-active a.lbi-nav-item .lbi-nav-item__icon,
.woocommerce-MyAccount-navigation li.is-active a.lbi-nav-item .lbi-nav-item__label,
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--active a.lbi-nav-item .lbi-nav-item__icon,
.woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--active a.lbi-nav-item .lbi-nav-item__label {
  color: var(--lbi-accent-text) !important;
}

/* Icono SVG */
.lbi-nav-item__icon {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: var(--lbi-brand) !important;
  transition: color var(--lbi-transition) !important;
}

/* Etiqueta de texto */
.lbi-nav-item__label {
  font-size: .8rem !important;
  font-weight: 600 !important;
  color: var(--lbi-brand) !important;
  letter-spacing: .03em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  transition: color var(--lbi-transition) !important;
}

/* Botón de cerrar sesión — distinción visual */
a.lbi-nav-item--logout .lbi-nav-item__icon,
a.lbi-nav-item--logout .lbi-nav-item__label {
  color: #999 !important;
}
a.lbi-nav-item--logout:hover {
  border-color: #e74c3c !important;
  background: #fff5f5 !important;
  box-shadow: 0 4px 14px rgba(231,76,60,.12) !important;
}
a.lbi-nav-item--logout:hover .lbi-nav-item__icon,
a.lbi-nav-item--logout:hover .lbi-nav-item__label {
  color: #c0392b !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .lbi-account-nav ul {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 520px) {
  .lbi-card  { padding: 2rem 1.25rem 1.5rem !important; }
  .lbi-card button.lbi-tab { font-size: 1rem !important; }
  .lbi-modal { padding: 2rem 1.25rem !important; }
  .lbi-account-nav ul {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: .75rem !important;
  }
  a.lbi-nav-item {
    padding: 1.1rem .75rem 1rem !important;
  }
  .lbi-nav-item__label {
    font-size: .72rem !important;
  }
}
