:root{
  --container: 1240px;
  --pad: 18px;

  --bg: #ffffff;
  --text: #111;
  --muted: #6b7280;
  --border: #e5e7eb;

  --primary: #111;
  --primaryText: #fff;
  --radius: 16px;
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
body{ font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:var(--text); background:var(--bg); }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; height:auto; display:block; }

.container{
  width: min(calc(100% - (var(--pad) * 2)), var(--container));
  margin-inline:auto;
}

/* Helpers */
.no-scroll{ overflow:hidden; }
.siteMain{ min-height: 60vh; }



/* Footer */
.siteFooter{
  border-top:1px solid var(--border);
  padding: 34px 0;
  margin-top: 40px;
}
.siteFooter__cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
}
.footerMenu{ list-style:none; padding:0; margin:0; display:flex; gap: 14px; flex-wrap:wrap; }
.footerMenu a{ color: var(--muted); }
.footerMenu a:hover{ color: var(--text); }

/* Buttons */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  cursor:pointer;
}
.btn--primary{
  background: var(--primary);
  color: var(--primaryText);
  border-color: var(--primary);
}
.btn--ghost{
  background:#fff;
}

/* Mini Cart Drawer */
.miniCartOverlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 1200;
}
.miniCartDrawer{
  position: fixed;
  top: 0;
  right: 0;
  height: 100vh;
  width: min(420px, 92vw);
  background: #fff;
  z-index: 1300;
  transform: translateX(105%);
  transition: transform .2s ease;
  border-left: 1px solid var(--border);
  display:flex;
  flex-direction:column;
}
.miniCartDrawer.is-open{ transform: translateX(0); }
.miniCartDrawer__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 16px;
  border-bottom: 1px solid var(--border);
}
.miniCartDrawer__body{
  padding: 16px;
  overflow:auto;
  flex:1;
}
.miniCartDrawer__foot{
  padding: 16px;
  border-top: 1px solid var(--border);
  display:grid;
  gap: 10px;
}

/* Search Modal */
.searchModal{
  position: fixed;
  inset: 0;
  z-index: 1400;
  display:none;
}
.searchModal.is-open{ display:block; }
.searchModal__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.35);
}
.searchModal__panel{
  position:absolute;
  top: 70px;
  left: 50%;
  transform: translateX(-50%);
  width: min(720px, 92vw);
  background:#fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: 0 20px 50px rgba(0,0,0,.18);
}
.searchModal__head{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 12px;
  border-bottom: 1px solid var(--border);
}
.searchModal__input{
  width:100%;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 999px;
  outline:none;
}
.searchModal__results{
  max-height: 60vh;
  overflow:auto;
  padding: 12px;
}
.searchResults{
  display:grid;
  gap: 10px;
}
.searchResultItem{
  display:flex;
  gap: 12px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 14px;
}
.searchResultItem__img{ width: 56px; height: 56px; object-fit: cover; border-radius: 12px; }
.searchResultItem__title{ font-weight: 600; }
.searchResultItem__price{ color: var(--muted); font-size: 14px; }

/* Responsive */
@media (max-width: 980px){
  .siteFooter__cols{ grid-template-columns: 1fr; }
  .mainMenu{ display:none; } /* luego hacemos menú mobile */
}


/* Home Hero */
.homeHero{ margin: 16px 0 26px; }
.heroSlide{
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  min-height: 420px;
}
.heroSlide__media img{
  width:100%;
  height: 420px;
  object-fit: cover;
}
.heroSlide__content{
  position: absolute;
  inset: 0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding: 26px;
  color: #fff;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.heroSlide__title{ font-size: clamp(26px, 3vw, 44px); margin:0 0 10px; max-width: 720px; }
.heroSlide__subtitle{ margin:0 0 16px; max-width: 620px; opacity:.95; }

.heroSlide.is-align-center .heroSlide__content{ align-items:center; text-align:center; }
.heroSlide.is-align-right .heroSlide__content{ align-items:flex-end; text-align:right; }

.swiper-button-prev, .swiper-button-next{ color: #fff; }

/* Banners */
.homeBanners{ margin: 18px 0 28px; }
.homeBanners__grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.bannerCard{
  display:block;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
  background:#fff;
}
.bannerCard__img{ width:100%; height: 180px; object-fit: cover; }
.bannerCard__content{ padding: 14px; }
.bannerCard__title{ font-weight: 700; margin-bottom: 6px; }
.bannerCard__text{ color: var(--muted); font-size: 14px; }

/* Sections */
.sectionHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 12px;
  margin: 0 0 12px;
}
.sectionHead h3{ margin:0; font-size: 20px; }
.sectionLink{ color: var(--muted); }
.sectionLink:hover{ color: var(--text); }

/* Product grid (Woo) */
.productsGrid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
}

/* Intro */
.homeIntro{
  margin: 34px 0 40px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.richText{ color: var(--text); }
.richText p{ color: var(--muted); line-height: 1.7; }

/* Responsive */
@media (max-width: 980px){
  .homeBanners__grid{ grid-template-columns: 1fr; }
  .productsGrid{ grid-template-columns: repeat(2, 1fr); }
  .heroSlide__media img{ height: 360px; }
  .heroSlide{ min-height: 360px; }
}

/* Home Tabs */
.homeTabs{
  padding: 46px 0 22px;
  background: #fff;
}
.homeTabs__head{
  text-align:center;
  padding: 0 var(--pad);
}
.homeTabs__kicker{
  letter-spacing: .14em;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
}
.homeTabs__title{
  margin:0;
  font-size: 22px;
  font-weight: 800;
}
.homeTabs__subtitle{
  margin: 6px 0 18px;
  color: var(--muted);
}

.tabsNav{
  display:flex;
  justify-content:center;
  gap: 18px;
  flex-wrap:wrap;
  margin-bottom: 20px;
}

.tabBtn{
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 10px 6px;
  font-weight: 700;
  color: #8a8a8a;
  border-bottom: 2px solid transparent;
}
.tabBtn.is-active{
  color: var(--text);
  border-bottom-color: var(--text);
}

.tabsPanels{
  width: min(calc(100% - (var(--pad) * 2)), var(--container));
  margin-inline:auto;
}

.tabPanel{ display:none; }
.tabPanel.is-active{ display:block; }

.productsGrid--compact{
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  padding-bottom: 22px;
}

@media (max-width: 980px){
  .productsGrid--compact{ grid-template-columns: repeat(2, 1fr); }
}

/* Home layout with sidebar */
.homeTop{ padding: 18px 0 18px; }
.homeTop__grid{
  display:grid;
  grid-template-columns: 260px 1fr;
  gap: 18px;
  align-items:start;
}
.homeTop__main .homeHero{ margin-top: 0; }

/* Categories sidebar */
.catSidebar{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow:hidden;
  background:#fff;
}
.catSidebar__title{
  background: #2f7f5f;
  color: #fff;
  font-weight: 800;
  padding: 12px 14px;
  font-size: 13px;
  letter-spacing: .03em;
}
.catSidebar__list{
  list-style:none;
  margin:0;
  padding: 10px 0;
}
.catSidebar__item > a{
  display:flex;
  padding: 10px 14px;
  font-weight: 700;
  border-radius: 10px;
  margin: 2px 8px;
}
.catSidebar__item > a:hover{
  background: rgba(0,0,0,.05);
}
.catSidebar__sub{
  list-style:none;
  margin: 0 0 8px;
  padding: 0 0 0 14px;
}
.catSidebar__sub a{
  display:block;
  padding: 8px 14px;
  color: var(--muted);
  font-size: 14px;
}
.catSidebar__sub a:hover{ color: var(--text); }

/* Promo banner (green) */
.promoBanner{ margin: 16px 0 26px; }
.promoBanner__slide{
  border-radius: var(--radius);
  overflow:hidden;
}
.promoBanner__inner{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  align-items:center;
  padding: 34px 0;
}
.promoBanner__media img{
  width:100%;
  max-width: 520px;
  margin-inline:auto;
  object-fit:contain;
}
.promoBanner__kicker{
  color: rgba(255,255,255,.85);
  font-weight: 700;
  letter-spacing:.08em;
  font-size: 12px;
  text-transform: uppercase;
}
.promoBanner__title{
  color:#fff;
  margin: 10px 0 10px;
  font-size: clamp(26px, 3vw, 44px);
  font-weight: 900;
}
.promoBanner__price{
  color:#fff;
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 14px;
}
.promoBanner__btn{
  background: rgba(0,0,0,.25);
  border-color: rgba(255,255,255,.25);
}

/* Responsive */
@media (max-width: 980px){
  .homeTop__grid{ grid-template-columns: 1fr; }
  .homeTop__sidebar{ display:none; }
  .promoBanner__inner{ grid-template-columns: 1fr; padding: 22px 0; text-align:center; }
}

html, body {
  overflow-x: hidden;
}

/* Evitar scroll horizontal por Swiper */
.swiper,
.swiper-wrapper,
.swiper-slide {
  max-width: 100%;
}

.homeHero,
.promoBanner {
  overflow: hidden;
}

.heroSlide__media,
.promoBanner__slide {
  overflow: hidden;
}

/* Por si alguna imagen viene enorme */
.heroSlide__media img,
.promoBanner__media img {
  max-width: 100%;
  height: auto;
}

.promoBanner__inner{
  padding: 34px var(--pad);
}

/* ===== FIX: evitar hero/promo infinitos ===== */
.homeHero .swiper,
.homeHero .swiper-wrapper,
.homeHero .swiper-slide,
.homeHero .heroSlide {
  height: auto !important;
  min-height: 0 !important;
}

.homeHero .heroSlide__media img{
  width: 100%;
  height: 420px;          /* ajustable */
  object-fit: cover;
  display: block;
}

@media (max-width: 980px){
  .homeHero .heroSlide__media img{ height: 320px; }
}

/* Promo banner */
.promoBanner .swiper,
.promoBanner .swiper-wrapper,
.promoBanner .swiper-slide{
  height: auto !important;
  min-height: 0 !important;
}

.promoBanner__slide{
  overflow: hidden;
}

/* HERO: que no quede full-width infinito, sino contenido en el layout */
.homeTop__main .homeHero{
  width: 100%;
}

.homeTop__main .homeHero .swiper{
  width: 100%;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: #000; /* mientras carga */
}

/* PROMO: idem, contenido y con borde */
.promoBanner{
  width: min(calc(100% - (var(--pad) * 2)), var(--container));
  margin-inline: auto;
}

.promoBanner .js-promo-swiper{
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
}

/* HERO full-width pro */
.homeHero{
  width: min(calc(100% - (var(--pad) * 2)), var(--container));
  margin-inline: auto;
}

/* PROMO full-width pro */
.promoBanner{
  padding: 0 var(--pad);
}
.promoBanner__slide{
  border-radius: var(--radius);
  border: 1px solid var(--border);
}

/* Asegurar que el main NO desborde y que el hero se encuadre */
.homeTop__main{
  min-width: 0;          /* clave en grids/flex */
  overflow: hidden;      /* recorta cualquier cosa que se salga */
}

/* Encapsular el HERO */
.homeTop__main .homeHero{
  width: 100%;
  max-width: 100%;
}

.homeTop__main .homeHero .swiper{
  width: 100%;
  max-width: 100%;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: #000; /* por si la imagen tarda */
}

/* Swiper interno: evitar que algo calcule widths raros */
.homeTop__main .homeHero .swiper-wrapper,
.homeTop__main .homeHero .swiper-slide{
  max-width: 100%;
}

/* Asegurar que el main NO desborde y que el hero se encuadre */
.homeTop__main{
  min-width: 0;          /* clave en grids/flex */
  overflow: hidden;      /* recorta cualquier cosa que se salga */
}

/* Encapsular el HERO */
.homeTop__main .homeHero{
  width: 100%;
  max-width: 100%;
}

.homeTop__main .homeHero .swiper{
  width: 100%;
  max-width: 100%;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: #000; /* por si la imagen tarda */
}

/* Swiper interno: evitar que algo calcule widths raros */
.homeTop__main .homeHero .swiper-wrapper,
.homeTop__main .homeHero .swiper-slide{
  max-width: 100%;
}

/* ===== Product card premium ===== */
.productsGrid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

@media (max-width: 980px){
  .productsGrid{ grid-template-columns: repeat(2, 1fr); gap: 14px; }
}

.pCard{
  list-style:none;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  overflow:hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.pCard:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 44px rgba(0,0,0,.10);
  border-color: rgba(47,127,95,.18);
}

.pCard__mediaWrap{
  position: relative;
  background: #fafafa;
}

.pCard__media{
  display:block;
  padding: 22px 22px 18px;
}

.pCard__img{
  width:100%;
  height: 280px;
  object-fit: contain;
  display:block;
}

.pCard__badge{
  position:absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pCard__badge--sale{
  background:#111;
  color:#fff;
}

.pCard__badge--new{
  background:#2f7f5f;
  color:#fff;
}

.pCard__body{
  padding: 14px 14px 16px;
}

.pCard__title{
  display:block;
  font-weight: 800;
  color: var(--text);
  font-size: 14px;
  line-height: 1.25;
  margin-bottom: 8px;

  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow:hidden;
  min-height: 36px;
}

.pCard__price{
  font-weight: 800;
  margin-bottom: 12px;
}

.pCard__price del{ opacity:.45; margin-right:6px; }
.pCard__price ins{ text-decoration:none; }

.pCard__actions{
  display:flex;
  gap: 10px;
}

/* Botón Woo */
.pCard .button,
.pCard a.button{
  width: 100%;
  text-align:center;
  border-radius: 12px;
  padding: 10px 12px;
  font-weight: 800;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
}

.pCard:hover .button{
  border-color: rgba(0,0,0,.18);
}

@media (hover:hover){
  .pCard__actions{ opacity: 0; transform: translateY(4px); transition: .18s ease; }
  .pCard:hover .pCard__actions{ opacity: 1; transform: translateY(0); }
}
@media (hover:none){
  .pCard__actions{ opacity:1; transform:none; }
}

/* ===== Header Pro ===== */
.topbar{
  background: #f6f6f6;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 8px 0;
}
.topbar__left, .topbar__right{
  display:flex;
  gap: 10px;
  align-items:center;
}
.topbar__sep{ opacity:.45; }
.topbar__link{ color: var(--muted); font-weight: 700; }
.topbar__link:hover{ color: var(--text); }

.headerMain{
  background:#fff;
  border-bottom: 1px solid var(--border);
}
.headerMain__inner{
  display:grid;
  grid-template-columns: 220px 1fr 180px;
  gap: 18px;
  align-items:center;
  padding: 16px 0;
}

.headerLogo__text{
  font-weight: 900;
  letter-spacing: .02em;
  font-size: 18px;
}

/* Woo search form */
.headerSearch form{
  position:relative;
  display:flex;
  gap: 10px;
}
.headerSearch input[type="search"],
.headerSearch input[type="text"]{
  width:100%;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 12px 46px 12px 16px;
  outline:none;
}
.headerSearch button,
.headerSearch input[type="submit"]{
  position:absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: #2f7f5f;
  color:#fff;
  border-radius: 999px;
  padding: 9px 14px;
  font-weight: 800;
  cursor:pointer;
}
.headerSearch button:hover,
.headerSearch input[type="submit"]:hover{
  filter: brightness(.95);
}

.headerIcons{
  display:flex;
  justify-content:flex-end;
  gap: 10px;
}
.hIcon{
  display:inline-flex;
  align-items:center;
}
.hIcon__circle{
  position:relative;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  transition: .18s ease;
}
.hIcon:hover .hIcon__circle{
  border-color: rgba(0,0,0,.18);
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
  transform: translateY(-1px);
}

.hIcon__badge{
  position:absolute;
  top: -6px;
  right: -6px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background:#2f7f5f;
  color:#fff;
  font-size: 12px;
  font-weight: 900;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 2px solid #fff;
}

/* Sticky */
.siteHeader.is-sticky .headerMain{
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
}

/* Responsive */
@media (max-width: 980px){
  .topbar{ display:none; }

  .headerMain__inner{
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "logo icons"
      "search search";
    gap: 10px;
    padding: 12px 0;
  }
  .headerLogo{ grid-area: logo; }
  .headerIcons{ grid-area: icons; }
  .headerSearch{ grid-area: search; }

  .headerIcons{ gap: 8px; }
  .hIcon__circle{ width: 40px; height: 40px; }
}

/* ===== Header PRO (mantiene mini-cart actual) ===== */
.topbar{
  background: #f6f6f6;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 8px 0;
}
.topbar__left, .topbar__right{
  display:flex;
  gap: 10px;
  align-items:center;
}
.topbar__sep{ opacity:.45; }
.topbar__link{ color: var(--muted); font-weight: 700; }
.topbar__link:hover{ color: var(--text); }

.headerMain{
  background:#fff;
  border-bottom: 1px solid var(--border);
}
.headerMain__inner{
  display:grid;
  grid-template-columns: 220px 1fr 200px;
  gap: 18px;
  align-items:center;
  padding: 16px 0;
}

.headerLogo__text{
  font-weight: 900;
  letter-spacing: .02em;
  font-size: 18px;
}

/* Buscador centrado */
.headerSearch form{ position:relative; }
.headerSearch input[type="search"],
.headerSearch input[type="text"]{
  width:100%;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 12px 46px 12px 16px;
  outline:none;
  background:#fff;
}
.headerSearch button,
.headerSearch input[type="submit"]{
  position:absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  border: 0;
  background: #2f7f5f;
  color:#fff;
  border-radius: 999px;
  padding: 9px 14px;
  font-weight: 800;
  cursor:pointer;
}
.headerSearch button:hover,
.headerSearch input[type="submit"]:hover{
  filter: brightness(.95);
}

/* Iconos (reusa tus iconBtn) */
.headerIcons{
  display:flex;
  justify-content:flex-end;
  gap: 10px;
}
.iconBtn{
  position:relative;
  border: 1px solid var(--border);
  background:#fff;
  border-radius: 999px;
  width: 42px;
  height: 42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition: .18s ease;
  font-weight: 700;
}
.iconBtn:hover{
  border-color: rgba(0,0,0,.18);
  box-shadow: 0 8px 18px rgba(0,0,0,.06);
  transform: translateY(-1px);
}

/* Contador mini-cart */
.miniCartCount{
  position:absolute;
  top: -6px;
  right: -6px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background:#2f7f5f;
  color:#fff;
  font-size: 12px;
  font-weight: 900;
  display:flex;
  align-items:center;
  justify-content:center;
  border: 2px solid #fff;
}

/* NAV debajo (tipo Kolibrie) */
.headerNav{
  background:#fff;
  border-bottom: 1px solid var(--border);
}
.headerNav__inner{
  padding: 10px 0;
}

.mainMenu--pro{
  display:flex;
  gap: 18px;
  align-items:center;
  flex-wrap:wrap;
}
.mainMenu--pro a{
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .02em;
  color: var(--text);
  opacity: .85;
}
.mainMenu--pro a:hover{ opacity: 1; }

/* Sticky */
.siteHeader.is-sticky .headerMain{
  position: sticky;
  top: 0;
  z-index: 999;
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
}

/* Mobile */
@media (max-width: 980px){
  .topbar{ display:none; }
  .headerNav{ display:none; } /* en mobile lo escondemos (lo vemos después con menú hamburguesa) */

  .headerMain__inner{
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "logo icons"
      "search search";
    gap: 10px;
    padding: 12px 0;
  }
  .headerLogo{ grid-area: logo; }
  .headerIcons{ grid-area: icons; gap: 8px; }
  .headerSearch{ grid-area: search; }

  .iconBtn{ width: 40px; height: 40px; }
}

/* Sticky robusto: no depende de clase, solo de scroll (con clase mejora sombra) */
.headerMain{
  position: sticky;
  top: 0;
  z-index: 999;
}

.siteHeader.is-sticky .headerMain{
  box-shadow: 0 10px 25px rgba(0,0,0,.06);
}

.headerNav{ display:block; }
@media (max-width: 980px){
  .headerNav{ display:none; } /* en mobile lo ocultamos por ahora */
}

/* ===== Welcome Popup ===== */
.welcomePopup[hidden]{
  display:none !important;
}

.welcomePopup{
  position: fixed;
  inset: 0;
  z-index: 99999;
}

.welcomePopup__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(2px);
}

.welcomePopup__dialog{
  position: relative;
  width: min(900px, calc(100% - 32px));
  min-height: 440px;
  margin: 6vh auto 0;
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  box-shadow: 0 30px 80px rgba(0,0,0,.28);
}

.welcomePopup__close{
  position:absolute;
  top: 14px;
  right: 14px;
  z-index: 5;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  color: #111;
  font-size: 18px;
  cursor:pointer;
}

.welcomePopup__media{
  position:relative;
  min-height: 440px;
}

.welcomePopup__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.welcomePopup__content{
  padding: 48px 36px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
}

.welcomePopup__title{
  margin:0 0 14px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
  font-weight: 900;
}

.welcomePopup__text{
  margin:0 0 22px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.6;
}

.welcomePopup__form{
  display:flex;
  flex-direction:column;
  gap: 12px;
  margin-bottom: 14px;
}

.welcomePopup__input{
  width:100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  outline:none;
}

.welcomePopup__button{
  width:100%;
  border:0;
  border-radius: 12px;
  padding: 14px 16px;
  background: #2f7f5f;
  color:#fff;
  font-weight: 800;
  cursor:pointer;
}

.welcomePopup__button:hover{
  filter: brightness(.95);
}

.welcomePopup__privacy{
  margin:0;
  font-size: 13px;
  color: var(--muted);
}

.welcomePopup__privacy a{
  color: var(--text);
  font-weight: 700;
}

@media (max-width: 980px){
  .welcomePopup__dialog{
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .welcomePopup__media{
    min-height: 220px;
  }

  .welcomePopup__content{
    padding: 28px 20px;
  }

  .welcomePopup__title{
    font-size: 28px;
  }
}

.welcomePopup__dialog{
  position: relative;
  width: min(920px, calc(100% - 32px));
  min-height: 460px;
  margin: 6vh auto 0;
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1fr;
  box-shadow: 0 30px 80px rgba(0,0,0,.28);
}

.welcomePopup__media{
  min-height: 460px;
  background: #f3f3f3;
}

.welcomePopup__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.welcomePopup__content{
  padding: 42px 34px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

.welcomePopup__content.is-full{
  grid-column: 1 / -1;
  max-width: 560px;
  margin: 0 auto;
}

.welcomePopup__title{
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
  font-weight: 900;
  margin: 0 0 14px;
  color: #111;
}

.welcomePopup__text{
  margin: 0 0 20px;
  color: #666;
  font-size: 16px;
  line-height: 1.6;
}

.welcomePopup__form{
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 14px;
}

.welcomePopup__input{
  width: 100%;
  border: 1px solid #ddd;
  border-radius: 12px;
  padding: 14px 16px;
  font-size: 15px;
}

.welcomePopup__button{
  width: 100%;
  border: 0;
  border-radius: 12px;
  padding: 14px 16px;
  background: #2f7f5f;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}

.welcomePopup__privacy{
  font-size: 13px;
  color: #777;
}

.welcomePopup__privacy a{
  color: #111;
  font-weight: 700;
}

@media (max-width: 980px){
  .welcomePopup__dialog{
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .welcomePopup__media{
    min-height: 220px;
  }

  .welcomePopup__content{
    padding: 26px 18px;
  }
}

/* ===== About Page ===== */
.sectionSpace{
  padding: 72px 0;
}

.sectionKicker{
  display: inline-block;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #7d8b85;
  margin-bottom: 12px;
}

.sectionKicker--light{
  color: rgba(255,255,255,.78);
}

.sectionTitle{
  font-size: clamp(30px, 4vw, 56px);
  line-height: 1.02;
  font-weight: 900;
  margin: 0 0 18px;
  color: #171717;
}

.aboutHero{
  position: relative;
  min-height: 620px;
  overflow: hidden;
  background: #dbe5e0;
}

.aboutHero__bg{
  position: absolute;
  inset: 0;
}

.aboutHero__bg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(.95);
}

.aboutHero::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(19,27,23,.72) 0%, rgba(19,27,23,.34) 42%, rgba(19,27,23,.12) 100%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.08));
  z-index: 1;
}

.aboutHero__inner{
  position: relative;
  z-index: 2;
  min-height: 620px;
  display: flex;
  align-items: center;
}

.aboutHero__content{
  max-width: 700px;
  color: #fff;
  padding: 90px 0;
}

.aboutHero__title{
  font-size: clamp(42px, 6vw, 88px);
  line-height: .98;
  letter-spacing: -.03em;
  margin: 0 0 18px;
  font-weight: 900;
  color: #fff;
}

.aboutHero__text{
  font-size: 18px;
  line-height: 1.7;
  margin: 0 0 24px;
  opacity: .95;
  margin-top: 8px;
  color: rgba(255,255,255,.9);
  max-width: 580px;
}

.aboutHero__btn{
  min-width: 180px;
}

/* Intro */
.aboutIntro__head{
  max-width: 760px;
  margin-bottom: 34px;
}

.aboutIntro__grid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 38px;
}

.aboutIntro__col{
  font-size: 16px;
}

.aboutIntro__col--lead{
  font-size: 18px;
}

.richText{
  color: #495057;
  line-height: 1.9;
}

.richText p{
  margin: 0 0 18px;
  margin-bottom: 22px;
}

.aboutIntro__col--lead p:first-child{
  font-size: 20px;
  color: #1c1c1c;
}

.richText strong{
  color: #171717;
}

/* Mission */
.aboutMission__card{
  background: linear-gradient(180deg, #f7faf8 0%, #eef4f1 100%);
  border: 1px solid rgba(47,127,95,.18);
  border-radius: 28px;
  padding: 46px;
  box-shadow: 0 18px 40px rgba(0,0,0,.05);
}

.aboutMission__text{
  max-width: 920px;
}

/* Values */
.aboutValues__grid{
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 42px;
  align-items: center;
}

.aboutValues__media{
  border-radius: 28px;
  overflow: hidden;
  background: #f3f3f3;
  box-shadow: 0 22px 50px rgba(0,0,0,.08);
}

.aboutValues__media img{
  width: 100%;
  height: 100%;
  min-height: 640px;
  object-fit: cover;
  display: block;
}

.aboutValues__list{
  display: grid;
  gap: 16px;
  margin-top: 26px;
}

.valueCard{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 18px 18px 16px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;

  opacity: 0;
  transform: translateY(10px);
  animation: fadeUp .6s ease forwards;
}

.valueCard:nth-child(2){ animation-delay: .05s; }
.valueCard:nth-child(3){ animation-delay: .1s; }
.valueCard:nth-child(4){ animation-delay: .15s; }

@keyframes fadeUp{
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

.valueCard:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 35px rgba(0,0,0,.08);
  border-color: rgba(47,127,95,.18);
  border-left: 3px solid #2f7f5f;
}

.valueCard__title{
  margin: 0 0 8px;
  font-size: 18px;
  font-weight: 800;
  color: #171717;
}

.valueCard__text{
  margin: 0;
  color: #66707a;
  line-height: 1.7;
  font-size: 15px;
}

/* Band */
.aboutBand{
  position: relative;
  min-height: 360px;
  overflow: hidden;
  margin: 22px 0;
}

.aboutBand__bg{
  position: absolute;
  inset: 0;
}

.aboutBand__bg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.aboutBand::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(18,24,21,.64), rgba(18,24,21,.36));
  z-index: 1;
}

.aboutBand__inner{
  position: relative;
  z-index: 2;
  min-height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.aboutBand__overlay{
  text-align: center;
  color: #fff;
  max-width: 760px;
}

.aboutBand__title{
  margin: 0 0 10px;
  font-size: clamp(34px, 5vw, 70px);
  line-height: 1;
  letter-spacing: -.03em;
  font-weight: 900;
  color: #fff;
  text-shadow: 0 6px 20px rgba(0,0,0,.4);
}

.aboutBand__text{
  margin: 0;
  font-size: 18px;
  line-height: 1.7;
  color: rgba(255,255,255,.88);
}

/* CTA */
.aboutCta__box{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  padding: 34px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  box-shadow: 0 18px 40px rgba(0,0,0,.04);
}

.aboutCta__text{
  margin: 0;
  color: #67727c;
  font-size: 16px;
  line-height: 1.8;
  max-width: 760px;
}

/* Responsive */
@media (max-width: 1100px){
  .aboutIntro__grid,
  .aboutValues__grid,
  .aboutCta__box{
    grid-template-columns: 1fr;
  }

  .aboutValues__media img{
    min-height: 420px;
  }
}

@media (max-width: 980px){
  .sectionSpace{
    padding: 52px 0;
  }

  .aboutHero,
  .aboutHero__inner{
    min-height: 520px;
  }

  .aboutHero__content{
    padding: 70px 0;
  }

  .aboutMission__card,
  .aboutCta__box{
    padding: 24px;
  }

  .aboutBand,
  .aboutBand__inner{
    min-height: 260px;
  }
}

/* ===== About Page refinements ===== */

/* Hero más impactante */
.aboutHero{
  min-height: 700px;
}

.aboutHero__inner{
  min-height: 700px;
}

.aboutHero::before{
  background:
    linear-gradient(90deg, rgba(14,22,18,.78) 0%, rgba(14,22,18,.46) 38%, rgba(14,22,18,.14) 100%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.08));
}

.aboutHero__content{
  max-width: 760px;
}

.aboutHero__title{
  max-width: 720px;
  font-size: clamp(48px, 6vw, 94px);
  line-height: .94;
}

.aboutHero__text{
  font-size: 19px;
  max-width: 620px;
}

.aboutHero__title::after{
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: #fff;
  margin-top: 18px;
  opacity: .6;
}

/* Intro más editorial */
.aboutIntro__head{
  max-width: 820px;
  margin-bottom: 42px;
}

.aboutIntro__grid{
  gap: 54px;
}

.aboutIntro__col{
  font-size: 17px;
}

.aboutIntro__col--lead{
  font-size: 19px;
}

.richText{
  line-height: 2;
  color: #5e6973;
}

/* Misión con más presencia */
.aboutMission__card{
  padding: 54px;
  border-radius: 32px;
  box-shadow: 0 24px 50px rgba(0,0,0,.05);
}

/* Valores */
.aboutValues__grid{
  gap: 56px;
  align-items: start;
}

.aboutValues__media{
  border-radius: 32px;
}

.aboutValues__media img{
  min-height: 720px;
}

.aboutValues__content{
  padding-top: 12px;
}

.aboutValues__list{
  margin-top: 30px;
  gap: 18px;
}

.valueCard{
  padding: 20px 20px 18px;
  border-radius: 20px;
}

.valueCard__title{
  font-size: 19px;
}

.valueCard__text{
  font-size: 15px;
  line-height: 1.75;
}

/* Banda más premium */
.aboutBand{
  min-height: 400px;
  margin: 34px 0;
}

.aboutBand__inner{
  min-height: 400px;
}

.aboutBand::before{
  background: linear-gradient(90deg, rgba(15,20,18,.70), rgba(15,20,18,.42));
}

.aboutBand__title{
  letter-spacing: -.04em;
}

.aboutBand__text{
  max-width: 620px;
  margin: 0 auto;
}

/* CTA final más fuerte */
.aboutCta__box{
  padding: 42px;
  border-radius: 32px;
  gap: 34px;
}

.aboutCta__text{
  font-size: 17px;
  line-height: 1.9;
}

.aboutCta__action .btn{
  min-width: 190px;
  min-height: 52px;
  font-size: 15px;
  font-weight: 800;
  background: #000;
  border-radius: 999px;
  padding: 14px 28px;
  transition: all .25s ease;
}

.aboutCta__action .btn:hover{
  background: #2f7f5f;
}

/* Más aire general */
.aboutMission.sectionSpace,
.aboutValues.sectionSpace,
.aboutCta.sectionSpace{
  padding-top: 86px;
  padding-bottom: 86px;
}

@media (max-width: 1100px){
  .aboutValues__media img{
    min-height: 460px;
  }
}

@media (max-width: 980px){
  .aboutHero,
  .aboutHero__inner{
    min-height: 560px;
  }

  .aboutHero__title{
    font-size: 52px;
  }

  .aboutHero__text{
    font-size: 17px;
  }

  .aboutMission__card,
  .aboutCta__box{
    padding: 28px;
  }

  .aboutValues__media img{
    min-height: 360px;
  }

  .aboutBand,
  .aboutBand__inner{
    min-height: 280px;
  }
}

/* ===== Shop Premium ===== */
.shopHero{
  background: linear-gradient(180deg, #dfe8e3 0%, #edf3f0 100%);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.shopHero--premium{
  position: relative;
  overflow: hidden;
}

.shopHero__inner{
  padding: 54px 0 42px;
}

.shopHero__title{
  font-size: clamp(38px, 5vw, 72px);
  line-height: .95;
  margin: 0 0 14px;
  font-weight: 900;
}

.shopHero__text{
  max-width: 760px;
  color: #66707a;
  line-height: 1.8;
  margin-bottom: 26px;
}

.shopHero__cats{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.shopHero__cat{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.56);
  border: 1px solid rgba(255,255,255,.5);
  color: #000;
  backdrop-filter: blur(8px);
  min-width: 170px;
}

.shopHero__cat:hover{
  background: rgba(255,255,255,.68);
}

.shopHero__catIcon{
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid #000;;
  font-size: 13px;
}

.shopHero__catText{
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.shopHero__catText strong{
  font-size: 12px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #000;
}

.shopHero__catText small{
  color: #000;
  font-size: 12px;
  margin-top: 2px;
}

/* Layout */
.shopGrid{
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 34px;
  align-items: start;
}

.shopSidebar{
  position: sticky;
  top: 110px;
}

.shopMain{
  min-width: 0;
}

/* Sidebar cards */
.shopFilterCard{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 20px;
  margin-bottom: 18px;
  box-shadow: 0 10px 24px rgba(0,0,0,.03);
}

.shopFilterCard__title{
  margin: 0 0 16px;
  font-size: 14px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 900;
  color: #171717;
}

.shopFilterCard__fields{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}

.shopFilterCard__fields input{
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  background: #fff;
}

.shopFilterCard__hint{
  color: #7b848d;
  font-size: 12px;
  line-height: 1.5;
  margin-bottom: 14px;
}

.shopFilterCard__btn{
  width: 100%;
}

.shopCheck{
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
  color: #4f5963;
  font-size: 14px;
}

/* Top products */
.shopTopProducts{
  display: grid;
  gap: 12px;
}

.shopTopProduct{
  display: grid;
  grid-template-columns: 62px 1fr;
  gap: 12px;
  align-items: center;
}

.shopTopProduct__media{
  width: 62px;
  height: 62px;
  border-radius: 14px;
  overflow: hidden;
  background: #fafafa;
  border: 1px solid rgba(0,0,0,.06);
  display: flex;
  align-items: center;
  justify-content: center;
}

.shopTopProduct__img{
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.shopTopProduct__title{
  font-size: 13px;
  line-height: 1.35;
  color: #171717;
  font-weight: 700;
  margin-bottom: 4px;
}

.shopTopProduct__price{
  font-size: 13px;
  font-weight: 900;
  color: #2f7f5f;
}

/* Toolbar */
.shopToolbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 18px;
  margin-bottom: 28px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.shopToolbar--premium{
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 18px;
  align-items: center;
}

.shopToolbar__left{
  color: #606a74;
  font-size: 14px;
}

.shopToolbar__center{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.shopToolbar__label{
  color: #7a838c;
  font-size: 14px;
}

.shopShowCount{
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  font-size: 13px;
  font-weight: 800;
  color: #171717;
}

.shopShowCount.is-active,
.shopShowCount:hover{
  background: #111;
  color: #fff;
}

.shopToolbar .woocommerce-ordering{
  margin: 0 !important;
}

.shopToolbar .woocommerce-ordering select{
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 10px 16px;
  background: #fff;
  min-width: 210px;
}

/* Product grid */
ul.products{
  display:grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin: 0 !important;
  padding: 0 !important;
}

/* Card */
.pCard{
  list-style:none;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  overflow:hidden;
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.pCard:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 44px rgba(0,0,0,.10);
  border-color: rgba(47,127,95,.18);
}

.pCard__mediaWrap{
  position: relative;
  background: #fafafa;
}

.pCard__media{
  display:block;
  padding: 22px;
}

.pCard__img{
  width:100%;
  height: 320px;
  object-fit: contain;
  display:block;
}

.pCard__badge{
  position:absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pCard__badge--sale{
  background:#111;
  color:#fff;
}

.pCard__badge--new{
  background: rgba(47,127,95,.9);
  font-size: 10px;
  padding: 5px 9px;
}

.pCard__hoverActions{
  position:absolute;
  left: 16px;
  right: 16px;
  bottom: 16px;
  opacity: 0;
  transform: translateY(10px);
  transition: .22s ease;
}

.pCard:hover .pCard__hoverActions{
  opacity: 1;
  transform: translateY(0);
}

.pCard:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 36px rgba(0,0,0,.08);
}

.pCard__quickview{
  width:100%;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  padding: 12px 14px;
  font-weight: 800;
  cursor:pointer;
  box-shadow: 0 12px 26px rgba(0,0,0,.12);
}

.pCard__body{
  height:100%;
  padding: 14px 16px 18px;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.pCard__cats{
  display:block;
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #8a948d;
  margin-bottom: 8px;
  line-height: 1.35;
  min-height: 26px;
  opacity: .82;
}

.pCard__title{
  display:block;
  font-weight: 800;
  color: #171717;
  font-size: 15px;
  line-height: 1.34;
  margin-bottom: 12px;

  display:-webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow:hidden;
  min-height: 60px;
}

.pCard__price{
  font-size: 19px;
  font-weight: 900;
  margin-bottom: 14px;
  margin-top:auto;
  color: #171717;
}

.pCard__price del{
  opacity: .45;
  margin-right: 6px;
}

.pCard__price ins{
  text-decoration:none;
}

.pCard__actions{
  margin-top: auto;
}

.pCard__actions .button,
.pCard__actions a.button{
  width:100%;
  border-radius: 999px;
  padding: 12px 16px;
  text-align:center;
  border: 1px solid rgba(0,0,0,.12);
  background:#fff;
  font-weight: 800;
  font-size: 14px;
}

.pCard__actions .button:hover,
.pCard__actions a.button:hover{
  background:#2f7f5f;
  color:#fff;
  border-color:#2f7f5f;
}

@media (hover:hover){
  .pCard__actions{
    opacity: 0;
    transform: translateY(8px);
    transition: .22s ease;
  }

  .pCard:hover .pCard__actions{
    opacity: 1;
    transform: translateY(0);
  }
}

@media (hover:none){
  .pCard__actions,
  .pCard__hoverActions{
    opacity:1;
    transform:none;
  }
}

@media (max-width: 780px){
  .pCard__img{
    height: 210px;
  }

  .pCard__title{
    font-size: 14px;
    min-height: 56px;
  }

  .pCard__price{
    font-size: 17px;
  }
}

/* Pagination */
.shopPagination{
  margin-top: 34px;
}

.shopPagination .page-numbers{
  display:flex;
  gap: 8px;
  flex-wrap:wrap;
}

.shopPagination .page-numbers li{
  list-style:none;
}

.shopPagination .page-numbers a,
.shopPagination .page-numbers span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 42px;
  height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background:#fff;
  font-weight: 700;
}

.shopPagination .page-numbers .current{
  background:#111;
  color:#fff;
}

/* Quick View */
.quickViewModal[hidden]{
  display:none !important;
}

.quickViewModal{
  position: fixed;
  inset: 0;
  z-index: 99999;
}

.quickViewModal__overlay{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.6);
  backdrop-filter: blur(2px);
}

.quickViewModal__dialog{
  position: relative;
  width: min(980px, calc(100% - 32px));
  margin: 6vh auto 0;
  background:#fff;
  border-radius: 24px;
  overflow:hidden;
  z-index:2;
  box-shadow: 0 30px 80px rgba(0,0,0,.28);
}

.quickViewModal__close{
  position:absolute;
  top: 14px;
  right: 14px;
  z-index: 4;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 999px;
  background:#fff;
  cursor:pointer;
}

.quickViewModal__content{
  min-height: 220px;
}

.quickViewModal h2{
  font-size: 28px;
  line-height: 1.2;
}

.quickViewModal p{
  color:#6f6f6f;
}
.quickViewLoading{
  padding: 40px;
}

.quickViewProduct{
  display:grid;
  grid-template-columns: 1fr 1fr;
}

.quickViewProduct__media{
  background:#f8f8f8;
  padding: 28px;
}

.quickViewProduct__img{
  width:100%;
  height: 520px;
  object-fit: contain;
  display:block;
}

.quickViewProduct__info{
  padding: 42px 36px;
}

.quickViewProduct__title{
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
  margin: 0 0 14px;
  font-weight: 900;
}

.quickViewProduct__price{
  font-size: 24px;
  font-weight: 900;
  margin-bottom: 18px;
}

.quickViewProduct__excerpt{
  color:#66707a;
  line-height: 1.8;
  margin-bottom: 24px;
}

.quickViewProduct__actions{
  display:flex;
  gap: 12px;
  flex-wrap:wrap;
}

.quickViewProduct__actions .btn,
.quickViewProduct__actions .button{
  min-width: 160px;
}



/* Responsive */
@media (max-width: 1200px){
  .shopGrid{
    grid-template-columns: 1fr;
  }

  .shopSidebar{
    position: static;
  }
}

@media (max-width: 1100px){
  ul.products{
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 880px){
  .quickViewProduct{
    grid-template-columns: 1fr;
  }

  .quickViewProduct__img{
    height: 320px;
  }

  .quickViewProduct__info{
    padding: 26px 20px;
  }

  .shopToolbar--premium{
    grid-template-columns: 1fr;
    align-items: flex-start;
  }
}

@media (max-width: 780px){
  ul.products{
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }

  .pCard__img{
    height: 220px;
  }
}  

/* ===== Single Product Premium ===== */
.singleProductPage{
  padding-top: 42px;
  padding-bottom: 80px;
}

.singleProductPage .woocommerce-breadcrumb{
  font-size: 13px;
  color: #7a838c;
  margin-bottom: 24px;
}

.singleProductPage .woocommerce-breadcrumb a{
  color: #59626c;
}

.singleProductPremium__grid{
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 76px;
  align-items: start;
}

/* Gallery */
.singleProductPremium__gallery{
  position: sticky;
  top: 110px;
}

.singleProductPremium__img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  border: 1px solid rgb(214, 214, 214);
  border-radius: 5%;
  padding: 15px;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);

}

.singleProductPremium__mainImage{
  height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.singleProductPremium__thumbs{
  display: flex;
  gap: 12px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.singleProductPremium__thumb{
  width: 84px;
  height: 84px;
  border: 1px solid transparent;
  border-radius: 12px;
  background: #fff;
  padding: 8px;
  cursor: pointer;
  transition: all .25s ease;
}

.singleProductPremium__thumb img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.singleProductPremium__thumb:hover{
  border-color: rgba(0,0,0,.15);
}

.singleProductPremium__thumb.is-active{
  border-color: #2f7f5f;
  box-shadow: 0 4px 12px rgba(0,0,0,.08);
}

/* Summary */
.singleProductPremium__summary{
  padding-top: 18px;
}

.singleProductPremium__topMeta{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
}

.singleProductPremium__cats{
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #7b848d;
  line-height: 1.5;
}

.singleProductPremium__cats a{
  color: inherit;
}

.singleProductPremium__badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 12px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 900;
}

.singleProductPremium__title{
  font-size: clamp(34px, 4vw, 62px);
  line-height: .98;
  letter-spacing: -.03em;
  margin: 0 0 18px;
  font-weight: 900;
  color: #171717;
  margin-bottom: 22px;
}

.singleProductPremium__price{
  font-size: 32px;
  font-weight: 900;
  color: #171717;
  margin-bottom: 20px;
}

.singleProductPremium__price del{
  opacity: .38;
  margin-right: 8px;
}

.singleProductPremium__price ins{
  text-decoration: none;
}

.singleProductPremium__excerpt{
  font-size: 15px;
  line-height: 1.9;
  color: #5f6871;
  max-width: 560px;
}

.singleProductPremium__purchase{
  padding: 22px 0 10px;
  border-top: 1px solid rgba(0,0,0,.08);
  border-bottom: 1px solid rgba(0,0,0,.08);
  margin-bottom: 24px;
}

/* Add to cart area */
.singleProductPremium__purchase form.cart{
  display: flex;
  align-items: stretch;
  gap: 12px;
  flex-wrap: wrap;
  margin: 0;
}

.singleProductPremium__purchase .quantity{
  margin: 0 !important;
}

.singleProductPremium__purchase .quantity input.qty{
  min-width: 90px;
  height: 52px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  background: #fff;
}

.singleProductPremium__purchase .single_add_to_cart_button{
  min-width: 220px;
  box-shadow: 0 14px 28px rgba(0,0,0,.10);
  height: 52px;
  border-radius: 999px !important;
  padding: 0 28px !important;
  background: #111 !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 800 !important;
  transition: .2s ease;
}

.singleProductPremium__purchase .single_add_to_cart_button:hover{
  background: #2f7f5f !important;
}

.singleProductPremium__meta{
  display: grid;
  gap: 8px;
  color: #5e6972;
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 24px;
}

.singleProductPremium__meta strong{
  color: #171717;
}

.singleProductPremium__benefits{
  display: grid;
  gap: 12px;
}

.singleProductPremium__benefit{
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: 14px;
  align-items: start;
  padding: 20px;
  border-radius: 20px;
  background: #f7faf8;
  border: 1px solid rgba(47,127,95,.08);
  transition: all .25s ease;
}

.singleProductPremium__benefit:hover{
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.singleProductPremium__benefitIcon{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  background: #eef4f1;
  color: #2f7f5f;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
}

.singleProductPremium__benefitText{
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.singleProductPremium__benefitText strong{
  font-size: 15px;
  color: #171717;
}

.singleProductPremium__benefitText span{
  color: #66707a;
  font-size: 14px;
  line-height: 1.65;
}

/* Tabs */
.singleProductPremium__tabsWrap{
  margin-top: 100px;
}

.singleProductPremium__tabsWrap .woocommerce-tabs{
  border-top: 1px solid rgba(0,0,0,.08);
  padding-top: 28px;
}

.singleProductPremium__tabsWrap ul.tabs{
  display: flex !important;
  gap: 12px;
  flex-wrap: wrap;
  padding: 0 !important;
  margin: 0 0 24px !important;
  border: 0 !important;
}

.singleProductPremium__tabsWrap ul.tabs::before,
.singleProductPremium__tabsWrap ul.tabs::after{
  display: none !important;
}

.singleProductPremium__tabsWrap ul.tabs li{
  border: 0 !important;
  background: transparent !important;
  margin: 0 !important;
  padding: 0 !important;
  border-radius: 999px !important;
}

.singleProductPremium__tabsWrap ul.tabs li a{
  display: inline-flex;
  padding: 12px 18px !important;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 999px;
  background: #fff;
  font-weight: 800 !important;
  color: #171717 !important;
}

.singleProductPremium__tabsWrap ul.tabs li.active a,
.singleProductPremium__tabsWrap ul.tabs li a:hover{
  background: #111;
  color: #fff !important;
  border-color: #111;
}

.singleProductPremium__tabsWrap .panel{
  padding-top: 10px;
  color: #5f6973;
  line-height: 1.9;
  font-size: 16px;
}

/* Related */
.singleProductPremium__related{
  margin-top: 84px;
}

.singleProductPremium__related .related > h2{
  font-size: 28px;
  margin: 0 0 22px;
  font-weight: 900;
  color: #171717;
}

/* Responsive */
@media (max-width: 1100px){
  .singleProductPremium__grid{
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .singleProductPremium__gallery{
    position: static;
  }

  .singleProductPremium__img{
    height: 460px;
  }
}

@media (max-width: 780px){
  .singleProductPage{
    padding-top: 26px;
  }

  .singleProductPremium__title{
    font-size: 38px;
  }

  .singleProductPremium__price{
    font-size: 28px;
  }

  .singleProductPremium__img{
    height: 320px;
  }

  .singleProductPremium__mainImage{
    padding: 34px;
    border-radius: 20px;
  }

  .singleProductPremium__thumb{
    width: 70px;
    height: 70px;
  }

  .singleProductPremium__purchase form.cart{
    flex-direction: column;
  }

  .singleProductPremium__purchase .quantity input.qty,
  .singleProductPremium__purchase .single_add_to_cart_button{
    width: 100%;
  }
}

.singleProductPremium__specialBtn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:220px;
  height:52px;
  padding:0 28px;
  border-radius:999px;
  background:#111;
  color:#fff;
  font-weight:800;
  text-decoration:none;
}

.singleProductPremium__specialBtn:hover{
  background:#2f7f5f;
  color:#fff;
}

.singleProductPremium__viewers{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 800;
  color: #d4551f;
  background: rgba(212,85,31,0.08);
  padding: 6px 10px;
  border-radius: 999px;
}

.kol-thankyou-feedback{
  margin-top:40px;
  padding:30px;
  border:1px solid #e6e6e6;
  border-radius:18px;
  background:#f9f9f9;
}

.kol-thankyou-feedback h3{
  margin-top:0;
  font-size:24px;
}

.kol-thankyou-feedback textarea{
  width:100%;
  padding:15px;
  border:1px solid #ddd;
  border-radius:12px;
  resize:vertical;
  font-size:15px;
  margin-top:12px;
  margin-bottom:14px;
}

.kol-thankyou-feedback-success{
  margin-top:30px !important;
}

.kol-checkout-shipping-note{
  margin-top:15px;
  padding:14px 16px;
  background:#f9f9f9;
  border:1px solid #ddd;
  border-radius:12px;
  line-height:1.7;
  font-size:14px;
}

/* ===== Variable products ===== */
.singleProductPremium__purchase .variations_form{
  width: 100%;
}

.singleProductPremium__purchase table.variations{
  width: 100%;
  border: 0;
  margin: 0 0 20px;
}

.singleProductPremium__purchase table.variations tbody,
.singleProductPremium__purchase table.variations tr,
.singleProductPremium__purchase table.variations td{
  display: block;
  width: 100%;
  border: 0;
  padding: 0;
}

.singleProductPremium__purchase table.variations tr{
  margin-bottom: 18px;
}

.singleProductPremium__purchase table.variations td.label{
  margin-bottom: 6px;
}

.singleProductPremium__purchase table.variations td.label label{
  display: block;
  font-size: 14px;
  font-weight: 800;
  color: #171717;
}

.singleProductPremium__purchase table.variations select:hover{
  border-color: rgba(0,0,0,.25);
}

.singleProductPremium__purchase table.variations td.value{
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.singleProductPremium__purchase table.variations select{
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 14px;
  background: #fff;
  padding: 0 14px;
  font-size: 14px;
  color: #171717;
}

.singleProductPremium__purchase .reset_variations{
  display: inline-flex;
  align-items: center;
  font-size: 13px;
  font-weight: 700;
  color: #2f7f5f;
  text-decoration: none;
}

.singleProductPremium__purchase .single_variation_wrap{
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 12px;
}

.singleProductPremium__purchase .woocommerce-variation{
  padding: 14px 16px;
  background: #f7faf8;
  border: 1px solid rgba(47,127,95,.12);
  border-radius: 16px;
}

.singleProductPremium__purchase .woocommerce-variation-description{
  color: #5f6871;
  line-height: 1.7;
  font-size: 14px;
}

.singleProductPremium__purchase .woocommerce-variation-price{
  font-size: 18px;
  font-weight: 900;
  color: #171717;
  margin-bottom: 8px;
}

.singleProductPremium__purchase .woocommerce-variation-add-to-cart{
  display: flex;
  align-items: stretch;
  gap: 12px;
  flex-wrap: wrap;
}

.singleProductPremium__purchase .woocommerce-variation-add-to-cart .quantity{
  margin: 0 !important;
}

.singleProductPremium__purchase .woocommerce-variation-add-to-cart .quantity input.qty{
  width: 90px;
  min-width: 90px;
  height: 52px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  background: #fff;
  text-align: center;
}

.singleProductPremium__purchase .woocommerce-variation-add-to-cart .single_add_to_cart_button{
  min-width: 220px;
  height: 52px;
  border-radius: 999px !important;
  padding: 0 28px !important;
  background: #111 !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 800 !important;
  box-shadow: 0 14px 28px rgba(0,0,0,.10);
}

.singleProductPremium__purchase .woocommerce-variation-add-to-cart .single_add_to_cart_button:hover{
  background: #2f7f5f !important;
}

/* Productos simples */
.singleProductPremium__purchase form.cart:not(.variations_form){
  display: flex;
  align-items: stretch;
  gap: 12px;
  flex-wrap: wrap;
}

.singleProductPremium__purchase form.cart:not(.variations_form) .quantity input.qty{
  width: 90px;
  min-width: 90px;
  height: 52px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  background: #fff;
  text-align: center;
}

.singleProductPremium__purchase form.cart:not(.variations_form) .single_add_to_cart_button{
  min-width: 220px;
  height: 52px;
  border-radius: 999px !important;
  padding: 0 28px !important;
  background: #111 !important;
  color: #fff !important;
  border: 0 !important;
  font-weight: 800 !important;
  box-shadow: 0 14px 28px rgba(0,0,0,.10);
}

.singleProductPremium__purchase form.cart:not(.variations_form) .single_add_to_cart_button:hover{
  background: #2f7f5f !important;
}

@media (max-width: 780px){
  .singleProductPremium__purchase .woocommerce-variation-add-to-cart{
    flex-direction: column;
  }

  .singleProductPremium__purchase .woocommerce-variation-add-to-cart .quantity input.qty,
  .singleProductPremium__purchase .woocommerce-variation-add-to-cart .single_add_to_cart_button,
  .singleProductPremium__purchase form.cart:not(.variations_form) .quantity input.qty,
  .singleProductPremium__purchase form.cart:not(.variations_form) .single_add_to_cart_button{
    width: 100%;
  }
}

/* Tabs single product: limpiar bullets/pseudoelementos */
.singleProductPremium__tabsWrap ul.tabs,
.singleProductPremium__tabsWrap ul.tabs li{
  list-style: none !important;
}

.singleProductPremium__tabsWrap ul.tabs li::before,
.singleProductPremium__tabsWrap ul.tabs li::after{
  display: none !important;
  content: none !important;
}

.singleProductPremium__tabsWrap ul.tabs li a::before,
.singleProductPremium__tabsWrap ul.tabs li a::after{
  display: none !important;
  content: none !important;
}

/* ===== Reviews tab premium ===== */
.singleProductPremium__tabsWrap #reviews{
  max-width: 920px;
}

.singleProductPremium__tabsWrap #reviews #comments{
  margin-bottom: 28px;
}

.singleProductPremium__tabsWrap #reviews h2,
.singleProductPremium__tabsWrap #reviews h3,
.singleProductPremium__tabsWrap #review_form_wrapper .comment-reply-title{
  font-size: 30px;
  line-height: 1.15;
  font-weight: 900;
  color: #171717;
  margin: 0 0 18px;
}

.singleProductPremium__tabsWrap #reviews p{
  color: #5f6871;
  line-height: 1.8;
  font-size: 15px;
}

.singleProductPremium__tabsWrap #review_form_wrapper{
  margin-top: 20px;
  padding: 28px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.04);
}

.singleProductPremium__tabsWrap #review_form .comment-form{
  display: grid;
  gap: 16px;
}

.singleProductPremium__tabsWrap #review_form label{
  display: block;
  font-size: 14px;
  font-weight: 800;
  color: #171717;
  margin-bottom: 8px;
}

.singleProductPremium__tabsWrap #review_form textarea,
.singleProductPremium__tabsWrap #review_form input[type="text"],
.singleProductPremium__tabsWrap #review_form input[type="email"]{
  width: 100%;
  min-height: 52px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  background: #fff;
  padding: 14px 16px;
  font-size: 15px;
  color: #171717;
}

.singleProductPremium__tabsWrap #review_form textarea{
  min-height: 180px;
  resize: vertical;
}

.singleProductPremium__tabsWrap #review_form input:focus,
.singleProductPremium__tabsWrap #review_form textarea:focus,
.singleProductPremium__tabsWrap #review_form select:focus{
  outline: none;
  border-color: rgba(47,127,95,.5);
  box-shadow: 0 0 0 4px rgba(47,127,95,.08);
}

.singleProductPremium__tabsWrap #review_form .form-submit{
  margin: 0;
}

.singleProductPremium__tabsWrap #review_form .submit{
  min-width: 180px;
  height: 52px;
  border: 0;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  padding: 0 24px;
  cursor: pointer;
  transition: .2s ease;
}

.singleProductPremium__tabsWrap #review_form .submit:hover{
  background: #2f7f5f;
}

/* Rating stars/select */
.singleProductPremium__tabsWrap #review_form .comment-form-rating{
  display: grid;
  gap: 8px;
}

.singleProductPremium__tabsWrap #review_form select{
  width: 100%;
  max-width: 320px;
  min-height: 46px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 14px;
  background: #fff;
  padding: 0 14px;
  font-size: 14px;
  color: #171717;
}

/* Reviews list */
.singleProductPremium__tabsWrap ol.commentlist{
  list-style: none !important;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 18px;
}

.singleProductPremium__tabsWrap ol.commentlist li{
  list-style: none !important;
  margin: 0;
  padding: 0;
}

.singleProductPremium__tabsWrap ol.commentlist li::before,
.singleProductPremium__tabsWrap ol.commentlist li::after{
  display: none !important;
  content: none !important;
}

.singleProductPremium__tabsWrap .woocommerce-Reviews .comment_container{
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 16px;
  padding: 20px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  background: #fff;
}

.singleProductPremium__tabsWrap .woocommerce-Reviews .avatar{
  width: 56px !important;
  height: 56px !important;
  border-radius: 999px;
}

.singleProductPremium__tabsWrap .woocommerce-review__author{
  font-weight: 800;
  color: #171717;
}

.singleProductPremium__tabsWrap .woocommerce-review__published-date{
  color: #7b848d;
  font-size: 13px;
}

.singleProductPremium__tabsWrap .description_tab,
.singleProductPremium__tabsWrap .reviews_tab{
  list-style: none !important;
}

/* Mensaje sin reviews */
.singleProductPremium__tabsWrap .woocommerce-noreviews{
  padding: 18px 20px;
  border-radius: 16px;
  background: #f7faf8;
  border: 1px solid rgba(47,127,95,.10);
  color: #5f6871;
}

/* Mobile */
@media (max-width: 780px){
  .singleProductPremium__tabsWrap #reviews h2,
  .singleProductPremium__tabsWrap #reviews h3,
  .singleProductPremium__tabsWrap #review_form_wrapper .comment-reply-title{
    font-size: 24px;
  }

  .singleProductPremium__tabsWrap #review_form_wrapper{
    padding: 20px;
    border-radius: 18px;
  }

  .singleProductPremium__tabsWrap .woocommerce-Reviews .comment_container{
    grid-template-columns: 1fr;
  }
}

/* ===== Sticky Add To Cart ===== */
.singleStickyBar[hidden]{
  display: none !important;
}

.singleStickyBar{
  position: fixed;
  left: 0;
  right: 0;
  bottom: 18px;
  z-index: 9999;
  pointer-events: none;
}

.singleStickyBar__inner{
  width: min(1180px, calc(100% - 24px));
  margin: 0 auto;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(14px);
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 18px 44px rgba(0,0,0,.14);
  border-radius: 22px;
  padding: 12px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  pointer-events: auto;
}

.singleStickyBar__product{
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.singleStickyBar__media{
  width: 56px;
  height: 56px;
  border-radius: 14px;
  overflow: hidden;
  background: #f7f7f7;
  border: 1px solid rgba(0,0,0,.06);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.singleStickyBar__img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.singleStickyBar__info{
  min-width: 0;
}

.singleStickyBar__title{
  font-size: 14px;
  line-height: 1.3;
  font-weight: 800;
  color: #171717;
  margin-bottom: 4px;

  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.singleStickyBar__price{
  font-size: 15px;
  font-weight: 900;
  color: #171717;
}

.singleStickyBar__price del{
  opacity: .45;
  margin-right: 6px;
}

.singleStickyBar__price ins{
  text-decoration: none;
}

.singleStickyBar__actions{
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.singleStickyBar__btn{
  min-width: 180px;
  height: 46px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  cursor: pointer;
  transition: .2s ease;
}

.singleStickyBar__btn:hover{
  background: #2f7f5f;
}

.singleStickyBar__btn--ghost{
  background: #fff;
  color: #111;
  border: 1px solid rgba(0,0,0,.12);
}

.singleStickyBar__btn--ghost:hover{
  background: #111;
  color: #fff;
  border-color: #111;
}

@media (max-width: 780px){
  .singleStickyBar{
    bottom: 10px;
  }

  .singleStickyBar__inner{
    width: calc(100% - 16px);
    padding: 10px;
    gap: 10px;
  }

  .singleStickyBar__media{
    width: 48px;
    height: 48px;
  }

  .singleStickyBar__title{
    font-size: 13px;
  }

  .singleStickyBar__price{
    font-size: 14px;
  }

  .singleStickyBar__btn{
    min-width: auto;
    padding: 0 16px;
    height: 42px;
    font-size: 13px;
  }
}

/* Sticky add to cart qty */
.singleStickyBar__qtyWrap{
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 999px;
  background: #fff;
  overflow: hidden;
  height: 46px;
}

.singleStickyBar__qtyBtn{
  width: 40px;
  height: 46px;
  border: 0;
  background: transparent;
  color: #171717;
  font-size: 18px;
  font-weight: 800;
  cursor: pointer;
  transition: .2s ease;
}

.singleStickyBar__qtyBtn:hover{
  background: #f3f3f3;
}

.singleStickyBar__qty{
  width: 52px;
  height: 46px;
  border: 0;
  text-align: center;
  font-size: 14px;
  font-weight: 800;
  color: #171717;
  background: transparent;
  appearance: textfield;
  -moz-appearance: textfield;
}

.singleStickyBar__qty::-webkit-outer-spin-button,
.singleStickyBar__qty::-webkit-inner-spin-button{
  -webkit-appearance: none;
  margin: 0;
}

@media (max-width: 780px){
  .singleStickyBar__actions{
    gap: 8px;
  }

  .singleStickyBar__qtyWrap{
    height: 42px;
  }

  .singleStickyBar__qtyBtn{
    width: 34px;
    height: 42px;
    font-size: 16px;
  }

  .singleStickyBar__qty{
    width: 42px;
    height: 42px;
    font-size: 13px;
  }
}

/* ===== Internal Woo Hero ===== */
.wooHeroInternal{
  position: relative;
  background: linear-gradient(180deg, #dfe8e3 0%, #edf3f0 100%);
  border-bottom: 1px solid rgba(0,0,0,.06);
  overflow: hidden;
}

.wooHeroInternal.has-bg{
  background-size: cover;
  background-position: center;
}

.wooHeroInternal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(16,18,18,.38);
  pointer-events: none;
}

.wooHeroInternal__inner{
  position: relative;
  z-index: 2;
  padding: 52px 0 38px;
}

.wooHeroInternal__title{
  font-size: clamp(36px, 5vw, 68px);
  line-height: .96;
  margin: 0 0 18px;
  font-weight: 900;
  color: #fff;
}

.wooSteps{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  color: rgba(255,255,255,.84);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-size: 13px;
}

.wooSteps__item.is-active{
  color: #fff;
}

.wooSteps__sep{
  opacity: .6;
}

/* ===== Shared cards/layout ===== */
.wooCard{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.wooBlockTitle{
  margin: 0 0 22px;
  font-size: 28px;
  line-height: 1.05;
  font-weight: 900;
  color: #171717;
}

/* ===== Cart ===== */
.wooCartLayout{
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 28px;
  align-items: start;
}

.wooCartTableWrap{
  padding: 16px 18px;
}

.wooCartTableWrap table{
  width: 100%;
  border-collapse: collapse;
}

.wooCartTableWrap th,
.wooCartTableWrap td{
  padding: 18px 12px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  vertical-align: middle;
}

.wooCartTableWrap th{
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #7a838c;
  font-weight: 900;
}

.wooCartTableWrap .product-thumbnail img{
  width: 88px;
  height: 88px;
  object-fit: contain;
  border-radius: 16px;
  background: #fafafa;
  border: 1px solid rgba(0,0,0,.05);
}

.wooCartTableWrap .product-name a{
  color: #171717;
  font-weight: 800;
  line-height: 1.5;
}

.wooCartTableWrap .remove{
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f5f5f5;
  color: #111 !important;
  font-size: 18px;
}

.wooCartTableWrap .quantity input.qty{
  width: 90px;
  height: 46px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 14px;
  text-align: center;
}

.wooCartTableWrap .actions{
  padding-top: 24px;
}

.wooCartTableWrap .coupon{
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.wooCartTableWrap .coupon label{
  display: none;
}

.wooCartTableWrap .coupon .input-text{
  min-width: 220px;
  height: 46px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 14px;
  padding: 0 14px;
}

.wooCartTableWrap .button,
.wooCartTableWrap button.button{
  height: 46px;
  border-radius: 999px;
  padding: 0 18px;
  border: 0;
  background: #111;
  color: #fff;
  font-weight: 800;
}

.wooCartTableWrap .button:hover,
.wooCartTableWrap button.button:hover{
  background: #2f7f5f;
  color: #fff;
}

.wooCartTotalsCard{
  padding: 22px;
  position: sticky;
  top: 110px;
}

.wooCartTotalsCard .cart_totals h2{
  font-size: 28px;
  margin: 0 0 20px;
  font-weight: 900;
}

.wooCartTotalsCard table{
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 20px;
}

.wooCartTotalsCard th,
.wooCartTotalsCard td{
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  vertical-align: top;
}

.wooCartTotalsCard .wc-proceed-to-checkout .checkout-button{
  width: 100%;
  min-height: 52px;
  border-radius: 999px;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800;
}

.wooCartTotalsCard .wc-proceed-to-checkout .checkout-button:hover{
  background: #2f7f5f !important;
}

/* ===== Checkout ===== */
.wooCheckoutLayout{
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 28px;
  align-items: start;
}

.wooCheckoutFields{
  padding: 24px;
}

.wooOrderReviewCard{
  padding: 24px;
  position: sticky;
  top: 110px;
}

.wooCheckoutFields .form-row{
  margin-bottom: 16px;
}

.wooCheckoutFields label{
  display: block;
  font-size: 14px;
  font-weight: 800;
  color: #171717;
  margin-bottom: 8px;
}

.wooCheckoutFields input.input-text,
.wooCheckoutFields textarea,
.wooCheckoutFields select{
  width: 100%;
  min-height: 50px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  background: #fff;
  padding: 12px 16px;
  font-size: 15px;
}

.wooCheckoutFields textarea{
  min-height: 140px;
  resize: vertical;
}

.wooCheckoutFields input:focus,
.wooCheckoutFields textarea:focus,
.wooCheckoutFields select:focus{
  outline: none;
  border-color: rgba(47,127,95,.45);
  box-shadow: 0 0 0 4px rgba(47,127,95,.08);
}

.wooOrderReviewCard table{
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 20px;
}

.wooOrderReviewCard th,
.wooOrderReviewCard td{
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  vertical-align: top;
}

.wooOrderReviewCard #payment{
  background: transparent !important;
  border: 0 !important;
}

.wooOrderReviewCard #payment ul.payment_methods{
  border: 0 !important;
  padding: 0 !important;
  margin: 16px 0 !important;
}

.wooOrderReviewCard #payment ul.payment_methods li{
  list-style: none;
  margin: 0 0 12px;
  padding: 14px 16px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  background: #fff;
}

.wooOrderReviewCard #payment .payment_box{
  background: #f7faf8 !important;
  border: 1px solid rgba(47,127,95,.10) !important;
  border-radius: 16px !important;
  color: #5f6871 !important;
  margin-top: 12px !important;
}

.wooOrderReviewCard #payment .payment_box::before{
  display: none !important;
}

.wooOrderReviewCard #place_order{
  width: 100%;
  min-height: 54px;
  border-radius: 999px !important;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800 !important;
  border: 0 !important;
}

.wooOrderReviewCard #place_order:hover{
  background: #2f7f5f !important;
}

/* Notices premium */


.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error{
  border: 0 !important;
  border-radius: 18px;
  padding: 16px 18px !important;
  box-shadow: 0 8px 20px rgba(0,0,0,.04);
}

.woocommerce-notices-wrapper .woocommerce-message{
  background: #eef8f1 !important;
  color: #1c6b3e !important;
}

.woocommerce-notices-wrapper .woocommerce-info{
  background: #f8f3df !important;
  color: #8d6a10 !important;
}

.woocommerce-notices-wrapper .woocommerce-error{
  background: #fdf0ef !important;
  color: #ab3b34 !important;
}

/* Reward / plugin blocks */
.wooCartPage .woocommerce-info,
.wooCheckoutPage .woocommerce-info{
  border-radius: 18px !important;
}

/* Responsive */
@media (max-width: 1100px){
  .wooCartLayout,
  .wooCheckoutLayout{
    grid-template-columns: 1fr;
  }

  .wooCartTotalsCard,
  .wooOrderReviewCard{
    position: static;
  }
}

@media (max-width: 780px){
  .wooHeroInternal__title{
    font-size: 40px;
  }

  .wooCartTableWrap{
    padding: 14px;
  }

  .wooCartTableWrap table.shop_table_responsive tr td{
    display: block;
    text-align: left !important;
  }

  .wooCartTableWrap table.shop_table_responsive tr td::before{
    font-weight: 800;
    color: #171717;
  }

  .wooCheckoutFields,
  .wooOrderReviewCard,
  .wooCartTotalsCard{
    padding: 18px;
  }
}

/* ===== Mini cart premium ===== */
.js-mini-cart .woocommerce-mini-cart,
.js-mini-cart ul.woocommerce-mini-cart{
  list-style: none !important;
  margin: 0;
  padding: 0;
}

.js-mini-cart .woocommerce-mini-cart li,
.js-mini-cart .woocommerce-mini-cart li::before,
.js-mini-cart .woocommerce-mini-cart li::after{
  list-style: none !important;
  content: none !important;
}

.miniCartItem{
  display: grid;
  grid-template-columns: 24px 82px 1fr;
  gap: 12px;
  align-items: start;
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.miniCartItem__remove .remove{
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f3f3f3;
  color: #111 !important;
  font-size: 16px;
  text-decoration: none;
}

.miniCartItem__thumb img{
  width: 82px;
  height: 82px;
  object-fit: contain;
  display: block;
  border-radius: 14px;
  background: #fafafa;
  border: 1px solid rgba(0,0,0,.06);
}

.miniCartItem__title{
  font-size: 15px;
  line-height: 1.4;
  font-weight: 800;
  color: #171717;
  margin-bottom: 6px;
}

.miniCartItem__title a{
  color: inherit;
  text-decoration: none;
}

.miniCartItem__meta{
  font-size: 12px;
  line-height: 1.5;
  color: #7b848d;
  margin-bottom: 6px;
}

.miniCartItem__price{
  font-size: 14px;
  font-weight: 800;
  color: #171717;
}

.miniCartFooter{
  padding-top: 18px;
}

.miniCartFooter__total{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 16px;
  font-size: 18px;
  font-weight: 900;
  color: #171717;
}

.miniCartFooter__actions{
  display: grid;
  gap: 10px;
}

.miniCartBtn{
  min-height: 50px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 20px;
  font-weight: 800;
  text-decoration: none;
  transition: .2s ease;
}

.miniCartBtn--primary{
  background: #111;
  color: #fff;
}

.miniCartBtn--primary:hover{
  background: #2f7f5f;
  color: #fff;
}

.miniCartBtn--ghost{
  background: #fff;
  color: #111;
  border: 1px solid rgba(0,0,0,.12);
}

.miniCartBtn--ghost:hover{
  background: #111;
  color: #fff;
  border-color: #111;
}

.pageDefault{
  padding-top: 40px;
  padding-bottom: 60px;
}

.checkout-button{
  margin-bottom: 18px;
}

.ppc-button-wrapper{
  border-radius: 999px;
}

.wooCartTotalsCard .wc-proceed-to-checkout{
  margin-top: 18px;
}

.wooCartTotalsCard .wc-proceed-to-checkout a.checkout-button{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
  border-radius: 999px;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800;
  text-decoration: none !important;
  border: 0 !important;
  box-shadow: 0 12px 24px rgba(0,0,0,.10);
}

.wooCartTotalsCard .wc-proceed-to-checkout a.checkout-button:hover{
  background: #2f7f5f !important;
  color: #fff !important;
}

.wooCartTotalsCard{
  padding: 28px;
}

.wooCartTotalsCard table{
  margin-bottom: 24px;
}

.wooCartTotalsCard th,
.wooCartTotalsCard td{
  font-size: 15px;
}

.wooCartTableWrap .quantity input.qty{
  width: 72px;
  height: 40px;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 12px;
  text-align: center;
  font-weight: 700;
}

.wooCartTableWrap .product-thumbnail img{
  width: 76px;
  height: 76px;
  border-radius: 14px;
}

.wooCartTableWrap .actions{
  padding-top: 22px;
}

.wooCartTableWrap .coupon{
  margin-bottom: 12px;
}

/* ===== Full hero cart / checkout ===== */
.wooHeroInternal{
  position: relative;
  width: 100%;
  min-height: 300px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: linear-gradient(180deg, #8f9792 0%, #838b87 100%);
}

.wooHeroInternal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.06);
  pointer-events: none;
}

.wooHeroInternal__inner{
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 54px 24px;
}

.wooHeroInternal .sectionKicker{
  margin-bottom: 12px;
}

.wooHeroInternal__title{
  font-size: clamp(44px, 6vw, 82px);
  line-height: .95;
  margin: 0 0 18px;
  font-weight: 900;
  color: #fff;
  letter-spacing: -.03em;
  max-width: 780px;
}

.wooSteps{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  color: rgba(255,255,255,.76);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 13px;
}

.wooSteps__item.is-active{
  color: #fff;
}

.wooSteps__sep{
  opacity: .55;
}

@media (max-width: 780px){
  .wooHeroInternal{
    min-height: 220px;
  }

  .wooHeroInternal__inner{
    padding: 34px 18px;
  }

  .wooHeroInternal__title{
    font-size: 42px;
  }

  .wooSteps{
    gap: 8px;
    font-size: 11px;
  }
}

.woocommerce-form-coupon-toggle{
  max-width: 1280px;
  margin: 18px auto 0;
  padding: 0 24px;
}

.woocommerce-form-coupon-toggle .woocommerce-info{
  border: 1px solid rgba(0,0,0,.08) !important;
  border-radius: 16px;
  background: #fff !important;
  color: #5f6871 !important;
  padding: 14px 18px !important;
  box-shadow: 0 8px 20px rgba(0,0,0,.04);
}

.wooOrderReviewCard{
  padding: 28px;
}

.wooOrderReviewCard .shop_table th,
.wooOrderReviewCard .shop_table td{
  padding: 16px 0;
}

.wooOrderReviewCard .shop_table{
  margin-bottom: 22px;
}

.wooOrderReviewCard #payment{
  margin-top: 18px;
}

.wooOrderReviewCard .woocommerce-info,
.wooOrderReviewCard .woocommerce-error{
  border-radius: 16px !important;
  padding: 16px 18px !important;
  background: #f7faf8 !important;
  color: #5f6871 !important;
  border: 1px solid rgba(47,127,95,.10) !important;
  box-shadow: none !important;
}

.woocommerce-info{
  margin-bottom: 20px;
}

.wooOrderReviewCard #place_order{
  width: 100%;
  min-height: 54px;
  border-radius: 999px !important;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800 !important;
  border: 0 !important;
  box-shadow: 0 14px 28px rgba(0,0,0,.10);
}

.wooOrderReviewCard #place_order:hover{
  background: #2f7f5f !important;
}

.wooCheckoutFields{
  padding: 28px;
}

.wooCheckoutFields .form-row{
  margin-bottom: 18px;
}

.wooCheckoutFields label{
  margin-bottom: 9px;
  font-size: 14px;
  font-weight: 800;
}

.wooCheckoutFields input.input-text,
.wooCheckoutFields textarea,
.wooCheckoutFields select{
  min-height: 52px;
  border-radius: 16px;
  padding: 13px 16px;
}

.wooCheckoutFields textarea{
  min-height: 150px;
}

.wooCartPage{
  padding-top: 58px;
}

.wooCartLayout{
  gap: 34px;
}

.wooCartTableWrap{
  padding: 20px 22px;
}

.wooCartTotalsCard{
  padding: 28px;
}

.wooCartPage.sectionSpace,
.wooCheckoutPage.sectionSpace{
  padding-top: 64px;
}


/* Nuevos cambios checkout y mini cart pro */

.wooCheckoutFields h3{
  font-size: 22px;
  font-weight: 900;
  margin-bottom: 20px;
}

.wooCheckoutFields h3::before{
  content: "1.";
  margin-right: 8px;
  color: #2f7f5f;
}

.wooOrderReviewCard h3::before{
  content: "2.";
  margin-right: 8px;
  color: #2f7f5f;
}

.wooCheckoutFields input,
.wooCheckoutFields textarea,
.wooCheckoutFields select{
  border: 1px solid rgba(0,0,0,.08);
  transition: all .2s ease;
  background: #fff;
}

.wooCheckoutFields input:focus,
.wooCheckoutFields textarea:focus,
.wooCheckoutFields select:focus{
  border-color: #2f7f5f;
  box-shadow: 0 0 0 3px rgba(47,127,95,.12);
  outline: none;
}

.wooOrderReviewCard{
  position: sticky;
  top: 120px;
}

.wooOrderReviewCard::after{
  content: "🔒 Compra segura · Tus datos están protegidos";
  display: block;
  font-size: 12px;
  margin-top: 12px;
  color: #7b8480;
  text-align: center;
}

.wooOrderReviewCard #place_order{
  font-size: 15px;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.miniCart{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}

.miniCart.active{
  display: block;
}

.miniCart__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.4);
}

.miniCart__panel{
  position: absolute;
  right: 0;
  top: 0;
  width: 420px;
  height: 100%;
  background: #fff;
  padding: 24px;
  transform: translateX(100%);
  transition: transform .3s ease;
}

.miniCart.active .miniCart__panel{
  transform: translateX(0);
}

.woocommerce-validated input{
  border-color: #2f7f5f;
}

.woocommerce-invalid input{
  border-color: #d33;
}

.checkoutTrust{
  text-align: center;
  margin-top: 20px;
  font-size: 14px;
  color: #7b8480;
}

/* CONTENEDOR GENERAL */
.woocommerce-form-coupon-toggle{
  max-width: 1280px;
  margin: 18px auto 0;
  padding: 0 24px;
}

/* LINK */
.woocommerce-form-coupon-toggle .woocommerce-info{
  border-radius: 999px !important;
  background: #f4f6f5 !important;
  padding: 12px 18px !important;
  text-align: center;
  font-size: 13px;
  cursor: pointer;
  border: none !important;
}

/* BLOQUE CUPON */
.checkout_coupon{
  max-width: 1280px;
  margin: 12px auto 0;
  padding: 0 24px;
  display: none;
}

/* CARD CUPON */
.checkout_coupon .form-row{
  display: flex;
  gap: 12px;
}

.checkout_coupon input{
  flex: 1;
  border-radius: 999px;
  padding: 12px 16px;
  border: 1px solid rgba(0,0,0,.08);
}

.checkout_coupon button{
  border-radius: 999px;
  padding: 12px 18px;
  background: #111;
  color: #fff;
  font-weight: 700;
}

.wooCheckoutPage .container{
  max-width: 1280px;
}

.wooCheckoutLayout{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 40px;
}

@media (max-width: 1024px){
  .wooCheckoutLayout{
    grid-template-columns: 1fr;
  }
}

.wooCheckoutFields input,
.wooCheckoutFields textarea,
.wooCheckoutFields select{
  background: #f7f7f7;
  border: none;
  border-radius: 14px;
  padding: 14px 16px;
  transition: all .2s ease;
}

.wooCheckoutFields input:focus,
.wooCheckoutFields textarea:focus,
.wooCheckoutFields select:focus{
  background: #fff;
  box-shadow: 0 0 0 2px #2f7f5f;
}

.woocommerce-invalid input{
  box-shadow: 0 0 0 2px #ff4d4f;
}

.woocommerce-validated input{
  box-shadow: 0 0 0 2px #2f7f5f;
}

.wooCard{
  transition: all .25s ease;
}

.wooCard:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 40px rgba(0,0,0,.06);
}

#place_order{
  position: relative;
  overflow: hidden;
}

#place_order::after{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.2), transparent);
  opacity: 0;
  transition: opacity .3s;
}

#place_order:hover::after{
  opacity: 1;
}

.wooOrderReviewCard{
  position: sticky;
  top: 110px;
  transition: all .2s ease;
}

.wooCheckoutPage{
  margin-top: -20px;
}

/* ===== SelectWoo / Select2 premium checkout ===== */
.wooCheckoutFields .select2-container,
.wooCheckoutFields .selectWoo-container{
  width: 100% !important;
}

.wooCheckoutFields .select2-container .select2-selection--single,
.wooCheckoutFields .selectWoo-container .select2-selection--single{
  min-height: 52px;
  background: #f7f7f7 !important;
  border: none !important;
  border-radius: 14px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 44px 0 16px !important;
  transition: all .2s ease;
  box-shadow: none !important;
}

.wooCheckoutFields .select2-container--default .select2-selection--single .select2-selection__rendered,
.wooCheckoutFields .selectWoo-container--default .select2-selection--single .select2-selection__rendered{
  line-height: 52px !important;
  color: #171717 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  font-size: 14px;
}

.wooCheckoutFields .select2-container--default .select2-selection--single .select2-selection__arrow,
.wooCheckoutFields .selectWoo-container--default .select2-selection--single .select2-selection__arrow{
  height: 52px !important;
  right: 12px !important;
}

.wooCheckoutFields .select2-container--default .select2-selection--single .select2-selection__placeholder,
.wooCheckoutFields .selectWoo-container--default .select2-selection--single .select2-selection__placeholder{
  color: #8b949e !important;
}

.wooCheckoutFields .select2-container--open .select2-selection--single,
.wooCheckoutFields .selectWoo-container--open .select2-selection--single,
.wooCheckoutFields .select2-container .select2-selection--single:focus,
.wooCheckoutFields .selectWoo-container .select2-selection--single:focus{
  background: #fff !important;
  box-shadow: 0 0 0 2px #2f7f5f !important;
}

.select2-dropdown,
.selectWoo-dropdown{
  border: 1px solid rgba(0,0,0,.08) !important;
  border-radius: 14px !important;
  box-shadow: 0 18px 40px rgba(0,0,0,.08) !important;
  overflow: hidden;
}

.select2-search--dropdown,
.selectWoo-search--dropdown{
  padding: 10px !important;
  background: #fff;
}

.select2-search--dropdown .select2-search__field,
.selectWoo-search--dropdown .select2-search__field{
  border: 1px solid rgba(0,0,0,.08) !important;
  border-radius: 10px !important;
  min-height: 42px;
  padding: 8px 12px !important;
}

.select2-results__option,
.selectWoo-results__option{
  padding: 10px 14px !important;
  font-size: 14px;
}

.select2-results__option--highlighted[aria-selected],
.selectWoo-results__option--highlighted[aria-selected]{
  background: #2f7f5f !important;
  color: #fff !important;
}

.wooCheckoutFields .select2-hidden-accessible{
  position: absolute !important;
  left: -9999px !important;
}

.woocommerce .wooCheckoutFields .select2-container--default .select2-selection--single,
.woocommerce .wooCheckoutFields .selectWoo-container--default .select2-selection--single{
  border: none !important;
  background: #f7f7f7 !important;
  border-radius: 14px !important;
}

.miniCartDrawer{
  display: flex;
  flex-direction: column;
}

.miniCartDrawer__body{
  flex: 1;
  overflow-y: auto;
  padding: 0 18px 18px;
}

.miniCartDrawer__head{
  padding: 18px 18px 14px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.miniCartFooter{
  padding: 18px 0 4px;
  border-top: 1px solid rgba(0,0,0,.08);
  margin-top: 18px;
}

.miniCartFooter__actions{
  display: grid;
  gap: 10px;
}

/* ===== Mini cart drawer premium ===== */
.miniCartOverlay{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.38);
  backdrop-filter: blur(3px);
  z-index: 9998;
}

.miniCartOverlay[hidden]{
  display: none !important;
}

.miniCartDrawer{
  position: fixed;
  top: 0;
  right: 0;
  width: min(430px, 100vw);
  height: 100vh;
  background: #fff;
  z-index: 9999;
  box-shadow: -18px 0 40px rgba(0,0,0,.12);
  transform: translateX(100%);
  transition: transform .28s ease;
  display: flex;
  flex-direction: column;
}

.miniCartDrawer.is-open{
  transform: translateX(0);
}

.miniCartDrawer__head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 18px 18px 16px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.miniCartDrawer__head h3{
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: #171717;
}

.miniCartDrawer__body{
  flex: 1;
  overflow-y: auto;
  padding: 0 18px 24px;
}

/* lista */
.js-mini-cart .woocommerce-mini-cart,
.js-mini-cart ul.woocommerce-mini-cart{
  list-style: none !important;
  margin: 0;
  padding: 0;
}

.js-mini-cart .woocommerce-mini-cart li,
.js-mini-cart .woocommerce-mini-cart li::before,
.js-mini-cart .woocommerce-mini-cart li::after{
  list-style: none !important;
  content: none !important;
}

/* item */
.miniCartItem{
  display: grid;
  grid-template-columns: 22px 86px 1fr;
  gap: 12px;
  align-items: start;
  padding: 16px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.miniCartItem__remove{
  padding-top: 8px;
}

.miniCartItem__remove .remove{
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f3f3f3;
  color: #111 !important;
  font-size: 15px;
  text-decoration: none;
  transition: all .2s ease;
}

.miniCartItem__remove .remove:hover{
  background: #111;
  color: #fff !important;
}

.miniCartItem__thumb img{
  width: 86px;
  height: 86px;
  object-fit: cover;
  display: block;
  border-radius: 16px;
  background: #fafafa;
  border: 1px solid rgba(0,0,0,.06);
}

.miniCartItem__title{
  font-size: 15px;
  line-height: 1.35;
  font-weight: 800;
  color: #171717;
  margin-bottom: 8px;
}

.miniCartItem__title a{
  color: inherit;
  text-decoration: none;
}

.miniCartItem__title a:hover{
  opacity: .78;
}

.miniCartItem__meta{
  font-size: 12px;
  line-height: 1.45;
  color: #7b848d;
  margin-bottom: 6px;
}

.miniCartItem__meta dl,
.miniCartItem__meta dd,
.miniCartItem__meta dt{
  margin: 0;
}

.miniCartItem__price{
  font-size: 15px;
  font-weight: 900;
  color: #171717;
}

/* footer */
.miniCartFooter{
  padding: 18px 0 6px;
  border-top: 1px solid rgba(0,0,0,.08);
  margin-top: 18px;
}

.miniCartFooter__total{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 18px;
  font-size: 16px;
  font-weight: 900;
  color: #171717;
}

.miniCartFooter__actions{
  display: grid;
  gap: 10px;
}

.miniCartBtn{
  min-height: 52px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  font-weight: 800;
  text-decoration: none;
  transition: .22s ease;
  font-size: 15px;
}

.miniCartBtn--primary{
  background: #111;
  color: #fff;
  border: 0;
}

.miniCartBtn--primary:hover{
  background: #2f7f5f;
  color: #fff;
}

.miniCartBtn--ghost{
  background: #fff;
  color: #111;
  border: 1px solid rgba(0,0,0,.12);
}

.miniCartBtn--ghost:hover{
  background: #111;
  color: #fff;
  border-color: #111;
}

.woocommerce-mini-cart__empty-message{
  padding: 24px 0;
  color: #6f7780;
  font-size: 14px;
}

@media (max-width: 640px){
  .miniCartDrawer{
    width: 100vw;
  }

  .miniCartDrawer__body{
    padding: 0 14px 20px;
  }

  .miniCartItem{
    grid-template-columns: 20px 76px 1fr;
    gap: 10px;
  }

  .miniCartItem__thumb img{
    width: 76px;
    height: 76px;
    border-radius: 14px;
  }

  .miniCartDrawer__head{
    padding: 16px 14px 14px;
  }
}

html.no-scroll,
body.no-scroll{
  overflow: hidden;
}

.miniCartDrawer__head{
  position: sticky;
  top: 0;
  background: #fff;
  z-index: 3;
}

.miniCartFooter{
  position: sticky;
  bottom: 0;
  background: #fff;
}

.miniCartDrawer__body{
  flex: 1;
  overflow-y: auto;
  padding: 0 18px 24px;
}

.js-mini-cart-body-inner{
  min-height: 100%;
}

.miniCartFooter{
  padding: 18px 0 6px;
  border-top: 1px solid rgba(0,0,0,.08);
  margin-top: 18px;
}

.miniCartFooter__actions{
  display: grid;
  gap: 10px;
}

.miniCartItem{
  padding: 18px 0;
}

.miniCartItem__title{
  font-size: 14px;
  line-height: 1.32;
  margin-bottom: 6px;
}

.miniCartItem__price{
  font-size: 14px;
}

.miniCartFooter__total{
  padding-top: 2px;
  padding-bottom: 16px;
  font-size: 15px;
}

.miniCartBtn{
  min-height: 50px;
  font-size: 14px;
  letter-spacing: .01em;
}

.miniCartFooter{
  padding-top: 16px;
}

.miniCartDrawer__body{
  padding-bottom: 18px;
}

.miniCartToast{
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 10020;
  background: #111;
  color: #fff;
  padding: 14px 18px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 18px 40px rgba(0,0,0,.18);
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease;
}

.miniCartToast.is-visible{
  opacity: 1;
  transform: translateY(0);
}

@media (max-width: 640px){
  .miniCartToast{
    left: 14px;
    right: 14px;
    bottom: 14px;
    border-radius: 16px;
    text-align: center;
  }
}

.js-mini-cart-remove.is-loading{
  opacity: .45;
  pointer-events: none;
}

/* ===== Thank you page premium ===== */
.wooThankYouPage{
  padding-top: 64px;
  padding-bottom: 80px;
}

.wooThankYouIntro{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 28px;
  margin-bottom: 30px;
}

.wooThankYouIntro__main,
.wooThankYouIntro__aside,
.wooThankYouOrder,
.wooThankYouHelp,
.wooThankYouAccount{
  padding: 28px;
}

.wooThankYouBadge{
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: #f4f7f5;
  color: #2f7f5f;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.wooThankYouTitle{
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.02;
  margin: 0 0 12px;
  font-weight: 900;
  letter-spacing: -.03em;
}

.wooThankYouText{
  color: #66707a;
  line-height: 1.8;
  max-width: 760px;
  margin: 0;
}

.wooThankYouMeta{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.wooThankYouMeta__item{
  padding: 16px 18px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  background: #fff;
}

.wooThankYouMeta__label{
  display: block;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #7e878f;
  margin-bottom: 6px;
}

.wooThankYouMeta__item strong{
  font-size: 16px;
  color: #171717;
}

.wooThankYouSteps{
  display: grid;
  gap: 18px;
}

.wooThankYouStep{
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 14px;
  align-items: start;
}

.wooThankYouStep__num{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  background: #f3f6f4;
  color: #2f7f5f;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
}

.wooThankYouStep strong{
  display: block;
  margin-bottom: 4px;
  font-size: 15px;
}

.wooThankYouStep p{
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: #66707a;
}

.wooThankYouGrid{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 28px;
}

.wooThankYouOrderTable{
  display: grid;
  gap: 16px;
  margin-top: 18px;
}

.wooThankYouOrderItem{
  display: grid;
  grid-template-columns: 84px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.wooThankYouOrderItem__thumb img{
  width: 84px;
  height: 84px;
  object-fit: cover;
  border-radius: 16px;
  display: block;
  background: #fafafa;
  border: 1px solid rgba(0,0,0,.06);
}

.wooThankYouOrderItem__title{
  font-weight: 800;
  line-height: 1.35;
  margin-bottom: 4px;
}

.wooThankYouOrderItem__qty{
  font-size: 13px;
  color: #7b848d;
}

.wooThankYouOrderItem__price{
  font-weight: 900;
  white-space: nowrap;
}

.wooThankYouTotals{
  margin-top: 22px;
  display: grid;
  gap: 12px;
}

.wooThankYouTotals__row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: #171717;
}

.wooThankYouTotals__row.is-total{
  padding-top: 16px;
  margin-top: 6px;
  border-top: 1px solid rgba(0,0,0,.08);
  font-size: 18px;
}

.wooThankYouActions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.wooThankYouActions--stack{
  display: grid;
  gap: 10px;
}

.wooThankYouHelp p,
.wooThankYouAccount p,
.wooThankYouFail__text{
  color: #66707a;
  line-height: 1.7;
}

.wooThankYouFail{
  padding: 32px;
}

.wooThankYouFail__title{
  margin: 0 0 10px;
  font-size: 32px;
  font-weight: 900;
}

@media (max-width: 1024px){
  .wooThankYouIntro,
  .wooThankYouGrid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px){
  .wooThankYouIntro__main,
  .wooThankYouIntro__aside,
  .wooThankYouOrder,
  .wooThankYouHelp,
  .wooThankYouAccount{
    padding: 22px 18px;
  }

  .wooThankYouMeta{
    grid-template-columns: 1fr;
  }

  .wooThankYouOrderItem{
    grid-template-columns: 72px 1fr;
    align-items: start;
  }

  .wooThankYouOrderItem__price{
    grid-column: 2;
  }
}

/* ===== Thank you - bloques default Woo ===== */
.woocommerce-order-details,
.woocommerce-customer-details{
  margin-top: 34px;
  padding: 28px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.woocommerce-order-details__title,
.woocommerce-column__title{
  margin: 0 0 18px;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.02em;
  color: #171717;
}

.woocommerce-order-details table.shop_table{
  width: 100%;
  border-collapse: collapse;
  margin: 0;
}

.woocommerce-order-details table.shop_table th,
.woocommerce-order-details table.shop_table td{
  padding: 14px 0;
  border-bottom: 1px solid rgba(0,0,0,.08);
  font-size: 14px;
  vertical-align: top;
}

.woocommerce-order-details table.shop_table th{
  color: #171717;
  font-weight: 800;
}

.woocommerce-order-details table.shop_table td{
  color: #5f6871;
}

.woocommerce-order-details table.shop_table tfoot th,
.woocommerce-order-details table.shop_table tfoot td{
  font-weight: 900;
  color: #171717;
}

.woocommerce-customer-details address{
  margin: 0;
  font-style: normal;
  line-height: 1.8;
  color: #5f6871;
  font-size: 14px;
}

.woocommerce-customer-details address p{
  margin: 0;
}

/* ===== Thank you - feedback box ===== */
.kol-thankyou-feedback{
  margin-top: 34px;
  padding: 28px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.kol-thankyou-feedback h3{
  margin: 0 0 12px;
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.02em;
  color: #171717;
}

.kol-thankyou-feedback p{
  margin: 0 0 16px;
  color: #66707a;
  line-height: 1.7;
}

.kol-thankyou-feedback textarea{
  width: 100%;
  min-height: 140px;
  resize: vertical;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  background: #f7f7f7;
  padding: 16px 18px;
  font-size: 14px;
  line-height: 1.6;
  transition: all .2s ease;
}

.kol-thankyou-feedback textarea:focus{
  outline: none;
  background: #fff;
  box-shadow: 0 0 0 2px #2f7f5f;
}

.kol-thankyou-feedback .button,
.kol-thankyou-feedback button{
  margin-top: 16px;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 999px !important;
  border: 0 !important;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 14px;
  letter-spacing: .02em;
  box-shadow: 0 12px 24px rgba(0,0,0,.08);
}

.kol-thankyou-feedback .button:hover,
.kol-thankyou-feedback button:hover{
  background: #2f7f5f !important;
  color: #fff !important;
}

.kol-thankyou-feedback-success{
  margin-top: 24px !important;
  border-radius: 18px !important;
  border: 1px solid rgba(47,127,95,.12) !important;
  background: #f4f8f5 !important;
  color: #2f7f5f !important;
  padding: 16px 18px !important;
}

@media (max-width: 640px){
  .woocommerce-order-details,
  .woocommerce-customer-details,
  .kol-thankyou-feedback{
    padding: 22px 18px;
    border-radius: 20px;
  }

  .woocommerce-order-details__title,
  .woocommerce-column__title,
  .kol-thankyou-feedback h3{
    font-size: 24px;
  }
}

/* ===== My Account Premium ===== */
.woocommerce-account .pageDefault,
.woocommerce-account .woocommerce,
.woocommerce-account .woocommerce-MyAccount-content,
.woocommerce-account .woocommerce-MyAccount-navigation{
  font-size: 15px;
}

.woocommerce-account .woocommerce{
  max-width: 1280px;
  margin: 0 auto;
  padding: 56px 24px 80px;
}

.woocommerce-account .woocommerce::after,
.woocommerce-account .woocommerce::before{
  content: "";
  display: table;
}

.woocommerce-account .woocommerce::after{
  clear: both;
}

.woocommerce-account .woocommerce-MyAccount-navigation{
  float: left;
  width: 280px;
}

.woocommerce-account .woocommerce-MyAccount-content{
  float: right;
  width: calc(100% - 320px);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul{
  list-style: none;
  margin: 0;
  padding: 0;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li{
  margin: 0;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li:last-child{
  border-bottom: 0;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a{
  display: flex;
  align-items: center;
  min-height: 56px;
  padding: 0 18px;
  color: #171717;
  text-decoration: none;
  font-weight: 700;
  transition: .2s ease;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover{
  background: #f6f8f7;
  color: #2f7f5f;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a{
  background: #111;
  color: #fff;
}

.woocommerce-account .woocommerce-MyAccount-content{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  padding: 30px;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3{
  margin-top: 0;
  margin-bottom: 16px;
  font-size: 30px;
  font-weight: 900;
  letter-spacing: -.02em;
  color: #171717;
}

.woocommerce-account .woocommerce-MyAccount-content p{
  color: #66707a;
  line-height: 1.8;
}

.woocommerce-account .woocommerce-MyAccount-content a{
  color: #2f7f5f;
}

.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info,
.woocommerce-account .woocommerce-error{
  border-radius: 18px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  background: #f8faf9 !important;
  box-shadow: none !important;
}

/* tablas */
.woocommerce-account table.shop_table{
  width: 100%;
  border-collapse: collapse;
  margin-top: 18px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  overflow: hidden;
}

.woocommerce-account table.shop_table th,
.woocommerce-account table.shop_table td{
  padding: 16px 14px;
  border-bottom: 1px solid rgba(0,0,0,.06);
  text-align: left;
  font-size: 14px;
}

.woocommerce-account table.shop_table th{
  background: #f7f8f8;
  color: #171717;
  font-weight: 800;
}

.woocommerce-account table.shop_table tr:last-child td{
  border-bottom: 0;
}

/* botones */
.woocommerce-account .button,
.woocommerce-account button.button,
.woocommerce-account .woocommerce-Button{
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px !important;
  border: 0 !important;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800 !important;
  box-shadow: 0 12px 24px rgba(0,0,0,.08);
}

.woocommerce-account .button:hover,
.woocommerce-account button.button:hover,
.woocommerce-account .woocommerce-Button:hover{
  background: #2f7f5f !important;
  color: #fff !important;
}

/* formularios */
.woocommerce-account input.input-text,
.woocommerce-account textarea,
.woocommerce-account select{
  min-height: 50px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: #f7f7f7;
  padding: 12px 14px;
  transition: .2s ease;
}

.woocommerce-account textarea{
  min-height: 140px;
  resize: vertical;
}

.woocommerce-account input.input-text:focus,
.woocommerce-account textarea:focus,
.woocommerce-account select:focus{
  outline: none;
  background: #fff;
  box-shadow: 0 0 0 2px #2f7f5f;
}

/* login / register */
.woocommerce-account .u-columns{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

.woocommerce-account .u-column1,
.woocommerce-account .u-column2{
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  padding: 28px;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.woocommerce-account .u-column1 h2,
.woocommerce-account .u-column2 h2{
  margin-top: 0;
  margin-bottom: 16px;
  font-size: 28px;
  font-weight: 900;
}

/* responsive */
@media (max-width: 980px){
  .woocommerce-account .woocommerce-MyAccount-navigation,
  .woocommerce-account .woocommerce-MyAccount-content{
    float: none;
    width: 100%;
  }

  .woocommerce-account .woocommerce-MyAccount-navigation{
    margin-bottom: 20px;
  }

  .woocommerce-account .u-columns{
    grid-template-columns: 1fr;
  }
}

.woocommerce-account .woocommerce-MyAccount-content > p:first-child{
  padding: 18px 20px;
  border-radius: 18px;
  background: #f7faf8;
  border: 1px solid rgba(47,127,95,.08);
  color: #5f6871;
}

/* ===== My account - dashboard cards ===== */
.accountDashboardCards{
  margin-bottom: 28px;
}

.accountDashboardCards__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.accountDashCard{
  padding: 22px 20px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #fafbfb 100%);
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.accountDashCard__kicker{
  display: block;
  margin-bottom: 10px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b848d;
  font-weight: 800;
}

.accountDashCard__value{
  margin: 0 0 6px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.accountDashCard__label{
  margin: 0;
  color: #66707a;
  line-height: 1.6;
}

.accountDashCard__actions{
  margin-top: 8px;
}

.accountDashCard__actions .miniCartBtn{
  min-height: 44px;
  padding: 0 16px;
  font-size: 13px;
}

.accountDashCard__actions a{
  color: #fff !important;
}

/* ===== My account - orders table ===== */
.woocommerce-account .woocommerce-orders-table{
  border-radius: 22px;
  overflow: hidden;
}

.woocommerce-account .woocommerce-orders-table th{
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.woocommerce-account .woocommerce-orders-table td{
  vertical-align: middle;
}

.woocommerce-account .woocommerce-orders-table__cell-order-number a{
  font-weight: 800;
  color: #171717;
  text-decoration: none;
}

.woocommerce-account .woocommerce-orders-table__cell-order-number a:hover{
  color: #2f7f5f;
}

/* badges de estado */
.woocommerce-account .order-status{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}

.woocommerce-account .order-status.status-processing{
  background: #eef6f1;
  color: #2f7f5f;
  border-color: rgba(47,127,95,.15);
}

.woocommerce-account .order-status.status-completed{
  background: #edf7f3;
  color: #237a57;
  border-color: rgba(35,122,87,.14);
}

.woocommerce-account .order-status.status-on-hold{
  background: #fff7e8;
  color: #a46b00;
  border-color: rgba(164,107,0,.14);
}

.woocommerce-account .order-status.status-pending{
  background: #f4f5f7;
  color: #5f6871;
  border-color: rgba(95,104,113,.12);
}

.woocommerce-account .order-status.status-cancelled,
.woocommerce-account .order-status.status-failed,
.woocommerce-account .order-status.status-refunded{
  background: #fff1f1;
  color: #c14c4c;
  border-color: rgba(193,76,76,.14);
}

/* botones tabla pedidos */
.woocommerce-account .woocommerce-orders-table .button{
  min-height: 40px;
  padding: 0 14px;
  font-size: 13px;
}

/* ===== My account - addresses ===== */
.woocommerce-account .woocommerce-Addresses{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 18px;
}

.woocommerce-account .woocommerce-Address{
  margin: 0;
  padding: 24px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #fafbfb 100%);
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

.woocommerce-account .woocommerce-Address header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.woocommerce-account .woocommerce-Address h3,
.woocommerce-account .woocommerce-Address h2{
  margin: 0;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: -.02em;
}

.woocommerce-account .woocommerce-Address .edit{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: #111;
  color: #fff !important;
  text-decoration: none;
  font-weight: 800;
  font-size: 13px;
}

.woocommerce-account .woocommerce-Address .edit:hover{
  background: #2f7f5f;
}

.woocommerce-account .woocommerce-Address address{
  color: #66707a;
  line-height: 1.8;
  font-size: 14px;
}

/* ===== My account - account details form ===== */
.woocommerce-account .edit-account fieldset{
  margin-top: 28px;
  padding: 20px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
}

.woocommerce-account .edit-account fieldset legend{
  padding: 0 8px;
  font-weight: 800;
  color: #171717;
}

/* ===== My account - downloads empty state ===== */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info{
  border-radius: 18px !important;
}

/* ===== Responsive ===== */
@media (max-width: 1100px){
  .accountDashboardCards__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 780px){
  .accountDashboardCards__grid,
  .woocommerce-account .woocommerce-Addresses{
    grid-template-columns: 1fr;
  }
}

/* ===== Mi cuenta - pulido fino ===== */

/* contenedor general del contenido */
.woocommerce-account .woocommerce-MyAccount-content{
  padding: 34px;
}

/* texto inicial del dashboard */
.woocommerce-account .woocommerce-MyAccount-content > p{
  max-width: 820px;
}

/* ===== Pedidos ===== */
.woocommerce-account .woocommerce-orders-table{
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

.woocommerce-account .woocommerce-orders-table thead th{
  background: #f7f8f8;
  padding: 16px 18px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 800;
  color: #171717;
}

.woocommerce-account .woocommerce-orders-table tbody td{
  padding: 18px;
  vertical-align: middle;
  font-size: 14px;
  color: #5f6871;
}

.woocommerce-account .woocommerce-orders-table__cell-order-number a{
  font-weight: 900;
  color: #171717;
  text-decoration: none;
}

.woocommerce-account .woocommerce-orders-table__cell-order-number a:hover{
  color: #2f7f5f;
}

.woocommerce-account .woocommerce-orders-table__cell-order-status{
  white-space: nowrap;
}

.woocommerce-account .woocommerce-orders-table__cell-order-total{
  white-space: nowrap;
  color: #171717;
  font-weight: 700;
}

.woocommerce-account .woocommerce-orders-table__cell-order-actions .button{
  min-height: 38px;
  padding: 0 14px;
  font-size: 12px;
}

/* badge más robusto por si Woo no toma el anterior */
.woocommerce-account .order-status,
.woocommerce-account .woocommerce-orders-table__cell-order-status mark{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  border: 1px solid transparent;
  box-shadow: none;
}

.woocommerce-account .woocommerce-orders-table__cell-order-status mark{
  background: #f4f5f7;
  color: #5f6871;
}

.woocommerce-account .order-status.status-processing,
.woocommerce-account .woocommerce-orders-table__cell-order-status .processing{
  background: #eef6f1 !important;
  color: #2f7f5f !important;
  border-color: rgba(47,127,95,.15) !important;
}

.woocommerce-account .order-status.status-completed,
.woocommerce-account .woocommerce-orders-table__cell-order-status .completed{
  background: #edf7f3 !important;
  color: #237a57 !important;
  border-color: rgba(35,122,87,.14) !important;
}

.woocommerce-account .order-status.status-on-hold,
.woocommerce-account .woocommerce-orders-table__cell-order-status .on-hold{
  background: #fff7e8 !important;
  color: #a46b00 !important;
  border-color: rgba(164,107,0,.14) !important;
}

.woocommerce-account .order-status.status-pending,
.woocommerce-account .woocommerce-orders-table__cell-order-status .pending{
  background: #f4f5f7 !important;
  color: #5f6871 !important;
  border-color: rgba(95,104,113,.12) !important;
}

/* ===== Direcciones ===== */
.woocommerce-account .woocommerce-Addresses{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-top: 20px;
}

.woocommerce-account .woocommerce-Address{
  padding: 28px 24px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  background: linear-gradient(180deg, #ffffff 0%, #fafbfb 100%);
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
  min-height: 260px;
}

.woocommerce-account .woocommerce-Address header{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
}

.woocommerce-account .woocommerce-Address h2,
.woocommerce-account .woocommerce-Address h3{
  margin: 0;
  font-size: 22px;
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: -.02em;
  max-width: 65%;
}

.woocommerce-account .woocommerce-Address .edit{
  flex-shrink: 0;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  background: #111;
  color: #fff !important;
  text-decoration: none;
  font-size: 12px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  white-space: nowrap;
}

.woocommerce-account .woocommerce-Address .edit:hover{
  background: #2f7f5f;
}

.woocommerce-account .woocommerce-Address address{
  margin: 0;
  font-style: normal;
  line-height: 1.9;
  color: #66707a;
  font-size: 14px;
}

.woocommerce-account .woocommerce-Address p{
  color: #66707a;
  line-height: 1.7;
}

/* ===== Detalles de la cuenta ===== */
.woocommerce-account form.woocommerce-EditAccountForm{
  display: grid;
  gap: 18px;
}

.woocommerce-account form.woocommerce-EditAccountForm > p{
  margin: 0;
}

.woocommerce-account form.woocommerce-EditAccountForm .woocommerce-form-row{
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

.woocommerce-account form.woocommerce-EditAccountForm .woocommerce-form-row-first,
.woocommerce-account form.woocommerce-EditAccountForm .woocommerce-form-row-last{
  width: calc(50% - 10px) !important;
  float: left !important;
}

.woocommerce-account form.woocommerce-EditAccountForm .woocommerce-form-row-first{
  margin-right: 20px !important;
}

.woocommerce-account form.woocommerce-EditAccountForm::after{
  content: "";
  display: block;
  clear: both;
}

.woocommerce-account form.woocommerce-EditAccountForm label{
  display: block;
  margin-bottom: 8px;
  font-size: 13px;
  font-weight: 800;
  color: #171717;
}

.woocommerce-account form.woocommerce-EditAccountForm input.input-text,
.woocommerce-account form.woocommerce-EditAccountForm input[type="email"],
.woocommerce-account form.woocommerce-EditAccountForm input[type="password"]{
  width: 100%;
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: #f7f7f7;
  padding: 0 14px;
  font-size: 14px;
}

.woocommerce-account form.woocommerce-EditAccountForm em{
  display: block;
  margin-top: 8px;
  color: #7b848d;
  font-size: 13px;
  line-height: 1.6;
}

.woocommerce-account form.woocommerce-EditAccountForm fieldset{
  margin-top: 14px;
  padding: 22px 20px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  background: #fbfbfb;
}

.woocommerce-account form.woocommerce-EditAccountForm fieldset legend{
  padding: 0 8px;
  font-size: 16px;
  font-weight: 900;
  color: #171717;
}

.woocommerce-account form.woocommerce-EditAccountForm button[type="submit"]{
  justify-self: start;
  min-width: 210px;
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .woocommerce-account .woocommerce-Addresses{
    grid-template-columns: 1fr;
  }

  .woocommerce-account .woocommerce-Address h2,
  .woocommerce-account .woocommerce-Address h3{
    max-width: 100%;
  }

  .woocommerce-account .woocommerce-Address header{
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 780px){
  .woocommerce-account .woocommerce-MyAccount-content{
    padding: 22px 18px;
  }

  .woocommerce-account form.woocommerce-EditAccountForm .woocommerce-form-row-first,
  .woocommerce-account form.woocommerce-EditAccountForm .woocommerce-form-row-last{
    width: 100% !important;
    float: none !important;
    margin-right: 0 !important;
  }

  .woocommerce-account .woocommerce-orders-table th,
  .woocommerce-account .woocommerce-orders-table td{
    padding: 14px 12px;
  }
}

/* ===== Login / Register Premium ===== */
.woocommerce-account:not(.logged-in) .woocommerce{
  max-width: 1180px;
  margin: 0 auto;
  padding: 56px 24px 80px;
}

.woocommerce-account:not(.logged-in) .u-columns{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: start;
}

.woocommerce-account:not(.logged-in) .u-column1,
.woocommerce-account:not(.logged-in) .u-column2{
  width: 100% !important;
  float: none !important;
  margin: 0 !important;
}

.woocommerce-account:not(.logged-in) .u-column1 .woocommerce-form-login,
.woocommerce-account:not(.logged-in) .u-column2 .woocommerce-form-register{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  padding: 34px 30px;
  box-shadow: 0 18px 40px rgba(0,0,0,.04);
  position: relative;
  overflow: hidden;
}

.woocommerce-account:not(.logged-in) .u-column1 .woocommerce-form-login::before,
.woocommerce-account:not(.logged-in) .u-column2 .woocommerce-form-register::before{
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 4px;
  background: linear-gradient(90deg, #2f7f5f 0%, #b9c4bc 100%);
}

.woocommerce-account:not(.logged-in) .u-column1 h2,
.woocommerce-account:not(.logged-in) .u-column2 h2{
  margin: 0 0 10px;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.woocommerce-account:not(.logged-in) .u-column1::before,
.woocommerce-account:not(.logged-in) .u-column2::before{
  display: block;
  margin-bottom: 18px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b848d;
  font-weight: 800;
}

.woocommerce-account:not(.logged-in) .u-column1::before{
  content: "Kolibrie";
}

.woocommerce-account:not(.logged-in) .u-column2::before{
  content: "Nuevo cliente";
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login p,
.woocommerce-account:not(.logged-in) .woocommerce-form-register p{
  color: #66707a;
  line-height: 1.7;
}

.woocommerce-account:not(.logged-in) .form-row{
  margin-bottom: 16px !important;
}

.woocommerce-account:not(.logged-in) label{
  display: block;
  margin-bottom: 8px;
  font-size: 13px;
  font-weight: 800;
  color: #171717;
}

.woocommerce-account:not(.logged-in) input.input-text,
.woocommerce-account:not(.logged-in) input[type="email"],
.woocommerce-account:not(.logged-in) input[type="password"],
.woocommerce-account:not(.logged-in) input[type="text"]{
  width: 100%;
  min-height: 54px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.08);
  background: #f7f7f7;
  padding: 0 16px;
  font-size: 14px;
  transition: all .22s ease;
}

.woocommerce-account:not(.logged-in) input.input-text:focus,
.woocommerce-account:not(.logged-in) input[type="email"]:focus,
.woocommerce-account:not(.logged-in) input[type="password"]:focus,
.woocommerce-account:not(.logged-in) input[type="text"]:focus{
  outline: none;
  background: #fff;
  box-shadow: 0 0 0 2px #2f7f5f;
}

.woocommerce-account:not(.logged-in) .woocommerce-button,
.woocommerce-account:not(.logged-in) button.button,
.woocommerce-account:not(.logged-in) .button{
  min-height: 52px;
  padding: 0 22px;
  border-radius: 999px !important;
  border: 0 !important;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800 !important;
  font-size: 14px;
  letter-spacing: .02em;
  box-shadow: 0 12px 24px rgba(0,0,0,.08);
}

.woocommerce-account:not(.logged-in) .woocommerce-button:hover,
.woocommerce-account:not(.logged-in) button.button:hover,
.woocommerce-account:not(.logged-in) .button:hover{
  background: #2f7f5f !important;
  color: #fff !important;
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__rememberme{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: #5f6871;
  cursor: pointer;
  margin-top: 6px;
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login__rememberme input{
  width: 18px;
  height: 18px;
  accent-color: #2f7f5f;
}

.woocommerce-account:not(.logged-in) .lost_password{
  margin-top: 12px;
}

.woocommerce-account:not(.logged-in) .lost_password a{
  color: #2f7f5f;
  font-weight: 700;
  text-decoration: none;
}

.woocommerce-account:not(.logged-in) .lost_password a:hover{
  text-decoration: underline;
}

.woocommerce-account:not(.logged-in) .woocommerce-form-login .form-row:last-child,
.woocommerce-account:not(.logged-in) .woocommerce-form-register .form-row:last-child{
  margin-bottom: 0 !important;
}

.woocommerce-account:not(.logged-in) .woocommerce-password-strength{
  margin-top: 10px;
  border-radius: 12px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
}

.woocommerce-account:not(.logged-in) .woocommerce-password-strength.strong{
  background: #edf7f3;
  color: #237a57;
}

.woocommerce-account:not(.logged-in) .woocommerce-password-strength.good{
  background: #eef6f1;
  color: #2f7f5f;
}

.woocommerce-account:not(.logged-in) .woocommerce-password-strength.short,
.woocommerce-account:not(.logged-in) .woocommerce-password-strength.bad{
  background: #fff1f1;
  color: #c14c4c;
}

.woocommerce-account:not(.logged-in) .woocommerce-password-hint{
  margin-top: 8px;
  color: #7b848d;
  font-size: 13px;
  line-height: 1.6;
}

.woocommerce-account:not(.logged-in) .woocommerce-error,
.woocommerce-account:not(.logged-in) .woocommerce-message,
.woocommerce-account:not(.logged-in) .woocommerce-info{
  border-radius: 18px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  background: #f8faf9 !important;
  box-shadow: none !important;
  margin-bottom: 20px !important;
}

.woocommerce-account:not(.logged-in) .show-password-input{
  top: 50% !important;
  transform: translateY(-50%);
  right: 16px;
}

.woocommerce-account:not(.logged-in) .form-row-wide{
  width: 100%;
}

@media (max-width: 900px){
  .woocommerce-account:not(.logged-in) .u-columns{
    grid-template-columns: 1fr;
  }

  .woocommerce-account:not(.logged-in) .u-column1 .woocommerce-form-login,
  .woocommerce-account:not(.logged-in) .u-column2 .woocommerce-form-register{
    padding: 26px 20px;
    border-radius: 24px;
  }
}

/* ===== Login/Register intro ===== */
.accountAccessIntro{
  margin-bottom: 26px;
}

.accountAccessIntro__inner{
  max-width: 760px;
}

.accountAccessIntro__kicker{
  margin-bottom: 10px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b848d;
  font-weight: 800;
}

.accountAccessIntro__title{
  margin: 0 0 10px;
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.accountAccessIntro__text{
  margin: 0;
  max-width: 720px;
  color: #66707a;
  line-height: 1.8;
}

/* ===== Mi cuenta / Pedidos en mobile ===== */
@media (max-width: 780px){

  .woocommerce-account .woocommerce-orders-table,
  .woocommerce-account .woocommerce-orders-table tbody,
  .woocommerce-account .woocommerce-orders-table tr,
  .woocommerce-account .woocommerce-orders-table td{
    display: block;
    width: 100%;
  }

  .woocommerce-account .woocommerce-orders-table thead{
    display: none;
  }

  .woocommerce-account .woocommerce-orders-table{
    border: 0;
    background: transparent;
    box-shadow: none;
  }

  .woocommerce-account .woocommerce-orders-table tbody tr{
    background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 22px;
    padding: 14px;
    margin-bottom: 16px;
    box-shadow: 0 12px 30px rgba(0,0,0,.04);
    overflow: hidden;
  }

  .woocommerce-account .woocommerce-orders-table tbody td{
    border: 0 !important;
    padding: 10px 0 !important;
    text-align: left !important;
  }

  .woocommerce-account .woocommerce-orders-table tbody td::before{
    content: attr(data-title);
    display: block;
    margin-bottom: 6px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #7b848d;
  }

  .woocommerce-account .woocommerce-orders-table__cell-order-number a{
    font-size: 18px;
    font-weight: 900;
  }

  .woocommerce-account .woocommerce-orders-table__cell-order-total{
    white-space: normal;
  }

  .woocommerce-account .woocommerce-orders-table__cell-order-actions .button{
    width: 100%;
    justify-content: center;
    min-height: 44px;
  }

  .woocommerce-account .woocommerce-orders-table__cell-order-status .order-status,
  .woocommerce-account .woocommerce-orders-table__cell-order-status mark{
    min-height: 36px;
    font-size: 11px;
    padding: 0 12px;
  }
}

/* ===== Empty states premium ===== */
.wooEmptyState{
  padding-top: 64px;
  padding-bottom: 90px;
}

.wooEmptyState__box{
  max-width: 760px;
  margin: 0 auto;
  padding: 44px 34px;
  text-align: center;
}

.wooEmptyState__icon{
  width: 84px;
  height: 84px;
  margin: 0 auto 18px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f4f7f5;
  font-size: 34px;
}

.wooEmptyState__kicker{
  margin-bottom: 10px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b848d;
  font-weight: 800;
}

.wooEmptyState__title{
  margin: 0 0 12px;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.wooEmptyState__text{
  max-width: 620px;
  margin: 0 auto;
  color: #66707a;
  line-height: 1.8;
  font-size: 15px;
}

.wooEmptyState__actions{
  margin-top: 24px;
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

@media (max-width: 640px){
  .wooEmptyState__box{
    padding: 28px 18px;
  }

  .wooEmptyState__actions{
    display: grid;
    gap: 10px;
  }

  .wooEmptyState__actions .miniCartBtn{
    width: 100%;
  }
}

/* ===== My account empty states ===== */
.woocommerce-account .woocommerce-message,
.woocommerce-account .woocommerce-info{
  border-radius: 20px !important;
}

.woocommerce-account .woocommerce-info{
  background: #f8faf9 !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  color: #5f6871 !important;
  padding: 18px 20px !important;
}

.woocommerce-account .woocommerce-info .button{
  float: none !important;
  margin-left: 12px;
  vertical-align: middle;
}

.accountEmptyState{
  padding: 34px 24px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  background: linear-gradient(180deg, #ffffff 0%, #fafbfb 100%);
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
  text-align: center;
}

.accountEmptyState__icon{
  width: 76px;
  height: 76px;
  margin: 0 auto 14px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #f4f7f5;
  font-size: 30px;
}

.accountEmptyState__kicker{
  margin-bottom: 8px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b848d;
  font-weight: 800;
}

.accountEmptyState__title{
  margin: 0 0 10px;
  font-size: 32px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.accountEmptyState__text{
  max-width: 560px;
  margin: 0 auto 18px;
  color: #66707a;
  line-height: 1.8;
}

/* ===== Cart / Checkout notices spacing ===== */
.woocommerce-notices-wrapper{
  max-width: 1280px;
  margin: 22px auto 0;
  padding: 0 24px;
  position: relative;
  z-index: 3;
}

.woocommerce-notices-wrapper .woocommerce-message,
.woocommerce-notices-wrapper .woocommerce-info,
.woocommerce-notices-wrapper .woocommerce-error{
  margin: 0 0 18px !important;
  border-radius: 18px !important;
  padding: 16px 18px !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  box-shadow: 0 12px 30px rgba(0,0,0,.04);
}

@media (max-width: 780px){
  .woocommerce-notices-wrapper{
    margin-top: 16px;
    padding: 0 16px;
  }
}

/* ===== Cart mobile premium ===== */
@media (max-width: 780px){

  .wooCartLayout{
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .wooCartMain,
  .wooCartAside{
    width: 100%;
  }

  .wooCartTableWrap{
    overflow: visible;
  }

  .wooCartTableWrap table.shop_table,
  .wooCartTableWrap table.shop_table tbody,
  .wooCartTableWrap table.shop_table tr,
  .wooCartTableWrap table.shop_table td{
    display: block;
    width: 100%;
  }

  .wooCartTableWrap table.shop_table thead{
    display: none;
  }

  .wooCartTableWrap table.shop_table{
    border: 0;
    background: transparent;
  }

  .wooCartTableWrap table.shop_table tbody tr.cart_item{
    position: relative;
    padding: 18px 14px 16px;
    margin-bottom: 16px;
    border: 1px solid rgba(0,0,0,.08);
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(0,0,0,.04);
    overflow: hidden;
  }

  .wooCartTableWrap table.shop_table tbody tr.cart_item td{
    border: 0 !important;
    padding: 0;
    margin: 0 0 14px;
    text-align: left !important;
  }

  .wooCartTableWrap table.shop_table tbody tr.cart_item td:last-child{
    margin-bottom: 0;
  }

  .wooCartTableWrap .product-remove{
    position: absolute;
    top: 14px;
    left: 14px;
    margin: 0 !important;
    width: auto;
  }

  .wooCartTableWrap .product-remove a{
    width: 34px;
    height: 34px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #f4f4f4;
    color: #111;
    text-decoration: none;
    font-size: 18px;
    line-height: 1;
  }

  .wooCartTableWrap .product-thumbnail{
    margin-top: 22px !important;
    margin-bottom: 14px !important;
  }

  .wooCartTableWrap .product-thumbnail a,
  .wooCartTableWrap .product-thumbnail img{
    display: block;
  }

  .wooCartTableWrap .product-thumbnail img{
    width: 92px;
    height: 92px;
    object-fit: cover;
    border-radius: 16px;
    border: 1px solid rgba(0,0,0,.08);
    background: #fafafa;
  }

  .wooCartTableWrap .product-name{
    margin-bottom: 12px !important;
  }

  .wooCartTableWrap .product-name a{
    display: block;
    font-size: 18px;
    line-height: 1.3;
    font-weight: 900;
    color: #171717;
    text-decoration: none;
  }

  .wooCartTableWrap .product-price,
  .wooCartTableWrap .product-quantity,
  .wooCartTableWrap .product-subtotal{
    padding-top: 10px !important;
    border-top: 1px solid rgba(0,0,0,.06) !important;
  }

  .wooCartTableWrap .product-price::before,
  .wooCartTableWrap .product-quantity::before,
  .wooCartTableWrap .product-subtotal::before{
    display: block;
    margin-bottom: 6px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #7b848d;
  }

  .wooCartTableWrap .product-price::before{
    content: "Precio";
  }

  .wooCartTableWrap .product-quantity::before{
    content: "Cantidad";
  }

  .wooCartTableWrap .product-subtotal::before{
    content: "Subtotal";
  }

  .wooCartTableWrap .product-quantity .quantity{
    display: inline-flex;
    width: auto;
  }

  .wooCartTableWrap .actions{
    padding: 0 !important;
    margin-top: 10px !important;
  }

  .wooCartTableWrap .actions .coupon{
    display: grid;
    gap: 10px;
    margin-bottom: 12px;
  }

  .wooCartTableWrap .actions .coupon input{
    width: 100%;
  }

  .wooCartTableWrap .actions .button{
    width: 100%;
    justify-content: center;
  }

  .wooCartTotalsCard{
    position: static;
  }

  .wooCartTotalsCard .checkout-button,
  .wooCartTotalsCard .button{
    width: 100%;
  }
}

.wooCartPage,
.wooCartLayout,
.wooCartMain,
.wooCartAside,
.wooCartTableWrap,
.wooCartTotalsCard{
  min-width: 0;
}

/* =========================================================
   BLOG PREMIUM - KOLIBRIE
========================================================= */

/* Hero */
.blogHero{
  position: relative;
  min-height: 280px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: linear-gradient(135deg, #9ea7a1 0%, #8f9791 100%);
}

.blogHero__bg{
  position: absolute;
  inset: 0;
  z-index: 1;
}

.blogHero__bg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.blogHero__overlay{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(49,57,54,.90) 0%, rgba(70,78,74,.84) 36%, rgba(95,103,99,.74) 70%, rgba(110,118,113,.64) 100%),
    linear-gradient(180deg, rgba(0,0,0,.22) 0%, rgba(0,0,0,.34) 100%);
  z-index: 2;
}

.blogHero__inner{
  position: relative;
  z-index: 3;
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: 54px 0;
}

.blogHero__kicker{
  margin-bottom: 12px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(255,255,255,.82);
  font-weight: 800;
}

.blogHero__title{
  margin: 0;
  max-width: 980px;
  font-size: clamp(42px, 6vw, 82px);
  line-height: .96;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #fff;
  text-wrap: balance;
}

.blogHero--single .blogHero__title{
  max-width: 980px;
}

.blogHero__breadcrumbs{
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 13px;
  color: rgba(255,255,255,.78);
}

.blogHero__breadcrumbs a{
  color: rgba(255,255,255,.92);
  text-decoration: none;
}

/* Wrapper general */
.blogPage{
  padding: 54px 0 80px;
}

.blogPage__grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 34px;
  align-items: start;
}

/* Listing */
.blogGrid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px;
  align-items: start;
}

.blogCard{
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
  min-width: 0;
}

.blogCard:hover{
  transform: translateY(-4px);
  box-shadow: 0 22px 48px rgba(0,0,0,.08);
  border-color: rgba(47,127,95,.14);
}

.blogCard__media{
  position: relative;
  height: 240px;
  overflow: hidden;
  background: #f3f4f4;
  flex-shrink: 0;
}

.blogCard__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform .35s ease;
}

.blogCard:hover .blogCard__media img{
  transform: scale(1.04);
}

.blogCard__date{
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
  width: 58px;
  min-height: 58px;
  border-radius: 18px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 10px 24px rgba(0,0,0,.08);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.blogCard__dateDay{
  font-size: 24px;
  font-weight: 900;
  color: #171717;
}

.blogCard__dateMonth{
  margin-top: 4px;
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #7b848d;
  font-weight: 800;
}

.blogCard__body{
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 20px 20px 22px;
}

.blogCard__cat{
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: #edf5f0;
  color: #2f7f5f;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-decoration: none;
  margin-bottom: 12px;
}

.blogCard__title{
  margin: 0 0 12px;
  font-size: 18px;
  line-height: 1.22;
  font-weight: 900;
  letter-spacing: -.02em;
  min-height: 66px;
}

.blogCard__title a{
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.blogCard__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 12px;
  color: #7b848d;
  font-size: 13px;
}

.blogCard__meta span{
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.blogCard__excerpt{
  color: #66707a;
  line-height: 1.75;
  font-size: 14px;
  margin-bottom: 16px;
  flex: 1;

  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 74px;
}

.blogCard__link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #2f7f5f;
  text-decoration: none;
  font-weight: 800;
  font-size: 13px;
}

/* Sidebar */
.blogSidebar{
  display: grid;
  gap: 20px;
}

.blogWidget{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  padding: 22px;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
}

.blogWidget__title{
  margin: 0 0 16px;
  font-size: 20px;
  line-height: 1.15;
  font-weight: 900;
  letter-spacing: -.02em;
  color: #171717;
}

.blogWidget ul{
  list-style: none;
  margin: 0;
  padding: 0;
}

.blogWidget ul li{
  padding: 10px 0;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.blogWidget ul li:last-child{
  border-bottom: 0;
  padding-bottom: 0;
}

.blogWidget ul li a{
  color: #171717;
  text-decoration: none;
}

.blogWidget ul li a:hover{
  color: #2f7f5f;
}

.blogRecentPost{
  display: grid;
  grid-template-columns: 72px minmax(0,1fr);
  gap: 12px;
  align-items: center;
}

.blogRecentPost__thumb img{
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 14px;
  display: block;
}

.blogRecentPost__title{
  font-size: 14px;
  line-height: 1.35;
  font-weight: 800;
  margin-bottom: 4px;
}

.blogRecentPost__meta{
  font-size: 12px;
  color: #7b848d;
}

/* Pagination */
.blogPagination{
  margin-top: 34px;
}

.blogPagination .nav-links{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.blogPagination .page-numbers{
  min-width: 42px;
  height: 42px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  font-weight: 700;
  color: #171717;
  box-sizing: border-box;
}

.blogPagination a.page-numbers:hover{
  background: #f5f7f6;
  color: #171717;
}

.blogPagination .page-numbers.current{
  background: #111;
  color: #fff;
  border-color: #111;
}

.blogPagination .page-numbers.dots{
  border-color: transparent;
  background: transparent;
  min-width: auto;
  padding: 0 4px;
}

.blogPage__grid main{
  min-width: 0;
}

.blogGrid > *{
  min-width: 0;
}

/* Single */
.singlePostPage{
  padding: 54px 0 80px;
}

.singlePostPage__grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 34px;
  align-items: start;
}

.singlePost{
  max-width: 100%;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  padding: 34px 34px 30px;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
  overflow: hidden;
}

.singlePost__cat{
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 12px;
  border-radius: 999px;
  background: #edf5f0;
  color: #2f7f5f;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-decoration: none;
  margin-bottom: 14px;
}

.singlePost__title{
  margin: 0 0 12px;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #171717;
  max-width: 920px;
}

.singlePost__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: 22px;
  color: #7b848d;
  font-size: 14px;
}

.singlePost__thumb{
  margin-bottom: 28px;
}

.singlePost__thumb img{
  width: 100%;
  border-radius: 24px;
  display: block;
  box-shadow: 0 18px 42px rgba(0,0,0,.08);
}

.singlePost__content{
  max-width: 760px;
  color: #4f5861;
  font-size: 16px;
  line-height: 1.95;
}

.singlePost__content > *{
  max-width: 100%;
}

.singlePost__content iframe,
.singlePost__content table{
  max-width: 100%;
}

.singlePost__content h2,
.singlePost__content h3,
.singlePost__content h4{
  margin: 34px 0 14px;
  color: #171717;
  font-weight: 900;
  letter-spacing: -.02em;
  line-height: 1.15;
}

.singlePost__content h2{
  font-size: 34px;
}

.singlePost__content h3{
  font-size: 28px;
}

.singlePost__content p{
  margin: 0 0 18px;
}

.singlePost__content ul,
.singlePost__content ol{
  margin: 0 0 18px 22px;
}

.singlePost__content li{
  margin-bottom: 8px;
}

.singlePost__content img{
  max-width: 100%;
  height: auto;
  border-radius: 20px;
}

.singlePost__share{
  margin-top: 30px;
  padding-top: 22px;
  border-top: 1px solid rgba(0,0,0,.08);
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.singlePost__shareLabel{
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: #7b848d;
  font-weight: 800;
}

.singlePost__nav{
  margin-top: 26px;
  padding-top: 22px;
  border-top: 1px solid rgba(0,0,0,.08);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.singlePost__navItem{
  display: block;
  padding: 16px 18px;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  text-decoration: none;
  color: #171717;
  background: #fafbfb;
}

.singlePost__navItem small{
  display: block;
  margin-bottom: 6px;
  color: #7b848d;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 11px;
  font-weight: 800;
}

.singlePost__navItem strong{
  line-height: 1.4;
  display: block;
}

/* Comments */
.singleComments{
  margin-top: 34px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  padding: 28px;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
}

.singleComments h3,
.singleComments .comment-reply-title{
  margin: 0 0 14px;
  font-size: 28px;
  line-height: 1.1;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.singleComments p{
  color: #66707a;
  line-height: 1.8;
}

.singleComments textarea,
.singleComments input[type="text"],
.singleComments input[type="email"],
.singleComments input[type="url"]{
  width: 100%;
  min-height: 52px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.08);
  background: #f7f7f7;
  padding: 12px 14px;
}

.singleComments textarea{
  min-height: 170px;
  resize: vertical;
}

.singleComments .form-submit .submit{
  min-height: 50px;
  padding: 0 22px;
  border-radius: 999px;
  border: 0;
  background: #111;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
}

.singleComments .form-submit .submit:hover{
  background: #2f7f5f;
}

/* Ocultar instagram viejo si aparece */
.blogInstagram,
.instagramFeed,
.single-post .sb-instagram-section,
.single-post .widget_instagram,
.single-post .null-instagram-feed{
  display: none !important;
}

/* Responsive */
@media (max-width: 1180px){
  .blogGrid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .blogPage__grid,
  .singlePostPage__grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px){
  .blogHero{
    min-height: 220px;
  }

  .blogHero__inner{
    width: min(100%, calc(100% - 32px));
    padding: 40px 0;
  }

  .blogGrid{
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .blogCard__body,
  .singlePost,
  .singleComments,
  .blogWidget{
    padding-left: 18px;
    padding-right: 18px;
  }

  .blogCard__media{
    height: 220px;
  }

  .singlePost{
    padding-top: 24px;
    padding-bottom: 22px;
    border-radius: 24px;
  }

  .singlePost__nav{
    grid-template-columns: 1fr;
  }
}


/* ===== Blog tools ===== */
.blogTools{
  margin-bottom: 26px;
}

.blogSearch{
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
}

.blogSearch__input{
  width: 100%;
  min-height: 54px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  padding: 0 18px;
  font-size: 14px;
  color: #171717;
  box-shadow: 0 10px 24px rgba(0,0,0,.03);
}

.blogSearch__input:focus{
  outline: none;
  border-color: rgba(47,127,95,.3);
  box-shadow: 0 0 0 2px rgba(47,127,95,.12);
}

.blogSearch__button{
  min-height: 54px;
  padding: 0 22px;
  border-radius: 999px;
  border: 0;
  background: #111;
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  box-shadow: 0 12px 24px rgba(0,0,0,.08);
}

.blogSearch__button:hover{
  background: #2f7f5f;
}

@media (max-width: 640px){
  .blogSearch{
    grid-template-columns: 1fr;
  }

  .blogSearch__button{
    width: 100%;
  }
}

/* ===== Blog Filters ===== */
.blogFilters{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 28px;
}

.blogFilterItem{
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border-radius: 999px;
  background: #f3f4f4;
  font-size: 13px;
  font-weight: 600;
  color: #4b5563;
  text-decoration: none;
  transition: all .2s ease;
}

.blogFilterItem:hover{
  background: #e5e7eb;
  color: #111;
}

.blogFilterItem.is-active{
  background: #111;
  color: #fff;
}

.emptyState{
  background: #fff;
  border-radius: 20px;
  padding: 60px 30px;
  text-align: center;
  border: 1px solid rgba(0,0,0,.06);
}

.emptyState h2{
  font-size: 22px;
  margin-bottom: 10px;
}

.emptyState p{
  color: #6b7280;
}

/* =========================================================
   BLOG MAGAZINE / DESTACADO PREMIUM
========================================================= */

.blogFeatured{
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 0;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 30px;
  overflow: hidden;
  box-shadow: 0 18px 38px rgba(0,0,0,.05);
  margin-bottom: 30px;
}

.blogFeatured__media{
  position: relative;
  min-height: 520px;
  overflow: hidden;
  background: #eef1ef;
}

.blogFeatured__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform .45s ease;
}

.blogFeatured:hover .blogFeatured__media img{
  transform: scale(1.03);
}

.blogFeatured__overlay{
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.02) 0%, rgba(0,0,0,.18) 100%);
}

.blogFeatured__content{
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 40px 38px;
}

.blogFeatured__cat{
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  width: fit-content;
  padding: 0 12px;
  border-radius: 999px;
  background: #edf5f0;
  color: #2f7f5f;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  margin-bottom: 16px;
}

.blogFeatured__title{
  margin: 0 0 16px;
  font-size: clamp(34px, 4.2vw, 56px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.045em;
}

.blogFeatured__title a{
  color: #171717;
  text-decoration: none;
}

.blogFeatured__meta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 18px;
  color: #7b848d;
  font-size: 14px;
}

.blogFeatured__excerpt{
  color: #66707a;
  font-size: 16px;
  line-height: 1.85;
  margin-bottom: 22px;
  max-width: 54ch;
}

.blogFeatured__link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #2f7f5f;
  text-decoration: none;
  font-weight: 800;
  font-size: 14px;
}

.blogGrid--magazine{
  margin-top: 0;
}

/* Mejoras extra a cards en modo magazine */
.blogGrid--magazine .blogCard__media{
  height: 230px;
}

.blogGrid--magazine .blogCard__title{
  font-size: 22px;
  min-height: 82px;
}

.blogGrid--magazine .blogCard__excerpt{
  min-height: 76px;
}

/* Responsive */
@media (max-width: 1180px){
  .blogFeatured{
    grid-template-columns: 1fr;
  }

  .blogFeatured__media{
    min-height: 380px;
  }
}

@media (max-width: 780px){
  .blogFeatured{
    border-radius: 24px;
    margin-bottom: 22px;
  }

  .blogFeatured__media{
    min-height: 260px;
  }

  .blogFeatured__content{
    padding: 24px 20px 22px;
  }

  .blogFeatured__title{
    font-size: 34px;
    line-height: 1.04;
  }

  .blogFeatured__excerpt{
    font-size: 15px;
    line-height: 1.8;
  }

  .blogGrid--magazine .blogCard__title{
    font-size: 20px;
    min-height: auto;
  }
}

/* =========================================================
   CONTACTO PREMIUM
========================================================= */

.contactHero{
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(90deg, rgba(79,89,83,.94) 0%, rgba(110,120,114,.82) 100%);
  min-height: 360px;
  display: flex;
  align-items: center;
}

.contactHero__overlay{
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.08), transparent 38%),
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.16));
}

.contactHero__inner{
  position: relative;
  z-index: 2;
  width: 100%;
}

.contactHero__content{
  max-width: 720px;
  padding: 42px 0;
}

.contactHero__title{
  margin: 0 0 14px;
  font-size: clamp(44px, 7vw, 92px);
  line-height: .92;
  font-weight: 900;
  letter-spacing: -.05em;
  color: #fff;
}

.contactHero__text{
  max-width: 620px;
  margin: 0;
  color: rgba(255,255,255,.88);
  font-size: 16px;
  line-height: 1.9;
}

.contactPage{
  background: #fafafa;
}

.contactIntro{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  margin-bottom: 26px;
}

.contactIntro__card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 28px;
  padding: 28px;
  box-shadow: 0 16px 34px rgba(0,0,0,.04);
}

.contactIntro__badge{
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: #edf5f0;
  color: #2f7f5f;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.contactIntro__title{
  margin: 0 0 10px;
  font-size: 32px;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.04em;
}

.contactIntro__text{
  margin: 0;
  color: #66707a;
  line-height: 1.85;
}

.contactLayout{
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, .9fr);
  gap: 26px;
  align-items: start;
}

.contactCard{
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 30px;
  padding: 30px;
  box-shadow: 0 18px 38px rgba(0,0,0,.04);
}

.contactCard + .contactCard{
  margin-top: 22px;
}

.contactCard__head{
  margin-bottom: 18px;
}

.contactCard__title{
  margin: 0;
  font-size: 34px;
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.045em;
}

.contactFormWrap .wpforms-container,
.contactFormWrap .wpcf7{
  margin: 0 !important;
}

.contactFallbackForm__grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.contactField{
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.contactField--full{
  grid-column: 1 / -1;
}

.contactField label{
  font-size: 13px;
  font-weight: 700;
  color: #171717;
}

.contactField input,
.contactField textarea{
  width: 100%;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 20px;
  background: #fff;
  min-height: 56px;
  padding: 0 18px;
  font-size: 14px;
  color: #171717;
  transition: .2s ease;
}

.contactField textarea{
  min-height: 170px;
  padding: 16px 18px;
  resize: vertical;
}

.contactField input:focus,
.contactField textarea:focus{
  outline: none;
  border-color: rgba(47,127,95,.3);
  box-shadow: 0 0 0 3px rgba(47,127,95,.10);
}

.contactSubmitBtn{
  margin-top: 20px;
}

.faqAccordion{
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.faqItem{
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 18px;
  background: #fff;
  overflow: hidden;
  transition: .2s ease;
}

.faqItem[open]{
  border-color: rgba(47,127,95,.16);
  box-shadow: 0 10px 24px rgba(0,0,0,.04);
}

.faqItem__summary{
  list-style: none;
  cursor: pointer;
  padding: 18px 20px;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.5;
  color: #171717;
  position: relative;
  padding-right: 52px;
}

.faqItem__summary::-webkit-details-marker{
  display: none;
}

.faqItem__summary::after{
  content: "+";
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #f3f4f4;
  color: #171717;
  font-size: 18px;
  font-weight: 700;
}

.faqItem[open] .faqItem__summary::after{
  content: "–";
  background: #edf5f0;
  color: #2f7f5f;
}

.faqItem__content{
  padding: 0 20px 18px;
  color: #66707a;
  line-height: 1.8;
}

.faqItem__content p{
  margin: 0;
}

.contactInfoList{
  display: grid;
  gap: 14px;
}

.contactInfoItem{
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  padding: 16px 18px;
  background: #fcfcfc;
}

.contactInfoItem__label{
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #7b848d;
  margin-bottom: 6px;
}

.contactInfoItem__value{
  color: #171717;
  text-decoration: none;
  font-weight: 700;
  line-height: 1.5;
}

.contactInfoItem__value:hover{
  color: #2f7f5f;
}

.contactTrust{
  margin-top: 22px;
  display: grid;
  gap: 10px;
}

.contactTrust__item{
  border-radius: 16px;
  background: #f6f8f7;
  padding: 14px 16px;
  color: #51606a;
  font-size: 14px;
  line-height: 1.6;
}

/* Si usás WPForms o CF7 */
.contactFormWrap input[type="text"],
.contactFormWrap input[type="email"],
.contactFormWrap input[type="tel"],
.contactFormWrap input[type="url"],
.contactFormWrap textarea,
.contactFormWrap select{
  width: 100%;
  min-height: 56px;
  border: 1px solid rgba(0,0,0,.08) !important;
  border-radius: 20px !important;
  background: #fff !important;
  padding: 0 18px !important;
  color: #171717 !important;
  font-size: 14px !important;
  box-shadow: none !important;
}

.contactFormWrap textarea{
  min-height: 170px;
  padding: 16px 18px !important;
}

.contactFormWrap button,
.contactFormWrap input[type="submit"],
.contactFormWrap .wpforms-submit,
.contactFormWrap .wpcf7-submit{
  min-height: 52px;
  padding: 0 22px !important;
  border-radius: 999px !important;
  border: 0 !important;
  background: #111 !important;
  color: #fff !important;
  font-weight: 800 !important;
  cursor: pointer;
  box-shadow: 0 14px 24px rgba(0,0,0,.08);
}

.contactFormWrap button:hover,
.contactFormWrap input[type="submit"]:hover,
.contactFormWrap .wpforms-submit:hover,
.contactFormWrap .wpcf7-submit:hover{
  background: #2f7f5f !important;
}

@media (max-width: 1024px){
  .contactIntro{
    grid-template-columns: 1fr;
  }

  .contactLayout{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px){
  .contactHero{
    min-height: 280px;
  }

  .contactHero__content{
    padding: 22px 0;
  }

  .contactHero__title{
    font-size: 52px;
  }

  .contactCard,
  .contactIntro__card{
    border-radius: 24px;
    padding: 22px 18px;
  }

  .contactCard__title,
  .contactIntro__title{
    font-size: 28px;
  }

  .contactFallbackForm__grid{
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   CONTACTO PREMIUM - AJUSTES FINALES
========================================================= */

/* HERO */
.contactHero{
  min-height: 390px;
  display: flex;
  align-items: center;
}

.contactHero__inner{
  position: relative;
  z-index: 2;
  width: 100%;
}

.contactHero__content{
  max-width: 760px;
  padding: 54px 0;
  margin-left: 0;
}

.contactHero .container{
  display: flex;
  align-items: center;
  max-width: 1320px;
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}

.contactHero__title{
  margin: 0 0 16px;
  font-size: clamp(52px, 7vw, 104px);
  line-height: .9;
  font-weight: 900;
  letter-spacing: -.055em;
  color: #fff;
}

.contactHero__text{
  max-width: 620px;
  margin: 0;
  color: rgba(255,255,255,.90);
  font-size: 16px;
  line-height: 1.9;
}

/* INTRO */
.contactIntro{
  margin-bottom: 26px;
}

.contactIntro--single{
  display: block;
}

.contactIntro__card--wide{
  max-width: 920px;
  margin: 0 auto;
  text-align: center;
  padding: 34px 34px 30px;
}

.contactIntro__card--wide .contactIntro__badge{
  margin-left: auto;
  margin-right: auto;
}

.contactIntro__card--wide .contactIntro__title{
  font-size: clamp(28px, 3vw, 46px);
  line-height: 1.04;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.contactIntro__card--wide .contactIntro__text{
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
  font-size: 15px;
}

/* LAYOUT GENERAL */
.contactLayout{
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
  gap: 28px;
  align-items: start;
}

.contactMain,
.contactSidebar{
  min-width: 0;
}

/* CARDS */
.contactCard{
  border-radius: 30px;
  padding: 32px;
  box-shadow: 0 16px 36px rgba(0,0,0,.045);
}

.contactCard__title{
  font-size: clamp(30px, 3vw, 42px);
}

/* FORM */
.contactFormCard{
  position: relative;
  overflow: hidden;
}

.contactFormCard::before{
  content: "";
  position: absolute;
  top: -120px;
  right: -120px;
  width: 240px;
  height: 240px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(47,127,95,.08) 0%, rgba(47,127,95,0) 70%);
  pointer-events: none;
}

.contactFallbackForm__grid{
  gap: 20px;
}

.contactField label{
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #56616a;
}

.contactField input,
.contactField textarea{
  border-radius: 18px;
  min-height: 58px;
  font-size: 14px;
  background: #fcfcfc;
}

.contactField textarea{
  min-height: 180px;
}

.contactSubmitBtn{
  min-width: 190px;
}

/* FAQ */
.faqCard .contactCard__title{
  margin-bottom: 4px;
}

.faqAccordion{
  gap: 10px;
}

.faqItem{
  border-radius: 16px;
  background: #fbfbfb;
}

.faqItem__summary{
  padding: 17px 18px;
  padding-right: 52px;
  font-size: 14px;
  line-height: 1.55;
}

.faqItem__content{
  padding: 0 18px 18px;
  font-size: 14px;
}

/* INFO */
.contactInfoCard{
  margin-top: 22px;
}

.contactInfoList{
  gap: 12px;
}

.contactInfoItem{
  border-radius: 16px;
  padding: 15px 16px;
}

.contactTrust{
  margin-top: 18px;
}

.contactTrust__item{
  border-radius: 14px;
  padding: 13px 14px;
  font-size: 13px;
}

/* FRANJA FINAL */
.contactTrustBand{
  padding: 0 0 84px;
  background: #fafafa;
}

.contactTrustBand__grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.contactTrustBand__item{
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 24px;
  padding: 26px 24px;
  box-shadow: 0 14px 28px rgba(0,0,0,.035);
}

.contactTrustBand__title{
  font-size: 20px;
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 10px;
  color: #171717;
}

.contactTrustBand__text{
  margin: 0;
  color: #66707a;
  font-size: 14px;
  line-height: 1.8;
}

/* MOBILE / TABLET */
@media (max-width: 1180px){
  .contactLayout{
    grid-template-columns: 1fr;
  }

  .contactTrustBand__grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px){
  .contactHero{
    min-height: 290px;
  }

  .contactHero .container{
    padding-left: 18px;
    padding-right: 18px;
  }

  .contactHero__content{
    padding: 26px 0;
  }

  .contactHero__title{
    font-size: 54px;
  }

  .contactHero__text{
    font-size: 15px;
    line-height: 1.8;
    max-width: 100%;
  }

  .contactIntro__card--wide{
    padding: 24px 18px 22px;
    text-align: left;
  }

  .contactIntro__card--wide .contactIntro__badge{
    margin-left: 0;
    margin-right: 0;
  }

  .contactIntro__card--wide .contactIntro__title,
  .contactIntro__card--wide .contactIntro__text{
    margin-left: 0;
    margin-right: 0;
  }

  .contactCard{
    padding: 22px 18px;
    border-radius: 24px;
  }

  .contactCard__title{
    font-size: 28px;
  }

  .contactTrustBand{
    padding-bottom: 54px;
  }

  .contactTrustBand__item{
    border-radius: 20px;
    padding: 20px 18px;
  }
}

/* =========================================================
   CONTACTO - BLOQUE INFERIOR FULL WIDTH
========================================================= */

.contactBottom{
  padding-top: 8px;
  padding-bottom: 8px;
  background: #fafafa;
}

.contactBottom__card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.07);
  border-radius: 30px;
  padding: 30px;
  box-shadow: 0 18px 38px rgba(0,0,0,.04);
}

.contactBottom__head{
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 20px;
  margin-bottom: 24px;
}

.contactBottom__title{
  margin: 6px 0 0;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.04em;
}

.contactBottom__socials{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.contactBottom__socials a{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  color: #171717;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  transition: .2s ease;
}

.contactBottom__socials a:hover{
  background: #111;
  border-color: #111;
  color: #fff;
}

.contactBottom__grid{
  display: grid;
  grid-template-columns: 1.25fr .75fr;
  gap: 22px;
  align-items: start;
}

.contactInfoList--bottom{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.contactBottom__support{
  display: grid;
  gap: 12px;
}

.contactBottom .contactTrust__item{
  min-height: 62px;
  display: flex;
  align-items: center;
}

@media (max-width: 1024px){
  .contactBottom__grid{
    grid-template-columns: 1fr;
  }

  .contactInfoList--bottom{
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 780px){
  .contactBottom__card{
    border-radius: 24px;
    padding: 22px 18px;
  }

  .contactBottom__head{
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 18px;
  }

  .contactBottom__title{
    font-size: 28px;
  }

  .contactBottom__socials{
    gap: 8px;
  }

  .contactBottom__socials a{
    min-height: 40px;
    padding: 0 14px;
    font-size: 12px;
  }

  .contactInfoList--bottom{
    grid-template-columns: 1fr;
  }
}

/* SOCIAL ICONS */

.contactBottom__socials .socialItem{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  color: #171717;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
  transition: .2s ease;
}

.contactBottom__socials .socialItem:hover{
  background: #111;
  border-color: #111;
  color: #fff;
}

.socialIcon{
  width: 16px;
  height: 16px;
  display: inline-flex;
}

.socialIcon svg{
  width: 100%;
  height: 100%;
}

.socialItem:nth-child(1):hover{ background:#E1306C; border-color:#E1306C; }
.socialItem:nth-child(2):hover{ background:#1877F2; border-color:#1877F2; }
.socialItem:nth-child(3):hover{ background:#000; border-color:#000; }

/* =========================================================
   ANIMACIONES SUTILES PREMIUM
========================================================= */

.revealUp{
  opacity: 0;
  transform: translateY(18px);
  transition:
    opacity .65s ease,
    transform .65s ease;
  will-change: opacity, transform;
}

.revealUp.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* Delay helpers */
.reveal-delay-1{ transition-delay: .05s; }
.reveal-delay-2{ transition-delay: .10s; }
.reveal-delay-3{ transition-delay: .15s; }
.reveal-delay-4{ transition-delay: .20s; }
.reveal-delay-5{ transition-delay: .25s; }

/* Hover premium general */
.contactCard,
.contactIntro__card,
.contactBottom__card,
.contactTrustBand__item,
.blogCard,
.singlePostCard,
.singlePostSidebarCard,
.wooCard,
.accountCard{
  transition:
    transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease;
}

.contactCard:hover,
.contactIntro__card:hover,
.contactBottom__card:hover,
.contactTrustBand__item:hover,
.blogCard:hover,
.singlePostCard:hover,
.singlePostSidebarCard:hover,
.wooCard:hover,
.accountCard:hover{
  transform: translateY(-4px);
  box-shadow: 0 22px 46px rgba(0,0,0,.06);
}

/* FAQ más viva */
.faqItem{
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    border-color .22s ease,
    background .22s ease;
}

.faqItem:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
}

.faqItem[open]{
  background: #fcfdfc;
}

/* Botones suaves */
.btn,
button,
input[type="submit"],
.wpforms-submit,
.wpcf7-submit,
.miniCartBtn,
.contactBottom__socials a{
  transition:
    transform .2s ease,
    box-shadow .2s ease,
    background .2s ease,
    color .2s ease,
    border-color .2s ease;
}

.btn:hover,
button:hover,
input[type="submit"]:hover,
.wpforms-submit:hover,
.wpcf7-submit:hover,
.miniCartBtn:hover,
.contactBottom__socials a:hover{
  transform: translateY(-1px);
}

/* =========================================================
   FOOTER PREMIUM V2
========================================================= */

.siteFooter{
  --footer-bg: #7d8a84;
  --footer-bg-dark: #6f7d77;
  --footer-text: rgba(255,255,255,.92);
  --footer-muted: rgba(255,255,255,.72);
  --footer-line: rgba(255,255,255,.18);
  --footer-chip: rgba(255,255,255,.10);
  --footer-chip-border: rgba(255,255,255,.14);

  position: relative;
  margin-top: 84px;
  background:
    radial-gradient(circle at top right, rgba(255,255,255,.08) 0%, rgba(255,255,255,0) 28%),
    linear-gradient(180deg, var(--footer-bg) 0%, var(--footer-bg-dark) 100%);
  color: #fff;
  overflow: hidden;
}

.siteFooter::before{
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
}

.siteFooter a{
  color: var(--footer-text);
  text-decoration: none;
}

.siteFooter a:hover{
  color: #fff;
}

.siteFooter__top{
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1.05fr 1.15fr .9fr;
  gap: 46px;
  padding-top: 72px;
  padding-bottom: 44px;
}

.siteFooter__brand{
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.siteFooter__logo{
  display: inline-flex;
  align-items: center;
  max-width: 280px;
}

.siteFooter__logo img{
  max-height: 78px;
  width: auto;
  filter: brightness(0) invert(1);
}

.siteFooter__logo span{
  font-size: clamp(42px, 5vw, 72px);
  line-height: .92;
  font-weight: 900;
  letter-spacing: -.055em;
  color: #fff;
}

.siteFooter__brandText{
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.92);
}

.siteFooter__brandDesc{
  max-width: 320px;
  color: var(--footer-muted);
  font-size: 14px;
  line-height: 1.85;
  margin: -6px 0 4px;
}

.siteFooter__socials{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 2px;
}

.siteFooter__socials a{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.03);
  color: #fff;
  transition: .22s ease;
  backdrop-filter: blur(4px);
}

.siteFooter__socials a svg{
  width: 18px;
  height: 18px;
}

.siteFooter__socials a:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.42);
}

.siteFooter__contact{
  display: grid;
  gap: 16px;
  padding-right: 30px;
  border-right: 1px solid var(--footer-line);
}

.siteFooter__item{
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 14px;
  align-items: start;
}

.siteFooter__icon{
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  font-size: 16px;
  line-height: 1;
  opacity: .95;
  margin-top: 2px;
}

.siteFooter__label{
  font-size: 14px;
  font-weight: 900;
  margin-bottom: 4px;
  letter-spacing: .02em;
}

.siteFooter__item p,
.siteFooter__item a{
  margin: 0;
  color: var(--footer-muted);
  font-size: 14px;
  line-height: 1.75;
}

.siteFooter__newsletter{
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}

.siteFooter__newsletter h3{
  margin: 0 0 12px;
  font-size: clamp(26px, 2.2vw, 34px);
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.03em;
}

.siteFooter__newsletter p{
  margin: 0 0 18px;
  color: var(--footer-muted);
  line-height: 1.85;
  font-size: 14px;
  max-width: 320px;
}

.siteFooter__newsletterForm{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  max-width: 420px;
}

.siteFooter__newsletterForm input{
  width: 100%;
  height: 54px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  color: #fff;
  padding: 0 16px;
  font-size: 14px;
  outline: none;
}

.siteFooter__newsletterForm input::placeholder{
  color: rgba(255,255,255,.68);
}

.siteFooter__newsletterForm input:focus{
  border-color: rgba(255,255,255,.42);
  background: rgba(255,255,255,.12);
}

.siteFooter__newsletterForm button{
  height: 54px;
  padding: 0 24px;
  border-radius: 16px;
  border: 0;
  background: #eef3f0;
  color: #31453c;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  transition: .2s ease;
}

.siteFooter__newsletterForm button:hover{
  background: #fff;
  transform: translateY(-1px);
}

.siteFooter__middle{
  position: relative;
  z-index: 2;
  padding-bottom: 18px;
}

.siteFooter__line{
  height: 1px;
  background: var(--footer-line);
}

.siteFooter__bottom{
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 22px;
  
}

.siteFooter__copy{
  color: rgba(255,255,255,.86);
  font-size: 12px;
  line-height: 1.7;
  letter-spacing: .02em;
}

.siteFooter__copy a{
  font-weight: 800;
}

.siteFooter__payments{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.siteFooter__payments img{
  height: 22px;
  width: auto;
  display: block;
  border-radius: 6px;
  background: white;
  padding: 3px 6px;
  border: 1px solid rgba(255,255,255,.12);
}

.siteFooter__payments span{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 68px;
  height: 30px;
  padding: 0 10px;
  border-radius: 10px;
  background: var(--footer-chip);
  border: 1px solid var(--footer-chip-border);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.siteFooter__toTop{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.09);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  font-size: 22px;
  font-weight: 700;
  transition: .22s ease;
}

.siteFooter__toTop:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.16);
}

/* MOBILE */
@media (max-width: 1100px){
  .siteFooter__top{
    grid-template-columns: 1fr;
    gap: 34px;
  }

  .siteFooter__contact{
    border-right: 0;
    padding-right: 0;
    padding-top: 6px;
    border-top: 1px solid var(--footer-line);
  }

  .siteFooter__bottom{
    grid-template-columns: 1fr;
    justify-items: start;
  }
}

@media (max-width: 780px){
  .siteFooter{
    margin-top: 58px;
  }

  .siteFooter__top{
    gap: 28px;
    padding-top: 44px;
    padding-bottom: 28px;
  }

  .siteFooter__logo{
    max-width: 220px;
  }

  .siteFooter__logo img{
    max-height: 60px;
  }

  .siteFooter__logo span{
    font-size: 44px;
  }

  .siteFooter__brand{
    gap: 14px;
  }

  .siteFooter__brandDesc{
    max-width: 100%;
    font-size: 14px;
  }

  .siteFooter__socials{
    gap: 10px;
  }

  .siteFooter__socials a{
    width: 42px;
    height: 42px;
  }

  .siteFooter__newsletter h3{
    font-size: 22px;
  }

  .siteFooter__newsletter p{
    max-width: 100%;
    margin-bottom: 14px;
  }

  .siteFooter__newsletterForm{
    grid-template-columns: 1fr;
  }

  .siteFooter__newsletterForm input,
  .siteFooter__newsletterForm button{
    width: 100%;
  }

  .siteFooter__middle{
    padding-bottom: 14px;
  }

  .siteFooter__bottom{
    gap: 16px;
    padding-bottom: 20px;
  }

  .siteFooter__payments{
    gap: 8px;
  }

  .siteFooter__payments img{
    height: 20px;
    padding: 3px 5px;
  }

  .siteFooter__payments span{
    min-width: auto;
    padding: 0 9px;
    font-size: 10px;
    height: 28px;
  }

  .siteFooter__toTop{
    width: 48px;
    height: 48px;
    font-size: 20px;
  }
}

@media (max-width: 780px){
  .siteFooter__brandDesc{
    display: none;
  }

  .siteFooter__contact{
    gap: 14px;
  }

  .siteFooter__item{
    gap: 10px;
  }

  .siteFooter__item p,
  .siteFooter__item a{
    font-size: 13px;
    line-height: 1.65;
  }

  .siteFooter__copy{
    font-size: 11px;
  }
}

/* ICONOS FOOTER CONTACTO */

.siteFooter__item{
  grid-template-columns: 42px 1fr;
  gap: 14px;
}

.siteFooter__iconWrap{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  margin-top: 2px;
}

.siteFooter__iconSvg{
  width: 19px;
  height: 19px;
  display: inline-flex;
  color: rgba(255,255,255,.94);
}

.siteFooter__iconSvg svg{
  width: 100%;
  height: 100%;
  display: block;
}

@media (max-width: 780px){
  .siteFooter__item{
    grid-template-columns: 38px 1fr;
    gap: 12px;
  }

  .siteFooter__iconWrap{
    width: 38px;
    height: 38px;
  }

  .siteFooter__iconSvg{
    width: 17px;
    height: 17px;
  }
}

.siteFooter__iconWrap:hover{
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.22);
  transform: translateY(-1px);
  transition: .2s ease;
}





/* =========================================================
   HEADER PREMIUM FINAL
========================================================= */

html.no-scroll,
body.no-scroll{
  overflow: hidden;
}

.siteHeader{
  position: sticky;
  top: 0;
  z-index: 9999;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0,0,0,.06);
  transition: box-shadow .25s ease, background .25s ease, transform .25s ease;
}

.siteHeader.is-scrolled,
.siteHeader.is-sticky{
  box-shadow: 0 16px 40px rgba(0,0,0,.08);
  background: rgba(255,255,255,.95);
}

.siteHeader__top{
  background: #7d8a84;
  color: #fff;
}

.siteHeader__topInner{
  min-height: 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.siteHeader__promo{
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .03em;
  text-transform: uppercase;
  color: #fff;
}

.siteHeader__topLinks{
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
}

.siteHeader__topLinks a{
  color: rgba(255,255,255,.96);
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
}

.siteHeader__topLinks a:hover{
  color: #fff;
}

/* MAIN */
.siteHeader__main{
  background: #fff;
}

.siteHeader__mainInner{
  min-height: 92px;
  display: grid;
  grid-template-columns: 220px minmax(420px, 1fr) auto;
  align-items: center;
  gap: 28px;
}

.siteHeader__mobileToggle{
  display: none;
}

.siteHeader__logo{
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: #111;
  min-width: 0;
}

.siteHeader__logo img{
  max-height: 48px;
  width: auto;
  display: block;
}

.siteHeader__logoText{
  font-size: 34px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #111;
}

.siteHeader__searchWrap{
  width: 100%;
  min-width: 0;
}

.siteHeader__actions{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  min-width: max-content;
}

.siteHeader__account{
  color: #171717;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  margin-right: 6px;
  white-space: nowrap;
}

.siteHeader__iconBtn{
  position: relative;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(0,0,0,.09);
  background: #fff;
  color: #5b646a;
  text-decoration: none;
  transition: .2s ease;
  cursor: pointer;
  box-shadow: none;
}

.siteHeader__iconBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(0,0,0,.16);
  color: #111;
}

.siteHeader__iconBtn svg{
  width: 18px;
  height: 18px;
  display: block;
}

.siteHeader__cartCount{
  position: absolute;
  top: -4px;
  right: -2px;
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  background: #3b8b65;
  color: #fff;
  font-size: 10px;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 5px;
}

/* NAV */
.siteHeader__nav{
  background: rgba(255,255,255,.98);
  border-top: 1px solid rgba(0,0,0,.04);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.siteHeader__navInner{
  min-height: 66px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 28px;
}

.siteHeader__menuWrap{
  min-width: 0;
}

.siteHeader__menu{
  display: flex;
  align-items: center;
  gap: 30px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.siteHeader__menu li{
  margin: 0;
}

.siteHeader__menu a{
  color: #171717;
  text-decoration: none;
  font-size: 15px;
  font-weight: 800;
  line-height: 1;
  transition: .18s ease;
}

.siteHeader__menu a:hover,
.siteHeader__menu .current-menu-item > a,
.siteHeader__menu .current_page_item > a{
  color: #3b8b65;
}

.siteHeader__navEnd{
  display: flex;
  justify-content: flex-end;
  min-width: max-content;
}

.siteHeader__navEnd a{
  color: #171717;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  white-space: nowrap;
}

.siteHeader__navEnd a:hover{
  color: #3b8b65;
}

/* CATEGORIES */
.headerCats{
  position: relative;
}

.headerCats__toggle{
  min-height: 48px;
  padding: 0 18px;
  border: 0;
  border-radius: 14px;
  background: #7d8a84;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
  cursor: pointer;
  transition: .22s ease;
  box-shadow: 0 12px 24px rgba(0,0,0,.05);
}

.headerCats__toggle:hover{
  background: #6f7d77;
  transform: translateY(-1px);
}

.headerCats__burger{
  display: inline-flex;
  flex-direction: column;
  gap: 3px;
}

.headerCats__burger span{
  width: 14px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  display: block;
}

.headerCats__panel{
  position: absolute;
  top: calc(100% + 12px);
  left: 0;
  width: 290px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  box-shadow: 0 24px 50px rgba(0,0,0,.08);
  padding: 12px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: .22s ease;
  z-index: 100;
}

.headerCats.is-open .headerCats__panel{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.headerCats__list{
  list-style: none;
  margin: 0;
  padding: 0;
}

.headerCats__list li + li{
  margin-top: 6px;
}

.headerCats__list a{
  min-height: 48px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #171717;
  font-size: 14px;
  font-weight: 700;
  border-radius: 12px;
  transition: .18s ease;
}

.headerCats__list a:hover{
  background: #f5f7f6;
}

/* SEARCH FORM */
.searchFormPremium{
  width: 100%;
}

.searchFormPremium__inner{
  display: grid !important;
  grid-template-columns: minmax(280px, 1fr) 220px 126px !important;
  gap: 0 !important;
  width: 100% !important;
  border: 1px solid rgba(0,0,0,.1) !important;
  border-radius: 999px !important;
  overflow: hidden !important;
  background: #fff !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.03) !important;
}

.searchFormPremium__field{
  width: 100% !important;
  height: 56px !important;
  border: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  padding: 0 22px !important;
  background: #fff !important;
  color: #171717 !important;
  font-size: 15px !important;
}

.searchFormPremium__field::placeholder{
  color: #7e878d;
}

.searchFormPremium__selectWrap{
  position: relative;
  border-left: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

.searchFormPremium__select{
  appearance: none;
  -webkit-appearance: none;
  width: 100%;
  height: 56px;
  border: 0 !important;
  outline: none;
  box-shadow: none !important;
  background: transparent;
  color: #5a646b;
  font-size: 14px;
  font-weight: 800;
  padding: 0 42px 0 16px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.searchFormPremium__selectIcon{
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #79838a;
  font-size: 14px;
  line-height: 1;
  pointer-events: none;
}

.searchFormPremium__submit{
  height: 56px !important;
  border: 0 !important;
  border-left: 1px solid rgba(0,0,0,.08) !important;
  border-radius: 0 !important;
  background: #3b8b65 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  padding: 0 20px !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  cursor: pointer;
  box-shadow: none !important;
  transition: .2s ease;
}

.searchFormPremium__submit:hover{
  background: #2f7656 !important;
}

.searchFormPremium__submitIcon{
  display: none;
}

.searchFormPremium__submitIcon svg{
  width: 18px;
  height: 18px;
  display: block;
}

/* MINI CART */
.miniCartOverlay{
  position: fixed;
  inset: 0;
  background: rgba(15,20,18,.32);
  opacity: 0;
  transition: opacity .22s ease;
  z-index: 9998;
}

.miniCartOverlay.is-visible{
  opacity: 1;
}

.miniCartDrawer{
  position: fixed;
  top: 0;
  right: 0;
  width: min(420px, 100vw);
  height: 100vh;
  background: #fff;
  box-shadow: -24px 0 50px rgba(0,0,0,.12);
  transform: translateX(100%);
  transition: transform .25s ease;
  z-index: 9999;
  display: flex;
  flex-direction: column;
}

.miniCartDrawer.is-open{
  transform: translateX(0);
}

.miniCartDrawer__head{
  min-height: 76px;
  padding: 0 20px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.miniCartDrawer__head h3{
  margin: 0;
  font-size: 30px;
  line-height: 1;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #111;
}

.miniCartDrawer__close{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.1);
  background: #fff;
  font-size: 20px;
  cursor: pointer;
}

.miniCartDrawer__body{
  flex: 1;
  overflow: auto;
  padding: 0;
}

/* SEARCH MODAL */
.searchModal{
  position: fixed;
  inset: 0;
  z-index: 10020;
  pointer-events: none;
}

.searchModal.is-open{
  pointer-events: auto;
}

.searchModal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(15,20,18,.34);
  opacity: 0;
  transition: opacity .22s ease;
}

.searchModal.is-open .searchModal__overlay{
  opacity: 1;
}

.searchModal__panel{
  position: absolute;
  top: 78px;
  left: 50%;
  transform: translateX(-50%) translateY(-12px);
  width: min(760px, calc(100vw - 32px));
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  box-shadow: 0 30px 70px rgba(0,0,0,.12);
  overflow: hidden;
  opacity: 0;
  transition: .22s ease;
}

.searchModal.is-open .searchModal__panel{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.searchModal__head{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.searchModal__input{
  width: 100%;
  height: 48px;
  border: 1px solid rgba(0,0,0,.1);
  border-radius: 999px;
  padding: 0 18px;
  font-size: 15px;
  outline: none;
}

.searchModal__results{
  max-height: 70vh;
  overflow: auto;
  padding: 18px;
}

.searchModal__results .searchModalEmpty{
  color: #66727a;
  font-size: 14px;
}

.iconBtn{
  width: 48px;
  height: 48px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.1);
  background: #fff;
  cursor: pointer;
  font-size: 20px;
}

/* MOBILE SEARCH */
.mobileSearch{
  position: fixed;
  inset: 0;
  z-index: 10030;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 16px;
}

.mobileSearch__inner{
  width: 100%;
  background: #fff;
  border-radius: 20px;
  padding: 14px;
  box-shadow: 0 24px 60px rgba(0,0,0,.14);
  transform: translateY(-10px);
  opacity: 0;
  transition: .22s ease;
}

.mobileSearch.is-open .mobileSearch__inner{
  transform: translateY(0);
  opacity: 1;
}

.mobileSearch__close{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.1);
  background: #fff;
  font-size: 20px;
  margin-left: auto;
  display: block;
  margin-bottom: 12px;
}

.mobileSearch__overlay{
  position: fixed;
  inset: 0;
  background: rgba(15,20,18,.34);
  z-index: 10029;
  opacity: 0;
  transition: opacity .22s ease;
}

.mobileSearch__overlay.is-visible{
  opacity: 1;
}

/* TOAST */
.miniCartToast{
  position: fixed;
  left: 24px;
  bottom: 24px;
  z-index: 10050;
  padding: 14px 18px;
  background: #111;
  color: #fff;
  border-radius: 14px;
  box-shadow: 0 16px 34px rgba(0,0,0,.16);
  font-size: 14px;
  font-weight: 700;
  opacity: 0;
  transform: translateY(12px);
  pointer-events: none;
  transition: .22s ease;
}

.miniCartToast.is-visible{
  opacity: 1;
  transform: translateY(0);
}

/* RESPONSIVE */
@media (max-width: 1180px){
  .siteHeader__mainInner{
    grid-template-columns: 180px minmax(320px, 1fr) auto;
  }

  .searchFormPremium__inner{
    grid-template-columns: 1fr 190px 120px !important;
  }
}

@media (max-width: 980px){
  .siteHeader__mainInner{
    grid-template-columns: 1fr;
    gap: 16px;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .siteHeader__logo{
    justify-content: center;
  }

  .siteHeader__actions{
    justify-content: center;
  }

  .siteHeader__navInner{
    grid-template-columns: 1fr;
    gap: 14px;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .siteHeader__navEnd{
    justify-content: flex-start;
  }
}

@media (max-width: 780px){
  .siteHeader__topInner{
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .siteHeader__promo{
    font-size: 11px;
  }

  .siteHeader__topLinks{
    gap: 12px;
  }

  .siteHeader__account{
    display: none;
  }

  .siteHeader__mobileToggle{
    display: inline-flex;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(0,0,0,.08);
    background: #fff;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
  }

  .siteHeader__mobileToggle span{
    width: 16px;
    height: 2px;
    border-radius: 999px;
    background: #171717;
    display: block;
  }

  .siteHeader__mainInner{
    grid-template-columns: 44px 1fr auto;
    align-items: center;
  }

  .siteHeader__searchWrap{
    display: none;
  }

  .siteHeader__menuWrap{
    display: none;
  }

  .siteHeader__menuWrap.is-open{
    display: block;
  }

  .siteHeader__menu{
    flex-direction: column;
    align-items: flex-start;
    gap: 14px;
  }

  .searchFormPremium__inner{
    grid-template-columns: 1fr !important;
    border-radius: 18px !important;
  }

  .searchFormPremium__selectWrap{
    border-left: 0;
    border-top: 1px solid rgba(0,0,0,.08);
  }

  .searchFormPremium__submit{
    border-left: 0 !important;
    border-top: 1px solid rgba(0,0,0,.08) !important;
    width: 100%;
  }

  .searchFormPremium__submitText{
    display: none;
  }

  .searchFormPremium__submitIcon{
    display: inline-flex;
  }

  .headerCats__panel{
    width: min(320px, calc(100vw - 32px));
  }

  .miniCartToast{
    left: 12px;
    right: 12px;
    bottom: 12px;
  }
}

/* =========================================================
   HEADER CLICK FIX + STICKY FIX
========================================================= */

/* el header siempre arriba y funcional */
.siteHeader{
  position: sticky;
  top: 0;
  z-index: 9999;
}

/* asegurar que cada bloque del header esté por encima */
.siteHeader__top,
.siteHeader__main,
.siteHeader__nav,
.siteHeader__topInner,
.siteHeader__mainInner,
.siteHeader__navInner,
.siteHeader__searchWrap,
.siteHeader__actions,
.siteHeader__menuWrap,
.siteHeader__navEnd,
.headerCats{
  position: relative;
  z-index: 3;
}

/* el buscador no puede invadir otras columnas */
.siteHeader__searchWrap{
  min-width: 0;
  width: 100%;
  overflow: visible;
}

.searchFormPremium{
  width: 100%;
  max-width: 100%;
}

.searchFormPremium__inner{
  width: 100%;
  max-width: 100%;
}

/* acciones siempre por encima */
.siteHeader__actions{
  position: relative;
  z-index: 5;
}

.siteHeader__actions > *{
  position: relative;
  z-index: 5;
}

/* menú clickeable */
.siteHeader__menuWrap,
.siteHeader__menu,
.siteHeader__menu li,
.siteHeader__menu a,
.siteHeader__navEnd a,
.headerCats__toggle,
.headerCats__panel,
.headerCats__list a{
  position: relative;
  z-index: 5;
}

/* dropdown de categorías arriba del resto */
.headerCats__panel{
  z-index: 50;
}

/* overlays ocultos NO deben interceptar clics */
.miniCartOverlay[hidden],
.mobileSearch[hidden],
.mobileSearch__overlay[hidden]{
  display: none !important;
  pointer-events: none !important;
}

/* search modal apagado no debe bloquear nada */
.searchModal{
  pointer-events: none;
}

.searchModal:not(.is-open){
  pointer-events: none !important;
}

.searchModal:not(.is-open) .searchModal__overlay,
.searchModal:not(.is-open) .searchModal__panel{
  pointer-events: none !important;
  opacity: 0;
  visibility: hidden;
}

/* search modal abierto sí */
.searchModal.is-open{
  pointer-events: auto;
}

.searchModal.is-open .searchModal__overlay,
.searchModal.is-open .searchModal__panel{
  pointer-events: auto;
  visibility: visible;
}

/* mini cart cerrado no bloquea */
.miniCartOverlay{
  pointer-events: none;
}

.miniCartOverlay.is-visible{
  pointer-events: auto;
}

/* mobile search cerrado no bloquea */
.mobileSearch__overlay{
  pointer-events: none;
}

.mobileSearch__overlay.is-visible{
  pointer-events: auto;
}

/* popup mobile search oculto no bloquea */
.mobileSearch{
  pointer-events: none;
}

.mobileSearch.is-open{
  pointer-events: auto;
}

/* por si algún pseudo-elemento del header tapa cosas */
.siteHeader *::before,
.siteHeader *::after{
  pointer-events: none;
}

.siteHeader a,
.siteHeader button,
.siteHeader input,
.siteHeader select,
.siteHeader textarea,
.siteHeader label{
  pointer-events: auto;
}

/* sticky estado visual */
.siteHeader.is-sticky,
.siteHeader.is-scrolled{
  position: sticky;
  top: 0;
  z-index: 9999;
}

.siteHeader__mobileSearchBtn{
  display: none;
}

@media (max-width: 780px){
  .siteHeader__mobileSearchBtn{
    display: inline-flex;
  }
}

.searchFormPremium__submit{
  min-width: 96px;
  padding: 0 !important;
}

.searchFormPremium__submitIcon{
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}

.searchFormPremium__submitIcon svg{
  width: 18px;
  height: 18px;
  display: block;
}

.searchFormPremium__submitText{
  display: none !important;
}

/* =========================================================
   HEADER FINAL FIX
========================================================= */

/* sticky real */
.siteHeader{
  position: relative;
  z-index: 9999;
}

.siteHeader.is-fixed{
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  z-index: 9999;
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 40px rgba(0,0,0,.08);
}

/* desktop main */
.siteHeader__mainInner{
  min-height: 92px;
  display: grid;
  grid-template-columns: 220px minmax(420px, 1fr) auto;
  align-items: center;
  gap: 24px;
}

/* nav compacto */
.siteHeader__nav{
  background: rgba(255,255,255,.98);
  border-top: 1px solid rgba(0,0,0,.04);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.siteHeader__navInner{
  min-height: 68px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 26px;
  padding-top: 0;
  padding-bottom: 0;
}

/* evita que el nav se estire raro */
.siteHeader__menuWrap{
  min-width: 0;
  height: auto;
}

.siteHeader__menu{
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 30px;
  list-style: none;
  margin: 0;
  padding: 0;
  height: auto;
}

.siteHeader__menu li{
  margin: 0;
  padding: 0;
}

.siteHeader__menu a{
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  color: #171717;
  text-decoration: none;
  font-size: 15px;
  font-weight: 800;
  line-height: 1;
  transition: .18s ease;
}

.siteHeader__menu a:hover,
.siteHeader__menu .current-menu-item > a,
.siteHeader__menu .current_page_item > a{
  color: #3b8b65;
}

.siteHeader__navEnd{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  min-width: max-content;
}

.siteHeader__navEnd a{
  display: inline-flex;
  align-items: center;
  min-height: 20px;
  color: #171717;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  white-space: nowrap;
}

/* categorías */
.headerCats{
  position: relative;
  z-index: 20;
}

.headerCats__toggle{
  min-height: 46px;
  padding: 0 18px;
  border: 0;
  border-radius: 14px;
  background: #7d8a84;
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
  cursor: pointer;
  transition: .22s ease;
}

.headerCats__panel{
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  width: 290px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  box-shadow: 0 24px 50px rgba(0,0,0,.08);
  padding: 12px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: .22s ease;
  z-index: 100;
}

.headerCats.is-open .headerCats__panel{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* actions */
.siteHeader__actions{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  min-width: max-content;
}

/* desktop: ocultar lupa extra */
.siteHeader__mobileSearchBtn{
  display: none !important;
}

/* =========================
   MOBILE
========================= */
@media (max-width: 980px){
  .siteHeader__mainInner{
    grid-template-columns: 44px 1fr auto;
    min-height: 82px;
    gap: 14px;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .siteHeader__logo{
    justify-content: flex-start;
  }

  .siteHeader__logo img{
    max-height: 42px;
  }

  .siteHeader__logoText{
    font-size: 28px;
  }

  .siteHeader__searchWrap{
    display: none;
  }

  .siteHeader__account{
    display: none;
  }

  .siteHeader__mobileToggle{
    display: inline-flex;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(0,0,0,.08);
    background: #fff;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 4px;
    cursor: pointer;
  }

  .siteHeader__mobileToggle span{
    width: 16px;
    height: 2px;
    border-radius: 999px;
    background: #171717;
    display: block;
  }

  .siteHeader__mobileSearchBtn{
    display: inline-flex !important;
  }

  .siteHeader__navInner{
    grid-template-columns: 1fr;
    gap: 14px;
    align-items: stretch;
    min-height: auto;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .siteHeader__navEnd{
    justify-content: flex-start;
  }

  /* menú mobile panel */
  .siteHeader__menuWrap{
    display: none;
    width: 100%;
    padding-top: 6px;
  }

  .siteHeader__menuWrap.is-open{
    display: block;
  }

  .siteHeader__menu{
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    width: 100%;
    background: #fff;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 18px 38px rgba(0,0,0,.05);
  }

  .siteHeader__menu li{
    width: 100%;
    border-bottom: 1px solid rgba(0,0,0,.06);
  }

  .siteHeader__menu li:last-child{
    border-bottom: 0;
  }

  .siteHeader__menu a{
    width: 100%;
    min-height: 54px;
    padding: 0 16px;
    font-size: 16px;
    font-weight: 800;
  }

  .headerCats{
    width: 100%;
  }

  .headerCats__toggle{
    width: 100%;
    justify-content: space-between;
  }

  .headerCats__panel{
    width: 100%;
    left: 0;
  }

  .siteHeader__navEnd{
    width: 100%;
    padding-top: 4px;
  }

  .siteHeader__navEnd a{
    font-size: 15px;
  }
}

@media (max-width: 780px){
  .siteHeader__topInner{
    min-height: auto;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .siteHeader__topLinks{
    gap: 12px;
    flex-wrap: wrap;
  }

  .siteHeader__topLinks a{
    font-size: 12px;
  }

  .siteHeader__promo{
    font-size: 11px;
  }
}

/* =========================================================
   HEADER MOBILE PREMIUM
========================================================= */

@media (max-width: 980px){

  /* header general */
  .siteHeader__top{
    position: relative;
    z-index: 20;
  }

  .siteHeader__topInner{
    padding: 10px 0 9px;
    gap: 8px;
  }

  .siteHeader__promo{
    font-size: 10px;
    line-height: 1.25;
    letter-spacing: .04em;
    opacity: .96;
  }

  .siteHeader__topLinks{
    gap: 10px;
  }

  .siteHeader__topLinks a{
    font-size: 11px;
    line-height: 1;
    opacity: .92;
  }

  /* bloque principal */
  .siteHeader__main{
    position: relative;
    z-index: 19;
  }

  .siteHeader__mainInner{
    min-height: 84px;
    grid-template-columns: 48px 1fr auto;
    gap: 14px;
    padding-top: 16px;
    padding-bottom: 16px;
  }

  /* botón hamburguesa */
  .siteHeader__mobileToggle{
    width: 48px;
    height: 48px;
    border-radius: 999px;
    border: 1px solid rgba(0,0,0,.08);
    background: #fff;
    box-shadow: 0 10px 22px rgba(0,0,0,.04);
    transition: .22s ease;
  }

  .siteHeader__mobileToggle:hover{
    transform: translateY(-1px);
    box-shadow: 0 16px 30px rgba(0,0,0,.06);
  }

  .siteHeader__mobileToggle span{
    width: 16px;
    height: 2px;
    background: #171717;
    border-radius: 999px;
    transition: .2s ease;
  }

  /* logo */
  .siteHeader__logo{
    min-width: 0;
    display: inline-flex;
    align-items: center;
  }

  .siteHeader__logo img{
    max-height: 40px;
    width: auto;
  }

  .siteHeader__logoText{
    font-size: 30px;
    font-weight: 900;
    letter-spacing: -.04em;
  }

  /* acciones */
  .siteHeader__actions{
    gap: 10px;
  }

  .siteHeader__iconBtn{
    width: 44px;
    height: 44px;
    box-shadow: 0 10px 22px rgba(0,0,0,.03);
  }

  .siteHeader__iconBtn svg{
    width: 18px;
    height: 18px;
  }

  .siteHeader__cartCount{
    top: -3px;
    right: -1px;
  }

  /* barra nav mobile */
  .siteHeader__nav{
    position: relative;
    z-index: 18;
    background: rgba(255,255,255,.98);
  }

  .siteHeader__navInner{
    gap: 16px;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  /* botón categorías */
  .headerCats__toggle{
    min-height: 52px;
    border-radius: 16px;
    padding: 0 16px;
    background: #7d8a84;
    box-shadow: 0 14px 26px rgba(0,0,0,.06);
    font-size: 14px;
    letter-spacing: .03em;
  }

  .headerCats__toggle span{
    line-height: 1;
  }

  .headerCats__burger{
    gap: 3px;
  }

  .headerCats__burger span{
    width: 14px;
    height: 2px;
  }

  .headerCats__chev{
    margin-left: auto;
    font-size: 14px;
    opacity: .9;
  }

  /* panel categorías */
  .headerCats__panel{
    top: calc(100% + 10px);
    width: 100%;
    border-radius: 18px;
    padding: 10px;
    box-shadow: 0 22px 44px rgba(0,0,0,.10);
  }

  .headerCats__list li + li{
    margin-top: 4px;
  }

  .headerCats__list a{
    min-height: 48px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 700;
    padding: 0 14px;
  }

  /* menú mobile panel */
  .siteHeader__menuWrap{
    width: 100%;
    padding-top: 0;
  }

  .siteHeader__menuWrap.is-open{
    animation: fadeSlideDown .22s ease;
  }

  .siteHeader__menu{
    width: 100%;
    background: #fff;
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 20px 40px rgba(0,0,0,.06);
  }

  .siteHeader__menu li{
    width: 100%;
    border-bottom: 1px solid rgba(0,0,0,.06);
  }

  .siteHeader__menu li:last-child{
    border-bottom: 0;
  }

  .siteHeader__menu a{
    width: 100%;
    min-height: 54px;
    padding: 0 16px;
    font-size: 16px;
    font-weight: 800;
    display: flex;
    align-items: center;
  }

  .siteHeader__menu .current-menu-item > a,
  .siteHeader__menu .current_page_item > a{
    color: #3b8b65;
    background: rgba(59,139,101,.06);
  }

  /* link final */
  .siteHeader__navEnd{
    padding-top: 2px;
  }

  .siteHeader__navEnd a{
    display: inline-flex;
    align-items: center;
    min-height: 20px;
    font-size: 15px;
    font-weight: 800;
  }

  /* search modal mobile */
  .mobileSearch{
    padding: 14px;
  }

  .mobileSearch__inner{
    border-radius: 22px;
    padding: 14px;
    box-shadow: 0 24px 60px rgba(0,0,0,.14);
  }

  .mobileSearch__close{
    width: 42px;
    height: 42px;
    border-radius: 999px;
    margin-bottom: 12px;
  }

  .mobileSearch .searchFormPremium__inner{
    grid-template-columns: 1fr !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  .mobileSearch .searchFormPremium__field{
    height: 52px !important;
    padding: 0 16px !important;
    font-size: 15px !important;
  }

  .mobileSearch .searchFormPremium__selectWrap{
    border-left: 0;
    border-top: 1px solid rgba(0,0,0,.08);
  }

  .mobileSearch .searchFormPremium__select{
    height: 52px;
    padding-left: 16px;
  }

  .mobileSearch .searchFormPremium__submit{
    height: 52px !important;
    border-left: 0 !important;
    border-top: 1px solid rgba(0,0,0,.08) !important;
    width: 100%;
    border-radius: 0 !important;
  }
}

@media (max-width: 640px){
  .siteHeader__topInner{
    padding-top: 8px;
    padding-bottom: 8px;
  }

  .siteHeader__promo{
    font-size: 9px;
  }

  .siteHeader__topLinks{
    gap: 8px;
  }

  .siteHeader__topLinks a{
    font-size: 10px;
  }

  .siteHeader__mainInner{
    min-height: 78px;
    grid-template-columns: 46px 1fr auto;
    gap: 12px;
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .siteHeader__logo img{
    max-height: 34px;
  }

  .siteHeader__logoText{
    font-size: 26px;
  }

  .siteHeader__actions{
    gap: 8px;
  }

  .siteHeader__iconBtn{
    width: 42px;
    height: 42px;
  }

  .headerCats__toggle{
    min-height: 50px;
    padding: 0 14px;
    font-size: 13px;
  }

  .siteHeader__menu a{
    min-height: 52px;
    padding: 0 14px;
    font-size: 15px;
  }

  .siteHeader__navEnd a{
    font-size: 14px;
  }
}

/* animación suave */
@keyframes fadeSlideDown{
  from{
    opacity: 0;
    transform: translateY(-8px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

/* =========================================================
   MOBILE NAV DRAWER PREMIUM
========================================================= */

.mobileNavOverlay{
  position: fixed;
  inset: 0;
  background: rgba(15,20,18,.34);
  opacity: 0;
  transition: opacity .24s ease;
  z-index: 10040;
  pointer-events: none;
}

.mobileNavOverlay.is-visible{
  opacity: 1;
  pointer-events: auto;
}

.mobileNavDrawer{
  position: fixed;
  top: 0;
  left: 0;
  width: min(390px, 90vw);
  height: 100vh;
  background: #fff;
  box-shadow: 24px 0 50px rgba(0,0,0,.12);
  transform: translateX(-100%);
  transition: transform .26s ease;
  z-index: 10041;
  display: flex;
  flex-direction: column;
}

.mobileNavDrawer.is-open{
  transform: translateX(0);
}

.mobileNavDrawer__head{
  min-height: 78px;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.mobileNavDrawer__brand{
  display: inline-flex;
  align-items: center;
}

.mobileNavDrawer__brand img{
  max-height: 34px;
  width: auto;
  display: block;
}

.mobileNavDrawer__brandText{
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #111;
}

.mobileNavDrawer__close{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  cursor: pointer;
  font-size: 20px;
}

.mobileNavDrawer__body{
  flex: 1;
  overflow: auto;
  padding: 16px;
}

.mobileNavDrawer__search{
  margin-bottom: 18px;
}

.mobileNavDrawer__search .searchFormPremium__inner{
  grid-template-columns: 1fr !important;
  border-radius: 18px !important;
}

.mobileNavDrawer__search .searchFormPremium__field{
  height: 52px !important;
  padding: 0 16px !important;
}

.mobileNavDrawer__search .searchFormPremium__selectWrap{
  border-left: 0;
  border-top: 1px solid rgba(0,0,0,.08);
}

.mobileNavDrawer__search .searchFormPremium__select{
  height: 52px;
  padding-left: 16px;
}

.mobileNavDrawer__search .searchFormPremium__submit{
  height: 52px !important;
  border-left: 0 !important;
  border-top: 1px solid rgba(0,0,0,.08) !important;
  width: 100%;
}

.mobileNavDrawer__section{
  margin-bottom: 18px;
}

.mobileNavDrawer__catsToggle{
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border: 0;
  border-radius: 16px;
  background: #7d8a84;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
  cursor: pointer;
  box-shadow: 0 12px 24px rgba(0,0,0,.06);
}

.mobileNavDrawer__catsPanel{
  display: none;
  padding-top: 10px;
}

.mobileNavDrawer__catsPanel.is-open{
  display: block;
}

.mobileNavDrawer__catsList{
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.04);
}

.mobileNavDrawer__catsList li + li{
  border-top: 1px solid rgba(0,0,0,.06);
}

.mobileNavDrawer__catsList a{
  min-height: 50px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #171717;
  font-size: 14px;
  font-weight: 700;
}

.mobileNavDrawer__catsList a:hover{
  background: #f6f8f7;
}

.mobileNavDrawer__menu{
  margin-bottom: 18px;
}

.mobileNavDrawer__menuList{
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 14px 28px rgba(0,0,0,.04);
}

.mobileNavDrawer__menuList li + li{
  border-top: 1px solid rgba(0,0,0,.06);
}

.mobileNavDrawer__menuList a{
  min-height: 54px;
  padding: 0 16px;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #171717;
  font-size: 16px;
  font-weight: 800;
}

.mobileNavDrawer__menuList .current-menu-item > a,
.mobileNavDrawer__menuList .current_page_item > a{
  color: #3b8b65;
  background: rgba(59,139,101,.06);
}

.mobileNavDrawer__links{
  display: grid;
  gap: 10px;
}

.mobileNavDrawer__links a{
  min-height: 50px;
  padding: 0 16px;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 14px;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #171717;
  font-size: 14px;
  font-weight: 800;
  background: #fff;
}

.mobileNavDrawer__links a:hover{
  background: #f8f9f8;
}

/* ocultar nav mobile vieja */
@media (max-width: 980px){
  .siteHeader__nav .siteHeader__menuWrap,
  .siteHeader__nav .siteHeader__navEnd{
    display: none !important;
  }
}

/* =========================================================
   MOBILE DRAWER PREMIUM PLUS
========================================================= */

.mobileNavOverlay{
  position: fixed;
  inset: 0;
  background: rgba(15,20,18,.28);
  backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity .28s ease;
  z-index: 10040;
  pointer-events: none;
}

.mobileNavOverlay.is-visible{
  opacity: 1;
  pointer-events: auto;
}

.mobileNavDrawer{
  position: fixed;
  top: 0;
  left: 0;
  width: min(390px, 92vw);
  height: 100vh;
  background:
    linear-gradient(180deg, rgba(125,138,132,.06) 0%, rgba(255,255,255,0) 22%),
    #fff;
  box-shadow: 24px 0 60px rgba(0,0,0,.14);
  transform: translateX(-100%);
  transition: transform .30s cubic-bezier(.2,.8,.2,1);
  z-index: 10041;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.mobileNavDrawer.is-open{
  transform: translateX(0);
}

.mobileNavDrawer__head{
  min-height: 82px;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid rgba(0,0,0,.06);
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
}

.mobileNavDrawer__brand{
  display: inline-flex;
  align-items: center;
}

.mobileNavDrawer__brand img{
  max-height: 34px;
  width: auto;
  display: block;
}

.mobileNavDrawer__brandText{
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #111;
}

.mobileNavDrawer__close{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  cursor: pointer;
  font-size: 20px;
  transition: .2s ease;
}

.mobileNavDrawer__close:hover{
  transform: rotate(90deg);
}

.mobileNavDrawer__body{
  flex: 1;
  overflow: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* buscador */
.mobileNavDrawer__search .searchFormPremium__inner{
  grid-template-columns: 1fr !important;
  border-radius: 18px !important;
  box-shadow: 0 16px 34px rgba(0,0,0,.05) !important;
}

.mobileNavDrawer__search .searchFormPremium__field{
  height: 52px !important;
  padding: 0 16px !important;
}

.mobileNavDrawer__search .searchFormPremium__selectWrap{
  border-left: 0;
  border-top: 1px solid rgba(0,0,0,.08);
}

.mobileNavDrawer__search .searchFormPremium__select{
  height: 52px;
  padding-left: 16px;
}

.mobileNavDrawer__search .searchFormPremium__submit{
  height: 52px !important;
  border-left: 0 !important;
  border-top: 1px solid rgba(0,0,0,.08) !important;
  width: 100%;
}

/* botón categorías */
.mobileNavDrawer__section{
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mobileNavDrawer__catsToggle{
  width: 100%;
  min-height: 54px;
  padding: 0 16px;
  border: 0;
  border-radius: 16px;
  background: #7d8a84;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
  cursor: pointer;
  box-shadow: 0 16px 30px rgba(0,0,0,.06);
  transition: .22s ease;
}

.mobileNavDrawer__catsToggle:hover{
  background: #6f7d77;
}

.mobileNavDrawer__catsLabel{
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.mobileNavDrawer__catsIcon{
  font-size: 17px;
  line-height: 1;
}

.mobileNavDrawer__catsArrow{
  font-size: 14px;
  line-height: 1;
  transition: transform .2s ease;
}

.mobileNavDrawer__catsToggle[aria-expanded="true"] .mobileNavDrawer__catsArrow{
  transform: rotate(180deg);
}

.mobileNavDrawer__catsPanel{
  display: none;
}

.mobileNavDrawer__catsPanel.is-open{
  display: block;
  animation: fadeSlideDown .22s ease;
}

.mobileNavDrawer__catsList{
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 16px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.04);
}

.mobileNavDrawer__catsList li + li{
  border-top: 1px solid rgba(0,0,0,.06);
}

.mobileNavDrawer__catsList a{
  min-height: 50px;
  padding: 0 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #171717;
  font-size: 14px;
  font-weight: 700;
}

.mobileNavDrawer__catsList a:hover{
  background: #f6f8f7;
}

.mobileNavDrawer__itemDot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #3b8b65;
  display: inline-block;
}

/* menú */
.mobileNavDrawer__menuList{
  list-style: none;
  margin: 0;
  padding: 0;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 14px 28px rgba(0,0,0,.04);
}

.mobileNavDrawer__menuList li + li{
  border-top: 1px solid rgba(0,0,0,.06);
}

.mobileNavDrawer__menuList a{
  min-height: 56px;
  padding: 0 16px;
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #171717;
  font-size: 16px;
  font-weight: 800;
  position: relative;
}

.mobileNavDrawer__menuList a::before{
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(59,139,101,.18);
  margin-right: 12px;
  flex: 0 0 auto;
}

.mobileNavDrawer__menuList .current-menu-item > a,
.mobileNavDrawer__menuList .current_page_item > a{
  color: #3b8b65;
  background: rgba(59,139,101,.06);
}

.mobileNavDrawer__menuText{
  display: inline-flex;
  align-items: center;
}

/* links extra */
.mobileNavDrawer__links{
  display: grid;
  gap: 10px;
}

.mobileNavDrawer__links a{
  min-height: 50px;
  padding: 0 16px;
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #171717;
  font-size: 14px;
  font-weight: 800;
  background: #fff;
}

.mobileNavDrawer__links a:hover{
  background: #f8f9f8;
}

.mobileNavDrawer__linkIcon{
  width: 24px;
  display: inline-flex;
  justify-content: center;
  font-size: 15px;
}

/* redes */
.mobileNavDrawer__social{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}

.mobileNavDrawer__social a{
  min-height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.06);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #171717;
  font-size: 13px;
  font-weight: 800;
  transition: .18s ease;
}

.mobileNavDrawer__social a:hover{
  background: #f8f9f8;
  transform: translateY(-1px);
}

/* footer interno */
.mobileNavDrawer__footer{
  margin-top: auto;
  padding-top: 6px;
}

.mobileNavDrawer__footerText{
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(125,138,132,.08);
  color: #5f6b72;
  font-size: 13px;
  line-height: 1.55;
  font-weight: 600;
}

/* hamburguesa a X */
.siteHeader__mobileToggle{
  transition: .22s ease;
}

.siteHeader__mobileToggle.is-active .siteHeader__mobileToggleLine:nth-child(1){
  transform: translateY(6px) rotate(45deg);
}

.siteHeader__mobileToggle.is-active .siteHeader__mobileToggleLine:nth-child(2){
  opacity: 0;
}

.siteHeader__mobileToggle.is-active .siteHeader__mobileToggleLine:nth-child(3){
  transform: translateY(-6px) rotate(-45deg);
}

.siteHeader__mobileToggleLine{
  transition: transform .22s ease, opacity .18s ease;
}

/* ocultar nav vieja mobile */
@media (max-width: 980px){
  .siteHeader__nav .siteHeader__menuWrap,
  .siteHeader__nav .siteHeader__navEnd{
    display: none !important;
  }
}

@media (max-width: 480px){
  .mobileNavDrawer{
    width: 92vw;
  }

  .siteHeader__nav{
    display: none !important;
  }

  .mobileNavDrawer__body{
    padding: 14px;
  }

  .mobileNavDrawer__social{
    grid-template-columns: 1fr;
  }

  .mobileNavDrawer__menuList a{
    min-height: 54px;
    font-size: 15px;
  }
}

/* =========================================================
   HOME HERO PREMIUM
========================================================= */

.homeHero--premium{
  position: relative;
  margin: 0 0 56px;
}

.homeHero--premium .swiper{
  overflow: hidden;
}

.heroSlide--premium{
  position: relative;
  min-height: clamp(540px, 72vh, 760px);
  display: flex;
  align-items: stretch;
  overflow: hidden;
  background: #eef1ef;
}

.heroSlide--premium .heroSlide__media{
  position: absolute;
  inset: 0;
  z-index: 1;
}

.heroSlide--premium .heroSlide__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.heroSlide__overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(15,20,18,.54) 0%, rgba(15,20,18,.28) 36%, rgba(15,20,18,.10) 58%, rgba(15,20,18,.10) 100%),
    linear-gradient(180deg, rgba(15,20,18,.08) 0%, rgba(15,20,18,.16) 100%);
}

.heroSlide__container{
  position: relative;
  z-index: 3;
  width: 100%;
  display: flex;
  align-items: center;
}

.heroSlide__content{
  max-width: 620px;
  padding: 88px 0;
  color: #fff;
}

.heroSlide__eyebrow{
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-bottom: 18px;
}

.heroSlide__title{
  margin: 0;
  font-size: clamp(42px, 6vw, 78px);
  line-height: .96;
  font-weight: 900;
  letter-spacing: -.06em;
  max-width: 9ch;
}

.heroSlide__subtitle{
  margin: 22px 0 0;
  max-width: 560px;
  font-size: clamp(16px, 2vw, 20px);
  line-height: 1.65;
  color: rgba(255,255,255,.9);
}

.heroSlide__actions{
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 30px;
}

.heroSlide__btn{
  min-width: 164px;
  min-height: 54px;
  border-radius: 999px;
  padding: 0 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  box-shadow: 0 16px 30px rgba(0,0,0,.14);
}

.heroSlide__secondaryLink{
  color: #fff;
  text-decoration: none;
  font-size: 15px;
  font-weight: 800;
  padding-bottom: 2px;
  border-bottom: 1px solid rgba(255,255,255,.36);
  transition: .2s ease;
}

.heroSlide__secondaryLink:hover{
  border-color: #fff;
  opacity: .92;
}

.heroPremiumNav{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 28px;
  z-index: 4;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  pointer-events: none;
}

.heroPremiumNav .swiper-button-prev,
.heroPremiumNav .swiper-button-next{
  position: static;
  width: 48px;
  height: 48px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
  color: #fff;
  pointer-events: auto;
  transition: .2s ease;
}

.heroPremiumNav .swiper-button-prev:hover,
.heroPremiumNav .swiper-button-next:hover{
  background: rgba(255,255,255,.24);
  transform: translateY(-1px);
}

.heroPremiumNav .swiper-button-prev::after,
.heroPremiumNav .swiper-button-next::after{
  font-size: 16px;
  font-weight: 900;
}

.heroPremiumNav .swiper-pagination{
  position: static;
  width: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  pointer-events: auto;
}

.heroPremiumNav .swiper-pagination-bullet{
  width: 9px;
  height: 9px;
  margin: 0 !important;
  background: rgba(255,255,255,.42);
  opacity: 1;
}

.heroPremiumNav .swiper-pagination-bullet-active{
  background: #fff;
  transform: scale(1.12);
}

@media (max-width: 980px){
  .heroSlide--premium{
    min-height: 620px;
  }

  .heroSlide__overlay{
    background:
      linear-gradient(180deg, rgba(15,20,18,.20) 0%, rgba(15,20,18,.36) 42%, rgba(15,20,18,.62) 100%);
  }

  .heroSlide__content{
    max-width: 100%;
    padding: 64px 0 110px;
  }

  .heroSlide__title{
    max-width: 11ch;
  }

  .heroSlide__subtitle{
    max-width: 100%;
  }
}

@media (max-width: 640px){
  .homeHero--premium{
    margin-bottom: 40px;
  }

  .heroSlide--premium{
    min-height: 540px;
  }

  .heroSlide__content{
    padding: 46px 0 96px;
  }

  .heroSlide__eyebrow{
    min-height: 28px;
    font-size: 10px;
    margin-bottom: 14px;
  }

  .heroSlide__title{
    font-size: clamp(34px, 10vw, 52px);
    max-width: 10ch;
  }

  .heroSlide__subtitle{
    margin-top: 16px;
    font-size: 15px;
    line-height: 1.55;
  }

  .heroSlide__actions{
    margin-top: 22px;
    gap: 12px;
  }

  .heroSlide__btn{
    min-height: 50px;
    min-width: 150px;
  }

  .heroPremiumNav{
    bottom: 18px;
    gap: 12px;
  }

  .heroPremiumNav .swiper-button-prev,
  .heroPremiumNav .swiper-button-next{
    width: 42px;
    height: 42px;
  }
}

/* =========================================================
   HOME STRUCTURE PREMIUM
========================================================= */

.siteMain--home{
  overflow: hidden;
}

.homeSections{
  display: flex;
  flex-direction: column;
  gap: 56px;
  padding-bottom: 56px;
}

.pageDefault{
  padding-top: 48px;
  padding-bottom: 64px;
}

.pageArticle{
  max-width: 1120px;
  margin: 0 auto;
}

.pageArticle__header{
  margin-bottom: 28px;
}

.pageTitle{
  margin: 0;
  font-size: clamp(34px, 4vw, 54px);
  line-height: .98;
  font-weight: 900;
  letter-spacing: -.05em;
  color: #171717;
}

.pageArticle__content{
  color: #4e5961;
  font-size: 16px;
  line-height: 1.75;
}

.pageArticle__content > *:first-child{
  margin-top: 0;
}

.pageArticle__content > *:last-child{
  margin-bottom: 0;
}

@media (max-width: 980px){
  .homeSections{
    gap: 44px;
    padding-bottom: 44px;
  }

  .pageDefault{
    padding-top: 36px;
    padding-bottom: 52px;
  }
}

@media (max-width: 640px){
  .homeSections{
    gap: 36px;
    padding-bottom: 36px;
  }

  .pageDefault{
    padding-top: 28px;
    padding-bottom: 40px;
  }

  .pageTitle{
    font-size: clamp(28px, 9vw, 40px);
  }
}

/* =========================================================
   FRONT PAGE PREMIUM STRUCTURE
========================================================= */

.siteMain--home{
  overflow: hidden;
}

.homeSections{
  display: flex;
  flex-direction: column;
  gap: 56px;
  padding: 40px 0 64px;
  padding-top: 0px !important;
}

.homeSection{
  position: relative;
}

.homeSection .container{
  position: relative;
}

.homeSection--tabs{
  padding-top: 0;
}

.homeSection--featured,
.homeSection--promo,
.homeSection--intro,
.homeSection--banners{
  padding-top: 0;
}

@media (max-width: 980px){
  .homeSections{
    gap: 44px;
    padding: 32px 0 52px;
  }
}

@media (max-width: 640px){
  .homeSections{
    gap: 36px;
    padding: 24px 0 40px;
  }
}

.homeHero--empty{
  padding: 28px 0 0;
}

.homeHero__emptyCard{
  border: 1px solid rgba(0,0,0,.08);
  background: #fff8e8;
  color: #3a2f12;
  border-radius: 18px;
  padding: 18px 20px;
  font-size: 14px;
  line-height: 1.6;
}

/* =========================================================
   HERO PREMIUM FIX FINAL
========================================================= */

.homeTop__main .homeHero.homeHero--premium{
  width: 100%;
  max-width: 100%;
  margin: 0 0 28px;
  overflow: visible;
}

.homeTop__main .homeHero.homeHero--premium .js-hero-swiper,
.homeTop__main .homeHero.homeHero--premium .swiper{
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(0,0,0,.08);
  background: #dfe5e1;
  position: relative;
}

.homeTop__main .homeHero.homeHero--premium .swiper-wrapper{
  height: auto !important;
}

.homeTop__main .homeHero.homeHero--premium .swiper-slide{
  height: auto !important;
  min-height: 0 !important;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide,
.homeTop__main .homeHero.homeHero--premium .heroSlide--premium{
  position: relative;
  min-height: clamp(520px, 68vh, 760px) !important;
  height: clamp(520px, 68vh, 760px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  overflow: hidden;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide__media{
  position: absolute !important;
  inset: 0 !important;
  z-index: 1;
  display: block;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide__media picture,
.homeTop__main .homeHero.homeHero--premium .heroSlide__media img{
  width: 100%;
  height: 100% !important;
  display: block;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide__media img{
  object-fit: cover;
  object-position: center center;
  max-width: none;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide__overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(90deg, rgba(15,19,18,.62) 0%, rgba(15,19,18,.34) 42%, rgba(15,19,18,.12) 100%);
}

.homeTop__main .homeHero.homeHero--premium .heroSlide__container{
  position: relative;
  z-index: 3;
  height: 100%;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide__content{
  position: relative;
  z-index: 3;
  min-height: clamp(520px, 68vh, 760px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 56px 56px 72px;
  color: #fff;
  text-align: left;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide.is-align-center .heroSlide__content{
  align-items: center;
  text-align: center;
}

.homeTop__main .homeHero.homeHero--premium .heroSlide.is-align-right .heroSlide__content{
  align-items: flex-end;
  text-align: right;
}

.homeTop__main .homeHero.homeHero--premium .heroPremiumNav{
  position: absolute;
  left: 32px;
  right: 32px;
  bottom: 22px;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  pointer-events: none;
}

.homeTop__main .homeHero.homeHero--premium .heroPremiumNav__prev,
.homeTop__main .homeHero.homeHero--premium .heroPremiumNav__next,
.homeTop__main .homeHero.homeHero--premium .swiper-button-prev,
.homeTop__main .homeHero.homeHero--premium .swiper-button-next{
  pointer-events: auto;
}

.homeTop__main .homeHero.homeHero--premium .swiper-button-prev,
.homeTop__main .homeHero.homeHero--premium .swiper-button-next{
  position: static;
  width: 44px;
  height: 44px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  color: #fff;
}

.homeTop__main .homeHero.homeHero--premium .swiper-button-prev::after,
.homeTop__main .homeHero.homeHero--premium .swiper-button-next::after{
  font-size: 16px;
  font-weight: 900;
}

.homeTop__main .homeHero.homeHero--premium .heroPremiumNav__pagination,
.homeTop__main .homeHero.homeHero--premium .swiper-pagination{
  position: static;
  width: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  pointer-events: auto;
}

.homeTop__main .homeHero.homeHero--premium .swiper-pagination-bullet{
  width: 10px;
  height: 10px;
  margin: 0 !important;
  background: rgba(255,255,255,.42);
  opacity: 1;
}

.homeTop__main .homeHero.homeHero--premium .swiper-pagination-bullet-active{
  background: #fff;
}

@media (max-width: 980px){
  .homeTop__main .homeHero.homeHero--premium .heroSlide,
  .homeTop__main .homeHero.homeHero--premium .heroSlide--premium{
    min-height: 420px !important;
    height: 420px !important;
  }

  .homeTop__main .homeHero.homeHero--premium .heroSlide__content{
    min-height: 420px;
    padding: 34px 28px 68px;
  }
}

@media (max-width: 640px){
  .homeTop__main .homeHero.homeHero--premium .heroSlide,
  .homeTop__main .homeHero.homeHero--premium .heroSlide--premium{
    min-height: 360px !important;
    height: 360px !important;
  }

  .homeTop__main .homeHero.homeHero--premium .heroSlide__content{
    min-height: 360px;
    padding: 24px 20px 62px;
  }

  .homeTop__main .homeHero.homeHero--premium .heroPremiumNav{
    left: 18px;
    right: 18px;
    bottom: 14px;
  }

  .homeTop__main .homeHero.homeHero--premium .swiper-button-prev,
  .homeTop__main .homeHero.homeHero--premium .swiper-button-next{
    width: 38px;
    height: 38px;
  }
}

/* =========================================================
   HERO PREMIUM FIX FINAL - HOME ACTUAL
========================================================= */

.siteMain--home .homeHero.homeHero--premium{
  width: min(calc(100% - (var(--pad) * 2)), var(--container));
  max-width: var(--container);
  margin: 0 auto 28px;
  overflow: visible;
}

.siteMain--home .homeHero.homeHero--premium .js-hero-swiper,
.siteMain--home .homeHero.homeHero--premium .swiper{
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(0,0,0,.08);
  background: #dfe5e1;
  position: relative;
}

.siteMain--home .homeHero.homeHero--premium .swiper-wrapper{
  height: auto !important;
}

.siteMain--home .homeHero.homeHero--premium .swiper-slide{
  height: auto !important;
  min-height: 0 !important;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide,
.siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
  position: relative;
  min-height: clamp(520px, 68vh, 760px) !important;
  height: clamp(520px, 68vh, 760px) !important;
  border: 0 !important;
  border-radius: 0 !important;
  overflow: hidden;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__media{
  position: absolute !important;
  inset: 0 !important;
  z-index: 1;
  display: block;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__media picture,
.siteMain--home .homeHero.homeHero--premium .heroSlide__media img{
  width: 100%;
  height: 100% !important;
  display: block;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__media img{
  object-fit: cover;
  object-position: center center;
  max-width: none;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__overlay{
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(90deg, rgba(15,19,18,.62) 0%, rgba(15,19,18,.34) 42%, rgba(15,19,18,.12) 100%);
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__container{
  position: relative;
  z-index: 3;
  height: 100%;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__content{
  position: relative;
  z-index: 3;
  min-height: clamp(520px, 68vh, 760px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 56px 56px 72px;
  color: #fff;
  text-align: left;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide.is-align-center .heroSlide__content{
  align-items: center;
  text-align: center;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide.is-align-right .heroSlide__content{
  align-items: flex-end;
  text-align: right;
}

.siteMain--home .homeHero.homeHero--premium .heroPremiumNav{
  position: absolute;
  left: 32px;
  right: 32px;
  bottom: 22px;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: space-between;
  pointer-events: none;
}

.siteMain--home .homeHero.homeHero--premium .heroPremiumNav__prev,
.siteMain--home .homeHero.homeHero--premium .heroPremiumNav__next,
.siteMain--home .homeHero.homeHero--premium .swiper-button-prev,
.siteMain--home .homeHero.homeHero--premium .swiper-button-next{
  pointer-events: auto;
}

.siteMain--home .homeHero.homeHero--premium .swiper-button-prev,
.siteMain--home .homeHero.homeHero--premium .swiper-button-next{
  position: static;
  width: 44px;
  height: 44px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  color: #fff;
}

.siteMain--home .homeHero.homeHero--premium .swiper-button-prev::after,
.siteMain--home .homeHero.homeHero--premium .swiper-button-next::after{
  font-size: 16px;
  font-weight: 900;
}

.siteMain--home .homeHero.homeHero--premium .heroPremiumNav__pagination,
.siteMain--home .homeHero.homeHero--premium .swiper-pagination{
  position: static;
  width: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  pointer-events: auto;
}

.siteMain--home .homeHero.homeHero--premium .swiper-pagination-bullet{
  width: 10px;
  height: 10px;
  margin: 0 !important;
  background: rgba(255,255,255,.42);
  opacity: 1;
}

.siteMain--home .homeHero.homeHero--premium .swiper-pagination-bullet-active{
  background: #fff;
}

@media (max-width: 980px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    min-height: 420px !important;
    height: 420px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: 420px;
    padding: 34px 28px 68px;
  }
}

@media (max-width: 640px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    min-height: 360px !important;
    height: 360px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: 360px;
    padding: 24px 20px 62px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroPremiumNav{
    left: 18px;
    right: 18px;
    bottom: 14px;
  }

  .siteMain--home .homeHero.homeHero--premium .swiper-button-prev,
  .siteMain--home .homeHero.homeHero--premium .swiper-button-next{
    width: 38px;
    height: 38px;
  }
}

/* =========================================================
   HERO FULL WIDTH PREMIUM
========================================================= */

.siteMain--home .homeHero.homeHero--premium{
  width: 100vw;
  max-width: 100vw;

  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);

  margin-top: 0;
  margin-bottom: 32px;

  padding: 0;
}

/* contenedor interno */
.siteMain--home .homeHero.homeHero--premium .js-hero-swiper,
.siteMain--home .homeHero.homeHero--premium .swiper{
  width: 100%;
  border-radius: 0; /* 👈 clave para full width */
  border: none;
}

/* si querés mantener estética premium con leve padding */
.siteMain--home .homeHero.homeHero--premium .heroSlide__container{
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--pad);
  padding-right: var(--pad);
}

/* =========================================================
   HERO PREMIUM ENHANCEMENTS
========================================================= */

/* Base visual */
.siteMain--home .homeHero.homeHero--premium{
  position: relative;
  margin-bottom: 42px;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide,
.siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
  min-height: clamp(560px, 78vh, 820px) !important;
  height: clamp(560px, 78vh, 820px) !important;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__overlay{
  background:
    linear-gradient(90deg, rgba(12,16,15,.66) 0%, rgba(12,16,15,.42) 36%, rgba(12,16,15,.16) 62%, rgba(12,16,15,.08) 100%),
    linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.18) 100%);
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__content{
  max-width: 620px;
  padding-top: 72px;
  padding-bottom: 100px;
}

/* Eyebrow */
.siteMain--home .homeHero.homeHero--premium .heroSlide__eyebrow{
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 32px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.16);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 18px;
}

/* Title */
.siteMain--home .homeHero.homeHero--premium .heroSlide__title{
  margin: 0 0 14px;
  font-size: clamp(46px, 6vw, 92px);
  line-height: .92;
  font-weight: 900;
  letter-spacing: -.055em;
  color: #fff;
  text-wrap: balance;
}

/* Subtitle */
.siteMain--home .homeHero.homeHero--premium .heroSlide__subtitle{
  margin: 0 0 26px;
  font-size: 17px;
  line-height: 1.8;
  color: rgba(255,255,255,.88);
  max-width: 560px;
}

/* Actions */
.siteMain--home .homeHero.homeHero--premium .heroSlide__actions{
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* CTA principal */
.siteMain--home .homeHero.homeHero--premium .heroSlide__btn,
.siteMain--home .homeHero.homeHero--premium .btn.heroSlide__btn{
  min-height: 54px;
  padding: 0 26px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  border: 1px solid rgba(0,0,0,.08);
  font-size: 14px;
  font-weight: 800;
  letter-spacing: .02em;
  box-shadow: 0 16px 34px rgba(0,0,0,.18);
  transition: transform .22s ease, background .22s ease, box-shadow .22s ease;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__btn:hover{
  background: #2f7f5f;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(0,0,0,.24);
}

/* Link secundario */
.siteMain--home .homeHero.homeHero--premium .heroSlide__secondaryLink{
  display: inline-flex;
  align-items: center;
  min-height: 54px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__secondaryLink:hover{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.24);
  color: #fff;
  transform: translateY(-2px);
}

/* Imagen con leve zoom */
.siteMain--home .homeHero.homeHero--premium .heroSlide__media{
  overflow: hidden;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__media img{
  transform: scale(1.02);
  transition: transform 6s ease;
  will-change: transform;
}

/* Solo el slide activo tiene un movimiento sutil */
.siteMain--home .homeHero.homeHero--premium .swiper-slide-active .heroSlide__media img{
  transform: scale(1.08);
}

/* Animación de entrada del contenido */
.siteMain--home .homeHero.homeHero--premium .heroSlide__eyebrow,
.siteMain--home .homeHero.homeHero--premium .heroSlide__title,
.siteMain--home .homeHero.homeHero--premium .heroSlide__subtitle,
.siteMain--home .homeHero.homeHero--premium .heroSlide__actions{
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .65s ease, transform .65s ease;
}

.siteMain--home .homeHero.homeHero--premium .swiper-slide-active .heroSlide__eyebrow{
  opacity: 1;
  transform: translateY(0);
  transition-delay: .08s;
}

.siteMain--home .homeHero.homeHero--premium .swiper-slide-active .heroSlide__title{
  opacity: 1;
  transform: translateY(0);
  transition-delay: .16s;
}

.siteMain--home .homeHero.homeHero--premium .swiper-slide-active .heroSlide__subtitle{
  opacity: 1;
  transform: translateY(0);
  transition-delay: .24s;
}

.siteMain--home .homeHero.homeHero--premium .swiper-slide-active .heroSlide__actions{
  opacity: 1;
  transform: translateY(0);
  transition-delay: .32s;
}

/* Nav premium */
.siteMain--home .homeHero.homeHero--premium .heroPremiumNav{
  left: auto;
  right: auto;
  bottom: 28px;
  width: min(var(--container), calc(100% - (var(--pad) * 2)));
  margin: 0 auto;
  padding-left: var(--pad);
  padding-right: var(--pad);
}

.siteMain--home .homeHero.homeHero--premium .heroPremiumNav{
  display: grid;
  grid-template-columns: 52px 1fr 52px;
  gap: 16px;
  align-items: center;
}

.siteMain--home .homeHero.homeHero--premium .swiper-button-prev,
.siteMain--home .homeHero.homeHero--premium .swiper-button-next{
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
  transition: transform .22s ease, background .22s ease, border-color .22s ease;
}

.siteMain--home .homeHero.homeHero--premium .swiper-button-prev:hover,
.siteMain--home .homeHero.homeHero--premium .swiper-button-next:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.20);
  border-color: rgba(255,255,255,.24);
}

.siteMain--home .homeHero.homeHero--premium .swiper-pagination{
  justify-content: center;
}

.siteMain--home .homeHero.homeHero--premium .swiper-pagination-bullet{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.34);
  transition: width .22s ease, background .22s ease, opacity .22s ease;
}

.siteMain--home .homeHero.homeHero--premium .swiper-pagination-bullet-active{
  width: 28px;
  background: #fff;
}

/* Alineaciones */
.siteMain--home .homeHero.homeHero--premium .heroSlide.is-align-center .heroSlide__content{
  margin-inline: auto;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide.is-align-right .heroSlide__content{
  margin-left: auto;
}

/* Mobile */
@media (max-width: 980px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    min-height: 480px !important;
    height: 480px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    max-width: 100%;
    padding-top: 38px;
    padding-bottom: 88px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__title{
    font-size: clamp(36px, 7vw, 58px);
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__subtitle{
    font-size: 15px;
    line-height: 1.7;
    max-width: 100%;
  }
}

@media (max-width: 640px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    min-height: 420px !important;
    height: 420px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    padding: 26px 20px 76px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__eyebrow{
    margin-bottom: 14px;
    min-height: 28px;
    padding: 0 12px;
    font-size: 10px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__title{
    font-size: 36px;
    line-height: .96;
    margin-bottom: 10px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__subtitle{
    font-size: 14px;
    margin-bottom: 18px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__actions{
    gap: 10px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__btn,
  .siteMain--home .homeHero.homeHero--premium .heroSlide__secondaryLink{
    min-height: 46px;
    padding: 0 16px;
    font-size: 13px;
  }

  .siteMain--home .homeHero.homeHero--premium .heroPremiumNav{
    grid-template-columns: 42px 1fr 42px;
    gap: 10px;
    bottom: 16px;
  }

  .siteMain--home .homeHero.homeHero--premium .swiper-button-prev,
  .siteMain--home .homeHero.homeHero--premium .swiper-button-next{
    width: 42px;
    height: 42px;
  }

  .siteMain--home .homeHero.homeHero--premium .swiper-pagination-bullet-active{
    width: 22px;
  }
}

/* =========================================================
   HERO PREMIUM - ALTURA ADAPTATIVA
========================================================= */

.siteMain--home .homeHero.homeHero--premium .heroSlide,
.siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
  min-height: auto !important;
  height: min(72vh, 660px) !important;
}

.siteMain--home .homeHero.homeHero--premium .heroSlide__content{
  min-height: min(78vh, 720px) !important;
  padding-top: 48px;
  padding-bottom: 84px;
}

/* notebooks y pantallas medianas */
@media (max-width: 1440px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    height: min(72vh, 640px) !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: min(72vh, 640px) !important;
    padding-top: 42px;
    padding-bottom: 76px;
  }
}

/* laptop común */
@media (max-width: 1280px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    height: min(68vh, 580px) !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: min(68vh, 580px) !important;
    padding-top: 36px;
    padding-bottom: 70px;
  }
}

/* tablet / desktop chico */
@media (max-width: 980px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    height: 520px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: 520px !important;
    padding-top: 34px;
    padding-bottom: 74px;
  }
}

/* mobile */
@media (max-width: 640px){
  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    height: 420px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: 420px !important;
    padding-top: 26px;
    padding-bottom: 72px;
  }
}

/* =========================================================
   HOME INTRO PREMIUM
========================================================= */

.homeIntro--premium{
  padding: 80px 0;
}

.homeIntro__grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 56px;
  align-items: center;
}

.homeIntro__content{
  max-width: 520px;
}

.homeIntro__eyebrow{
  display: inline-block;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
  margin-bottom: 14px;
}

.homeIntro__title{
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.04em;
  margin: 0 0 16px;
}

.homeIntro__text{
  font-size: 15px;
  line-height: 1.8;
  color: #555;
  margin-bottom: 26px;
}

.homeIntro__actions{
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}

/* botón */
.homeIntro__btn{
  min-height: 50px;
  padding: 0 22px;
  border-radius: 999px;
  font-weight: 800;
}

/* link */
.homeIntro__link{
  font-size: 14px;
  font-weight: 700;
  color: #2f7f5f;
  text-decoration: none;
  transition: opacity .2s ease;
}

.homeIntro__link:hover{
  opacity: .7;
}

/* imagen */
.homeIntro__media{
  position: relative;
}

.homeIntro__media img{
  width: 100%;
  height: auto;
  border-radius: 24px;
  display: block;
}

/* mobile */
@media (max-width: 980px){
  .homeIntro__grid{
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .homeIntro__content{
    max-width: 100%;
  }
}

/* =========================================================
   INTRO PREMIUM PRO
========================================================= */

.homeIntro--bg{
  padding: 90px 0;
  background: linear-gradient(135deg, #f6f7f6 0%, #eef2ef 100%);
}

.homeIntro__grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 60px;
  align-items: center;
}

.homeIntro__content{
  max-width: 520px;
}

.homeIntro__title{
  font-size: clamp(38px, 4vw, 58px);
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.04em;
  margin-bottom: 18px;
}

.homeIntro__text{
  font-size: 16px;
  line-height: 1.9;
  color: #555;
  margin-bottom: 28px;
}

.homeIntro__btn{
  background: #2f7f5f;
  color: #fff;
  border-radius: 999px;
  padding: 0 26px;
  height: 52px;
  font-weight: 800;
  box-shadow: 0 14px 28px rgba(0,0,0,.12);
}

.homeIntro__btn:hover{
  background: #25664c;
  transform: translateY(-2px);
}

/* =========================================================
   COLIBRÍ DECORATIVO PREMIUM
========================================================= */

.homeIntro__media{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}

.homeIntro__media img{
  width: 100%;
  max-width: 420px;
  height: auto;
  display: block;

  /* efecto premium */
  filter: drop-shadow(0 30px 50px rgba(0,0,0,.18));

  /* leve animación */
  animation: kolFloat 6s ease-in-out infinite;
}

/* animación suave */
@keyframes kolFloat{
  0%   { transform: translateY(0px); }
  50%  { transform: translateY(-12px); }
  100% { transform: translateY(0px); }
}

.homeIntro__media::before{
  content: "";
  position: absolute;
  width: 260px;
  height: 260px;
  background: radial-gradient(circle, rgba(47,127,95,.18) 0%, rgba(47,127,95,0) 70%);
  filter: blur(30px);
  z-index: 0;
}

.homeIntro__media img{
  position: relative;
  z-index: 2;
}

/* =========================================================
   HOME FEATURED PREMIUM
========================================================= */

.homeFeatured--premium{
  padding: 84px 0 34px;
}

.homeFeatured__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 28px;
}

.homeFeatured__headText{
  max-width: 720px;
}

.homeFeatured__eyebrow{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
}

.homeFeatured__title{
  margin: 0;
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #171717;
}

.homeFeatured__subtitle{
  margin-top: 12px;
  max-width: 620px;
  color: #66707a;
  font-size: 15px;
  line-height: 1.8;
}

.homeFeatured__subtitle p{
  margin: 0;
}

.homeFeatured__headAction{
  flex-shrink: 0;
}

.homeFeatured__link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  color: #171717;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
  transition: all .22s ease;
}

.homeFeatured__link:hover{
  background: #111;
  color: #fff;
  border-color: #111;
  transform: translateY(-2px);
}

.homeFeatured__grid{
  gap: 24px;
}

.homeFeatured--premium .productsGrid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 24px;
}

@media (max-width: 1100px){
  .homeFeatured--premium .productsGrid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 780px){
  .homeFeatured--premium{
    padding: 64px 0 24px;
  }

  .homeFeatured__head{
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 22px;
  }

  .homeFeatured--premium .productsGrid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  .homeFeatured__title{
    font-size: 34px;
  }

  .homeFeatured__subtitle{
    font-size: 14px;
    line-height: 1.7;
  }
}

/* =========================================================
   PROMO BANNER PREMIUM
========================================================= */

.promoBanner--premium{
  padding: 88px 0;
}

.promoBanner--premium .js-promo-swiper,
.promoBanner--premium .swiper{
  overflow: hidden;
  border-radius: 34px;
  box-shadow: 0 24px 50px rgba(0,0,0,.08);
  position: relative;
}

.promoBanner__slide{
  position: relative;
  overflow: hidden;
}

.promoBanner__slide::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.14), transparent 35%),
    linear-gradient(90deg, rgba(255,255,255,.04), rgba(255,255,255,.00));
  pointer-events: none;
}

.promoBanner__inner{
  min-height: 520px;
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 42px;
  align-items: center;
  padding: 48px 42px 78px;
}

.promoBanner__media{
  display: flex;
  align-items: center;
  justify-content: center;
}

.promoBanner__media img{
  width: 100%;
  max-width: 420px;
  height: auto;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 26px 40px rgba(0,0,0,.16));
  transition: transform .4s ease;
}

.promoBanner__slide:hover .promoBanner__media img{
  transform: translateY(-4px) scale(1.02);
}

.promoBanner__content{
  max-width: 560px;
  color: #fff;
}

.promoBanner__eyebrow{
  display: inline-block;
  margin-bottom: 12px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.84);
}

.promoBanner__kicker{
  margin-bottom: 10px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255,255,255,.76);
}

.promoBanner__title{
  margin: 0 0 14px;
  font-size: clamp(38px, 5vw, 68px);
  line-height: .96;
  font-weight: 900;
  letter-spacing: -.05em;
  color: #fff;
}

.promoBanner__price{
  margin-bottom: 22px;
  font-size: 28px;
  line-height: 1.1;
  font-weight: 900;
  color: #fff;
}

.promoBanner__actions{
  display: flex;
  gap: 14px;
  align-items: center;
  flex-wrap: wrap;
}

.promoBanner__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  box-shadow: 0 14px 30px rgba(0,0,0,.16);
  transition: all .22s ease;
}

.promoBanner__btn:hover{
  transform: translateY(-2px);
  background: #fff;
  color: #111;
}

.promoBanner__secondary{
  display: inline-flex;
  align-items: center;
  min-height: 52px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 700;
  backdrop-filter: blur(8px);
  transition: all .22s ease;
}

.promoBanner__secondary:hover{
  background: rgba(255,255,255,.18);
  color: #fff;
  transform: translateY(-2px);
}

.promoBanner__nav{
  position: absolute;
  left: 0;
  right: 0;
  bottom: 22px;
  z-index: 5;
  display: grid;
  grid-template-columns: 48px 1fr 48px;
  gap: 16px;
  align-items: center;
  width: min(var(--container), calc(100% - 48px));
  margin: 0 auto;
  pointer-events: none;
}

.promoBanner__prev,
.promoBanner__next,
.promoBanner--premium .swiper-button-prev,
.promoBanner--premium .swiper-button-next{
  pointer-events: auto;
}

.promoBanner--premium .swiper-button-prev,
.promoBanner--premium .swiper-button-next{
  position: static;
  width: 48px;
  height: 48px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.16);
  color: #fff;
  backdrop-filter: blur(8px);
  transition: all .22s ease;
}

.promoBanner--premium .swiper-button-prev:hover,
.promoBanner--premium .swiper-button-next:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.20);
}

.promoBanner--premium .swiper-button-prev::after,
.promoBanner--premium .swiper-button-next::after{
  font-size: 16px;
  font-weight: 900;
}

.promoBanner__pagination,
.promoBanner--premium .swiper-pagination{
  position: static;
  display: flex;
  justify-content: center;
  gap: 8px;
  pointer-events: auto;
}

.promoBanner--premium .swiper-pagination-bullet{
  width: 10px;
  height: 10px;
  margin: 0 !important;
  background: rgba(255,255,255,.38);
  opacity: 1;
  transition: all .22s ease;
}

.promoBanner--premium .swiper-pagination-bullet-active{
  width: 28px;
  border-radius: 999px;
  background: #fff;
}

@media (max-width: 980px){
  .promoBanner--premium{
    padding: 68px 0;
  }

  .promoBanner__inner{
    min-height: 0;
    grid-template-columns: 1fr;
    text-align: center;
    padding: 36px 24px 76px;
  }

  .promoBanner__content{
    max-width: 100%;
  }

  .promoBanner__media img{
    max-width: 300px;
  }

  .promoBanner__actions{
    justify-content: center;
  }

  .promoBanner__title{
    font-size: 42px;
  }
}

@media (max-width: 640px){
  .promoBanner--premium .js-promo-swiper,
  .promoBanner--premium .swiper{
    border-radius: 24px;
  }

  .promoBanner__inner{
    padding: 28px 18px 70px;
  }

  .promoBanner__media img{
    max-width: 220px;
  }

  .promoBanner__title{
    font-size: 34px;
  }

  .promoBanner__price{
    font-size: 24px;
  }

  .promoBanner__btn,
  .promoBanner__secondary{
    min-height: 46px;
    padding: 0 16px;
    font-size: 13px;
  }

  .promoBanner__nav{
    grid-template-columns: 40px 1fr 40px;
    width: calc(100% - 24px);
    bottom: 14px;
  }

  .promoBanner--premium .swiper-button-prev,
  .promoBanner--premium .swiper-button-next{
    width: 40px;
    height: 40px;
  }
}

/* =========================================================
   PROMO BANNER FIX - ALTURA CONSISTENTE
========================================================= */

.promoBanner--premium .swiper-slide{
  height: auto !important;
}

.promoBanner--premium .promoBanner__slide{
  min-height: 0;
  height: 100%;
}

.promoBanner--premium .promoBanner__inner{
  min-height: 520px;
  grid-template-columns: 1fr 1fr;
  align-items: center;
}

.promoBanner--premium .promoBanner__media{
  min-height: 360px;
  height: 360px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.promoBanner--premium .promoBanner__media img{
  width: 100%;
  max-width: 360px;
  max-height: 360px;
  height: auto;
  object-fit: contain;
  object-position: center center;
  display: block;
}

/* Que el contenido no empuje diferente según texto */
.promoBanner--premium .promoBanner__content{
  min-height: 360px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 980px){
  .promoBanner--premium .promoBanner__inner{
    min-height: 0;
    grid-template-columns: 1fr;
  }

  .promoBanner--premium .promoBanner__media{
    min-height: 260px;
    height: 260px;
  }

  .promoBanner--premium .promoBanner__media img{
    max-width: 260px;
    max-height: 260px;
  }

  .promoBanner--premium .promoBanner__content{
    min-height: 0;
  }
}

@media (max-width: 640px){
  .promoBanner--premium .promoBanner__media{
    min-height: 220px;
    height: 220px;
  }

  .promoBanner--premium .promoBanner__media img{
    max-width: 220px;
    max-height: 220px;
  }
}

/* =========================================================
   HOME INTRO FIX - MOBILE
========================================================= */

@media (max-width: 640px){
  .homeIntro--bg{
    padding: 56px 0;
  }

  .homeIntro__grid{
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .homeIntro__content{
    max-width: 100%;
    order: 1;
  }

  .homeIntro__media{
    order: 2;
    justify-content: center;
  }

  .homeIntro__title{
    font-size: 34px;
    line-height: 1.02;
    margin-bottom: 14px;
  }

  .homeIntro__text{
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 20px;
  }

  .homeIntro__actions{
    gap: 10px;
  }

  .homeIntro__btn{
    min-height: 46px;
    padding: 0 18px;
    font-size: 13px;
  }

  .homeIntro__link{
    font-size: 13px;
  }

  .homeIntro__media img{
    max-width: 140px;
    width: 100%;
    animation: none;
  }

  .homeIntro__media::before{
    width: 120px;
    height: 120px;
    filter: blur(18px);
  }
}

/* =========================================================
   HOME BLOG PREVIEW PREMIUM
========================================================= */

.homeBlog--premium{
  padding: 92px 0;
}

.homeBlog__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 30px;
}

.homeBlog__headText{
  max-width: 760px;
}

.homeBlog__eyebrow{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
}

.homeBlog__title{
  margin: 0;
  font-size: clamp(32px, 4vw, 54px);
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #171717;
}

.homeBlog__subtitle{
  margin-top: 12px;
  max-width: 620px;
  color: #66707a;
  font-size: 15px;
  line-height: 1.8;
}

.homeBlog__subtitle p{
  margin: 0;
}

.homeBlog__link{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  color: #171717;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
  transition: all .22s ease;
}

.homeBlog__link:hover{
  background: #111;
  color: #fff;
  border-color: #111;
  transform: translateY(-2px);
}

.homeBlog__grid{
  display: grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: start;
}

.homeBlog__featured{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 16px 34px rgba(0,0,0,.04);
}

.homeBlog__featuredMedia{
  display: block;
  height: 420px;
  overflow: hidden;
  background: #f3f4f4;
}

.homeBlog__featuredMedia img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}

.homeBlog__featured:hover .homeBlog__featuredMedia img{
  transform: scale(1.03);
}

.homeBlog__featuredBody{
  padding: 26px 24px 24px;
}

.homeBlog__featuredCat,
.homeBlog__cardCat{
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: #edf5f0;
  color: #2f7f5f;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-decoration: none;
}

.homeBlog__featuredTitle{
  margin: 14px 0 12px;
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.04em;
}

.homeBlog__featuredTitle a,
.homeBlog__cardTitle a{
  color: #171717;
  text-decoration: none;
}

.homeBlog__featuredMeta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 14px;
  color: #7b848d;
  font-size: 13px;
}

.homeBlog__featuredExcerpt{
  color: #66707a;
  font-size: 15px;
  line-height: 1.8;
  margin-bottom: 18px;
}

.homeBlog__readMore,
.homeBlog__cardLink{
  color: #2f7f5f;
  text-decoration: none;
  font-size: 13px;
  font-weight: 800;
}

.homeBlog__list{
  display: grid;
  gap: 18px;
}

.homeBlog__card{
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 16px;
  align-items: center;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  padding: 14px;
  box-shadow: 0 12px 26px rgba(0,0,0,.03);
}

.homeBlog__cardMedia{
  display: block;
  width: 120px;
  height: 120px;
  overflow: hidden;
  border-radius: 18px;
  background: #f3f4f4;
}

.homeBlog__cardMedia img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.homeBlog__cardBody{
  min-width: 0;
}

.homeBlog__cardTitle{
  margin: 10px 0 8px;
  font-size: 22px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.03em;
}

.homeBlog__cardMeta{
  margin-bottom: 10px;
  color: #7b848d;
  font-size: 13px;
}

@media (max-width: 1100px){
  .homeBlog__grid{
    grid-template-columns: 1fr;
  }
}

@media (max-width: 780px){
  .homeBlog--premium{
    padding: 68px 0;
  }

  .homeBlog__head{
    flex-direction: column;
    align-items: flex-start;
  }

  .homeBlog__featuredMedia{
    height: 280px;
  }

  .homeBlog__featuredBody{
    padding: 20px 18px;
  }

  .homeBlog__featuredTitle{
    font-size: 30px;
  }

  .homeBlog__card{
    grid-template-columns: 88px 1fr;
    gap: 12px;
    padding: 12px;
  }

  .homeBlog__cardMedia{
    width: 88px;
    height: 88px;
    border-radius: 14px;
  }

  .homeBlog__cardTitle{
    font-size: 18px;
  }
}

/* =========================================================
   HOME BLOG - AJUSTE 3 POSTS
========================================================= */

.homeBlog__list{
  align-content: start;
}

.homeBlog__grid{
  align-items: start;
}

.homeBlog__card{
  min-height: 150px;
}

@media (min-width: 1101px){
  .homeBlog__featured{
    min-height: 100%;
  }
}

/* =========================================================
   HOME COMMUNITY / TIKTOK PREMIUM
========================================================= */

.homeCommunity--premium{
  padding: 88px 0;
}

.homeCommunity__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 28px;
}

.homeCommunity__headText{
  max-width: 760px;
}

.homeCommunity__eyebrow{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
}

.homeCommunity__title{
  margin: 0;
  font-size: clamp(32px, 4vw, 54px);
  line-height: 1.04;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #171717;
}

.homeCommunity__text{
  margin-top: 12px;
  max-width: 620px;
  color: #66707a;
  font-size: 15px;
  line-height: 1.8;
}

.homeCommunity__text p{
  margin: 0;
}

.homeCommunity__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  transition: all .22s ease;
}

.homeCommunity__btn:hover{
  background: #2f7f5f;
  color: #fff;
  transform: translateY(-2px);
}

.homeCommunity__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.homeCommunity__card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
  transition: transform .22s ease, box-shadow .22s ease;
}

.homeCommunity__card:hover{
  transform: translateY(-4px);
  box-shadow: 0 20px 38px rgba(0,0,0,.08);
}

.homeCommunity__cardLink{
  display: block;
  color: inherit;
  text-decoration: none;
}

.homeCommunity__media{
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: #f3f4f4;
}

.homeCommunity__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .35s ease;
}

.homeCommunity__card:hover .homeCommunity__media img{
  transform: scale(1.04);
}

.homeCommunity__caption{
  padding: 14px 14px 16px;
  font-size: 14px;
  line-height: 1.6;
  font-weight: 700;
  color: #171717;
}

@media (max-width: 1100px){
  .homeCommunity__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 780px){
  .homeCommunity--premium{
    padding: 68px 0;
  }

  .homeCommunity__head{
    flex-direction: column;
    align-items: flex-start;
  }

  .homeCommunity__grid{
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }

  .homeCommunity__caption{
    font-size: 13px;
    padding: 12px;
  }
}

/* =========================================================
   HOME COMMUNITY - PREMIUM REWORK
========================================================= */

.homeCommunity--premium{
  padding: 88px 0;
}

.homeCommunity__head{
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 30px;
}

.homeCommunity__headText{
  max-width: 760px;
}

.homeCommunity__eyebrow{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
}

.homeCommunity__title{
  margin: 0;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #171717;
}

.homeCommunity__text{
  margin-top: 12px;
  max-width: 620px;
  color: #66707a;
  font-size: 15px;
  line-height: 1.8;
}

.homeCommunity__text p{
  margin: 0;
}

.homeCommunity__btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 20px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 800;
  transition: all .22s ease;
  box-shadow: 0 12px 24px rgba(0,0,0,.08);
}

.homeCommunity__btn:hover{
  background: #2f7f5f;
  color: #fff;
  transform: translateY(-2px);
}

.homeCommunity__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.homeCommunity__card{
  background: linear-gradient(180deg, #ffffff 0%, #fafbfb 100%);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.homeCommunity__card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 42px rgba(0,0,0,.08);
  border-color: rgba(47,127,95,.16);
}

.homeCommunity__cardLink{
  display: block;
  color: inherit;
  text-decoration: none;
  height: 100%;
}

.homeCommunity__media{
  height: 210px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  background:
    radial-gradient(circle at top left, rgba(47,127,95,.10), transparent 36%),
    linear-gradient(180deg, #f6f8f7 0%, #eef2ef 100%);
}

.homeCommunity__media img{
  width: 100%;
  max-width: 120px;
  max-height: 120px;
  object-fit: contain;
  display: block;
  transition: transform .28s ease;
}

.homeCommunity__card:hover .homeCommunity__media img{
  transform: scale(1.06);
}

.homeCommunity__caption{
  padding: 18px 18px 22px;
}

.homeCommunity__caption strong{
  display: block;
  margin-bottom: 6px;
  font-size: 22px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.homeCommunity__caption span{
  display: block;
  color: #66707a;
  font-size: 14px;
  line-height: 1.65;
}

.homeCommunity__caption em{
  display: inline-flex;
  align-items: center;
  margin-top: 14px;
  font-style: normal;
  color: #2f7f5f;
  font-size: 13px;
  font-weight: 800;
}

@media (max-width: 1100px){
  .homeCommunity__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 780px){
  .homeCommunity--premium{
    padding: 68px 0;
  }

  .homeCommunity__head{
    flex-direction: column;
    align-items: flex-start;
  }

  .homeCommunity__grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .homeCommunity__media{
    height: 180px;
    padding: 22px;
  }

  .homeCommunity__media img{
    max-width: 96px;
    max-height: 96px;
  }

  .homeCommunity__caption{
    padding: 16px 16px 18px;
  }

  .homeCommunity__caption strong{
    font-size: 20px;
  }
}

/* =========================================================
   HOME COMMUNITY - PREMIUM FIX FINAL
========================================================= */

.homeCommunity__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.homeCommunity__card{
  background: linear-gradient(180deg, #ffffff 0%, #fafbfb 100%);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 28px;
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(0,0,0,.04);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.homeCommunity__card:hover{
  transform: translateY(-6px);
  box-shadow: 0 22px 42px rgba(0,0,0,.08);
  border-color: rgba(47,127,95,.16);
}

.homeCommunity__cardLink{
  display: block;
  color: inherit;
  text-decoration: none;
  height: 100%;
}

.homeCommunity__media{
  position: relative;
  height: 240px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  overflow: hidden;
}

/* badge superior */
.homeCommunity__badge{
  position: absolute;
  top: 16px;
  left: 16px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  backdrop-filter: blur(8px);
  color: #171717;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.homeCommunity__media img{
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 140px;
  max-height: 140px;
  object-fit: contain;
  display: block;
  transition: transform .28s ease;
  filter: drop-shadow(0 14px 24px rgba(0,0,0,.12));
}

.homeCommunity__card:hover .homeCommunity__media img{
  transform: scale(1.07);
}

.homeCommunity__caption{
  padding: 18px 18px 22px;
}

.homeCommunity__caption strong{
  display: block;
  margin-bottom: 8px;
  font-size: 24px;
  line-height: 1.06;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.homeCommunity__caption span{
  display: block;
  color: #66707a;
  font-size: 14px;
  line-height: 1.72;
}

.homeCommunity__caption em{
  display: inline-flex;
  align-items: center;
  margin-top: 16px;
  font-style: normal;
  color: #2f7f5f;
  font-size: 13px;
  font-weight: 800;
}

/* fondos por red */
.homeCommunity__card.is-tiktok .homeCommunity__media{
  background:
    radial-gradient(circle at 20% 20%, rgba(37,244,238,.18), transparent 32%),
    radial-gradient(circle at 80% 75%, rgba(254,44,85,.16), transparent 28%),
    linear-gradient(135deg, #0d0d0d 0%, #1b1b1b 100%);
}

.homeCommunity__card.is-tiktok .homeCommunity__badge{
  color: #111;
  background: rgba(255,255,255,.9);
}

.homeCommunity__card.is-facebook .homeCommunity__media{
  background:
    radial-gradient(circle at top left, rgba(255,255,255,.16), transparent 28%),
    linear-gradient(135deg, #1877f2 0%, #0f5ec9 100%);
}

.homeCommunity__card.is-instagram .homeCommunity__media{
  background:
    radial-gradient(circle at 20% 110%, rgba(252,175,69,.34), transparent 26%),
    radial-gradient(circle at 80% 10%, rgba(131,58,180,.28), transparent 24%),
    linear-gradient(135deg, #f58529 0%, #dd2a7b 40%, #8134af 70%, #515bd4 100%);
}

/* en fondos fuertes, badge más legible */
.homeCommunity__card.is-facebook .homeCommunity__badge,
.homeCommunity__card.is-instagram .homeCommunity__badge{
  background: rgba(255,255,255,.88);
}

@media (max-width: 1100px){
  .homeCommunity__grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 780px){
  .homeCommunity__grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .homeCommunity__media{
    height: 210px;
    padding: 22px;
  }

  .homeCommunity__media img{
    max-width: 120px;
    max-height: 120px;
  }

  .homeCommunity__caption strong{
    font-size: 22px;
  }
}

.homeSection,
.homeFeatured,
.homeBlog,
.homeCommunity,
.homeIntro,
.promoBanner {
  margin-top: 64px;
}

@media (max-width: 780px){
  .homeSection,
  .homeFeatured,
  .homeBlog,
  .homeCommunity,
  .homeIntro,
  .promoBanner {
    margin-top: 40px;
  }
}

.heroSlide__overlay{
  background: linear-gradient(
    90deg,
    rgba(0,0,0,.55) 0%,
    rgba(0,0,0,.35) 40%,
    rgba(0,0,0,.15) 70%,
    rgba(0,0,0,0) 100%
  );
}

.products .product{
  transition: transform .25s ease, box-shadow .25s ease;
}

.products .product:hover{
  transform: translateY(-6px);
  box-shadow: 0 16px 28px rgba(0,0,0,.08);
}

.homeBlog__list article{
  background: #fff;
  border-radius: 16px;
  padding: 12px;
  box-shadow: 0 6px 18px rgba(0,0,0,.04);
}

.homeIntro__media img{
  filter: drop-shadow(0 20px 40px rgba(0,0,0,.15));
}

.homeCommunity__media{
  display: flex;
  align-items: center;
  justify-content: center;
}

.homeCommunity__caption strong{
  font-size: 20px;
}

section{
  scroll-margin-top: 100px;
}

/* =========================================================
   HOME TESTIMONIALS PREMIUM
========================================================= */

.homeTestimonials--premium{
  position: relative;
  padding: 96px 0;
  background: linear-gradient(180deg, #f5f7f5 0%, #eef2ef 100%);
}

.homeTestimonials__head{
  max-width: 760px;
  margin-bottom: 34px;
}

.homeTestimonials__eyebrow{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
}

.homeTestimonials__title{
  margin: 0;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.03;
  font-weight: 900;
  letter-spacing: -.04em;
  color: #171717;
}

.homeTestimonials__subtitle{
  margin-top: 12px;
  max-width: 620px;
  color: #66707a;
  font-size: 15px;
  line-height: 1.8;
}

.homeTestimonials__subtitle p{
  margin: 0;
}

.homeTestimonials__grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.homeTestimonials__card{
  background: rgba(255,255,255,.86);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 28px;
  padding: 28px 24px 24px;
  box-shadow: 0 18px 36px rgba(0,0,0,.04);
  transition: transform .22s ease, box-shadow .22s ease;
}

.homeTestimonials__card:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 42px rgba(0,0,0,.08);
}

.homeTestimonials__quoteMark{
  font-size: 54px;
  line-height: 1;
  font-weight: 900;
  color: #2f7f5f;
  margin-bottom: 8px;
}

.homeTestimonials__quote{
  color: #3f4952;
  font-size: 15px;
  line-height: 1.9;
  margin-bottom: 22px;
}

.homeTestimonials__author strong{
  display: block;
  font-size: 16px;
  font-weight: 900;
  color: #171717;
  margin-bottom: 4px;
}

.homeTestimonials__author span{
  display: block;
  color: #7b848d;
  font-size: 13px;
}

@media (max-width: 1100px){
  .homeTestimonials__grid{
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 780px){
  .homeTestimonials--premium{
    padding: 72px 0;
  }

  .homeTestimonials__grid{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .homeTestimonials__card{
    padding: 22px 18px 18px;
  }
}

/* =========================================================
   HOME FLOW / RHYTHM
========================================================= */

.homeSection--featured{
  padding: 72px 0 24px;
}

.homeSection--promo{
  padding: 28px 0 28px;
}

.homeSection--blog{
  padding: 52px 0 24px;
}

.homeSection--intro{
  padding: 42px 0 0;
}

.homeSection--testimonials{
  padding: 52px 0 0;
}

.homeSection--community{
  padding: 52px 0 88px;
}

@media (max-width: 780px){
  .homeSection--featured{
    padding: 48px 0 18px;
  }

  .homeSection--promo{
    padding: 18px 0 18px;
  }

  .homeSection--blog{
    padding: 38px 0 18px;
  }

  .homeSection--intro{
    padding: 28px 0 0;
  }

  .homeSection--testimonials{
    padding: 36px 0 0;
  }

  .homeSection--community{
    padding: 36px 0 64px;
  }
}

/* =========================================================
   HOME FLOW FINAL
========================================================= */

.siteMain--home .homeSections{
  display: flex;
  flex-direction: column;
}

/* Hero */
.siteMain--home .homeHero{
  margin-bottom: 34px;
}

/* Secciones normales */
.homeSection--featured{
  padding: 18px 0 10px;
}

.homeSection--promo{
  padding: 28px 0 12px;
}

.homeSection--blog{
  padding: 26px 0 18px;
}

/* Bloques full width */
.homeSection--testimonials{
  padding: 38px 0 0;
}

.homeSection--intro{
  padding: 26px 0 0;
}

.homeSection--community{
  padding: 38px 0 72px;
}

/* Quitar excesos internos heredados */
.homeFeatured--premium,
.promoBanner--premium,
.homeBlog--premium,
.homeTestimonials--premium,
.homeIntro--premium,
.homeCommunity--premium{
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* Separación visual más natural entre testimonials e intro */
.homeTestimonials--premium{
  padding-top: 76px;
  padding-bottom: 52px;
}

.homeIntro--premium{
  padding-top: 64px;
  padding-bottom: 76px;
}

/* Hacer que no se peguen visualmente siendo dos full width */
.homeSection--testimonials{
  background: #f5f7f5;
}

.homeSection--intro{
  background: #eef2ef;
}

/* Community vuelve a base limpia */
.homeSection--community{
  background: transparent;
}

/* Mobile */
@media (max-width: 780px){
  .siteMain--home .homeHero{
    margin-bottom: 24px;
  }

  .homeSection--featured{
    padding: 10px 0 8px;
  }

  .homeSection--promo{
    padding: 18px 0 10px;
  }

  .homeSection--blog{
    padding: 18px 0 12px;
  }

  .homeSection--testimonials{
    padding: 26px 0 0;
  }

  .homeSection--intro{
    padding: 18px 0 0;
  }

  .homeSection--community{
    padding: 26px 0 54px;
  }

  .homeTestimonials--premium{
    padding-top: 54px;
    padding-bottom: 34px;
  }

  .homeIntro--premium{
    padding-top: 42px;
    padding-bottom: 48px;
  }
}

.homeTestimonials--premium{
  position: relative;
  overflow: hidden;
}

.homeTestimonials--premium::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 20%, rgba(47,127,95,.06), transparent 28%),
    radial-gradient(circle at 85% 75%, rgba(47,127,95,.05), transparent 24%);
  pointer-events: none;
}

.homeTestimonials--premium .container{
  position: relative;
  z-index: 2;
}

.homeIntro--premium{
  position: relative;
  overflow: hidden;
}

.homeIntro--premium::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
  pointer-events: none;
}

.homeIntro--premium .container{
  position: relative;
  z-index: 2;
}

.homeFeatured__head,
.homeBlog__head{
  margin-bottom: 22px;
}

.homeFeatured--premium{
  padding-bottom: 10px;
}

.homeBlog--premium{
  padding-top: 54px;
  padding-bottom: 22px;
}

/* =========================================================
   HOME TESTIMONIALS - PREMIUM REWORK
========================================================= */

.homeTestimonials--premium{
  position: relative;
  overflow: hidden;
  padding: 96px 0 88px;
  background:
    radial-gradient(circle at 12% 20%, rgba(47,127,95,.06), transparent 26%),
    radial-gradient(circle at 88% 78%, rgba(47,127,95,.05), transparent 24%),
    linear-gradient(180deg, #f3f6f4 0%, #eef2ef 100%);
}

.homeTestimonials--premium .container{
  position: relative;
  z-index: 2;
}

.homeTestimonials__head{
  max-width: 820px;
  margin-bottom: 34px;
}

.homeTestimonials__eyebrow{
  display: inline-block;
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #2f7f5f;
}

.homeTestimonials__title{
  margin: 0;
  font-size: clamp(36px, 4vw, 58px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.045em;
  color: #171717;
}

.homeTestimonials__subtitle{
  margin-top: 14px;
  max-width: 660px;
  color: #66707a;
  font-size: 15px;
  line-height: 1.85;
}

.homeTestimonials__subtitle p{
  margin: 0;
}

.homeTestimonials__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  align-items: stretch;
}

.homeTestimonials__card{
  position: relative;
  min-height: 100%;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 30px;
  padding: 30px 28px 26px;
  box-shadow: 0 18px 36px rgba(0,0,0,.04);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.homeTestimonials__card:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 42px rgba(0,0,0,.08);
  border-color: rgba(47,127,95,.14);
}

.homeTestimonials__top{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.homeTestimonials__quoteMark{
  font-size: 60px;
  line-height: .8;
  font-weight: 900;
  color: #2f7f5f;
  opacity: .95;
}

.homeTestimonials__stars{
  display: inline-flex;
  gap: 4px;
  margin-top: 6px;
  color: #2f7f5f;
  font-size: 14px;
  letter-spacing: .04em;
}

.homeTestimonials__quote{
  color: #3f4952;
  font-size: 16px;
  line-height: 1.9;
  margin-bottom: 26px;
  max-width: 52ch;
}

.homeTestimonials__author{
  padding-top: 18px;
  border-top: 1px solid rgba(0,0,0,.06);
}

.homeTestimonials__author strong{
  display: block;
  font-size: 16px;
  font-weight: 900;
  color: #171717;
  margin-bottom: 4px;
}

.homeTestimonials__author span{
  display: block;
  color: #7b848d;
  font-size: 13px;
  line-height: 1.5;
}

@media (max-width: 980px){
  .homeTestimonials--premium{
    padding: 76px 0 68px;
  }

  .homeTestimonials__grid{
    grid-template-columns: 1fr;
    gap: 18px;
  }
}

@media (max-width: 640px){
  .homeTestimonials--premium{
    padding: 58px 0 54px;
  }

  .homeTestimonials__head{
    margin-bottom: 24px;
  }

  .homeTestimonials__title{
    font-size: 36px;
  }

  .homeTestimonials__subtitle{
    font-size: 14px;
    line-height: 1.75;
  }

  .homeTestimonials__card{
    padding: 22px 18px 18px;
    border-radius: 24px;
  }

  .homeTestimonials__quote{
    font-size: 14px;
    line-height: 1.8;
    margin-bottom: 20px;
  }

  .homeTestimonials__quoteMark{
    font-size: 48px;
  }
}

/* =========================================================
   HOME TESTIMONIALS SWIPER
========================================================= */

.homeTestimonials--premium .js-testimonials-swiper{
  overflow: hidden;
  position: relative;
}

.homeTestimonials--premium .swiper-slide{
  height: auto;
}

.homeTestimonials--premium .homeTestimonials__card{
  height: 100%;
}

.homeTestimonials__nav{
  margin-top: 24px;
  display: grid;
  grid-template-columns: 44px 1fr 44px;
  gap: 16px;
  align-items: center;
}

.homeTestimonials--premium .swiper-button-prev,
.homeTestimonials--premium .swiper-button-next{
  position: static;
  width: 44px;
  height: 44px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(0,0,0,.08);
  color: #171717;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  transition: all .22s ease;
}

.homeTestimonials--premium .swiper-button-prev:hover,
.homeTestimonials--premium .swiper-button-next:hover{
  transform: translateY(-2px);
  background: #fff;
  border-color: rgba(47,127,95,.18);
}

.homeTestimonials--premium .swiper-button-prev::after,
.homeTestimonials--premium .swiper-button-next::after{
  font-size: 15px;
  font-weight: 900;
}

.homeTestimonials__pagination,
.homeTestimonials--premium .swiper-pagination{
  position: static;
  display: flex;
  justify-content: center;
  gap: 8px;
}

.homeTestimonials--premium .swiper-pagination-bullet{
  width: 10px;
  height: 10px;
  margin: 0 !important;
  background: rgba(47,127,95,.24);
  opacity: 1;
  transition: all .22s ease;
}

.homeTestimonials--premium .swiper-pagination-bullet-active{
  width: 28px;
  border-radius: 999px;
  background: #2f7f5f;
}

@media (max-width: 640px){
  .homeTestimonials__nav{
    grid-template-columns: 40px 1fr 40px;
    gap: 10px;
    margin-top: 18px;
  }

  .homeTestimonials--premium .swiper-button-prev,
  .homeTestimonials--premium .swiper-button-next{
    width: 40px;
    height: 40px;
  }
}

.homeSection--community{
  background: linear-gradient(180deg, #f7f9f8 0%, #f1f4f2 100%);
}

.homeCommunity__card{
  box-shadow: 0 18px 34px rgba(0,0,0,.05);
}

.homeCommunity__card:hover{
  box-shadow: 0 24px 42px rgba(0,0,0,.09);
}

.homeCommunity__media{
  height: 250px;
}

.homeCommunity__media img{
  max-width: 150px;
  max-height: 150px;
}

.homeSection--community{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

.homeCommunity--premium{
  padding-bottom: 18px !important;
  margin-bottom: 0 !important;
}

.siteFooter,
.footerMain,
footer.site-footer{
  margin-top: 0 !important;
}

.homeSection--community{
  padding-top: 80px;
  padding-bottom: 60px; /* antes estaba mal balanceado */
  margin-bottom: 0 !important;
}

.homeCommunity__grid{
  margin-top: 32px;
  padding-bottom: 94px; /* 👈 esto es lo que faltaba */
}

.homeCommunity__card{
  padding-bottom: 34px; /* más aire interno */
}

.homeSection--community{
  border-bottom: 1px solid rgba(0,0,0,.04);
}

.siteFooter,
footer.site-footer{
  margin-top: 0 !important;
}

.homeSection--community + footer{
  margin-top: 0 !important;
}

/* wrapper general de todas las secciones de home */
.siteMain--home .homeSections{
  padding-bottom: 0 !important;
}

/* community */
.homeSection--community{
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

.homeCommunity--premium{
  margin-bottom: 0 !important;
}

/* aire interno real del bloque */
.homeCommunity__grid{
  margin-top: 32px;
  padding-bottom: 94px;
}

/* footer pegado */
.siteFooter,
footer.site-footer,
.footerMain{
  margin-top: 0 !important;
}


.homeIntro{
  max-width: 1200px;
  margin: 0 auto;
}

.homeSection--intro{
  padding-left: 32px;
  padding-right: 32px;
  padding-bottom: 70px;
  padding-top: 70px;
}
.homeIntro{
  border-radius: 18px;
  overflow: hidden; /* importante */
}

@media (max-width: 768px){
  .homeSection--intro{
    padding-left: 16px;
    padding-right: 16px;
  }
}

.homeIntro{
  box-shadow: 0 20px 40px rgba(0,0,0,.04);
}

/* =========================================================
   TESTIMONIALS NAV FIX
========================================================= */

.homeTestimonials__nav{
  margin-top: 26px;
  display: grid;
  grid-template-columns: 52px 1fr 52px;
  gap: 18px;
  align-items: center;
}

.homeTestimonials--premium .swiper-button-prev,
.homeTestimonials--premium .swiper-button-next{
  position: static;
  width: 52px;
  height: 52px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(0,0,0,.06);
  color: #171717;
  box-shadow: 0 12px 28px rgba(0,0,0,.06);
  transition: all .22s ease;
}

.homeTestimonials--premium .swiper-button-prev:hover,
.homeTestimonials--premium .swiper-button-next:hover{
  transform: translateY(-2px);
  background: #f8faf8;
  border-color: rgba(47,127,95,.18);
  box-shadow: 0 16px 34px rgba(0,0,0,.10);
}

.homeTestimonials--premium .swiper-button-prev::after,
.homeTestimonials--premium .swiper-button-next::after{
  font-size: 16px;
  font-weight: 900;
}

/* que no queden “pegadas” al borde visual */
.homeTestimonials--premium .swiper-button-prev{
  justify-self: start;
}

.homeTestimonials--premium .swiper-button-next{
  justify-self: end;
}

/* mobile */
@media (max-width: 640px){
  .homeTestimonials__nav{
    grid-template-columns: 44px 1fr 44px;
    gap: 12px;
  }

  .homeTestimonials--premium .swiper-button-prev,
  .homeTestimonials--premium .swiper-button-next{
    width: 44px;
    height: 44px;
  }
}


.homeTestimonials--premium .container{
  padding-left: 24px;
  padding-right: 24px;
}

@media (max-width: 768px){
  .homeTestimonials--premium .container{
    padding-left: 16px;
    padding-right: 16px;
  }
}

/* =========================================================
   TESTIMONIALS NAV FINAL FIX
========================================================= */

/* más aire debajo de las cards */
.homeTestimonials--premium .js-testimonials-swiper{
  padding-bottom: 14px;
}

/* baja la navegación para sacarla de la zona de sombra */
.homeTestimonials__nav{
  margin-top: 34px !important;
  display: grid;
  grid-template-columns: 52px 1fr 52px;
  gap: 18px;
  align-items: center;
}

/* cards un poco más separadas visualmente */
.homeTestimonials__card{
  box-shadow: 0 18px 36px rgba(0,0,0,.04);
}

/* flechas limpias */
.homeTestimonials--premium .swiper-button-prev,
.homeTestimonials--premium .swiper-button-next{
  position: static;
  width: 52px;
  height: 52px;
  margin: 0;
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  color: #171717;
  box-shadow: 0 10px 24px rgba(0,0,0,.05);
  transition: all .22s ease;
}

.homeTestimonials--premium .swiper-button-prev::after,
.homeTestimonials--premium .swiper-button-next::after{
  font-size: 16px;
  font-weight: 900;
}

.homeTestimonials--premium .swiper-button-prev:hover,
.homeTestimonials--premium .swiper-button-next:hover{
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(0,0,0,.08);
}

/* dots centrados y con aire */
.homeTestimonials__pagination,
.homeTestimonials--premium .swiper-pagination{
  position: static;
  display: flex;
  justify-content: center;
  gap: 8px;
}

/* mobile */
@media (max-width: 640px){
  .homeTestimonials--premium .js-testimonials-swiper{
    padding-bottom: 10px;
  }

  .homeTestimonials__nav{
    margin-top: 24px !important;
    grid-template-columns: 44px 1fr 44px;
    gap: 12px;
  }

  .homeTestimonials--premium .swiper-button-prev,
  .homeTestimonials--premium .swiper-button-next{
    width: 44px;
    height: 44px;
  }
}
.homeTestimonials__card{
  box-shadow: 0 10px 22px rgba(0,0,0,.035);
}

/* =========================================================
   TESTIMONIALS CARD SHADOW FIX
========================================================= */

.homeTestimonials__card{
  box-shadow: 0 8px 18px rgba(0,0,0,.035) !important;
}

/* hover más contenido también */
.homeTestimonials__card:hover{
  box-shadow: 0 12px 24px rgba(0,0,0,.05) !important;
}

.homeTestimonials__card{
  box-shadow:
    0 2px 6px rgba(0,0,0,.02),
    0 10px 18px rgba(0,0,0,.025) !important;
}

.homeTestimonials__card:hover{
  box-shadow:
    0 4px 10px rgba(0,0,0,.025),
    0 14px 24px rgba(0,0,0,.04) !important;
}
.homeTestimonials--premium .swiper-wrapper{
  padding-bottom: 10px;
}

.homeTestimonials__nav{
  margin-top: 28px !important;
}
.homeTestimonials__card{
  box-shadow: 0 8px 18px rgba(0,0,0,.035) !important;
}

.homeTestimonials__card:hover{
  box-shadow: 0 12px 24px rgba(0,0,0,.05) !important;
}

.homeTestimonials--premium .swiper-wrapper{
  padding-bottom: 10px;
}

.homeTestimonials__nav{
  margin-top: 28px !important;
}

.homeSection--intro{
  margin-top: 0px !important;
}

.homeHero--premium{
  margin-bottom: 0px !important;
}

.headerCats__mega{
  display:flex;
  width:720px;
  min-height:320px;
}

.headerCats__main{
  width:260px;
  background:#f5f5f5;
  padding:16px 0;
}

.headerCats__mainItem{
  padding:12px 20px;
  cursor:pointer;
  transition:all .2s;
}

.headerCats__mainItem:hover{
  background:#e9eeeb;
  color:#2f6f57;
}

.headerCats__sub{
  flex:1;
  padding:24px;
  background:#fff;
}

.headerCats__subPanel{
  display:none;
}

.headerCats__subPanel.active{
  display:block;
}

/* =========================================================
   HEADER CATEGORIES MEGA MENU WOW
========================================================= */

.headerCats{
  position: relative;
}

.headerCats__panel{
  position: absolute;
  top: calc(100% + 12px);
  left: 0;
  z-index: 60;
  width: 980px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 22px;
  box-shadow: 0 28px 60px rgba(0,0,0,.12);
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: all .22s ease;
}

.headerCats.is-open .headerCats__panel{
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.headerCats__mega{
  display: grid;
  grid-template-columns: 270px 1fr;
  min-height: 470px;
}

.headerCats__main{
  list-style: none;
  margin: 0;
  padding: 18px 0;
  background: #f4f6f5;
  border-right: 1px solid rgba(0,0,0,.06);
}

.headerCats__mainItem{
  position: relative;
  padding: 16px 24px;
  font-size: 16px;
  font-weight: 700;
  color: #161616;
  cursor: pointer;
  transition: all .2s ease;
}

.headerCats__mainItem:hover,
.headerCats__mainItem.is-active{
  background: #e8eeea;
  color: #2f7f5f;
}

.headerCats__mainItem.is-active::before{
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  bottom: 10px;
  width: 4px;
  border-radius: 999px;
  background: #2f7f5f;
}

.headerCats__content{
  position: relative;
  background: #fff;
}

.headerCats__subPanel{
  display: none;
  height: 100%;
}

.headerCats__subPanel.active{
  display: block;
}

.headerCats__subWrap{
  display: grid;
  grid-template-columns: 1.25fr .9fr;
  min-height: 470px;
}

.headerCats__subCol{
  padding: 28px 30px 22px;
  display: flex;
  flex-direction: column;
}

.headerCats__subTitle{
  margin-bottom: 16px;
  font-size: 14px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #171717;
}

.headerCats__subList{
  list-style: none;
  margin: 0;
  padding: 0;
  columns: 2;
  column-gap: 40px;
}

.headerCats__subList li{
  margin: 0 0 14px;
  break-inside: avoid;
}

.headerCats__subList a{
  color: #333;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.4;
  transition: color .2s ease, transform .2s ease;
}

.headerCats__subList a:hover{
  color: #2f7f5f;
}

.headerCats__empty a{
  color: #2f7f5f;
  text-decoration: none;
  font-weight: 700;
}

.headerCats__subFooter{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
  margin-top: auto;
  padding-top: 24px;
  border-top: 1px solid rgba(0,0,0,.06);
}

.headerCats__subFooterItem strong{
  display: block;
  margin-bottom: 6px;
  font-size: 14px;
  font-weight: 900;
  color: #171717;
}

.headerCats__subFooterItem span{
  display: block;
  font-size: 14px;
  line-height: 1.6;
  color: #6c727a;
}

.headerCats__feature{
  padding: 24px;
  border-left: 1px solid rgba(0,0,0,.06);
  background: linear-gradient(180deg, #fbfcfb 0%, #f5f7f5 100%);
}

.headerCats__featureCard{
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  overflow: hidden;
  box-shadow: 0 16px 30px rgba(0,0,0,.05);
  transition: transform .22s ease, box-shadow .22s ease;
}

.headerCats__featureCard:hover{
  transform: translateY(-4px);
  box-shadow: 0 24px 40px rgba(0,0,0,.10);
}

.headerCats__featureMedia{
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 240px;
  padding: 24px;
  background: #fff;
}

.headerCats__featureMedia img{
  max-width: 100%;
  max-height: 220px;
  object-fit: contain;
  display: block;
}

.headerCats__featureBody{
  padding: 18px 18px 22px;
  text-align: center;
}

.headerCats__featureEyebrow{
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #8a938c;
}

.headerCats__featureTitle{
  margin: 0 0 10px;
  font-size: 28px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.headerCats__featurePrice{
  margin-bottom: 12px;
  font-size: 24px;
  font-weight: 900;
  color: #2f7f5f;
}

.headerCats__featurePrice .amount{
  color: inherit;
}

.headerCats__featureLink{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
}

/* mejorar z-index sobre hero */
.siteHeader{
  z-index: 100;
}

/* =========================================================
   HEADER MEGA MENU - ALIGN FIX
========================================================= */

/* estructura general más ordenada */
.headerCats__subWrap{
  display: grid;
  grid-template-columns: 1.25fr .9fr;
  grid-template-rows: 1fr auto;
  min-height: 470px;
}

/* columnas superiores */
.headerCats__subCol{
  padding: 28px 30px 24px;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.headerCats__feature{
  padding: 24px;
  border-left: 1px solid rgba(0,0,0,.06);
  background: linear-gradient(180deg, #fbfcfb 0%, #f5f7f5 100%);
  display: flex;
  align-items: stretch;
}

/* bloque destacado consistente */
.headerCats__featureCard{
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 100%;
  text-decoration: none;
  color: inherit;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,.06);
  overflow: hidden;
  box-shadow: 0 16px 30px rgba(0,0,0,.05);
  transition: transform .22s ease, box-shadow .22s ease;
}

.headerCats__featureMedia{
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  max-height: 200px;
  padding: 20px;
  background: #fff;
}

.headerCats__featureMedia img{
  max-width: 100%;
  max-height: 160px;
  object-fit: contain;
  display: block;
}

/* cuerpo del destacado */
.headerCats__featureBody{
  padding: 16px 16px 18px;
  text-align: center;
  display: flex;
  flex-direction: column;
  flex: 1;
}

.headerCats__featureEyebrow{
  margin-bottom: 8px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #8a938c;
}

/* título consistente */
.headerCats__featureTitle{
  margin: 0 0 10px;
  font-size: 22px;
  line-height: 1.08;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;

  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;

  min-height: 95px;
}

/* precio y botón abajo, estables */
.headerCats__featurePrice{
  margin-top: auto;
  margin-bottom: 12px;
  font-size: 20px;
  font-weight: 900;
  color: #2f7f5f;
}

.headerCats__featureLink{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 13px;
  font-weight: 800;
}

/* footer inferior full width */
.headerCats__subFooter{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
  padding: 20px 24px;
  border-top: 1px solid rgba(0,0,0,.06);
  background: #fafbfa;
}

/* quitar borde raro al pie */
.headerCats__subCol .headerCats__subFooter{
  margin-top: 0;
  padding-top: 0;
  border-top: 0;
}

/* subcategorías mejor alineadas */
.headerCats__subList{
  list-style: none;
  margin: 0;
  padding: 0;
  columns: 2;
  column-gap: 40px;
}

.headerCats__subList li{
  margin: 0 0 14px;
  break-inside: avoid;
}

.headerCats__subList a{
  color: #333;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.35;
  transition: color .2s ease, transform .2s ease;
}

.headerCats__subList a:hover{
  color: #2f7f5f;
}

/* footer items */
.headerCats__subFooterItem strong{
  display: block;
  margin-bottom: 6px;
  font-size: 14px;
  font-weight: 900;
  color: #171717;
}

.headerCats__subFooterItem span{
  display: block;
  font-size: 14px;
  line-height: 1.55;
  color: #6c727a;
}

/* =========================================================
   HEADER MEGA MENU - FULL WIDTH USE
========================================================= */

.headerCats__panel{
  width: 1120px;
  max-width: calc(100vw - 80px);
}

.headerCats__mega{
  display: grid;
  grid-template-columns: 260px 1fr;
  min-height: 500px;
}

.headerCats__content{
  display: block;
  width: 100%;
}

.headerCats__subWrap{
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: auto auto;
  gap: 0;
  width: 100%;
}

/* columna subcategorías más cómoda */
.headerCats__subCol{
  padding: 30px 34px 26px;
}

/* subcategorías ocupando mejor el ancho */
.headerCats__subList{
  list-style: none;
  margin: 0;
  padding: 0;
  columns: 2;
  column-gap: 56px;
}

.headerCats__subList li{
  margin: 0 0 16px;
  break-inside: avoid;
}

.headerCats__subList a{
  display: inline-block;
  font-size: 16px;
  line-height: 1.35;
}

/* destacado más ancho */
.headerCats__feature{
  padding: 28px;
}

.headerCats__featureCard{
  max-width: 100%;
}

.headerCats__featureMedia{
  min-height: 220px;
  max-height: 220px;
  padding: 20px;
}

.headerCats__featureMedia img{
  max-height: 180px;
}

.headerCats__featureBody{
  padding: 18px 20px 22px;
}

.headerCats__featureTitle{
  font-size: 22px;
  line-height: 1.06;
  min-height: 94px;
}

/* footer mejor repartido */
.headerCats__subFooter{
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 22px;
  padding: 22px 28px;
}

/* =========================================================
   HEADER MEGA MENU - CATEGORY ICONS
========================================================= */

.headerCats__mainItemInner{
  display: flex;
  align-items: center;
  gap: 12px;
}

.headerCats__mainIcon{
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.headerCats__mainIcon img{
  width: 20px;
  height: 20px;
  object-fit: contain;
  display: block;
}

.headerCats__mainDot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #b6c0ba;
  display: block;
}

.headerCats__mainItem.is-active .headerCats__mainDot,
.headerCats__mainItem:hover .headerCats__mainDot{
  background: #2f7f5f;
}

.headerCats__panel{
  width: 1280px; /* 👈 más ancho */
  max-width: calc(100vw - 40px);
}

.headerCats__mega{
  grid-template-columns: 260px 1fr;
}

.headerCats__content{
  width: 100%;
}

.headerCats__subWrap{
  grid-template-columns: 2fr 1.2fr; /* 👈 más peso visual */
}

.headerCats__subCol{
  width: 100%;
  padding: 30px 40px;
}

.headerCats__feature{
  width: 100%;
  padding: 30px 40px;
}

.headerCats__featureCard{
  max-width: 340px;
  margin: 0 auto;
}

.headerCats__panel{
  left: 0;
  transform: none;
}

.headerCats{
  position: static;
}

/* =========================================================
   HEADER MEGA MENU FINAL WIDTH FIX
========================================================= */

.headerCats__panel{
  width: 1180px !important;
  max-width: calc(100vw - 40px) !important;
}

.headerCats__mega{
  display: grid !important;
  width: 100% !important;
  min-height: 500px !important;
  grid-template-columns: 260px 1fr !important;
}

.headerCats__content{
  width: 100% !important;
}

.headerCats__subWrap{
  display: grid !important;
  width: 100% !important;
  min-height: 500px !important;
  grid-template-columns: 1.7fr 1fr !important;
  grid-template-rows: 1fr auto !important;
}

.headerCats__subCol{
  width: 100% !important;
  padding: 30px 34px 26px !important;
}

.headerCats__feature{
  width: 100% !important;
  padding: 28px !important;
}

.headerCats__subFooter{
  grid-column: 1 / -1 !important;
  width: 100% !important;
}

/* =========================================================
   HEADER MEGA MENU - PANEL ANIMATION
========================================================= */

.headerCats__content{
  position: relative;
  overflow: hidden;
}

.headerCats__subPanel{
  display: none;
  opacity: 0;
  transform: translateY(10px);
}

.headerCats__subPanel.active{
  display: block;
  animation: megaPanelIn .24s ease forwards;
}

@keyframes megaPanelIn{
  from{
    opacity: 0;
    transform: translateY(10px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

/* =========================================================
   HEADER MEGA MENU - SUBCATEGORY HOVER
========================================================= */

.headerCats__subList a{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #333;
  text-decoration: none;
  font-size: 16px;
  line-height: 1.35;
  transition: color .2s ease, transform .2s ease, opacity .2s ease;
}

.headerCats__subList a::before{
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: rgba(47,127,95,.18);
  transition: background .2s ease, transform .2s ease;
}

.headerCats__subList a:hover{
  color: #2f7f5f;
  transform: translateX(4px);
}

.headerCats__subList a:hover::before{
  background: #2f7f5f;
  transform: scale(1.15);
}



.quickViewModal[hidden]{
  display: none !important;
}

.quickViewModal{
  position: fixed;
  inset: 0;
  z-index: 9999;
}

.quickViewModal__overlay{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.48);
}

.quickViewModal__dialog{
  position: relative;
  z-index: 2;
  width: min(980px, calc(100vw - 32px));
  max-height: calc(100vh - 40px);
  overflow: auto;
  margin: 20px auto;
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 30px 60px rgba(0,0,0,.18);
  padding: 24px;
}

.quickViewModal__close{
  position: absolute;
  top: 14px;
  right: 14px;
  width: 40px;
  height: 40px;
  border: 0;
  border-radius: 999px;
  background: #f3f4f4;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
}

.quickViewModal__content{
  min-height: 120px;
}

.quickViewLoading{
  padding: 48px 24px;
  text-align: center;
  font-weight: 700;
}

/* =========================================================
   MINI CART - SPACING FIX
========================================================= */

.miniCartDrawer{
  display: flex;
  flex-direction: column;
}

.miniCartDrawer__head{
  position: relative;
  padding: 28px 24px 18px;
  border-bottom: 1px solid rgba(0,0,0,.08);
}

.miniCartDrawer__head h3{
  margin: 0;
  padding-right: 56px;
  font-size: 28px;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -.03em;
}

.miniCartDrawer__close{
  position: absolute;
  top: 18px;
  right: 18px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.miniCartDrawer__body,
.js-mini-cart-body-inner{
  padding: 0 24px 24px;
}

.mini_cart_item{
  display: grid !important;
  grid-template-columns: 84px 1fr;
  gap: 14px;
  align-items: start;
  padding: 18px 0 !important;
  border-bottom: 1px solid rgba(0,0,0,.08);
  position: relative;
}

.mini_cart_item a.remove{
  position: absolute !important;
  left: -6px;
  top: 18px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: #f3f4f4;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.mini_cart_item img{
  width: 84px !important;
  height: 84px !important;
  object-fit: contain;
  border-radius: 16px;
  background: #fafafa;
  padding: 8px;
  margin: 0 !important;
}

.mini_cart_item a:not(.remove){
  font-size: 15px;
  line-height: 1.35;
  font-weight: 800;
}

.mini_cart_item .quantity{
  display: block;
  margin-top: 8px;
  font-size: 14px;
  line-height: 1.5;
  color: #4b5563;
}

.woocommerce-mini-cart__total{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 18px 0 14px !important;
  margin: 0 !important;
  border-bottom: 0 !important;
  font-size: 16px;
}

.woocommerce-mini-cart__buttons{
  display: grid;
  gap: 14px;
  padding-top: 6px;
}

.woocommerce-mini-cart__buttons .button{
  width: 100%;
  min-height: 52px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
}

.woocommerce-mini-cart__empty-message,
.mini_cart_item:last-child{
  margin-bottom: 0;
}

@media (max-width: 640px){
  .miniCartDrawer__head{
    padding: 22px 18px 14px;
  }

  .miniCartDrawer__body,
  .js-mini-cart-body-inner{
    padding: 0 18px 18px;
  }

  .mini_cart_item{
    grid-template-columns: 72px 1fr;
    gap: 12px;
  }

  .mini_cart_item img{
    width: 72px !important;
    height: 72px !important;
  }
}

/* =========================================================
   CHECKOUT - ENVÍOS PREMIUM
========================================================= */

.woocommerce-checkout-review-order-table ul#shipping_method {
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.woocommerce-checkout-review-order-table ul#shipping_method li {
  margin: 0;
}

/* Label completo como card */
.woocommerce-checkout-review-order-table ul#shipping_method li label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;

  padding: 14px 16px;
  border-radius: 12px;

  background: #f7f8f7;
  border: 1px solid #e3e6e3;

  cursor: pointer;
  transition: all 0.25s ease;
}

/* Hover */
.woocommerce-checkout-review-order-table ul#shipping_method li label:hover {
  border-color: #cdd5cd;
  background: #f2f5f2;
}

/* Radio oculto */
.woocommerce-checkout-review-order-table ul#shipping_method input[type="radio"] {
  display: none;
}

/* Fake radio */
.woocommerce-checkout-review-order-table ul#shipping_method label::before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;

  border: 2px solid #c4c9c4;
  display: inline-block;
  flex-shrink: 0;

  transition: all 0.2s ease;
}

/* Estado seleccionado */
.woocommerce-checkout-review-order-table ul#shipping_method input[type="radio"]:checked + label {
  border-color: #2f6f4e;
  background: #eef6f1;
}

.woocommerce-checkout-review-order-table ul#shipping_method input[type="radio"]:checked + label::before {
  border-color: #2f6f4e;
  background: #2f6f4e;
  box-shadow: inset 0 0 0 4px #fff;
}

/* Texto del método */
.woocommerce-checkout-review-order-table ul#shipping_method label {
  font-size: 14px;
  font-weight: 500;
  color: #1f2a1f;
}

/* Precio destacado */
.woocommerce-checkout-review-order-table ul#shipping_method .amount {
  font-weight: 600;
  color: #2f6f4e;
}

/* Mejor spacing del bloque */
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
  vertical-align: top;
}

.woocommerce-checkout-review-order-table ul#shipping_method label {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.woocommerce-checkout-review-order-table ul#shipping_method label span {
  display: block;
}

#shipping_method li label {
  min-height: 60px;
}

#shipping_method .amount {
  font-size: 15px;
  letter-spacing: 0.3px;
}

#shipping_method li label:hover {
  transform: translateY(-1px);
}

/* =========================================================
   CHECKOUT PREMIUM
========================================================= */

.woocommerce-checkout .sectionSpace{
  padding-top: 56px;
  padding-bottom: 80px;
}

/* =========================================================
   CHECKOUT LAYOUT FIX
========================================================= */

.woocommerce-checkout form.checkout{
  display: block;
}

.woocommerce-checkout .col2-set{
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  gap: 28px;
  align-items: start;
}

.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2{
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
}

.woocommerce-checkout #customer_details{
  width: 100%;
}

.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2{
  width: 100% !important;
  float: none !important;
}

.woocommerce-checkout #order_review_heading{
  display: none;
}

.woocommerce-checkout #order_review{
  width: 100%;
  margin-top: 0;
}

@media (max-width: 980px){
  .woocommerce-checkout .col2-set{
    grid-template-columns: 1fr;
  }
}

/* ---------- BLOQUES ---------- */

.woocommerce-checkout #customer_details,
.woocommerce-checkout #order_review{
  width: 100%;
}

.woocommerce-checkout #customer_details > div,
.woocommerce-checkout #order_review{
  background: #fff;
  border: 1px solid #e7ebe7;
  border-radius: 22px;
  box-shadow: 0 16px 40px rgba(16, 24, 16, .04);
}

.woocommerce-checkout #customer_details > div{
  padding: 28px 24px 24px;
}

.woocommerce-checkout #order_review{
  padding: 22px 20px 20px;
  position: sticky;
  top: 120px;
}

@media (max-width: 980px){
  .woocommerce-checkout #order_review{
    position: static;
  }
}

/* ---------- TÍTULOS ---------- */

.woocommerce-checkout h3,
.woocommerce-checkout .col-1 > h3,
.woocommerce-checkout .col-2 > h3,
.woocommerce-checkout #order_review_heading{
  margin: 0 0 22px;
  font-size: 30px;
  line-height: 1.05;
  letter-spacing: -.03em;
  font-weight: 900;
  color: #171717;
}

.woocommerce-checkout #order_review_heading{
  display: none;
}

/* ---------- FILAS / CAMPOS ---------- */

.woocommerce-checkout .woocommerce-billing-fields__field-wrapper,
.woocommerce-checkout .woocommerce-shipping-fields__field-wrapper{
  display: grid;
  gap: 14px;
}

.woocommerce-checkout .form-row{
  margin: 0 0 2px;
}

.woocommerce-checkout .form-row label{
  display: block;
  margin: 0 0 8px;
  font-size: 13px;
  line-height: 1.35;
  font-weight: 800;
  color: #202820;
  letter-spacing: -.01em;
}

.woocommerce-checkout .form-row .required{
  color: #2f6f4e;
  text-decoration: none;
  font-weight: 900;
}

.woocommerce-checkout input.input-text,
.woocommerce-checkout textarea,
.woocommerce-checkout select{
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border-radius: 14px;
  border: 1px solid #dce3dd;
  background: #fbfcfb;
  color: #182018;
  font-size: 15px;
  line-height: 1.4;
  transition: border-color .22s ease, box-shadow .22s ease, background .22s ease;
  box-shadow: none;
}

.woocommerce-checkout textarea{
  min-height: 120px;
  padding: 14px 16px;
  resize: vertical;
}

.woocommerce-checkout input.input-text::placeholder,
.woocommerce-checkout textarea::placeholder{
  color: #98a19a;
}

.woocommerce-checkout input.input-text:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus{
  outline: none;
  border-color: #7fb093;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(47, 111, 78, .10);
}

/* ---------- CHECKBOX / SHIP TO ---------- */

.woocommerce-checkout .woocommerce-shipping-fields{
  margin-top: 4px;
}

.woocommerce-checkout .woocommerce-shipping-fields h3{
  margin-top: 10px;
}

.woocommerce-checkout .woocommerce-form__label-for-checkbox,
.woocommerce-checkout .shipping_address + p label,
.woocommerce-checkout .form-row.create-account label{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
}

.woocommerce-checkout input[type="checkbox"]{
  appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 6px;
  border: 2px solid #c8d0c9;
  background: #fff;
  margin: 0;
  position: relative;
  transition: all .18s ease;
}

.woocommerce-checkout input[type="checkbox"]:checked{
  background: #2f6f4e;
  border-color: #2f6f4e;
}

.woocommerce-checkout input[type="checkbox"]:checked::after{
  content: "";
  position: absolute;
  inset: 3px 5px 4px 4px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}

/* ---------- TABLA PEDIDO ---------- */

.woocommerce-checkout-review-order-table{
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td{
  padding: 16px 0;
  border-bottom: 1px solid #ecefed;
  vertical-align: top;
}

.woocommerce-checkout-review-order-table thead th{
  padding-top: 6px;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #6f786f;
}

.woocommerce-checkout-review-order-table .product-name{
  font-size: 14px;
  line-height: 1.65;
  color: #273027;
}

.woocommerce-checkout-review-order-table .product-total,
.woocommerce-checkout-review-order-table tfoot td{
  text-align: right;
  font-weight: 700;
  color: #171717;
}

.woocommerce-checkout-review-order-table tfoot th{
  font-weight: 800;
  color: #171717;
}

.woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout-review-order-table .order-total td{
  font-size: 16px;
  font-weight: 900;
}

/* ---------- SHIPPING YA PREMIUM ---------- */

.woocommerce-checkout-review-order-table ul#shipping_method{
  list-style: none;
  margin: 12px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.woocommerce-checkout-review-order-table ul#shipping_method li{
  margin: 0;
}

.woocommerce-checkout-review-order-table ul#shipping_method li label{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 60px;
  padding: 14px 16px;
  border-radius: 14px;
  background: #f7f8f7;
  border: 1px solid #e3e6e3;
  cursor: pointer;
  transition: all .22s ease;
}

.woocommerce-checkout-review-order-table ul#shipping_method li label:hover{
  border-color: #cdd5cd;
  background: #f2f5f2;
  transform: translateY(-1px);
}

.woocommerce-checkout-review-order-table ul#shipping_method input[type="radio"]{
  display: none;
}

.woocommerce-checkout-review-order-table ul#shipping_method label::before{
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid #c4c9c4;
  display: inline-block;
  flex-shrink: 0;
  transition: all .2s ease;
}

.woocommerce-checkout-review-order-table ul#shipping_method input[type="radio"]:checked + label{
  border-color: #2f6f4e;
  background: #eef6f1;
}

.woocommerce-checkout-review-order-table ul#shipping_method input[type="radio"]:checked + label::before{
  border-color: #2f6f4e;
  background: #2f6f4e;
  box-shadow: inset 0 0 0 4px #fff;
}

.woocommerce-checkout-review-order-table ul#shipping_method label{
  font-size: 14px;
  font-weight: 600;
  color: #1f2a1f;
}

.woocommerce-checkout-review-order-table ul#shipping_method .amount{
  font-weight: 700;
  color: #2f6f4e;
  font-size: 15px;
}

/* ---------- PAYMENT ---------- */

.woocommerce-checkout #payment{
  margin-top: 18px;
  background: transparent;
  border: 0;
}

.woocommerce-checkout #payment ul.payment_methods{
  margin: 0;
  padding: 0;
  border: 0;
}

.woocommerce-checkout #payment ul.payment_methods > li{
  list-style: none;
  margin: 0 0 12px;
  padding: 0;
  border: 0;
}

.woocommerce-checkout #payment ul.payment_methods > li > label{
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 56px;
  padding: 0 16px;
  border-radius: 14px;
  background: #fafbfa;
  border: 1px solid #e3e7e4;
  font-weight: 700;
  cursor: pointer;
  transition: all .22s ease;
}

.woocommerce-checkout #payment ul.payment_methods > li > label:hover{
  background: #f3f6f3;
  border-color: #d2d9d2;
}

.woocommerce-checkout #payment input[type="radio"]{
  accent-color: #2f6f4e;
}

.woocommerce-checkout #payment div.payment_box{
  margin: 10px 0 0;
  padding: 14px 16px;
  border-radius: 12px;
  background: #f6f8f6;
  border: 1px solid #e5eae6;
  color: #58615a;
  font-size: 14px;
  line-height: 1.7;
}

.woocommerce-checkout #payment .place-order{
  padding-top: 8px;
}

.woocommerce-checkout #place_order{
  width: 100%;
  min-height: 56px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: .02em;
  background: #111;
  border: 0;
  box-shadow: 0 14px 28px rgba(0,0,0,.10);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.woocommerce-checkout #place_order:hover{
  transform: translateY(-1px);
  background: #2f6f4e;
  box-shadow: 0 18px 32px rgba(47, 111, 78, .18);
}

/* ---------- CUPONES / MENSAJES / INFO ---------- */

.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-error{
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 18px;
}

.woocommerce-checkout .woocommerce-additional-fields{
  margin-top: 12px;
}

/* ---------- SELECT2 ---------- */

.woocommerce-checkout .select2-container .select2-selection--single{
  min-height: 52px;
  border-radius: 14px;
  border: 1px solid #dce3dd;
  background: #fbfcfb;
  display: flex;
  align-items: center;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered{
  line-height: 50px;
  padding-left: 16px;
  color: #182018;
}

.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow{
  height: 50px;
  right: 10px;
}

/* ---------- RESUMEN EXTRA ---------- */

.woocommerce-checkout #order_review .woocommerce-privacy-policy-text,
.woocommerce-checkout #order_review .form-row.place-order > p{
  font-size: 13px;
  line-height: 1.7;
  color: #6a736c;
}

.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper{
  margin-top: 10px;
}

/* ---------- MOBILE ---------- */

@media (max-width: 980px){
  .woocommerce-checkout #customer_details > div,
  .woocommerce-checkout #order_review{
    padding: 22px 18px 18px;
    border-radius: 18px;
  }

  .woocommerce-checkout h3,
  .woocommerce-checkout .col-1 > h3,
  .woocommerce-checkout .col-2 > h3{
    font-size: 24px;
    margin-bottom: 18px;
  }
}



.woocommerce-checkout #order_review {
  position: sticky;
  top: 120px;
}

.woocommerce-checkout-review-order-table tfoot th,
.woocommerce-checkout-review-order-table tfoot td {
  padding-top: 14px;
  padding-bottom: 14px;
}

#order_review h3 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 12px;
}

.woocommerce-checkout-review-order-table tbody {
  max-height: 300px;
  overflow-y: auto;
  display: block;
}

.woocommerce-checkout-review-order-table thead,
.woocommerce-checkout-review-order-table tfoot {
  display: table;
  width: 100%;
}

.woocommerce-checkout-review-order-table tbody tr {
  display: table;
  width: 100%;
}

#place_order {
  font-size: 15px;
  padding: 16px;
  border-radius: 12px;
}

.woocommerce-checkout-review-order-table tbody {
  scrollbar-width: thin;
  scrollbar-color: #c9d3cc transparent;
}

.woocommerce-checkout-review-order-table tbody::-webkit-scrollbar {
  width: 8px;
}

.woocommerce-checkout-review-order-table tbody::-webkit-scrollbar-track {
  background: transparent;
}

.woocommerce-checkout-review-order-table tbody::-webkit-scrollbar-thumb {
  background: #c9d3cc;
  border-radius: 999px;
}

.woocommerce-checkout-review-order-table tbody::-webkit-scrollbar-thumb:hover {
  background: #aebbb1;
}

.siteFooter__newsletter h3{
  color: #ffffff;
}

.legalPage {
  max-width: 960px;
  margin: 0 auto;
  padding: 56px 20px 80px;
}

.legalPage h1 {
  margin: 0 0 24px;
  font-size: 46px;
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: -.03em;
  color: #171717;
}

.legalPage h2 {
  margin: 34px 0 14px;
  font-size: 24px;
  line-height: 1.15;
  font-weight: 800;
  color: #171717;
}

.legalPage p,
.legalPage li {
  font-size: 15px;
  line-height: 1.85;
  color: #5d6670;
}

.legalPage ul,
.legalPage ol {
  margin: 0 0 18px 20px;
  padding: 0;
}

.legalPage strong {
  color: #171717;
}

@media (max-width: 768px) {
  .legalPage {
    padding: 40px 16px 56px;
  }

  .legalPage h1 {
    font-size: 34px;
  }

  .legalPage h2 {
    font-size: 20px;
  }
}

/* =========================================================
   YITH POINTS - MY ACCOUNT MOBILE FIX
========================================================= */

@media (max-width: 768px){

  .woocommerce-account .ywpar_tabs_content_container{
    overflow: visible;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive,
  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive thead,
  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive tbody,
  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive tr,
  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive th,
  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive td{
    display: block;
    width: 100% !important;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive thead{
    display: none;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive{
    border: 0;
    background: transparent;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive tbody{
    display: grid;
    gap: 14px;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive tr.ywpar-item{
    background: #fff;
    border: 1px solid #e7ebe7;
    border-radius: 18px;
    box-shadow: 0 10px 24px rgba(16, 24, 16, .05);
    padding: 14px 14px 10px;
    overflow: hidden;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive td{
    border: 0 !important;
    padding: 10px 0 !important;
    margin: 0;
    text-align: left !important;
    position: relative;
    min-height: 0;
  }

  .woocommerce-account table.ywpar_points_rewards.shop_table_responsive td::before{
    content: attr(data-title);
    display: block;
    margin-bottom: 4px;
    font-size: 11px;
    line-height: 1.2;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
    color: #7a837c;
  }

  .woocommerce-account .ywpar_points_rewards-date,
  .woocommerce-account .ywpar_points_rewards-action,
  .woocommerce-account .ywpar_points_rewards-order,
  .woocommerce-account .ywpar_points_rewards-points{
    font-size: 14px;
    line-height: 1.5;
    color: #1b241d;
    word-break: break-word;
  }

  .woocommerce-account .ywpar_points_rewards-order a{
    color: #2f6f4e;
    font-weight: 800;
    text-decoration: none;
  }

  .woocommerce-account .ywpar_points_rewards-order a:hover{
    text-decoration: underline;
  }

  .woocommerce-account .ywpar_points_rewards-points{
    padding-top: 12px !important;
    margin-top: 6px;
    border-top: 1px solid #edf1ed !important;
    font-weight: 700;
  }

  .woocommerce-account .ywpar_points_rewards-points .ywpar_plus{
    color: #2f9d57;
    font-weight: 900;
    margin-right: 6px;
  }

  .woocommerce-account .ywpar_points_rewards-points .ywpar_minus{
    color: #d94141;
    font-weight: 900;
    margin-right: 6px;
  }

  /* tabs del plugin un poco más cómodos en mobile */
  .woocommerce-account #ywpar_tabs{
    margin-top: 14px !important;
  }

  .woocommerce-account .ywpar_tabs_header{
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 6px;
  }

  .woocommerce-account .ywpar_tabs_header::-webkit-scrollbar{
    display: none;
  }

  .woocommerce-account .ywpar_tabs_header ul{
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
    min-width: max-content;
  }

  .woocommerce-account .ywpar_tabs_header li{
    flex: 0 0 auto;
  }
}

@media (max-width: 768px){
  .woocommerce-account .ywpar-wrapper{
    margin-top: 10px;
  }

  .woocommerce-account .ywpar_tabs_content_container{
    padding: 0;
    background: transparent;
    border: 0;
  }
}

/* =========================================================
   YITH POINTS - TAB GESTIONAR PUNTOS
========================================================= */

.woocommerce-account #share_points.ywpar_tabcontent{
  background: #fff;
  border: 1px solid #e7ebe7;
  border-radius: 22px;
  box-shadow: 0 16px 40px rgba(16, 24, 16, .04);
  padding: 28px 24px 24px;
}

.woocommerce-account #share_points h3{
  margin: 0 0 16px;
  font-size: 42px;
  line-height: 1.04;
  letter-spacing: -.03em;
  font-weight: 900;
  color: #171717;
  max-width: 20ch;
}

.woocommerce-account #share_points > p{
  margin: 0 0 22px;
  max-width: 50ch;
  font-size: 16px;
  line-height: 1.8;
  color: #5f6870;
}

/* formulario */
.woocommerce-account #ywpar-share-points{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 12px;
  padding: 18px 0 8px;
}

.woocommerce-account #ywpar-share-points > span{
  font-size: 16px;
  line-height: 1.5;
  color: #1f2721;
}

.woocommerce-account #ywpar-share-points input[type="number"]{
  width: 120px;
  min-height: 48px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid #dce3dd;
  background: #fbfcfb;
  color: #182018;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  transition: border-color .22s ease, box-shadow .22s ease, background .22s ease;
}

.woocommerce-account #ywpar-share-points input[type="number"]:focus{
  outline: none;
  border-color: #7fb093;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(47, 111, 78, .10);
}

.woocommerce-account #ywpar-share-points .worth-price,
.woocommerce-account #ywpar-share-points .worth-price .amount{
  font-weight: 900;
  color: #2f6f4e;
}

.woocommerce-account #ywpar-share-points__submit{
  min-height: 48px;
  padding: 0 22px;
  border: 0;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-size: 14px;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 12px 26px rgba(0,0,0,.08);
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.woocommerce-account #ywpar-share-points__submit:hover{
  transform: translateY(-1px);
  background: #2f6f4e;
  box-shadow: 0 16px 30px rgba(47, 111, 78, .16);
}

/* errores */
.woocommerce-account .ywpar-share-points-error{
  margin: 12px 0 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.woocommerce-account .ywpar-share-points-error .error{
  display: none;
  padding: 10px 12px;
  border-radius: 12px;
  background: #fff5f5;
  border: 1px solid #f1c9c9;
  color: #b83a3a;
  font-size: 13px;
  line-height: 1.5;
  font-weight: 700;
}

/* si el plugin los muestra inline, quedan bien */
.woocommerce-account .ywpar-share-points-error .error[style*="block"],
.woocommerce-account .ywpar-share-points-error .error[style*="inline"],
.woocommerce-account .ywpar-share-points-error .error:not(:empty){
  display: block;
}

/* ocultar labels visuales pero mantener accesibilidad */
.woocommerce-account #share_points .screen-reader-text{
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  border: 0;
}

/* mobile */
@media (max-width: 768px){
  .woocommerce-account #share_points.ywpar_tabcontent{
    padding: 22px 18px 18px;
    border-radius: 18px;
  }

  .woocommerce-account #share_points h3{
    font-size: 30px;
    max-width: 20ch;
    margin-bottom: 14px;
  }

  .woocommerce-account #share_points > p{
    font-size: 15px;
    line-height: 1.75;
    margin-bottom: 18px;
  }

  .woocommerce-account #ywpar-share-points{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: stretch;
  }

  .woocommerce-account #ywpar-share-points input[type="number"]{
    width: 100%;
    text-align: left;
  }

  .woocommerce-account #ywpar-share-points__submit{
    width: 100%;
    margin-left: 0px !important;
  }
}

/* =========================================================
   CARRITO - ENVÍOS EN TOTALES (SELECTOR REAL)
========================================================= */

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method,
.wooCartAside .cart_totals ul#shipping_method{
  list-style: none !important;
  margin: 10px 0 0 !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li,
.wooCartAside .cart_totals ul#shipping_method li{
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  align-items: center;
  gap: 12px;
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li label,
.wooCartAside .cart_totals ul#shipping_method li label{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  min-height: 58px;
  margin: 0 !important;
  padding: 14px 16px !important;
  border-radius: 14px;
  background: #f7f8f7;
  border: 1px solid #e3e6e3;
  cursor: pointer;
  transition: all .22s ease;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.45;
  color: #1f2a1f;
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li label:hover,
.wooCartAside .cart_totals ul#shipping_method li label:hover{
  background: #f2f5f2;
  border-color: #cdd5cd;
  transform: translateY(-1px);
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li input[type="radio"],
.wooCartAside .cart_totals ul#shipping_method li input[type="radio"]{
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid #c4c9c4;
  background: #fff;
  margin: 0 !important;
  flex: 0 0 18px;
  box-shadow: none;
  position: static;
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li input[type="radio"]:checked,
.wooCartAside .cart_totals ul#shipping_method li input[type="radio"]:checked{
  border-color: #2f6f4e;
  background: #2f6f4e;
  box-shadow: inset 0 0 0 4px #fff;
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li input[type="radio"]:checked + label,
.wooCartAside .cart_totals ul#shipping_method li input[type="radio"]:checked + label{
  background: #eef6f1;
  border-color: #2f6f4e;
}

.wooCartAside .cart_totals.calculated_shipping ul#shipping_method li label .amount,
.wooCartAside .cart_totals ul#shipping_method li label .amount{
  font-weight: 800;
  color: #2f6f4e;
  font-size: 15px;
  white-space: nowrap;
}

.wooCartAside .cart_totals.calculated_shipping .woocommerce-shipping-destination,
.wooCartAside .cart_totals .woocommerce-shipping-destination{
  margin-top: 14px !important;
  font-size: 14px;
  line-height: 1.7;
  color: #5f6870;
}

.wooCartAside .cart_totals.calculated_shipping .woocommerce-shipping-destination strong,
.wooCartAside .cart_totals .woocommerce-shipping-destination strong{
  color: #171717;
}

.wooCartAside .cart_totals.calculated_shipping .shipping-calculator-button,
.wooCartAside .cart_totals .shipping-calculator-button{
  display: inline-block;
  margin-top: 8px;
  color: #2f6f4e;
  font-weight: 700;
  text-decoration: none;
}

.wooCartAside .cart_totals.calculated_shipping .shipping-calculator-button:hover,
.wooCartAside .cart_totals .shipping-calculator-button:hover{
  text-decoration: underline;
}

#yith-par-message-cart{
  margin-left: 20px;
}

/* =========================================================
   CARRITO - YITH POINTS & REWARDS
========================================================= */

.woocommerce-cart .woocommerce-notices-wrapper{
  margin-bottom: 26px;
}

.woocommerce-cart .woocommerce-cart-notice{
  border: 1px solid #e4dcc3 !important;
  background: #f7f0d8 !important;
  color: #8a6516 !important;
  border-radius: 18px !important;
  padding: 18px 20px !important;
  box-shadow: none !important;
}

.woocommerce-cart .woocommerce-cart-notice img{
  vertical-align: middle;
  margin-right: 10px !important;
}

/* bloque de puntos */
.woocommerce-cart #yith-par-message-reward-cart{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px 16px;
}

.woocommerce-cart #yith-par-message-reward-cart form.ywpar_apply_discounts{
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px 12px;
  margin: 0;
  width: 100%;
  font-size: 0; /* elimina huecos raros del texto inline */
  line-height: 1.7;
}

/* texto general */
.woocommerce-cart #yith-par-message-reward-cart form.ywpar_apply_discounts{
  font-size: 16px;
  color: #8a6516;
}

.woocommerce-cart #yith-par-message-reward-cart form.ywpar_apply_discounts > span{
  display: inline-flex;
  align-items: center;
  margin: 0 !important;
}

/* input */
.woocommerce-cart #yith-par-message-reward-cart input[type="text"]#ywpar-points-max,
.woocommerce-cart #yith-par-message-reward-cart .input-text#ywpar-points-max{
  width: 112px !important;
  min-width: 112px;
  height: 46px;
  padding: 0 14px !important;
  border: 1px solid #d8d8d8 !important;
  border-radius: 14px !important;
  background: #fff !important;
  color: #171717 !important;
  font-size: 16px !important;
  font-weight: 800;
  text-align: center;
  box-shadow: none !important;
  outline: none;
  margin: 0 !important;
}

.woocommerce-cart #yith-par-message-reward-cart input[type="text"]#ywpar-points-max:focus,
.woocommerce-cart #yith-par-message-reward-cart .input-text#ywpar-points-max:focus{
  border-color: #2f6f4e !important;
  box-shadow: 0 0 0 3px rgba(47,111,78,.10) !important;
}

/* botón */
.woocommerce-cart #yith-par-message-reward-cart button#ywpar_apply_discounts,
.woocommerce-cart #yith-par-message-reward-cart .button.ywpar_apply_discounts{
  appearance: none;
  border: 0 !important;
  border-radius: 999px !important;
  background: #111111 !important;
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  padding: 15px 24px !important;
  min-height: 46px;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  margin-left: 6px !important;
}

.woocommerce-cart #yith-par-message-reward-cart button#ywpar_apply_discounts:hover,
.woocommerce-cart #yith-par-message-reward-cart .button.ywpar_apply_discounts:hover{
  background: #1b1b1b !important;
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(0,0,0,.14);
}

/* énfasis */
.woocommerce-cart #yith-par-message-reward-cart strong{
  color: #8a6516;
  font-weight: 800;
}

.woocommerce-cart #yith-par-message-reward-cart .amount,
.woocommerce-cart #yith-par-message-reward-cart .woocommerce-Price-amount{
  color: #8a6516 !important;
  font-weight: 800;
}

.woocommerce-cart #yith-par-message-reward-cart .clear{
  display: none !important;
}

/* mensaje de cupón eliminado */
.woocommerce-cart .woocommerce-message{
  border-radius: 18px !important;
  border: 1px solid #cfe0d6 !important;
  background: #eef6f1 !important;
  color: #2f6f4e !important;
  padding: 18px 20px !important;
}

/* mobile */
@media (max-width: 767px){
  .woocommerce-cart #yith-par-message-reward-cart form.ywpar_apply_discounts{
    flex-direction: column;
    align-items: flex-start;
  }

  .woocommerce-cart #yith-par-message-reward-cart input[type="text"]#ywpar-points-max,
  .woocommerce-cart #yith-par-message-reward-cart .input-text#ywpar-points-max{
    width: 100% !important;
    max-width: 180px;
  }

  .woocommerce-cart #yith-par-message-reward-cart button#ywpar_apply_discounts,
  .woocommerce-cart #yith-par-message-reward-cart .button.ywpar_apply_discounts{
    margin-left: 0 !important;
  }
}

.siteHeader__logo {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  max-width: 240px;
}

.siteHeader__logo .custom-logo-link,
.siteHeader__logo a {
  display: inline-flex;
  align-items: center;
}

.siteHeader__logo img,
.siteHeader__logo .custom-logo {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 56px;
  height: auto;
}

@media (max-width: 767px) {
  .siteHeader__logo {
    max-width: 180px;
  }

  .siteHeader__logo img,
  .siteHeader__logo .custom-logo {
    max-height: 42px;
  }
}
.siteHeader__logo img,
.siteHeader__logo .custom-logo {
  max-height: 40px; /* antes 56px */
}

.siteHeader__logo {
  max-width: 200px;
}

.siteFooter__logo img {
  max-height: 60px;
  width: auto;
  display: block;
}

.siteFooter__logo img {
  max-height: 72px;
}

.siteFooter__logo {
  margin-bottom: 20px;
}

.siteFooter__logo img {
  opacity: 0.9;
  transition: all .3s ease;
}

.siteFooter__logo img:hover {
  opacity: 1;
  transform: scale(1.03);
}

/* =========================================================
   FIX REAL MOBILE KOLIBRIE - S24 / móviles grandes
========================================================= */

@media (max-width: 640px){

  .siteMain--home .homeHero.homeHero--premium{
    margin-bottom: 34px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    height: 520px !important;
    min-height: 520px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__media,
  .siteMain--home .homeHero.homeHero--premium .heroSlide__media img{
    height: 100% !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__media img{
    object-fit: cover !important;
    object-position: center center !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__container{
    height: 100% !important;
    align-items: center !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: 520px !important;
    justify-content: center !important;
    padding: 54px 24px 88px !important;
    max-width: 68% !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__title{
    font-size: 40px !important;
    line-height: .94 !important;
    max-width: 9ch !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__subtitle{
    font-size: 14px !important;
    line-height: 1.55 !important;
    max-width: 280px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__actions{
    flex-wrap: nowrap !important;
    gap: 10px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__btn,
  .siteMain--home .homeHero.homeHero--premium .heroSlide__secondaryLink{
    min-height: 46px !important;
    padding: 0 18px !important;
    font-size: 13px !important;
    white-space: nowrap !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroPremiumNav{
    bottom: 22px !important;
  }
}

/* S24 Ultra / móviles altos */
@media (min-width: 390px) and (max-width: 480px){

  .siteMain--home .homeHero.homeHero--premium .heroSlide,
  .siteMain--home .homeHero.homeHero--premium .heroSlide--premium{
    height: 560px !important;
    min-height: 560px !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__content{
    min-height: 560px !important;
    max-width: 62% !important;
  }

  .siteMain--home .homeHero.homeHero--premium .heroSlide__title{
    font-size: 42px !important;
  }
}
