/* css/portfolio-carousel.css */
/* Minimal Web – Portfolio Carousel
   Uses CSS scroll-snap for buttery scrolling and a tiny JS controller.
   Relies on the page-level CSS variables: --bg, --fg, --muted, --border, --card.
*/
.carousel{position:relative}
.carousel__viewport{
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  border-radius:16px
}
.carousel__viewport::-webkit-scrollbar{display:none}

.carousel__track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:100%;
  gap:14px
}
@media(min-width:780px){.carousel__track{grid-auto-columns:50%}}
@media(min-width:1100px){.carousel__track{grid-auto-columns:33.333%}}

.slide{scroll-snap-align:start}

.shot{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:16px;
  aspect-ratio:4/3;
  overflow:hidden;
  display:block
}
.shot__img{width:100%; height:100%; object-fit:cover; display:block}

.carousel__arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  border:1px solid var(--border);
  background:color-mix(in oklab, var(--bg) 90%, transparent);
  backdrop-filter:saturate(150%) blur(4px);
  padding:8px 12px;
  border-radius:999px;
  cursor:pointer;
  user-select:none;
  z-index: 100;
}
.carousel__arrow.prev{left:-4px}
.carousel__arrow.next{right:-4px}
@media(min-width:780px){
  .carousel__arrow.prev{left:-8px}
  .carousel__arrow.next{right:-8px}
}

.carousel__dots{
  display:flex;
  gap:8px;
  justify-content:center;
  margin-top:12px
}
.carousel__dots .dot{
  width:8px; height:8px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--card);
  cursor:pointer
}
.carousel__dots .dot.is-active{background:var(--fg)}