

/* ===== Product tagline + title spacing ===== */
.lr-product-tagline{
  margin: 0 0 6px;
  font-size: clamp(14px, 1.9vw, 16px);
  line-height: 1.35;
  color: #6b7280;
  font-weight: 500;
  letter-spacing: .2px;
  opacity: .95;
}
.single-product .product .product_title{ margin-top: .1rem; }

/* ===== Woo notices: monocromo sin azul ===== */
.woocommerce-info,
.woocommerce-message,
.woocommerce-error{
  border: none !important;
  background: #fff !important;
  color: #111 !important;
  box-shadow: none !important;
}
.woocommerce-info::before,
.woocommerce-message::before,
.woocommerce-error::before{
  color: #000 !important;
}

/* ===== Botones Woo (global) ===== */
.woocommerce button,
.woocommerce-page button,
.woocommerce a.button,
.woocommerce-page a.button,
.woocommerce input.button,
.woocommerce-page input.button,
.woocommerce #respond input#submit,
.woocommerce-page #respond input#submit{
  border-radius: 12px !important;
}

/* ===== My Account: layout general ===== */
.woocommerce-account .woocommerce-MyAccount-content{
  background:#fff;
  border-radius:16px;
  padding:28px;
  box-shadow:0 12px 32px rgba(0,0,0,.06);
  border:1px solid #eee;
}
.woocommerce-MyAccount-navigation ul{
  display:flex; flex-direction:column; gap:10px;
}
.woocommerce-MyAccount-navigation ul li a{
  display:flex; align-items:center; gap:10px;
  padding:12px 16px;
  border-radius:12px;
  background:#fff;
  border:1px solid #eee;
  color:#111; font-weight:600;
  box-shadow:0 4px 12px rgba(0,0,0,.04);
  transition:transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li a:hover{
  border-color:#111;
  transform:translateY(-1px);
  box-shadow:0 10px 20px rgba(0,0,0,.07);
}
.woocommerce-account .woocommerce-MyAccount-content > p:first-of-type{
  color:#555; margin-bottom:18px;
}

/* ===== My Account → Addresses ===== */

/* 0) Contenedor en grid (mata floats legacy) */
.woocommerce-MyAccount-content .u-columns.woocommerce-Addresses.addresses{
  display:grid;
  grid-template-columns: repeat(2, minmax(320px, 1fr));
  gap:24px;
  align-items:start;
  width:100%;
}
.woocommerce-MyAccount-content .u-columns.woocommerce-Addresses.addresses .col-1,
.woocommerce-MyAccount-content .u-columns.woocommerce-Addresses.addresses .col-2{
  float:none !important;
  width:auto !important;
  margin:0 !important;
}

/* 1) Tarjeta */
.woocommerce-Addresses .woocommerce-Address{
  position:relative;
  background:#fafafa;
  border:1px solid #eee;
  border-radius:16px;
  padding:22px 22px 64px;   /* espacio p/ botón */
  box-shadow:0 8px 20px rgba(0,0,0,.04);
  min-height:220px;
  box-sizing:border-box;
}

/* 2) Título + reserva para botón */
.woocommerce-Address .title{
  position:relative;
  display:flex; align-items:flex-start; justify-content:flex-start;
  padding-right:120px;              /* evita choque con el botón */
  margin-bottom:8px;
}
.woocommerce-Address-title h3{
  margin:0;
  font-size:12px;                   /* más equilibrado */
  font-weight:800;
  line-height:1.15;
  letter-spacing:.2px;
  color:#111;
}

/* 3) Botón Add/Edit en pill, fijo arriba-derecha */
.woocommerce-Address .edit{
  position:absolute; top:16px; right:16px;
  display:inline-flex; align-items:center; justify-content:center;
  padding:8px 14px;
  height:auto; width:auto;
  white-space:nowrap;
  border-radius:9999px;
  border:1px solid #111;
  background:#fff; color:#111 !important;
  font-weight:700; font-size:14px; line-height:1;
  text-decoration:none !important;
  transition:background .15s ease, color .15s ease, transform .12s ease;
}
.woocommerce-Address .edit:hover{
  background:#111; color:#fff !important; transform:translateY(-1px);
}

/* 4) Texto del cuerpo */
.woocommerce-Address address{ margin:10px 0 0; color:#333; font-size:15px; }
.woocommerce-Address .no-address,
.woocommerce-Address p{ color:#666; font-size:15px; }

/* 5) Responsive */
@media (max-width: 840px){
  .woocommerce-MyAccount-content .u-columns.woocommerce-Addresses.addresses{
    grid-template-columns:1fr; gap:16px;
  }
  .woocommerce-Address-title h3{ font-size:20px; }
  .woocommerce-account .woocommerce-MyAccount-content{ padding:18px; }
}

/* ===== Variables ===== */
:root{
  --lr-black:#111111;
  --lr-gray:#444444;
  --lr-white:#ffffff;
  --lr-glass-brd: rgba(17,17,17,0.08);

  --lr-safe-top: env(safe-area-inset-top, 0px);
  --lr-adminbar: 0px;
  --lr-header-h: 64px;   /* desktop */
}
@media (max-width:920px){
  :root{ --lr-header-h: 56px; } /* móvil */
}

/* ===== Header fijo + vidrio full-width ===== */
.lr-headerbar{
  position: fixed !important;
  top: calc(var(--lr-adminbar) + var(--lr-safe-top));
  left: 0; right: 0;
  z-index: 300001;
  overflow: visible;
}
.lr-headerbar::before{
  content:"";
  position:absolute; inset:0;            /* ocupa todo el ancho del viewport */
  background: rgba(255,255,255,.50);
  -webkit-backdrop-filter: saturate(140%) blur(7px);
  backdrop-filter: saturate(140%) blur(7px);
  border-bottom: 1px solid var(--lr-glass-brd);
  z-index: 0;
}

/* Contenido del header (sin otro rectángulo) */
.lr-headerbar .lr-hero-inner{
  position: relative;
  height: var(--lr-header-h);            /* altura fija */
  padding: 0 18px;
  display: flex; align-items: center;    /* centra verticalmente */
  background: transparent !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  border: 0 !important;
  max-width: 1150px;
  margin: 0 auto;
}

/* Mata cualquier pseudo interno previo */
.lr-headerbar .lr-hero-inner::before{ content:none !important; }

/* Asegura stacking del contenido sobre el vidrio */
.lr-headerbar .lr-hero-inner > *{ position:relative; z-index:1; }

/* Empuje del contenido */
.lr-headerbar-spacer{ height: var(--lr-header-h); display:block; }

/* Tema a veces añade sticky: desactívalo aquí */
.lr-hero-inner.is-fixed{ position: static !important; height: var(--lr-header-h) !important; }

/* ===== Menú móvil: siempre bajo la barra fija ===== */
@media (max-width:920px){
  .lr-nav-toggle{ display:inline-flex; }
  .lr-nav-menu{
    position: fixed;
    inset: calc(var(--lr-header-h) + env(safe-area-inset-top, 0px)) 12px auto 12px;
    display:none;
    flex-direction:column; gap:8px; padding:12px; border-radius:16px;
    background: rgba(255,255,255,.96);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    backdrop-filter: blur(10px) saturate(140%);
    border:1px solid rgba(17,17,17,.06);
    box-shadow:0 24px 60px rgba(0,0,0,.20);
    z-index: 12999;
  }
  .lr-nav-menu.is-open{ display:flex; }
}

/* Z-index utilidades */
.lr-menu-scrim{ z-index: 9998; }
@media (min-width:921px){ .lr-nav-menu{ z-index:1001; } }

/* Contenedores del tema que rompen fixed/sticky */
#content.site-content, .site-content, .content-area{ overflow:visible !important; }

/* (Resto de estilos de hero-band, links, cuenta, etc. — sin tocar el vidrio) */
@media (max-width: 920px){ .lr-nav-menu{ z-index: 12999; } }


/* ===== Franja/hero band en desktop ===== */
@media (min-width: 921px){
  .lr-hero-band{
    align-self: center;
    width: min(100% - 36px, 720px);
    margin: auto 18px 40px;
  }
  .lr-hero-inner{ align-self: stretch; }
}

/* ===== Contenedor principal ===== */
.lr-hero-section{
  position: relative;
  max-width: 1150px;
  margin: 12px auto 60px;
  border-radius: 28px;
  overflow: hidden;               /* se abre con el menú */
  background: #fff;
  box-shadow: 0 14px 44px rgba(0,0,0,.08);
  min-height: 460px;
  display: flex;
  flex-direction: column;
}
.lr-hero-section.lr-menu-open{ overflow: visible; }

/* ===== Media de fondo ===== */
.lr-hero-media{ position:absolute; inset:0; z-index:0; }
.lr-hero-video,.lr-hero-image{
  position:absolute; inset:0;
  width:100%; height:100%; object-fit:cover;
  filter:saturate(105%) contrast(102%);
}
.lr-hero-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg,
    rgba(255,255,255,.350) 0%,
    rgba(255,255,255,.360) 30%,
    rgba(255,255,255,.370) 100%);
  backdrop-filter: blur(4px);
}

/* ===== Branding + nav (desktop) ===== */
.lr-brand{ display:flex; align-items:center; gap:10px; }
.lr-logo img{ height:28px; width:auto; display:block; }
.lr-logo-text{ font-family:"Playfair Display",serif; font-weight:700; font-size:20px; text-decoration:none; color:var(--lr-black); }

.lr-nav{ display:flex; align-items:center; gap:10px; }
.lr-nav-toggle{ display:none; background:transparent; border:0; padding:10px; color:var(--lr-black); cursor:pointer; border-radius:12px; }
.lr-ico{ display:block; }

.lr-nav-menu{
  display:flex; align-items:center; gap:18px;
  list-style:none; margin:0; padding:0;
}

/* ===== Franja de copy ===== */
.lr-hero-band{
  margin: auto 18px 40px;
  padding: 36px 28px;
  max-width: 720px;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.70), rgba(255,255,255,.55));
  -webkit-backdrop-filter: blur(14px) saturate(160%);
  backdrop-filter: blur(14px) saturate(160%);
  border: 1px solid var(--lr-glass-brd);
  box-shadow: var(--lr-glass-shadow);
  z-index: 10;
  text-align: left;
}
.lr-hero-title{ margin:0 0 10px; font-size:clamp(28px,4vw,46px); color:var(--lr-black); letter-spacing:.2px; }
.lr-hero-sub{ margin:0 0 20px; color:#333; font-size:clamp(14px,2.2vw,18px); }

/* ===== Botón cristal ===== */
.lr-btn-glass{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.7rem 1rem; border-radius:14px; text-decoration:none; font-weight:600;
  color:var(--lr-black);
  background:linear-gradient(180deg, rgba(255,255,255,.66), rgba(255,255,255,.45));
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  backdrop-filter: blur(12px) saturate(150%);
  border:1px solid var(--lr-glass-brd);
  box-shadow: 0 10px 28px rgba(0,0,0,.06), inset 0 0 0 1px rgba(255,255,255,.35);
  transition: transform .15s, background .2s, box-shadow .2s;
}
.lr-btn-glass:hover,.lr-btn-glass:active{
  background:linear-gradient(180deg, rgba(255,255,255,.76), var(--lr-accent));
  box-shadow:0 12px 36px rgba(0,0,0,.08);
  transform: translateY(-1px);
}
.lr-btn-lg{ padding:.9rem 1.2rem; border-radius:16px; }

/* ===== Links ===== */
.nav-link{
  color:var(--lr-gray); text-decoration:none; font-weight:500;
  padding:8px 10px; border-radius:12px; transition:background .2s, color .2s;
}
.nav-link:hover{ background:var(--lr-accent); color:var(--lr-black); }

/* ===== Mobile ===== */
@media (max-width: 920px){
  .lr-hero-section{
    max-width:100%;
    margin:8px auto 32px;
    border-radius:0;
    min-height:90vh;
  }

  .lr-hero-band{
    margin-top:auto;
    margin-bottom:12vh;
    padding:22px 16px;
    border-radius:16px;
    max-width:100%;
    z-index:10;
  }

  .lr-hero-title{ font-size:clamp(22px,6vw,30px); margin-bottom:8px; }
  .lr-hero-sub{ font-size:14px; margin-bottom:14px; }

  /* panel del menú móvil: justo debajo de la barra fija */
  .lr-nav-toggle{ display:inline-flex; }
  .lr-nav-menu{
    position:fixed;
    inset: calc(var(--lr-header-h) + env(safe-area-inset-top, 0px)) 12px auto 12px;
    display:none; flex-direction:column; gap:8px; padding:12px; border-radius:16px;
    background:rgba(255,255,255,.96);
    -webkit-backdrop-filter:blur(10px) saturate(140%);
    backdrop-filter:blur(10px) saturate(140%);
    border:1px solid rgba(17,17,17,.06);
    box-shadow:0 24px 60px rgba(0,0,0,.20);
  }
  .lr-nav-menu.is-open{ display:flex; }

  .lr-hero-overlay{
    background:linear-gradient(180deg,
      rgba(255,255,255,.36) 0%,
      rgba(255,255,255,.37) 35%,
      rgba(255,255,255,.38) 100%);
    backdrop-filter:blur(5px);
  }

  body,.site-content,.site-main{ margin-top:0 !important; padding-top:0 !important; }
  .lr-hero-section{ margin-top:0 !important; }
}

/* ===== Scrim y bloqueo scroll cuando abre menú ===== */
html.lr-no-scroll, html.lr-no-scroll body{ overflow: hidden; }
.lr-menu-scrim{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(2px);
  opacity: 0; pointer-events: none;
  transition: opacity .18s ease;
}
.lr-menu-scrim.is-visible{ opacity: 1; pointer-events: auto; }

/* ===== Cuenta dentro/afuera del menú ===== */
@media (min-width: 921px){
  .lr-hb-account.outside { display: none; }
  .lr-nav-account-li { display: flex; }
}
@media (max-width: 920px){
  .lr-hb-account.outside { display: inline-flex; }
  .lr-nav-account-li { display: none; }
}

/* Estructura panel */
.lr-nav-inner{ display:flex; flex-direction:column; height:100%; }
.lr-nav-menu{ flex:1 1 auto; }
.lr-nav-footer{ display:none; }

.lr-nav-account-li{ display:flex; align-items:center; }
.lr-hb-account{
  display:inline-flex;
  width:36px; height:36px;
  justify-content:center; align-items:center;
  border-radius:999px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(17,17,17,.08);
  box-shadow:0 6px 18px rgba(0,0,0,.10);
  color:#111; text-decoration:none;
  -webkit-tap-highlight-color:transparent;
  transition: background .2s ease, transform .2s ease;
}
.lr-hb-account:hover{ background:rgba(17,17,17,.06); }
.lr-hb-account:active{ transform:translateY(1px); }
.lr-hb-account svg{
  width:18px; height:18px;
  stroke:currentColor; stroke-width:2; fill:none;
}

/* Desktop: que no rompa el flow */
@media (min-width:921px){
  .lr-nav-inner{ display:contents; height:auto; }
  .lr-nav-menu{ flex:none; overflow:visible; }
}

/* Accesibilidad */
@media (prefers-reduced-motion: reduce){
  .lr-hb-account{ transition:none; }
}

/* ===== Coherencia con el arreglo anterior del vidrio ===== */
/* Fuera del header fijo, jamás uses sticky aquí */
.lr-hero-inner{ position: static; } /* solo para instancias fuera de .lr-headerbar */

/* Evita recortes cuando el menú está abierto */
html.lr-menu-open .lr-hero-section { overflow: visible !important; }

/* ==== Alturas fijas y coherentes ==== */
:root{
  --lr-safe-top: env(safe-area-inset-top, 0px);
  --lr-adminbar: 0px;
  --lr-header-h: 64px;     /* desktop por defecto */
}
@media (max-width:920px){
  :root{ --lr-header-h: 56px; } /* móvil */
}


/* Cualquier regla que intentaba estirar el pseudo en desktop, la neutralizamos */
@media (min-width:921px){
  .lr-headerbar .lr-hero-inner::before{
    top:0; bottom:auto; left:0; right:0; /* por claridad, pero inset:0 ya lo cubre */
  }
}


/* (opcional) contenedores del tema que suelen romper fixed/sticky */
#content.site-content, .site-content, .content-area{ overflow:visible !important; }

/* Z-index coherente */
.lr-headerbar{ z-index: 300000 !important; }
.lr-menu-scrim{ z-index: 300100 !important; }

@media (max-width:920px){
  .lr-nav-menu{ z-index: 300200 !important; }
}

.lr-contact{ z-index: 300300 !important; } /* si usas modal de contacto */

/* ===== SOLO MÓVIL: panel por encima + look premium ===== */
@media (max-width:920px){
  /* 1) Prioridades de stacking */
  .lr-menu-scrim{ z-index: 199000 !important; }               /* fondo oscuro */
  .lr-nav-menu{
    position: fixed !important;
    inset: calc(var(--lr-header-h) + env(safe-area-inset-top,0px)) 12px auto 12px !important;
    z-index: 200000 !important;                                /* por encima del scrim y del header */
    display: none; flex-direction: column;
    padding: 10px; border-radius: 16px;
    background: rgba(255,255,255,.96);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    backdrop-filter: blur(10px) saturate(140%);
    border: 1px solid rgba(17,17,17,.06);
    box-shadow: 0 24px 60px rgba(0,0,0,.20);
  }
  .lr-nav-menu.is-open{ display:flex; }

  /* 2) Ocultar icono de cuenta dentro del menú */
  .lr-nav-account-li{ display:none !important; }
  .lr-hb-account.outside{ display:inline-flex !important; }    /* solo el de fuera */

  /* 3) Estética “lujo”: izquierda, separadores y activo en pill */
  .lr-nav-menu li{ margin:0; }
  .lr-nav-menu li + li{ border-top: 1px solid rgba(17,17,17,.06); }

  .lr-nav-menu a{
    display:block;
    text-align:left;
    padding:14px 14px;
    font-size:18px;
    line-height:1.2;
    color:#111;
    text-decoration:none;
    border-radius:12px;
  }
  .lr-nav-menu a:hover,
  .lr-nav-menu a:active{
    background: rgba(17,17,17,.06);
  }

  /* Activo elegante tipo “pill” */
  .lr-nav-menu a.is-active{
    font-weight: 800;
    background: rgba(17,17,17,.06);
    box-shadow: 0 6px 16px rgba(0,0,0,.06), inset 0 0 0 1px rgba(255,255,255,.6);
  }

  /* CTA dentro del panel: un poco más marcado */
  .lr-cta-li a{
    margin-top: 6px;
    font-weight: 700;
  }
}
@media (max-width:920px){
  .lr-nav-menu{
    position: fixed;
    left: 12px; right: 12px;
    top: calc(var(--lr-header-h) + env(safe-area-inset-top, 0px));
    display: none;
    flex-direction: column;
    gap: 0;                          /* separadores, no gaps */
    padding: 10px;
    border-radius: 16px;
    background: rgba(255,255,255,.96);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    backdrop-filter: blur(10px) saturate(140%);
    border: 1px solid rgba(17,17,17,.06);
    box-shadow: 0 24px 60px rgba(0,0,0,.20);
    text-align: left;                /* clave: no centrado */
  }
  .lr-nav-menu.is-open{ display:flex; }

  .lr-nav-menu li{ margin:0; }
  .lr-nav-menu li + li{ border-top:1px solid rgba(17,17,17,.06); }

  .lr-nav-menu a{
    display:block;
    padding:14px 14px;
    font-size:18px;
    line-height:1.25;
    color:#111; text-decoration:none;
    border-radius:10px;
  }
  .lr-nav-menu a:hover,
  .lr-nav-menu a:active{ background: rgba(17,17,17,.06); }

  /* activo elegante */
  .lr-nav-menu .nav-link.is-active{
    font-weight: 700;
    background: rgba(17,17,17,.06);
  }

  /* CTA full-width con un poco más de aire */
  .lr-nav-menu .lr-cta-li{ margin-top:8px; border-top:0; }
  .lr-nav-menu .lr-cta-li a{
    display:block; text-align:center; font-weight:600;
    padding:14px 16px; border-radius:14px;
  }
}