/* === Responsive banner hero === */
.mw-hero {
  position: relative;
  margin: 0;
  width: 100%;
  overflow: hidden;
}

/* Allow banner to scale naturally */
.mw-hero-img {
  width: 100%;
  height: auto;              
  display: block;
  max-width: 100%;
  border: 0;
}

/* === Recipes Section === */
/* Section spacing (no outer box) */
.mw-recipes { padding-top:40px; }

/* Two-column strip, equal height, no card background */
.mw-recipes-strip{
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  height: clamp(220px, 28vw, 340px);
  
  margin: 0 auto;
 
 
  gap: 0;
}
/* Left panel */
.mw-recipes-left{
  background: #0e0f12;
  color: #fff;
  padding: clamp(16px, 3vw, 28px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Title + line */
.mw-recipes-title{
  font-family: 'HelveticaNeueExtended', Arial, sans-serif;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.4rem, 2.2vw, 2.1rem);
  margin: 0 0 .6rem;
}
.mw-recipes-underline{
  display: inline-block;
  width: 90px;
  height: 3px;
  background: linear-gradient(135deg, #0f52ba, #1a237e);
  margin-bottom: .9rem;
}

/* Copy + button */
.mw-recipes-desc{
  font-family: 'NeueHaasGrotText', Arial, sans-serif;
  color: #e6ebef;
  line-height: 1.45;
  font-size: clamp(.95rem, 1.2vw, 1.08rem);
  margin: 0 0 1rem;
  max-width: 36ch;
}
.mw-recipes-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0.7rem 1.6rem;
  font-family: 'NeueHaasGrotText', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  color: #fff;
  text-decoration: none;
  background: linear-gradient(90deg, #0f52ba 0%, #1a237e 100%);
  border: none;
  border-radius: 999px;            /* perfect pill shape */
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
  transition: all 0.25s ease-in-out;
  cursor: pointer;
  width: fit-content;
}

.mw-recipes-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.1);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.35);
}

.mw-recipes-btn:active {
  transform: translateY(1px);
  box-shadow: 0 3px 10px rgba(0, 0, 0, 0.2);
}


/* Right Image — scales perfectly within its div */
.mw-recipes-right {
  width: 100%;
  height: 100%;
  overflow: hidden;
  display: flex;
}

.mw-recipes-right img {
  width: 100%;
  height: 100%;
  object-fit: cover;        /* ensures it fills the area */
  object-position: center;  /* keeps the image centered */
  display: block;
  border: none;
}

/* Overlapping scalloped badge on the seam */
/* decorative only */
.mw-recipes-badge{
  position: absolute;
  top: -35px;
  left: 50%;
  transform: translateX(-50%);
  width: clamp(70px, 10vw, 96px);
  height: auto;
  pointer-events: none; 
  z-index: 3;
}

/* --- Mobile --- */
@media (max-width: 768px){
  .mw-recipes{ margin-bottom: none }
  .mw-recipes-strip{
    grid-template-columns: 1fr;
    height: auto;
     position: relative;
      /* or: overflow: clip; */
    isolation: isolate; /* keeps overlays from painting outside */
    
  }
    .mw-recipes-right{
    min-height: clamp(240px, 62vw, 400px);
  }
.mw-recipes h2{
  padding-top: 55px;
  text-align: center;
}
.mw-recipes p{
  text-align: center;
}
  .mw-recipes-right img{
    width: 100%;
    height: 100%;           /* fill the min-height above */
    object-fit: cover;
    object-position: center;
    display: block;
  }

  .mw-recipes-left{
   position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0,0,0,.58), rgba(0,0,0,.30));
    z-index: 2;
  }

  .mw-recipes-underline{ margin: 0 auto .8rem; }
  .mw-recipes-desc{
    color:#fff; max-width:32ch; margin:0 auto 1rem;
    font-size: clamp(.9rem, 3.4vw, 1rem);
  }
  .mw-recipes-btn{ margin:0 auto; }

  .mw-recipes-badge{
    top: -22px;               /* overlap amount */
    left: 50%;
    transform: translateX(-50%);
    width: clamp(70px, 22vw, 96px);
  }
}

/* ===== Points Club strip ===== */
.mw-points{
  position: relative;
  width: 100%;
  overflow: hidden;
  height: clamp(260px, 38vw, 460px); /* responsive height */
  isolation: isolate;      /* keeps overlay/content scoped */
}

/* background image fills section */
.mw-points-bg{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 60% center; /* focuses a bit to the right on desktop */
  display: block; border: 0;
  z-index: 0;
}

/* dark gradient overlay for legibility */
.mw-points-shade{
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.25) 40%, rgba(0,0,0,.25) 100%);
  z-index: 1;
}

/* content block (desktop: left-aligned) */
.mw-points-content{
  position: relative;
  z-index: 2;
  height: 100%;
  display: grid;
  align-content: center;
  justify-items: start;
  gap: .85rem;
  padding: 0 clamp(16px, 4vw, 48px);
  color: #fff;
  max-width: 1200px;
  margin: 0 auto;
}

.mw-points-title{
  font-family: 'NeueHaasGrotText', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-weight: 900;
  line-height: 1.1;
  font-size: clamp(1.4rem, 2.2vw, 2.1rem); /* same as .mw-recipes-title */
  margin: 0 0 .6rem;
  text-shadow: 0 2px 12px rgba(0,0,0,.4);
}


.mw-points-sub{
  font-family: 'NeueHaasGrotText', Arial, sans-serif;
  color: #e6ebef;
  line-height: 1.45;
  font-size: clamp(.95rem, 1.2vw, 1.08rem); /* same as .mw-recipes-desc */
  max-width: 36ch;
  margin: 0 0 1rem;
  text-shadow: 0 2px 10px rgba(0,0,0,.35);
}

/* pill gradient button */
.mw-points-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0.7rem 1.6rem;
  font-family: 'NeueHaasGrotText', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-weight: 600;
  font-size: 0.95rem;
  color: #fff;
  text-decoration: none;
  background: linear-gradient(90deg, #0f52ba 0%, #1a237e 100%);
  border: none;
  border-radius: 999px;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
  transition: all 0.25s ease-in-out;
  cursor: pointer;
  width: fit-content;
  gap: 0.5rem;
}
.mw-points-btn:hover{ transform: translateY(-2px); filter: brightness(1.06); }
.mw-points-btn:active{ transform: translateY(0); box-shadow: 0 4px 12px rgba(0,0,0,.22); }
.mw-points-btn i{ font-size: .95rem; }

/* ===== Responsive ===== */

/* Tablet: keep left alignment but tighten spacing; ensure no footer overlap */
@media (min-width: 769px) and (max-width: 1024px){
  .mw-points{ height: clamp(300px, 44vw, 420px); margin-bottom: 24px; }
  .mw-points-content{ padding: 0 clamp(16px, 5vw, 36px); }
  .mw-points-sub{ max-width: 46ch; }
}

/* Mobile: center everything on the image with a stronger overlay */
@media (max-width: 768px){
  .mw-points{
    height: clamp(320px, 78vw, 440px);
    margin-bottom: 0px;
  }
  .mw-points-bg{ object-position: center; }
  .mw-points-shade{
    background: linear-gradient(0deg, rgba(0,0,0,.55), rgba(0,0,0,.35));
  }
  .mw-points-content{
    justify-items: center;      /* center text/button */
    text-align: center;
    padding: 0 18px;
    gap: .9rem;
  }
  .mw-points-title{ font-size: clamp(1.35rem, 6.4vw, 2rem); }
  .mw-points-sub{
    font-size: clamp(1rem, 4.2vw, 1.2rem);
    max-width: 32ch;
    margin-bottom: .35rem;
  }
}


/* === Categories Section === */
.mw-cats-section { background:#fff; padding: 40px 0 20px; }

.mw-cats-title{
  font-family:'HelveticaNeueExtended', Arial, sans-serif;
  font-weight:900;
  letter-spacing:.5px;
  text-align:center;
  margin: 0 0 24px;
  font-size:28px;
}

.mw-cats{
  max-width:960px;
  margin:0 auto;
  display:grid;
  gap:16px;
  padding: 0 16px 40px; /* rhythm consistent with home sections */
  color:#2a2d32;
}

/* Tile */
.mw-cat{
  position:relative;
  display:flex;
  align-items:center;
  gap:18px;
  min-height:110px;
  padding:18px 26px;
  background:#eef2f3;              
  color:#2a2d32;                   
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.15);
  overflow:visible;
  text-decoration:none;
  transition: background .25s ease, color .25s ease,
              transform .25s ease, box-shadow .25s ease;
}
.mw-cat:hover,
.mw-cat:focus-within{
  background:#0f0f10;               
  color:#fff;                        
  transform:translateY(-2px);
  box-shadow:0 12px 36px rgba(0,0,0,.45);
}

/* Icon */
.mw-cat-icon{
  width:86px; height:86px;
  object-fit:contain;
  flex:0 0 auto;
  filter: drop-shadow(0 8px 12px rgba(0,0,0,.25));
}

/* Copy */
.mw-cat-copy{ display:grid; gap:6px; }

.mw-cat-heading{
  font-family:'HelveticaNeueExtended', Arial Black, sans-serif;
  font-size:36px; line-height:1; letter-spacing:.3px;
  font-weight:700; margin:0;
}

.mw-cat-desc{
  font-family:'NeueHaasGrotText', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-size:14px; line-height:1.35;
  color:#d6dde5;
  opacity:0; max-height:0;
  transition: opacity .25s ease, max-height .25s ease;
}
.mw-cat:hover .mw-cat-desc,
.mw-cat:focus-within .mw-cat-desc{
  opacity:1; max-height:3.2em;
}

/* Hover photo */
.mw-cat-photo{
  position:absolute; top:50%; right:-28px;
  width:260px; height:160px;
  border-radius:16px; overflow:hidden;
  transform:translateY(-50%) scale(.98);
  opacity:0;
  box-shadow:0 14px 38px rgba(0,0,0,.55);
  z-index:3; pointer-events:none;
  transition: opacity .28s ease, transform .28s ease;
}
.mw-cat-photo img{ width:100%; height:100%; object-fit:cover; }

.mw-cat:hover .mw-cat-photo,
.mw-cat:focus-within .mw-cat-photo{
  opacity:1; transform:translateY(-50%) scale(1);
}

/* Empty state */
.mw-cats-empty{
  text-align:center;
  opacity:.7;
  margin: 8px 0 0;
}

/* Responsive */
@media (max-width: 640px){
  .mw-cat-heading{ font-size:28px; }
  .mw-cat-icon{ width:70px; height:70px; }
  .mw-cat-photo{ display:none; }
}

/* ===========================
   Special Offers
   =========================== */
.mw-offers{
  padding: 28px 0 36px;
  background:#fff;
}

.mw-offers-head{
  text-align:center;
  margin-bottom: 18px;
}

.mw-offers-title{
  font-family: 'NeueHaasGrotText', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  font-weight: 900;
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  line-height: 1.1;
  margin: 0 0 6px;
  color:#111827;
}

.mw-offers-sub{
  font-family: 'NeueHaasGrotText', system-ui, -apple-system, 'Segoe UI', Roboto, Arial, sans-serif;
  color:#4b5563;
  margin: 0 auto;
  max-width: 56ch;
  font-size: clamp(.95rem, 1.3vw, 1.05rem);
}

/* Grid */
.mw-offers-grid{
  display:grid;
  gap: 18px;
  grid-template-columns: repeat( auto-fill, minmax(240px, 1fr) );
}

/* Card — match product list feel */
.mw-offer-card{
  background:#ffffff;
  border: none;
  border-radius:16px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition: transform .12s ease, box-shadow .12s ease;
}
.mw-offer-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0,0,0,.08);
}

/* Image wrapper — square, inset margin, rounded */
.mw-offer-imgwrap{
  display:block;
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 16px;
  overflow: hidden;
  margin: 10px;
  background: #111;
}
.mw-offer-imgwrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Body */
.mw-offer-body{
  padding: 0 16px 16px;
  display:flex;
  flex-direction: column;
  gap:8px;
}

/* Title with gradient underline (like products) */
.mw-offer-name{
  margin: 2px 0 0;
  font-size: 1rem;
  line-height: 1.25rem;
}
.mw-offer-name a{
  position: relative;
  display: inline-block;
  text-decoration: none;
  color: #000;
  font-family: 'NeueHaasGrotText', Arial, sans-serif;
  font-weight: 700;
  padding-bottom: 3px; 
}
.mw-offer-name a::after{
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(135deg, #0f52ba, #1a237e);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.25s ease;
}
.mw-offer-name a:hover::after{
  transform: scaleX(1);
}

/* Price line (same weights/colors as product list) */
.mw-offer-price{
  font-family: 'NeueHaasGrotText', Arial, sans-serif;
  font-weight: 700;
}
.mw-offer-price .price-old{
  color: #777;
  text-decoration: line-through;
  text-decoration-thickness: 2px;
  text-decoration-color: #777;
  text-decoration-skip-ink: none;
  margin-right: 6px;
  font-weight: 500;
  display: inline-block;
}
.mw-offer-price .price-new{
  color: #e53935;
  font-weight: 700;
}

/* CTA — same gradient button look */
.mw-offer-btn{
  margin-top: 6px;
  border-radius: 10px;
  background: linear-gradient(135deg, #0f52ba, #1a237e);
  color: #fff;
  font-weight: 600;
  padding: 10px 14px;
  width: 100%;
  text-decoration: none;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border: none;
}
.mw-offer-btn:hover{
  opacity: .95;
  color: #fff;
}

/* Small screens */
@media (max-width: 575px){
  .mw-offer-imgwrap{ aspect-ratio: 1 / 1; } 
}

/* ===== Offers carousel viewport ===== */
.mw-offers-viewport{
  position: relative;
}

/* Horizontal track: swipeable + snap */
.mw-offers-track{
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 2px 56px 2px 2px;   
  -ms-overflow-style: none;    
  scrollbar-width: none;       
}
.mw-offers-track::-webkit-scrollbar{ display:none; }

/* Each card acts like a slide */
.mw-offer-card{
  flex: 0 0 clamp(220px, 28vw, 300px); /* responsive width */
  scroll-snap-align: start;
}

/* Chevron buttons */
.mw-offers-nav{
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  border: 0;
  border-radius: 50%;
  background: #0f0f10;
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  cursor: pointer;
  z-index: 5;
}
.mw-offers-nav:hover{ filter: brightness(1.1); }
.mw-offers-nav:disabled,
.mw-offers-nav[hidden]{ display:none; }

.mw-offers-nav.prev{ left: 6px; }
.mw-offers-nav.next{ right: 6px; }

/* Mobile tweaks */
@media (max-width: 575px){
  .mw-offers-nav{
    width: 38px; height: 38px;
  }
  .mw-offers-track{ gap: 14px; padding-right: 50px; }
}









