/* ==========================================================================
   MOSAIC — PERFORMANCE (dead CSS, no HTML section)
   ========================================================================== */
.mosaic-container {
  padding: var(--pad-y) var(--pad-x);
  --bgColor: var(--white);
  background-color: var(--bgColor);
}
.mosaic-container .section-inner {
  max-width: var(--container);
  margin: 0 auto;
}
.mosaic-container .mosaic-header {
  margin-bottom: 40px;
}
.mosaic-container .mosaic-header .eyebrow-hr {
  margin-bottom: 16px;
}

/* Mosaic Carousel */
.mosaic-carousel {
  position: relative;
  overflow: hidden;
}
.mosaic-carousel__track {
  display: flex;
  transition: transform 0.6s cubic-bezier(0.25, 0.1, 0.25, 1);
}
.mosaic-slide-container {
  min-width: 100%;
  flex-shrink: 0;
}

/* Layout-one: image left, text right */
.mosaic-slide-container.layout-one {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
}
.mosaic-slide-container.layout-one .mosaic-image {
  border-radius: var(--radius-feature);
  overflow: hidden;
  aspect-ratio: 16 / 10;
}
.mosaic-slide-container.layout-one .mosaic-info {
  padding: 0;
}

/* Layout-two: text left, image right (reversed) */
.mosaic-slide-container.layout-two {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
}
.mosaic-slide-container.layout-two .mosaic-image {
  border-radius: var(--radius-feature);
  overflow: hidden;
  aspect-ratio: 16 / 10;
}

/* Layout-three: different ratio */
.mosaic-slide-container.layout-three {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
}
.mosaic-slide-container.layout-three .mosaic-image {
  border-radius: var(--radius-feature);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}

.mosaic-info__eyebrow {
  color: var(--mid-gray);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 8px;
}
.mosaic-info__title {
  margin-bottom: 12px;
}
.mosaic-info__body {
  color: var(--mid-gray);
}

/* Carousel controls */
.mosaic-carousel__controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 32px;
}
.mosaic-carousel__btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--lighter-gray);
  background: var(--white);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: var(--transition);
}
.mosaic-carousel__btn:hover {
  border-color: var(--black);
  background: var(--black);
  color: var(--white);
}
.mosaic-carousel__btn:hover svg { stroke: var(--white); }
.mosaic-carousel__btn svg {
  width: 18px;
  height: 18px;
  stroke: var(--black);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.mosaic-carousel__dots {
  display: flex;
  gap: 8px;
}
.mosaic-carousel__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--lighter-gray);
  border: none;
  cursor: pointer;
  transition: var(--transition);
}
.mosaic-carousel__dot.active {
  background: var(--red-cta);
  width: 24px;
  border-radius: 4px;
}


