/* ── shared carousel controls ── */

.carousel-arrow {
  background: transparent;
  color: var(--color-border);
  border: 1px solid var(--color-border);
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: bold;
  padding: 6px 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
  flex-shrink: 0;
}

.carousel-arrow:hover {
  background: var(--color-inv-bg);
  border-color: var(--color-inv-bg);
  color: var(--color-inv-text);
}

.carousel-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 12px;
}

.carousel-more {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.06em;
  color: var(--color-border);
  background: transparent;
  border: 1px solid var(--color-border);
  padding: 6px 20px;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.carousel-more:hover {
  background: var(--color-inv-bg);
  border-color: var(--color-inv-bg);
  color: var(--color-inv-text);
}

.carousel-dots {
  display: flex;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
}

.carousel-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--purple-200);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background 0.2s;
}

.carousel-dot.active {
  background: var(--color-border);
}

@media (max-width: 480px) {
  .carousel-arrow {
    width: 26px;
    height: 26px;
    font-size: 13px;
  }
}
