/*
 * cg-preventa.css — Carolina Gammariello / Travele
 * Carga sobre el theme Recife sin pisar sus estilos.
 * Todas las clases llevan prefijo "cg-" para evitar colisiones.
 */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@600;700;800&family=Barlow:ital,wght@0,300;0,400;0,500;1,300&display=swap');

/* =====================================================
   VARIABLES
===================================================== */
:root {
  --cg-cream : #F5F0E8;
  --cg-brown : #3A2E26;
  --cg-camel : #C9A876;
  --cg-black : #0D0D0D;
  --cg-white : #FFFFFF;
  --cg-gray  : #E8E2D9;
  --cg-fd    : 'Barlow Condensed', sans-serif;
  --cg-fb    : 'Barlow', sans-serif;
}

/* =====================================================
   PROMO BAR
===================================================== */
.cg-promobar {
  background: var(--cg-brown);
  color: var(--cg-cream);
  font-family: var(--cg-fb);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: .08em;
  text-align: center;
  padding: 9px 44px;
  min-height: 36px;
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 300;
}
.cg-promobar__msg {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 44px;
  opacity: 0;
  transition: opacity .5s ease;
  pointer-events: none;
}
.cg-promobar__msg.is-active {
  opacity: 1;
  pointer-events: auto;
}
.cg-promobar__link {
  color: var(--cg-camel);
  text-decoration: underline;
  text-underline-offset: 2px;
  margin-left: 6px;
}

/* =====================================================
   HOME — CONTENEDOR GENERAL
===================================================== */
.cg-home {
  background: var(--cg-cream);
  overflow-x: hidden;
}

/* =====================================================
   BOTONES COMPARTIDOS
===================================================== */
.cg-btn {
  display: inline-block;
  font-family: var(--cg-fb);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: lowercase;
  padding: 13px 28px;
  cursor: pointer;
  transition: all .22s ease;
  border: 1px solid transparent;
  text-decoration: none;
}
.cg-btn--cream {
  background: var(--cg-cream);
  color: var(--cg-brown);
  border-color: var(--cg-cream);
}
.cg-btn--cream:hover { background: var(--cg-white); color: var(--cg-brown); text-decoration: none; }
.cg-btn--dark {
  background: var(--cg-brown);
  color: var(--cg-cream);
  border-color: var(--cg-brown);
}
.cg-btn--dark:hover { background: var(--cg-black); border-color: var(--cg-black); color: var(--cg-cream); text-decoration: none; }
.cg-btn--outline {
  background: transparent;
  color: var(--cg-brown);
  border-color: var(--cg-brown);
}
.cg-btn--outline:hover { background: var(--cg-brown); color: var(--cg-cream); text-decoration: none; }
.cg-btn--block { display: block; width: 100%; text-align: center; }

/* =====================================================
   HERO
===================================================== */
.cg-hero {
  position: relative;
  height: 88vh;
  min-height: 540px;
  overflow: hidden;
  background: #EDEAE4;
}
.cg-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}
.cg-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(20,8,4,.00)  0%,
    rgba(20,8,4,.05) 35%,
    rgba(20,8,4,.38) 65%,
    rgba(20,8,4,.72) 100%
  );
}
.cg-hero__body {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 0 24px 38px;
  color: var(--cg-white);
}
.cg-hero__eyebrow {
  font-size: 10px;
  font-weight: 300;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: #C9A876;
  margin-bottom: 12px;
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
}
.cg-hero__title {
  font-family: var(--cg-fd);
  font-size: 56px;
  font-weight: 800;
  text-transform: uppercase;
  line-height: .9;
  margin-bottom: 14px;
  color: #FFF8EF;
  text-shadow: 0 2px 12px rgba(0,0,0,.28);
}
.cg-hero__subtitle {
  font-size: 9.5px;
  font-weight: 400;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,248,239,.7);
  margin-bottom: 10px;
}
.cg-hero__desc {
  font-size: 13px;
  font-weight: 300;
  font-style: italic;
  color: rgba(255,248,239,.82);
  line-height: 1.7;
  max-width: 280px;
  margin-bottom: 28px;
}

/* Botón hero bordeaux */
.cg-btn--bordeaux {
  background   : #6F1D22;
  color        : #FFF8EF;
  border       : none;
}
.cg-btn--bordeaux:hover {
  background     : #591519;
  color          : #FFF8EF;
  text-decoration: none;
}

/* CTA del hero */
.cg-hero__cta {
  display        : block;
  width          : 80%;
  max-width      : 300px;
  text-align     : center;
  font-size      : 11px;
  font-weight    : 600;
  letter-spacing : .2em;
  text-transform : uppercase;
  padding        : 17px 28px;
  box-shadow     : 0 4px 18px rgba(111,29,34,.45);
}

/* Acercar el botón al texto — menos margen bajo el desc */
.cg-hero__desc {
  margin-bottom: 18px;
}

/* Hero body: menos padding inferior para subir el bloque */
.cg-hero__body {
  padding-bottom: 44px;
}

/* =====================================================
   JUST DROPPED
===================================================== */
.cg-dropped { padding-bottom: 52px; background: var(--cg-cream); }
.cg-dropped__badge {
  background: var(--cg-camel);
  color: var(--cg-brown);
  text-align: center;
  font-family: var(--cg-fb);
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
  padding: 7px 16px;
}
.cg-dropped__imgwrap {
  height: 420px;
  overflow: hidden;
  background: #EDEAE4;
}
.cg-dropped__imgwrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.cg-dropped__body { padding: 30px 24px 0; }
.cg-dropped__title {
  font-family: var(--cg-fd);
  font-size: 44px;
  font-weight: 800;
  text-transform: uppercase;
  line-height: .92;
  color: var(--cg-brown);
  margin-bottom: 14px;
}
.cg-dropped__text {
  font-size: 13px;
  font-weight: 300;
  color: var(--cg-brown);
  opacity: .72;
  line-height: 1.7;
  margin-bottom: 8px;
}
.cg-dropped__note {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .1em;
  color: var(--cg-camel);
  margin-bottom: 20px;
}
.cg-dropped__stock {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 22px;
}
.cg-dotpulse {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #8B5E3C;
  flex-shrink: 0;
  animation: cg-pulse 2.2s ease-in-out infinite;
}
@keyframes cg-pulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50%      { opacity: .35; transform: scale(.85); }
}
.cg-dropped__stocklabel {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .06em;
  color: var(--cg-brown);
}

/* =====================================================
   LIFESTYLE BANNER (full-bleed)
===================================================== */
.cg-banner {
  position: relative;
  height: 480px;
  overflow: hidden;
}
.cg-banner__img {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}
.cg-banner__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(160deg, rgba(58,46,38,.18) 0%, rgba(58,46,38,.68) 100%);
}
.cg-banner__body {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 24px;
  color: var(--cg-white);
}
.cg-banner__eye {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .38em;
  text-transform: uppercase;
  color: var(--cg-camel);
  margin-bottom: 14px;
}
.cg-banner__title {
  font-family: var(--cg-fd);
  font-size: 48px;
  font-weight: 800;
  text-transform: uppercase;
  line-height: .9;
  color: var(--cg-white);
  margin-bottom: 14px;
}
.cg-banner__sub {
  font-size: 12px;
  font-weight: 300;
  font-style: italic;
  color: rgba(255,255,255,.78);
  letter-spacing: .06em;
  margin-bottom: 30px;
}

/* =====================================================
   SECTION HEADER COMPARTIDO
===================================================== */
.cg-sechdr {
  text-align: center;
  padding: 44px 24px 30px;
}
.cg-sechdr__eye {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--cg-camel);
  margin-bottom: 8px;
}
.cg-sechdr__title {
  font-family: var(--cg-fd);
  font-size: 36px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .02em;
  line-height: .95;
  color: var(--cg-brown);
}
.cg-sechdr__desc {
  font-size: 13px;
  font-weight: 300;
  color: var(--cg-brown);
  opacity: .65;
  margin-top: 10px;
  line-height: 1.65;
}

/* =====================================================
   URGENCY STRIP
===================================================== */
.cg-urgency {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 24px;
  background: var(--cg-cream);
}
.cg-urgency__line { flex: 1; height: 1px; background: var(--cg-camel); opacity: .5; }
.cg-urgency__txt {
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--cg-brown);
  white-space: nowrap;
}

/* =====================================================
   GRILLA DE CATEGORÍAS
===================================================== */
.cg-pgrid { padding: 0 14px 52px; background: var(--cg-cream); }
.cg-pgrid__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* Card de categoría */
.cg-catcard { background: var(--cg-white); overflow: hidden; }
.cg-catcard__imgwrap {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: #EDEAE4;
}
.cg-catcard__imgwrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .45s ease;
}
.cg-catcard:hover .cg-catcard__imgwrap img { transform: scale(1.05); }

/* Badge de preventa sobre la foto */
.cg-ptag {
  position: absolute;
  top: 9px; left: 9px;
  font-family: var(--cg-fb);
  font-size: 7.5px;
  font-weight: 700;
  letter-spacing: .13em;
  text-transform: uppercase;
  padding: 3px 7px;
}
.cg-ptag--p1 { background: var(--cg-brown); color: var(--cg-cream); }
.cg-ptag--p2 { background: var(--cg-camel); color: var(--cg-brown); }
.cg-ptag--star { background: var(--cg-camel); color: var(--cg-brown); }

/* Info del card */
.cg-catcard__info { padding: 11px 12px 13px; }
.cg-catcard__from {
  font-size: 8.5px;
  font-weight: 400;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cg-brown);
  opacity: .45;
  margin-bottom: 1px;
}
.cg-catcard__name {
  font-family: var(--cg-fd);
  font-size: 15px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  line-height: 1.1;
  color: var(--cg-brown);
  margin-bottom: 4px;
}
.cg-catcard__price {
  font-family: var(--cg-fd);
  font-size: 17px;
  font-weight: 700;
  color: var(--cg-black);
  margin-bottom: 10px;
}
.cg-catcard__btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: 9px 10px;
  font-family: var(--cg-fb);
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: .13em;
  text-transform: lowercase;
  background: var(--cg-brown);
  color: var(--cg-cream);
  border: none;
  cursor: pointer;
  transition: background .2s;
  text-decoration: none;
}
.cg-catcard__btn:hover { background: var(--cg-black); color: var(--cg-cream); text-decoration: none; }
.cg-catcard__btn--camel { background: var(--cg-camel); color: var(--cg-brown); }
.cg-catcard__btn--camel:hover { background: #b8944f; color: var(--cg-brown); }

/* =====================================================
   PRUEBA SOCIAL
===================================================== */
.cg-social {
  background: var(--cg-gray);
  padding: 50px 20px 48px;
}
.cg-social__hdr { text-align: center; margin-bottom: 26px; }
.cg-social__eye {
  font-size: 9px;
  font-weight: 500;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--cg-camel);
  margin-bottom: 6px;
}
.cg-social__title {
  font-family: var(--cg-fd);
  font-size: 28px;
  font-weight: 800;
  text-transform: uppercase;
  line-height: .95;
  color: var(--cg-brown);
}
.cg-social__handle {
  font-size: 11px;
  font-weight: 400;
  color: var(--cg-camel);
  margin-top: 5px;
  letter-spacing: .1em;
}
.cg-social__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 22px;
}
.cg-social__item {
  overflow: hidden;
  background: #D5CEC5;
  aspect-ratio: 1;
}
.cg-social__item--wide {
  grid-column: 1 / -1;
  aspect-ratio: 16/9;
}
.cg-social__item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}
.cg-social__item:hover img { transform: scale(1.04); }
.cg-social__cta { text-align: center; }

/* =====================================================
   BADGE PREVENTA en grilla de productos (category.tpl)
   Usado en snipplets/grid/item.tpl via tags del producto
===================================================== */
.cg-badge {
  display: inline-block;
  font-family: var(--cg-fb);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 3px 8px;
  margin-bottom: 4px;
  line-height: 1.2;
}
.cg-badge--p1 { background: var(--cg-brown); color: var(--cg-cream); }
.cg-badge--p2 { background: var(--cg-camel); color: var(--cg-brown); }

/* =====================================================
   GRILLA DE PRODUCTOS — Category / Search / Collection
   Afecta .template-category, .template-search y
   complementarios en .template-product.
===================================================== */

/* --- Reducir gutters del grid Recife (Bootstrap) --- */
.template-category .js-product-table,
.template-search .js-product-table,
.template-product .js-product-table {
  margin-left  : -4px;
  margin-right : -4px;
}
.template-category .js-product-table .item-product,
.template-search .js-product-table .item-product,
.template-product .js-product-table .item-product {
  padding-left  : 4px;
  padding-right : 4px;
  margin-bottom : 8px;
  border        : none;
  box-shadow    : none;
}

/* --- Imagen: altura uniforme 4:3 (portrait bolsos) --- */
.template-category .item-image,
.template-search .item-image {
  background   : #F0EDE8;
  overflow     : hidden;
  position     : relative;
}
.template-category .item-image .position-relative,
.template-search .item-image .position-relative {
  aspect-ratio   : 3 / 4;
  padding-bottom : 0 !important;
}
.template-category .item-image .img-absolute,
.template-search .item-image .img-absolute {
  position       : absolute;
  inset          : 0;
  width          : 100%;
  height         : 100%;
  object-fit     : contain;
  object-position: center;
}

/* --- Área de texto debajo de la imagen --- */
.template-category .item-description,
.template-search .item-description {
  padding : 8px 6px 10px;
}

/* --- Nombre del producto --- */
.template-category .item-name,
.template-search .item-name {
  font-family    : var(--cg-fd);
  font-size      : 12px;
  font-weight    : 600;
  text-transform : uppercase;
  letter-spacing : .04em;
  line-height    : 1.15;
  color          : var(--cg-brown);
  margin-bottom  : 4px;
  white-space    : nowrap;
  overflow       : hidden;
  text-overflow  : ellipsis;
}

/* --- Precio --- */
.template-category .item-price-container,
.template-search .item-price-container {
  margin-bottom: 4px;
}
.template-category .item-price,
.template-search .item-price {
  font-family : var(--cg-fd);
  font-size   : 15px;
  font-weight : 700;
  color       : var(--cg-brown);
}
.template-category .price-compare,
.template-search .price-compare {
  font-size   : 10px;
  opacity     : .45;
  margin-right: 4px;
}

/* --- Cuotas --- */
.template-category .item-installments,
.template-search .item-installments {
  font-size     : 9px;
  margin-bottom : 2px;
  opacity       : .65;
}

/* --- Botón de acción en la card --- */
.template-category .item-actions,
.template-category .item-actions-inline,
.template-search .item-actions,
.template-search .item-actions-inline {
  margin-top : 6px;
}
.template-category .item-actions a,
.template-category .item-actions button,
.template-category .item-actions input[type="submit"],
.template-search .item-actions a,
.template-search .item-actions button,
.template-search .item-actions input[type="submit"] {
  border-radius  : 0 !important;
  font-family    : var(--cg-fb);
  font-size      : 9.5px;
  font-weight    : 500;
  letter-spacing : .1em;
  text-transform : lowercase;
  padding        : 8px 10px;
  width          : 100%;
}

/* --- Floating elements (labels / badges) --- */
.template-category .item-floating-elements,
.template-search .item-floating-elements {
  top  : 0;
  left : 0;
}

/* --- Relacionados / complementarios en producto — ajuste visual mobile --- */
@media (max-width: 767px) {
  .template-product .section-products-related .item-product {
    padding-left  : 0;
    padding-right : 0;
    border        : none;
    box-shadow    : none;
  }
}

/* --- Encabezado de categoría: más compacto en mobile --- */
@media (max-width: 767px) {
  .category-controls {
    padding-top    : 8px;
    padding-bottom : 8px;
  }
  .page-header {
    padding-top    : 4px;
    padding-bottom : 4px;
    margin-bottom  : 4px !important;
  }
  .page-header h1,
  .page-header .h1,
  .page-header .h2 {
    font-size     : 20px;
    margin-bottom : 2px;
  }
  .category-body {
    margin-top : 4px !important;
  }
  /* breadcrumb compacto */
  .breadcrumb {
    margin-bottom : 2px;
    padding       : 4px 0;
  }
}

/* =====================================================
   NICOLE EDITION — overrides sobre .cg-dropped
===================================================== */
.cg-nicole { background: #EDE8E0; }

.cg-nicole__sub {
  font-size      : 11px;
  font-weight    : 400;
  font-style     : italic;
  letter-spacing : .08em;
  text-transform : none;
  color          : var(--cg-camel);
  margin-bottom  : 8px;
}

.cg-nicole__highlight {
  font-style : italic;
  opacity    : .78;
  margin-top : 10px;
}

.cg-nicole .cg-urgency {
  margin  : 18px 0 22px;
  padding : 0;
}

/* =====================================================
   DESKTOP (breakpoint opcional — Recife usa 768px)
===================================================== */
@media (min-width: 768px) {
  .cg-hero { height: 100vh; max-height: 860px; }
  .cg-hero__title { font-size: 88px; }

  .cg-dropped {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .cg-dropped__badge { grid-column: 1 / -1; }
  .cg-dropped__imgwrap { height: auto; min-height: 520px; }
  .cg-dropped__body {
    padding: 48px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .cg-pgrid { padding: 0 24px 64px; }
  .cg-pgrid__grid { grid-template-columns: repeat(4, 1fr); gap: 12px; }

  .cg-banner { height: 580px; }
  .cg-banner__title { font-size: 64px; }
}


/* =====================================================
   RECIFE GLOBAL OVERRIDE — CG BRAND SYSTEM
   Overrides the Recife theme's CSS variable tokens
   (defined in static/css/style-tokens.tpl) with CG
   brand values. Loads after inline <style> → wins.
===================================================== */

:root {

  /* --- Core palette --- */
  --main-background           : #F5F0E8;
  --main-foreground           : #3A2E26;
  --accent-color              : #C9A876;
  --button-background         : #3A2E26;
  --button-foreground         : #F5F0E8;
  --label-background          : #C9A876;
  --label-foreground          : #3A2E26;

  /* --- Header --- */
  --header-background         : #F5F0E8;
  --header-foreground         : #3A2E26;
  --header-transparent-foreground : #F5F0E8;

  /* --- Ad bar (not used — we have our own promobar) --- */
  --adbar-background          : #3A2E26;
  --adbar-foreground          : #F5F0E8;

  /* --- Newsletter band --- */
  --newsletter-background     : #3A2E26;
  --newsletter-foreground     : #F5F0E8;

  /* --- Footer --- */
  --footer-background         : #3A2E26;
  --footer-foreground         : #F5F0E8;

  /* --- Opacity variants — main-foreground (#3A2E26) --- */
  --main-foreground-opacity-05 : #3A2E260D;
  --main-foreground-opacity-08 : #3A2E2614;
  --main-foreground-opacity-10 : #3A2E261A;
  --main-foreground-opacity-20 : #3A2E2633;
  --main-foreground-opacity-30 : #3A2E264D;
  --main-foreground-opacity-40 : #3A2E2666;
  --main-foreground-opacity-50 : #3A2E2680;
  --main-foreground-opacity-60 : #3A2E2699;
  --main-foreground-opacity-80 : #3A2E26CC;
  --main-foreground-opacity-90 : #3A2E26E6;

  /* --- Opacity variants — main-background (#F5F0E8) --- */
  --main-background-opacity-20 : #F5F0E833;
  --main-background-opacity-30 : #F5F0E84D;
  --main-background-opacity-50 : #F5F0E880;
  --main-background-opacity-60 : #F5F0E899;
  --main-background-opacity-80 : #F5F0E8CC;
  --main-background-opacity-90 : #F5F0E8E6;

  /* --- Opacity variants — accent (#C9A876) --- */
  --accent-color-opacity-20    : #C9A87633;

  /* --- Opacity variants — header foreground (#3A2E26) --- */
  --header-foreground-opacity-20 : #3A2E2633;
  --header-foreground-opacity-30 : #3A2E264D;
  --header-background-opacity-50 : #F5F0E880;
  --header-transparent-foreground-opacity-30 : #F5F0E84D;

  /* --- Opacity variants — footer foreground (#F5F0E8) --- */
  --footer-foreground-opacity-20 : #F5F0E833;
  --footer-foreground-opacity-30 : #F5F0E84D;
  --footer-foreground-opacity-50 : #F5F0E880;
  --footer-foreground-opacity-60 : #F5F0E899;
  --footer-foreground-opacity-80 : #F5F0E8CC;

  /* --- Opacity variant — newsletter foreground (#F5F0E8) --- */
  --newsletter-foreground-opacity-80 : #F5F0E8CC;

  /* --- Typography (+30%) --- */
  --heading-font       : 'Barlow Condensed', sans-serif;
  --body-font          : 'Barlow', sans-serif;
  --title-font-weight  : 700;
  --h1                 : 62px;
  --h2                 : 49px;
  --h3                 : 36px;
  --h4                 : 29px;
  --h5                 : 23px;
  --h6                 : 21px;
  --font-large         : 21px;
  --font-big           : 18px;
  --font-base          : 17px;
  --font-medium        : 16px;
  --font-small         : 14px;
  --font-smallest      : 13px;
}


/* =====================================================
   RECIFE COMPONENT OVERRIDES
===================================================== */

/* --- Page background + base text --- */
body {
  background-color : var(--main-background);
  color            : var(--main-foreground);
  font-family      : var(--body-font);
}

/* --- Headings: condensed, uppercase, tight --- */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family    : var(--heading-font);
  font-weight    : 700;
  text-transform : uppercase;
  letter-spacing : .02em;
  line-height    : .95;
  color          : var(--main-foreground);
}

/* --- Buttons: rectangular, lowercase, brand colors --- */
.btn,
.btn-primary,
.btn-secondary,
.btn-default,
.btn-success {
  border-radius  : 0 !important;
  font-family    : var(--body-font);
  font-weight    : 500;
  letter-spacing : .1em;
  text-transform : lowercase;
  transition     : background .22s ease, border-color .22s ease, color .22s ease;
}
.btn-primary {
  background-color : var(--button-background) !important;
  border-color     : var(--button-background) !important;
  color            : var(--button-foreground) !important;
}
.btn-primary:hover,
.btn-primary:focus {
  background-color : #0D0D0D !important;
  border-color     : #0D0D0D !important;
  color            : #F5F0E8 !important;
}
.btn-secondary,
.btn-default {
  background-color : transparent !important;
  border-color     : var(--main-foreground) !important;
  color            : var(--main-foreground) !important;
}
.btn-secondary:hover,
.btn-default:hover {
  background-color : var(--main-foreground) !important;
  color            : var(--main-background) !important;
}
.btn-link {
  color            : var(--main-foreground);
  font-weight      : 400;
  text-decoration  : underline;
  text-underline-offset : 2px;
}
.btn-link:hover { color: var(--accent-color); }

/* --- Header --- */
.head-main,
.js-head-main {
  background-color : var(--header-background);
  border-bottom    : 1px solid #E8E2D9;
}
.head-main a,
.js-head-main a {
  color: var(--header-foreground);
}

/* --- Desktop navigation --- */
.nav-desktop a,
.nav-desktop-list a {
  font-family    : var(--body-font);
  font-size      : 11px;
  font-weight    : 500;
  letter-spacing : .12em;
  text-transform : uppercase;
  color          : var(--header-foreground);
  text-decoration: none;
  padding-bottom : 2px;
  border-bottom  : 1px solid transparent;
  transition     : border-color .2s, color .2s;
}
.nav-desktop a:hover,
.nav-desktop-list a:hover,
.nav-desktop a.active,
.nav-desktop-list a.active {
  color        : var(--accent-color);
  border-color : var(--accent-color);
  text-decoration: none;
}

/* --- Icons in header (cart, search, account) --- */
.head-main .icon-inline,
.js-head-main .icon-inline {
  color: var(--header-foreground);
}

/* --- Product grid items --- */
.item-product {
  background   : #FFFFFF;
  border       : 1px solid #E8E2D9;
  transition   : box-shadow .25s ease;
}
.item-product:hover {
  box-shadow : 0 4px 20px rgba(58,46,38,.08);
}
.item-name,
.js-item-name {
  font-family    : var(--heading-font);
  font-weight    : 600;
  text-transform : uppercase;
  letter-spacing : .04em;
  font-size      : 13px;
  color          : var(--main-foreground);
}
.item-price,
.js-price-display {
  font-family : var(--heading-font);
  font-weight : 700;
  font-size   : 16px;
  color       : var(--main-foreground);
}
.price-compare {
  color   : var(--main-foreground-opacity-40);
  opacity : 1;
}

/* --- Labels (sale, new, etc.) --- */
.item-floating-elements .label,
.label-primary,
.label-success {
  background-color : var(--label-background);
  color            : var(--label-foreground);
  border-radius    : 0;
  font-family      : var(--body-font);
  font-size        : 8px;
  font-weight      : 700;
  letter-spacing   : .12em;
  text-transform   : uppercase;
}

/* --- Category / page header band --- */
.page-header,
.category-title {
  background  : var(--main-background);
  font-family : var(--heading-font);
  color       : var(--main-foreground);
}

/* --- Breadcrumb --- */
.breadcrumb,
.breadcrumb a {
  font-family : var(--body-font);
  font-size   : 10px;
  letter-spacing: .1em;
  text-transform: lowercase;
  color       : var(--main-foreground-opacity-50);
}
.breadcrumb a:hover { color: var(--main-foreground); }
.breadcrumb-item.active { color: var(--main-foreground); }

/* =====================================================
   PÁGINA DE PRODUCTO — Mejoras CRO
===================================================== */

/* Trust strip debajo del CTA */
.cg-trust-strip {
  display        : flex;
  align-items    : center;
  flex-wrap      : wrap;
  gap            : 4px 0;
  padding        : 10px 0 14px;
  font-family    : var(--cg-fb);
  font-size      : 11px;
  font-weight    : 500;
  letter-spacing : .02em;
  color          : var(--cg-brown);
  border-top     : 1px solid var(--cg-gray);
  margin-top     : -8px;
}
.cg-trust-item {
  display     : inline-flex;
  align-items : center;
  gap         : 5px;
  opacity     : .75;
}
.cg-trust-sep {
  margin  : 0 12px;
  opacity : .3;
  font-weight : 300;
}

/* Descripción del producto: espaciado y tipografía */
.template-product .product-description {
  font-size   : 14px;
  line-height : 1.8;
  color       : var(--cg-brown);
}
.template-product .product-description p {
  margin-bottom : 14px;
}
.template-product .product-description ul,
.template-product .product-description ol {
  padding-left  : 18px;
  margin-bottom : 14px;
}
.template-product .product-description li {
  margin-bottom : 5px;
}
.template-product .product-description strong,
.template-product .product-description b {
  font-weight : 600;
}

/* Separador entre form y descripción */
.template-product #product-description {
  border-top  : 1px solid var(--cg-gray);
  padding-top : 20px;
}

/* Acordeón de medios de pago: borde superior limpio */
.template-product .js-accordion-container {
  border-top    : 1px solid var(--cg-gray);
  padding-top   : 6px;
  margin-top    : 4px;
}

/* --- Product detail page --- */
.product-detail,
.js-product-detail {
  background : var(--main-background);
}
.product-description {
  font-family : var(--body-font);
  font-size   : var(--font-base);
  line-height : 1.75;
  color       : var(--main-foreground);
}

/* --- Dividers --- */
.divider {
  border-color : var(--main-foreground-opacity-10);
}

/* --- Forms: inputs, selects --- */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea,
select,
.form-control,
.form-select {
  font-family   : var(--body-font);
  font-size     : var(--font-base);
  color         : var(--main-foreground);
  background    : #FFFFFF;
  border        : 1px solid #D5CEC5;
  border-radius : 0 !important;
  outline       : none;
  transition    : border-color .2s;
}
input:focus,
textarea:focus,
select:focus,
.form-control:focus,
.form-select:focus {
  border-color : var(--main-foreground);
  box-shadow   : none !important;
}

/* --- Footer --- */
.js-footer,
footer {
  background-color : var(--footer-background);
  color            : var(--footer-foreground);
}
.js-footer a,
footer a {
  color       : var(--footer-foreground-opacity-80);
  font-family : var(--body-font);
  font-size   : var(--font-small);
  letter-spacing: .06em;
}
.js-footer a:hover,
footer a:hover {
  color           : var(--footer-foreground);
  text-decoration : none;
}
.js-footer .subtitle,
footer .subtitle {
  font-family    : var(--heading-font);
  font-weight    : 700;
  font-size      : 11px;
  letter-spacing : .18em;
  text-transform : uppercase;
  color          : var(--footer-foreground);
}
.js-footer .divider,
footer .divider {
  border-color : var(--footer-foreground-opacity-20);
}

/* --- Newsletter band in footer --- */
.js-newsletter,
.newsletter-container {
  background : var(--newsletter-background);
  color      : var(--newsletter-foreground);
}
.newsletter-container input[type="email"] {
  background   : rgba(255,255,255,.1);
  border-color : var(--footer-foreground-opacity-30);
  color        : var(--newsletter-foreground);
}
.newsletter-container input[type="email"]::placeholder {
  color: var(--footer-foreground-opacity-50);
}
.newsletter-container .btn-primary {
  background-color : var(--accent-color) !important;
  border-color     : var(--accent-color) !important;
  color            : var(--main-foreground) !important;
}

/* --- Subcategory / section titles on category page --- */
.subtitle {
  font-family    : var(--heading-font);
  font-weight    : 700;
  letter-spacing : .12em;
  text-transform : uppercase;
}

/* --- Quantity selector --- */
.js-qty-control,
.qty-control {
  border-radius    : 0 !important;
  border-color     : var(--main-foreground-opacity-20);
  background-color : var(--main-background);
  color            : var(--main-foreground);
}

/* --- Cart / notification drawer --- */
.cart-subtotal-title,
.cart-item-name {
  font-family : var(--heading-font);
  font-weight : 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--main-foreground);
}

/* --- Pagination --- */
.pagination .page-link {
  border-radius : 0 !important;
  color         : var(--main-foreground);
  border-color  : var(--main-foreground-opacity-20);
  background    : transparent;
  font-family   : var(--body-font);
  font-size     : var(--font-small);
  letter-spacing: .08em;
}
.pagination .page-item.active .page-link {
  background   : var(--main-foreground);
  border-color : var(--main-foreground);
  color        : var(--main-background);
}
.pagination .page-link:hover {
  background   : var(--main-foreground-opacity-10);
  text-decoration: none;
}

/* --- Accent color use throughout --- */
a {
  color: var(--main-foreground);
}
a:hover {
  color: var(--accent-color);
  text-decoration: none;
}
.text-accent { color: var(--accent-color) !important; }

/* --- Quick shop actions button in grid --- */
.item-actions a,
.item-actions button,
.item-actions-inline a,
.item-actions-inline button {
  border-radius  : 0 !important;
  font-family    : var(--body-font);
  font-weight    : 500;
  letter-spacing : .1em;
  text-transform : lowercase;
}

/* Ocultar breadcrumb en página de producto */
.template-product .breadcrumbs {
  display : none !important;
}


/* =====================================================
   PRECIO PRODUCTO — display agresivo
===================================================== */

/* Precio tachado */
.template-product .price-compare,
.template-product .js-compare-price-display {
  font-size       : 13px !important;
  font-weight     : 500 !important;
  color           : var(--cg-brown) !important;
  opacity         : .4;
  text-decoration : line-through;
  margin-bottom   : 2px;
}

/* Precio principal */
.template-product .js-price-display,
.template-product #price_display {
  font-family : var(--cg-fd) !important;
  font-size   : 34px !important;
  font-weight : 800 !important;
  color       : var(--cg-brown) !important;
  line-height : 1;
}

/* Cuotas — destacado con borde izquierdo */
.template-product .item-installments {
  font-family   : var(--cg-fb) !important;
  font-size     : 14px !important;
  font-weight   : 600 !important;
  color         : var(--cg-brown) !important;
  opacity       : 1 !important;
  border-left   : 3px solid var(--cg-camel) !important;
  padding-left  : 10px !important;
  margin-top    : 8px !important;
  margin-bottom : 2px !important;
  line-height   : 1.45 !important;
}

/* Descuento por transferencia */
.template-product .js-product-discount-container {
  display       : inline-block !important;
  background    : rgba(201,168,118,.15) !important;
  border        : 1px solid rgba(201,168,118,.5) !important;
  border-radius : 6px !important;
  padding       : 5px 10px !important;
  margin-top    : 6px !important;
  font-size     : 13px !important;
  font-weight   : 500 !important;
  color         : var(--cg-brown) !important;
}
.template-product .js-product-discount-container .text-accent {
  font-size   : 15px !important;
  font-weight : 800 !important;
  color       : var(--cg-brown) !important;
}

/* =====================================================
   SUBTÍTULO DE PRODUCTO — Mini XL
===================================================== */
.cg-prod-subtitle {
  font-family    : var(--cg-fd);
  font-size      : 17px;
  font-weight    : 600;
  text-transform : uppercase;
  letter-spacing : .02em;
  color          : var(--cg-brown);
  opacity        : .72;
  margin-top     : -10px;
  margin-bottom  : 16px;
  line-height    : 1.2;
}

/* =====================================================
   CHECKS DE BENEFICIOS — Mini XL (inicio descripción)
===================================================== */
.cg-desc-hero {
  margin-bottom  : 24px;
  padding        : 16px 18px;
  border         : 1px solid #C9B99A;
  border-radius  : 8px;
}
.cg-desc-hero__list {
  list-style     : none;
  padding        : 0;
  margin         : 0;
  display        : flex;
  flex-direction : column;
  gap            : 10px;
}
.cg-desc-hero__list li {
  font-family : var(--cg-fb);
  font-size   : 17px;
  font-weight : 700;
  color       : #3A2E26;
  line-height : 1.45;
}

/* =====================================================
   FAQ ACORDEÓN — Página de producto
===================================================== */
.cg-faq__hdr {
  border-top : 1px solid var(--cg-gray);
  padding    : 10px 0 2px;
  margin-top : 4px;
}
.cg-faq .js-accordion-container {
  margin-bottom : 6px;
}
.cg-faq .js-accordion-toggle .font-weight-bold {
  font-size : 1.4em;
}


/* =====================================================
   GRID PRODUCTOS — imagen 1:1 contain, global
   Aplica en: catálogo, búsqueda, home, relacionados.
   No toca la galería de la ficha de producto.
===================================================== */

/* Cuadrado 1:1 en todos los contextos de grilla */
.item-image .position-relative {
  padding-bottom : 100% !important;
}

/* Imagen centrada con contain y fondo crema */
.item-image .img-absolute {
  object-fit       : contain !important;
  background-color : var(--cg-cream);
}

/* Gutters parejos entre cards */
.js-product-table {
  margin-left  : -6px !important;
  margin-right : -6px !important;
}
.js-product-table .item-product {
  padding-left  : 6px !important;
  padding-right : 6px !important;
  margin-bottom : 16px !important;
}

