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

:root {
  --lbi-brand:        #1a1a1a;
  --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;
}
.lbi-pw-wrap:focus-within {
  border-bottom-color: var(--lbi-border-focus) !important;
}
.lbi-pw-wrap .input-text,
.lbi-pw-wrap input {
  border: none !important;
  border-bottom: none !important;
  flex: 1 !important;
  padding-right: .4rem !important;
  box-shadow: none !important;
}

/* Reset total del botón toggle contraseña */
.lbi-pw-wrap button.lbi-toggle-pw {
  all: unset !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !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;
  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-brand) !important;
  color: #fff !important;
}
.lbi-card a.lbi-btn--primary:hover,
.lbi-card button.lbi-btn--primary:hover {
  opacity: .84 !important;
  transform: translateY(-1px) !important;
  color: #fff !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;
}

/* ============================================================
   MODAL OVERLAY — producto exclusivo
   ============================================================ */
.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, .65) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !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-brand) !important;
  color: #fff !important;
}
a.lbi-modal__btn--primary:hover {
  opacity: .84 !important;
  transform: translateY(-1px) !important;
  color: #fff !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;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@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; }
}
