/* ============================================================
   Gisel Premium – main.css
   Versión: 3.0 | CSS propio, sin Tailwind
   ============================================================ */

/* ── 1. Variables ── */
:root {
  --azul:       #21515E;
  --coral:      #CF5C57;
  --dorado:     #D4A352;
  --beige:      #FBF9F6;
  --blanco:     #FFFFFF;
  --texto:      #1F2933;
  --suave:      #637381;
  --claro:      #F0EAE1;
  --borde:      rgba(33,81,94,.12);
  --sombra-sm:  0 2px 8px rgba(0,0,0,.07);
  --sombra:     0 6px 24px rgba(0,0,0,.10);
  --sombra-lg:  0 16px 48px rgba(0,0,0,.14);
  --radio:      .75rem;
  --radio-lg:   1.5rem;
  --tr:         all .3s ease;
  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'Montserrat', 'Helvetica Neue', Arial, sans-serif;
  --max-w:      80rem;
  --px:         1.5rem;
}

/* ── 2. Reset & Base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-sans);
  color: var(--texto);
  background: var(--beige);
  overflow-x: hidden;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: var(--font-sans); }

/* ── 3. Tipografía ── */
h1, h2, h3, h4, h5 {
  font-family: var(--font-serif);
  line-height: 1.2;
  color: var(--azul);
  margin-bottom: .5rem;
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); font-weight: 700; }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.8rem); font-weight: 600; }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.8rem); font-weight: 600; }
h4 { font-size: 1.15rem; font-weight: 600; }
p  { margin-bottom: 1rem; color: var(--suave); line-height: 1.75; }
p:last-child { margin-bottom: 0; }
.text-italic { font-style: italic; }
.text-coral  { color: var(--coral); }
.text-dorado { color: var(--dorado); }
.text-azul   { color: var(--azul); }
.text-blanco { color: var(--blanco); }
.text-center { text-align: center; }
.text-sm     { font-size: .875rem; }
.text-xs     { font-size: .75rem; letter-spacing: .08em; }
.font-light  { font-weight: 300; }
.font-bold   { font-weight: 700; }
.tracking    { letter-spacing: .12em; text-transform: uppercase; }

/* ── 4. Layout ── */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 var(--px); }
.container-sm { max-width: 48rem; margin: 0 auto; padding: 0 var(--px); }
.container-md { max-width: 64rem; margin: 0 auto; padding: 0 var(--px); }
.section { padding: 5rem 0; }
.section-sm { padding: 3rem 0; }
.section-lg { padding: 7rem 0; }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.flex-center { display: flex; align-items: center; justify-content: center; }
.flex-between { display: flex; align-items: center; justify-content: space-between; }
.flex-gap { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.mb-sm { margin-bottom: 1rem; }
.mb-md { margin-bottom: 2rem; }
.mb-lg { margin-bottom: 3rem; }
.mt-auto { margin-top: auto; }

/* ── 5. Sección Header / Etiqueta ── */
.section-tag {
  display: inline-flex; align-items: center; gap: .5rem;
  font-size: .7rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--coral); margin-bottom: 1rem;
}
.section-tag::before, .section-tag::after {
  content: ''; display: block; height: 2px; width: 2rem; background: var(--coral);
}
.section-header { text-align: center; margin-bottom: 3.5rem; }
.section-header p { max-width: 38rem; margin: .75rem auto 0; }

/* ── 6. Botones ── */
.btn {
  display: inline-block; font-family: var(--font-sans); font-size: .75rem;
  font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  padding: .9rem 2.5rem; border-radius: 0; cursor: pointer;
  transition: var(--tr); text-align: center; line-height: 1.4;
}
.btn-primary {
  background: var(--coral); color: var(--blanco);
  box-shadow: 0 6px 20px rgba(207,92,87,.3);
}
.btn-primary:hover {
  background: var(--azul); transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(207,92,87,.35);
}
.btn-secondary {
  background: transparent; color: var(--azul);
  border: 2px solid var(--azul);
}
.btn-secondary:hover { background: var(--azul); color: var(--blanco); }
.btn-dorado {
  background: var(--dorado); color: var(--azul);
  box-shadow: 0 6px 20px rgba(212,163,82,.3);
}
.btn-dorado:hover { background: var(--azul); color: var(--blanco); transform: translateY(-2px); }
.btn-blanco {
  background: var(--blanco); color: var(--azul);
}
.btn-blanco:hover { background: var(--dorado); }
.btn-lg { padding: 1.1rem 3rem; font-size: .8rem; }
.btn-full { display: block; width: 100%; text-align: center; }
.btn-rounded { border-radius: 3rem; }

/* ── 7. Navegación ── */
#site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  background: var(--azul); box-shadow: 0 2px 20px rgba(0,0,0,.2);
  transition: padding .3s ease;
}
#main-nav {
  display: flex; align-items: center; justify-content: space-between;
  max-width: var(--max-w); margin: 0 auto; padding: 1.25rem 1.5rem;
}
.nav-logo {
  font-family: var(--font-serif); font-size: 1.5rem; font-style: italic;
  color: var(--blanco); letter-spacing: .05em;
}
.nav-logo span { color: var(--dorado); }
.nav-links { display: flex; align-items: center; gap: 2rem; }
.nav-links a {
  font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.7); transition: var(--tr);
}
.nav-links a:hover { color: var(--dorado); }
.nav-cta { background: var(--coral); color: var(--blanco) !important; padding: .6rem 1.5rem; }
.nav-cta:hover { background: var(--dorado) !important; color: var(--azul) !important; }
.nav-toggle {
  display: none; flex-direction: column; gap: 5px; padding: .5rem; cursor: pointer;
}
.nav-toggle span {
  display: block; width: 22px; height: 2px; background: var(--blanco); transition: var(--tr);
}
#mobile-menu {
  display: none; background: var(--azul); border-top: 1px solid rgba(255,255,255,.1);
}
#mobile-menu.open { display: block; }
#mobile-menu a {
  display: block; padding: .9rem 1.5rem; font-size: .75rem; font-weight: 600;
  letter-spacing: .1em; text-transform: uppercase; color: rgba(255,255,255,.7);
  border-bottom: 1px solid rgba(255,255,255,.05); transition: var(--tr);
}
#mobile-menu a:hover { color: var(--dorado); background: rgba(255,255,255,.05); }
#mobile-menu .nav-cta { background: var(--coral) !important; color: var(--blanco) !important; margin: 1rem; display: block; text-align: center; }

/* ── 8. Hero ── */
.hero {
  min-height: 90vh; display: flex; align-items: center;
  padding: 8rem 0 4rem; background: var(--beige); position: relative; overflow: hidden;
}
.hero-oscuro { background: var(--azul); }
.hero-oscuro h1, .hero-oscuro h2, .hero-oscuro h3 { color: var(--blanco); }
.hero-oscuro p { color: rgba(255,255,255,.7); }
.hero-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.hero-tag {
  font-size: .7rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--dorado); display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem;
}
.hero-tag::before { content: ''; display: block; height: 2px; width: 2rem; background: var(--dorado); }
.hero-titulo { margin-bottom: 1.25rem; }
.hero-subtitulo { font-size: 1.1rem; font-weight: 300; margin-bottom: 2rem; }
.hero-ctas { display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-imagen { position: relative; }
.hero-imagen img {
  border-radius: var(--radio-lg); box-shadow: var(--sombra-lg);
  border: 4px solid rgba(255,255,255,.5);
}
.hero-imagen-marco {
  position: absolute; inset: 0;
  background: var(--dorado); opacity: .2;
  border-radius: var(--radio-lg);
  transform: translate(1rem, 1rem); z-index: -1;
}
.hero-badges { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 1.5rem; }
.badge {
  display: inline-flex; align-items: center; gap: .4rem;
  background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.2);
  border-radius: 2rem; padding: .35rem .85rem;
  font-size: .7rem; font-weight: 600; color: rgba(255,255,255,.85);
}
.badge-light { background: rgba(212,163,82,.12); border-color: var(--dorado); color: var(--azul); }

/* ── 9. Stats bar ── */
.stats-bar { background: var(--blanco); border-bottom: 1px solid var(--borde); }
.stats-bar-inner {
  display: grid; grid-template-columns: repeat(3, 1fr);
}
.stat-item {
  padding: 2rem; text-align: center;
  border-right: 1px solid var(--borde);
}
.stat-item:last-child { border-right: none; }
.stat-num {
  font-family: var(--font-serif); font-size: 2.5rem; color: var(--coral);
  font-weight: 700; display: block;
}
.stat-txt { font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--suave); }

/* ── 10. Tarjetas ── */
.card {
  background: var(--blanco); border-radius: var(--radio);
  border: 1px solid var(--borde); padding: 2rem;
  box-shadow: var(--sombra-sm); transition: var(--tr);
  display: flex; flex-direction: column; overflow: hidden;
}
.card:hover { box-shadow: var(--sombra); transform: translateY(-4px); border-color: rgba(212,163,82,.3); }
.card-icon {
  width: 3.5rem; height: 3.5rem; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem; margin-bottom: 1rem; background: rgba(207,92,87,.1);
}
.card-icon-azul  { background: rgba(33,81,94,.1); }
.card-icon-dorado{ background: rgba(212,163,82,.12); }
.card-num {
  font-family: var(--font-serif); font-size: 3rem; font-weight: 700;
  color: rgba(33,81,94,.1); line-height: 1; margin-bottom: .5rem;
}
.card-title { font-family: var(--font-serif); font-size: 1.3rem; color: var(--azul); margin-bottom: .5rem; }
.card-tag { font-size: .65rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--coral); margin-bottom: .75rem; }
.card-top-line { height: 4px; border-radius: var(--radio) var(--radio) 0 0; margin: -2rem -2rem 1.5rem; }
.card-actions { margin-top: auto; padding-top: 1.5rem; display: flex; flex-direction: column; gap: .75rem; }

/* ── 11. Sección oscura ── */
.bg-azul   { background: var(--azul); }
.bg-beige  { background: var(--beige); }
.bg-blanco { background: var(--blanco); }
.bg-claro  { background: var(--claro); }
.bg-azul h1, .bg-azul h2, .bg-azul h3, .bg-azul h4 { color: var(--blanco); }
.bg-azul p  { color: rgba(255,255,255,.7); }
.bg-azul .section-tag { color: var(--dorado); }
.bg-azul .section-tag::before, .bg-azul .section-tag::after { background: var(--dorado); }

/* ── 12. Beneficios / Features ── */
.feature-list { display: flex; flex-direction: column; gap: 1.25rem; }
.feature-item { display: flex; align-items: flex-start; gap: 1rem; }
.feature-icon {
  width: 2.25rem; height: 2.25rem; border-radius: 50%;
  background: rgba(207,92,87,.15); color: var(--coral);
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem; flex-shrink: 0; margin-top: .15rem;
}
.feature-text strong { display: block; color: var(--azul); font-weight: 600; margin-bottom: .2rem; font-size: .95rem; }

/* ── 13. Testimonios ── */
.testimonio {
  background: var(--blanco); border-radius: var(--radio-lg);
  padding: 2.5rem; box-shadow: var(--sombra-sm);
  border: 1px solid var(--borde); position: relative;
}
.testimonio::before {
  content: '\201C'; font-family: var(--font-serif); font-size: 5rem;
  color: var(--dorado); opacity: .25; position: absolute; top: .5rem; left: 1.5rem;
  line-height: 1;
}
.testimonio-texto { font-style: italic; font-size: 1rem; color: var(--texto); line-height: 1.8; margin-bottom: 1.5rem; }
.testimonio-stars { color: var(--dorado); font-size: .9rem; letter-spacing: .2em; margin-bottom: 1rem; }
.testimonio-autor { display: flex; align-items: center; gap: .75rem; }
.testimonio-avatar {
  width: 2.75rem; height: 2.75rem; border-radius: 50%;
  background: var(--azul); color: var(--dorado);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-serif); font-size: 1.1rem; font-weight: 700; flex-shrink: 0;
}
.testimonio-nombre { font-weight: 700; font-size: .875rem; color: var(--azul); }
.testimonio-cargo  { font-size: .75rem; color: var(--suave); }

/* ── 14. Pilares ALMA ── */
.pilares-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.pilar {
  border-radius: var(--radio); padding: 2rem 1.5rem; text-align: center;
  color: var(--blanco); position: relative; overflow: hidden;
}
.pilar-letra {
  font-family: var(--font-serif); font-size: 5rem; font-weight: 700;
  opacity: .15; position: absolute; bottom: -.5rem; right: .25rem; line-height: 1;
}
.pilar h4 { color: var(--blanco); font-size: 1rem; margin-bottom: .5rem; }
.pilar p  { color: rgba(255,255,255,.75); font-size: .8rem; line-height: 1.6; }
.pilar-1 { background: linear-gradient(135deg, #21515E, #2d6b7f); }
.pilar-2 { background: linear-gradient(135deg, #CF5C57, #b04a45); }
.pilar-3 { background: linear-gradient(135deg, #2d1055, #4a1a8a); }
.pilar-4 { background: linear-gradient(135deg, #b07a10, #D4A352); }

/* ── 15. Formulario ── */
.form-wrap { background: var(--blanco); border-radius: var(--radio-lg); padding: 3rem; box-shadow: var(--sombra-lg); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-group label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--azul); }
.form-group input,
.form-group textarea,
.form-group select {
  background: transparent; border: none; border-bottom: 2px solid var(--borde);
  padding: .75rem 0; font-family: var(--font-sans); font-size: .9rem; color: var(--texto);
  transition: border-color .25s; outline: none; width: 100%;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus { border-bottom-color: var(--dorado); }
.form-group textarea { resize: vertical; min-height: 6rem; }
.form-group select { cursor: pointer; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='%23D4A352'%3E%3Cpath d='M0 0l6 8 6-8z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 0 center; }
.form-consent { display: flex; align-items: flex-start; gap: .75rem; }
.form-consent input { width: auto; margin-top: .2rem; accent-color: var(--coral); }
.form-consent label { font-size: .78rem; color: var(--suave); font-weight: 400; text-transform: none; letter-spacing: 0; cursor: pointer; }
.form-consent a { text-decoration: underline; color: var(--coral); }
#gc-form-message { font-size: .85rem; font-weight: 700; min-height: 1.5rem; }
#gc-form-message.success { color: #2A9D8F; }
#gc-form-message.error   { color: var(--coral); }

/* ── 16. Sección agenda ── */
.agenda-box {
  background: var(--azul); color: var(--blanco); border-radius: var(--radio-lg);
  padding: 4rem; text-align: center; box-shadow: var(--sombra-lg);
}
.agenda-box h2 { color: var(--blanco); margin-bottom: .75rem; }
.agenda-box p  { color: rgba(255,255,255,.7); margin-bottom: 2rem; }
.agenda-embed  { background: rgba(255,255,255,.05); border-radius: var(--radio); padding: 1.5rem; }
.agenda-embed iframe { width: 100%; min-height: 600px; border: none; border-radius: var(--radio); }

/* ── 17. Garantía ── */
.garantia {
  display: flex; align-items: center; gap: 1.5rem;
  background: rgba(212,163,82,.1); border: 1px solid rgba(212,163,82,.3);
  border-radius: var(--radio); padding: 1.5rem 2rem;
}
.garantia-icon { font-size: 2.5rem; flex-shrink: 0; }
.garantia h4 { color: var(--azul); margin-bottom: .25rem; }
.garantia p  { font-size: .85rem; }

/* ── 18. CTA Final ── */
.cta-final {
  background: linear-gradient(135deg, var(--azul) 0%, #132e36 100%);
  padding: 6rem 0; text-align: center; position: relative; overflow: hidden;
}
.cta-final::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 50%, rgba(212,163,82,.1) 0%, transparent 60%),
              radial-gradient(circle at 70% 50%, rgba(207,92,87,.08) 0%, transparent 60%);
}
.cta-final .container { position: relative; z-index: 1; }
.cta-final h2 { color: var(--blanco); }
.cta-final p  { color: rgba(255,255,255,.65); max-width: 36rem; margin: 1rem auto 2.5rem; font-size: 1.1rem; }
.cta-final-price { font-family: var(--font-serif); font-size: 3rem; font-weight: 700; color: var(--dorado); margin-bottom: 1.5rem; }

/* ── 19. Urgencia / Barra superior ── */
.urgencia-bar {
  background: var(--coral); color: var(--blanco); text-align: center;
  padding: .65rem 1rem; font-size: .78rem; font-weight: 600; letter-spacing: .04em;
}
.urgencia-bar strong { color: var(--blanco); }
.urgencia-bar .cupos { color: #FFE87C; font-weight: 700; }

/* ── 20. WooCommerce ── */

/* Wrapper general */
.woocommerce-page .woocommerce {
  padding: 7rem 1.5rem 4rem; max-width: var(--max-w); margin: 0 auto;
}

/* Ocultar sidebar */
.woocommerce-sidebar { display: none !important; }

/* Breadcrumb */
.woocommerce-breadcrumb { font-size: .78rem; color: var(--suave); padding: 1rem 0 2rem; }
.woocommerce-breadcrumb a { color: var(--coral); }

/* ── Botones globales WC ── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
  background: var(--coral) !important; color: var(--blanco) !important;
  border-radius: 0 !important; font-family: var(--font-sans) !important;
  font-size: .72rem !important; font-weight: 700 !important;
  letter-spacing: .1em !important; text-transform: uppercase !important;
  padding: .85rem 2rem !important; border: none !important;
  transition: var(--tr) !important; cursor: pointer !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover { background: var(--azul) !important; }

/* ── Catálogo (lista de productos) ── */
.woocommerce ul.products {
  display: grid !important; grid-template-columns: repeat(3, 1fr) !important;
  gap: 2rem !important; margin: 0 !important; padding: 0 !important;
}
.woocommerce ul.products li.product {
  margin: 0 !important; background: var(--blanco);
  border-radius: var(--radio); overflow: hidden;
  border: 1px solid var(--borde); box-shadow: var(--sombra-sm);
  transition: var(--tr); display: flex !important; flex-direction: column !important;
}
.woocommerce ul.products li.product:hover { box-shadow: var(--sombra); transform: translateY(-4px); }
.woocommerce ul.products li.product img { border-radius: 0; width: 100%; height: 260px; object-fit: cover; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--font-serif); font-size: 1.15rem; color: var(--azul); padding: 1.25rem 1.25rem .4rem;
}
.woocommerce ul.products li.product .price { color: var(--coral); font-weight: 700; padding: 0 1.25rem .75rem; font-size: 1.1rem; }
.woocommerce ul.products li.product .button { margin: auto 1.25rem 1.25rem !important; display: block !important; text-align: center !important; }

/* ── Página de producto individual ── */

.woocommerce div.product {
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  grid-template-rows: auto;
  gap: 0 3rem;
  align-items: start;
}

/* Columna imagen – sticky en desktop */
.woocommerce div.product div.images {
  grid-column: 1;
  grid-row: 1 / 3;
  position: sticky;
  top: 5.5rem;
}
.woocommerce div.product div.images::before { display: none; }
.woocommerce div.product div.images .woocommerce-product-gallery {
  background: var(--claro);
  border-radius: var(--radio-lg);
  padding: 1.5rem;
}
.woocommerce div.product div.images img {
  border-radius: var(--radio) !important;
  box-shadow: var(--sombra) !important;
  width: 100% !important;
  object-fit: contain !important;
  max-height: 480px;
  border: none !important;
}

/* Miniaturas galería */
.woocommerce div.product div.images .flex-control-thumbs {
  display: flex; gap: .5rem; margin-top: .75rem; padding: 0;
}
.woocommerce div.product div.images .flex-control-thumbs li {
  margin: 0; width: calc(25% - .375rem); flex-shrink: 0;
}
.woocommerce div.product div.images .flex-control-thumbs li img {
  border-radius: var(--radio) !important;
  border: 2px solid var(--borde) !important;
  box-shadow: none !important;
  cursor: pointer; opacity: .7; transition: opacity .2s, border-color .2s;
  object-fit: cover !important; max-height: none !important;
}
.woocommerce div.product div.images .flex-control-thumbs li img:hover,
.woocommerce div.product div.images .flex-control-thumbs li img.flex-active {
  opacity: 1; border-color: var(--dorado) !important;
}

/* Columna resumen */
.woocommerce div.product div.summary {
  grid-column: 2;
  grid-row: 1;
  padding: .5rem 0 0;
}

/* Categoría */
.woocommerce div.product .posted_in {
  font-size: .68rem; font-weight: 700; letter-spacing: .15em; text-transform: uppercase;
  color: var(--dorado); display: flex; align-items: center; gap: .5rem; margin-bottom: .75rem;
}
.woocommerce div.product .posted_in::before {
  content: ''; display: block; height: 2px; width: 2rem; background: var(--dorado);
}
.woocommerce div.product .posted_in a { color: var(--dorado); }

/* Título */
.woocommerce div.product h1.product_title {
  font-family: var(--font-serif) !important;
  font-size: clamp(1.8rem, 3vw, 2.6rem) !important;
  font-weight: 700 !important;
  color: var(--azul) !important;
  line-height: 1.2 !important;
  margin-bottom: .75rem !important;
}

/* Estrellas de calificación */
.woocommerce-product-rating {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}
.star-rating {
  position: relative;
  display: inline-block;
  width: 5.8em;
  font-size: .9rem;
  overflow: hidden;
  line-height: 1;
}
.star-rating::before {
  content: '\2605\2605\2605\2605\2605';
  color: #ddd;
  letter-spacing: .15em;
}
.star-rating > span {
  position: absolute;
  top: 0; left: 0;
  overflow: hidden;
  white-space: nowrap;
}
.star-rating > span::before {
  content: '\2605\2605\2605\2605\2605';
  letter-spacing: .15em;
  color: var(--dorado);
}
.woocommerce-review-link {
  font-size: .8rem;
  color: var(--suave);
}
.woocommerce-review-link:hover { color: var(--coral); }

/* Precio con fondo suave */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  display: flex !important;
  align-items: baseline !important;
  gap: 1rem !important;
  margin-bottom: 1.25rem !important;
  padding: .85rem 1.25rem !important;
  background: rgba(207,92,87,.06) !important;
  border-radius: var(--radio) !important;
}
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
  font-size: 1.05rem !important;
  color: var(--suave) !important;
  font-family: var(--font-serif) !important;
  opacity: .7;
}
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
  font-size: 2.2rem !important;
  font-weight: 700 !important;
  font-family: var(--font-serif) !important;
  color: var(--coral) !important;
  text-decoration: none !important;
}
.woocommerce div.product .price bdi { color: inherit; }

/* Descripción corta – sin decoración adicional; el HTML interno ya tiene su propio estilo */
.woocommerce div.product .woocommerce-product-details__short-description {
  margin-bottom: 1.5rem;
}
.woocommerce div.product .woocommerce-product-details__short-description ul {
  list-style: none;
  padding: 0;
}

/* Stock */
.woocommerce div.product .stock {
  font-size: .78rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em;
  color: #2A9D8F; display: flex; align-items: center; gap: .4rem; margin-bottom: 1rem;
}
.woocommerce div.product .stock::before { content: '●'; font-size: .6rem; }

/* Formulario: qty + agregar en misma fila; comprar ahora ocupa fila completa */
.woocommerce div.product form.cart {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-bottom: 1.25rem;
  align-items: stretch;
}
.woocommerce div.product form.cart .quantity {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
}
.woocommerce div.product form.cart .quantity input.qty {
  width: 5rem !important;
  height: 3rem;
  border: 2px solid var(--borde) !important;
  border-radius: var(--radio) !important;
  text-align: center;
  font-size: 1rem;
  font-family: var(--font-sans);
  background: var(--blanco);
  color: var(--texto);
  padding: 0 .5rem;
}
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce .single_add_to_cart_button {
  flex: 1;
  min-width: 160px;
  background: var(--coral) !important;
  color: var(--blanco) !important;
  border-radius: 0 !important;
  font-size: .78rem !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  padding: 0 2rem !important;
  height: 3rem !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 6px 20px rgba(207,92,87,.25) !important;
  transition: var(--tr) !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.woocommerce .single_add_to_cart_button:hover {
  background: var(--azul) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 28px rgba(33,81,94,.2) !important;
}

/* Botón Comprar ahora (hooked) – fila completa */
.woocommerce div.product form.cart .btn-dorado {
  flex: 0 0 100%;
  display: block !important;
}

/* Trust badges */
.wc-trust-badges {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-top: 1.25rem;
  padding: 1rem 1.25rem;
  background: var(--beige);
  border: 1px solid var(--borde);
  border-radius: var(--radio);
}
.wc-trust-badge {
  display: flex; align-items: center; gap: .5rem;
  font-size: .72rem; font-weight: 600; color: var(--azul);
}
.wc-trust-badge .badge-icon { font-size: 1rem; flex-shrink: 0; }

/* Metadatos */
.woocommerce div.product .product_meta {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--borde);
  font-size: .75rem; color: var(--suave);
}
.woocommerce div.product .product_meta span { display: block; margin-bottom: .3rem; }
.woocommerce div.product .product_meta a { color: var(--coral); }

/* Tabs */
.woocommerce div.product .woocommerce-tabs {
  grid-column: 1 / -1;
  margin-top: 4rem;
  border-top: 2px solid var(--borde);
  padding-top: 3rem;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex; gap: 0; margin: 0 0 2.5rem !important; padding: 0 !important;
  border-bottom: 2px solid var(--borde) !important;
  list-style: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { display: none !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  margin: 0 !important; padding: 0 !important; border: none !important;
  background: none !important; border-radius: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--font-sans) !important;
  font-size: .72rem !important; font-weight: 700 !important;
  text-transform: uppercase !important; letter-spacing: .12em !important;
  color: var(--suave) !important;
  padding: .9rem 2rem !important; display: block;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: color .25s, border-color .25s;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--azul) !important;
  border-bottom-color: var(--coral) !important;
}
.woocommerce div.product .woocommerce-tabs .panel {
  padding: 0 !important; background: none !important; border: none !important;
}
.woocommerce div.product .woocommerce-tabs .panel h2 { font-size: 1.5rem; margin-bottom: 1.25rem; }

/* ── Reseñas ── */
.woocommerce-Reviews-title {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  color: var(--azul);
  margin-bottom: 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 2px solid var(--borde);
}
.woocommerce .commentlist {
  list-style: none; padding: 0; margin: 0 0 2.5rem;
}
.woocommerce .commentlist li.comment {
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: 1rem;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--borde);
  align-items: start;
}
.woocommerce .commentlist li.comment:last-child { border-bottom: none; }
.woocommerce .commentlist li.comment img.avatar {
  width: 3rem; height: 3rem; border-radius: 50%; object-fit: cover;
}
.woocommerce .commentlist .star-rating { margin-bottom: .35rem; }
.woocommerce .commentlist p.meta {
  font-size: .78rem; color: var(--suave); margin-bottom: .5rem;
}
.woocommerce .commentlist p.meta strong { color: var(--azul); font-weight: 700; }
.woocommerce .commentlist .description p {
  font-size: .9rem; color: var(--texto); line-height: 1.75; margin: 0;
}
.woocommerce-noreviews {
  color: var(--suave); font-size: .9rem; font-style: italic; padding: .75rem 0;
}

/* Formulario de reseña */
#review_form_wrapper {
  margin-top: 2rem; padding-top: 2rem; border-top: 1px solid var(--borde);
}
#review_form_wrapper h3 {
  font-family: var(--font-serif); font-size: 1.25rem; color: var(--azul); margin-bottom: 1.5rem;
}
#review_form .comment-form {
  display: flex; flex-direction: column; gap: 1.25rem;
}
#review_form .comment-form-rating label,
#review_form .comment-form-comment label,
#review_form .comment-form-author label,
#review_form .comment-form-email label {
  font-size: .72rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--azul); display: block; margin-bottom: .4rem;
}
#review_form .comment-form-rating .stars {
  display: flex; gap: .4rem;
}
#review_form .comment-form-rating .stars a {
  color: #ddd; font-size: 1.5rem; cursor: pointer; transition: color .2s; text-decoration: none;
}
#review_form .comment-form-rating .stars a:hover,
#review_form .comment-form-rating .stars.selected a,
#review_form .comment-form-rating .stars a.active { color: var(--dorado); }
#review_form .comment-form-comment textarea,
#review_form .comment-form-author input[type="text"],
#review_form .comment-form-email input[type="email"] {
  width: 100%; background: transparent; border: none;
  border-bottom: 2px solid var(--borde); padding: .75rem 0;
  font-family: var(--font-sans); font-size: .9rem; color: var(--texto);
  transition: border-color .25s; outline: none;
}
#review_form .comment-form-comment textarea:focus,
#review_form .comment-form-author input:focus,
#review_form .comment-form-email input:focus { border-bottom-color: var(--dorado); }
#review_form .comment-form-comment textarea { min-height: 5rem; resize: vertical; }
#review_form .form-submit { margin: 0; }
#review_form .form-submit input[type="submit"] {
  background: var(--coral) !important; color: var(--blanco) !important;
  border: none !important; padding: .9rem 2.5rem !important;
  font-family: var(--font-sans) !important; font-size: .75rem !important;
  font-weight: 700 !important; text-transform: uppercase !important;
  letter-spacing: .12em !important; cursor: pointer !important;
  transition: var(--tr) !important; display: block !important; width: 100% !important;
}
#review_form .form-submit input[type="submit"]:hover { background: var(--azul) !important; }

/* Productos relacionados */
.related.products {
  grid-column: 1 / -1;
  margin-top: 4rem;
}
.related.products h2 {
  font-family: var(--font-serif); font-size: 2rem; color: var(--azul); margin-bottom: 2rem;
}
.related.products ul.products {
  grid-template-columns: repeat(3, 1fr) !important;
}

/* ── 21. Footer ── */
#site-footer { background: var(--azul); color: rgba(255,255,255,.6); padding: 4rem 0 2rem; }
.footer-inner { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 3rem; margin-bottom: 3rem; }
.footer-brand .nav-logo { font-size: 1.75rem; display: block; margin-bottom: .75rem; }
.footer-brand p { font-size: .85rem; line-height: 1.7; }
.footer-col h5 { font-family: var(--font-sans); font-size: .7rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--dorado); margin-bottom: 1.25rem; }
.footer-col a { display: block; font-size: .85rem; color: rgba(255,255,255,.55); padding: .35rem 0; transition: var(--tr); }
.footer-col a:hover { color: var(--dorado); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.1); padding-top: 1.5rem; display: flex; justify-content: space-between; align-items: center; font-size: .75rem; flex-wrap: wrap; gap: .5rem; }
.footer-bottom .alma { color: var(--dorado); font-weight: 700; text-transform: uppercase; letter-spacing: .1em; }

/* ── 22. WhatsApp flotante ── */
.whatsapp-float {
  position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 200;
  width: 3.5rem; height: 3.5rem; border-radius: 50%;
  background: #25D366; color: var(--blanco); font-size: 1.5rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(37,211,102,.4); transition: var(--tr);
}
.whatsapp-float:hover { transform: scale(1.1); box-shadow: 0 8px 24px rgba(37,211,102,.5); }

/* ── 23. Reveals ── */
.reveal {
  opacity: 0; transform: translateY(24px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: .1s; }
.reveal-delay-2 { transition-delay: .2s; }
.reveal-delay-3 { transition-delay: .3s; }

/* ── 24. Utilidades extra ── */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border-width: 0; }
.separador { height: 2px; width: 3rem; background: var(--dorado); display: block; margin: 1rem auto; }
.separador-izq { margin-left: 0; }
.pill { display: inline-block; background: rgba(212,163,82,.12); color: var(--azul); border: 1px solid rgba(212,163,82,.3); border-radius: 2rem; padding: .3rem .9rem; font-size: .7rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.pill-coral { background: rgba(207,92,87,.1); border-color: rgba(207,92,87,.3); color: var(--coral); }
.faq-item { border: 1px solid var(--borde); border-radius: var(--radio); overflow: hidden; margin-bottom: .75rem; }
.faq-btn { width: 100%; text-align: left; display: flex; justify-content: space-between; align-items: center; padding: 1.1rem 1.5rem; background: var(--blanco); font-weight: 600; font-size: .9rem; color: var(--azul); transition: background .2s; }
.faq-btn:hover { background: var(--beige); }
.faq-icon { font-size: .8rem; color: var(--coral); transition: transform .25s; }
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-answer { display: none; padding: 0 1.5rem 1.25rem; background: var(--beige); }
.faq-item.open .faq-answer { display: block; }
.faq-answer p { font-size: .9rem; }

/* ── 25. Exit Popup / Utilidad ocultar ── */
.hidden { display: none !important; }
#exit-popup {
  position: fixed; inset: 0; z-index: 500;
  align-items: center; justify-content: center; padding: 1rem;
  display: none;
}
#exit-popup:not(.hidden) { display: flex; }
#exit-popup .popup-bg {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
}
#exit-popup .popup-box {
  position: relative; background: var(--blanco);
  border-radius: var(--radio-lg); box-shadow: var(--sombra-lg);
  max-width: 26rem; width: 100%; padding: 2.5rem; text-align: center;
  z-index: 1;
}
#exit-popup .popup-close {
  position: absolute; top: 1rem; right: 1rem;
  color: var(--suave); font-size: 1.1rem;
}

/* ── 26. Responsive ── */
@media (max-width: 1024px) {
  .grid-3    { grid-template-columns: repeat(2, 1fr); }
  .grid-4    { grid-template-columns: repeat(2, 1fr); }
  .pilares-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  .related.products ul.products { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 768px) {
  :root { --px: 1rem; }
  .grid-2 { grid-template-columns: 1fr; }
  .grid-3 { grid-template-columns: 1fr; }
  .grid-4 { grid-template-columns: 1fr; }
  .pilares-grid { grid-template-columns: 1fr 1fr; }
  .hero { padding: 7rem 0 3rem; min-height: auto; }
  .hero-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .hero-imagen { order: -1; }
  .section { padding: 3.5rem 0; }
  .section-lg { padding: 4rem 0; }
  .stats-bar-inner { grid-template-columns: 1fr; }
  .stat-item { border-right: none; border-bottom: 1px solid var(--borde); }
  .stat-item:last-child { border-bottom: none; }
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
  .form-grid { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .garantia { flex-direction: column; text-align: center; }
  .agenda-box { padding: 2.5rem 1.5rem; }
  .agenda-embed iframe { min-height: 400px; }
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
  .woocommerce div.product { grid-template-columns: 1fr !important; }
  .woocommerce div.product div.images {
    position: static !important;
    grid-row: auto !important;
    max-width: 300px;
    margin: 0 auto 1.5rem;
  }
  .woocommerce div.product div.images .woocommerce-product-gallery { padding: 1rem; }
  .woocommerce div.product div.images img { max-height: 320px; }
  .woocommerce div.product div.summary { grid-column: 1 !important; padding: 0 !important; }
  .woocommerce div.product .woocommerce-tabs { grid-column: 1 !important; }
  .related.products { grid-column: 1 !important; }
  .wc-trust-badges { grid-template-columns: 1fr 1fr; }
  /* Botones móvil: Comprar ahora primero, luego qty + Agregar */
  .woocommerce div.product form.cart { flex-direction: column; }
  .woocommerce div.product form.cart .btn-dorado { order: 1; }
  .woocommerce div.product form.cart .single_add_to_cart_button { order: 3; flex: 0 0 auto; height: 2.75rem !important; min-width: auto; }
  .woocommerce div.product form.cart .quantity { order: 2; }
  .woocommerce div.product form.cart .quantity input.qty { width: 100% !important; }
  .woocommerce .commentlist li.comment { grid-template-columns: 2.5rem 1fr; }
  .cta-final { padding: 4rem 0; }
  .form-wrap { padding: 2rem 1.25rem; }
  .woocommerce-page .woocommerce { padding: 5rem 1rem 3rem; }
  .related.products ul.products { grid-template-columns: 1fr !important; }
  #tienda .grid-2 { padding: 1.5rem !important; gap: 1.5rem !important; }
}
@media (max-width: 480px) {
  h1 { font-size: 1.9rem; }
  h2 { font-size: 1.6rem; }
  .pilares-grid { grid-template-columns: 1fr; }
  .hero-ctas { flex-direction: column; }
  .btn { width: 100%; text-align: center; }
}
