/* ===========================================================================
   No1 Princess — What's On This Month page (Figma node 601-3103)
   Layered on top of home.css (shares header/nav/drawer/contact/footer + tokens).
   Section classes use the np-won prefix. Light page → dark nav variant.
   =========================================================================== */

/* ---- Dark nav variant (page background is light) ------------------------ */
.np-whatson-page .np-nav__brand-mark { color: var(--c-dark); }
.np-whatson-page .np-nav__toggle { border-color: rgba(29, 29, 27, 0.55); }
.np-whatson-page .np-nav__toggle span { background: var(--c-dark); }
.np-whatson-page .np-cart-toggle { border-color: rgba(29, 29, 27, 0.5); color: var(--c-dark); }
.np-whatson-page .np-cart-toggle:hover { background: var(--c-dark); color: var(--c-cream); }

/* ---- Hero (cream) + tab bar --------------------------------------------- */
/* padding-top (not a child margin) so the cream fills behind the floating
   header — otherwise margin-collapse exposes the dark body + hides the nav. */
.np-won-hero { background: var(--c-cream); padding-top: clamp(76px, 9vh, 96px); padding-bottom: clamp(36px, 5vw, 72px); }

.np-won-tabs { background: var(--c-beige); }
.np-won-tabs__inner { display: flex; flex-wrap: wrap; align-items: center; gap: clamp(18px, 2.6vw, 40px); padding-block: 15px; }
.np-won-tab {
  font-family: var(--font-body); font-weight: 800; font-size: clamp(11px, 0.9vw, 13px);
  letter-spacing: .08em; text-transform: uppercase; color: var(--c-dark);
  padding-bottom: 3px; border-bottom: 2px solid transparent; white-space: nowrap;
  transition: opacity .2s ease;
}
.np-won-tab--label { font-weight: 800; }
a.np-won-tab { opacity: .55; }
a.np-won-tab:hover { opacity: 1; }
a.np-won-tab.is-active { opacity: 1; border-bottom-color: var(--c-dark); }

.np-won-hero__inner { text-align: center; padding-top: clamp(40px, 6vw, 80px); }
.np-won-hero__title {
  font-family: var(--font-display); font-weight: 400; color: var(--c-dark);
  font-size: clamp(48px, 8.6vw, 128px); line-height: 1; letter-spacing: -0.05em; margin: 0;
}
.np-won-hero__month {
  font-family: var(--font-body); font-weight: 700; color: var(--c-dark);
  font-size: clamp(13px, 1.2vw, 18px); letter-spacing: .14em; text-transform: uppercase;
  margin: clamp(14px, 1.6vw, 22px) 0 0;
}
.np-won-hero__media { margin: clamp(28px, 3.4vw, 50px) 0 0; }
.np-won-hero__media img {
  width: 100%; aspect-ratio: 1280 / 700; object-fit: cover;
  border-radius: clamp(14px, 1.6vw, 22px); display: block;
}

/* ---- Updates & seasonal news (white, rounded bottom) -------------------- */
.np-won-updates {
  background: #fff;
  padding: clamp(48px, 6vw, 96px) 0 clamp(48px, 6vw, 90px);
  border-radius: 0 0 clamp(20px, 2.6vw, 44px) clamp(20px, 2.6vw, 44px);
}
.np-won-updates__head { text-align: center; margin-bottom: clamp(28px, 3.4vw, 48px); padding-inline: var(--gutter); }
.np-won-updates__eyebrow {
  font-family: var(--font-display); font-weight: 400; color: var(--c-dark);
  font-size: clamp(15px, 1.3vw, 24px); letter-spacing: -0.04em; margin: 0 0 6px;
}
.np-won-updates__title {
  font-family: var(--font-display); font-weight: 400; color: var(--c-dark);
  font-size: clamp(30px, 4.4vw, 64px); line-height: 1.04; letter-spacing: -0.04em; margin: 0;
}

/* ---- News carousel ------------------------------------------------------ */
.np-won-track {
  display: flex; gap: clamp(16px, 2vw, 40px); overflow-x: auto;
  scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
  padding: 0 var(--gutter) 6px; scrollbar-width: none;
}
.np-won-track::-webkit-scrollbar { display: none; }

.np-won-card {
  position: relative; flex: 0 0 min(86vw, 1080px); scroll-snap-align: start;
  aspect-ratio: 1280 / 900; border-radius: clamp(14px, 1.6vw, 22px); overflow: hidden; background: var(--c-ink);
}
.np-won-card__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.np-won-card__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.55) 18%, rgba(0,0,0,0) 46%);
}
.np-won-card__body {
  position: absolute; left: 0; bottom: 0; z-index: 2;
  padding: clamp(20px, 3vw, 44px); color: #fff; max-width: min(78%, 760px);
}
.np-won-card__date { font-family: var(--font-body); font-weight: 500; font-size: clamp(12px, 1vw, 16px); opacity: .85; margin: 0 0 8px; }
.np-won-card__title { font-family: var(--font-display); font-weight: 400; font-size: clamp(22px, 2.6vw, 32px); line-height: 1.05; letter-spacing: -0.04em; margin: 0 0 10px; }
.np-won-card__desc { font-family: var(--font-body); font-weight: 500; font-size: clamp(13px, 1.15vw, 20px); line-height: 1.5; opacity: .9; margin: 0 0 14px; }
.np-won-card__price { font-family: var(--font-display); font-weight: 400; font-size: clamp(18px, 2vw, 24px); letter-spacing: -0.03em; margin: 0; }
.np-won-card__add {
  position: absolute; right: clamp(18px, 3vw, 44px); bottom: clamp(18px, 3vw, 44px); z-index: 3;
  width: clamp(46px, 4.5vw, 64px); height: clamp(46px, 4.5vw, 64px); border-radius: 50%;
  background: #fff; color: var(--c-dark); border: none; display: grid; place-items: center; cursor: pointer;
  transition: background-color .2s ease, color .2s ease;
}
.np-won-card__add svg { width: 42%; height: 42%; }
.np-won-card__add:hover { background: var(--c-gold); color: #fff; }

/* ---- Dots (wired by catering.js — uses .np-ctr-dot) --------------------- */
.np-ctr-dots { display: flex; justify-content: center; gap: 10px; margin-top: clamp(24px, 3vw, 42px); }
.np-ctr-dot { width: 10px; height: 10px; border-radius: 50%; border: none; background: rgba(29, 29, 27, 0.22); cursor: pointer; padding: 0; transition: background-color .2s ease; }
.np-ctr-dot.is-active { background: var(--c-dark); }

/* ---- Responsive --------------------------------------------------------- */
@media (max-width: 700px) {
  .np-won-card { flex-basis: 88vw; aspect-ratio: 1 / 1; }
  .np-won-card__body { max-width: 92%; }
}
