/* Products List — Figma 1009:7024 (desktop) / 1009:7696 (mobile) / 693:3891 (more-info). */

/* ---- Section shell ---- */
.rw-block-products-list {
  position: relative; overflow: hidden; isolation: isolate;
  background: var(--rw-color-bg-mist);
}
.rw-block-products-list .rw-container { position: relative; z-index: 2; }
.rw-block-products-list[data-bg-dots-position="top-left"]     .bg-dots { left: -7%; top: -12%; z-index: 1; }
.rw-block-products-list[data-bg-dots-position="top-right"]    .bg-dots { right: -7%; top: -12%; left: auto; z-index: 1; }
.rw-block-products-list[data-bg-dots-position="bottom-left"]  .bg-dots { left: -7%; bottom: -12%; top: auto; z-index: 1; }
.rw-block-products-list[data-bg-dots-position="bottom-right"] .bg-dots { right: -7%; bottom: -12%; left: auto; top: auto; z-index: 1; }

/* ---- Intro ---- */
.rw-block-products-list .intro {
  max-width: 56rem; display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: var(--rw-space-sm); margin: 0 auto 7.5rem;
}
.rw-block-products-list .intro h2 {
  font-size: var(--rw-h2-size); line-height: var(--rw-h2-line);
  letter-spacing: var(--rw-h2-tracking); color: var(--rw-color-primary-green); margin: 0;
}
.rw-block-products-list .intro .body {
  margin: 0; color: var(--rw-color-grey-01);
  font-size: var(--rw-p1-size); line-height: var(--rw-p1-line);
}

/* ---- List header row ---- */
.rw-block-products-list .list-header {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--rw-space-sm); margin-bottom: var(--rw-space-lg);
}
.rw-block-products-list .list-heading {
  font-size: 2rem; /* 32px — no exact token; matches h2/h1 mobile lower bound */
  line-height: 1.25; letter-spacing: var(--rw-h2-tracking);
  color: var(--rw-color-primary-green); margin: 0;
}

/* ---- Filter chips ---- */
.rw-block-products-list .filters { display: flex; flex-wrap: wrap; gap: var(--rw-space-xs); }
.rw-block-products-list .filter-chip {
  display: inline-flex; align-items: center; padding: 14px 16px; line-height: 1;
  border: 0; border-radius: 4px; background: rgba(70, 75, 80, 0.1);
  color: var(--rw-color-grey-01); font-family: var(--rw-font-mono); font-weight: 500;
  font-size: var(--rw-caption-size); letter-spacing: var(--rw-caption-tracking);
  text-transform: uppercase; cursor: pointer; transition: background 0.15s ease, color 0.15s ease;
}
.rw-block-products-list .filter-chip.is-active { background: var(--rw-color-primary-blue); color: var(--rw-color-white); }
.rw-block-products-list .filter-chip:focus-visible { outline: none; box-shadow: var(--rw-state-focus-ring); }

/* ---- Cards grid ---- */
.rw-block-products-list .cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  column-gap: var(--rw-space-md); row-gap: 3rem;
  list-style: none; margin: 0; padding: 0;
}

/* ---- Card ---- */
.rw-block-products-list .card {
  background: var(--rw-color-white); border-radius: var(--rw-radius-lg);
  padding: var(--rw-space-md) var(--rw-space-md) var(--rw-space-xl);
  display: flex; flex-direction: column;
}
/* Filter hide — beat .card's display:flex specificity. */
.rw-block-products-list .card[hidden] { display: none; }

/* ---- Image wrap ---- */
.rw-block-products-list .img-wrap {
  position: relative; background: rgba(206, 214, 226, 0.3);
  border-radius: var(--rw-radius-xs); overflow: hidden; aspect-ratio: 376 / 382;
  display: flex; align-items: center; justify-content: center;
  border: 0; padding: 0; cursor: default; width: 100%;
}
.rw-block-products-list .img-wrap.has-video { cursor: pointer; }
.rw-block-products-list .img-wrap img {
  display: block; width: 100%; height: 100%; object-fit: contain; transition: transform 0.4s ease;
  mix-blend-mode: multiply;
}
.rw-block-products-list .img-wrap.has-video:hover img { transform: scale(1.04); }

/* ---- Play overlay — bottom-right glass square ---- */
.rw-block-products-list .play-overlay {
  position: absolute; bottom: var(--rw-space-xs); right: var(--rw-space-xs);
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px; border-radius: 0.4rem;
  background: rgba(0, 0, 0, 0.40);
  backdrop-filter: blur(50px);
  -webkit-backdrop-filter: blur(50px);
}
.rw-block-products-list .play-overlay svg { width: 8px; height: 10px; }

/* ---- Card text ---- */
.rw-block-products-list .card-eyebrow {
  margin: 2rem 0; font-family: var(--rw-font-mono); font-weight: 500;
  font-size: var(--rw-caption-size); line-height: 1;
  letter-spacing: var(--rw-caption-tracking); text-transform: uppercase; color: var(--rw-color-grey-01);
}
.rw-block-products-list .card-title {
  margin: 0 0 1rem; font-size: 2rem; line-height: 1.25;
  letter-spacing: var(--rw-h3-tracking); color: var(--rw-color-primary-green);
}
.rw-block-products-list .more-info-text {
  margin: 0 0 1rem; font-family: var(--rw-font-text);
  font-size: var(--rw-p2-size); line-height: 1.4; color: var(--rw-color-grey-01);
}

/* ---- More info — native <details> ---- */
.rw-block-products-list .more-info {
  border-bottom: 1px solid var(--rw-color-border); padding-bottom: var(--rw-space-sm);
  margin-bottom: 1.5rem;
}
.rw-block-products-list .more-info summary {
  display: flex; align-items: center; justify-content: space-between; cursor: pointer;
  list-style: none; font-family: var(--rw-font-text);
  font-size: var(--rw-p2-size); color: var(--rw-color-primary-green); gap: var(--rw-space-xs);
}
.rw-block-products-list .more-info summary .label { font-weight: 700; }
.rw-block-products-list .more-info summary::-webkit-details-marker { display: none; }
.rw-block-products-list .more-info summary .icon { display: inline-flex; flex-shrink: 0; }
/* +/- icon swap via [open] state — no rotate. */
.rw-block-products-list .more-info summary .icon--minus { display: none; }
.rw-block-products-list .more-info[open] summary .icon--plus  { display: none; }
.rw-block-products-list .more-info[open] summary .icon--minus { display: inline-flex; }
.rw-block-products-list .more-info-body {
  padding-top: var(--rw-space-sm); display: flex; flex-direction: column; gap: var(--rw-space-xs);
}
.rw-block-products-list .more-info-body p {
  margin: 0; font-size: var(--rw-p2-size); line-height: var(--rw-p2-line); color: var(--rw-color-grey-01);
}
.rw-block-products-list .more-info-body ul { margin: 0; padding: 0; list-style: none; display: flex; flex-direction: column; gap: 0.375rem; }
.rw-block-products-list .more-info-body li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: var(--rw-p2-size); line-height: var(--rw-p2-line); color: var(--rw-color-grey-01);
}
.rw-block-products-list .more-info-body li .bullet-icon {
  display: inline-flex; flex-shrink: 0; position: relative; margin-top: 0.2em;
}

/* ---- Download button ---- */
.rw-block-products-list .download {
  display: flex; align-items: center; justify-content: space-between; gap: var(--rw-space-sm);
  padding: 0.875rem var(--rw-space-md); border: 1px solid var(--rw-color-border);
  border-radius: var(--rw-radius-sm); background: transparent; color: var(--rw-color-primary-green);
  font-family: var(--rw-font-text); font-weight: 600; font-size: var(--rw-p2-size);
  line-height: 1; text-decoration: none;
  transition: background-color .35s ease, color .35s ease, border-color .35s ease, box-shadow .35s ease, opacity .35s ease;
}
.rw-block-products-list .download:hover {
  background: var(--rw-color-primary-green); color: var(--rw-color-white);
  border-color: var(--rw-color-primary-green); opacity: 1;
}
.rw-block-products-list .download:focus-visible { outline: none; box-shadow: var(--rw-state-focus-ring); }
.rw-block-products-list .empty { color: var(--rw-color-grey-01); text-align: center; padding: var(--rw-space-lg) 0; }

/* ---- Video dialog (mirrors hero-media dialog pattern) ---- */
.rw-products-list-dialog {
  position: fixed; inset: 0; margin: auto; border: 0; padding: 0;
  width: min(90vw, 64rem); max-height: 90vh; background: transparent; color: inherit;
}
.rw-products-list-dialog::backdrop { background: rgba(0, 5, 12, 0.85); }
.rw-products-list-dialog .rw-pl-video-host { display: block; }
.rw-products-list-dialog video { width: 100%; height: auto; display: block; border-radius: var(--rw-radius-md); }
.rw-products-list-dialog .rw-video-embed-iframe { width: 100%; aspect-ratio: 16 / 9; display: block; border: 0; border-radius: var(--rw-radius-md); background: #000; }
.rw-products-list-dialog .dialog-close {
  position: absolute; top: -2.5rem; right: 0; width: 2.25rem; height: 2.25rem;
  background: transparent; border: 0; color: var(--rw-color-white);
  font-size: 1.75rem; line-height: 1; cursor: pointer;
}
.rw-products-list-dialog .dialog-close:focus-visible { outline: none; box-shadow: var(--rw-state-focus-ring); }

/* ---- Mobile ---- */
@media (max-width: 767px) {
  .rw-block-products-list .intro { margin-bottom: var(--rw-space-lg); }
  .rw-block-products-list .list-header { flex-direction: column; align-items: flex-start; }
  .rw-block-products-list .cards { grid-template-columns: 1fr; }
}
