[data-fui-comp="ui-carousel"] {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-sm, 8px);
  --ui-carousel-cols: 1;
}
[data-fui-comp="ui-carousel"].ui-carousel--cols-1 { --ui-carousel-cols: 1; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-2 { --ui-carousel-cols: 2; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-3 { --ui-carousel-cols: 3; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-4 { --ui-carousel-cols: 4; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-5 { --ui-carousel-cols: 5; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-6 { --ui-carousel-cols: 6; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-7 { --ui-carousel-cols: 7; }
[data-fui-comp="ui-carousel"].ui-carousel--cols-8 { --ui-carousel-cols: 8; }

[data-fui-comp="ui-carousel"] .ui-carousel__track {
  display: flex;
  gap: var(--spacing-md, 12px);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
[data-fui-comp="ui-carousel"] .ui-carousel__track:focus-visible {
  outline: 2px solid var(--color-primary, #4F46E5);
  outline-offset: 2px;
}
[data-fui-comp="ui-carousel"] .ui-carousel__track::-webkit-scrollbar { display: none; }

[data-fui-comp="ui-carousel"] .ui-carousel__slide {
  flex: 0 0 calc((100% - (var(--ui-carousel-cols) - 1) * var(--spacing-md, 12px)) / var(--ui-carousel-cols));
  scroll-snap-align: start;
  border-radius: var(--radii-md, 8px);
  overflow: hidden;
}

[data-fui-comp="ui-carousel"] .ui-carousel__nav {
  position: absolute;
  inset-block-start: 50%;
  transform: translateY(-50%);
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-block-size: var(--spacing-touch-target, 44px);
  min-inline-size: var(--spacing-touch-target, 44px);
  border: 0;
  border-radius: 999px;
  background: var(--color-surface, #FFFFFF);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  color: var(--color-text, #18181B);
  cursor: pointer;
}
[data-fui-comp="ui-carousel"] .ui-carousel__nav--prev { inset-inline-start: 8px; }
[data-fui-comp="ui-carousel"] .ui-carousel__nav--next { inset-inline-end: 8px; }
[data-fui-comp="ui-carousel"] .ui-carousel__nav:hover { background: var(--color-surface-soft, #F4F4F5); }
[data-fui-comp="ui-carousel"] .ui-carousel__nav:focus-visible {
  outline: 2px solid var(--color-primary, #4F46E5);
  outline-offset: 2px;
}
[data-fui-comp="ui-carousel"] .ui-carousel__nav:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

[data-fui-comp="ui-carousel"] .ui-carousel__dots {
  display: flex;
  gap: 6px;
  justify-content: center;
  padding-block-start: var(--spacing-xs, 4px);
}
[data-fui-comp="ui-carousel"] .ui-carousel__dot {
  inline-size: 10px;
  block-size: 10px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--color-border, #E4E4E7);
  cursor: pointer;
  transition: background 120ms ease, transform 120ms ease;
}
[data-fui-comp="ui-carousel"] .ui-carousel__dot[aria-current="true"] {
  background: var(--color-primary, #4F46E5);
  transform: scale(1.2);
}
[data-fui-comp="ui-carousel"] .ui-carousel__dot:focus-visible {
  outline: 2px solid var(--color-primary, #4F46E5);
  outline-offset: 2px;
}