/* ============================================================
   RIVERLINE — Hoja de estilos principal
   Implementación propia que respeta los tokens visuales
   documentados en docs/visual-tokens.md
   ============================================================ */

/* ----- TOKENS ----- */
:root {
  /* Tipografías (Google Fonts) */
  --font-1: 'Barlow', system-ui, -apple-system, sans-serif;          /* body, nav, links */
  --font-2: 'Jost', system-ui, -apple-system, sans-serif;            /* headings, botones */

  /* Tamaños base */
  --fs-body: 16px;
  --fs-heading: 28px;
  --fs-page-title: 28px;
  --fs-menu-lv1: 15px;
  --fs-menu-lv2: 15px;
  --fs-product-title: 18px;
  --fs-product-vendor: 14px;
  --fs-product-price: 16px;
  --fs-button: 16px;
  --fs-button-3: 14px;
  --fs-footer-heading: 16px;
  --fs-footer-link: 16px;

  /* Pesos */
  --fw-body: 400;
  --fw-heading: 700;
  --fw-menu: 400;
  --fw-megamenu-lv2: 600;
  --fw-button: 700;
  --fw-button-3: 800;
  --fw-product-title: 400;
  --fw-product-vendor: 700;
  --fw-product-price: 700;
  --fw-footer-heading: 800;

  /* Line-heights */
  --lh-body: 1.5;
  --lh-heading: 36px;
  --lh-menu: 22px;
  --lh-footer-heading: 22px;
  --lh-footer-link: 36px;

  /* Letter spacing */
  --ls-menu-lv1: 0.05em;
  --ls-menu-lv2: 0.02em;
  --ls-page-title: 0.05em;
  --ls-footer-heading: 0.02em;

  /* Colores texto */
  --c-text:        #232323;
  --c-text-2:      #969696;
  --c-text-grey:   #868686;
  --c-link:        #232323;
  --c-link-hover:  #232323;

  /* Colores marca */
  --c-purple-primary:  #572582;  /* dots active del slideshow */
  --c-purple-dark:     #240b38;  /* header bg, arrow bg */
  --c-purple-medium:   #613489;  /* arrow hover */
  --c-purple-light:    #a180b9;
  --c-purple-button:   #230a3e;  /* press banner button */
  --c-purple-hover:    #8159b1;  /* press banner hover */
  --c-purple-divider:  #522583;
  --c-purple-text:     #573c6e;  /* títulos de bloques producto */
  --c-purple-260:      #260f40;  /* border title style */

  /* Producto */
  --c-product-hover:   #4e90d9;
  --c-product-sale:    #f6231a;
  --c-product-compare: #969696;
  --c-product-stock:   #d62828;

  /* Backgrounds */
  --c-bg:        #ffffff;
  --c-bg-soft:   #f5f4f5;       /* press_bg */
  --c-bg-grey:   #fafafa;
  --c-line:      #e8e8e8;

  /* Anchos máximos */
  --w-body:      1800px;
  --w-section:   1600px;
  --w-narrow:    1170px;        /* container 1170 (brand slider, press banner) */

  /* Spacings de secciones */
  --section-py:  60px;
  --section-py-mb: 40px;
}

/* ----- RESET MÍNIMO ----- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  padding: 0;
  font-family: var(--font-1);
  font-size: var(--fs-body);
  font-weight: var(--fw-body);
  line-height: var(--lh-body);
  letter-spacing: 0;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { max-width: 100%; height: auto; display: block; }
button { font: inherit; cursor: pointer; }
a { color: var(--c-link); text-decoration: none; transition: color .2s; }
a:hover { color: var(--c-link-hover); }
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-2);
  font-weight: var(--fw-heading);
  line-height: var(--lh-heading);
  margin: 0;
  color: var(--c-text);
  letter-spacing: 0em;
}
ul, ol { list-style: none; margin: 0; padding: 0; }
p { margin: 0; }
input, select, textarea { font: inherit; color: inherit; }

/* ----- CONTENEDORES ----- */
.rvl-container        { max-width: var(--w-section); margin: 0 auto; padding: 0 30px; }
.rvl-container-wide   { max-width: var(--w-body);    margin: 0 auto; padding: 0 30px; }
.rvl-container-narrow { max-width: var(--w-narrow);  margin: 0 auto; padding: 0 30px; }

/* ============================================================
   TOPBAR (announcement bar)
   ============================================================ */
.rvl-topbar {
  background: var(--c-purple-dark);
  color: rgba(255,255,255,.85);
  font-size: 12px;
  font-family: var(--font-1);
}
.rvl-topbar__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 38px;
  max-width: var(--w-body);
  margin: 0 auto;
  padding: 0 30px;
  gap: 20px;
}
.rvl-topbar a { color: inherit; }
.rvl-topbar a:hover { color: #fff; }
.rvl-topbar__right { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }

/* ============================================================
   HEADER
   ============================================================ */
.rvl-header {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--c-purple-dark);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.rvl-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 36px;
  height: 88px;
  max-width: var(--w-body);
  margin: 0 auto;
  padding: 0 30px;
}
.rvl-header__hamburger {
  display: none;
  background: none;
  border: none;
  width: 36px;
  height: 36px;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  padding: 0;
}
.rvl-header__hamburger span {
  display: block;
  width: 26px;
  height: 2px;
  background: #fff;
}

.rvl-header__logo { display: flex; align-items: center; flex-shrink: 0; }
.rvl-header__logo img { height: 44px; width: auto; max-width: 200px; object-fit: contain; }

.rvl-nav { justify-self: center; }
.rvl-nav__list { display: flex; gap: 0; align-items: center; }
.rvl-nav__item { position: relative; }
.rvl-nav__link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 32px 22px;
  font-family: var(--font-1);
  font-size: var(--fs-menu-lv1);
  font-weight: var(--fw-menu);
  line-height: var(--lh-menu);
  text-transform: uppercase;
  letter-spacing: var(--ls-menu-lv1);
  color: #cdc6d6;
  text-decoration: none;
}
.rvl-nav__link:hover { color: #fff; }
.rvl-nav__caret { font-size: 9px; line-height: 1; }

/* Mega menu */
.rvl-megamenu {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  min-width: 240px;
  background: #fff;
  padding: 22px 28px;
  box-shadow: 0 22px 50px -18px rgba(0,0,0,.35);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .25s, visibility .25s, transform .25s;
  z-index: 200;
}
.rvl-nav__item:hover .rvl-megamenu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.rvl-megamenu ul { display: flex; flex-direction: column; gap: 0; }
.rvl-megamenu a {
  display: block;
  padding: 9px 6px;
  font-family: var(--font-1);
  font-size: var(--fs-menu-lv2);
  font-weight: var(--fw-megamenu-lv2);
  line-height: 20px;
  letter-spacing: var(--ls-menu-lv2);
  text-transform: capitalize;
  color: var(--c-text);
}
.rvl-megamenu a:hover { color: var(--c-purple-primary); }
.rvl-megamenu__title {
  font-family: var(--font-1);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--c-text-2);
  margin: 0 0 10px;
}
.rvl-megamenu__brands {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--c-line);
}

/* Header icons */
.rvl-header__icons { display: flex; align-items: center; gap: 8px; justify-self: end; }
.rvl-header__icon-btn {
  background: none;
  border: none;
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  cursor: pointer;
  border-radius: 50%;
  text-decoration: none;
  transition: background .2s;
}
.rvl-header__icon-btn:hover { background: rgba(255,255,255,.08); color: #fff; }
.rvl-header__icon-btn--login { width: auto; padding: 0 10px; border-radius: 6px; gap: 7px; }
.rvl-login-label { font-family: var(--font-1); font-size: 13px; font-weight: 600; color: #fff; letter-spacing: .02em; white-space: nowrap; }

/* Search overlay */
.rvl-search-overlay {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: #fff;
  padding: 28px 0;
  box-shadow: 0 12px 30px -10px rgba(0,0,0,.2);
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  transition: all .3s ease;
  z-index: 50;
}
.rvl-search-overlay.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.rvl-search-form {
  display: flex;
  align-items: center;
  gap: 12px;
  border-bottom: 2px solid var(--c-text);
  padding-bottom: 14px;
}
.rvl-search-form input {
  flex: 1;
  border: none;
  outline: none;
  font-family: var(--font-1);
  font-size: 18px;
  background: transparent;
  color: var(--c-text);
}
.rvl-search-form button {
  background: none;
  border: none;
  padding: 6px;
  color: var(--c-text);
}
.rvl-search-form button[data-close] { font-size: 28px; line-height: 1; }
.rvl-search-popular {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin-top: 18px;
  font-size: 12px;
}
.rvl-search-popular__label {
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--c-text-2);
  font-weight: 600;
}
.rvl-search-popular a {
  text-transform: uppercase;
  letter-spacing: .08em;
  font-weight: 600;
  color: var(--c-purple-primary);
  padding: 6px 14px;
  border: 1px solid var(--c-line);
  border-radius: 999px;
}
.rvl-search-popular a:hover {
  background: var(--c-purple-primary);
  color: #fff;
  border-color: var(--c-purple-primary);
}

/* ============================================================
   HERO SLIDESHOW
   ============================================================ */
.rvl-hero {
  position: relative;
  width: 100%;
  background: #f2f2f2;        /* slideshow_background del settings */
  overflow: hidden;
}
.rvl-hero__slides { position: relative; width: 100%; }
.rvl-hero__slide {
  position: relative;
  display: none;
  width: 100%;
  text-decoration: none;
}
.rvl-hero__slide.is-active { display: block; }
.rvl-hero__slide img,
.rvl-hero__slide picture {
  width: 100%;
  height: auto;
  display: block;
}

/* Arrows */
.rvl-hero__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 50px;
  height: 50px;
  background: var(--c-purple-dark);
  color: #fff;
  border: none;
  border-radius: 0;
  font-size: 30px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .2s;
}
.rvl-hero__arrow:hover { background: var(--c-purple-medium); }
.rvl-hero__arrow--prev { left: 1%; }
.rvl-hero__arrow--next { right: 1%; }

/* Dots */
.rvl-hero__dots {
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  z-index: 5;
}
.rvl-hero__dot {
  width: 50px;
  height: 4px;
  background: #e8e8e8;
  border: 1px solid rgba(0,0,0,0);
  border-radius: 0;
  cursor: pointer;
  padding: 0;
  transition: width .25s, background .25s;
}
.rvl-hero__dot.is-active {
  background: var(--c-purple-primary);
  border-color: var(--c-purple-primary);
  width: 100px;
}

/* ============================================================
   BRAND SLIDER (6 marcas)
   ============================================================ */
.rvl-brands {
  padding: 50px 0;
  background: #f4f4f6;
}
.rvl-brands__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 40px;
}
.rvl-brand-item { flex: 0 0 auto; min-width: 120px; }
.rvl-brand-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 6px;
  text-align: center;
  text-decoration: none;
  color: var(--c-purple-text);
  transition: transform .25s;
}
.rvl-brand-item:hover { transform: translateY(-3px); }
.rvl-brand-item img {
  width: 120px;
  height: 120px;
  object-fit: contain;
}
.rvl-brand-item span {
  font-family: var(--font-2);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-purple-text);
}

/* ============================================================
   PRODUCT BLOCK (carruseles de productos)
   ============================================================ */
.rvl-product-block {
  padding: var(--section-py) 0;
  background: #fff;
}
.rvl-product-block--alt { background: var(--c-bg-soft); }
.rvl-product-block__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 50px;
  gap: 20px;
  flex-wrap: wrap;
}
.rvl-product-block__title {
  font-family: var(--font-2);
  font-size: 30px;
  font-weight: 400;
  line-height: 1;
  color: var(--c-purple-text);
  margin: 0;
  letter-spacing: 0;
  text-transform: none;
}
.rvl-product-block__viewall {
  font-family: var(--font-1);
  font-size: 14px;
  color: #337fd3;
  font-weight: 400;
  text-decoration: none;
}
.rvl-product-block__viewall:hover { text-decoration: underline; text-underline-offset: 4px; }

.rvl-products-flex {
  display: flex;
  gap: 30px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 45px;
  -webkit-overflow-scrolling: touch;
  justify-content: center;
  flex-wrap: wrap;
}
.rvl-products-flex::-webkit-scrollbar { height: 4px; }
.rvl-products-flex::-webkit-scrollbar-track { background: #dadada; }
.rvl-products-flex::-webkit-scrollbar-thumb { background: #000; }

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.rvl-pcard {
  flex: 0 0 calc((100% - 120px) / 5);
  scroll-snap-align: start;
  background: transparent;
  text-decoration: none;
  display: block;
  transition: transform .25s;
}
.rvl-pcard:hover { transform: translateY(-3px); }
.rvl-pcard__media {
  position: relative;
  background: #fff;
  border: 1px solid var(--c-line);
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  overflow: hidden;
}
.rvl-pcard__media > img:not(.rvl-pcard__img2) {
  position: relative;
  z-index: 1;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  transition: opacity .5s ease;
}
.rvl-pcard__media .rvl-pcard__img2 {
  position: absolute;
  top: 28px;
  left: 28px;
  width: calc(100% - 56px);
  height: calc(100% - 56px);
  max-width: none;
  max-height: none;
  margin: 0;
  object-fit: contain;
  opacity: 0;
  z-index: 2;
  pointer-events: none;
  transition: opacity .5s ease;
}
.rvl-pcard:hover .rvl-pcard__media .rvl-pcard__img2 { opacity: 1; }
.rvl-pcard__info {
  padding: 16px 0 0;
  text-align: left;
}
.rvl-pcard__title {
  font-family: var(--font-1);
  font-size: var(--fs-product-title);
  font-weight: var(--fw-product-title);
  color: #232323;
  line-height: 1.45;
  margin: 0 0 8px;
  text-transform: none;
  letter-spacing: 0;
}
.rvl-pcard:hover .rvl-pcard__title { color: var(--c-product-hover); }
.rvl-pcard__price {
  font-family: var(--font-1);
  font-size: var(--fs-product-price);
  font-weight: var(--fw-product-price);
  color: #232323;
  margin: 0;
}
.rvl-pcard__price::after {
  content: 'IVA incluido';
  display: block;
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .02em;
  color: #8a8a8a;
  margin-top: 1px;
  text-transform: none;
}
.rvl-pcard__price--tier {
  color: #572582;
  position: relative;
}
.rvl-pcard__price--tier::before {
  content: 'Tu precio';
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  color: #572582;
  text-transform: uppercase;
  opacity: .7;
  margin-bottom: 2px;
}
/* Tablas de ficha técnica (generadas desde Dolibarr) */
.rvl-ficha { width: 100%; border-collapse: collapse; margin: 0 0 24px; font-size: 14px; border: 2px solid #572582; }
.rvl-ficha td { padding: 12px 18px; border-bottom: 1px solid #d8d3e1; vertical-align: top; }
.rvl-ficha td:first-child { font-weight: 600; color: #333; width: 45%; background: #f7f5fa; }
.rvl-ficha td:last-child { color: #444; background: #fff; }
.rvl-ficha tr:last-child td { border-bottom: none; }
.rvl-ficha__section { font-family: var(--font-2); font-size: 15px; font-weight: 700; color: #572582; letter-spacing: .06em; text-transform: uppercase; text-align: center; margin: 28px 0 0; padding: 14px 18px; background: #f0ebf5; border: 2px solid #572582; border-bottom: none; }
.rvl-ficha__section:first-child { margin-top: 0; }
.rvl-ficha__section + .rvl-ficha { border-top: 2px solid #572582; }
/* Headings dentro de descripción de producto */
.rvl-desc__heading { font-family: var(--font-2); font-size: 18px; font-weight: 700; color: #572582; margin: 22px 0 8px; letter-spacing: .01em; }
.rvl-product__tab-content ul { padding-left: 22px; margin: 10px 0 16px; }
.rvl-product__tab-content li { margin-bottom: 6px; line-height: 1.55; }
.rvl-product__tab-content li strong { color: #333; }

.rvl-product__price {
  position: relative;
}
.rvl-product__price::after {
  content: 'IVA incluido';
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: #7a7a7a;
  margin-top: 2px;
  letter-spacing: .02em;
}

/* ============================================================
   CUSTOM SERVICE BLOCK (3 cifras)
   ============================================================ */
.rvl-service-block {
  position: relative;
  padding: 90px 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.rvl-service-block::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(38,15,64,.55);
}
.rvl-service-block__inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  text-align: center;
}
.rvl-service-block__item {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity .9s ease, transform .9s ease;
}
.rvl-service-block__item.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.rvl-service-block__item:nth-child(2) { transition-delay: .2s; }
.rvl-service-block__item:nth-child(3) { transition-delay: .4s; }
.rvl-service-block__item img {
  height: 110px;
  width: auto;
  margin: 0 auto 20px;
}
.rvl-service-block__item p {
  font-family: var(--font-2);
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  letter-spacing: .04em;
  margin: 0;
  text-shadow: 0 2px 6px rgba(0,0,0,.4);
}

/* ============================================================
   PRODUCT TABS BLOCK (Cables / Repartidores / Derivadores)
   ============================================================ */
.rvl-ptabs {
  padding: var(--section-py) 0;
  background: #fff;
}
.rvl-ptabs__nav {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--c-line);
  margin-bottom: 40px;
}
.rvl-ptabs__nav-btn {
  background: transparent;
  border: none;
  padding: 14px 28px;
  font-family: var(--font-2);
  font-size: 18px;
  font-weight: 700;
  color: #999;
  cursor: pointer;
  position: relative;
  text-transform: uppercase;
  letter-spacing: .04em;
  transition: color .2s;
}
.rvl-ptabs__nav-btn::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 3px;
  background: var(--c-purple-text);
  transition: width .3s;
}
.rvl-ptabs__nav-btn.is-active,
.rvl-ptabs__nav-btn:hover { color: var(--c-purple-text); }
.rvl-ptabs__nav-btn.is-active::after { width: 60%; }
.rvl-ptabs__panel { display: none; }
.rvl-ptabs__panel.is-active { display: block; }

/* ============================================================
   PRESS BANNER (PRÓXIMO WEBINAR)
   ============================================================ */
.rvl-press-banner {
  padding: 60px 0;
  background: var(--c-bg-soft);
}
.rvl-press-banner__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 75px;
  align-items: center;
}
.rvl-press-banner__image {
  overflow: hidden;
}
.rvl-press-banner__image img {
  width: 100%;
  height: auto;
  display: block;
  transition: transform .5s ease;
}
.rvl-press-banner__image:hover img { transform: scale(1.04); }
.rvl-press-banner__content { max-width: 400px; }
.rvl-press-banner__sub {
  font-family: var(--font-1);
  font-size: 16px;
  font-weight: 800;
  color: #232323;
  margin: 0 0 30px;
  text-transform: none;
}
.rvl-press-banner__title {
  font-family: var(--font-2);
  font-size: 40px;
  font-weight: 800;
  color: #000;
  margin: 0;
  line-height: 1.1;
}
.rvl-press-banner__date {
  font-family: var(--font-2);
  font-size: 22px;
  font-weight: 700;
  color: #232323;
  margin: 14px 0 0;
}
.rvl-press-banner__divider {
  display: block;
  width: 70px;
  height: 3px;
  background: var(--c-purple-divider);
  margin: 15px 0;
}
.rvl-press-banner__des {
  font-size: 16px;
  font-weight: 400;
  color: #000;
  line-height: 1.6;
  margin: 0 0 30px;
}
.rvl-press-banner__btn {
  display: inline-block;
  padding: 14px 32px;
  background: var(--c-purple-button);
  color: #fff;
  font-family: var(--font-1);
  font-size: 16px;
  font-weight: 700;
  text-transform: capitalize;
  text-decoration: none;
  border: 1px solid var(--c-purple-button);
  min-width: 230px;
  text-align: center;
  transition: background .25s, border-color .25s, transform .25s;
}
.rvl-press-banner__btn:hover {
  background: var(--c-purple-hover);
  border-color: var(--c-purple-hover);
  color: #fff;
  transform: translateY(-2px);
}

/* ============================================================
   SPOTLIGHT (3 servicios)
   ============================================================ */
.rvl-spotlight {
  padding: var(--section-py) 0;
  background: #fff;
}
.rvl-spotlight__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
.rvl-spotlight__card {
  text-align: center;
}
.rvl-spotlight__image {
  aspect-ratio: 16 / 11;
  overflow: hidden;
  margin-bottom: 20px;
}
.rvl-spotlight__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}
.rvl-spotlight__card:hover .rvl-spotlight__image img { transform: scale(1.05); }
.rvl-spotlight__title {
  font-family: var(--font-2);
  font-size: 20px;
  font-weight: 700;
  color: #232323;
  line-height: 1.3;
  margin: 0;
  padding: 0 16px;
}

/* ============================================================
   IMAGE BANNER MOCKUP (final)
   ============================================================ */
.rvl-image-banner {
  position: relative;
  width: 100%;
  background: var(--c-purple-260);
}
.rvl-image-banner img {
  width: 100%;
  height: auto;
  display: block;
}
.rvl-image-banner__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
}
.rvl-image-banner__title {
  font-family: var(--font-2);
  font-size: 40px;
  font-weight: 800;
  color: #fff;
  line-height: 48px;
  letter-spacing: 0;
  margin: 0;
  max-width: 600px;
}

/* ============================================================
   POLICIES BAR (4 columnas: Garantía, Costo, RITEL, Certifícate)
   ============================================================ */
.rvl-social-strip {
  padding: 50px 0;
  background: #f4f4f6;
  text-align: center;
}
.rvl-social-strip h3 {
  font-family: var(--font-1);
  font-size: 22px;
  font-weight: 500;
  color: #232323;
  margin: 0 0 22px;
}
.rvl-social-strip__icons {
  display: flex;
  justify-content: center;
  gap: 18px;
}
.rvl-social-strip__icons a {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1a1a1a;
  color: #fff;
  border-radius: 4px;
  transition: transform .2s;
}
.rvl-social-strip__icons a:hover { transform: translateY(-2px); }

.rvl-policies {
  padding: 30px 0;
  background: #1a1a1a;
}
.rvl-policies__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  text-align: center;
}
.rvl-policies__item {
  font-family: var(--font-1);
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  letter-spacing: .04em;
}

/* ============================================================
   FOOTER
   ============================================================ */
.rvl-footer {
  background: var(--c-purple-dark);
  color: #fff;
  padding-top: 80px;
}
.rvl-footer__inner {
  display: grid;
  grid-template-columns: 1.4fr 0.8fr 0.8fr 1.2fr;
  align-items: start;
  gap: 40px;
  padding: 0 30px 40px;
  max-width: var(--w-body);
  margin: 0 auto;
}
.rvl-footer__links ul { margin: 0; padding: 0; list-style: none; }
.rvl-footer__brand-logo { height: 48px !important; width: auto !important; max-width: 220px; object-fit: contain; }
.rvl-footer__brand-logo { height: 48px; margin-bottom: 18px; }
.rvl-footer__brand-text {
  color: rgba(255,255,255,.7);
  font-size: 14px;
  margin: 0 0 24px;
  max-width: 320px;
}
.rvl-footer h4 {
  font-family: var(--font-2);
  font-size: var(--fs-footer-heading);
  font-weight: var(--fw-footer-heading);
  line-height: var(--lh-footer-heading);
  text-transform: uppercase;
  letter-spacing: var(--ls-footer-heading);
  color: rgba(255,255,255,.95);
  margin: 0 0 18px;
}
.rvl-footer ul li {
  font-family: var(--font-1);
  font-size: var(--fs-footer-link);
  line-height: var(--lh-footer-link);
  text-transform: capitalize;
  letter-spacing: 0;
}
.rvl-footer ul li a {
  color: rgba(255,255,255,.78);
}
.rvl-footer ul li a:hover { color: #fff; }

.rvl-footer__newsletter form {
  display: flex;
  align-items: center;
  border-bottom: 1px solid rgba(255,255,255,.4);
  padding-bottom: 8px;
  margin: 8px 0 22px;
}
.rvl-footer__newsletter input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  color: #fff;
  font-family: var(--font-1);
  font-size: 13px;
  padding: 8px 0;
}
.rvl-footer__newsletter input::placeholder { color: rgba(255,255,255,.5); }
.rvl-footer__newsletter button {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 22px;
  cursor: pointer;
  padding: 0 8px;
}
.rvl-footer__contact-mini {
  font-size: 13px;
  color: rgba(255,255,255,.7);
  line-height: 1.7;
}
.rvl-footer__contact-mini a { color: rgba(255,255,255,.85); }
.rvl-footer__contact-mini a:hover { color: #fff; }

.rvl-footer__social {
  display: flex;
  gap: 10px;
  margin-top: 8px;
}
.rvl-footer__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50%;
  color: rgba(255,255,255,.8);
}
.rvl-footer__social a:hover {
  background: var(--c-purple-primary);
  color: #fff;
  border-color: var(--c-purple-primary);
}

.rvl-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 22px 30px;
  font-size: 12px;
  color: rgba(255,255,255,.5);
  text-align: center;
}

/* Footer address (Cra. 46 #36-21, Medellin...) */
.rvl-footer__address {
  color: rgba(255,255,255,.7);
  font-size: 13px;
  margin: 0 0 18px;
  line-height: 1.6;
  font-family: var(--font-1);
}

/* Newsletter form completo */
.rvl-newsletter-form {
  display: flex;
  gap: 0;
  align-items: stretch;
  margin: 8px 0 14px;
  flex-wrap: wrap;
}
.rvl-newsletter-form input {
  flex: 1;
  min-width: 0;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  outline: none;
  color: #fff;
  font-family: var(--font-1);
  font-size: 13px;
  padding: 12px 14px;
  border-right: none;
}
.rvl-newsletter-form input::placeholder { color: rgba(255,255,255,.5); }
.rvl-newsletter-form input:focus { border-color: rgba(255,255,255,.5); }
.rvl-newsletter-form button {
  background: var(--c-purple-primary);
  border: 1px solid var(--c-purple-primary);
  color: #fff;
  font-family: var(--font-2);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 12px 22px;
  cursor: pointer;
  transition: background .2s;
}
.rvl-newsletter-form button:hover { background: var(--c-purple-medium); }
.rvl-newsletter-msg {
  width: 100%;
  margin-top: 8px;
  font-size: 12px;
  color: #a7f3d0;
}

/* Footer payments bar */
.rvl-footer__payments {
  background: rgba(0,0,0,.25);
  padding: 18px 0;
  border-top: 1px solid rgba(255,255,255,.06);
}
.rvl-footer__payments .rvl-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 20px;
}
.rvl-footer__payments-label {
  font-family: var(--font-1);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255,255,255,.6);
}
.rvl-footer__payments-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}
.rvl-footer__payments-list img {
  height: 28px;
  width: auto;
  background: #fff;
  border-radius: 4px;
  padding: 4px 8px;
}
.rvl-pay-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 14px;
  background: #fff;
  color: #1a1a1a;
  font-family: var(--font-2);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  border-radius: 4px;
  text-transform: uppercase;
}

@media (max-width: 700px) {
  .rvl-footer__payments .rvl-container { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   COLECCION (sidebar + grid)
   ============================================================ */
.rvl-collection {
  padding: 50px 0 80px;
}
.rvl-breadcrumb {
  font-size: 11px;
  color: var(--c-text-2);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.rvl-breadcrumb a { color: var(--c-text-2); }
.rvl-breadcrumb a:hover { color: var(--c-purple-primary); }

.rvl-collection__hero {
  text-align: center;
  margin-bottom: 18px;
  padding: 4px 0 10px;
}
.rvl-collection__hero h1 {
  font-family: var(--font-2);
  font-weight: 700;
  font-size: 26px;
  letter-spacing: .04em;
  margin: 0 0 4px;
  text-transform: uppercase;
}
.rvl-collection__hero p {
  color: var(--c-text-2);
  font-size: 13px;
  margin: 0;
}

.rvl-collection { padding: 14px 0 50px; }
.rvl-collection__layout {
  display: grid;
  grid-template-columns: 210px 1fr;
  gap: 34px;
  align-items: start;
}
.rvl-sidebar {
  position: sticky;
  top: 110px;
  font-family: var(--font-1);
}
.rvl-sidebar__block {
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--c-line);
}
.rvl-sidebar__block:last-child { border-bottom: none; }
.rvl-sidebar__block h4 {
  font-family: var(--font-1);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .1em;
  color: var(--c-text);
  margin: 0 0 12px;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rvl-sidebar__block ul { list-style: none; margin: 0; padding: 0; }
.rvl-sidebar__block ul li {
  font-size: 13px;
  line-height: 26px;
  letter-spacing: .04em;
}
.rvl-sidebar__block ul li a {
  color: var(--c-text);
  display: inline-block;
  padding: 2px 0;
  text-transform: uppercase;
  font-weight: 500;
}
.rvl-sidebar__block ul li a:hover { color: var(--c-purple-primary); }
.rvl-sidebar__block ul li a.is-active {
  color: var(--c-purple-primary);
  font-weight: 700;
}
.rvl-sidebar__check {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--c-text-grey);
  cursor: pointer;
}
.rvl-sidebar__check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--c-purple-primary);
}
.rvl-sidebar__price {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}
.rvl-sidebar__price input {
  flex: 1;
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--c-line);
  font-size: 13px;
  font-family: var(--font-1);
  border-radius: 0;
}
.rvl-sidebar__price input:focus {
  outline: none;
  border-color: var(--c-purple-primary);
}
.rvl-sidebar__price span { color: var(--c-text-grey); }
.rvl-sidebar__apply {
  width: 100%;
  background: var(--c-text);
  color: #fff;
  border: none;
  padding: 11px;
  font-family: var(--font-2);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s;
  border-radius: 0;
}
.rvl-sidebar__apply:hover { background: var(--c-purple-primary); }

.rvl-collection__toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0;
  border-bottom: 1px solid var(--c-line);
  margin-bottom: 24px;
  flex-wrap: wrap;
  gap: 12px;
}
.rvl-collection__count {
  font-size: 13px;
  color: var(--c-text-grey);
  font-weight: 600;
}
.rvl-collection__sort {
  padding: 8px 14px;
  border: 1px solid var(--c-line);
  font-family: var(--font-1);
  font-size: 13px;
  background: #fff;
  cursor: pointer;
  border-radius: 0;
}
.rvl-collection__sort:focus { outline: none; border-color: var(--c-purple-primary); }

.rvl-collection__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}
.rvl-collection__grid .rvl-pcard {
  flex: none;
}

/* Toolbar left/right */
.rvl-toolbar__left, .rvl-toolbar__right { display: flex; align-items: center; gap: 14px; }
.rvl-view-toggle { display: flex; gap: 0; border: 1px solid var(--c-line); }
.rvl-view-btn {
  background: #fff; border: none; padding: 6px 10px; cursor: pointer;
  color: var(--c-text-grey); display: flex; align-items: center;
}
.rvl-view-btn + .rvl-view-btn { border-left: 1px solid var(--c-line); }
.rvl-view-btn.is-active { color: var(--c-purple-primary); background: #f5f2fa; }
.rvl-toolbar__perpage { font-size: 13px; color: var(--c-text-grey); display: flex; align-items: center; gap: 6px; }
.rvl-toolbar__perpage select {
  padding: 6px 10px; border: 1px solid var(--c-line); background: #fff; font-family: var(--font-1); font-size: 13px;
}

/* Active filter chips */
.rvl-active-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.rvl-active-filters:empty { display: none; }
.rvl-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; background: #f5f2fa; color: var(--c-purple-text);
  border: 1px solid #e4def0; border-radius: 999px; font-size: 12px; font-weight: 600;
  cursor: pointer; transition: background .2s;
}
.rvl-chip:hover { background: #ece4f8; }
.rvl-chip--clear { background: transparent; border: none; color: var(--c-text-grey); text-decoration: underline; }

/* Price range slider (dual handle) */
.rvl-price-slider {
  position: relative;
  height: 32px;
  margin: 18px 0 8px;
}
.rvl-price-slider__track {
  position: absolute; top: 14px; left: 0; right: 0; height: 4px;
  background: #e4e4e4; border-radius: 2px;
}
.rvl-price-slider__range {
  position: absolute; top: 0; bottom: 0;
  background: var(--c-purple-primary); border-radius: 2px;
}
.rvl-price-slider input[type="range"] {
  position: absolute; top: 0; left: 0; width: 100%; height: 32px;
  background: none; pointer-events: none; -webkit-appearance: none; appearance: none; margin: 0;
}
.rvl-price-slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2px solid var(--c-purple-primary);
  cursor: pointer; pointer-events: auto; box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.rvl-price-slider input[type="range"]::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; border: 2px solid var(--c-purple-primary);
  cursor: pointer; pointer-events: auto;
}

.rvl-sidebar__clear {
  width: 100%; margin-top: 10px; padding: 10px;
  background: transparent; border: 1px solid var(--c-line); color: var(--c-text-grey);
  font-family: var(--font-1); font-size: 12px; font-weight: 600;
  cursor: pointer; text-transform: uppercase; letter-spacing: .05em;
}
.rvl-sidebar__clear:hover { border-color: var(--c-purple-primary); color: var(--c-purple-primary); }

/* Pagination */
.rvl-pagination {
  display: flex; justify-content: center; align-items: center;
  gap: 6px; margin: 40px 0 20px;
}
.rvl-page-btn {
  min-width: 36px; height: 36px; padding: 0 10px;
  background: #fff; border: 1px solid var(--c-line); color: var(--c-text);
  font-family: var(--font-1); font-size: 13px; font-weight: 600;
  cursor: pointer; transition: all .2s;
}
.rvl-page-btn:hover:not(:disabled) { border-color: var(--c-purple-primary); color: var(--c-purple-primary); }
.rvl-page-btn.is-active { background: var(--c-purple-primary); color: #fff; border-color: var(--c-purple-primary); }
.rvl-page-btn:disabled { opacity: .4; cursor: not-allowed; }

/* List view */
.rvl-collection__grid--list { grid-template-columns: 1fr !important; }
.rvl-collection__grid--list .rvl-pcard {
  display: grid; grid-template-columns: 200px 1fr; gap: 20px; align-items: center;
}
.rvl-collection__grid--list .rvl-pcard__media { aspect-ratio: 1/1; }
.rvl-collection__grid--list .rvl-pcard__info { padding: 0; }
.rvl-collection__grid--2 { grid-template-columns: repeat(2, 1fr) !important; }
.rvl-collection__grid--3 { grid-template-columns: repeat(3, 1fr) !important; }
.rvl-collection__grid--4 { grid-template-columns: repeat(4, 1fr) !important; }

/* Toolbar labels */
.rvl-toolbar__lbl {
  font-family: var(--font-1);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--c-text);
}

/* Refined-by panel (sidebar bottom) */
.rvl-refined { margin-bottom: 20px; padding-bottom: 16px; border-bottom: 1px solid var(--c-line); display: none; }
.rvl-refined:has(.rvl-chip), .rvl-refined.is-visible { display: block; }
.rvl-refined__head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 6px; }
.rvl-refined__head strong { font-family: var(--font-1); font-size: 12px; font-weight: 800; letter-spacing: .12em; color: var(--c-text); }
.rvl-refined__head a { font-size: 12px; color: var(--c-text); text-decoration: underline; }
.rvl-refined__count { font-size: 12px; color: var(--c-text-grey); margin: 0 0 10px; }

/* ============================================================
   PRODUCTO (ficha individual)
   ============================================================ */
.rvl-product-page {
  padding: 50px 0 80px;
}
.rvl-product__layout {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: start;
}
.rvl-product__gallery {
  position: sticky;
  top: 110px;
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 14px;
  align-items: start;
}
.rvl-product__gallery-thumbs {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.rvl-thumb {
  width: 80px;
  height: 80px;
  padding: 6px;
  background: #fff;
  border: 1px solid var(--c-line);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color .2s;
}
.rvl-thumb img { max-width: 100%; max-height: 100%; object-fit: contain; }
.rvl-thumb:hover { border-color: var(--c-purple-primary); }
.rvl-thumb.is-active { border: 2px solid var(--c-purple-primary); }
.rvl-product__gallery-main {
  background: #fff;
  border: 1px solid var(--c-line);
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 60px;
  overflow: hidden;
}
.rvl-product__shortdesc {
  font-family: var(--font-1);
  font-size: 14px;
  line-height: 1.6;
  color: var(--c-text-grey);
  margin: 4px 0 18px;
}
.rvl-product__avail {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; color: var(--c-text-grey);
  margin: 0 0 24px;
}
.rvl-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.rvl-dot--ok { background: #2ec27e; box-shadow: 0 0 0 3px rgba(46,194,126,.18); }
.rvl-product__meta {
  list-style: none; padding: 22px 0 0; margin: 0;
  border-top: 1px solid var(--c-line);
}
.rvl-product__meta li {
  display: flex; justify-content: space-between;
  padding: 9px 0; font-size: 13px;
  border-bottom: 1px dashed var(--c-line);
}
.rvl-product__meta li:last-child { border-bottom: none; }
.rvl-product__meta strong { font-family: var(--font-1); font-weight: 700; color: var(--c-text); text-transform: uppercase; letter-spacing: .06em; font-size: 11px; }
.rvl-product__meta span { color: var(--c-text-grey); }
.rvl-product__gallery-main img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.rvl-product__info { padding: 20px 0; }
.rvl-product__vendor {
  display: inline-block;
  font-family: var(--font-1);
  font-size: var(--fs-product-vendor);
  font-weight: var(--fw-product-vendor);
  color: var(--c-text);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 10px;
}
.rvl-product__title {
  font-family: var(--font-2);
  font-weight: 700;
  font-size: 28px;
  line-height: 36px;
  letter-spacing: 0;
  color: var(--c-text);
  margin: 0 0 16px;
}
.rvl-product__price {
  font-family: var(--font-1);
  font-size: 28px;
  font-weight: 700;
  color: var(--c-text);
  margin: 18px 0 30px;
}
.rvl-product__cta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}
.rvl-btn {
  display: inline-block;
  padding: 13px 32px;
  font-family: var(--font-2);
  font-size: 16px;
  font-weight: 700;
  text-transform: capitalize;
  text-decoration: none;
  border: 1px solid;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s;
  border-radius: 0;
}
.rvl-btn--primary {
  background: var(--c-purple-button);
  color: #fff;
  border-color: var(--c-purple-button);
}
.rvl-btn--primary:hover {
  background: var(--c-purple-hover);
  border-color: var(--c-purple-hover);
  color: #fff;
}
.rvl-btn--ghost {
  background: transparent;
  color: var(--c-text);
  border-color: var(--c-text);
}
.rvl-btn--ghost:hover {
  background: var(--c-text);
  color: #fff;
}

/* Tabs producto (Descripción / Fichas Técnicas / Descargables) */
.rvl-product__tabs { margin-top: 40px; margin-bottom: 0; }
.rvl-product-page { padding-bottom: 30px; }
.rvl-related { padding-top: 10px !important; }
.rvl-product__tabs-nav {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--c-purple-primary);
  margin-bottom: 24px;
  flex-wrap: wrap;
}
.rvl-product__tab-btn {
  background: var(--c-bg-soft);
  border: none;
  padding: 14px 28px;
  font-family: var(--font-1);
  font-weight: 700;
  font-size: 14px;
  color: var(--c-purple-primary);
  cursor: pointer;
  transition: all .25s;
  border-radius: 0;
}
.rvl-product__tab-btn:hover { background: rgba(87,37,130,.08); }
.rvl-product__tab-btn.is-active {
  background: var(--c-purple-primary);
  color: #fff;
}
.rvl-product__tab-content {
  display: none;
  padding: 20px 4px;
  font-size: 15px;
  line-height: 1.7;
  color: var(--c-text);
}
.rvl-product__tab-content.is-active { display: block; }
.rvl-product__tab-content p { margin: 0 0 14px; }
.rvl-product__tab-content h3 {
  color: var(--c-purple-primary);
  font-weight: 700;
  margin: 24px 0 12px;
  font-size: 18px;
  font-family: var(--font-1);
}
.rvl-product__tab-content ul {
  margin: 0 0 16px;
  padding-left: 22px;
  list-style: disc;
}
.rvl-product__tab-content ul li { margin-bottom: 8px; }
.rvl-product__tab-content strong { color: var(--c-text); font-weight: 700; }
.rvl-product__tab-content table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 22px;
  font-size: 14px;
}
.rvl-product__tab-content table {
  width: 100%;
  border: 1px solid var(--c-line);
  border-collapse: collapse;
  font-family: var(--font-1);
  font-size: 14px;
  background: #fff;
}
.rvl-product__tab-content table th {
  background: var(--c-purple-primary);
  color: #fff;
  padding: 14px 18px;
  text-align: center;
  font-family: var(--font-2);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.rvl-product__tab-content table td {
  padding: 12px 18px;
  border-bottom: 1px solid var(--c-line);
  vertical-align: middle;
  color: var(--c-text);
}
.rvl-product__tab-content table td:first-child {
  font-weight: 600;
  color: var(--c-text);
  width: 45%;
  background: #faf9fc;
  border-right: 1px solid var(--c-line);
}
.rvl-product__tab-content table tr:last-child td { border-bottom: none; }
.rvl-product__tab-content table tr:hover td { background: #f7f4fb; }
.rvl-product__tab-content table tr:hover td:first-child { background: #f0eaf8; }

.rvl-product__downloads { display: grid; gap: 14px; }
.rvl-product__download-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px;
  border: 1px solid var(--c-line);
  background: #fff;
  transition: all .25s;
  position: relative;
  padding-left: 64px;
}
.rvl-product__download-item::before {
  content: '';
  position: absolute;
  left: 18px; top: 50%; transform: translateY(-50%);
  width: 32px; height: 38px;
  background: #e63946;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8l-6-6zm-1 7V3.5L18.5 9H13z'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'><path d='M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8l-6-6zm-1 7V3.5L18.5 9H13z'/></svg>") center/contain no-repeat;
}
.rvl-product__download-item::after {
  content: 'PDF';
  position: absolute;
  left: 22px; top: 58%;
  font-size: 8px; font-weight: 800;
  color: #fff; font-family: var(--font-1);
}
.rvl-product__download-item:hover {
  border-color: var(--c-purple-primary);
}
.rvl-product__download-info { flex: 1; min-width: 0; }
.rvl-product__download-info strong {
  display: block;
  color: var(--c-text);
  font-weight: 700;
  font-size: 14px;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.rvl-product__download-info span {
  display: block;
  color: var(--c-text-grey);
  font-size: 12px;
  margin-top: 4px;
  word-break: break-all;
}
.rvl-product__download-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  background: var(--c-purple-button);
  color: #fff;
  text-decoration: none;
  font-family: var(--font-1);
  font-weight: 700;
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .05em;
  white-space: nowrap;
  transition: background .2s;
}
.rvl-product__download-btn:hover {
  background: var(--c-purple-hover);
  color: #fff;
}

/* Related products */
/* Nosotros page */
.rvl-nos-banner img { width: 100%; display: block; }
.rvl-nos-intro { padding: 60px 0 30px; text-align: center; }
.rvl-nos-intro h2 { font-family: var(--font-2); font-size: 32px; font-weight: 700; color: var(--c-text); margin: 0 0 18px; }
.rvl-nos-intro p { max-width: 820px; margin: 0 auto; font-size: 15px; line-height: 1.7; color: var(--c-text-grey); }
.rvl-nos-pillars { padding: 40px 0 60px; background: var(--c-purple-dark); color: #fff; }
.rvl-nos-pillars__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 50px; }
.rvl-nos-pillar { text-align: center; }
.rvl-nos-pillar img { width: 110px; height: 110px; object-fit: contain; margin: 0 auto 18px; display: block; filter: brightness(0) invert(1); }
.rvl-nos-pillar h3 { font-family: var(--font-2); font-size: 18px; font-weight: 700; margin: 0 0 12px; color: #fff; text-transform: uppercase; letter-spacing: .04em; }
.rvl-nos-pillar p { font-size: 14px; line-height: 1.6; color: #c5bece; margin: 0; }
.rvl-nos-side { position: relative; }
.rvl-nos-side img { width: 100%; display: block; max-height: 520px; object-fit: cover; }
.rvl-nos-side__overlay {
  position: absolute; top: 0; bottom: 0; left: 0;
  width: 50%;
  display: flex; flex-direction: column; justify-content: center;
  padding: 0 8% 0 8%;
  color: #fff;
}
.rvl-nos-side--alt .rvl-nos-side__overlay { left: auto; right: 0; }
.rvl-nos-side__overlay h3 {
  font-family: var(--font-2); font-size: 36px; font-weight: 800; margin: 0 0 18px;
  text-transform: uppercase; letter-spacing: .03em;
  text-shadow: 0 2px 12px rgba(0,0,0,.5);
}
.rvl-nos-side__overlay p { font-size: 15px; line-height: 1.6; max-width: 460px; text-shadow: 0 1px 6px rgba(0,0,0,.5); margin: 0; }
.rvl-nos-card { padding: 60px 0; background: #f4f4f6; }
.rvl-nos-card__inner {
  max-width: 760px; margin: 0 auto; text-align: center;
  background: linear-gradient(135deg, var(--c-purple-dark), var(--c-purple-primary));
  color: #fff; padding: 60px 50px; border-radius: 6px;
  box-shadow: 0 20px 50px -20px rgba(80,30,140,.45);
}
.rvl-nos-card__inner h3 { font-family: var(--font-2); font-size: 30px; font-weight: 800; margin: 0 0 18px; text-transform: uppercase; letter-spacing: .03em; }
.rvl-nos-card__inner p { font-size: 15px; line-height: 1.7; margin: 0; color: #e8e2f4; }
.rvl-nos-eyebrow { font-family: var(--font-1); font-size: 13px; font-weight: 700; letter-spacing: .15em; color: var(--c-text); margin: 0 0 14px; }
.rvl-nos-bigtitle { font-family: var(--font-2); font-size: 36px; font-weight: 800; color: var(--c-text); margin: 0 0 18px; }
@media (max-width: 749px) {
  .rvl-nos-side { min-height: 340px; }
  .rvl-nos-side img { min-height: 340px; }
  .rvl-nos-side__overlay { width: 100%; background: rgba(0,0,0,.4); padding: 0 24px; }
  .rvl-nos-side__overlay h3 { font-size: 26px; }
}
.rvl-nos-especialistas { padding: 40px 0; text-align: center; background: #fff; }
.rvl-nos-especialistas h3 { font-family: var(--font-2); font-size: 28px; font-weight: 800; color: var(--c-text); margin: 0; letter-spacing: .04em; }
@media (max-width: 749px) {
  .rvl-nos-pillars__grid { grid-template-columns: 1fr; gap: 36px; }
}

/* Chat IA modal */
.rvl-chat-modal { position: fixed; inset: 0; z-index: 9500; display: none; }
.rvl-chat-modal.is-open { display: block; }
.rvl-chat-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,.5); }
.rvl-chat-window {
  position: absolute; right: 24px; bottom: 90px;
  width: 380px; max-width: calc(100vw - 48px);
  height: 560px; max-height: calc(100vh - 130px);
  background: #fff; border-radius: 12px; overflow: hidden;
  display: flex; flex-direction: column;
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.5);
}
.rvl-chat-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 16px 18px;
  background: linear-gradient(135deg, var(--c-purple-primary), var(--c-purple-dark));
  color: #fff;
}
.rvl-chat-title { display: block; font-family: var(--font-2); font-weight: 700; font-size: 15px; }
.rvl-chat-sub { display: block; font-size: 12px; opacity: .85; margin-top: 2px; }
.rvl-chat-actions { display: flex; gap: 4px; align-items: center; }
.rvl-chat-close, .rvl-chat-reset { background: transparent; border: none; color: #fff; line-height: 1; cursor: pointer; padding: 4px 8px; border-radius: 4px; transition: background .2s; }
.rvl-chat-close { font-size: 24px; }
.rvl-chat-reset { font-size: 18px; }
.rvl-chat-close:hover, .rvl-chat-reset:hover { background: rgba(255,255,255,.18); }
.rvl-typing-dots { display: inline-flex; gap: 4px; padding: 2px 0; }
.rvl-typing-dots span { width: 7px; height: 7px; background: var(--c-purple-primary); border-radius: 50%; opacity: .4; animation: rvl-typing 1.2s infinite; }
.rvl-typing-dots span:nth-child(2) { animation-delay: .15s; }
.rvl-typing-dots span:nth-child(3) { animation-delay: .3s; }
@keyframes rvl-typing { 0%,60%,100% { opacity: .3; transform: translateY(0); } 30% { opacity: 1; transform: translateY(-3px); } }
.rvl-chat-body { flex: 1; overflow-y: auto; padding: 16px; background: #f7f6fa; font-size: 14px; }
.rvl-chat-welcome, .rvl-chat-info { background: #fff; padding: 12px 14px; border-radius: 8px; line-height: 1.5; }
.rvl-chat-info a { color: var(--c-purple-primary); }
.rvl-msg { margin: 10px 0; display: flex; }
.rvl-msg-bubble { background: #fff; padding: 10px 14px; border-radius: 10px; max-width: 80%; line-height: 1.4; box-shadow: 0 2px 8px rgba(0,0,0,.06); font-size: 14px; }
.rvl-msg-user { justify-content: flex-end; }
.rvl-msg-user .rvl-msg-bubble { background: var(--c-purple-primary); color: #fff; }
.rvl-msg-assistant .rvl-msg-bubble { background: #fff; color: var(--c-text); }
.rvl-chat-loading { padding: 20px; text-align: center; color: var(--c-text-grey); }
.rvl-chat-form { display: flex; gap: 8px; padding: 12px; border-top: 1px solid var(--c-line); background: #fff; }
.rvl-chat-form input { flex: 1; padding: 10px 12px; border: 1px solid var(--c-line); border-radius: 8px; font-family: var(--font-1); font-size: 14px; }
.rvl-chat-form input:focus { outline: none; border-color: var(--c-purple-primary); }
.rvl-chat-form button { background: var(--c-purple-primary); color: #fff; border: none; width: 40px; border-radius: 8px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.rvl-chat-form button:hover { background: var(--c-purple-hover); }
@media (max-width: 480px) {
  .rvl-chat-window { right: 12px; left: 12px; bottom: 84px; width: auto; height: calc(100vh - 110px); }
}

/* Floating buttons (WhatsApp + IA) */
.float-buttons {
  position: fixed; right: 20px; bottom: 20px;
  display: flex; flex-direction: column; gap: 12px;
  z-index: 9000;
}
.fb-btn {
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: none; cursor: pointer; text-decoration: none;
  box-shadow: 0 8px 22px -6px rgba(0,0,0,.35);
  transition: transform .2s, box-shadow .2s;
  color: #fff;
}
.fb-btn:hover { transform: translateY(-3px); box-shadow: 0 14px 30px -8px rgba(0,0,0,.4); }
.fb-ai { background: linear-gradient(135deg, var(--c-purple-primary), var(--c-purple-dark)); }
.fb-ai span { display: none; }
.fb-wa { background: #25d366; }
.fb-logout { background: #6b7280; }
.fb-wa svg { width: 30px; height: 30px; }

/* ============================================================
   PORTAL PRIVADO
   ============================================================ */
.portal-body { background: #f5f5f7; font-family: var(--font-1); }
.portal-shell { display: grid; grid-template-columns: 260px 1fr; min-height: 100vh; }
.portal-sidebar {
  background: var(--c-purple-dark);
  color: #fff;
  display: flex; flex-direction: column;
  padding: 30px 0;
  position: sticky; top: 0; height: 100vh;
}
.portal-logo { display: flex; justify-content: center; padding: 0 24px 28px; border-bottom: 1px solid rgba(255,255,255,.1); margin-bottom: 22px; }
.portal-logo img { height: 38px; width: auto; max-width: 180px; object-fit: contain; }
.portal-nav { display: flex; flex-direction: column; flex: 1; padding: 0 14px; gap: 2px; }
.portal-nav a {
  color: rgba(255,255,255,.8);
  text-decoration: none;
  padding: 11px 16px;
  font-family: var(--font-1); font-size: 13px; font-weight: 500;
  letter-spacing: .04em; text-transform: uppercase;
  border-radius: 4px;
  transition: background .2s, color .2s;
}
.portal-nav a:hover { background: rgba(255,255,255,.08); color: #fff; }
.portal-nav a.is-active { background: var(--c-purple-primary); color: #fff; font-weight: 700; }
.portal-nav-disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }
.portal-nav-section {
  font-size: 10px; font-weight: 800; letter-spacing: .14em;
  color: rgba(255,255,255,.45); text-transform: uppercase;
  padding: 22px 16px 8px;
}
.portal-sidebar-foot { padding: 22px 24px 0; border-top: 1px solid rgba(255,255,255,.1); margin-top: 14px; }
.portal-user-mini { margin-bottom: 14px; }
.portal-user-name { font-family: var(--font-2); font-size: 14px; font-weight: 700; color: #fff; }
.portal-user-role { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.6); margin-top: 3px; }
.portal-logout {
  display: block; padding: 10px; text-align: center;
  color: #fff; background: transparent; border: 1px solid rgba(255,255,255,.25);
  font-family: var(--font-1); font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em; text-decoration: none;
  transition: all .2s;
}
.portal-logout:hover { background: var(--c-purple-primary); border-color: var(--c-purple-primary); }

.portal-main { padding: 50px 56px; max-width: 1240px; }
.portal-page-head { margin-bottom: 36px; }
.portal-page-head .section-eyebrow,
.section-eyebrow {
  display: block; font-family: var(--font-1); font-size: 11px; font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase; color: var(--c-purple-primary);
  margin: 0 0 10px;
}
.portal-page-head h1 {
  font-family: var(--font-2); font-size: 34px; font-weight: 800;
  color: var(--c-text); margin: 0 0 10px; letter-spacing: .01em;
}
.portal-page-head > p { color: var(--c-text-grey); font-size: 14px; max-width: 680px; }

.portal-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 40px; }
.portal-card {
  background: #fff; border: 1px solid var(--c-line);
  padding: 26px 24px;
  transition: border-color .2s, transform .2s;
}
.portal-card:hover { border-color: var(--c-purple-primary); transform: translateY(-2px); }
.portal-card-eyebrow {
  font-family: var(--font-1); font-size: 11px; font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase; color: var(--c-purple-primary);
  margin: 0 0 8px;
}
.portal-card h3 {
  font-family: var(--font-2); font-size: 20px; font-weight: 700;
  color: var(--c-text); margin: 0 0 10px;
}
.portal-card p { font-size: 13px; line-height: 1.5; color: var(--c-text-grey); margin: 0; }

.portal-section { margin-top: 50px; }
.portal-section .section-head { margin-bottom: 26px; }
.portal-section .section-head h2 {
  font-family: var(--font-2); font-size: 26px; font-weight: 800;
  color: var(--c-text); margin: 0;
}

.info-blocks { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.info-block { background: #fff; border: 1px solid var(--c-line); padding: 24px; }
.info-block .num {
  display: inline-block; font-family: var(--font-2); font-size: 11px; font-weight: 800;
  letter-spacing: .12em; padding: 4px 10px;
  background: var(--c-purple-primary); color: #fff;
  margin-bottom: 12px;
}
.info-block h3 {
  font-family: var(--font-2); font-size: 17px; font-weight: 700;
  color: var(--c-text); margin: 0 0 8px;
}
.info-block p { font-size: 13px; line-height: 1.55; color: var(--c-text-grey); margin: 0; }

.portal-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--c-line); margin-top: 14px; font-size: 13px; }
.portal-table th, .portal-table td { padding: 11px 14px; text-align: left; border-bottom: 1px solid var(--c-line); }
.portal-table th { background: #faf9fc; font-family: var(--font-1); font-weight: 800; text-transform: uppercase; letter-spacing: .06em; font-size: 11px; color: var(--c-text); }
.portal-table tfoot td { background: #faf9fc; font-weight: 700; }
.portal-table a { color: var(--c-purple-primary); font-weight: 600; }

.badge { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.badge-draft     { background: #f1f1f4; color: #555; }
.badge-sent      { background: #e3f2fd; color: #0d47a1; }
.badge-validated { background: #e8f5e9; color: #1b5e20; }
.badge-rejected  { background: #fdecea; color: #b3261e; }
.badge-converted { background: #fff3e0; color: #e65100; }
.badge-pending_payment { background: #fff8e1; color: #b26a00; }
.badge-paid { background: #e8f5e9; color: #1b5e20; }
.badge-processing { background: #e3f2fd; color: #0d47a1; }
.badge-shipped { background: #ede7f6; color: #4527a0; }
.badge-delivered { background: #e0f2f1; color: #00695c; }
.badge-cancelled { background: #fdecea; color: #b3261e; }
.badge-pay-pending { background: #fff8e1; color: #b26a00; }
.badge-pay-approved { background: #e8f5e9; color: #1b5e20; }
.badge-pay-declined { background: #fdecea; color: #b3261e; }
.badge-pay-refunded { background: #ede7f6; color: #4527a0; }
.badge-pay-error { background: #fdecea; color: #b3261e; }

.quote-builder { display: grid; grid-template-columns: 1.6fr 1fr; gap: 28px; align-items: start; }
.quote-products { background: #fff; border: 1px solid var(--c-line); padding: 18px; }
.quote-products input[type=search] { width: 100%; padding: 10px 14px; border: 1px solid var(--c-line); margin-bottom: 14px; font-family: var(--font-1); font-size: 14px; }
.quote-products-grid { display: grid; gap: 8px; max-height: 540px; overflow-y: auto; }
.quote-prod { display: flex; justify-content: space-between; align-items: center; padding: 12px 14px; border: 1px solid var(--c-line); background: #fff; }
.quote-prod-info strong { display: block; font-size: 13px; color: var(--c-text); }
.quote-prod-info span { font-size: 11px; color: var(--c-text-grey); }
.quote-prod .add-line { background: var(--c-purple-primary); color: #fff; border: none; padding: 7px 14px; font-family: var(--font-1); font-weight: 700; font-size: 11px; text-transform: uppercase; letter-spacing: .06em; cursor: pointer; }
.quote-prod .add-line:hover { background: var(--c-purple-hover); }

.quote-cart { background: #fff; border: 1px solid var(--c-line); padding: 22px; position: sticky; top: 110px; }
.quote-cart h3 { font-family: var(--font-2); font-size: 18px; margin: 0 0 14px; color: var(--c-text); }
.quote-cart .muted { color: var(--c-text-grey); font-size: 13px; }
.cart-line { display: grid; grid-template-columns: 1.4fr auto auto; gap: 10px; align-items: center; padding: 10px 0; border-bottom: 1px solid var(--c-line); font-size: 13px; }
.cart-qty { display: flex; align-items: center; gap: 8px; }
.cart-qty button { background: #f1f1f4; border: none; width: 24px; height: 24px; cursor: pointer; font-size: 15px; }
.cart-total { padding: 14px 0; margin-top: 4px; border-top: 2px solid var(--c-text); display: flex; justify-content: space-between; font-family: var(--font-2); font-size: 16px; }
.quote-cart label { display: block; font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; color: var(--c-text); margin: 14px 0 6px; }
.quote-cart textarea { width: 100%; border: 1px solid var(--c-line); padding: 10px; font-family: var(--font-1); font-size: 13px; resize: vertical; margin-bottom: 14px; }

@media (max-width: 900px) {
  .quote-builder { grid-template-columns: 1fr; }
  .portal-shell { grid-template-columns: 1fr; }
  .portal-sidebar { position: relative; height: auto; }
  .portal-main { padding: 30px 24px; }
  .portal-cards, .info-blocks { grid-template-columns: 1fr; }
}

/* Auth pages (login / registro / recuperar) */
.auth-section { padding: 70px 0 90px; background: #f7f6fa; }
.auth-card {
  max-width: 460px; margin: 0 auto;
  background: #fff; padding: 50px 44px;
  border: 1px solid var(--c-line);
  box-shadow: 0 30px 60px -30px rgba(0,0,0,.18);
}
.auth-card-head { text-align: center; margin-bottom: 28px; }
.auth-card-head .section-eyebrow {
  font-family: var(--font-1); font-size: 11px; font-weight: 800;
  letter-spacing: .15em; color: var(--c-purple-primary);
  text-transform: uppercase; margin: 0 0 10px;
}
.auth-card-head h1 {
  font-family: var(--font-2); font-size: 30px; font-weight: 800;
  color: var(--c-text); margin: 0 0 10px; letter-spacing: .02em;
}
.auth-card-head p { font-size: 14px; color: var(--c-text-grey); margin: 0; }
.auth-form { display: flex; flex-direction: column; gap: 16px; margin-top: 8px; }
.auth-form label {
  display: flex; flex-direction: column; gap: 6px;
  font-family: var(--font-1); font-size: 12px; font-weight: 700;
  letter-spacing: .08em; text-transform: uppercase; color: var(--c-text);
}
.auth-form input {
  padding: 12px 14px; border: 1px solid var(--c-line);
  font-family: var(--font-1); font-size: 14px; background: #fff;
  text-transform: none; letter-spacing: 0; font-weight: 400;
  transition: border-color .2s;
}
.auth-form input:focus { outline: none; border-color: var(--c-purple-primary); }
.auth-form .btn,
.auth-form button[type="submit"] {
  margin-top: 8px; padding: 14px 32px;
  background: var(--c-purple-button); color: #fff;
  border: 1px solid var(--c-purple-button);
  font-family: var(--font-2); font-size: 15px; font-weight: 700;
  letter-spacing: .04em; cursor: pointer; transition: background .2s;
}
.auth-form button[type="submit"]:hover { background: var(--c-purple-hover); }
.auth-links {
  margin-top: 22px; text-align: center;
  font-size: 13px; color: var(--c-text-grey);
}
.auth-links a { color: var(--c-purple-primary); font-weight: 600; }
.auth-links a:hover { text-decoration: underline; }
.auth-links span { margin: 0 8px; opacity: .5; }
.alert { padding: 12px 16px; margin-bottom: 16px; font-size: 13px; border-radius: 0; }
.alert-error { background: #fdecea; color: #b3261e; border: 1px solid #f5c6c2; }
.alert-success { background: #e8f5e9; color: #1b5e20; border: 1px solid #b8dfbb; }

.rvl-related { padding: 20px 0 30px; background: #fff; }
.rvl-related__title {
  font-family: var(--font-2);
  font-weight: 400;
  font-size: 24px;
  color: var(--c-purple-text);
  text-align: center;
  margin: 0 0 22px;
  letter-spacing: .04em;
}

/* ============================================================
   PAGE HERO (interior)
   ============================================================ */
.rvl-page-hero {
  background: linear-gradient(135deg, var(--c-purple-dark), var(--c-purple-primary));
  color: #fff;
  padding: 130px 0 100px;
}
.rvl-page-hero.with-image {
  background:
    linear-gradient(120deg, rgba(15,5,30,.78) 0%, rgba(61,26,94,.55) 60%, rgba(0,0,0,.2) 100%),
    var(--ph-img) center/cover no-repeat;
}
.rvl-page-hero__eyebrow {
  font-family: var(--font-1);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .22em;
  color: rgba(255,255,255,.9);
  margin: 0 0 20px;
}
.rvl-page-hero h1 {
  color: #fff;
  font-family: var(--font-2);
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.15;
  margin: 0 0 20px;
  max-width: 820px;
  letter-spacing: 0;
}
.rvl-page-hero h1 .accent {
  color: var(--c-purple-light);
  font-style: italic;
  font-weight: 400;
}
.rvl-page-hero p {
  color: rgba(255,255,255,.85);
  font-size: 18px;
  max-width: 640px;
  margin: 12px 0 0;
}

/* ============================================================
   INFO SECTION (3 bloques numerados)
   ============================================================ */
.rvl-info-section { padding: 110px 0; background: #fff; }
.rvl-info-section--alt { background: var(--c-bg-soft); }
.rvl-section-head { margin-bottom: 50px; max-width: 760px; }
.rvl-section-head__eyebrow {
  font-family: var(--font-1);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .22em;
  color: var(--c-purple-primary);
  margin: 0 0 14px;
}
.rvl-section-head h2 {
  font-family: var(--font-2);
  font-size: clamp(24px, 3vw, 36px);
  font-weight: 700;
  line-height: 1.2;
  margin: 0 0 16px;
}
.rvl-section-head p {
  color: var(--c-text-grey);
  font-size: 16px;
  line-height: 1.6;
}
.rvl-info-blocks {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 50px;
}
.rvl-info-block {
  padding: 40px 32px;
  background: var(--c-bg-soft);
  border: 1px solid var(--c-line);
  transition: all .3s;
}
.rvl-info-block:hover {
  border-color: var(--c-purple-primary);
  transform: translateY(-3px);
}
.rvl-info-block__num {
  font-family: var(--font-2);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .12em;
  color: var(--c-purple-primary);
  display: block;
  margin-bottom: 18px;
}
.rvl-info-block h3 {
  font-family: var(--font-2);
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 12px;
}
.rvl-info-block p {
  color: var(--c-text-grey);
  font-size: 15px;
  line-height: 1.6;
  margin: 0;
}

/* ============================================================
   FORMACION (banda morada)
   ============================================================ */
.rvl-band {
  padding: 140px 0;
  background: linear-gradient(135deg, var(--c-purple-dark), var(--c-purple-primary));
  color: #fff;
}
.rvl-band h2 { color: #fff; max-width: 600px; font-family: var(--font-2); font-size: 36px; font-weight: 700; margin: 0 0 18px; }
.rvl-band p { color: rgba(255,255,255,.8); max-width: 560px; margin-bottom: 36px; font-size: 17px; line-height: 1.6; }

/* ============================================================
   CONTACT (datos + formulario)
   ============================================================ */
.rvl-contact {
  padding: 100px 0;
  background: #fff;
}
.rvl-contact__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.rvl-contact h2 {
  font-family: var(--font-2);
  font-size: 32px;
  font-weight: 700;
  margin: 0 0 16px;
}
.rvl-contact-list {
  margin-top: 32px;
}
.rvl-contact-list li {
  padding: 18px 0;
  border-bottom: 1px solid var(--c-line);
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 16px;
  font-size: 15px;
}
.rvl-contact-list strong {
  color: var(--c-text-grey);
  font-weight: 700;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.rvl-contact-list a { color: var(--c-text); }
.rvl-contact-list a:hover { color: var(--c-purple-primary); }

.rvl-form {
  display: grid;
  gap: 18px;
  background: var(--c-bg-soft);
  padding: 36px;
  border: 1px solid var(--c-line);
}
.rvl-form label {
  display: grid;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--c-text-grey);
}
.rvl-form input,
.rvl-form textarea {
  padding: 14px 16px;
  border: 1px solid var(--c-line);
  background: #fff;
  font-family: var(--font-1);
  font-size: 15px;
  font-weight: 400;
  color: var(--c-text);
  text-transform: none;
  letter-spacing: 0;
  border-radius: 0;
}
.rvl-form input:focus,
.rvl-form textarea:focus { outline: none; border-color: var(--c-purple-primary); }

.rvl-locations-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 40px;
}
.rvl-location-card {
  padding: 36px;
  border: 1px solid var(--c-line);
  background: #fff;
}
.rvl-location-card h3 {
  color: var(--c-purple-primary);
  margin-bottom: 10px;
  font-size: 22px;
  font-weight: 700;
  font-family: var(--font-2);
}
.rvl-location-card p {
  margin: 0 0 6px;
  color: var(--c-text-grey);
  font-size: 15px;
}

/* ============================================================
   SOPORTE / DESCARGABLES
   ============================================================ */
.rvl-soporte-hero {
  background: linear-gradient(135deg, var(--c-purple-dark), var(--c-purple-primary));
  color: #fff;
  padding: 100px 0;
}
.rvl-soporte-hero__inner {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: center;
}
.rvl-soporte-hero h1 {
  color: #fff;
  font-family: var(--font-2);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 700;
  line-height: 1.25;
  margin: 0 0 28px;
}
.rvl-soporte-hero h1 .accent { color: var(--c-purple-light); font-style: italic; font-weight: 400; }
.rvl-soporte-hero p {
  color: rgba(255,255,255,.88);
  font-size: 17px;
  line-height: 1.75;
  margin: 0 0 36px;
  max-width: 480px;
}
.rvl-soporte-hero__images {
  position: relative;
  height: 360px;
}
.rvl-soporte-hero__images img {
  position: absolute;
  border-radius: 12px;
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.5);
}
.rvl-soporte-hero__images img:first-child { top: 50%; left: 50%; width: 70%; max-width: 280px; transform: translate(-50%,-50%); z-index: 2; }

.rvl-downloads-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 50px;
}
.rvl-download-card {
  background: #fff;
  border: 1px solid var(--c-line);
  padding: 40px 32px;
  text-align: center;
  transition: all .3s;
  display: flex;
  flex-direction: column;
}
.rvl-download-card:hover {
  border-color: var(--c-purple-primary);
  transform: translateY(-4px);
}
.rvl-download-card__icon { font-size: 48px; margin-bottom: 18px; }
.rvl-download-card h3 {
  font-family: var(--font-2);
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 14px;
}
.rvl-download-card p {
  font-size: 14px;
  color: var(--c-text-grey);
  line-height: 1.6;
  margin-bottom: 28px;
  flex: 1;
}

/* ============================================================
   LEGAL (politica de privacidad)
   ============================================================ */
.rvl-legal {
  padding: 80px 0 120px;
  background: #fff;
}
.rvl-legal__container { max-width: 800px; margin: 0 auto; }
.rvl-legal__intro {
  font-size: 16px !important;
  line-height: 1.8 !important;
  padding: 24px;
  background: var(--c-bg-soft);
  border-left: 3px solid var(--c-purple-primary);
  margin-bottom: 30px;
}
.rvl-legal h2 {
  font-family: var(--font-2);
  font-size: 22px;
  font-weight: 700;
  margin: 48px 0 16px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--c-line);
  color: var(--c-text);
}
.rvl-legal h2:first-of-type { margin-top: 30px; }
.rvl-legal p {
  font-size: 15px;
  line-height: 1.75;
  margin-bottom: 14px;
  color: var(--c-text-grey);
}
.rvl-legal ul {
  list-style: disc;
  padding-left: 22px;
  margin: 0 0 18px;
}
.rvl-legal ul li {
  font-size: 15px;
  line-height: 1.75;
  margin-bottom: 8px;
  color: var(--c-text-grey);
}
.rvl-legal strong { color: var(--c-text); }
.rvl-legal a {
  color: var(--c-purple-primary);
  border-bottom: 1px solid var(--c-purple-light);
}
.rvl-legal hr {
  border: none;
  border-top: 1px solid var(--c-line);
  margin: 60px 0 30px;
}
.rvl-legal__update {
  text-align: center;
  margin-top: 40px;
  font-size: 13px !important;
  color: var(--c-text-grey);
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
  .rvl-pcard { flex-basis: calc((100% - 90px) / 4); }
  .rvl-collection__grid { grid-template-columns: repeat(3, 1fr); }
  .rvl-info-blocks { grid-template-columns: 1fr; gap: 24px; }
  .rvl-contact__inner { grid-template-columns: 1fr; gap: 50px; }
  .rvl-soporte-hero__inner { grid-template-columns: 1fr; gap: 40px; }
  .rvl-soporte-hero__images { height: 240px; max-width: 400px; margin: 0 auto; }
  .rvl-downloads-grid { grid-template-columns: 1fr; }
  .rvl-locations-grid { grid-template-columns: 1fr; }
}
@media (max-width: 1024px) {
  .rvl-collection__layout { grid-template-columns: 1fr; gap: 24px; }
  .rvl-sidebar { position: static; }
  .rvl-product__layout { grid-template-columns: 1fr; gap: 30px; }
  .rvl-product__gallery { position: static; }
  .rvl-collection__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
  .rvl-topbar__inner { flex-direction: column; height: auto; padding: 8px 30px; gap: 4px; }
  .rvl-header__inner { grid-template-columns: auto 1fr auto; gap: 16px; }
  .rvl-header__hamburger { display: flex; }
  .rvl-header__logo img { height: 32px; max-width: 120px; }
  .rvl-nav { display: none; }
  /* Header: fixed al abrir, se expande en 2 filas */
  .rvl-header.nav-open {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 9999;
  }
  .rvl-header.nav-open .rvl-header__inner {
    grid-template-columns: auto 1fr auto !important;
    grid-template-rows: 88px auto !important;
    height: auto !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    max-height: 100vh;
    overflow-y: auto;
  }
  .rvl-header.nav-open .rvl-header__hamburger { grid-column: 1; grid-row: 1; padding: 0 0 0 16px !important; align-self: center; }
  .rvl-header.nav-open .rvl-header__logo    { grid-column: 2; grid-row: 1; justify-self: center; align-self: center; }
  .rvl-header.nav-open .rvl-header__icons   { grid-column: 3; grid-row: 1; align-self: center; padding: 0 16px 0 0 !important; }
  /* Nav ocupa toda la segunda fila */
  .rvl-header.nav-open .rvl-nav {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;
    display: block !important;
    position: static !important;
    transform: none !important;
    width: 100% !important;
    background: #3d1a5e;
    padding: 0 0 20px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.1);
    max-height: calc(100vh - 88px);
    overflow-y: auto;
  }
  .rvl-header.nav-open .rvl-nav .rvl-nav__list { display: block !important; width: 100%; padding: 0; margin: 0; }
  .rvl-header.nav-open .rvl-nav .rvl-nav__item { display: block !important; width: 100%; border-bottom: 1px solid rgba(255,255,255,.12); }
  .rvl-header.nav-open .rvl-nav .rvl-nav__link { padding: 16px 20px !important; display: flex !important; justify-content: space-between; align-items: center; font-size: 16px; width: 100%; box-sizing: border-box; cursor: pointer; color: #fff !important; }
  .rvl-header.nav-open .rvl-nav .rvl-nav__caret { transition: transform .2s; display: inline-block; flex-shrink: 0; }
  .rvl-header.nav-open .rvl-nav .rvl-nav__item.is-open > .rvl-nav__link .rvl-nav__caret { transform: rotate(180deg); }
  /* Megamenu: oculto por defecto, sólo se abre con .is-open */
  .rvl-header.nav-open .rvl-nav .rvl-megamenu {
    display: none !important;
    position: static !important;
    transform: none !important;
    opacity: 1 !important;
    visibility: visible !important;
    transition: none !important;
  }
  .rvl-header.nav-open .rvl-nav .rvl-nav__item.is-open > .rvl-megamenu {
    display: block !important;
    background: rgba(0,0,0,.22);
    padding: 4px 0 10px;
    width: 100%;
    pointer-events: auto;
  }
  .rvl-header.nav-open .rvl-nav .rvl-megamenu ul { display: block !important; padding: 0; margin: 0; }
  .rvl-header.nav-open .rvl-nav .rvl-megamenu li { display: block !important; opacity: 1 !important; visibility: visible !important; transform: none !important; }
  .rvl-header.nav-open .rvl-nav .rvl-megamenu a { display: block !important; padding: 12px 32px; color: rgba(255,255,255,.85) !important; font-size: 15px; border-bottom: 1px solid rgba(255,255,255,.05); opacity: 1 !important; visibility: visible !important; }
  .rvl-header.nav-open .rvl-nav .rvl-megamenu a:hover { color: #fff !important; background: rgba(255,255,255,.06); }
  .rvl-header.nav-open .rvl-nav .rvl-megamenu__title { display: block !important; padding: 10px 32px 4px; font-size: 11px; color: rgba(255,255,255,.45) !important; text-transform: uppercase; letter-spacing: .1em; margin: 0; }
  .rvl-sidebar { display: none; }
  .rvl-collection__layout { grid-template-columns: 1fr; }
  .rvl-brands__grid { grid-template-columns: repeat(3, 1fr); }
  .rvl-pcard { flex-basis: calc((100% - 30px) / 2); }
  .rvl-service-block__inner { grid-template-columns: 1fr; gap: 30px; }
  .rvl-press-banner__inner { grid-template-columns: 1fr; gap: 36px; }
  .rvl-press-banner__content { max-width: none; text-align: center; margin: 0 auto; }
  .rvl-press-banner__divider { margin-left: auto; margin-right: auto; }
  .rvl-spotlight__grid { grid-template-columns: 1fr; }
  .rvl-policies__grid { grid-template-columns: repeat(2, 1fr); }
  .rvl-footer__inner { grid-template-columns: 1fr; gap: 40px; }
  .rvl-image-banner__title { font-size: 20px; line-height: 1.3; max-width: 70%; }
  .rvl-press-banner__title { font-size: 28px; }
  .rvl-hero__arrow { width: 36px; height: 36px; font-size: 22px; }
  .rvl-hero__arrow--prev { left: 10px; }
  .rvl-hero__arrow--next { right: 10px; }
}

@media (max-width: 600px) {
  .rvl-brands__grid { grid-template-columns: repeat(2, 1fr); }
  .rvl-pcard { flex-basis: 80%; }
  .rvl-product-block__title { font-size: 24px; }
  .rvl-policies__grid { grid-template-columns: 1fr; gap: 12px; }
}
