/* ================================================================
   MarkettingCampaigns.css — Campaign carousel and location bar
   All values use Momento design tokens from tokens.css
   ================================================================ */

/* ── Location set button ────────────────────────────────────── */
.setlocation-container {
  display: flex;
  padding: 0 var(--space-2) var(--space-2) var(--space-2);
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-1);
  align-self: stretch;
}

.setlocationBtn {
  display: flex;
  min-width: 64px;
  min-height: 32px;
  border-radius: var(--radius-sm);
  background: var(--color-brand-primary);
  align-items: center;
  gap: var(--space-1);
  justify-content: start;
  width: 100%;
}

.setlocationbtn_text {
  color: var(--color-surface-default);
  text-align: center;
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  font-size: var(--text-label-md-size);
  overflow: hidden;
  line-height: var(--text-label-md-lh);
  letter-spacing: 0.2px;
}

.location_btn_cls {
  display: flex;
  flex-direction: row;
  gap: var(--space-1);
  align-items: center;
  cursor: pointer;
}

.setlocation_location_arrow {
  color: var(--color-surface-default);
  font-size: var(--text-action-md-size);
}

.setlocation_down_arrow {
  color: var(--color-surface-default);
  font-size: 10px;
  font-weight: var(--fw-semibold);
}

/* ── View Deal button ───────────────────────────────────────── */
.viewdealBtn {
  display: flex;
  height: 56px;
  min-width: 104px;
  min-height: 56px;
  padding: 12px var(--space-3);
  align-self: stretch;
  justify-content: center;
  align-items: center;
  gap: var(--space-1);
  border-radius: var(--radius-lg);
  background: var(--color-brand-accent);
  color: var(--color-surface-default);
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-label-md-size);
  font-weight: var(--fw-bold);
  line-height: var(--text-label-md-lh);
  letter-spacing: 0.2px;
  text-transform: none;
  margin-top: var(--space-2);
}

.viewdealBtn:hover {
  background: var(--color-brand-accent);
  color: var(--color-surface-default);
}

@media (min-width: 745px) {
  .viewdealBtn {
    align-self: center;
    width: 100%;
  }
}

/* ── Campaign carousel ──────────────────────────────────────── */
.carousel-container {
  display: flex;
  max-height: 500px;
  height: 350px;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  align-self: stretch;
  background: var(--color-brand-primary);
  overflow: hidden;
  touch-action: pan-x;
}

.campaign_container_web {
  background: var(--color-brand-primary);
  padding-block: 12px;
  padding-inline: var(--space-2);
}

@media (max-width: 715px) { .carousel-container { height: 400px; } }
@media (min-width: 716px) { .carousel-container { height: 400px; } }
@media (min-width: 403px) and (max-width: 744px) {
  .campaign_container_both { max-width: 100% !important; }
}

/* ── Carousel indicators ────────────────────────────────────── */
.custom-indicators {
  display: flex;
  justify-content: center;
  gap: var(--space-1);
  padding-bottom: var(--space-2);
}

.campaign-custom-bullet {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
  border-radius: 100px;
  opacity: 0.5;
  background: var(--color-surface-default);
}

.campaign-custom-bullet.active {
  width: 24px;
  height: 12px;
  flex-shrink: 0;
  border-radius: 100px;
  background: var(--color-surface-default);
  opacity: 1;
}

/* ── Campaign item ──────────────────────────────────────────── */
.campaign-item {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  max-height: 100%;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  touch-action: pan-y;
}

/* Campaign headline — display-level, uses Inter */
.campaign-label {
  color: var(--color-surface-default);
  font-family: var(--font-heading);
  font-size: var(--text-display-lg-size);
  font-weight: var(--fw-xbold);
  line-height: 28px;
  text-align: start;
}

/* Campaign body — body text, uses Helvetica Neue */
.campaign-desc {
  color: var(--color-surface-default);
  font-family: var(--font-body);
  font-size: var(--text-action-md-size);
  font-weight: var(--fw-normal);
  line-height: 22px;
  text-align: start;
}

/* ── Desktop campaign layout ────────────────────────────────── */
.campaign-larger-container {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
  flex: 1 0 0;
  align-self: stretch;
}

.campaign-larger-label {
  color: var(--color-surface-default);
  font-family: var(--font-heading);
  font-size: var(--text-display-lg-size);
  font-weight: var(--fw-xbold);
  line-height: var(--text-display-lg-lh);
  letter-spacing: -0.4px;
}

.campaign-larger-desc {
  color: var(--color-surface-default);
  font-family: var(--font-body);
  font-size: var(--text-action-md-size);
  font-weight: var(--fw-normal);
  line-height: 28px;
}

.campaign-larger-viewBtn {
  display: flex;
  height: 56px;
  width: 146px;
  min-width: 104px;
  max-width: 600px;
  min-height: 56px;
  padding: var(--space-1) var(--space-2);
  justify-content: center;
  align-items: center;
  gap: var(--space-1);
  border-radius: var(--radius-lg);
  background: var(--color-brand-accent);
  text-transform: none;
  color: var(--color-surface-default);
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-action-md-size);
  font-weight: var(--fw-bold);
  line-height: var(--text-action-md-lh);
  letter-spacing: 0.2px;
}

.campaign-larger-viewBtn:hover {
  background: var(--color-brand-accent);
  color: var(--color-surface-default);
}

/* ── Icon colours ───────────────────────────────────────────── */
.location-arrow-icon,
.setlocation_location_arrow {
  color: var(--color-surface-default);
  font-size: var(--text-label-md-size);
  font-weight: 300;
  line-height: normal;
}

.setlocationtxt {
  color: var(--color-surface-default);
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-label-md-size);
  font-weight: var(--fw-bold);
  line-height: var(--text-label-md-lh);
  letter-spacing: 0.2px;
}
