/* ════════════════════════════════════════════════════════════════
   APIFLOR · HOME ONE-PAGE
   Estilos: carrusel, grid de categorías, nosotros, blog, contacto, footer
   ════════════════════════════════════════════════════════════════ */

/* ════════════ CARRUSEL (banners) ════════════ */
.carousel {
  position: relative;
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  overflow: hidden;
  background: #FEFAF0;
  border-radius: 16px;
}

.carousel__track {
  width: 100%;
  position: relative;
  aspect-ratio: 1600 / 760;
}

.carousel__slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.8s ease-in-out;
  pointer-events: none;
  display: block;
}
.carousel__slide.is-active { opacity: 1; pointer-events: all; }
.carousel__slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(254,250,240,0.15);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--color-crema);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
  transition: background var(--tr);
  border: 1px solid rgba(254,250,240,0.2);
}
.carousel__arrow:hover { background: var(--color-dorado); color: var(--color-cafe-dark); }
.carousel__arrow--prev { left: var(--space-md); }
.carousel__arrow--next { right: var(--space-md); }

.carousel__dots {
  position: absolute;
  bottom: var(--space-lg);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  z-index: 3;
}
.carousel__dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(254,250,240,0.4);
  cursor: pointer;
  transition: all var(--tr);
}
.carousel__dot.is-active { background: var(--color-dorado); width: 28px; border-radius: 999px; }

/* ════════════ TIENDA — Grid de categorías ════════════ */
.tienda-cats { padding: var(--space-2xl) 0; background: var(--color-crema); }

.cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

.cat-card {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 1;
  display: block;
  text-decoration: none;
  transition: transform var(--tr), box-shadow var(--tr);
  background: var(--color-crema-dk);
  box-shadow: var(--shadow-sm);
}
.cat-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.cat-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.5s ease;
}
.cat-card:hover img { transform: scale(1.04); }

/* ════════════ QUIÉNES SOMOS ════════════ */
.nosotros { padding: var(--space-2xl) 0; background: var(--color-white); }
.nosotros__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: var(--space-2xl);
  align-items: start;
  margin-bottom: var(--space-2xl);
}
.nosotros__text { font-size: var(--fs-body); color: var(--color-texto-mut); margin-bottom: var(--space-md); line-height: 1.7; }
.nosotros__text strong { color: var(--color-cafe); font-weight: 700; }

.nosotros__list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-lg) 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.nosotros__list li {
  display: block;
  font-size: var(--fs-body);
  color: var(--color-texto-mut);
  line-height: 1.6;
  position: relative;
  padding-left: 22px;
}

.nosotros__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-dorado);
}
.nosotros__list li strong { color: var(--color-cafe); font-weight: 700; }

.nosotros__buttons { display: flex; flex-direction: column; gap: var(--space-sm); margin-top: var(--space-lg); }

.info-btn {
  display: block;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-crema);
  border: 1px solid var(--color-borde);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: all var(--tr);
  text-align: center;
}
.info-btn:hover { border-color: var(--color-dorado); background: #fff; transform: translateY(-2px); box-shadow: var(--shadow-md); }
.info-btn strong { display: block; color: var(--color-cafe); font-size: 1rem; }
.info-btn span { display: block; font-size: 0.8rem; color: var(--color-texto-mut); margin-top: 2px; }

.nosotros__media-col {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.nosotros__media { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/3; }
.nosotros__media img { width: 100%; height: 100%; object-fit: cover; }

.nosotros__gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-md);
}
.nosotros__gallery-item {
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  box-shadow: var(--shadow-sm);
}
.nosotros__gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform 0.5s ease;
}

.nosotros__gallery-item:last-child img {
  object-position: 50% 15%;
}
.nosotros__gallery-item:hover img { transform: scale(1.05); }

@media (max-width: 1024px) {
  .nosotros__grid { grid-template-columns: 1fr; gap: var(--space-lg); }
  .nosotros__gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .nosotros__gallery { grid-template-columns: repeat(2, 1fr); gap: var(--space-sm); }
}

/* ════════════ BLOG ════════════ */
.blog { padding: var(--space-2xl) 0; background: var(--color-crema); }
.blog-cats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-md);
  margin-bottom: var(--space-lg);
}
.blog-cat {
  background: var(--color-white);
  border: 1px solid var(--color-borde);
  border-radius: var(--radius-md);
  padding: var(--space-lg) var(--space-md);
  text-align: center;
  text-decoration: none;
  transition: all var(--tr);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.blog-cat:hover { border-color: var(--color-dorado); transform: translateY(-4px); box-shadow: var(--shadow-md); }
.blog-cat__icon { font-size: 1.75rem; }
.blog-cat__name { font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--color-cafe); line-height: 1.2; }
.blog-cat__sub { font-size: 0.78rem; color: var(--color-texto-mut); }
.blog-soon { text-align: center; color: var(--color-texto-mut); font-size: 0.95rem; }
.blog-soon a { color: var(--color-dorado-dk); font-weight: 600; }

/* ════════════ CONTACTO ════════════ */
.contacto { padding: var(--space-2xl) 0; background: var(--color-white); }
.contacto__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-2xl); align-items: start; }
.contacto__subtitle { font-family: var(--font-display); font-size: 1.35rem; color: var(--color-cafe); margin-bottom: var(--space-md); }

.contacto__channel {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) 0;
  text-decoration: none;
  transition: transform var(--tr);
}
.contacto__channel:hover { transform: translateX(4px); }
.contacto__channel-icon {
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--color-crema-dk);
  color: var(--color-dorado-dk);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.contacto__channel-info { display: flex; flex-direction: column; font-size: 0.95rem; color: var(--color-texto); }
.contacto__channel-info strong { color: var(--color-cafe); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; }

.contacto__location { margin-top: var(--space-lg); padding-top: var(--space-lg); border-top: 1px solid var(--color-borde); }
.contacto__location h4 { font-family: var(--font-display); color: var(--color-cafe); margin-bottom: var(--space-xs); font-size: 1.1rem; }
.contacto__location p { font-size: 0.9rem; color: var(--color-texto-mut); line-height: 1.6; }

.contacto__form-wrap { background: var(--color-crema); padding: var(--space-lg); border-radius: var(--radius-lg); border: 1px solid var(--color-borde); }
.form-field { margin-bottom: var(--space-md); }
.form-field label { display: block; font-size: 0.85rem; font-weight: 700; color: var(--color-cafe); margin-bottom: 6px; }
.form-field input, .form-field textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--color-borde);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--color-texto);
  background: #fff;
  transition: border-color var(--tr);
}
.form-field input:focus, .form-field textarea:focus { outline: none; border-color: var(--color-dorado); }
.form-field textarea { resize: vertical; }
.form-submit { width: 100%; }
.form-status { text-align: center; font-size: 0.9rem; margin-top: var(--space-sm); }
.form-status.success { color: var(--color-verde-dk); }
.form-status.error { color: #B91C1C; }

/* ════════════ FOOTER — franja de confianza ════════════ */
.footer-trust { background: var(--color-cafe); border-bottom: 1px solid rgba(254,250,240,0.1); }
.footer-trust__inner { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-lg); padding: var(--space-lg) var(--container-pad); }
.footer-trust__item { display: flex; align-items: center; gap: var(--space-md); color: var(--color-crema); }
.footer-trust__item svg { color: var(--color-dorado); flex-shrink: 0; }
.footer-trust__item strong { display: block; font-size: 0.95rem; }
.footer-trust__item span { display: block; font-size: 0.8rem; color: rgba(254,250,240,0.6); }

.footer__inner--3col { grid-template-columns: 1.5fr 1.3fr 1fr; }

/* ════════════ RESPONSIVE ════════════ */
@media (max-width: 1024px) {
  .cat-grid { grid-template-columns: repeat(3, 1fr); }
  .blog-cats { grid-template-columns: repeat(3, 1fr); }
  .nosotros__grid { grid-template-columns: 1fr; gap: var(--space-lg); }
  .contacto__grid { grid-template-columns: 1fr; gap: var(--space-lg); }
  .footer__inner--3col { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 768px) {
  .carousel { aspect-ratio: 16 / 9; margin-bottom: 0; }
  .carousel__arrow { width: 38px; height: 38px; }
  .carousel__arrow--prev { left: 8px; }
  .carousel__arrow--next { right: 8px; }
  .cat-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-sm); }
  .tienda-cats { padding: var(--space-lg) 0; }
  .blog-cats { grid-template-columns: repeat(2, 1fr); }
  .footer-trust__inner { grid-template-columns: 1fr; gap: var(--space-md); }
  .footer__inner--3col { grid-template-columns: 1fr; }
  .nav__proadech { display: none; }
}

@media (max-width: 480px) {
  .cat-grid { grid-template-columns: 1fr 1fr; }
  .blog-cats { grid-template-columns: 1fr; }
  .cat-card__name { font-size: 1.2rem; }
}

/* ════════════════════════════════════════════════════════════════
   MODAL DE PRODUCTO
   ════════════════════════════════════════════════════════════════ */
.pm-overlay {
  position: fixed; inset: 0;
  background: rgba(26,14,0,0.55);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
  z-index: 250;
}
.pm-overlay.is-open { opacity: 1; pointer-events: all; }

.product-modal {
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%, -48%) scale(0.96);
  width: calc(100% - 2rem);
  max-width: 980px;
  max-height: 92vh;
  overflow-y: auto;
  background: var(--color-crema);
  border-radius: var(--radius-lg);
  z-index: 251;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 30px 80px rgba(60,30,10,0.35);
}
.product-modal.is-open { opacity: 1; pointer-events: all; transform: translate(-50%, -50%) scale(1); }

.pm-close {
  position: absolute; top: 14px; right: 14px;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.9); color: var(--color-cafe);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 5; transition: background var(--tr);
}
.pm-close:hover { background: #fff; }

.pm-grid { display: grid; grid-template-columns: 1fr 1.05fr; }

.pm-media {
  background: radial-gradient(ellipse at center, #fff 0%, var(--color-crema-dk) 100%);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-2xl) var(--space-xl);
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
  min-height: 500px;
}
.pm-media img {
  width: 100%; height: auto; max-height: 520px;
  object-fit: contain;
  filter: drop-shadow(0 16px 32px rgba(60,30,10,0.22));
  transition: opacity 0.2s;
}

.pm-info { padding: var(--space-2xl) var(--space-xl); display: flex; flex-direction: column; }
.pm-tag {
  display: inline-block; align-self: flex-start;
  font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--color-dorado-dk); background: rgba(232,168,0,0.15);
  padding: 6px 14px; border-radius: 999px; margin-bottom: var(--space-md);
}
.pm-name {
  font-family: var(--font-display); font-size: 2.1rem; font-weight: 900;
  color: var(--color-cafe); line-height: 1.1; margin-bottom: var(--space-md);
  letter-spacing: -0.01em;
}
.pm-desc {
  font-size: 1rem; line-height: 1.65;
  color: var(--color-texto); margin-bottom: var(--space-md);
}
.pm-origen {
  font-size: 0.9rem; line-height: 1.6; color: var(--color-texto-mut);
  border-left: 3px solid var(--color-dorado); padding-left: 14px;
  margin-bottom: var(--space-lg); font-style: italic;
}
.pm-label {
  font-size: 0.9rem; font-weight: 700;
  color: var(--color-cafe); margin-bottom: 10px;
  text-transform: uppercase; letter-spacing: 0.05em;
}

.pm-presentaciones { display: flex; flex-direction: column; gap: 10px; margin-bottom: var(--space-lg); }
.pm-pres {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px; background: #fff;
  border: 1.5px solid var(--color-borde); border-radius: var(--radius-md);
  cursor: pointer; transition: all var(--tr); text-align: left;
}
.pm-pres:hover { border-color: var(--color-dorado); transform: translateX(2px); }
.pm-pres.is-active { border-color: var(--color-cafe); background: var(--color-crema-dk); box-shadow: 0 2px 8px rgba(60,30,10,0.08); }
.pm-pres__label { font-size: 0.95rem; font-weight: 600; color: var(--color-texto); }
.pm-pres__price { font-family: var(--font-display); font-size: 1.2rem; font-weight: 700; color: var(--color-cafe); }

.pm-buy { display: flex; gap: 12px; margin-top: auto; align-items: stretch; }
.pm-qty {
  display: flex; align-items: center; gap: 4px;
  border: 1.5px solid var(--color-borde); border-radius: var(--radius-md);
  background: #fff; padding: 0 4px;
}
.pm-qty button {
  width: 34px; height: 100%; min-height: 44px;
  background: transparent; color: var(--color-cafe);
  font-size: 1.2rem; font-weight: 700; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.pm-qty button:hover { color: var(--color-dorado-dk); }
.pm-qty span { min-width: 28px; text-align: center; font-weight: 700; color: var(--color-cafe); }
.pm-add { flex: 1; white-space: nowrap; }

@media (max-width: 700px) {
  .pm-grid { grid-template-columns: 1fr; }
  .pm-media { border-radius: var(--radius-lg) var(--radius-lg) 0 0; padding: var(--space-lg); }
  .pm-media img { max-height: 240px; }
  .pm-info { padding: var(--space-lg); }
  .pm-name { font-size: 1.4rem; }
  .pm-buy { flex-direction: column; }
}

/* ════════════════════════════════════════════════════════════════
   MODAL EN MODO COTIZACIÓN (mayoreo)
   ════════════════════════════════════════════════════════════════ */

/* Ocultar el selector de cantidad cuando es cotización */
.product-modal.is-cotizacion .pm-qty {
  display: none;
}

/* Botón verde tipo WhatsApp cuando es cotización */
.product-modal.is-cotizacion .pm-add {
  background: #25D366;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product-modal.is-cotizacion .pm-add:hover {
  background: #1FAD53;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

/* Pill "Cotizar" en lugar de precio */
.pm-pres__price--quote {
  background: var(--color-verde, #5C8A1E);
  color: #fff;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* ════════════════════════════════════════════════════════════════
   BOTÓN WHATSAPP EN CARRITO
   ════════════════════════════════════════════════════════════════ */
.btn--whatsapp {
  background: #25D366;
  color: #fff;
  border: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  margin-top: 10px;
}
.btn--whatsapp:hover {
  background: #1FAD53;
  transform: translateY(-1px);
}

/* ════════════════════════════════════════════════════════════════
   MODAL DE COTIZACIÓN DE ENVÍO
   ════════════════════════════════════════════════════════════════ */
.quote-overlay {
  position: fixed; inset: 0;
  background: rgba(26,14,0,0.55);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
  z-index: 300;
}
.quote-overlay.is-open { opacity: 1; pointer-events: all; }

.quote-modal {
  position: fixed;
  top: 50%; left: 50%;
  transform: translate(-50%, -48%) scale(0.96);
  width: calc(100% - 2rem);
  max-width: 720px;
  max-height: 92vh;
  overflow-y: auto;
  background: var(--color-crema);
  border-radius: var(--radius-lg);
  z-index: 301;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 30px 80px rgba(60,30,10,0.35);
}
.quote-modal.is-open {
  opacity: 1; pointer-events: all;
  transform: translate(-50%, -50%) scale(1);
}

.quote-close {
  position: absolute; top: 14px; right: 14px;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.9);
  color: var(--color-cafe);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; z-index: 5;
  border: none;
  transition: background var(--tr);
}
.quote-close:hover { background: #fff; }

.quote-modal__head {
  padding: var(--space-xl) var(--space-xl) var(--space-md);
  border-bottom: 1px solid var(--color-borde);
}
.quote-modal__title {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 900;
  color: var(--color-cafe);
  margin: 0 0 8px 0;
  line-height: 1.15;
}
.quote-modal__sub {
  font-size: 0.92rem;
  color: var(--color-texto-mut);
  margin: 0;
  line-height: 1.5;
}

.quote-modal__body {
  padding: var(--space-lg) var(--space-xl) var(--space-xl);
}

/* Resumen del pedido */
.quote-resumen {
  background: #fff;
  border: 1px solid var(--color-borde);
  border-radius: var(--radius-md);
  padding: var(--space-md);
  margin-bottom: var(--space-lg);
}
.quote-resumen h4 {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-cafe);
  margin: 0 0 10px 0;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.quote-resumen ul {
  list-style: none;
  padding: 0;
  margin: 0 0 12px 0;
}
.quote-resumen li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.88rem;
  color: var(--color-texto);
  padding: 6px 0;
  border-bottom: 1px dashed var(--color-borde);
}
.quote-resumen li:last-child { border-bottom: none; }
.quote-resumen li .qr-item-name { flex: 1; padding-right: 8px; }
.quote-resumen li .qr-item-qty {
  color: var(--color-texto-mut);
  font-size: 0.8rem;
  margin-right: 10px;
}
.quote-resumen li .qr-item-price {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--color-cafe);
}
.quote-resumen__total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  border-top: 2px solid var(--color-cafe);
  font-size: 0.95rem;
  color: var(--color-cafe);
}
.quote-resumen__total strong {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 900;
}

/* Formulario */
.quote-form__row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}
.quote-form__row--2 { grid-template-columns: 1fr 1fr; }
.quote-form__row--3 { grid-template-columns: 1fr 1fr 0.6fr; }

.quote-field { display: flex; flex-direction: column; }
.quote-field label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-cafe);
  margin-bottom: 6px;
}
.quote-field input,
.quote-field textarea {
  width: 100%;
  padding: 11px 13px;
  border: 1px solid var(--color-borde);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 0.92rem;
  color: var(--color-texto);
  background: #fff;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.quote-field input:focus,
.quote-field textarea:focus {
  outline: none;
  border-color: var(--color-dorado);
  box-shadow: 0 0 0 3px rgba(232,168,0,0.15);
}
.quote-field textarea { resize: vertical; min-height: 60px; }

.quote-submit {
  width: 100%;
  margin-top: var(--space-sm);
}
.quote-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.quote-status {
  text-align: center;
  margin-top: var(--space-md);
  font-size: 0.92rem;
  min-height: 1.4em;
}
.quote-status.success { color: var(--color-verde-dk, #1B7F2A); font-weight: 600; }
.quote-status.error { color: #B91C1C; font-weight: 600; }

@media (max-width: 600px) {
  .quote-modal__head { padding: var(--space-lg) var(--space-lg) var(--space-md); }
  .quote-modal__body { padding: var(--space-md) var(--space-lg) var(--space-lg); }
  .quote-modal__title { font-size: 1.3rem; }
  .quote-form__row--2,
  .quote-form__row--3 { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════════════════════════════
   PAYMENT BADGES (confianza de pago)
   ════════════════════════════════════════════════════════════════ */
.payment-badges {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-borde);
  text-align: center;
}

.payment-badges__title {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-verde-dk, #1B7F2A);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 10px;
}

.payment-badges__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}

.payment-logo {
  display: inline-flex;
  align-items: center;
  height: 24px;
  filter: grayscale(0%) opacity(0.95);
  transition: filter var(--tr);
}
.payment-logo:hover { filter: grayscale(0%) opacity(1); }
.payment-logo svg { height: 24px; width: auto; display: block; }

.payment-logo--mp img { height: 28px; width: auto; }
.payment-logo--visa img { height: 22px; width: auto; background: #fff; padding: 3px 6px; border-radius: 4px; border: 1px solid #E5DCC8; }
.payment-logo--mc img { height: 28px; width: auto; }
.payment-logo--amex img { height: 24px; width: auto; border-radius: 4px; }
.btn-wa-logo { height: 22px; width: auto; display: inline-block; vertical-align: middle; }

.payment-badges__note {
  font-size: 0.72rem;
  color: var(--color-texto-mut);
  margin: 8px 0 0;
  font-style: italic;
}

/* Variante para el modal de cotización */
.payment-badges--modal {
  margin-top: var(--space-lg);
  background: rgba(232,168,0,0.04);
  padding: var(--space-md);
  border-radius: var(--radius-md);
  border-top: none;
  border: 1px solid rgba(232,168,0,0.2);
}

@media (max-width: 768px) {
  .nav.is-open {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100vh;
    background: var(--color-crema);
    z-index: 200;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: var(--space-lg);
  }
  .nav.is-open .nav__list {
    flex-direction: column;
    align-items: center;
    gap: var(--space-lg);
  }
  .nav.is-open .nav__link {
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--color-cafe);
  }
  .nav__toggle {
    z-index: 201;
    position: relative;
  }
  .nav__toggle.is-active {
    position: fixed;
    top: 20px;
    right: var(--container-pad);
  }
}
