/* Menu Preview Carousel
   Displays this week's meals grouped by category with left/right navigation. */

:root {
  --dtec-carousel-bg:          var(--dtec-bg-section, #FDF8F4);
  --dtec-carousel-maroon:      var(--dtec-primary, #8F385D);
  --dtec-carousel-badge-bg:    var(--dtec-primary-dark, #6C2C47);
  --dtec-carousel-card-width:  260px;
  --dtec-carousel-gap:         1rem;
  --dtec-carousel-arrow-size:  2.5rem;
}

/* ---- Section wrapper ---- */
.dtec-menu-carousel {
  background: var(--dtec-carousel-bg);
  padding: var(--space-3xl) var(--space-m);
  text-align: center;
  position: relative;
}

/* ---- Heading ---- */
.dtec-menu-carousel__heading {
  font-size: var(--text-3xl);
  font-weight: var(--dtec-font-extrabold);
  color: var(--dtec-text);
  margin: 0 auto var(--space-2xs);
  max-width: 640px;
  line-height: var(--dtec-leading-tight);
}

/* ---- Subtitle (date range) ---- */
.dtec-menu-carousel__subtitle {
  font-size: var(--text-s);
  color: var(--dtec-carousel-maroon);
  font-weight: var(--dtec-font-semibold);
  letter-spacing: 0.03em;
  margin: 0 auto var(--space-s);
}

/* ---- Description paragraph ---- */
.dtec-menu-carousel__desc {
  font-size: var(--text-m);
  color: var(--dtec-text-muted);
  margin: 0 auto var(--space-xl);
  max-width: 560px;
  line-height: var(--dtec-leading-relaxed);
}

/* ---- Category toggle tabs ---- */
.dtec-menu-carousel__toggle {
  display: flex;
  justify-content: center;
  gap: var(--space-2xs);
  margin-bottom: var(--space-xl);
  flex-wrap: wrap;
}

.dtec-menu-carousel__toggle-btn {
  padding: var(--space-2xs) var(--space-l);
  border-radius: var(--dtec-radius-full);
  border: 2px solid var(--dtec-carousel-maroon);
  background: transparent;
  color: var(--dtec-carousel-maroon);
  font-size: var(--text-s);
  font-weight: var(--dtec-font-semibold);
  cursor: pointer;
  transition: background var(--dtec-duration-fast) var(--dtec-ease-default),
              color var(--dtec-duration-fast) var(--dtec-ease-default);
  font-family: var(--dtec-font-family);
}

.dtec-menu-carousel__toggle-btn--active {
  background: var(--dtec-carousel-maroon);
  color: var(--dtec-white);
}

.dtec-menu-carousel__toggle-btn:hover:not(.dtec-menu-carousel__toggle-btn--active) {
  background: color-mix(in srgb, var(--dtec-carousel-maroon) 10%, transparent);
}

/* ---- Card track ---- */
.dtec-menu-carousel__track-wrapper {
  position: relative;
  max-width: var(--dtec-max-width-xl);
  margin: 0 auto;
  padding: 0 calc(var(--dtec-carousel-arrow-size) + var(--space-2xs));
}

.dtec-menu-carousel__cards {
  display: flex;
  gap: var(--dtec-carousel-gap);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;          /* Firefox */
  -ms-overflow-style: none;       /* IE 11 */
  padding-bottom: var(--space-m); /* room for shadow */
}

.dtec-menu-carousel__cards::-webkit-scrollbar {
  display: none;
}

/* ---- Individual meal card ---- */
.dtec-menu-carousel__card {
  flex: 0 0 var(--dtec-carousel-card-width);
  scroll-snap-align: start;
  background: var(--dtec-white);
  border-radius: var(--dtec-radius-lg);
  box-shadow: var(--dtec-shadow-md);
  overflow: hidden;
  text-align: left;
}

/* Mobile: fill viewport width */
@media (max-width: 639px) {
  .dtec-menu-carousel__card {
    flex: 0 0 calc(100% - var(--space-m));
  }
}

/* Tablet: 2 cards */
@media (min-width: 640px) and (max-width: 1023px) {
  .dtec-menu-carousel__card {
    flex: 0 0 calc(50% - var(--dtec-carousel-gap) / 2);
  }
}

/* Desktop: 3 cards naturally at 260px each — track-wrapper handles max-width */

/* ---- Card image area ---- */
.dtec-menu-carousel__card-img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  background: var(--dtec-neutral-100);
}

.dtec-menu-carousel__card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.dtec-menu-carousel__card-img--placeholder {
  width: 100%;
  height: 100%;
  background: var(--dtec-neutral-200);
}

/* ---- Organic badge ---- */
.dtec-menu-carousel__card-badge {
  position: absolute;
  top: var(--space-2xs);
  left: var(--space-2xs);
  background: var(--dtec-carousel-badge-bg);
  color: var(--dtec-white);
  font-size: var(--text-xs);
  font-weight: var(--dtec-font-bold);
  letter-spacing: 0.06em;
  padding: var(--space-3xs) var(--space-2xs);
  border-radius: var(--dtec-radius-sm);
  text-transform: uppercase;
  line-height: 1.2;
}

/* ---- Dietary tags ---- */
.dtec-menu-carousel__card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3xs);
  list-style: none;
  margin: var(--space-s) var(--space-s) 0;
  padding: 0;
}

.dtec-menu-carousel__card-tag {
  font-size: var(--text-xs);
  font-weight: var(--dtec-font-bold);
  padding: 2px var(--space-2xs);
  border-radius: var(--dtec-radius-full);
  background: var(--dtec-neutral-100);
  color: var(--dtec-text-muted);
  letter-spacing: 0.04em;
}

/* ---- Card text ---- */
.dtec-menu-carousel__card-name {
  font-size: var(--text-m);
  font-weight: var(--dtec-font-bold);
  color: var(--dtec-text);
  margin: var(--space-2xs) var(--space-s) var(--space-3xs);
  line-height: var(--dtec-leading-tight);
}

.dtec-menu-carousel__card-desc {
  font-size: var(--text-s);
  color: var(--dtec-text-muted);
  margin: 0 var(--space-s) var(--space-s);
  line-height: var(--dtec-leading-normal);
}

/* ---- Arrow navigation ---- */
.dtec-menu-carousel__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: var(--dtec-carousel-arrow-size);
  height: var(--dtec-carousel-arrow-size);
  border-radius: var(--dtec-radius-full);
  background: var(--dtec-white);
  border: 1px solid var(--dtec-border);
  box-shadow: var(--dtec-shadow-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: var(--dtec-text);
  transition: box-shadow var(--dtec-duration-fast) var(--dtec-ease-default),
              background var(--dtec-duration-fast) var(--dtec-ease-default);
  padding: 0;
  line-height: 1;
  font-family: var(--dtec-font-family);
}

.dtec-menu-carousel__arrow:hover {
  background: var(--dtec-neutral-50);
  box-shadow: var(--dtec-shadow-lg);
}

.dtec-menu-carousel__arrow--left {
  left: 0;
}

.dtec-menu-carousel__arrow--right {
  right: 0;
}

/* ---- Empty state ---- */
.dtec-menu-carousel__empty {
  color: var(--dtec-text-muted);
  font-size: var(--text-s);
  padding: var(--space-xl) 0;
  width: 100%;
  text-align: center;
}

@media (max-width: 768px) {
  .dtec-menu-carousel__track-wrapper {
    padding: 0 0 60px;
  }

  .dtec-menu-carousel__arrow {
    top: auto;
    bottom: 0;
    transform: none;
    width: 40px;
    height: 40px;
  }

  .dtec-menu-carousel__arrow--left {
    left: calc(50% - 56px);
  }

  .dtec-menu-carousel__arrow--right {
    right: calc(50% - 56px);
  }
}
