/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --cb-navy: #0c1788;
  --cb-navy-alt: #1e4489;
  --cb-red: #dc2328;
  --cb-pink: #ffe2e2;
  --cb-lav: #f5f4fd;
  --cb-blue: #e6f0ff;
  --cb-sage: #d7e2dc;
  --cb-fpink: #f8edeb;
  --cb-grey: #d9d9d9;
  --cb-text: #434453;
  --cb-body: #50547c;
  --cb-card: #5b5e84;
  --cb-muted: #787878;
  --cb-link: #554343;
  --cb-ftext: #7d6f6c;
  --cb-border: #878AAA;
  --cb-card-border: rgba(12, 23, 136, 0.10);
  --cb-know-border: #e7e8f4;
  --cb-ease: .25s ease;
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-text);
  overflow-x: hidden;
  background: #fff;
  -webkit-font-smoothing: antialiased;
}

html,
body {
  overflow-x: hidden;
}

a {
  text-decoration: none;
  color: inherit;
}
header {
  position: sticky !important;
  top: 0 !important;
  z-index: 10000 !important;
}



/* ── Skip link ─────────────────────────────────────────────── */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--cb-navy);
  color: #fff;
  padding: .5rem 1rem;
  z-index: 997;
  border-radius: 0 0 4px 0;
}

.skip-link:focus {
  top: 0;
}

/* ── Utility ───────────────────────────────────────────────── */
.section-pad {
  padding-bottom: 4.5rem;
}

.section-title {
  font-size: clamp(1.6rem, 2.8vw, 2.5rem);
  font-weight: 600;
  color: var(--cb-text);
}

.btn-cb-red {
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  font-weight: 600;
  padding: .75rem 2rem;
  transition: transform var(--transition), box-shadow var(--transition);
}

.btn-cb-red:hover {
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(220, 35, 40, .35);
}

.btn-cb-white {
  background: #fff;
  color: var(--cb-navy);
  border: none;
  border-radius: 100px;
  font-weight: 600;
  padding: .75rem 2rem;
  transition: transform var(--transition), box-shadow var(--transition);
}

.btn-cb-white:hover {
  color: var(--cb-navy);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .12);
}

.btn-cb-outline {
  background: #fff;
  color: var(--cb-link);
  border: 1px solid #a4a4a4;
  border-radius: 100px;
  font-weight: 700;
  font-size: .9rem;
  padding: .45rem 1.5rem;
  transition: background var(--transition), color var(--transition);
}

.btn-cb-outline:hover {
  background: var(--cb-navy);
  color: #fff;
  /* border-color: var(--cb-navy); */
}

/* ── Top Bar ───────────────────────────────────────────────── */
#topbar {
  background: var(--cb-lav);
  font-size: clamp(0.7rem, 1.8vw, 0.8125rem);
  font-weight: 700;
  color: var(--cb-navy);
  /* padding: clamp(0.35rem, 1vw, 0.5rem) 0; */
  height: 40px;
}

#topbar .phone {
  color: var(--cb-red);
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

#topbar .hours {
  color: #686A7E;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

#topbar .quick-help {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

.great {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

#topbar .topbar-right {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 1.5vw, 0.75rem);
}

#topbar .trustpilot-wrap img {
  height: clamp(16px, 4vw, 21px);
  width: auto;
}

#topbar .review-count {
  color: #878AAA;
  font-family: "DM Sans";
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
.head-strip{
  width:100%;
  background:#EAF4EC;
  
}

.review-strip{
  gap:10px;
  display:flex;
  justify-content:center;
  align-items:center;
  padding:8px 0;
  
}

/* ── Navbar ─────────────────────────────────────────────────── */
#mainNav {
  background: #fff;
  box-shadow: 0 2px 16px rgba(0, 0, 0, .06);
  transition: padding 0.3s ease, box-shadow 0.3s ease;
    /* padding-top: 15px;
    padding-bottom: 15px; */
     /* top: 0 !important;
  z-index: 10000 !important;  */
}

#mainNav.scrolled {
  box-shadow: 0 4px 24px rgba(0, 0, 0, .12);
  /* padding-top: 7px !important;
  padding-bottom: 7px !important; */

}

.navbar {
  position: relative;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  /* padding-top: 15px;
  padding-bottom: 15px; */
  display: block;
  padding: 0 !important;
}

/* .navbar-brand {
  margin-right: 40px;

} */

/* .navbar-brand{
  width:180px;
} */

.navbar-brand svg {
  width: 144px;
  height: 38px;
  transition: width 0.3s ease, height 0.3s ease;
  margin-top: 4px;
  margin-bottom: 4px;
}

.nav-item {
  font-weight: 600;
  font-size: clamp(0.8rem, 2vw, 0.9375rem);
  color: #554343 !important;
  position: relative;
  padding: 16px !important;
  transition: color var(--transition);

}

.nav-link {
color: #554343 !important;
font-weight: 600;

}

.nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: clamp(0.5rem, 1.5vw, 0.75rem);
  right: clamp(0.5rem, 1.5vw, 0.75rem);
  /* height: 2px; */
  background: var(--cb-red);
  transform: scaleX(0);
  transition: transform var(--transition);
  border-radius: 2px;
}

.mega-parent:hover > .nav-item,
.mega-parent:focus-within > .nav-item {
  background: #FEE8D5;
  border-radius: 10px 10px 0px 0px;
}

.nav-item:hover::after,
.nav-item.active::after {
  transform: scaleX(1);

}

.nav-item:hover,
.nav-item:hover::after,
.nav-item.active::after {
  /* color: var(--cb-red) !important; */
  border-radius: 10px;
  padding: 16px !important;
  background: #FEE8D5;
}

.nav-child-link:hover,
.nav-child-link:hover::after,
.nav-child-link.active::after {
  border-radius: 0px;
  background: #FEE8D5;
}

.nav-bar-right-section {
  display: flex;
  align-items: center;
  margin-top: 0.5rem;
  flex-direction: row;
  gap: 20px;
}

.postcode-pill {
  background: #FFE8E8;
  border: none;
  border-radius: 100px;
  font-size: clamp(0.7rem, 1.8vw, 0.875rem);
  font-weight: 600;
  color: var(--cb-text);
  display: flex;
  align-items: center;
  cursor: pointer;
  transition: background var(--transition);
  padding: 10px 18px;
  gap: 10px;

}

.postcode-text {
  color: #E99E9E;
  font-size: 13px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  white-space: nowrap;
}

.postcode-pill:hover {
  background: rgba(218, 221, 255, .85);
}

.nav-icons {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-left: 40px;
  /* space between icons */
}

.nav-icons a {
  font-size: clamp(0.9rem, 2vw, 1.1rem);
  color: var(--cb-text);
  margin: 0 0;
  transition: color var(--transition);
}

.nav-icons a:hover {
  color: var(--cb-red);
}

/* ── Hero ───────────────────────────────────────────────────── */
.hero-section {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  min-height: clamp(800px, 70vh, 1100px);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-slider {
  position: relative;
  width: 100%;
  height: 100%;
}

.slide {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1s ease-in-out;
  /* smooth fade between images */
}

.slide.active {
  opacity: 1;
}

.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* Overlay */
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}

/* Content */
.hero-content {
  position: relative;
  z-index: 2;
  /* max-width: 1440px; */
  padding-top: 120px;
  /* padding: clamp(1.5rem, 5vw, 5rem); */
  width: 100%;
  text-align: center;
  justify-content: center;
  margin: 0 auto;

}

/* Heading */
.hero-content h1 {
  color: #FFF;
  text-align: center;
  font-family: "DM Sans";
  font-size: 40px;
  font-style: normal;
  font-weight: 600;
  /* 110% */
}

/* Button */
.hero-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: white;
  color: #878AAA;
  font-family: "DM Sans", sans-serif;
  font-weight: 600;
  font-size: clamp(0.875rem, 2vw, 1.25rem);
  padding: 0 clamp(3rem, 5vw, 5rem);
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  margin-top: 20px;
  height: 60px;
  /* min-height: 50px; */
}

.hero-btn:hover {
  background: #ffdcdc;
  color: white;
}

.hero-btn:active {
  transform: scale(0.95);
}

/* Wave */
.wave-bottom {
  position: absolute;
  bottom: 0 !important;
  width: 100%;
  z-index: 3;
}

.wave-bottom svg {
  width: 100%;
  height: 70px;
  display: block;
}

/* ── Finest Collection ──────────────────────────────────────── */
.collections-section {
  /* background: linear-gradient(180deg, #FFC9C0 0%, rgba(232, 226, 214, 0) 100%); */
  background: #FFF5E9;
  padding: clamp(2rem, 5vw, 3.75rem) 0;
  /* height: 600px; */
}

.wave-bottom_1{
  position: relative;
  bottom: 8px;
  width: 100%;
  z-index: 3;
}

.badge {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1rem 4rem;
}

.badge svg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 82px;
  height: 79px;
  /* opacity: 0.85; */
}

.badge p {
  position: relative;
  /* sits above the SVG */
  z-index: 1;
  margin: 0;
  color: #434453;
  font-family: "DM Sans";
  font-size: clamp(24px, 4vw, 40px);
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  white-space: nowrap;
}


.container {
  /* max-width: 1440px; */
  margin: auto;
  padding: 0 clamp(1rem, 5vw, 5rem);
}

.container-fluid {
  max-width: auto;
}

.heading {
  text-align: center;
  margin-bottom: 20px;
}

.heading-icon {
  width: clamp(50px, 12vw, 80px);
  height: clamp(50px, 12vw, 80px);
  margin-bottom: clamp(-20px, -3vw, -30px);
}

.heading h2 {
  font-family: "DM Sans", sans-serif;
  font-size: clamp(1.5rem, 5vw, 2.5rem);
  font-weight: 600;
  color: #434453;
  margin-top: clamp(-10px, -2vw, -15px);
}

.carousel {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 2vw, 1rem);
  position: relative;
}

.carousel-container {
  overflow: hidden;
  width: 100%;
  flex: 1;
}

/* Carousel wrapper - horizontal scroll */
.carousel-wrapper {
  display: flex;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* hide scrollbar Firefox */
  padding: 12px 4px 20px;
}

.carousel-wrapper::-webkit-scrollbar {
  display: none;
  /* hide scrollbar Chrome/Safari */
}

/* Card */
.card {
  flex: 0 0 160px;
  overflow: hidden;
  scroll-snap-align: start;
}


/* Image container */
.card-img {
  height: 300px;
  width: 150;
  border-radius: 10px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}



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


/* Card body */
.card-body {
  text-align: center;
}

.card-heading {
  margin: 0;
  margin-top: 15px;
  font-size: 14px;
  font-weight: 700;
  color: #1a237e;
  /* dark navy blue, matches screenshot */
  line-height: 1.3;
  text-align: center;
}

/* .carousel-wrapper {
  display: flex;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  transition: transform .5s ease;
} */

/* .card {
  flex: 0 0 calc(100% - 1rem);
  border-radius: 10px;
  box-shadow: 0 2px 15px rgba(0, 0, 0, 0.08);
  border: 1px solid #eee;
  cursor: pointer;
 
  overflow: hidden;
} */

/* .card:hover {
  
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
} */

/* .card-img {
  height: 350px;
  width: 280px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(40px, 8vw, 64px);
} */

/* .card-img img {
  border-radius: 10px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
} */

.card:hover .card-img img {
  transform: scale(1.08);
}

.card-img.icon-box {
  color: var(--cb-pink);
  opacity: 0.7;
}

.card-body {
  padding: clamp(0.75rem, 2vw, 1.25rem);
  text-align: center;
}

.card-body h3 {
  font-size: clamp(0.85rem, 2.2vw, 1.1rem);
  font-weight: 700;
  color: #1b254b;
  margin: 0;
  line-height: 1.3;
}

.arrow {
  width: clamp(36px, 8vw, 48px);
  height: clamp(36px, 8vw, 48px);
  min-width: clamp(36px, 8vw, 48px);
  min-height: clamp(36px, 8vw, 48px);
  border: none;
  background: transparent;
  border-radius: 50%;
  cursor: pointer;
  font-size: clamp(16px, 3vw, 24px);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--transition), color var(--transition);
}

.arrow:hover {
  transform: scale(1.1);
}

.arrow svg {
  width: 100%;
  height: 100%;
  display: block;
}
/* .wave-section ::before{
  content: '';
  position: absolute;
  top: -2px;
  left: 0;
  right: 0;
  height: 100px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,60 C360,0 720,100 1080,40 C1260,10 1380,50 1440,60 L1440,0 L0,0 Z'/%3E%3C/svg%3E") no-repeat top center / 100% 100%;
  z-index: 2;
}
.wave-section::before,
.wave-section::after {
  content: '';
  display: block;
  position: relative;
  width: 100%;
  height: 100px;
  background: #fff;
  z-index: 1;
} */
/* ──────────────────────────────────────────────────────────────
       RESPONSIVE COLLECTIONS SECTION MEDIA QUERIES
       ────────────────────────────────────────────────────────────── */

/* Small Phones (320px - 480px) */
@media (max-width: 480px) {
  .container {
    padding: 0 clamp(0.75rem, 4vw, 1rem);
  }

  .hero-content h1 {
    font-size: 45px;
    padding: 0px 20px;
  }

  .heading-icon {
    width: clamp(40px, 10vw, 55px);
    height: clamp(40px, 10vw, 55px);
  }

  .heading h2 {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
  }

  .carousel {
    gap: clamp(0.4rem, 1.5vw, 0.6rem);
  }

  .carousel-wrapper {
    gap: clamp(0.6rem, 1.5vw, 0.9rem);
  }

  .card {
    flex: 0 0 calc(100% - 0.8rem);
    border-radius: 12px;
  }

  .card-img {
    height: clamp(120px, 28vw, 180px);
    font-size: clamp(30px, 6vw, 48px);
  }

  .card-body {
    padding: clamp(0.6rem, 1.5vw, 0.85rem);
  }

  .card-body h3 {
    font-size: clamp(0.75rem, 2vw, 0.9rem);
  }

  .arrow {
    width: clamp(32px, 7vw, 40px);
    height: clamp(32px, 7vw, 40px);
    min-width: clamp(32px, 7vw, 40px);
    min-height: clamp(32px, 7vw, 40px);
  }

  .message-textbox {
    margin-top: 15px;
  }
}

.product-listing {
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-gap: 10px;
}

/* Tablets (481px - 768px) */
@media (min-width: 481px) and (max-width: 768px) {

  .collections-section {
    padding: 0 0;
  }

  .container {
    padding: 0 clamp(1rem, 4.5vw, 1.5rem);
  }

  .heading-icon {
    width: clamp(45px, 11vw, 65px);
    height: clamp(45px, 11vw, 65px);
  }

  .heading h2 {
    font-size: clamp(1.4rem, 4.5vw, 2rem);
  }

  .carousel {
    gap: clamp(0.5rem, 1.8vw, 0.8rem);
  }

  .carousel-wrapper {
    gap: clamp(0.8rem, 2vw, 1rem);
  }

  .card {
    flex: 0 0 calc(50% - 0.5rem);
    border-radius: 13px;
  }

  .card-img {
    height: clamp(140px, 28vw, 200px);
    font-size: clamp(36px, 6.5vw, 56px);
  }

  .card-body {
    padding: clamp(0.7rem, 1.8vw, 1rem);
  }

  .card-body h3 {
    font-size: clamp(0.8rem, 2.2vw, 0.95rem);
  }

  .arrow {
    width: clamp(36px, 7.5vw, 44px);
    height: clamp(36px, 7.5vw, 44px);
    min-width: clamp(36px, 7.5vw, 44px);
    min-height: clamp(36px, 7.5vw, 44px);
  }
}

/* Desktop (1025px and above) */
@media (min-width: 1025px) {
  .collections-section {
    padding: 0 0;
  }

  .container {
    padding: 0 5rem;
  }

  .heading-icon {
    width: 80px;
    height: 80px;
  }

  .heading h2 {
    font-size: 2.5rem;
  }

  .carousel {
    gap: 1.25rem;
  }

  .carousel-wrapper {
    gap: 1.25rem;
  }

  .card {
    flex: 0 0 calc(25% - 0.9375rem);
    border-radius: 15px;
  }

  .card-img {
    height: 220px;
    font-size: 64px;
  }

  .card-body {
    padding: 1.25rem;
  }

  .card-body h3 {
    font-size: 1.1rem;
  }

  .arrow {
    width: 48px;
    height: 48px;
    min-width: 48px;
    min-height: 48px;
  }
}



/* ── New Arrivals ───────────────────────────────────────────── */
#newArrivals {
  background: linear-gradient(180deg, #e6f0ff 0%, rgba(237, 238, 255, 0) 100%);
  padding: clamp(2rem, 5vw, 3.5rem) 0 clamp(2.5rem, 5vw, 4rem);
  position: relative;
}

.star-decoration {
  width: 147px;
  height: 147px;
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}

.arrival-card {
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .06);
  height: 280px;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition);
  overflow: hidden;
}

.arrival-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, .1);
}

.arrivals-section {
  /* background: linear-gradient(180deg, #FFC9C0 0%, rgba(232, 226, 214, 0) 100%);
      padding: 80px 0; */
  background: #E6F0FF;
  padding: 20px 0 20px;
  position: relative;
}

/* Container */

.container {
  /* max-width: 1440px; */
  margin: auto;
  padding: 0 80px;
}

/* Grid */

.arrivals-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(1rem, 3vw, 1.5rem);
  margin-top: clamp(1.5rem, 3vw, 2rem);
}

.arrival-card {
  background: var(--cb-grey);
  border-radius: 20px;
  height: clamp(200px, 40vw, 280px);
  cursor: pointer;
  transition: opacity var(--transition), box-shadow var(--transition);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

.arrival-card:hover {
  opacity: 0.85;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
}

.arrival-card span {
  font-size: clamp(0.75rem, 2vw, 0.875rem);
  font-weight: 600;
  color: #434453;
  text-align: center;
  padding: clamp(1rem, 2vw, 1.5rem);
}

.signup-text {
  width: 80%;
  margin: 0 auto;
  color: #EB7F82;
font-family: "Poppins";
font-size: 14px;
font-style: normal;
font-weight: 600;
line-height: normal;
}

/* ──────────────────────────────────────────────────────────────
       RESPONSIVE ARRIVALS MEDIA QUERIES
       ────────────────────────────────────────────────────────────── */

/* Small Phones (320px - 480px) */
@media (max-width: 480px) {
  .arrivals-section {
    padding: clamp(1.5rem, 4vw, 2.5rem) 0;
  }

  .container {
    padding: 0 clamp(0.75rem, 4vw, 1rem);
  }

  .arrivals-grid {
    grid-template-columns: 1fr;
    gap: clamp(0.8rem, 2vw, 1rem);
    margin-top: clamp(1.2rem, 2.5vw, 1.5rem);
  }

  .arrival-card {
    height: clamp(180px, 45vw, 240px);
  }

  .arrival-card span {
    font-size: clamp(0.7rem, 1.8vw, 0.8rem);
    padding: clamp(0.8rem, 1.5vw, 1rem);
  }

  .footer-bottom-links {
    justify-content: center !important;
    text-align: center;
  }

  .footer-copy-right {
    display: flex;
    text-align: center;
    justify-content: center !important;
  }

  .footer-copy-right p {
    margin-bottom: 0;
  }
}

/* Tablets (481px - 768px) */
@media (min-width: 481px) and (max-width: 768px) {
  .arrivals-section {
    padding: 10px 0;
  }

  .hero-content h1 {
    font-size: 45px;
    padding: 0px 20px;
  }

  .container {
    padding: 0 clamp(1rem, 4.5vw, 1.5rem);
  }

  .arrivals-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: clamp(1rem, 2.5vw, 1.3rem);
    margin-top: clamp(1.3rem, 3vw, 1.8rem);
  }

  .arrival-card {
    height: clamp(200px, 38vw, 260px);
  }

  .arrival-card span {
    font-size: clamp(0.72rem, 1.9vw, 0.85rem);
    padding: clamp(0.9rem, 1.8vw, 1.1rem);
  }
}

/* Large Tablets (769px - 1024px) */
@media (min-width: 769px) and (max-width: 1024px) {
  .arrivals-section {
    padding: clamp(2.5rem, 5vw, 3.5rem) 0;
  }

  .container {
    padding: 0 clamp(1.2rem, 4.5vw, 2rem);
  }

  .hero-content h1 {
    font-size: 35px;
    padding: 0px 20px;
  }

  .arrivals-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(1.1rem, 2.8vw, 1.4rem);
    margin-top: clamp(1.4rem, 3.2vw, 1.9rem);
  }

  .arrival-card {
    height: clamp(210px, 36vw, 270px);
  }

  .arrival-card span {
    font-size: clamp(0.75rem, 2vw, 0.875rem);
    padding: clamp(1rem, 1.9vw, 1.2rem);
  }
}

/* Desktop (1025px and above) */
@media (min-width: 1025px) {

  .container {
    padding: 0 5rem;
  }

  .arrivals-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-top: 2rem;
  }

  .arrival-card {
    height: 280px;
  }

  .arrival-card span {
    font-size: 0.875rem;
    padding: 1.5rem;
  }
}


/* ── Made for Love ──────────────────────────────────────────── */
#loveBanner {
  background: var(--cb-pink);
  position: relative;
  padding: clamp(2.5rem, 5vw, 5rem) 0;
  overflow: hidden;
}

#loveBanner::before {
  content: '';
  position: absolute;
  top: -2px;
  left: 0;
  right: 0;
  height: 100px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,60 C360,0 720,100 1080,40 C1260,10 1380,50 1440,60 L1440,0 L0,0 Z'/%3E%3C/svg%3E") no-repeat top center / 100% 100%;
  z-index: 2;
}

#loveBanner::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 100px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 100' preserveAspectRatio='none'%3E%3Cpath fill='%23ffffff' d='M0,40 C360,100 720,0 1080,60 C1260,90 1380,50 1440,40 L1440,100 L0,100 Z'/%3E%3C/svg%3E") no-repeat bottom center / 100% 100%;
  z-index: 2;
}

.love-inner {
  position: relative;
  z-index: 3;
}

.love-title {
  font-size: clamp(2rem, 4vw, 3.75rem);
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.1;
  margin-bottom: 1rem;
}

.love-body {
  font-size: 1rem;
  font-weight: 600;
  color: var(--cb-navy);
  margin-bottom: 2rem;
}

.banner-cake-img {
  max-height: 380px;
  object-fit: contain;
  position: absolute;
  right: 0;
  bottom: 0;
  pointer-events: none;
}

.love-section {
  position: relative;
  background: #E6F0FF;
  padding: 0;
  margin: 0;
}




.love-heading {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 60px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
}

/* Paragraph */

.love-tag {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin-top: 10px;
  width:80%;
}

/* Button */

.love-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #DC2328;
  color: white;
  font-weight: 700;
  font-size: clamp(0.875rem, 2vw, 1.25rem);
  padding: clamp(0.5rem, 2vw, 1.0rem) clamp(1.0rem, 4vw, 2.0rem);
  border-radius: 50px;
  text-decoration: none;
  transition: all .3s ease;
  min-width: clamp(200px, 40vw, 250px);
  margin-top: 10px;
}

.love-btn:hover {
  background: #b91c20;
}

.love-btn:active {
  transform: scale(.95);
}

.wave-inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  padding: 60px 0 25px 0;
}

/* Centre text */
.wave-text-container {
  flex: 2;
  align-items: flex-start;
  justify-content: flex-start;
  
}

.decor-left {
  flex-shrink: 0;
  width: 200px;
  height: 220px;
  border-radius: 50%;
  overflow: hidden;
  margin-left: -220px;
  display: none;
}

.decor-left img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transform: rotate(43deg);
}

.decor-right {
  flex:3;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  right: 0 !important;
  top: 20%;
  height: 400px;
  pointer-events: none;

}

.decor-right img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

.best-selling-section {
  margin-bottom: 50px;
}

.product-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: clamp(1.25rem, 3vw, 2rem);
  flex-wrap: wrap;
  gap: clamp(0.75rem, 2vw, 1.5rem);
}

.placeholder-card {
  background: var(--cb-grey);
  border-radius: 20px;
  height: auto;
  width: 100%;
  cursor: pointer;
  transition: opacity var(--transition);
  aspect-ratio: 1;
}

.finest-collection-image {
  width: 100%;
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: border-color var(--transition);
  /* position: relative; */
}

.product-image img{
width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.8s ease;
  transform-origin: center center;
  overflow: hidden;
}

.product-image:hover img {
 /* opacity: 0.85; */
  transform: scale(1.06);
}

.finest-collection-image img{
width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.8s ease;
  transform-origin: center center;
}

.finest-collection-image:hover img {
 transform: scale(1.06);
}


/* ── Reasons to Shop ────────────────────────────────────────── */
#reasons {
  padding: 70px 0 40px 0;
  background: #fff;
}

.reasons-title {
  font-size: clamp(1.25rem, 4vw, 1.875rem);
  font-weight: 600;
  color: var(--cb-navy);
  text-align: center;
  margin-bottom: 40px;
}

.reason-card {
  text-align: center;
  padding: clamp(1rem, 3vw, 1.5rem);
}

.reason-icon {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  height: 190px;

}

.reason-title {
  font-size: 20px;
  font-weight: 600;
  color: var(--cb-navy);
  margin-bottom: 16.5px;
}

.reason-text {
  font-size: 16px;
  color: var(--cb-body);
  margin: 0;
  line-height: 1.5;
  font-weight: 500;
}

/* ── About / Come Say Hello ─────────────────────────────────── */
#aboutSection {
  background: #fff;
}

.about-card {
  border-radius: 0px 0px 10px 10px;
  overflow: hidden;
  display: flex;
  /* height: 750px; */
  flex-direction: column;
}

.about-card-img {
  border-radius: 10px 10px 0px 0px;
  flex: 1;
  background: var(--cb-grey);
  height: 500px;
  width: 100%;
  object-fit: cover;
}

.about-card-body {
  background: #73B3EF;
  padding: clamp(1.25rem, 4vw, 2rem) clamp(1.25rem, 5vw, 2.5rem);
  color: #fff;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.about-card-body-title {
  font-size: 30px;
  font-weight: 600;
  margin-bottom: 15px;
  text-align: center;
}

.about-card-body-text {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 30px;
  color: white;
  text-align: center;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.btn-about {
  justify-items: center;
  background: #fff;
  color: #73B3EF;
  border: none;
  border-radius: 100px;
  font-weight: 600;
  font-size: 16px;
  padding: clamp(0.3rem, 1.5vw, 0.5rem) clamp(1rem, 3vw, 2rem);
  transition: opacity var(--transition), transform var(--transition);
  margin-bottom: 20px;
}

.btn-about:hover {
  opacity: .9;
  transform: translateY(-2px);
}

/* ── Newsletter ─────────────────────────────────────────────── */
.newsletter-section {
  background: #ffdcdc;
  padding: 25px 0 10px;
}

.newsletter-section .row {
  margin-left: 0;
  margin-right: 0;
}

/* 2. Kill column side padding that causes overflow */
.newsletter-section .row>* {
  padding-left: 0;
  padding-right: 0;
}

/* 3. Prevent the section itself from overflowing */
.newsletter-section {
  overflow-x: hidden;
}

.newsletter-wrapper {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: clamp(1rem, 3vw, 2rem);
  flex-wrap: wrap;
}

.newsletter-left h2 {
  color: #FFF;
  font-family: "Angelina";
  font-size: 30px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

.newsletter-left p {
  color: #5E6570;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  padding-left: 10px;
}




.newsletter-form input {
  background: #fff;
  border: 2px solid #fff;
  border-radius: 10px;
  padding: clamp(0.5rem, 2vw, 0.7rem) clamp(0.75rem, 2vw, 1.2rem);
  width: 95%;
  box-sizing: border-box;
  outline: none;
  transition: border-color var(--transition);
  color: #C5DBC4;
  font-family: "DM Sans";
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  display: flex;
  align-items: flex-end;
}

#newsletterEmail::placeholder {
  color: #EB7F82;
font-family: "DM Sans";
font-size: 16px;
font-style: normal;
font-weight: 600;
line-height: normal;
}

.newsletter-form-button {
  width: 95%;
  background: #EB7F82;
  border: none;
  border-radius: 100px;
  padding: clamp(0.5rem, 2vw, 0.7rem) clamp(1rem, 2vw, 1.75rem);
  cursor: pointer;
  transition: opacity var(--transition), transform var(--transition);
  white-space: nowrap;
  color: #FFF;
  font-family: "DM Sans";
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.newsletter-form button:hover {
  opacity: .9;
  transform: translateY(-1px);
}

/* ── Footer ─────────────────────────────────────────────────── */
.footer {
  background: white;
  padding: 3rem 0px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr repeat(4, auto);
  gap: clamp(1.5rem, 4vw, 2.5rem);
  align-items: start;
  margin-bottom: clamp(1.5rem, 3vw, 2rem);
}

/* .footer-logo img {
      max-height: 56px;
      width: auto;
    } */

.footer-logo-wordmark {
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  color: #ffffff;
  line-height: 1;
  font-size: clamp(1.5rem, 5vw, 3rem);
}

.logo-link {
  display: inline-block;
  flex-shrink: 0;
  border-radius: 6px;
  outline: none;
  text-decoration: none;
}

.logo-link:focus {
  box-shadow: 0 0 0 2px #1e3a8a;
}

/* logo image */

.logo-img {
  height: clamp(35px, 8vw, 50px);
  width: auto;
  display: block;
}

.social-icons {
  display: flex;
  gap: clamp(0.35rem, 1.5vw, 0.5rem);
  margin-top: clamp(0.75rem, 2vw, 1rem);
  flex-wrap: wrap;
}

.social-icons a {
  width: clamp(32px, 6vw, 36px);
  height: clamp(32px, 6vw, 36px);
  border-radius: 50%;
  background: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--cb-navy);
  font-size: clamp(0.75rem, 1.5vw, 0.9rem);
  transition: background var(--transition), color var(--transition), transform var(--transition);
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}

.social-icons a:hover {
  /* background: var(--cb-navy);
      color: #fff; */
  transform: translateY(-2px);
}

.footer-column h3 {
  color: #DC2328;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin-bottom: clamp(0.5rem, 1.5vw, 0.75rem);
}

.footer-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-column ul li {
  margin-bottom: clamp(0.25rem, 1vw, 0.35rem);
}

.footer-column ul li a,
.footer-column p {
  color: #655A57;
  font-family: Poppins;
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: 29px;
  /* 207.143% */
}

.footer-column ul li a:hover {
  color: var(--cb-navy);
}

.footer-contact-num {
  color: var(--cb-navy);
  font-family: "DM Sans";
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: 29px;
  /* 96.667% */
  margin-bottom: .25rem;
}

.footer-hours {
  font-size: clamp(0.75rem, 2vw, 0.875rem);
  font-weight: 600;
  color: var(--cb-ftext);
  margin-bottom: .25rem;
}

.footer-note {
  color: #655A57;
font-size: 10px !important;
font-style: normal;
font-weight: 600;
line-height: 14px !important; /* 140% */
margin-bottom: 0px !important;
  max-width: 220px;
}

.footer-bottom {
  border-top: 1px solid rgba(0, 0, 0, .08);
  padding-top: clamp(0.75rem, 2vw, 1.25rem);
  margin-top: clamp(1.5rem, 3vw, 2rem);
  display: flex;
  align-items: center;
  /* justify-content: space-between; */
  flex-wrap: wrap;
  /* gap: clamp(0.5rem, 2vw, 0.75rem); */
  font-size: clamp(0.75rem, 1.5vw, 0.8125rem);
  color: #888;
}

.footer-bottom-links {
  flex-direction: row;
  display: flex;
  justify-content: end;
  /* gap: clamp(0.75rem, 2vw, 1.25rem); */
  flex-wrap: wrap;
}

.footer-bottom-links a {
  color: #888;
  transition: color var(--transition);
}

.footer-bottom-links a:hover {
  color: var(--cb-navy);
}

/* ── Scroll to top ──────────────────────────────────────────── */
#scrollTopBtn {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 990;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cb-red);
  color: #fff;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 16px rgba(220, 35, 40, .4);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition), transform var(--transition);
  cursor: pointer;
}

#scrollTopBtn.show {
  opacity: 1;
  pointer-events: all;
}

#scrollTopBtn:hover {
  transform: translateY(-3px);
}

/* ── Reveal animation ───────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .6s ease, transform .6s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ──────────────────────────────────────────────────────────────
       RESPONSIVE MEDIA QUERIES - MOBILE FIRST APPROACH
       ────────────────────────────────────────────────────────────── */

/* Small Phones (320px - 480px) */
@media (max-width: 480px) {
  #topbar {
    display: none;
    font-size: clamp(0.65rem, 1.5vw, 0.75rem);
    padding: clamp(0.3rem, 0.8vw, 0.4rem) 0;
  }

  #topbar .phone {
    font-weight: 700;
  }

  #topbar .hours {
    display: none;
  }

  #topbar .topbar-right {
    gap: clamp(0.3rem, 1vw, 0.5rem);
  }

  #topbar .trustpilot-wrap img {
    height: clamp(14px, 3vw, 18px);
  }

  #topbar .review-count {
    font-size: clamp(0.6rem, 1.2vw, 0.65rem);
  }

  .nav-icons a {
    font-size: clamp(0.9rem, 2vw, 1.1rem);
    padding: 0 clamp(0.35rem, 1vw, 0.5rem);
  }

  /* Hero section - mobile */
  .hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .card-img {
    height: clamp(120px, 22vw, 180px);
  }

  .card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .heading-icon {
    width: clamp(40px, 10vw, 60px);
    height: clamp(40px, 10vw, 60px);
  }

  .decor-left {
    display: none;
  }

  /* Footer adjustments */
  .footer {
    padding: 1.5 rem 0px;
  }

  .footer-grid {
    grid-template-columns: 1fr;
    gap: clamp(1rem, 2.5vw, 1.5rem);
    margin-bottom: clamp(1rem, 2vw, 1.5rem);
  }

  .footer-logo-wordmark {
    font-size: clamp(1.2rem, 3.5vw, 1.5rem);
  }

  .logo-img {
    width: 144px;
    height: 50px;
  }

  .social-icons {
    gap: clamp(0.25rem, 0.8vw, 0.35rem);
    margin-top: clamp(0.5rem, 1.5vw, 0.75rem);
  }

  .social-icons a {
    width: clamp(28px, 5vw, 32px);
    height: clamp(28px, 5vw, 32px);
    font-size: clamp(0.65rem, 1.2vw, 0.8rem);
  }
}

/* Tablets (481px - 768px) */
@media (min-width: 481px) and (max-width: 767px) {
  #topbar {
    display: none;
    font-size: clamp(0.7rem, 1.8vw, 0.8rem);
    padding: clamp(0.4rem, 0.9vw, 0.5rem) 0;
  }

  #topbar .topbar-right {
    gap: clamp(0.6rem, 1.8vw, 0.8rem);
  }

  #topbar .trustpilot-wrap img {
    height: clamp(16px, 3.5vw, 20px);
  }

  .nav-icons a {
    font-size: clamp(1rem, 2vw, 1.125rem);
    padding: 0 clamp(0.45rem, 1.2vw, 0.6rem);
  }

  /* Image responsive sizing - tablets */
  .card-img {
    height: clamp(150px, 24vw, 200px);
  }

  .card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .heading-icon {
    width: clamp(50px, 11vw, 70px);
    height: clamp(50px, 11vw, 70px);
  }

  .hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .decor-left {
   display: none;
  }

  /* Footer */
  .footer {
    padding: 1.5rem 0px;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(1.2rem, 3vw, 1.8rem);
    margin-bottom: clamp(1.2rem, 2.5vw, 1.8rem);
  }

  .footer-logo-wordmark {
    font-size: clamp(1.4rem, 4vw, 1.8rem);
    grid-column: 1 / -1;
    margin-bottom: clamp(0.5rem, 1.5vw, 0.75rem);
  }

  .logo-img {
    width: 144px;
    height: 50px;
  }

  .social-icons {
    grid-column: 1 / -1;
    gap: clamp(0.3rem, 1vw, 0.4rem);
    margin-top: clamp(0.6rem, 1.5vw, 0.9rem);
  }

  .social-icons a {
    width: clamp(30px, 5.5vw, 34px);
    height: clamp(30px, 5.5vw, 34px);
    font-size: clamp(0.7rem, 1.4vw, 0.85rem);
  }



  /* Arrivals section handled in dedicated media queries */
}

/* Large Tablets (769px - 1024px) */
@media (min-width: 768px) and (max-width: 1024px) {
  .reasons-title {
    margin-bottom: 25px;
  }

  #topbar {
    display: block;
    font-size: clamp(0.75rem, 1.8vw, 0.85rem);
    padding: clamp(0.45rem, 1vw, 0.55rem) 0;
  }

  #topbar .hours {
    display: inline;
  }

  /* Card images - large tablet */
  .card-img {
    height: clamp(170px, 26vw, 230px);
  }

  .card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .heading-icon {
    width: clamp(55px, 12vw, 75px);
    height: clamp(55px, 12vw, 75px);
  }

  .hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .decor-left {
    left: -180px;
    width: 400px;
    height: 320px;
  }

  .decor-right {
    width: 400px;
    height: 320px;
  }
  .decor-right img {
    object-fit: contain;
  }

  /* Footer */
  .footer {
    padding: 2rem 0px;
  }

  .footer-grid {
    grid-template-columns: 1fr repeat(2, auto);
    gap: clamp(1.5rem, 3.5vw, 2.2rem);
    margin-bottom: clamp(1.5rem, 3vw, 2rem);
  }

  .footer-logo-wordmark {
    font-size: clamp(1.6rem, 4vw, 2rem);
  }

  .logo-img {
    width: 144px;
    height: 50px;
  }

  .social-icons {
    gap: clamp(0.35rem, 1.2vw, 0.5rem);
    margin-top: clamp(0.8rem, 1.8vw, 1rem);
  }

  .social-icons a {
    width: clamp(32px, 5.5vw, 36px);
    height: clamp(32px, 5.5vw, 36px);
    font-size: clamp(0.75rem, 1.5vw, 0.9rem);
  }

  .footer-hours {
    font-size: clamp(0.8rem, 1.8vw, 0.9rem);
  }

  .footer-note {
    font-size: clamp(0.7rem, 1.5vw, 0.8rem);
  }
}

@media (min-width: 1400px) { 
    .decor-right {
    width: auto;
    height: auto;
  }
  .decor-right img {
    width: 100%;
    height: auto;
    object-fit: contain;
  }
 .wave-inner {
    padding: 100px 0 60px 0;
  }
}

/* Desktop (1025px and above) */
@media (min-width: 1025px) {
  #topbar {
    display: block;
    font-size: 0.8125rem;
    padding: 0.5rem 0;
  }

  #topbar .hours {
    display: inline;
  }

  /* Card images - desktop */
  .card-img {
    height: 220px;
  }

  .card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .heading-icon {
    width: 80px;
    height: 80px;
  }

  .hero-bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .decor-left {
    left: -250px;
    width: 450px;
    height: 360px;
  }

  .decor-right {
    width: 450px;
    height: 360px;
  }

  /* Footer */
  .footer {
    padding: 3rem 0px;
  }

  .footer-grid {
    grid-template-columns: 1fr repeat(4, auto);
    gap: 2.5rem;
    margin-bottom: 2rem;
  }

  .footer-logo-wordmark {
    font-size: 3rem;
  }

  .logo-img {
    width: 200px;
    height: 50px;
  }

  .social-icons {
    gap: 0.5rem;
    margin-top: 1rem;
  }

  .social-icons a {
    width: 36px;
    height: 36px;
    font-size: 0.9rem;
  }

  .footer-hours {
    font-size: 0.875rem;
  }

  .footer-note {
    font-size: 0.75rem;
  }



  /* Arrivals section handled in dedicated media queries */
}

/* ------------------------------------------------------------------------------------------------------------------------------------------------ */
.page-hero {
  background: linear-gradient(180deg, #E6F0FF 0%, rgba(230, 240, 255, 0.00) 97%);
  padding: 52px 0 14px;
  text-align: center;
  margin: 0;
}


.cb-breadcrumb {
  font-size: 13px;
}

.cb-breadcrumb a {
  color: var(--cb-muted);
  text-decoration: none;
}

.cb-breadcrumb a:hover {
  color: var(--cb-navy);
}

.cb-breadcrumb .sep {
  color: #c7c8d0;
  margin: 0 6px;
}

.cb-breadcrumb .current {
  color: var(--cb-navy);
  font-weight: 600;
}

.filter-bar {
  background: #fff;
  border: 1px solid var(--cb-border);
  border-radius: 100px;
  padding: 14px 28px;

}

.filter-bar-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0;
  row-gap: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}

.sort-bar-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
}



.filter-divider {
  width: 1px;
  height: 20px;
  background: #e0e0e6;
  margin: 0 18px;
  flex-shrink: 0;
}

.filter-select {
  border: none;
  outline: none;
  font-weight: 500;
  color: var(--cb-navy);
  background:
    url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 5L7 9L11 5' stroke='%230c1788' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 4px center;
  -webkit-appearance: none;
  appearance: none;
  padding-right: 32px;
  padding-left: 0;
  cursor: pointer;
  transition: color .2s;
  background-size: 14px 14px;
  background-position: right 15px center;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: url("/newdesign/images/down.svg");
  background-repeat: no-repeat;
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  /* space for arrow */
}

.filter-select:hover {
  color: var(--cb-red);
}

.filter-select:focus {
  color: var(--cb-navy);
  box-shadow: none;
  outline: 2px solid var(--cb-navy);
  outline-offset: 2px;
  border-radius: 4px;
}

.toggle-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.toggle-label {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.toggle-switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 22px;
  flex-shrink: 0;
}

.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
}

.toggle-track {
  position: absolute;
  inset: 0;
  border-radius: 100px;
  background: #e0e0e6;
  border: 1px solid #c7c8d0;
  cursor: pointer;
  transition: background .3s, border-color .3s;
}

.toggle-track::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  top: 2px;
  left: 2px;
  transition: transform .3s;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .2);
}

.toggle-switch input:checked~.toggle-track {
  background: var(--cb-red);
  border-color: var(--cb-red);
}

.toggle-switch input:checked~.toggle-track::after {
  transform: translateX(14px);
}

/* 
.toggle-switch input:focus~.toggle-track {
  outline: 2px solid var(--cb-navy);
  outline-offset: 2px;
} */

.sort-tab {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: #878aaa;
  cursor: pointer;
  white-space: nowrap;
  transition: color .2s;

}

.sort-tab:first-child {
  padding-left: 0;
}

.sort-tab:last-of-type {
  border-right: none;
}

.sort-tab:hover {
  color: var(--cb-navy);
}

.sort-tab.active {
  color: var(--cb-navy);
  font-weight: 700;
}


.pdot-margin {
  margin-right: 17px;
}

.page-dots {
  display: flex;
  align-items: center;
  gap: 5px;
}

.pdot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  cursor: pointer;
  border: 1px solid transparent;
  padding: 0;
  transition: background .2s, border-color .2s;
}

/* .pdot.on {
  background: var(--cb-navy);
  border-color: var(--cb-navy);
} */

.page-dots.on .pdot {
  background: var(--cb-navy);
  border-color: var(--cb-navy);
}

/* When button is OFF, grey dots */
.page-dots.off .pdot {
  background: #c7c8d0;
  border-color: #c7c8d0;
}

/* .pdot.off {
  background: #c7c8d0;
  border-color: #c7c8d0;
}
.pdot:focus {
  outline: 2px solid var(--cb-navy);
  outline-offset: 2px;
} */

.product-card {
  border-radius: 20px;
  /* overflow: hidden; */
  /* transition: transform .3s ease, box-shadow .3s ease; */
  /* cursor: pointer; */
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* .product-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 18px 44px rgba(12, 23, 136, .13);
} */

/* .product-card:focus-within {
  outline: 2px solid var(--cb-navy);
  outline-offset: 2px;
} */

.product-img-wrap {
   background: var(--cb-grey);
  border-radius: 20px;
  /* height: auto; */
  width: 100%;
  cursor: pointer;
  transition: opacity var(--transition);
  aspect-ratio: 1;
}

/* .product-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .45s ease;
}

.product-card:hover .product-img-wrap img {
  transform: scale(1.06);
} */

.badge-recommended {
  position: absolute;
  top: 10px;
  left: 20px;
  background: #E9FFED;
  color: #7A877C;
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  border-radius: 100px;
  padding: 3px 10px;
  white-space: nowrap;
  z-index: 2;
  /* text-transform: uppercase; */
}
@media (max-width: 767px) {
  .badge-recommended {
 padding: 1px 10px;
}
}

.product-code {
  font-size: 12px;
  color: var(--cb-navy);
  font-weight: 400;
  margin-bottom: 3px;
  text-transform: uppercase;
  letter-spacing: 0.5px;

}

.product-name {
  font-size: 18px;
  font-weight: 700;
  color: #434453;
  line-height: 1.35;
 margin-bottom: .4rem;
  word-break: break-word;
}

.product-price {
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-red);
  margin-bottom: 0;
}

.menu-product-price{
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-red);
  margin-bottom: 15px;
}

.product-price .discount {
  color: #C7C8D0 !important;
}

.product-detail-price {
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-red);
  margin-bottom: 15px;
  text-align: left;
}

.price-strike {
  text-decoration: line-through;
  color: var(--cb-red);
  font-size: 16px;
  font-weight: 700;
  margin-right: 4px;
}

.price-sale {
  color: var(--cb-red);
  font-size: 16px;
  font-weight: 700;
  margin-right: 4px;
}

.price-off {
  color: var(--cb-navy);
  font-size: 14px;
  font-weight: 700;
}

.nl-title {
  font-family: 'Poppins', sans-serif;
  font-size: 26px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 2px;
  line-height: 1.2;
  word-break: break-word;
}

.nl-sub {
  font-family: 'Poppins', sans-serif;
  font-size: 13px;
  color: #5e6570;
  margin-bottom: 0;
}

.nl-input {
  flex: 1;
  background: #fff;
  border: 2px solid #fff;
  border-radius: 10px;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  color: var(--cb-text);
  padding: 14px 20px;
  outline: none;
  min-width: 0;
  transition: border-color .2s;
  max-width: 100%;
}

.nl-input::placeholder {
  color: #c5dbc4;
}

.nl-input:focus {
  border-color: var(--cb-navy);
}

.nl-btn {
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  font-family: 'Poppins', sans-serif;
  font-size: 15px;
  font-weight: 600;
  padding: 14px 36px;
  white-space: nowrap;
  cursor: pointer;
  transition: background .2s, transform .2s;
  min-height: 52px;
  flex-shrink: 0;
}

.nl-btn:hover {
  background: #b51d21;
  transform: scale(1.03);
}

.nl-btn:focus {
  outline: 2px solid var(--cb-navy);
  outline-offset: 2px;
}

.nl-btn:active {
  transform: scale(0.98);
}

.page-hero .hero-subtitle {
  color: #554343;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin-top: 7px;
}

.filter-select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

.flex-end-wrap {
  display: flex;
  /* d-flex */
  align-items: center;
  /* align-items-center */
  flex-wrap: wrap;
  /* flex-wrap */
  gap: 20px;
  /* gap-4 in Bootstrap is 1rem */
}

.sort-bar-section {
  margin: 0px 0;
}

.sort-bar {
  padding: 0 40px;
  margin-bottom: 20px;
}

@media (max-width: 991px) {
  .sort-bar {
    padding: 0 0px;
  }
}

@media (max-width: 1199.98px) {
  :root {
    font-size: 15px;
  }

  .page-hero {
    padding: 48px 0 24px;
  }

  .page-hero h1 {
    font-size: 36px;
  }

  .page-hero .hero-subtitle {
    color: #554343;
    font-family: "DM Sans";
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-top: 7px;
  }

  .filter-bar {
    flex-wrap: wrap;
    border-radius: 18px;
    padding: 22px 30px;
  }

  .filter-divider {
    display: none;
  }

  .product-name {
    font-size: 16px;
  }

  .nl-title {
    font-size: 24px;
  }

  .nl-btn {
    padding: 12px 28px;
    font-size: 14px;
  }
}


@media (max-width: 991.98px) {
  :root {
    font-size: 14px;
  }

  .page-hero {
    padding: 40px 0 20px;
  }

  .page-hero h1 {
    font-size: 30px;
    margin-bottom: 8px;
  }

  .page-hero .hero-subtitle {
    font-size: 12px;
  }

  .cb-breadcrumb {
    font-size: 12px;
  }

  .filter-bar {
    padding: 10px 14px;
    border-radius: 16px;
    gap: 0;
    row-gap: 8px;
  }

  .filter-divider {
    margin: 0 10px;
    height: 18px;
  }

  .sort-tab {
    padding: 0 10px;
    font-size: 11px;
  }

  .product-card {
    border-radius: 16px;
  }

  .nl-title {
    font-size: 22px;
  }

  .nl-input {
    padding: 12px 16px;
    font-size: 13px;
  }

  .nl-btn {
    padding: 12px 24px;
    font-size: 13px;
  }
}

@media (max-width: 767.98px) {
  :root {
    font-size: 13px;
  }

  .page-hero {
    padding: 32px 0 18px;
  }

  .page-hero h1 {
    font-size: 24px;
    margin-bottom: 6px;
  }

  .page-hero .hero-subtitle {
    font-size: 11px;
    max-width: 600px;
  }

  .cb-breadcrumb {
    font-size: 11px;
  }

  /* .container-xl {
    padding-left: 12px;
    padding-right: 12px;
  } */

  .filter-bar {
    padding: 10px 12px;
    border-radius: 14px;
    flex-wrap: wrap;
    row-gap: 8px;
  }

  .filter-divider {
    margin: 0 8px;
    height: 16px;
    display: none;
  }

  .filter-select {
    font-size: 11px;
    padding: 6px 10px;
    flex: 1 1 calc(50% - 6px);
    min-width: 110px;
  }

  .sort-tab {
    padding: 0 8px;
    font-size: 10px;
  }

  .sort-tab:first-child {
    padding-left: 0;
  }

  .product-card {
    border-radius: 14px;
    /* border: 1px solid #f5f5f5; */
  }
  .nl-title {
    font-size: 18px;
  }

  .nl-sub {
    font-size: 11px;
  }

  .nl-input {
    padding: 10px 12px;
    font-size: 12px;
  }

  .nl-btn {
    padding: 10px 20px;
    font-size: 12px;
    min-height: 44px;
  }

  .footer-contact-num {
    font-size: 29px;

  }
  .footer-hours {
  font-size: 16px;
  }
  .footer-note {
    font-size: 14px;
  }

}

@media (max-width: 575.98px) {
  :root {
    font-size: 12px;
  }

  body {
    font-size: 12px;
  }

  .page-hero {
    padding: 24px 0 14px;
  }

  .page-hero h1 {
    font-size: 20px;
    margin-bottom: 4px;
  }

  .page-hero .hero-subtitle {
    font-size: 14px;
    line-height: 1.4;
  }

  .cb-breadcrumb {
    font-size: 10px;
  }

  /* .container-xl {
    padding-left: 10px;
    padding-right: 10px;
  } */

  .filter-bar {
    padding: 8px 10px;
    border-radius: 10px;
    flex-wrap: wrap;
    row-gap: 6px;
    gap: 6px;
  }

  .filter-divider {
    display: none;
  }

  .filter-select {
    font-size: 10px;
    padding: 5px 8px;
    flex: 1 1 calc(50% - 3px);
    min-width: 90px;
    background-size: 12px 12px;
    padding-right: 18px;
  }

  .sort-tab {
    padding: 0 6px;
    font-size: 9px;
  }

  .sort-tab:first-child {
    padding-left: 0;
  }

  .product-card {
    border-radius: 12px;
    margin-bottom: 12px;
  }

  .product-code {
    font-size: 9px;
    margin-bottom: 1px;
  }

  .newsletter-section {
    padding: 30px 0 10px;
  }

  .nl-title {
    font-size: 16px;
    margin-bottom: 1px;
  }

  .nl-sub {
    font-size: 10px;
    margin-bottom: 10px;
  }

  .nl-input {
    padding: 8px 10px;
    font-size: 11px;
    border-radius: 6px;
  }

  .nl-btn {
    padding: 8px 16px;
    font-size: 11px;
    min-height: 40px;
    border-radius: 20px;
  }

  .toggle-switch {
    width: 30px;
    height: 18px;
  }

  .toggle-track::after {
    width: 14px;
    height: 14px;
    top: 1px;
    left: 1px;
  }

  .toggle-switch input:checked~.toggle-track::after {
    transform: translateX(12px);
  }



}


@media (max-width: 359.98px) {
  :root {
    font-size: 11px;
  }

  .page-hero h1 {
    font-size: 18px;
  }

  .filter-select {
    font-size: 9px;
    flex: 1 1 100%;
    min-width: 100%;
  }

  .nl-title {
    font-size: 14px;
  }

}


/* @media (hover: hover) {
  .product-card:hover {
    transform: translateY(-7px);
  }
} */

/* @media (hover: none) {
  .product-card:active {
    transform: translateY(-3px);
  }

  .nl-btn:active {
    transform: scale(0.95);
  }
} */


@media (orientation: landscape) and (max-height: 500px) {

  .page-hero h1 {
    font-size: 24px;
    margin-bottom: 4px;
  }

  /* #mainNav {
    padding: .3rem 0;
  } */
}

.section-header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 40px 0 40px 0;
}

/* Empty pseudo pushes h2 to true centre */
.section-header::before {
  content: '';
}

#miniCheesecakes {
  padding-top: 34px;
}

.section-header p,
.section-header a {
  margin: 0;
  /* remove default spacing */
}

.section-header-title {
  color: #434453;
  font-family: "DM Sans";
  font-size: 40px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  grid-column: 2;
  text-align: center;
  margin: 60px 0;
 
}

.view-all-btn {
  justify-self: end;
  padding: 3px 25px;
  border: 1.5px solid #ccc;
  border-radius: 999px;
  font-size: 0.875rem;
  color: #333;
  text-decoration: none;
  white-space: nowrap;
  transition: border-color 0.2s, color 0.2s;
  grid-column: 3;
}

.view-all-btn:hover {
  border-color: #e91e8c;
  color: #e91e8c;
}

/* Layout */
.category-layout {
  margin-top: 25px;
  display: flex;
  align-items: center;
  gap: 50px;
}

/* Scroll area */
.category-scroll {
  display: flex;
  gap: 20px;
  overflow-x: auto;
  scroll-behavior: smooth;
  flex: 1;
  scrollbar-width: none;
}

.category-scroll::-webkit-scrollbar {
  display: none;
}

/* Card */
.category-card {
  flex: 0 0 23%;
  text-align: center;
}

.category-card img {
  width: 100%;
  /* height: 350px; */
  object-fit: cover;
  border-radius: 10px;
  aspect-ratio: 28 / 35;
}



.category-card p {
  margin-top: 10px;
  font-weight: 700;
  color: #0C1788;
  font-size: 20px;
}

/* Buttons */
.scroll-btn {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 1px solid #ff6b6b;
  background: #fff;
  color: #ff6b6b;
  cursor: pointer;
  position: absolute;
}

.scroll-left {
  left: 3%;
}

.scroll-right {
  right: 3%;
}

.cake-category-section {
  padding-bottom: 40px;
  position: relative;
}

/* Disabled */
.scroll-btn:disabled {
  opacity: .4;
  cursor: not-allowed;
}

/* Tablet */
@media (max-width:992px) {
  .category-card {
    flex: 0 0 calc(33.333% - 20px);
  }

  .scroll-btn {
    display: none;
  }

  .category-card img {
    width: 100%;
    height: 250px;
  }
}
@media (max-width:767px) {

 .collections-section {
    padding: 0 0;
    height: auto;
      /* background: linear-gradient(
    to bottom,
    #FFF5E9 0px,
    #FFF5E9 300px,
    transparent 200px,
    transparent 100%
  ); */
  }

  .cake-category-section {
    margin-bottom: 0px;
    padding-bottom: 20px;
  }
  .home-mobile-container{
    padding-top: 50px;
    background: #FFF5E9;
    color: #FFF5E9;
  }
  .section-header-title {
 
  margin: 0px 0 20px 0;
 
  }
  .heading{
    display :flex;
    justify-content: center;
    align-items: center;
  }
  .wave-inner {
    padding: 20px 0 35px 0;
    flex-direction: column;
  }
 .category-card {
    flex: 0 0 90%;
    
  }

  .scroll-btn {
    display: none;
  }

  .category-card img {
    width: 100%;
    aspect-ratio: 3 / 4;
    height: auto;
  }

  .category-scroll {
    gap: 30px;
  }
  .love-heading {
  font-size: 33px;
  max-width: 80%;
  }
  .love-tag {
  font-size: 16px;
  width: 90%;
  }
  .wave-text-container {
    padding-left: 6%;
    padding-right: 6%;
  }
  .love-btn {
    width: 100%;
    padding: 10px 0;
    font-size: 21px;
  }
  .decor-right {
   padding-left: 6%;
   margin-top: 40px;
  }
  .wave-display-class{
    display: none;
  }
  .mobile-display-btn{
    display: block !important;
    margin-top: 20px;
  }
  .view-all-btn{
    width: 100%;
    display: flex !important;
    justify-content: center !important;
    justify-self: center !important;
     padding: 5px 10px;
     font-size: 12px;
  }
  .desktop-display-btn{
    display: none !important;
  }
  .section-header-title {
    text-align: center !important;
  }
  .about-card-img {
    
    margin-top: 20px;
    
  }
  .about-card{
    margin-bottom: 30px;
  }
  .mobile-footer-bottom{
    display: block !important;
     
  }
  .mobile-logo-wrapper{
     margin-top: 20px;
     display: flex;
     justify-content: space-between;
  }
  .mobile-social-icons{
    display: flex;
    flex:1;
    gap: 15px;
    justify-content: end;
  }
  .desktop-footer-bottom{
    display: none !important;
  }
  .reasons-title {
    font-size: 26px;
  }
  .mobile-banner-wave{
    display: block !important;
  }
  .desktop-banner-wave{
    display: none !important;
  }
  .wave-bottom svg {
  height: auto;
  }
}
.mobile-footer-bottom{
  display: none;
}
.mobile-display-btn{
  display: none;
}
.mobile-banner-wave{
  display: none;
}

.container-xl, .topbar-container, .sl-sameday__col{
  padding-left: 6%;
  padding-right: 6%;
}
.wave-text-container{
   padding-left: 6%;
}



@media (min-width:1536px) {


  .category-card img {
    width: 100%;
    object-fit: cover;
    border-radius: 10px;
  }

  .love-bg {
    height: 700px;
  }

  .product-img-wrap {

    width: 100%;

  }

  .container-xl, .topbar-container, .sl-sameday__col {
    padding-left: 10%;
    ;
    padding-right: 10%;
    ;
  }
  .wave-text-container{
     padding-left: 10%;
  }
}

/* -----------------------------Product-detatil.css -------------------------------------------------- */


a {
  text-decoration: none;
  color: inherit;
}

.container {
  max-width: 1200px;
  width: 90%;
  margin: auto;
}




/* ─── GALLERY ─── */
.product-gallery-wrap {
  padding: 50px 0px;
}

.gallery-thumb {
  width: 100%;
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  /* border: 1px solid var(--cb-grey); */
  overflow: hidden;
  aspect-ratio: 1 / 1.05;
  cursor: pointer;
  transition: border-color var(--transition);
  position: relative;
}



.gallery-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  /* transition: transform 0.4s ease;
  transform-origin: var(--x, 50%) var(--y, 50%); */
  /* Slower transition */
  transition: transform 1.2s ease;

  /* Keep zoom centered */
  transform-origin: center center;
}

.gallery-thumb:hover img {
  /* transform: scale(1.6); */
  transform: scale(1.12);
}

/* ─── PRODUCT SECTION (config panel card) ─── */
.product-section {
  justify-content: flex-start;
  margin-bottom: .5rem;
  width: 100%;
  max-width: 100%;
  border-radius: 10px;
  border: 1px solid #DFE1F5;
  background: #FFF;
  /* display: flex; */
  flex-direction: column;
  align-items: flex-start;
}

.product-title-section {
  border-bottom: 1px solid #DFE1F5;
}

.product-title-padding {
  padding: 24px 34px;
  width: 100%;
}
@media (min-width:600px) and (max-width: 991px){
  .product-section .product-title-padding {
    padding: 24px 34px;
    /* width: fit-content; */
  }
 
}

@media (min-width:767px) and(max-width: 991px) {
 .wave-inner {
    padding: 40px 0 35px 0 !important;
  }
}

.config-panel {
  position: static;
}

@media (min-width: 1024px) {
  .config-panel {
    /*position: sticky;*/
    top: 88px;
  }
}

/* ─── PRODUCT TEXT ─── */
.product-sku {
  font-size: 14px;
  color: var(--cb-navy);
  font-weight: 400;
  margin-bottom: .4rem;
  text-align: left;
}


.product-details-name {
  font-size: 26px;
  font-weight: 600;
  color: var(--cb-navy);
  line-height: 1.3;
  margin-bottom: .4rem;
  text-align: left;
}

.product-desc {
  font-size: 12px;
  font-weight: 500;
  color: var(--cb-navy);
  line-height: 1.6;
  margin-bottom: 1rem;
  text-align: left;
}

.config-divider {
  border: 0;
  border-top: 2px solid var(--cb-border);
  margin: 1rem 0;
}

/* ─── SIZE OPTIONS ─── */
.size-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-navy);
  margin-bottom: .5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.size-label a {
  color: #878AAA;
  font-family: "DM Sans";
  font-size: 10px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
  text-underline-position: from-font;
}

.size-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  overflow: hidden;
}

.size-option.row {
  margin-left: 0;
  margin-right: 0;
}

.size-option .col-6:first-child {
  display: flex;
  justify-content: center;
  align-items: center;
}

.size-option {
  background: #fff;
  border: 1px solid var(--cb-border);
  border-radius: 10px;
  padding: .5rem .25rem;
  text-align: center;
  cursor: pointer;
  transition: background var(--transition), border-color var(--transition);
}


.size-option.active {
  background: #FEE8D5;
  border-color: transparent;
}



.size-option .size-name {
  font-size: 14px;
  font-weight: 600;
  color: #000;
  display: block;
  margin-bottom: 2px;
  text-align: left;
}



.size-option .size-serving {
  font-size: 10px;
  font-weight: 500;
  color: #878aaa;
  display: block;
  text-align: left;
}

.size-option.active .size-serving {
  color: #000000;
}

/* ─── CONFIG SECTION (pink blush card) ─── */
.config-section {
  margin-bottom: 10px;
  margin-top: 10px;
  width: 100%;
  max-width: 100%;
  border-radius: 10px;
  padding: 20px 24px;
  background: #FEE8D5;
}

.sponge-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.config-section-label {
  font-size: 16px;
  font-weight: 600;
  color: var(--cb-navy);
  margin-bottom: .75rem;
  text-align: left;
}

/* ─── RADIO OPTIONS ─── */
.radio-opts {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem 1.5rem;
}

.radio-opt {
  display: flex;
  align-items: center;
  gap: .4rem;
  cursor: pointer;
  font-size: .9375rem;
}

.radio-opt input[type="radio"] {
  accent-color: var(--cb-red);
  width: 20px;
  height: 20px;
  cursor: pointer;
}

.radio-opt .opt-label {
  font-size: 16px;
  font-weight: 600;
  color: var(--cb-red);
}

.radio-opt input[type="radio"]:checked+.opt-label {
  color: #DC2328;
}

.radio-opt input[type="radio"]+.opt-label {
  color: #878aaa;
  cursor: pointer;
}

.radio-opt .opt-label.inactive {
  color: #878aaa;
}

/* ─── SELECT & TEXTAREA ─── */
.config-select {
  width: 100%;
  border: none;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;

  /* custom arrow */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='21' viewBox='0 0 20 21' fill='none'%3E%3Cg clip-path='url(%23clip0_86_56)'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M10 1.03312e-06C18.235 1.75305e-06 20 1.85325 20 10.5C20 19.1468 18.235 21 10 21C1.765 21 1.62016e-07 19.1467 9.17939e-07 10.5C1.67386e-06 1.85325 1.765 3.13194e-07 10 1.03312e-06ZM6.07742 9.36871L9.41075 12.8687C9.73617 13.2104 10.2638 13.2104 10.5893 12.8687L13.9226 9.36871C14.248 9.02703 14.248 8.47298 13.9226 8.13129C13.5972 7.7896 13.0695 7.7896 12.7441 8.13129L10 11.0126L7.25592 8.13129C6.9305 7.7896 6.40284 7.7896 6.07742 8.13129C5.752 8.47297 5.752 9.02702 6.07742 9.36871Z' fill='%23878AAA'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  background-size: 16px;

  /* spacing for arrow */
  padding: .6rem 2rem .6rem .875rem;

  border-radius: 10px;
  background-color: #fff;

  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  color: var(--cb-navy);
  cursor: pointer;
  outline: none;
}

.config-select:focus {
  /* outline: 2px solid var(--cb-navy); */
  outline-offset: 2px;
}

.config-textarea {
  width: 100%;
  border: none;
  background: #fff;
  border-radius: 10px;
  padding: .6rem .875rem;
  font-family: 'DM Sans', sans-serif;
  font-size: .875rem;
  color: var(--cb-navy);
  resize: none;
  height: 40px;
  outline: none;

}

.config-textarea:focus {
  /* outline: 2px solid var(--cb-navy); */
  outline-offset: 2px;
}

.config-hint {
  font-size: 12px;
  font-weight: 400;
  color: var(--cb-muted);
  margin-top: .75rem;
  text-align: left;
}

.config-message-hint {
  font-size: 12px;
  font-weight: 400;
  color: var(--cb-muted);
  text-align: left;
}

/* ─── PHOTO TOGGLE ─── */
.photo-toggle-row {
  display: flex;
  align-items: center;
  gap: .75rem;
}

.photo-toggle-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-navy);
}

.toggle-switch {
  position: relative;
  display: inline-block;
  width: 36px;
  height: 22px;
}

.toggle-switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-track {
  position: absolute;
  inset: 0;
  background: #ccc;
  border-radius: 22px;
  cursor: pointer;
  transition: background var(--transition);
}

.toggle-track::after {
  content: '';
  position: absolute;
  left: 3px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  background: #fff;
  border-radius: 50%;
  transition: transform var(--transition);
}

.toggle-switch input:checked~.toggle-track {
  background: var(--cb-red);
}

.toggle-switch input:checked~.toggle-track::after {
  transform: translate(14px, -50%);
}

/* ─── QTY + ADD TO BASKET ─── */
.qty-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: .75rem;
  flex-wrap: wrap;
}

.qty-box {
  display: flex;
  height: 48px;
  align-items: center;
  background: #fff;
  border-radius: 10px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--cb-border);
  flex-shrink: 0;
}


.qty-btn {
  background: none;
  border: none;
  font-size: 1.25rem;
  color: var(--cb-navy);
  width: 24px;
  /* height: 24px; */
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: color var(--transition);
  padding: 0;
}

.qty-btn:hover {
  color: var(--cb-red);
}

.qty-val {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--cb-navy);
  min-width: 20px;
  text-align: center;
}

.qty-val-muted {
  color: #878aaa;
}

.btn-addbasket {
  flex: 1;
  min-width: 0;
  height: 48px;
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 10px;
  text-align: center;
  font-weight: 700;
  font-size: 15px;
  padding: 10px 16px;
  cursor: pointer;
  transition: opacity var(--transition), transform var(--transition);
}

@media (min-width: 480px) {
  .btn-addbasket {
    height: 50px;
    font-size: 16px;
  }
}

.btn-addbasket:hover {
  opacity: .9;
  transform: translateY(-2px);
}

/* ─── TOTAL & KLARNA ─── */
.total-row {
  margin-bottom: .75rem;
}

.total-label {
  font-size: 14px;
  font-weight: 400;
  color: #000;
}

.total-val {
  font-size: 20px;
  font-weight: 700;
  color: var(--cb-red);
}

.klarna-wrap {
  border-radius: 8px;
  padding: .75rem;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-top: .75rem;
  flex-wrap: wrap;
}

@media (min-width: 480px) {
  .klarna-wrap {
    gap: 30px;
    padding: .75rem 1rem;
    flex-wrap: nowrap;
  }
}

.klarna-text {
  font-size: 12px;
  font-weight: 400;
  color: var(--cb-muted);
  line-height: normal;
  text-align: left;
}

/* ─── PRODUCT INFO BAND ─── */
.product-info {
  width: 100%;
  background: rgba(254, 242, 241, 0.71);
  padding: 80px 0;
}

/* ─── INFO GRID ─── */
.info-grid {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}

.info-description-section {
  width: 90%;

}

.info-box {
  padding-right: 15px;

}

.info-box h3 {
  font-size: 18px;
  font-weight: 700;
  color: #2c3e94;
  margin-bottom: 20px;
  position: relative;

}


.info-box h3::after {
  content: "";
  width: 120px;
  height: 3px;
  background: #2c3e94;
  position: absolute;
  left: 0;
  bottom: -6px;
}

.info-box p {
  font-size: 14px;
  color: #333;
  line-height: 1.7;
  margin-bottom: 12px;
}

.allergen-title {
  margin-top: 10px;
  font-weight: 600;
}

.allergen-icons {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 10px;
}

.allergen-icons img {
  width: 35px;
  height: 35px;
  border-radius: 20px;
}

/* ─── RELATED SECTION ─── */
.related-section {
  padding: 70px 0;
}



.related-section h1 {
  color: var(--cb-navy);
  font-family: "DM Sans";
  font-size: 30px;
  font-weight: 600;
  text-align: center;
}


.related-title {
  font-size: 16px;
  color: var(--cb-navy);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 1.5rem;
  text-align: center;
}

.related-card {
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  border-radius: 20px;
  cursor: pointer;
  transition: opacity var(--transition), transform var(--transition);
}

.related-card:hover {
  opacity: .9;
  transform: translateY(-4px);
}

.related-name {
  color: #434453;
  font-family: "DM Sans";
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 23px;
  margin-top: 18px;
  /* 127.778% */
}



/* ─── REVEAL ANIMATION ─── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
  height: fit-content;
}

.love-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* parent */
.mega-parent {
  position: static;
  padding-bottom: 2px;
}

#mainNav {
  position: relative;
}



/* dropdown panel */
.mega-menu {
  position: absolute;
  left: 0;
  top: 100%;
  background: #FEE8D5;
  padding: 40px 6%;
  display: none;
  left: 0;
  top: 100%;
  width: 100%;
  animation: fadeSlide 0.2s ease;
  /* margin-top: -18px; */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, visibility 0.2s ease;
  pointer-events: none;
}


/* show on hover */
.mega-parent:hover .mega-menu,
.mega-menu:hover {
  display: block;
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

@keyframes fadeSlide {
  from {
    opacity: 0;
    transform: translateY(-8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* layout */
.mega-container {
  margin: 30px 30px;
  display: flex;
}

/* column */
.mega-col ul {
  list-style: none;
  padding: 0px;
  margin: 0
}

.mega-col li {
  color: #554343;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
   /* margin-bottom: 10px; */
  /* line-height: 28px; */
  /* 200% */
}

.mega-inner-col {
  padding-right: 25px;

}

.mega-inner-col li {
  margin-bottom: 7px;
}

.mega-sub-menu ul li {
  color: #554343;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  /* line-height: 34px; */
  padding-left: 20px;
  padding-right: 50px;
  padding-top: 5px;
  padding-bottom: 5px;
  /* margin-bottom: 10px; */
}

.megu-inner-menu {
  background-color: white;
  display: flex;
  padding: 27px 40px;
  gap: 60px;
  border-radius: 10px;
  margin-right: 23px;
}

.mega-sub-menu ul li:hover,
.mega-sub-menu ul li.active {
  background: #fff;
}

.mega-inner-menu.remove-top-left {
  border-radius: 0 10px 10px 10px;
}

.mega-col h6 {
  font-weight: 600;
  margin-bottom: 10px;
}

/* red headings */
.red {
  color: #DC2328;
  font-family: "DM Sans";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 34px;
  /* 212.5% */
}

/* right image */
.mega-image img {
  width: 200px;
  border-radius: 10px;
}

.view-all-text {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 600;
  line-height: 28px;
  /* 200% */
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
  text-underline-position: from-font;
}

.product-list-title {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 40px;
  font-style: normal;
  font-weight: 700;
  line-height: 55px;
  /* 137.5% */
}

.product-category-text {
  color: #0C1788;
  text-align: center;
  font-family: "DM Sans";
  font-size: 32px;
  font-style: normal;
  font-weight: 200;
  line-height: normal;
  margin-top: 30px;
}

.enquire-btn {
  display: inline-block;
  padding: 8px 0;
  width: 100%;
  border-radius: 100px;
  border: 1px solid var(--cb-red);
  /* background: #FFE2E2; */
  background: #fff;
  color: var(--cb-red);
  /* color: #0C1788; */
  text-align: center;
  font-family: "DM Sans", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  text-transform: capitalize;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
  cursor: pointer;
  margin-top: 10px;
  margin-bottom: 20px;
}

.product-card:hover .product-image img,
.product-card:focus-within .product-image img {
    /* opacity: 0.85; */
    transform: scale(1.06);
}

/* Button effect when card is hovered */
.product-card:hover .enquire-btn,
.product-card:focus-within .enquire-btn {
    background: var(--cb-red);
    color: #fff;
}

/* Keep button hover effect */
.product-card .enquire-btn:hover {
    background: var(--cb-red);
    color: #fff;
}

/* Active / hover state */
.enquire-btn:hover,
.enquire-btn.active {
  background: #DC2328;
  color: #fff;
}

/* ------------------------------------------- Store-Locations.css-------------------------------------- */

.map-hero {
  position: relative;
  width: 100%;
  /* height: 450px; */
  overflow: hidden;
  background: #fff;
}

/* Map background image */
.map-hero-bg {
  position: absolute;
  inset: 0;
}

.map-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

/* Pink gradient overlay at top */
.map-pink-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom,
      #ffc9c0 0%,
      rgba(255, 232, 232, 0) 35%);
  pointer-events: none;
}

/* ── SEARCH PILL ────────────────────────────── */
.search-pill-wrap {
  position: absolute;
  top: 30px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  width: 100%;
  max-width: 900px;
  padding: 0 20px;
}

.search-pill {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 100px;
  height: 60px;
  padding: 0 0 0 24px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .12);
  gap: 0;
}

.search-pill-left {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.search-pill-text {
  color: var(--cb-navy);
  font-weight: 600;
  font-size: 18px;
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
  font-variation-settings: 'opsz' 14;
}

.search-divider {
  width: 2px;
  height: 100%;
  background: #D5D7E9;
  flex-shrink: 0;
  margin: 0 18px;
}

.search-pill-postcode {
  color: rgba(12, 23, 136, .5);
  font-weight: 600;
  font-size: 18px;
  font-family: 'DM Sans', sans-serif;
  font-variation-settings: 'opsz' 14;
  white-space: nowrap;
}

.search-pill-postcode em {
  font-style: normal;
  text-transform: lowercase;
}

.search-find-btn {
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  height: 60px;
  width: 186.8px;
  padding: 0 28px;
  font-weight: 600;
  font-size: 18px;
  font-family: 'DM Sans', sans-serif;
  font-variation-settings: 'opsz' 14;
  white-space: nowrap;
  cursor: pointer;
  transition: background var(--cb-ease);
  flex-shrink: 0;
}

.search-find-btn:hover {
  background: #c01e22;
}

/* ── MAP PINS & POPUP ───────────────────────── */
.map-pin-area {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.map-pin {
  position: absolute;
  width: 46px;
  pointer-events: all;
  cursor: pointer;
  transform: translateX(-50%);
  transition: transform .2s ease;
}

.map-pin:hover {
  transform: translateX(-50%) scale(1.15);
}

/* Popup card */
.map-popup {
  position: absolute;
  background: #ffe2e2;
  border-radius: 10px;
  padding: 15px 18px;
  font-size: 13px;
  font-family: 'DM Sans', sans-serif;
  color: #222;
  line-height: 1.6;
  white-space: nowrap;
  z-index: 20;
  pointer-events: none;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .10);
}

.map-popup strong {
  display: block;
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 4px;
  color: #111;
}

/* ═══════════════════════════════════════════
       STORE LOCATIONS WHITE CARD
    ═══════════════════════════════════════════ */
.locations-section {
  padding: 0 0 60px;
}

.locations-card {
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 -8px 40px rgba(0, 0, 0, .08);
  max-width: 1340px;
  margin: -50px auto 0;
  position: relative;
  z-index: 5;
  padding: 40px 50px 50px;
}
@media (min-width: 300px) and (max-width: 767px) {
  .locations-card {
    padding: 30px 20px 40px;
    margin: -30px 10px 0;
  }
}
@media (min-width: 768px) and (max-width: 990px) {
  .locations-card {
    padding: 30px 20px 40px;
    margin: -150px 15px 0;
  }
}
@media (min-width: 991px) and (max-width: 1023px) {
  .locations-card {
    padding: 30px 20px 40px;
    margin: -70px 15px 0;
  }
  
}
@media (min-width: 1024px){
  .locations-card {
    padding: 40px 50px 50px;
    margin: -70px 20px 0;
  }
}
@media (min-width: 1400px){
  .locations-card {
    padding: 40px 50px 50px;
    margin: -50px auto 0;
  }
}
/* ── HEADING ROW ──────────────────────────── */
.locations-nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 32px;
}

.locations-heading {
  color: var(--cb-navy);
  font-size: 24px;
  font-weight: 600;
  margin: 0;
  font-variation-settings: 'opsz' 14;
}

.slider-arrows {
  display: flex;
  gap: 10px;
}

.arrow-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--cb-grey);
  background: #fff;
  color: var(--cb-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 14px;
  transition: all var(--cb-ease);
}

.arrow-btn:hover:not(:disabled) {
  border-color: var(--cb-navy);
  background: var(--cb-navy);
  color: #fff;
}

.arrow-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
}

/* ── SLIDER WRAPPER ───────────────────────── */
.slider-viewport {
  overflow: hidden;
  width: 100%;
  scroll-behavior: smooth;
}

.slider-track {
  display: flex;
  gap: 30px;
  transition: transform .4s cubic-bezier(.4, 0, .2, 1);
  will-change: transform;
}

/* ── STORE CARD ───────────────────────────── */
.store-slide {
  flex: 0 0 calc((100% - 60px) / 3);
  max-width: calc((100% - 60px) / 3);
}

.store-card {
  background: #fff;
  border: 1px solid #D9D9D9;
  border-radius: 15px;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
  cursor: pointer;
  transition: box-shadow var(--cb-ease), border-color var(--cb-ease);
}

.store-card.is-active {
  border: 2px solid #0C1788;
  box-shadow: 0 10px 32px rgba(220, 35, 40, .15);
}

.store-card:hover:not(.is-active) {
  box-shadow: 0 8px 26px rgba(12, 23, 136, .10);
}

/* Image placeholder area */
.store-img-wrap {
  margin: 8px;
  border-radius: 10px;
  height: 200px;
  background: #fff;
  border: 1px solid var(--cb-grey);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
}

.store-img-placeholder {
  font-size: 30px;
  font-weight: 600;
  color: #d7caca;
  font-family: 'DM Sans', sans-serif;
  user-select: none;
}

.store-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Card body */
.store-body {
  padding: 16px 20px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.store-name {
  color: var(--cb-navy);
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 8px;
  font-variation-settings: 'opsz' 14;
}

.store-addr {
  color: #626170;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  margin-bottom: 14px;
  flex: 1;
  font-variation-settings: 'opsz' 14;
}

.store-hrs-label {
  color: var(--cb-navy);
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 6px;
}

.store-hrs-val {
  color: #626170;
  font-size: 15px;
  margin-bottom: 18px;
  font-weight: 500;
}

.store-hrs-sep {
  color: #d0cee4;
  margin: 0 6px;
}

/* Action buttons */
.btn-direction {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  border: 1px solid var(--cb-navy);
  border-radius: 100px;
  color: var(--cb-navy);
  font-weight: 600;
  font-size: 16px;
  font-family: 'DM Sans', sans-serif;
  margin-bottom: 10px;
  transition: background var(--cb-ease), color var(--cb-ease);
  font-variation-settings: 'opsz' 14;
}

.btn-direction:hover {
  background: var(--cb-navy);
  color: #fff;
}

.btn-store-info {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  border: 1px solid var(--cb-red);
  border-radius: 100px;
  background: none;
  color: var(--cb-red);
  font-weight: 600;
  font-size: 16px;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer;
  width: 100%;
  transition: background var(--cb-ease), color var(--cb-ease);
  font-variation-settings: 'opsz' 14;
}

.btn-store-info:hover {
  background: var(--cb-red);
  color: #fff;
}

/* ── PROGRESS BAR ─────────────────────────── */
.progress-wrap {
  margin-top: 32px;
}

.progress-track {
  height: 10px;
  background: #f9efef;
  border-radius: 100px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  background: var(--cb-red);
  border-radius: 100px;
  width: 25%;
  transition: width .4s ease;
}
#postcodeInput {
  color: rgba(12, 23, 136, 0.50);
font-size: 20px;
font-style: normal;
font-weight: 600;
line-height: normal;
}
#postcodeInput::placeholder {
   color: rgba(12, 23, 136, 0.50);
font-size: 20px;
font-style: normal;
font-weight: 600;
line-height: normal;
text-transform: lowercase;
}

@media (max-width: 1199px) {
  /* .locations-card {
    padding: 32px 30px 40px;
  } */

  .store-slide {
    flex: 0 0 calc((100% - 30px) / 2);
    max-width: calc((100% - 30px) / 2);
  }
}

@media (max-width: 991px) {
  .map-hero {
    height: 520px;
  }

  .search-pill-text {
    font-size: 14px;
  }

  .search-pill-postcode {
    font-size: 13px;
  }

  .search-find-btn {
    font-size: 14px;
    padding: 0 18px;
  }

}

@media (max-width: 767px) {
  .map-hero {
    height: 420px;
  }

  .search-pill-wrap {
    padding: 0 12px;
  }

  .search-pill {
    height: 52px;
    padding: 0 0 0 16px;
  }

  .search-pill-text {
    font-size: 13px;
  }

  .search-divider {
    display: none;
  }

  .search-pill-postcode {
    display: none;
  }

  .search-find-btn {
    height: 44px;
    font-size: 13px;
    padding: 0 16px;
  }

  .store-slide {
    flex: 0 0 calc(100% - 0px);
    max-width: 100%;
  }

  /* .locations-card {
    margin: -30px 12px 0;
    padding: 24px 16px 32px;
  } */

}

.mobile-postcode-section {
  display: none;
}

@media (max-width:447px) {
  .desktop-postcode-section {
    display: none;
  }

  .mobile-postcode-section {
    display: flex;
  }

  .search-find-btn {
    height: 52px;
    width: 110px;
    padding: 0 14px;
    font-weight: 500;
    font-size: 11px;
  }

  #postcodeInput {
    font-size: 10px;
  }

  .search-pill-text {
    font-size: 11px;
  }
}

.product-page-hero {
 background: linear-gradient(180deg, #E6F0FF 0%, rgba(230, 240, 255, 0.00) 97%);
 width: 100%;
  background-size: 100% 150px;
  background-repeat: no-repeat;
  background-color: #ffffff;

}




/* ─── HERO TITLE ─── */
.page-hero-title {
  font-size: 24px;
  font-weight: 700;
  color: var(--cb-navy);
  margin-bottom: 8px;
  font-variation-settings: 'opsz' 14;

  /* Cross-browser */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .page-hero-title {
    font-size: 28px;
    margin-bottom: 10px;
  }
}

@media (min-width: 768px) {
  .page-hero-title {
    font-size: 34px;
  }
}

@media (min-width: 1024px) {
  .page-hero-title {
    font-size: 40px;
  }
}

/* ─── HERO SUBTITLE ─── */
.page-hero-sub {
  font-size: 13px;
  font-weight: 600;
  color: #554343;
  margin: 0;
  font-variation-settings: 'opsz' 14;

  /* Cross-browser */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (max-width: 767px) {
  .page-hero-sub {
    padding: 0 6%;
  }
}

@media (min-width: 768px) {
  .page-hero-sub {
    font-size: 14px;
  }
}

/* ─── ACCOMPLISHMENTS SECTION ─── */
.accomplishments-section {
  padding: 20px 0px;
}

@media (min-width: 768px) {
  .accomplishments-section {
    padding: 30px 0 60px;
  }
}

@media (min-width: 1024px) {
  .accomplishments-section {
    padding: 40px 0 80px;
  }
}

.awards-container {
  max-width: 1260px;
  margin: 0 auto;
  padding: 0 16px;
}

@media (min-width: 480px) {
  .awards-container {
    padding: 0 40px;
  }
}

/* ─── WIDE LANDSCAPE AWARD CARD ─── */
.award-card-wide {
  background: #fff;
  border: 1px solid #C9C9C9;
  border-radius: 30px;
  margin-bottom: 20px;
  overflow: visible;
  position: relative;
}

@media (min-width: 768px) {
  .award-card-wide {
    border-radius: 30px;
    margin-bottom: 24px;
  }
}

@media (min-width: 1024px) {
  .award-card-wide {
    border-radius: 30px;
    margin-bottom: 28px;
  }
}

.award-card-wide-inner {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  padding: 0px;
  /* gap: 20px; */
}

@media (max-width: 767px) {
  .award-card-wide-inner {
    flex-direction: column;
    padding: 0px;
  }
  .award-img-col img.award-photo {
  
    border-radius: 20px 20px 0px 0px !important;
   
}
}

/* Image column */
.award-img-col {
  flex: none;
  width: 100%;
  /* position: relative; */
}

@media (min-width: 768px) {
  .award-img-col {
    flex: 0 0 320px;
    max-width: 320px;
  }
}

@media (min-width: 1024px) {
  .award-img-col {
    flex: 0 0 428px;
    max-width: 428px;
  }
}

.award-img-col img.award-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  border-radius: 20px 0 0 20px;
  display: block;
}

@media (max-width: 480px) {
  .award-img-col img.award-photo {
    height: 260px;
    border-radius: 20px 20px 0 0px;
  }
}

@media (min-width: 768px) {
  .award-img-col img.award-photo {
    height: 100%;
  }
}
@media (min-width: 1024px) {
  .award-img-col img.award-photo {
    height: 100%;
  }
}



/* Badge overlay */
.award-badge-wrap {
  position: absolute;
  z-index: 2;
right: 0px;
  /* transform: translateX(-50%); */
  top: 0px;
  display: flex;
  justify-content: center;
  width: 80px;
  height: 80px;
}


.award-badge-wrap img {
  width: 90px;
  height: 90px;
  border-radius: 10px 20px 10px 10px;
}

/* Secondary badge */
.award-badge-secondary {
  position: absolute;
  z-index: 6;
  object-fit: contain;
  border-radius: 14px;
  border: 2px solid #fff;

  /* Mobile: slightly offset from primary */
  right: 6px;
  bottom: -76px;
  width: 72px;
  height: 72px;
}

@media (min-width: 480px) {
  .award-badge-secondary {
    right: 8px;
    bottom: -92px;
    width: 90px;
    height: 90px;
  }
}

@media (min-width: 768px) {
  .award-badge-secondary {
    right: -50px;
    bottom: auto;
    top: calc(50% + 10px);
    width: 110px;
    height: 110px;
    border-radius: 16px;
  }
}

@media (min-width: 1024px) {
  .award-badge-secondary {
    right: -68px;
    width: 148px;
    height: 148px;
    border-radius: 20px;
  }
}

/* Text column */
.award-text-col {
  position: relative;
  flex: 1;
  text-align: center;
  padding: 30px 30px 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  background-color: #FFF5E9;
  border-radius: 0px 0px 30px 30px;

}

.award-text-col-1{
  background-color: #F5F4FD;
}
.award-card-portrait-1{
  background-color: #F5F4FD !important;
}

@media (min-width: 480px) {
  .award-text-col {
    text-align: center;
    padding: 68px 30px 20px;
  }
}

@media (max-width: 767px) {
  .award-text-col {
    text-align: center;
    padding: 40px 30px 30px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}

@media (min-width: 768px) {
  .award-text-col {
    text-align: left;
    padding: 85px 56px 30px;
    border-radius: 0px 30px 30px 0px;
  }

}
@media (min-width: 768px) and (max-width: 1023px) {
 .award-badge-wrap img {
  width: 70px;
  height: 70px;
}

}


@media (min-width: 1024px) {
  .award-text-col {
    text-align: left;
    padding: 90px 56px 30px;
    border-radius: 0px 30px 30px 0px;
  }
}

@media (min-width: 1280px) {
  .award-text-col {
    text-align: left;
    padding: 70px 56px 30px 80px;
    border-radius: 0px 30px 30px 0px;
  }
}

.award-title {
  font-size: 30px;
  font-weight: 600;
  color: var(--cb-navy);
  line-height: 1.3;
  margin-bottom: 14px;
  font-variation-settings: 'opsz' 14;
    margin-bottom: 20px;
}

@media (max-width: 480px) {
  .award-title {
    font-size: 16px;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .award-title {
    font-size: 20px;
    margin-bottom: 18px;
  }
}

.award-desc {
   font-size: 16px;
    margin-bottom: 28px;
  font-weight: 600;
  color: var(--cb-text);
  line-height: 1.6;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) and (max-width: 1023px) {
  .award-desc {
    font-size: 15px;
    margin-bottom: 24px;
  }
}

@media (max-width: 767px){
  .award-desc {
    font-size: 13px;
    margin-bottom: 18px;
  }
}

.btn-more-details {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 48px;
  width: 100%;
  max-width: 100%;
  background: var(--cb-red);
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  font-variation-settings: 'opsz' 14;
  border-radius: 100px;
  border: none;
  cursor: pointer;
  text-transform: capitalize;
  transition: background var(--cb-ease), transform var(--cb-ease);
  -webkit-appearance: none;
  appearance: none;
}

@media (min-width: 480px) {
  .btn-more-details {
    width: 160px;
    font-size: 17px;
  }
}

@media (min-width: 768px) {
  .btn-more-details {
    width: 187px;
    height: 54px;
    font-size: 18px;
  }
}

@media (min-width: 1024px) {
  .btn-more-details {
    height: 60px;
    font-size: 20px;
  }
}

.btn-more-details:hover {
  background: #c01e22;
  color: #fff;
  transform: translateY(-2px);
}

/* ─── PORTRAIT CARDS (2-up) ─── */
.portrait-cards-row {
  display: flex;
  flex-direction: column;
  gap: 20px;
  justify-content: center;
  margin-bottom: 0;
  margin-top: 20px;
}

@media (min-width: 600px) {
  .portrait-cards-row {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 20px;
    margin-top: 60px;
  }
}

@media (min-width: 1024px) {
  .portrait-cards-row {
    gap: 30px;
    flex-wrap: nowrap;
    margin-top: 80px;
  }
}

.award-card-portrait {
  background-color: #FFF5E9;
  border: 1px solid #C9C9C9;
  border-radius: 16px;
  width: 100%;
  max-width: 100%;
  overflow: visible;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 20px 16px 28px;
}

@media (min-width: 600px) {
  .award-card-portrait {
    width: calc(50% - 10px);
    max-width: 500px;
    border-radius: 20px;
    padding: 24px 20px 32px;
  }
}

@media (min-width: 1024px) {
  .award-card-portrait {
    width: calc(50% - 15px);
    border-radius: 30px;
    padding: 32px 24px 40px;
  }
}

/* Portrait image */
.award-portrait-img-wrap {
  position: relative;
  width: 100%;
  margin-bottom: 0;
}

.award-portrait-img-wrap img.award-photo {
  width: 100%;
  height: 200px;
  object-fit: cover;
  object-position: center top;
  border-radius: 14px;
  display: block;
}

@media (min-width: 480px) {
  .award-portrait-img-wrap img.award-photo {
    height: 240px;
  }
}

@media (min-width: 768px) {
  .award-portrait-img-wrap img.award-photo {
    height: 280px;
    border-radius: 16px;
  }
}

@media (min-width: 1024px) {
  .award-portrait-img-wrap img.award-photo {
    height: 342px;
    border-radius: 20px;
  }
}

/* Portrait badge */
.portrait-badge-wrap {
  position: relative;
  margin-top: -55px;
  margin-bottom: 16px;
  display: flex;
  gap: 8px;
  justify-content: center;
}

@media (min-width: 480px) {
  .portrait-badge-wrap {
    margin-top: -65px;
  }
}

@media (min-width: 768px) {
  .portrait-badge-wrap {
    margin-top: -75px;
    margin-bottom: 20px;
    gap: 10px;
  }
}

@media (min-width: 1024px) {
  .portrait-badge-wrap {
    margin-top: -90px;
    margin-bottom: 24px;
  }
}

.portrait-badge-wrap img {
  width: 80px;
  height: 80px;
  border-radius: 14px;
  border: 2px solid transparent;
}

@media (min-width: 480px) {
  .portrait-badge-wrap img {
    width: 100px;
    height: 100px;
  }
}

@media (min-width: 768px) {
  .portrait-badge-wrap img {
    width: 115px;
    height: 115px;
    border-radius: 16px;
  }
}

@media (min-width: 1024px) {
  .portrait-badge-wrap img {
    width: 130px;
    height: 130px;
    border-radius: 20px;
  }
}

/* Portrait text */
.award-portrait-body {
  text-align: center;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.award-portrait-body .award-title {
     font-size: 30px;
    margin-bottom: 16px;
  font-weight: 600;
}

@media (min-width: 768px) and (max-width: 1023px) {
  .award-portrait-body .award-title {
    font-size: 26px;
    margin-bottom: 14px;
  }
}

@media (max-width: 767px) {
  .award-portrait-body .award-title {
    font-size: 20px;
  margin-bottom: 12px;
    
  }
}

.award-portrait-body .award-desc {
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 18px;
}

@media (min-width: 768px) {
  .award-portrait-body .award-desc {
    font-size: 15px;
    margin-bottom: 22px;
  }
}

@media (min-width: 1024px) {
  .award-portrait-body .award-desc {
    font-size: 16px;
    margin-bottom: 24px;
  }
}

.cart-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 520px;
  max-width: 100vw;
  height: 100vh;
  background: #FEE8D5;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.38s cubic-bezier(0.4, 0, 0.2, 1);
  padding: 30px 40px;
}


.cart-drawer.open {
  transform: translateX(0);
}

@media (max-width: 480px) {
  .cart-drawer {
    width: 100vw;
  }
}

.overlay {
  position: fixed;
  /* ← NOT absolute */
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.45);
  z-index: 9998;
  /* ← just below drawer */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.35s ease, visibility 0.35s ease;
}

.overlay.active {
  opacity: 1;
  visibility: visible;
}

/* 3. Prevent body from scrolling when cart is open */
body.cart-open {
  overflow: hidden;
}

#cartToggle,
#cartToggleMobile,
#triggerBtn,
#drawerToggler,
#btn3,
#btn4,
#drawer-close-btn,
#postcodePopupClose,
#topPopupClose,
#triggerBtnSearch,
#fdTrigger,
#mobileAccountBtn,
#cartClose {
  background: none;
  border: none;
  outline: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: none;
  -webkit-appearance: none;
  appearance: none;
}

#cartToggle:focus,
#cartToggleMobile:focus,
#cartToggleMobile:focus-visible,
#triggerBtnSearch:focus,
#triggerBtnSearch:focus-visible,
#triggerBtn:focus,
#triggerBtn:focus-visible,
#fdTrigger:focus,
#btn3:focus,
#btn4:focus,
#drawer-close-btn:focus,
#drawer-close-btn:focus-visible,
#drawerToggler:focus,
#drawerToggler:focus-visible,
#mobileAccountBtn:focus,
#mobileAccountBtn:focus-visible,
#btn3:focus-visible,
#btn4:focus-visible,
#fdTrigger:focus-visible,
#postcodePopupClose:focus,
#postcodePopupClose:focus-visible,
#cartToggle:focus-visible {
  outline: none;
  box-shadow: none;
  border: none;
}

.drawer-items {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  min-height: 0;
  /* ← CRITICAL for flex scroll to work */
  padding: 0 0;
}

.drawer-header {
  display: flex;
  justify-content: flex-end;
}

.cart-heading-title {
  color: #434453;
  font-family: "DM Sans";
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.ci-card {
  background: #ffffff;
  border-radius: 10px;
  padding: 24px 24px;
  width: 100%;
  margin-bottom: 11px;
}

.ci-top {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.ci-image {
  width: 120px;
  height: 120px;
  border-radius: 10px;
  object-fit: cover;
  flex-shrink: 0;

}

.ci-title {
  color: #434453;
  font-family: "DM Sans";
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.ci-sku {
  color: #434453;
  font-family: "DM Sans";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.ci-attrs {
  border-top: 1px solid #D9D9D9;
  margin-bottom: 1rem;
  margin-top: 15px;
}

.ci-attr-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid #D9D9D9;
}

.ci-attr-cell {
  padding: 0.55rem 0.5rem;
}

.ci-attr-cell:first-child {
  border-right: 1px solid #D9D9D9;
}

.ci-attr-key {
  color: #626170;
  font-family: "DM Sans";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.ci-attr-val {
  color: #434453;
  font-family: "DM Sans";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.ci-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 0.9rem;
}

.ci-price {
  color: #DC2328;
  font-family: "DM Sans";
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}

/* Qty stepper */
.ci-qty-box {
  display: flex;
  align-items: center;
  background: #FFE2E2;
  border-radius: 10px;
  overflow: hidden;
  gap: 0;
}

.ci-qty-dec,
.ci-qty-inc {
  background: none;
  border: none;
  width: 30px;
  height: 30px;
  font-size: 16px;
  font-weight: 400;
  color: #0C1788;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, color 0.15s;
}

.ci-qty-dec {
  margin-right: 20px;
  margin-left: 10px;
}

.ci-qty-inc {
  margin-left: 20px;
  margin-right: 10px;
}

.ci-btn-update {
  background: #FFE2E2;
  border: none;
  border-radius: 100px;
  padding: 0.25rem 1.1rem;
  color: #434453;
  font-family: "DM Sans";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  cursor: pointer;
  transition: background 0.2s;
}

.ci-btn-update:hover {
  background: #f8c8d8;
}

.ci-btn-remove {
  background: white;
  border-radius: 100px;
  border: 1px solid #FFE2E2;
  padding: 0.25rem 1.1rem;
  color: #878AAA;
  font-family: "DM Sans";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}

.ci-btn-remove:hover {
  background: #fce8ef;
  color: #e53935;
}

.checkout-now-btn {
  display: block;
  width: 100%;
  border: none;
  border-radius: 10px;
  background: #DC2328;
  color: #FFF;
  font-family: "DM Sans", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  padding: 14px 32px;
  cursor: pointer;
  transition: background 0.2s;
  text-align: center;
}

.checkout-now-btn:hover {
  background: #b81c20;
}

.drawer-header {
  flex-shrink: 0;
  /* ← stays fixed at top */
}

.drawer-footer {
  flex-shrink: 0;
  /* ← stays fixed at bottom */
}

.drawer-items::-webkit-scrollbar {
  width: 4px;
}

.drawer-items::-webkit-scrollbar-track {
  background: #f5f5f5;
  border-radius: 10px;
}

.drawer-items::-webkit-scrollbar-thumb {
  background: #DC2328;
  border-radius: 10px;
}

/* Firefox */
.drawer-items {
  scrollbar-width: thin;
  scrollbar-color: #DC2328 #f5f5f5;
}

/* Fixed bottom */
.drawer-footer {
  flex-shrink: 0;
  padding: 1rem 1.25rem;
  border-top: 1px solid #f0f0f0;
}

.top-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh; 
  z-index: 99999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-20px);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

.top-popup.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.top-popup-inner {
  align-items: center;
  justify-content: center;
  gap: 12px;
  background: #EDF4FF;
  color: #fff;
  height: 100%;
  padding: 6%;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 500;
  position: relative;
  box-shadow: 0 4px 20px rgba(220, 35, 40, 0.3);
}

.close-btn {
  display: flex;
  justify-content: flex-end;
  margin-left: auto;
}

.search-input-wrapper {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 100px;
  padding: 14px 20px;
  gap: 12px;
  max-width: 800px;
  margin: 0 auto 23px;
}

.search-input {
  flex: 1;
  border: none;
  outline: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  color: #333;
  background: transparent;
}

.search-input::placeholder {
  color: #bbb;
}

.search-icon {
  flex-shrink: 0;
  color: #999;
}

/* ── TAGS ────────────────────────────────── */
.search-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 28px;
}

.search-tag {
  display: inline-block;
  padding: 7px 18px;
  border-radius: 100px;
  background: #fff;
  color: #000;
  font-family: "DM Sans";
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: normal;
  border: 1px solid transparent;
  transition: all 0.2s;
  cursor: pointer;
}

.search-tag:hover,
.search-tag.active {
  background: #DC2328;
  color: #fff;
}

/* coloured tags */
.search-tag.green {
  background: #C5DBC4;
}

.search-tag.blue {
  background: #DBC4DB;
}

.search-tag.pink {
  background: #FF9C9D;
}

.search-tag.green:hover,
.search-tag.blue:hover,
.search-tag.pink:hover {
  background: #DC2328;
  color: #fff;
}

/* ── NEW ARRIVALS SECTION ────────────────── */
.search-arrivals h3 {
  color: #434453;
  font-family: Poppins;
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin-bottom: 20px;
  display: flex;
  justify-self: center;
}

.search-arrivals-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  max-width: 1000px;
  margin: 0 auto;
}

.search-product-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
  cursor: pointer;
}
.search-product-card a {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.search-product-img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
  flex: 1;
}

.search-product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.search-product-name {
  color: #434453;
  text-align: center;
  font-family: "DM Sans";
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 23px;
  margin-top: 15px !important;
  text-align: center !important;
  /* 127.778% */
}

.top-popup-close {
  display: flex;
  justify-content: flex-end;
  margin-left: auto;
  margin-bottom: 10px;
}

.product-details-padding {
  padding: 20px 0px 30px 5px;
}

@media (max-width: 768px) {

  .product-details-padding {
  padding: 20px 0px 15px 5px;
}

.home-product-image{
  margin-bottom: 20px;
}

  .heading {
    margin-bottom: 2rem;
  }

  .arrivals-section {
    padding-top: 2rem;
  }

  .hero-section {
    min-height: clamp(300px, 60vh, 400px);
  }

  .hero-content {

    padding-top: 40px;


  }

  .hero-content h1 {

    font-size: 30px;
    padding: 0px 10px;
  }

  .hero-btn {
    margin-top: 5px;
    padding: 0 clamp(3rem, 5vw, 5rem);
    height: 30px;
  }

  .heading {
    padding-top: 1rem;
    margin-bottom: 0rem;
  }

  .placeholder-card {
    width: 98%;
    height: auto;
    aspect-ratio: 1;
    margin-bottom: 0px;
  }

  #reasons {
    padding: 50px 0 40px 0;
  }

  .about-card-img {
    width: 100%;
    height: 300px;
  }

  .about-card-body-title {
    font-size: 25px;
    margin-bottom: 5px;
  }

  .about-card-body-text {
    font-size: 15px;
    margin-bottom: 15px;
    -webkit-line-clamp: 4;
    line-clamp: 4;
  }

  .btn-about {
    font-size: 16px;
    padding: 8px 18px;
    margin-bottom: 10px;
  }

  .signup-text {
    margin-top: 10px;
    margin-bottom: 20px;
    margin-left: 0px;
  }

  .section-header-title {
    font-size: 25px;
  }

  .nav-icons {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-left: 0px;
    /* space between icons */
  }

  #bestselling {
    margin-top: 15px;
  }

  .product-img-wrap {

    width: 100%;
    border-radius: 20px;

  }

  .product-name {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 0px;
  }

  .product-price {
    font-size: 12px;
    margin-bottom: 0;
  }

  .price-strike {
    font-size: 11px;
    margin-right: 2px;
    font-weight: 500;
  }

  .price-sale {
    font-size: 11px;
    margin-right: 2px;
    font-weight: 500;
  }

  .price-off {
    font-size: 11px;
    font-weight: 500;
  }

  .container-xl, .topbar-container, .sl-sameday__col, .sl-sameday__col:last-child, .sl-sameday__col:first-child  {
    padding-left: 4% !important;
    ;
    padding-right: 4% !important;
    ;
  }
   .wave-text-container{
     padding-left: 4% !important;
  }

  .filter-bar {
    display: none;
  }

  .filter-btn {
    display: flex !important;
  }

  .product-category-text {
    font-size: 16px;
    margin-top: 0px;
  }

  .page-hero .hero-subtitle {
    margin-top: 0px;
  }

  .product-list-title {

    line-height: 40px;
    /* 137.5% */
  }

  .footer-column ul li a,
  .footer-column p {
    color: #7D6F6C;
    font-family: Poppins;
    font-size: 10px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    /* 207.143% */
  }

  .footer-column h3 {
    font-size: 16px;
  }

  .product-info {
    padding: 40px 0;
  }



  .search-arrivals-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    max-width: 800px;
    margin: 0 auto;
  }
}

@media (max-width:768px){
    .info-box {
    margin-bottom: 15px;
    padding-right: 10px;
  }
}

/* Large Tablets (769px - 1024px) */
@media (min-width: 768px) and (max-width: 1024px) {
  .container-xl, .topbar-container, .sl-sameday__col, .sl-sameday__col:last-child, .sl-sameday__col:first-child {
    padding-left: 3% !important;
    ;
    padding-right: 3% !important;
    ;
  }
   .wave-text-container{
     padding-left: 3% !important;
  }

  .filter-bar {
    display: none;
  }

  .filter-btn {
    display: flex !important;
  }

  .collections-section {
    padding: 0 0;
    height: auto !important;
  }

  .about-card-img {
    height: 300px;
  }


  .container {
    padding: 0 clamp(1.2rem, 4.5vw, 2rem);
  }

  .heading {
    margin-bottom: 2rem;
  }


  .heading-icon {
    width: clamp(50px, 12vw, 70px);
    height: clamp(50px, 12vw, 70px);
  }

  .heading h2 {
    font-size: clamp(1.5rem, 4.5vw, 2.2rem);
  }

  .carousel {
    gap: clamp(0.6rem, 1.9vw, 0.9rem);
  }

  .carousel-wrapper {
    gap: clamp(0.9rem, 2.1vw, 1.15rem);
  }

  .card {
    flex: 0 0 calc(33.333% - 0.8rem);
    border-radius: 14px;
  }

  .card-img {
    height: clamp(150px, 28vw, 220px);
    font-size: clamp(40px, 7vw, 60px);
  }

  .card-body {
    padding: clamp(0.8rem, 1.9vw, 1.1rem);
  }

  .card-body h3 {
    font-size: clamp(0.85rem, 2.3vw, 1rem);
  }

  .arrow {
    width: clamp(40px, 8vw, 46px);
    height: clamp(40px, 8vw, 46px);
    min-width: clamp(40px, 8vw, 46px);
    min-height: clamp(40px, 8vw, 46px);
  }

  .signup-text {
    margin-bottom: 10px;
    margin-left: 20px;
  }

  .newsletter-form {
    margin-bottom: 10px;
    flex: 1;
    flex-direction: column;
  }

  .about-card-body-title {
    font-size: 25px;
    margin-bottom: 5px;
  }

  .about-card-body-text {
    font-size: 15px;
    margin-bottom: 15px;
    -webkit-line-clamp: 3;
    line-clamp: 3;
  }

  .btn-about {
    font-size: 16px;
    padding: 8px 18px;

  }

  #reasons {
    padding: 30px 0 30px 0;
  }

  .placeholder-card {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    margin-bottom: 0px;
  }

  .home-product-image{
  margin-bottom: 20px;
}

  .section-header-title {
    font-size: 35px;
  }

  .decor-right {

    width: 300px;

  }

  .love-heading {
    font-size: 40px;
    width: 80%;
  }
  .love-tag{
    font-size: 18px;
    width: 90%;
  }

  .heading {
    padding-top: 2rem;
    margin-bottom: 2.5rem;
  }

  .hero-section {
    min-height: clamp(500px, 60vh, 700px);
  }

  #topbar {
    display: none;
    padding: clamp(0.3rem, 0.8vw, 0.4rem) 0;
  }

  .nav-icons {
    display: flex;
    align-items: center;
    gap: 20px;
    padding-left: 0px;
    /* space between icons */
  }

  #bestselling {
    margin-top: 15px;
  }

  .product-img-wrap {

    width: 100%;
    border-radius: 10px;


  }

  .product-category-text {
    font-size: 24px;
    margin-top: 10px;
  }

  .product-list-title {

    line-height: 50px;
    /* 137.5% */
  }

  .product-info {
    padding: 60px 0;
  }


}

@media (min-width: 1025px) and (max-width: 1280px) {
  .container-xl, .topbar-container, .sl-sameday__col {
    padding-left: 5%;
    ;
    padding-right: 5%;
    ;
  }
   .wave-text-container{
     padding-left: 5% !important;
  }

  .placeholder-card {
    width: 99%;
    aspect-ratio: 1;
  }

  .about-card {
    border-radius: 0px 0px 10px 10px;
    overflow: hidden;
    display: flex;
    /* height: 700px; */
    flex-direction: column;
  }

  #reasons {
    padding: 60px 0 40px 0;
  }
}

/* Carousel indicator buttons — circular */
.carousel-indicators button {
  width: 12px !important;
  height: 12px !important;
  border-radius: 50% !important;
  border: none !important;
  background-color: #FFE2E2 !important;
  opacity: 1 !important;
  padding: 0 !important;
  margin: 0 4px !important;
  transition: background 0.2s, transform 0.2s !important;
}

/* Active state */
.carousel-indicators button.active {
  background-color: #DC2328 !important;
  transform: scale(1.2);
}

/* Hover state */
.carousel-indicators button:hover {
  background-color: #DC2328 !important;
}

/* ── OVERLAY ── */
.fd-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}

.fd-overlay.show {
  opacity: 1;
  visibility: visible;
}

/* ── DRAWER ── */
.fd-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: 380px;
  max-width: 100vw;
  height: 100vh;
  background: #fff;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 16px 0 0 16px;
}

.fd-drawer.show {
  transform: translateX(0);
}

.fd-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: none;
  cursor: pointer;
  color: #3B1F8C;
  font-size: 22px;
  font-weight: 700;
  z-index: 1;
}

/* ── BODY ── */
.fd-body {
  flex: 1;
  overflow-y: auto;
  padding: 60px 24px 24px;
  min-height: 0;
}

.fd-body::-webkit-scrollbar {
  width: 4px;
}

.fd-body::-webkit-scrollbar-thumb {
  background: #3B1F8C;
  border-radius: 4px;
}

/* ── SECTION ── */
.fd-section {
  margin-bottom: 28px;
}

.fd-section-title {
  font-size: 16px;
  font-weight: 600;
  color: #3B1F8C;
  padding-bottom: 10px;
  border-bottom: 1.5px solid #3B1F8C;
  margin-bottom: 16px;
}

/* ── SELECT ── */
.fd-select-wrap {
  position: relative;
  margin-bottom: 20px;
}

.fd-select {
  width: 60%;
  padding: 12px 40px 12px 16px;
  border: none;
  border-radius: 10px;
  background: #EDEDF8;
  color: #3B1F8C;
  font-size: 15px;
  font-weight: 500;
  appearance: none;
  cursor: pointer;
  outline: none;
}

.fd-select-arrow {
  position: absolute;
  right: calc(40% + 12px);
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}

/* ── TOGGLE ── */
.fd-toggle-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 16px;
}

.fd-toggle {
  position: relative;
  width: 50px;
  height: 26px;
  flex-shrink: 0;
}

.fd-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.fd-toggle-slider {
  position: absolute;
  inset: 0;
  background: #ccc;
  border-radius: 26px;
  cursor: pointer;
  transition: background 0.2s;
}

.fd-toggle-slider::before {
  content: '';
  position: absolute;
  width: 20px;
  height: 20px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s;
}

.fd-toggle input:checked+.fd-toggle-slider {
  background: #3B1F8C;
}

.fd-toggle input:checked+.fd-toggle-slider::before {
  transform: translateX(24px);
}

.fd-toggle-label {
  font-size: 15px;
  color: #333;
  font-weight: 500;
}

/* ── CHECKBOXES ── */
.fd-checkbox-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 16px;
}

.fd-checkbox-item {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.fd-checkbox-item input[type="checkbox"] {
  display: none;
}

.fd-checkbox-box {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: #EDEDF8;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.fd-checkbox-item input:checked~.fd-checkbox-box {
  background: #3B1F8C;
}

.fd-checkbox-item input:checked~.fd-checkbox-box::after {
  content: '✓';
  color: #fff;
  font-size: 13px;
  font-weight: 700;
}

.fd-checkbox-label {
  font-size: 14px;
  color: #333;
  font-weight: 500;
}

/* ── FOOTER ── */
.fd-footer {
  flex-shrink: 0;
  display: flex;
  gap: 12px;
  padding: 16px 24px;
  border-top: 1px solid #eee;
}

.fd-btn-cancel {
  flex: 1;
  padding: 14px;
  border: 1.5px solid #ccc;
  border-radius: 100px;
  background: #fff;
  color: #333;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
}

.fd-btn-cancel:hover {
  border-color: #3B1F8C;
}

.fd-btn-apply {
  flex: 1;
  padding: 14px;
  border: none;
  border-radius: 100px;
  background: #3B1F8C;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
}

.fd-btn-apply:hover {
  background: #2d1670;
}

.filter-btn {
  margin-left: auto;
}

#fdTrigger {
  text-decoration: underline;
  color: #DC2328
}

#mainNav.scrolled .mega-menu {
  /* margin-top: -10px; */
}



@media (min-width: 1550px) {
  .placeholder-card {
    width: 99%;
    aspect-ratio: 1;
  }

  .mega-menu {
    padding: 50px 10%;
  }

  #reasons {
    padding: 40px 0 20px 0;
    background: #fff;
  }
}

@media (min-width:993px) and (max-width:1300px) {
 
  .postcode-pill {
    padding: 8px;
    gap: 5px;
  }

  .postcode-text {
    color: #554343;
    font-size: 10px;
    font-style: normal;
    font-weight: 500;
    line-height: normal;
  }

  .nav-icons {
    padding-left: 20px;
  }

  .footer-column ul li a,
  .footer-column p {
    font-size: 12px;

    line-height: 24px;
  }

  .footer-contact-num {
    font-size: 20px;
    line-height: 29px;
    margin-bottom: .25rem;
  }

}


@media (min-width:993px) and (max-width:1440px) {
  .scroll-left {
    left: 2%
  }

  .scroll-right {
    right: 2%;
  }
}

.lightbox-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  z-index: 10000;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.lightbox-overlay.active {
  display: flex;
}

.lightbox-track-wrapper {
  width: 560px;
  max-width: 90vw;
  overflow: hidden;
}

.lightbox-track {
  display: flex;
  transition: transform 0.4s ease;
}

.lightbox-track img {
  min-width: 560px;
  max-width: 1vw;
  max-height: 70vh;
  object-fit: contain;
  border-radius: 12px;
}

/* Prev / Next buttons */
.lightbox-prev,
.lightbox-next {
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  background: white;
  border: none;
  border-radius: 50%;
  width: 44px;
  height: 44px;
  font-size: 16px;
  cursor: pointer;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lightbox-prev {
  left: 24px;
}

.lightbox-next {
  right: 24px;
}

/* Close button */
.lightbox-close {
  position: fixed;
  top: 20px;
  right: 24px;
  background: white;
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  font-size: 16px;
  cursor: pointer;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Dots */
.lightbox-dots {
  display: flex;
  gap: 8px;
  margin-top: 16px;
}

.lightbox-dots span {
  width: 32px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.3);
  cursor: pointer;
  transition: background 0.3s;
}

.lightbox-dots span.active {
  background: #7c3aed;
  width: 48px;
}

.lightbox-zoom-wrap {
  min-width: 560px;
  max-width: 90vw;
  overflow: hidden;
  border-radius: 12px;
  cursor: pointer;
  flex-shrink: 0;
}

.lightbox-zoom-wrap img {
  width: 100%;
  max-height: 70vh;
  object-fit: contain;
  display: block;
  transition: transform 0.15s ease;
  transform-origin: 50% 50%;
}

.lightbox-zoom-wrap:hover {
  cursor: zoom-out;
}

.postcode-popup {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-20px);
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s;
}

.postcode-popup.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.postcode-popup-inner {
  align-items: center;
  justify-content: center;
  gap: 12px;
  background: #E2E4FF;
  color: #fff;
  min-height: 400px;
  padding: 6%;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 500;
  position: relative;
  box-shadow: 0 4px 20px rgba(226, 228, 255, 100);
}

.postcode-popup-close {
  display: flex;
  justify-content: flex-end;
  margin-left: auto;
  margin-bottom: 10px;
}

.postcode-input-wrapper {
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 100px;
  padding: 14px 20px;
  gap: 12px;
  max-width: 800px;
  margin: 0 auto 23px;
}

.postcode-input {
  flex: 1;
  border: none;
  outline: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  color: #333;
  background: transparent;
}

.postcode-input::placeholder {
  color: #bbb;
}

.postcode-icon {
  flex-shrink: 0;
  color: #999;
}

/* Overlay */
.nav-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 9998;
}

.nav-overlay.active {
  display: block;
}

/* Drawer wrapper — clips the sliding panels */
.nav-drawer {
  position: fixed;
  top: 0;
  left: 0px;
  width: 100%;
  height: 100dvh;
  z-index: 9999;  
  overflow: hidden;
  transform: translateY(-100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.13);
  padding-top: 70px;  
}

.nav-drawer.open {
 transform: translateY(0);
}

/* Each panel sits inside the drawer */
.drawer-panel {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #FEE8D5;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overflow-y: auto;
}

/* Secondary panels start off-screen to the right */
.drawer-panel--secondary {
  transform: translateX(100%);
}

/* Active panel slides into view */
.drawer-panel.active {
  transform: translateX(0);
}

/* Previous panel slides left when a child is active */
.drawer-panel.slide-left {
  transform: translateX(-30%);
}

/* Header */
.drawer-header {
  display: flex;
  align-items: center;
  justify-content: start;
  padding: 0.875rem 1rem;
  border-bottom: 1px solid #f0ece7;
  flex-shrink: 0;
  gap: 0rem;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.drawer-brand {
  color: #DC2328;
font-size: 26px;
font-style: normal;
font-weight: 700;
}

.drawer-panel-title {
color: #554343;
font-family: "DM Sans";
font-size: 28px;
font-style: normal;
font-weight: 700;
text-align: left;
padding-left: 15px;
}

.drawer-back {
  background: none;
  border: none;
  font-size: 25px;
  font-weight: 700;
  color: #DC2328;
  cursor: pointer;
  padding: 4px 0;
  white-space: nowrap;
}

.drawer-back:hover {
  opacity: 0.75;
}

.drawer-close {
  background: none;
  border: none;
  font-size: 1.2rem;
  color: #888;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 4px;
  line-height: 1;
  flex-shrink: 0;
}

.drawer-close:hover {
  background: #f5f0eb;
  color: #333;
}

/* Nav items */
.drawer-nav {
  list-style: none;
  padding: 0.4rem 0;
  margin: 0;
  background: #FEE8D5;
}

.drawer-nav>li>a,
.drawer-nav>li>span.has-sub {
  display: flex;
  gap:30px;
  align-items: center;
  padding: 0.5rem 1.25rem;
  text-decoration: none;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
    color: #554343;
  font-size: 24px !important;
  font-style: normal;
  font-weight: 700;
}

.drawer-nav>li>a:hover,
.drawer-nav>li>span.has-sub:hover {
  color: #DC2328;
  background: #fdf8f8;
}

/* Divider label inside nav */
.drawer-divider {
  padding: 0.6rem 1.25rem 0.4rem;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #DC2328;
  background: #faf8f6;
  border-bottom: 1px solid #f0ece7;
}

.chevron {
  font-style: normal;
    color: #554343;
font-size: 18px;
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-text);
  background: #fff;
  overflow-x: hidden;
  margin: 0;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  color: inherit;
}

.au-hero {
  background: #F0F6FF;
  min-height: 180px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  padding: 32px 16px;
  box-sizing: border-box;
}

.au-hero__title {
  font-size: 24px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.3;
  margin: 0 0 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.au-hero__sub {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  margin: 0;
}


/* =============================================
   480px — Small phones landscape
============================================= */
@media (min-width: 480px) {
  .au-hero {
    min-height: 200px;
    padding: 36px 20px;
  }

  .au-hero__title {
    font-size: 28px;
  }
}


/* =============================================
   768px — Tablet
============================================= */
@media (min-width: 768px) {
  .au-hero {
    min-height: 220px;
    padding: 40px 24px;
  }

  .au-hero__title {
    font-size: 34px;
    margin: 0 0 10px;
  }

  .au-hero__sub {
    font-size: 15px;
  }
}


/* =============================================
   1024px — Laptop / original desktop values
============================================= */
@media (min-width: 1024px) {
  .au-hero {
    min-height: 250px;
    padding: 48px 24px;
  }

  .au-hero__title {
    font-size: 40px;
    line-height: 55px;
  }

  .au-hero__sub {
    font-size: 16px;
  }
}


/* ══════════════════════════════════════════
   IMAGE PLACEHOLDER
══════════════════════════════════════════ */
.au-img-placeholder {
  background: var(--cb-grey);
  border-radius: 10px;
  width: 100%;
  aspect-ratio: 500 / 480;
  min-height: 180px;
  box-sizing: border-box;
  overflow: hidden;
}

.au-img-placeholder img {
  border-radius: 10px;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media (min-width: 480px) {
  .au-img-placeholder {
    min-height: 200px;
  }
}

@media (min-width: 768px) {
  .au-img-placeholder {
    min-height: 220px;
  }
}


/* ══════════════════════════════════════════
   STORY SECTION
══════════════════════════════════════════ */
.au-story {
  padding: 40px 0;
}

.au-story__intro {
  font-size: 18px;
  font-weight: 200;
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-navy);
  line-height: normal;
  margin-bottom: 20px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.au-story__body {
  font-size: 13px;
  font-weight: 500;
  color: #50547C;
  line-height: 1.6;
  margin: 0;
}

@media (min-width: 480px) {
  .au-story__intro {
    font-size: 20px;
  }
}

@media (min-width: 768px) {
  .au-story {
    padding: 56px 0;
  }

  .au-story__intro {
    font-size: 26px;
    margin-bottom: 24px;
  }

  .au-story__body {
    font-size: 15px;
    line-height: 24px;
  }
}

@media (min-width: 1024px) {
  .au-story {
    padding: 72px 50px;
  }

  .au-story__intro {
    font-size: 32px;
    margin-bottom: 28px;
  }

  .au-story__body {
    font-size: 16px;
  }
}


/* ══════════════════════════════════════════
   CELEBRATE SECTION
══════════════════════════════════════════ */
.au-celebrate {
  background: var(--cb-blue);
  padding: 40px 0;
}

.au-celebrate__title {
  font-size: 24px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.3;
  margin-bottom: 16px;
  max-width: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.au-celebrate__body {
  font-size: 13px;
  font-weight: 500;
  color: var(--cb-navy);
  line-height: 1.6;
  margin: 0;
}

.au-celebrate__card {
  background: #fff;
  border-radius: 10px;
  min-height: auto;
  padding: 24px 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 16px;
  margin-top: 32px;
  box-sizing: border-box;
}

.au-celebrate__card-heading {
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-navy);
  margin: 0 0 6px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.au-celebrate__card-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 12px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--cb-border);
}

.au-celebrate__card-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.au-celebrate__card-icon {
  width: 38px;
  height: 38px;
  min-width: 38px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  background: var(--cb-blue);
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: var(--cb-navy);
  font-size: 16px;
}

.au-celebrate__card-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--cb-red);
  margin: 0 0 3px;
}

.au-celebrate__card-val {
  font-size: 13px;
  font-weight: 500;
  color: var(--cb-navy);
  margin: 0;
  line-height: 1.5;
}

@media (min-width: 480px) {
  .au-celebrate__title {
    font-size: 28px;
  }

  .au-celebrate__card {
    padding: 28px 24px;
    gap: 20px;
  }
}

@media (min-width: 768px) {
  .au-celebrate {
    padding: 56px 0;
  }

  .au-celebrate__title {
    font-size: 34px;
    margin-bottom: 20px;
    max-width: 501px;
  }

  .au-celebrate__body {
    font-size: 15px;
    line-height: 26px;
  }

  .au-celebrate__card {
    padding: 32px 28px;
    margin-top: 0;
  }

  .au-celebrate__card-heading {
    font-size: 17px;
    margin: 0 0 8px;
  }

  .au-celebrate__card-item {
    gap: 16px;
    padding-bottom: 20px;
  }

  .au-celebrate__card-icon {
    width: 44px;
    height: 44px;
    min-width: 44px;
    font-size: 18px;
  }

  .au-celebrate__card-label {
    font-size: 13px;
  }

  .au-celebrate__card-val {
    font-size: 14px;
    line-height: 22px;
  }
}

@media (min-width: 1024px) {
  .au-celebrate {
    padding: 72px 50px;
  }

  .au-celebrate__title {
    font-size: 40px;
    line-height: 42px;
    margin-bottom: 24px;
  }

  .au-celebrate__body {
    font-size: 16px;
    line-height: 28px;
  }

  .au-celebrate__card {
    min-height: 604px;
    padding: 40px 36px;
    gap: 24px;
  }

  .au-celebrate__card-heading {
    font-size: 18px;
  }

  .au-celebrate__card-val {
    font-size: 15px;
  }
}


/* ══════════════════════════════════════════
   SERVICES SECTION
══════════════════════════════════════════ */
.au-services {
  padding: 40px 0;
}

.au-services__title {
  font-size: 24px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.3;
  margin-bottom: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.au-services__body {
  font-size: 13px;
  font-weight: 500;
  color: #50547C;
  line-height: 1.6;
}

.au-services__body p {
  margin-bottom: 14px;
}

.au-services__body p:last-child {
  margin-bottom: 0;
}

@media (min-width: 480px) {
  .au-services__title {
    font-size: 28px;
  }
}

@media (min-width: 768px) {
  .au-services {
    padding: 56px 0;
  }

  .au-services__title {
    font-size: 34px;
    margin-bottom: 20px;
  }

  .au-services__body {
    font-size: 15px;
    line-height: 24px;
  }

  .au-services__body p {
    margin-bottom: 16px;
  }
}

@media (min-width: 1024px) {
  .au-services {
    padding: 72px 50px;
  }

  .au-services__title {
    font-size: 40px;
    line-height: 42px;
    margin-bottom: 24px;
  }

  .au-services__body {
    font-size: 16px;
  }
}


/* ══════════════════════════════════════════
   CTA SECTION
══════════════════════════════════════════ */
.au-cta {
  background: #FEE8D580;
  min-height: auto;
  padding: 36px 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
}

.au-cta__heading {
  font-size: 18px;
  font-weight: 400;
  color: var(--cb-navy);
  line-height: 1.4;
  margin: 0 0 6px;
  max-width: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.au-cta__hours {
  font-size: 13px;
  font-weight: 500;
  color: var(--cb-text);
  margin: 0 0 20px;
}

.au-cta__contacts {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 20px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.au-cta__contact-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: center;
  justify-content: center;
  gap: 12px;
}

.au-cta__contact-icon {
  width: 40px;
  height: 32px;
  min-width: 40px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: var(--cb-navy);
  font-size: 18px;
}

.au-cta__contact-label {
  font-size: 13px;
  font-weight: 500;
  color: var(--cb-red);
  margin: 0 0 3px;
  line-height: 1.5;
}

.au-cta__contact-value {
  font-size: 16px;
  font-weight: 500;
  color: var(--cb-navy);
  margin: 0;
  line-height: 1.4;
}

a.au-cta__contact-value {
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: color .2s;
  transition: color .2s;
  text-decoration: none;
}

a.au-cta__contact-value:hover {
  color: var(--cb-red);
}

@media (min-width: 480px) {
  .au-cta {
    padding: 40px 20px;
  }

  .au-cta__heading {
    font-size: 20px;
  }
}

@media (min-width: 600px) {
  .au-cta__contacts {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    gap: 40px;
  }
}

@media (min-width: 768px) {
  .au-cta {
    min-height: 200px;
    padding: 44px 24px;
  }

  .au-cta__heading {
    font-size: 22px;
    margin: 0 0 8px;
    max-width: 774px;
  }

  .au-cta__hours {
    font-size: 15px;
    margin: 0 0 24px;
  }

  .au-cta__contact-item {
    gap: 14px;
  }

  .au-cta__contact-icon {
    width: 45px;
    height: 35px;
    min-width: 45px;
    font-size: 20px;
  }

  .au-cta__contact-label {
    font-size: 15px;
    text-align: left;
    line-height: 24px;
  }

  .au-cta__contact-value {
    font-size: 18px;
    line-height: 28px;
  }
}

@media (min-width: 1024px) {
  .au-cta {
    min-height: 250px;
    padding: 52px 24px;
  }

  .au-cta__heading {
    font-size: 24px;
    line-height: 42px;
  }

  .au-cta__hours {
    font-size: 16px;
    margin: 0 0 28px;
  }

  .au-cta__contacts {
    gap: 80px;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .au-cta__contact-label {
    font-size: 16px;
    text-align: left;
  }

  .au-cta__contact-value {
    font-size: 20px;
  }
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-text);
  background: #fff;
  overflow-x: hidden;
  margin: 0;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  color: inherit;
}

.franchise-hero {
  background: #F0F6FF;
  padding: 40px 16px 60px;
  text-align: center;
  position: relative;
}

@media (min-width: 768px) {
  .franchise-hero {
    padding: 60px 20px 90px;
  }
}

@media (min-width: 1024px) {
  .franchise-hero {
    padding: 39.5px 20px 60px;
  }
}

.hero-inner {
  max-width: 1200px;
  margin: auto;
}

.hero-img-col img {
  width: 100%;
  max-width: 500px;
  margin: auto;
  display: block;
}

.hero-join-label {
  letter-spacing: 4px;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--cb-navy);
  margin-bottom: 8px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .hero-join-label {
    letter-spacing: 6px;
    font-size: 14px;
  }
}

@media (min-width: 768px) {
  .hero-join-label {
    font-size: 16px;
  }
}

.hero-heading {
  font-size: 26px;
  font-weight: 700;
  color: var(--cb-navy);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .hero-heading {
    font-size: 30px;
  }
}

@media (min-width: 768px) {
  .hero-heading {
    font-size: 36px;
  }
}

@media (min-width: 1024px) {
  .hero-heading {
    font-size: 40px;
  }
}

.hero-sub {
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-link);
  margin-top: 8px;
}

@media (min-width: 768px) {
  .hero-sub {
    font-size: 16px;
    margin-top: 10px;
  }
}

/* ═══════════════════════════════════════════
   FRANCHISE NAV PILL
═══════════════════════════════════════════ */
.franchise-nav {
  position: relative;
  margin-top: -28px;
  z-index: 10;
}

@media (min-width: 300px) and (max-width: 767px) {
  .franchise-nav {
    height: 130px;
    margin-top: -35px;
  }
}

@media (min-width: 769px) {
  .franchise-nav {
    margin-top: -35px;
  }
}

.franchise-nav-inner {
  max-width: 1200px;
  margin: auto;
  border-radius: 100px;
  border: 2px solid #FFE2E2;
  background: #FFF;
  box-shadow: 0 10px 4px 0 rgba(0, 0, 0, 0.10);
}

@media (min-width: 300px) and (max-width: 580px) {
  .franchise-nav-pill {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .franchise-nav-inner {
    width: auto;
  }

  .fnav-dropdown {
    width: 100%;
    /* max-width: 320px; */
    margin: 0 auto;
  }

  .select-wrapper {
    position: relative;
  }

  .fnav-select {
    width: 100%;
    padding: 0 30px;
    border-radius: 25px;
    border: 1.5px solid #e5bcbc;
    background-color: #FFF;
    color: #5E6570;
    font-family: "DM Sans";
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 55px;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    /* background: transparent; */
  }
  .fnav-select:focus {
    outline: none;
    box-shadow: none;
  }

  .fnav-select:focus-visible {
    outline: none;
  }

  /* Custom arrow */
  .select-wrapper::after {
    content: "" ;
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 15px;
    height: 8px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='11' viewBox='0 0 20 11' fill='none'><path fill-rule='evenodd' clip-rule='evenodd' d='M0.292192 0.366476C0.104594 0.56402 0 0.826048 0 1.09848C0 1.3709 0.104594 1.63293 0.292192 1.83048L8.55619 10.3935C8.73835 10.5852 8.9576 10.7378 9.20059 10.8421C9.44359 10.9464 9.70526 11.0002 9.96969 11.0002C10.2341 11.0002 10.4958 10.9464 10.7388 10.8421C10.9818 10.7378 11.201 10.5852 11.3832 10.3935L19.7082 1.76847C20.0932 1.36848 20.0982 0.720475 19.7182 0.314475C19.6277 0.216181 19.5179 0.137545 19.3957 0.0834514C19.2735 0.029358 19.1415 0.000960467 19.0079 0C18.8742 -0.000914445 18.7418 0.0256263 18.6189 0.0780002C18.496 0.130374 18.3851 0.207461 18.2932 0.304475L10.6762 8.19748C10.5851 8.29339 10.4755 8.36977 10.3539 8.42197C10.2324 8.47416 10.1015 8.50108 9.96919 8.50108C9.83691 8.50108 9.70602 8.47416 9.58448 8.42197C9.46293 8.36977 9.35328 8.29339 9.26219 8.19748L1.70519 0.367475C1.61419 0.271585 1.50462 0.195224 1.38316 0.143042C1.2617 0.0908594 1.13089 0.0639486 0.998691 0.0639486C0.866495 0.0639486 0.735682 0.0908594 0.614221 0.143042C0.492759 0.195224 0.383192 0.270586 0.292192 0.366476Z' fill='%235E6570'/></svg>");
    background-repeat: no-repeat;
    background-size: contain;
    pointer-events: none;
  }

}

@media (width: 768px) {
  .fnav-dropdown-toggle {
    padding: 12px 16px;
  }
}

@media (min-width: 582px) and (max-width: 991px) {
  .franchise-nav-pill {
    flex-direction: row;
    align-items: stretch;
    gap: 12px;
  }
  .fnav-dropdown {
    width: 100%;
    /* max-width: 320px; */
    margin: 0 auto;
  }

  .select-wrapper {
    position: relative;
  }

  .fnav-select {
    width: 100%;
    padding: 0 30px;
    border: none;
    margin-left: 10px;
    color: #5E6570;
    font-family: "DM Sans";
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    line-height: 55px;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    background: transparent;
  }
  .fnav-select:focus {
    outline: none;
    box-shadow: none;
  }

  .fnav-select:focus-visible {
    outline: none;
  }
  .select-wrapper::after {
    content: "" ;
    position: absolute;
    right: 16px;
    top: 50%;
    transform: translateY(-50%);
    width: 20px;
    height: 11px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='11' viewBox='0 0 20 11' fill='none'><path fill-rule='evenodd' clip-rule='evenodd' d='M0.292192 0.366476C0.104594 0.56402 0 0.826048 0 1.09848C0 1.3709 0.104594 1.63293 0.292192 1.83048L8.55619 10.3935C8.73835 10.5852 8.9576 10.7378 9.20059 10.8421C9.44359 10.9464 9.70526 11.0002 9.96969 11.0002C10.2341 11.0002 10.4958 10.9464 10.7388 10.8421C10.9818 10.7378 11.201 10.5852 11.3832 10.3935L19.7082 1.76847C20.0932 1.36848 20.0982 0.720475 19.7182 0.314475C19.6277 0.216181 19.5179 0.137545 19.3957 0.0834514C19.2735 0.029358 19.1415 0.000960467 19.0079 0C18.8742 -0.000914445 18.7418 0.0256263 18.6189 0.0780002C18.496 0.130374 18.3851 0.207461 18.2932 0.304475L10.6762 8.19748C10.5851 8.29339 10.4755 8.36977 10.3539 8.42197C10.2324 8.47416 10.1015 8.50108 9.96919 8.50108C9.83691 8.50108 9.70602 8.47416 9.58448 8.42197C9.46293 8.36977 9.35328 8.29339 9.26219 8.19748L1.70519 0.367475C1.61419 0.271585 1.50462 0.195224 1.38316 0.143042C1.2617 0.0908594 1.13089 0.0639486 0.998691 0.0639486C0.866495 0.0639486 0.735682 0.0908594 0.614221 0.143042C0.492759 0.195224 0.383192 0.270586 0.292192 0.366476Z' fill='%235E6570'/></svg>");
    background-repeat: no-repeat;
    background-size: contain;
    pointer-events: none;
    /* font-size: 20px;
    color: #666;
    pointer-events: none; */
  }

}

@media (min-width: 992px) {
  .fnav-dropdown {
    display: none;
  }

  .fnav-dropdown.active {
    display: block;
  }
}

.franchise-nav-pill {
  background: white;
  border-radius: 60px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  /* padding: 10px 16px; */
  box-shadow: 0 10px 30px rgba(0, 0, 0, .15);
}

@media (min-width: 769px) {
  .franchise-nav-pill {
    padding: 0 0 0 40px;

  }
}

@media (min-width: 300px) and (max-width: 540px) {
  .franchise-nav-pill {
    padding: 0px;
    height: 50px;

  }
}

.fnav-links {
  display: none;
  align-items: center;
  /* gap: 14px; */
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
}

@media (min-width: 992px) {
  .fnav-links {
    display: flex;
    text-align: center;
  }
}

.fnav-links a {
  text-decoration: none;
  padding: 20px;
  color: #5E6570;
  font-family: DM Sans;
  font-size: 16px;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .fnav-links a {
    font-size: 16px;
    text-align: center;
  }
}

.btn-apply-now {
  background: #DC2328;
  border: none;
  color: white;
  width: 265px;
  height: 80px;
  padding: 10px 40px;
  border-radius: 40px;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  white-space: nowrap;
  transition: background 0.2s ease;
}

@media (max-width: 767px) {
  .btn-apply-now {
    padding: 12px 24px;
    font-size: 20px;
    height: 50px;
    width: 100%;
  }
}

@media (width: 768px) {
  .btn-apply-now {
    padding: 12px 24px;
    font-size: 20px;
    /* width: 100%; */
  }
}

@media (min-width: 992px) and (min-width: 1024px) {
  .btn-apply-now {
    font-size: 24px;
    padding: 12px 28px;
  }
}

.btn-apply-now:hover {
  background: #c01e22;
}

/* ═══════════════════════════════════════════
   STATS BAR
═══════════════════════════════════════════ */
.stats-bar {
  background: #fff;
  padding: 24px 16px;
}

@media (min-width: 768px) {
  .stats-bar {
    padding: 50px 20px 30px;
  }
}

.stats-inner {
  max-width: 1200px;
  margin: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

@media (max-width: 767px) {

  /* .stats-inner {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  } */
  .stats-inner {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
    /* IMPORTANT: remove gap */
    /* border-top: 2px solid rgba(135, 138, 170, 0.20);
    border-left: 2px solid rgba(135, 138, 170, 0.20); */
  }

  .stat-item {
    padding: 20px 10px;
    text-align: left;
    border-right: 1px solid rgba(135, 138, 170, 0.20);
    border-bottom: 1px solid rgba(135, 138, 170, 0.20);
  }

  /* Remove extra borders on edges */
  .stat-item:nth-child(2n) {
    border-right: none;
    /* last column */
  }

  .stat-item:nth-last-child(-n+2) {
    border-bottom: none;
    /* last row */
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .stats-inner {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    padding: 0 50px;
    gap: 0;
  }

  .stat-item {
    padding: 20px 10px;
    text-align: left;
    border-right: 1px solid rgba(135, 138, 170, 0.20);
    border-bottom: 1px solid rgba(135, 138, 170, 0.20);
  }

  /* Remove extra borders on edges */
  .stat-item:nth-child(2n) {
    border-right: none;
    /* last column */
  }

  .stat-item:nth-last-child(-n+2) {
    border-bottom: none;
    /* last row */
  }
}

@media (min-width: 992px) {
  .stats-inner {
    grid-template-columns: repeat(4, 1fr);
  }
}

.stat-item {
  display: flex;
  align-items: center;
  height: 95px;
  gap: 33px;
  padding-right: 0;
}

@media (min-width:300px) and (max-width: 767px) {
  .stat-item {
    display: flex;
    gap: 20px;
    align-items: center;
    /* padding: 0 20px; */
  }

  .stat-item img,
  .stat-item svg {
    width: 35px;
    height: 35px;
  }

  .stat-item .stat-value,
  .stat-item .stat-label {
    font-size: 12px;
  }
}

@media (min-width:768px) and (max-width: 991px) {
  .stat-item {
    align-items: center;
  }
}

@media (min-width: 992px) {
  .stat-item {
    border-right: 2px solid rgba(135, 138, 170, 0.20);
    ;
    gap: 33px;
  }

  .stat-item:last-child {
    border-right: none;
  }
}

.stat-item img,
.stat-item svg {
  /* width: 60px;
  height: 60px; */
  flex-shrink: 0;
}

/* @media (min-width:300px) and (max-width: 767px) {
  .stat-item .star-icon img,
  .stat-item .star-icon svg {
    width: 35px;
    height: 35px;
  }
} */
@media (min-width: 768px) {

  .stat-item img,
  .stat-item svg {
    width: 75px;
    height: 75px;
  }
}

@media (min-width: 1024px) {

  .stat-item img,
  .stat-item svg {
    width: 87px;
    height: 87px;
  }
}

.stat-value {
  font-size: 16px;
  font-weight: 700;
  color: #e6292a;
}

@media (min-width: 768px) {
  .stat-value {
    font-size: 18px;
  }
}

@media (min-width: 1024px) {
  .stat-value {
    font-size: 20px;
  }
}

.stat-label {
  font-size: 16px;
  color: var(--cb-navy);
  font-weight: 700;
}

@media (min-width: 1024px) {
  .stat-label {
    font-size: 20px;
  }
}

/* ═══════════════════════════════════════════
   SECTION BASE
═══════════════════════════════════════════ */
.section-wrap {
  padding: 30px 0;
}

@media (min-width: 768px) {
  .section-wrap {
    padding: 20px 0;
  }
}

@media (min-width: 1024px) {
  .section-wrap {
    padding: 80px 0;
  }
}

.section-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 16px;
}

@media (min-width: 480px) {
  .section-inner {
    padding: 0 20px;
  }
}

@media (min-width: 1024px) {
  .section-inner {
    padding: 0 24px;
  }
}

.section-heading {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  color: var(--cb-navy);
  line-height: 1.3;
  /* margin-bottom: 10px; */
  font-variation-settings: 'opsz' 14;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .section-heading {
    font-size: 28px;
  }
}

@media (min-width: 768px) {
  .section-heading {
    font-size: 34px;
    margin-bottom: 12px;
  }
}

@media (min-width: 1024px) {
  .section-heading {
    font-size: 40px;
  }
}

.section-sub {
  font-size: 24px;
  font-weight: 200;
  text-align: center;
  color: var(--cb-red);
  font-family: DM Sans;
  margin: 0;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .section-sub {
    font-size: 32px;
    text-align: center;
  }
}

@media (min-width: 1024px) {
  .section-sub {
    font-size: 40px;
    text-align: center;
  }
}

.fnav-sep {
  width: 1440px;
  height: 1px;
  background: #DEDEDE;
}

/* ═══════════════════════════════════════════
   WHY CAKES & BAKES
═══════════════════════════════════════════ */
.why-cb-section {
  background: #fff;
}

.why-cb-inner {
  max-width: 1320px;
  /* height: 500px; */
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 72px;
}

@media (min-width: 480px) {
  .why-cb-inner {
    padding: 30px 30px;
  }
}

@media (min-width: 992px) {
  .why-cb-inner {
    flex-direction: row;
    align-items: center;
    gap: 50px;
    padding: 0 80px;
  }
}

.why-cb-img-card {
  flex: none;
  width: 100%;
  background: var(--cb-lav);
  border-radius: 16px;
  overflow: hidden;
  height: 220px;
  position: relative;
}

@media (min-width: 480px) {
  .why-cb-img-card {
    height: 260px;
  }
}

@media (min-width: 768px) {
  .why-cb-img-card {
    height: 300px;
    border-radius: 20px;
  }
}

@media (min-width: 992px) {
  .why-cb-img-card {
    flex: 0 0 360px;
    max-width: 360px;
    height: 360px;
  }
}

@media (min-width: 1200px) {
  .why-cb-img-card {
    flex: 0 0 500px;
    max-width: 500px;
    height: 400px;
  }
}

.why-cb-img-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.why-cb-text {
  flex: 1;
}

.why-cb-text .section-sub {
  margin-bottom: 16px;
  text-align: center;
}

@media (min-width: 768px) {
  .why-cb-text .section-sub {
    margin-bottom: 20px;
  }
}

.why-cb-body {
  font-size: 14px;
  font-weight: 500;
  color: var(--cb-body);
  line-height: 1.75;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .why-cb-body {
    font-size: 16px;
    padding: 0 30px;
  }
}

/* ═══════════════════════════════════════════
   WHY FRANCHISE
═══════════════════════════════════════════ */
.why-franchise-section {
  background: #FEF2F1;
}

.why-franchise-watermark {
  position: absolute;
  /* left: -250px; */
  margin-top: 50px;
  width: 484px;
  height: 485px;
}

.why-franchise-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 16px;
}

@media (min-width: 480px) {
  .why-franchise-inner {
    padding: 0 20px;
  }
}

@media (min-width: 1024px) {
  .why-franchise-inner {
    padding: 0 24px;
  }
}

.why-franchise-top {
  display: flex;
  flex-direction: column;
  gap: 32px;
  margin-bottom: 32px;
}

@media (min-width: 992px) {
  .why-franchise-top {
    flex-direction: row;
    gap: 60px;
    margin-bottom: 40px;
    align-items: center;
  }
}

.why-franchise-left {
  flex: none;
  text-align: center;
  width: 100%;
}

@media (min-width: 992px) {
  .why-franchise-left {
    text-align: center;
    max-width: 420px;
    flex: 0 0 420px;
  }
}

.franchise-brand-icon {
  display: inline-flex;
  width: 80px;
  height: 80px;
  margin-bottom: 12px;
  align-items: center;
}

@media (min-width: 768px) {
  .franchise-brand-icon {
    width: 100px;
    height: 100px;
  }
}

@media (min-width: 1024px) {
  .franchise-brand-icon {
    width: 115px;
    height: 115px;
    margin-bottom: 16px;
  }
}

.franchise-brand-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.why-franchise-left .section-heading {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
}

@media (min-width: 480px) {
  .why-franchise-left .section-heading {
    font-size: 28px;
  }
}

@media (min-width: 992px) {
  .why-franchise-left .section-heading {
    font-size: 34px;
    line-height: 39px;
    text-align: center;
  }
}

@media (min-width: 1024px) {
  .why-franchise-left .section-heading {
    font-size: 40px;
  }
}

.why-franchise-left .why-fr-sub {
  font-size: 14px;
  font-weight: 500;
  color: #3b3e5c;
  text-align: center;
  line-height: 1.65;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .why-franchise-left .why-fr-sub {
    font-size: 15px;
  }
}

@media (min-width: 992px) {
  .why-franchise-left .why-fr-sub {
    font-size: 16px;
    padding: 0 50px;
    text-align: center;
  }
}

/* 2x2 Q&A cards */
.faq-cards-grid {
  flex: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 600px) {
  .faq-cards-grid {
    grid-template-columns: 1fr 1fr;
    gap: 20px;
  }
}

.faq-card-1 {
  background: #fff;
  border-radius: 20px;
  width: 100%;
  max-width: 400px;
  height: 360px;
  padding: 20px 38px;
}
.faq-card-colour{
  background-color: #FFC5C5;
}
.faq-card-colour-1{
  background-color: #DADDFF;
}

@media (min-width:300px) and (max-width: 767px) {
  .faq-card-1 {
    height: fit-content;
    border-radius: 20px;
    padding: 28px 38px;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .faq-card-1 {
    height: 100%;
    border-radius: 20px;
    padding: 28px 38px;
  }
}

@media (min-width: 992px) {
  .faq-card-1 {
    height: 100%;
    border-radius: 20px;
    padding: 28px 38px;
  }
}


.faq-card-q {
  font-size: 18px;
  font-weight: 700;
  color: white;
  margin-bottom: 10px;
  line-height: 1.25;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .faq-card-q {
    font-size: 22px;
    margin-bottom: 14px;
  }
}

@media (min-width: 1024px) {
  .faq-card-q {
    font-size: 24px;
  }
}

.faq-card-a {
  font-size: 13px;
  font-weight: 500;
  color: white;
  line-height: 1.65;
  margin: 0;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .faq-card-a {
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .faq-card-a {
    font-size: 16px;
  }
}

/* ═══════════════════════════════════════════
   OUR FRANCHISES
═══════════════════════════════════════════ */
.franchises-section {
  background: #fff;
}

.franchise-row {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 48px;
  justify-content: center;
  margin-top: 32px;
}

@media (min-width: 768px) {
  .franchise-row {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 60px;
    margin-top: 40px;
  }
}

@media (min-width: 1200px) {
  .franchise-row {
    gap: 80px;
  }
}

.franchise-model {
  width: 100%;
  max-width: 460px;
  background: #fff;
  gap: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

@media (min-width: 480px) {
  .franchise-model {
    flex-direction: row;
    text-align: left;
    gap: 24px;
  }
}

@media (min-width: 768px) {
  .franchise-model {
    max-width: 520px;
    gap: 40px;
  }
}

.franchise-model-img {
  width: 160px;
  height: 275px;
  background: #d9d9d9;
  border-radius: 80px;
  overflow: hidden;
  flex-shrink: 0;
  margin: 0 auto;
}

@media (min-width: 480px) {
  .franchise-model-img {
    margin: 0;
  }
}

@media (min-width: 768px) {
  .franchise-model-img {
    width: 180px;
    height: 310px;
    border-radius: 90px;
  }
}

@media (min-width: 1024px) {
  .franchise-model-img {
    width: 213px;
    height: 366px;
    border-radius: 100px;
  }
}

.franchise-model-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.franchise-model-content {
  max-width: 100%;
}

@media (min-width: 768px) {
  .franchise-model-content {
    max-width: 320px;
  }
}

.franchise-model-name {
  font-size: 20px;
  font-weight: 700;
  color: var(--cb-navy);
  margin-bottom: 12px;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .franchise-model-name {
    font-size: 22px;
    margin-bottom: 14px;
  }
}

@media (min-width: 1024px) {
  .franchise-model-name {
    font-size: 24px;
    width: 299px;
    margin-bottom: 16px;
  }
}

.franchise-model-desc {
  font-size: 13px;
  font-weight: 500;
  color: #5b5e84;
  line-height: normal;
  margin-bottom: 20px;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .franchise-model-desc {
    font-size: 15px;
    margin-bottom: 28px;
  }
}

.btn-perfect-for {
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  height: 36px;
  padding: 0 20px;
  font-weight: 700;
  font-size: 13px;
  font-family: 'DM Sans', sans-serif;
  cursor: default;
  margin-bottom: 12px;
  font-variation-settings: 'opsz' 14;
  display: inline-block;
}

@media (min-width: 768px) {
  .btn-perfect-for {
    height: 40px;
    padding: 0 28px;
    font-size: 15px;
    margin-bottom: 14px;
  }
}

.franchise-locations {
  font-size: 13px;
  font-weight: 700;
  color: #5b5e84;
  line-height: 1.65;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .franchise-locations {
    font-size: 15px;
  }
}

.franchise-locations .sep {
  color: #d9d9d9;
  padding: 0 6px;
}

/* ═══════════════════════════════════════════
   THE OPPORTUNITY
═══════════════════════════════════════════ */
.opportunity-section {
  background: #E6F0FF99;
}

.opportunity-desc {
  font-size: 14px;
  font-weight: 300;
  color: #5b5e84;
  line-height: normal;
  max-width: 1220px;
  margin: 16px auto 28px;
  text-align: center;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .opportunity-desc {
    font-size: 15px;
    margin: 20px auto 36px;
  }
}

@media (min-width: 1024px) {
  .opportunity-desc {
    font-size: 24px;
    margin: 20px auto 60px;
  }
}

.opportunity-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}

@media (min-width: 600px) {
  .opportunity-cards {
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
  }
}

@media (min-width: 1200px) {
  .opportunity-cards {
    grid-template-columns: repeat(4, 1fr);
    padding-bottom: 20px;
  }
}

.opp-card {
  background: #fff;
  border-radius: 10px;
  padding: 22px 18px 26px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.opp-card-1{
  background-color: #FFC5C5;
}

.opp-card-2{
  background-color: #FAD4BA;
}

.opp-card-3{
  background-color: #C5DBC4;
}

.opp-card-colour-1{
  background-color: #DADDFF;
}

@media (min-width: 768px) {
  .opp-card {
    padding: 40px 35px 32px;
  }
}

.opp-card-title {
  font-size: 20px;
  font-weight: 700;
  color: white;
  margin-bottom: 14px;
  line-height: normal;
}

@media (min-width: 768px) {
  .opp-card-title {
    font-size: 22px;
    margin-bottom: 18px;
  }
}

@media (min-width: 1024px) {
  .opp-card-title {
    font-size: 24px;
  }
}

.opp-card-body {
  font-size: 13px;
  font-weight: 500;
  color: white;
  line-height: normal;
  margin: 0;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .opp-card-body {
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .opp-card-body {
    font-size: 16px;
  }
}

/* ═══════════════════════════════════════════
   FRANCHISE BENEFITS
═══════════════════════════════════════════ */
.benefits-section {
  background: #fff;
}

.benefits-head {
  text-align: center;
  margin-bottom: 36px;
}

@media (min-width: 768px) {
  .benefits-head {
    margin-bottom: 48px;
  }
}

@media (min-width: 1024px) {
  .benefits-head {
    margin-bottom: 56px;
  }
}

.benefits-head .section-heading {
  display: inline-block;
}

.benefits-sub {
  font-size: 24px;
  font-weight: 300;
  color: #5b5e84;
  line-height: 1.7;
  max-width: 1100px;
  margin: 16px auto 0;
  font-variation-settings: 'opsz' 14;
}

.benefits-sub strong {
  font-weight: 700;
}

@media (min-width: 300px) and (max-width: 767px) {

  .benefits-sub,
  .benefits-sub strong {
    font-size: 14px;
    /* margin: 20px auto 0; */
  }
}

@media (min-width: 768px) {

  .benefits-sub,
  .benefits-sub strong {
    font-size: 14px;
    margin: 20px auto 0;
  }
}

@media (min-width: 1024px) {

  .benefits-sub,
  .benefits-sub strong {
    font-size: 24px;
  }
}

/* Benefits grid with divider lines */
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  position: relative;
  border: 1px solid #D9D9D9;
}

@media (min-width: 768px) {
  .benefits-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (min-width: 768px) {
  .benefits-grid::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    height: 1px;
    background: #D9D9D9;
  }
}

.benefit-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 24px 16px;
  position: relative;
}

@media (min-width: 300px) and (max-width: 767px) {
  .benefit-item {
    padding: 28px 24px;
    border-right: 1px solid #D9D9D9;
    border-bottom: 1px solid #D9D9D9;
  }

  .stat-item:not(:nth-child(4n))::after {
    border-right: none;
    /* last column */
  }

  .stat-item:nth-child(odd)::after {
    border-bottom: none;
    /* last row */
  }
}

@media (min-width: 768px) {
  .benefit-item {
    padding: 36px 24px;
    border-right: 1px solid #D9D9D9;
    /* border-bottom: 1px solid #D9D9D9; */
  }
}

/* Vertical dividers on desktop (every 4th) */
/* @media (min-width: 768px) {
  .benefit-item:not(:nth-child(4n))::after {
    content: '';
    position: absolute;
    right: 0;
    top: 1px;
    height: 225px;
    width: 1px;
    background: #D9D9D9;
  }
}


@media (max-width: 767px) {
  .benefit-item:nth-child(odd)::after {
    content: '';
    position: absolute;
    right: 0;
    top: 10%;
    height: 80%;
    width: 1px;
    background: #D9D9D9;
  }
} */

.benefit-icon {
  width: 52px;
  height: 52px;
  margin-bottom: 14px;
}

@media (min-width: 768px) {
  .benefit-icon {
    width: 64px;
    height: 64px;
  }
}

@media (min-width: 1024px) {
  .benefit-icon {
    width: 72px;
    height: 72px;
    margin-bottom: 18px;
  }
}

.benefit-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.benefit-label {
  font-size: 13px;
  font-weight: 600;
  color: #50547c;
  line-height: normal;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 300px) and (max-width: 767px) {
  .benefit-label {
    font-size: 12px;
    padding: 10px 0 0px;
  }
}

@media (min-width: 768px) {
  .benefit-label {
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .benefit-label {
    font-size: 18px;
  }
}

.benefit-label.accent {
  color: var(--cb-red);
}

/* ═══════════════════════════════════════════
   FAQ ACCORDION
═══════════════════════════════════════════ */
.faqs-section {
  background: #FFE2E2;
}

.faqs-head {
  text-align: center;
  margin-bottom: 28px;
}

@media (min-width: 768px) {
  .faqs-head {
    margin-bottom: 40px;
  }
}

.faq-list {
  max-width: 862px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.faq-item {
  /* width: 861.44px; */
  padding: 10px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, .06);
  overflow: hidden;
}

.faq-btn {
  width: 100%;
  background: none;
  border: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  font-weight: 700;
  font-size: 15px;
  color: var(--cb-navy);
  text-align: left;
  cursor: pointer;
  gap: 12px;
  transition: color 0.2s ease;
  font-variation-settings: 'opsz' 14;
  -webkit-appearance: none;
  appearance: none;
}
@media (max-width: 580px) {
  .faq-btn {
    padding: 10px 19px;
    font-size: 13px;
    gap: 13px;
  }
}

@media (min-width: 768px) {
  .faq-btn {
    padding: 20px 28px;
    font-size: 15px;
    gap: 16px;
  }
}

@media (min-width: 1024px) {
  .faq-btn {
    padding: 22px 28px;
    font-size: 18px;
  }
}

.faq-btn:hover {
  color: var(--cb-red);
}

.faq-btn i {
  flex-shrink: 0;
  font-size: 13px;
  transition: transform .3s ease;
}

@media (min-width: 768px) {
  .faq-btn i {
    font-size: 14px;
  }
}

.faq-btn[aria-expanded="true"] i {
  transform: rotate(180deg);
}

.faq-answer {
  padding: 0 20px 16px;
  font-size: 13px;
  font-weight: 500;
  color: #5b5e84;
  line-height: 1.7;
  display: none;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .faq-answer {
    padding: 0 28px 20px;
    font-size: 14px;
  }
}

@media (min-width: 1024px) {
  .faq-answer {
    font-size: 15px;
  }
}

.faq-answer.open {
  display: block;
}

/* ═══════════════════════════════════════════
   CONTACT / ENQUIRIES
═══════════════════════════════════════════ */
.contact-section {
  background: #fff;
}

.contact-head {
  text-align: center;
  margin-bottom: 6px;
}

.contact-subtitle {
  text-align: center;
  font-size: 16px;
  font-weight: 500;
  color: var(--cb-red);
  margin-bottom: 28px;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .contact-subtitle {
    font-size: 18px;
    margin-bottom: 36px;
  }
}

@media (min-width: 1024px) {
  .contact-subtitle {
    font-size: 20px;
    margin-bottom: 40px;
  }
}

.contact-form-wrap {
  max-width: 900px;
  margin: 0 auto;
}

.form-row {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 14px;
}

@media (min-width: 600px) {
  .form-row {
    flex-direction: row;
    gap: 20px;
    margin-bottom: 16px;
  }
}

.form-field {
  flex: 1;
  display: flex;
  position: relative;
}

.floating-field label {
  position: absolute;
  left: 14px;
  top: 16px;
  font-size: 15px;
  font-weight: 400;
  color: var(--cb-navy);
  padding: 0 6px;
  transition: 0.25s ease;
  pointer-events: none;
}

@media (min-width: 768px) {
  .floating-field label {
    font-size: 18px;
  }
}

.form-input:focus+label,
.form-input:not(:placeholder-shown)+label,
.form-textarea:focus+label,
.form-textarea:not(:placeholder-shown)+label {
  top: -8px;
  left: 10px;
  font-size: 13px;
  font-weight: 300;
  color: var(--cb-navy);
  background: #fff;
}

@media (min-width: 768px) {

  .form-input:focus+label,
  .form-input:not(:placeholder-shown)+label,
  .form-textarea:focus+label,
  .form-textarea:not(:placeholder-shown)+label {
    font-size: 14px;
  }
}

.form-input {
  width: 100%;
  height: 52px;
  background: #fff;
  border: 1px solid #878aaa;
  border-radius: 10px;
  padding: 0 16px;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-navy);
  outline: none;
  transition: border-color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

@media (min-width: 768px) {
  .form-input {
    height: 58px;
    padding: 0 18px;
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .form-input {
    height: 60px;
    font-size: 16px;
  }
}

.form-input:focus {
  border-color: var(--cb-navy);
}

.form-input.error {
  border-color: var(--cb-red);
}

/* Radio row */
.franchise-type-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px;
  padding: 0 16px;
  min-height: 52px;
  background: #fff;
  border-radius: 10px;
}

@media (max-width: 480px) {
  .franchise-type-row {
    gap: 50px;
    padding: 0 0px;
    flex-wrap: nowrap;
    min-height: 0px;
    margin-bottom: 20px;
  }

  .search-tags {
    display: none;
  }

  .search-arrivals h3 {
    font-size: 20px;
  }

  .search-product-name {
    font-size: 14px;
    font-weight: 700;
    line-height: normal;
  }
}

.form-control:-webkit-autofill,
.form-control:-webkit-autofill:hover,
.form-control:-webkit-autofill:focus,
.form-control:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0px 1000px #ffffff inset !important;
  box-shadow: 0 0 0px 1000px #ffffff inset !important;
  -webkit-text-fill-color: #000 !important;
  background-color: #ffffff !important;
}

.form-input:-webkit-autofill,
.form-input:-webkit-autofill:hover,
.form-input:-webkit-autofill:focus,
.form-input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0px 1000px #ffffff inset !important;
  box-shadow: 0 0 0px 1000px #ffffff inset !important;
  -webkit-text-fill-color: #000 !important;
  background-color: #ffffff !important;
}


.franchise-type {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.franchise-type-row label {
  font-size: 15px;
  font-weight: 400;
  color: var(--cb-navy);
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-variation-settings: 'opsz' 14;
}

@media (min-width: 768px) {
  .franchise-type-row label {
    font-size: 18px;
  }
}

.franchise-type-row input[type="radio"] {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--cb-navy);
  flex-shrink: 0;
}

@media (min-width: 768px) {
  .franchise-type-row input[type="radio"] {
    width: 20px;
    height: 20px;
  }
}

.form-textarea {
  width: 100%;
  min-height: 120px;
  background: #fff;
  border: 1px solid #878aaa;
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-navy);
  outline: none;
  resize: vertical;
  transition: border-color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

@media (min-width: 768px) {
  .form-textarea {
    min-height: 140px;
    padding: 16px 18px;
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .form-textarea {
    min-height: 153px;
    font-size: 16px;
  }
}

.form-textarea:focus {
  border-color: var(--cb-navy);
}

.captcha-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  margin-top: 16px;
}

@media (min-width: 600px) {
  .captcha-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 20px;
  }
}

.captcha-img {
  height: 64px;
  border-radius: 6px;
}

@media (min-width: 768px) {
  .captcha-img {
    height: 80px;
  }
}

.btn-send-enquiry {
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  height: 52px;
  width: 100%;
  font-weight: 600;
  font-size: 16px;
  font-family: 'DM Sans', sans-serif;
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
  display: block;
  margin: 0 auto;
  font-variation-settings: 'opsz' 14;
  -webkit-appearance: none;
  appearance: none;
}

@media (min-width: 480px) {
  .btn-send-enquiry {
    width: 320px;
    font-size: 18px;
  }
}

@media (min-width: 768px) {
  .btn-send-enquiry {
    width: 380px;
    height: 58px;
    font-size: 19px;
  }
}

@media (min-width: 1024px) {
  .btn-send-enquiry {
    width: 400px;
    height: 60px;
    font-size: 20px;
  }
}

.btn-send-enquiry:hover {
  background: #c01e22;
  transform: translateY(-2px);
}

body {
  font-family: 'DM Sans', sans-serif;
  color: #434453;
  overflow-x: hidden;
}

.cr-hero {
  background: linear-gradient(180deg, rgba(230, 240, 255, 0.50) 0%, rgba(230, 240, 255, 0.00) 97%);
  padding: 24px 16px 32px;
  text-align: center;
}

@media (min-width: 480px) {
  .cr-hero {
    padding: 28px 20px 36px;
  }
}

@media (min-width: 768px) {
  .cr-hero {
    padding: 32px 24px 0px;
  }
}

@media (min-width: 1024px) {
  .cr-hero {
    padding: 36px 0 0px;
  }
}

.cr-hero__heading {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.375;
  margin-bottom: 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .cr-hero__heading {
    font-size: 26px;
    margin-bottom: 10px;
  }
}

@media (min-width: 768px) {
  .cr-hero__heading {
    font-size: 32px;
  }
}

@media (min-width: 1024px) {
  .cr-hero__heading {
    font-size: 40px;
  }
}

.cr-hero__sub {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  max-width: 100%;
  margin: 0 auto;
}

@media (min-width: 480px) {
  .cr-hero__sub {
    font-size: 13px;
    max-width: 480px;
  }
}

@media (min-width: 768px) {
  .cr-hero__sub {
    font-size: 14px;
    max-width: 940px;
  }
}

/* ═══════════════════════════════════════
   JOBS SECTION
═══════════════════════════════════════ */
.cr-jobs {
  padding: 28px 0 48px;
  background: #fff;
}

@media (min-width: 768px) {
  .cr-jobs {
    padding: 34px 0 60px;
  }
}

@media (min-width: 1024px) {
  .cr-jobs {
    padding: 30px 0 72px;
  }
}

/* ═══════════════════════════════════════
   JOB CARD
═══════════════════════════════════════ */
.cr-job-card {
  background: #fff;
  border: 1px solid var(--cb-card-border);
  border-radius: 14px;
  padding: 18px 18px 20px;
  height: auto;
  min-height: 240px;
  display: flex;
  flex-direction: column;
  transition: box-shadow .3s ease, transform .25s ease;
}

@media (min-width: 480px) {
  .cr-job-card {
    border-radius: 16px;
    padding: 20px 20px 22px;
    min-height: 260px;
  }
}

@media (min-width: 768px) {
  .cr-job-card {
    border-radius: 18px;
    padding: 22px 22px 24px;
  }
}

@media (min-width: 1024px) {
  .cr-job-card {
    border-radius: 20px;
    padding: 22px 30px 24px;
    height: 300px;
    min-height: unset;
  }
}

.cr-job-card:hover {
  box-shadow: 0 8px 28px rgba(12, 23, 136, .1);
  transform: translateY(-3px);
}

.cr-job-card__id {
  font-size: 10px;
  font-weight: 600;
  color: var(--cb-muted);
  text-transform: capitalize;
  line-height: 20px;
  margin-bottom: 2px;
}

.cr-job-card__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-red);
  text-transform: capitalize;
  line-height: 1.3;
  margin-bottom: 12px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  /* -webkit-line-clamp: 4; */
  /* overflow: hidden; */
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .cr-job-card__title {
    font-size: 17px;
    margin-bottom: 14px;
  }
}

@media (min-width: 768px) {
  .cr-job-card__title {
    font-size: 18px;
  }
}

@media (min-width: 1024px) {
  .cr-job-card__title {
    font-size: 20px;
    line-height: 21px;
    margin-bottom: 16px;
  }
}

.cr-job-card__meta {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.cr-job-card__meta-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--cb-muted);
  text-transform: capitalize;
  line-height: 20px;
  margin-bottom: 0;
}

.cr-job-card__meta-value {
  font-size: 14px;
  font-weight: 800;
  color: var(--cb-navy-alt);
  text-transform: capitalize;
  line-height: 20px;
  margin-bottom: 6px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .cr-job-card__meta-value {
    font-size: 15px;
    margin-bottom: 8px;
  }
}

@media (min-width: 1024px) {
  .cr-job-card__meta-value {
    font-size: 16px;
  }
}

.cr-job-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 30px;
  width: 110px;
  background: #fff;
  border: 1px solid var(--cb-know-border);
  border-radius: 100px;
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-red);
  text-decoration: none;
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease, transform .15s ease;
  margin-top: auto;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}

@media (min-width: 768px) {
  .cr-job-card__btn {
    width: 115px;
    font-size: 13px;
  }
}

@media (min-width: 1024px) {
  .cr-job-card__btn {
    width: 120px;
    font-size: 14px;
  }
}

.cr-job-card__btn:hover {
  background: #fff5f5;
  border-color: var(--cb-red);
  color: var(--cb-red);
  transform: translateY(-1px);
}

/* ═══════════════════════════════════════
   MODAL OVERLAY
═══════════════════════════════════════ */
.cr-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  z-index: 2000;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
}

@media (min-width: 600px) {
  .cr-modal-overlay {
    align-items: center;
    padding: 16px;
  }
}

@media (min-width: 768px) {
  .cr-modal-overlay {
    padding: 24px;
  }
}

.cr-modal-overlay.open {
  opacity: 1;
  pointer-events: auto;
}

/* ═══════════════════════════════════════
   MODAL
═══════════════════════════════════════ */
.cr-modal {
  background: #fff;
  border-radius: 16px 16px 0 0;
  max-width: 100%;
  width: 100%;
  padding: 24px 20px 32px;
  position: relative;
  transform: translateY(100%);
  transition: transform .25s ease;
  max-height: 90vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

@media (min-width: 600px) {
  .cr-modal {
    border-radius: 16px;
    max-width: 560px;
    padding: 28px 24px;
    transform: translateY(20px);
    max-height: none;
    overflow-y: visible;
  }
}

@media (min-width: 768px) {
  .cr-modal {
    padding: 36px;
  }
}

.cr-modal-overlay.open .cr-modal {
  transform: translateY(0);
}

.cr-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  background: none;
  border: none;
  font-size: 18px;
  color: var(--cb-muted);
  cursor: pointer;
  line-height: 1;
  transition: color .2s ease;
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  padding: 4px;
}

@media (min-width: 768px) {
  .cr-modal__close {
    top: 16px;
    right: 16px;
    font-size: 20px;
  }
}

.cr-modal__close:hover {
  color: var(--cb-red);
}

.cr-modal__id {
  font-size: 10px;
  font-weight: 600;
  color: var(--cb-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-bottom: 6px;
}

@media (min-width: 768px) {
  .cr-modal__id {
    font-size: 11px;
    margin-bottom: 8px;
  }
}

.cr-modal__title {
  font-size: 20px;
  font-weight: 700;
  color: var(--cb-red);
  text-transform: capitalize;
  line-height: 1.25;
  margin-bottom: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 768px) {
  .cr-modal__title {
    font-size: 22px;
    margin-bottom: 18px;
  }
}

@media (min-width: 1024px) {
  .cr-modal__title {
    font-size: 24px;
    margin-bottom: 20px;
  }
}

.cr-modal__badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--cb-lav);
  color: var(--cb-navy);
  border-radius: 100px;
  font-size: 12px;
  font-weight: 600;
  padding: 4px 12px;
  margin-right: 6px;
  margin-bottom: 16px;
}

@media (min-width: 768px) {
  .cr-modal__badge {
    font-size: 13px;
    gap: 6px;
    padding: 4px 14px;
    margin-right: 8px;
    margin-bottom: 20px;
  }
}

.cr-modal__section-heading {
  font-size: 12px;
  font-weight: 700;
  color: var(--cb-navy);
  text-transform: uppercase;
  letter-spacing: .6px;
  margin-bottom: 6px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 768px) {
  .cr-modal__section-heading {
    font-size: 13px;
    margin-bottom: 8px;
  }
}

.cr-modal__body {
  font-size: 13px;
  font-weight: 400;
  color: #555;
  line-height: 1.7;
  margin-bottom: 16px;
}

@media (min-width: 768px) {
  .cr-modal__body {
    font-size: 14px;
    margin-bottom: 20px;
  }
}

.cr-modal__apply-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  font-size: 14px;
  font-weight: 700;
  height: 40px;
  padding: 0 28px;
  width: 100%;
  text-decoration: none;
  cursor: pointer;
  transition: opacity .2s ease;
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
}

@media (min-width: 480px) {
  .cr-modal__apply-btn {
    width: auto;
    font-size: 15px;
    height: 42px;
    padding: 0 32px;
  }
}

@media (min-width: 768px) {
  .cr-modal__apply-btn {
    height: 44px;
    padding: 0 36px;
  }
}

.cr-modal__apply-btn:hover {
  opacity: .88;
  color: #fff;
}

/* ═══════════════════════════════════════
   REVEAL ANIMATION
═══════════════════════════════════════ */
.reveal-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .5s ease, transform .5s ease;
}

.reveal-item.revealed {
  opacity: 1;
  transform: none;
}

.reveal-item:nth-child(2) {
  transition-delay: .07s;
}

.reveal-item:nth-child(3) {
  transition-delay: .14s;
}

.reveal-item:nth-child(4) {
  transition-delay: .21s;
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-link);
  margin: 0;
  overflow-x: hidden;
}

img {
  max-width: 100%;
}

.bl-hero {
  background: linear-gradient(180deg, rgba(230, 240, 255, 0.50) 0%, rgba(230, 240, 255, 0.00) 97%);;
  padding: 32px 16px 28px;
  text-align: center;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.bl-hero__title {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.3;
  margin-bottom: 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.bl-hero__subtitle {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  margin-bottom: 0;
}

/* ── Blog listing section ── */
.blog-listing {
  padding: 36px 0 48px;
}

/* ── Blog card ── */
.blog-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  /* width: 40px; */
  height: 100%;
}

/* ── Card image wrap ── */
.blog-card__img-wrap {
  border-radius: 14px;
  overflow: hidden;
  height: 200px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  margin-bottom: 14px;
}

.blog-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  -webkit-transition: -webkit-transform .4s ease;
  transition: -webkit-transform .4s ease;
  transition: transform .4s ease;
  transition: transform .4s ease, -webkit-transform .4s ease;
}

.blog-card:hover .blog-card__img {
  -webkit-transform: scale(1.04);
  transform: scale(1.04);
}

/* ── Card meta ── */
.blog-card__date {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  margin-bottom: 6px;
}

.blog-card__title {
  font-size: 17px;
  font-weight: 700;
  color: var(--cb-red);
  line-height: 1.35;
  margin-bottom: 10px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.blog-card__title a {
  color: inherit;
  text-decoration: none;
  -webkit-transition: opacity .2s;
  transition: opacity .2s;
  -webkit-tap-highlight-color: transparent;
}

.blog-card__title a:hover {
  opacity: .8;
}

.blog-card__body {
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-link);
  line-height: 1.7;
  margin-bottom: 18px;
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
}

/* ── Card button ── */
.blog-card__btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: var(--cb-red);
  color: #fff;
  border: none;
  border-radius: 100px;
  height: 44px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 130px;
  padding: 20px 24px;
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: background .2s, -webkit-transform .2s;
  transition: background .2s, -webkit-transform .2s;
  transition: background .2s, transform .2s;
  transition: background .2s, transform .2s, -webkit-transform .2s;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-appearance: none;
  appearance: none;
}

.blog-card__btn:hover {
  background: #b81d21;
  color: #fff;
  -webkit-transform: translateY(-2px);
  transform: translateY(-2px);
}

/* ── Row spacing ── */
.blog-row+.blog-row {
  margin-top: 60px;
}

/* ── Scroll reveal ── */
.reveal-item {
  opacity: 0;
  -webkit-transform: translateY(24px);
  transform: translateY(24px);
  -webkit-transition: opacity .55s ease, -webkit-transform .55s ease;
  transition: opacity .55s ease, -webkit-transform .55s ease;
  transition: opacity .55s ease, transform .55s ease;
  transition: opacity .55s ease, transform .55s ease, -webkit-transform .55s ease;
}

.reveal-item.revealed {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}


/* =============================================
   480px — Small phones landscape
============================================= */
@media (min-width: 480px) {
  .bl-hero {
    padding: 36px 20px 30px;
  }

  .bl-hero__title {
    font-size: 24px;
  }

  .bl-hero__subtitle {
    font-size: 14px;
  }

  .blog-card__img-wrap {
    height: 210px;
    border-radius: 16px;
  }

  .blog-card__title {
    font-size: 18px;
  }

  .blog-card__body {
    font-size: 15px;
  }

  .blog-card__btn {
    height: 46px;
    font-size: 15px;
    min-width: 140px;
  }

  .blog-row+.blog-row {
    margin-top: 40px;
  }
}


/* =============================================
   600px — Large phones
============================================= */
@media (min-width: 600px) {
  .bl-hero {
    padding: 40px 24px 34px;
  }

  .bl-hero__title {
    font-size: 26px;
  }

  .blog-card__img-wrap {
    height: 220px;
  }

  .blog-card__title {
    font-size: 19px;
    margin-bottom: 12px;
  }

  .blog-listing {
    padding: 40px 0 56px;
  }
}


/* =============================================
   768px — Tablet
============================================= */
@media (min-width: 768px) {
  .bl-hero {
    padding: 44px 32px 38px;
  }

  .bl-hero__title {
    font-size: 30px;
    line-height: 1.3;
  }

  .blog-card__img-wrap {
    height: 240px;
    border-radius: 18px;
    margin-bottom: 16px;
  }

  .blog-card__title {
    font-size: 19px;
    line-height: 25px;
  }

  .blog-card__body {
    font-size: 15px;
    margin-bottom: 20px;
  }

  .blog-card__btn {
    height: 48px;
    min-width: 145px;
  }

  .blog-row+.blog-row {
    margin-top: 44px;
  }

  .blog-listing {
    padding: 44px 0 60px;
  }
}


/* =============================================
   992px — Tablet landscape
============================================= */
@media (min-width: 992px) {
  .bl-hero {
    padding: 48px 40px 42px;
  }

  .bl-hero__title {
    font-size: 34px;
    line-height: 1.25;
  }

  .blog-card__img-wrap {
    height: 260px;
    border-radius: 20px;
    margin-bottom: 18px;
  }

  .blog-card__title {
    font-size: 20px;
  }

  .blog-card {
    width: 100%;
  }

  .blog-card__body {
    font-size: 16px;
    /*margin-bottom: 40px;*/
  }

  .blog-card__btn {
    height: 50px;
    width: 150px;
    font-size: 16px;
  }

  .blog-row+.blog-row {
    margin-top: 48px;
  }

  .blog-listing {
    padding: 48px 0 64px;
  }
}


/* =============================================
   1024px — Laptop / original desktop values
============================================= */
@media (min-width: 1024px) {
  .bl-hero {
    padding: 30px 0 10px;
  }

  .bl-hero__title {
    font-size: 40px;
    line-height: 55px;
  }

  /* .blog-card{
        width: 460px;
      } */

  .blog-card__img-wrap {
    height: 280px;
  }

  .blog-card__date {
    font-size: 14px;
    margin-bottom: 8px;
  }

  .blog-card__title {
    font-size: 20px;
    line-height: 25px;
    margin-bottom: 12px;
  }

  .blog-row+.blog-row {
    margin-top: 52px;
  }

  .blog-listing {
    padding: 30px 0 72px;
  }
}


/* =============================================
   1200px — Large desktop
============================================= */
@media (min-width: 1200px) {
  .bl-hero__title {
    font-size: 40px;
    line-height: 55px;
  }

  .blog-card__img-wrap {
    height: 280px;
  }
}

.pagination .page-link {
  color: red;
  border-color: red;
}

.pagination .page-link:hover {
  color: white;
  background-color: red;
  border-color: red;
}

.pagination .page-item.active .page-link {
  background-color: red;
  border-color: red;
  color: white;
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-link);
  margin: 0;
  overflow-x: hidden;
}

img {
  max-width: 100%;
}

.bl-hero__label {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  color: var(--cb-link);
  background: rgba(255, 255, 255, .55);
  border-radius: 100px;
  padding: 3px 12px;
  margin-bottom: 12px;
  letter-spacing: .4px;
  -webkit-tap-highlight-color: transparent;
}

.bl-hero__title {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.25;
  margin-bottom: 10px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.bl-hero__subtitle {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  margin-bottom: 8px;
}

.bl-hero__date {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
}

/* ── Article wrapper ── */
.bl-article {
  padding: 0 0 48px;
}

/* ── Content column ── */
.bl-content {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 16px;
  box-sizing: border-box;
}

/* ── Hero image ── */
.bl-hero-img {
  width: 100%;
  border-radius: 14px;
  object-fit: cover;
  display: block;
  margin-bottom: 28px;
}

/* ── Divider ── */
.bl-divider {
  width: 100%;
  max-width: 900px;
  height: 1px;
  border: none;
  border-top: 1px solid #E4C9F6;
  margin: 28px auto;
}

/* ── Section title ── */
.bl-section-title {
  font-size: 17px;
  font-weight: 700;
  padding: 8px 0;
  color: var(--cb-navy);
  text-align: center;
  margin-bottom: 12px;
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Section body ── */
.bl-section-body {
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-link);
  text-align: center;
  width: 100%;
  max-width: 807px;
  margin: 0 auto 24px;
  line-height: 1.75;
}

/* ── Feature heading ── */
.bl-feature-heading {
  font-size: 16px;
  font-weight: 700;
  color: var(--cb-red);
  margin-bottom: 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Feature body ── */
.bl-feature-body {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  line-height: 1.65;
  margin-bottom: 0;
}

/* ── Section image ── */
.bl-section-img {
  width: 100%;
  border-radius: 14px;
  object-fit: cover;
  display: block;
  margin: 28px 0;
}

/* ── Rich link ── */
.bl-rich-link {
  color: var(--cb-navy);
  text-decoration: underline;
  font-weight: 700;
  -webkit-tap-highlight-color: transparent;
  transition: color .2s;
}

.bl-rich-link:hover {
  color: var(--cb-red);
}

/* ── Intro block ── */
.bl-intro {
  margin-bottom: 0;
}

.bl-intro-heading {
  font-size: 17px;
  font-weight: 700;
  color: var(--cb-navy);
  text-align: center;
  margin-bottom: 12px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.bl-intro-body {
  font-size: 14px;
  font-weight: 600;
  color: var(--cb-link);
  text-align: center;
  line-height: 1.75;
  width: 100%;
  max-width: 807px;
  margin: 0 auto;
}

/* ── Scroll reveal ── */
.reveal-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .55s ease, transform .55s ease;
}

.reveal-item.revealed {
  opacity: 1;
  transform: none;
}


/* =============================================
   480px — Small phones landscape
============================================= */
@media (min-width: 480px) {
  .bl-hero {
    padding: 40px 20px 36px;
  }

  .bl-content {
    padding: 0 20px;
  }

  .bl-hero__title {
    font-size: 26px;
  }

  .bl-hero__subtitle,
  .bl-hero__date {
    font-size: 14px;
  }

  .bl-section-title,
  .bl-intro-heading {
    font-size: 18px;
  }

  .bl-section-body,
  .bl-intro-body {
    font-size: 15px;
  }

  .bl-feature-body {
    font-size: 14px;
  }

  .bl-hero-img {
    border-radius: 16px;
    margin-bottom: 32px;
  }

  .bl-section-img {
    border-radius: 16px;
    margin: 32px 0;
  }

  .bl-divider {
    margin: 32px auto;
  }
}


/* =============================================
   600px — Large phones
============================================= */
@media (min-width: 600px) {
  .bl-hero {
    padding: 44px 24px 40px;
  }

  .bl-content {
    padding: 0 24px;
  }

  .bl-hero__title {
    font-size: 28px;
  }

  .bl-hero-img {
    border-radius: 18px;
  }

  .bl-section-img {
    border-radius: 18px;
  }
}


/* =============================================
   768px — Tablet
============================================= */
@media (min-width: 768px) {
  .bl-hero {
    padding: 48px 32px 42px;
  }

  .bl-content {
    padding: 0 32px;
  }

  .bl-hero__title {
    font-size: 32px;
  }

  .bl-hero__label {
    font-size: 13px;
    padding: 3px 14px;
  }

  .bl-section-title,
  .bl-intro-heading {
    font-size: 19px;
    padding: 10px 0;
    margin-bottom: 14px;
  }

  .bl-section-body,
  .bl-intro-body {
    font-size: 16px;
    margin-bottom: 28px;
  }

  .bl-feature-heading {
    font-size: 17px;
  }

  .bl-feature-body {
    font-size: 14px;
  }

  .bl-hero-img {
    border-radius: 20px;
    margin-bottom: 36px;
  }

  .bl-section-img {
    border-radius: 20px;
    margin: 36px 0;
  }

  .bl-divider {
    margin: 36px auto;
  }

  .bl-article {
    padding: 0 0 60px;
  }
}


/* =============================================
   992px — Tablet landscape
============================================= */
@media (min-width: 992px) {
  .bl-hero {
    padding: 50px 40px 44px;
  }

  .bl-content {
    padding: 0 40px;
  }

  .bl-hero__title {
    font-size: 36px;
  }

  .bl-section-title,
  .bl-intro-heading {
    font-size: 20px;
  }

  .bl-hero-img {
    margin-bottom: 40px;
  }

  .bl-section-img {
    margin: 40px 0;
  }

  .bl-divider {
    margin: 40px auto;
  }
}


/* =============================================
   1024px — Laptop
============================================= */
@media (min-width: 1024px) {
  .bl-hero {
    padding: 52px 0 44px;
  }

  .bl-content {
    padding: 0;
  }

  .bl-hero__title {
    font-size: 40px;
  }

  .bl-hero__subtitle,
  .bl-hero__date {
    font-size: 14px;
  }

  .bl-article {
    padding: 0 0 72px;
  }
}


/* =============================================
   1200px — Large desktop
============================================= */
@media (min-width: 1200px) {
  .bl-hero {
    padding: 52px 0 44px;
  }

  .bl-hero__title {
    font-size: 40px;
    line-height: 1.2;
  }
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-link);
  margin: 0;
  overflow-x: hidden;
}

img {
  max-width: 100%;
}

.faq-hero {
  background: white;
  padding: 32px 16px 24px;
  text-align: center;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.faq-hero__title {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.3;
  margin-bottom: 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.faq-hero__subtitle {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  margin-bottom: 0;
}

.faq-section {
  padding: 32px 0 0px;
}


/* ── Tab list ── */
.faq-tabs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 28px;
  list-style: none;
  padding: 0;
  /* Scrollable on very small screens */
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* IE / Edge */
}

.faq-tabs::-webkit-scrollbar {
  display: none;
  /* Chrome / Safari */
}


/* ── Tab button ── */
.faq-tab-btn {
  height: 42px;
  padding: 0 18px;
  border-radius: 100px;
  border: 1px solid #ededed;
  background: #fff;
  color: var(--cb-navy);
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
  -webkit-appearance: none;
  appearance: none;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transition: background .2s, color .2s, border-color .2s;
  transition: background .2s, color .2s, border-color .2s;
}

.faq-tab-btn[aria-selected="true"] {
  background: var(--cb-navy);
  color: #fff;
  border-color: var(--cb-navy);
}

.faq-tab-btn:hover:not([aria-selected="true"]) {
  border-color: var(--cb-navy);
}


/* ── Panel visibility ── */
.faq-panel {
  display: none;
}

.faq-panel.active {
  display: block;
}


/* ── FAQ card ── */
.faq-card {
  background: #fff;
  border: 1px solid #a4a4a4;
  border-radius: 10px;
  padding: 20px 18px;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  box-sizing: border-box;
}

.faq-card+.faq-card {
  margin-top: 12px;
}

.faq-card__q {
  font-size: 16px;
  font-weight: 600;
  color: var(--cb-navy);
  margin-bottom: 10px;
  line-height: 1.35;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.faq-card__a {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  line-height: 1.7;
  margin-bottom: 0;
}

.faq-card__a a {
  color: var(--cb-navy);
  text-decoration: underline;
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: color .2s;
  transition: color .2s;
}

.faq-card__a a:hover {
  color: var(--cb-red);
}

.faq-card__a p {
  margin-bottom: 8px;
}

.faq-card__a p:last-child {
  margin-bottom: 0;
}


/* ── CTA block ── */
.faq-cta {
  text-align: center;
  width: 100%;
  max-width: 920px;
  margin: 36px auto 80px;
  padding: 0 16px;
  box-sizing: border-box;
}

.faq-cta__heading {
  font-size: 17px;
  font-weight: 600;
  color: var(--cb-red);
  margin-bottom: 10px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.faq-cta__body {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  line-height: 1.7;
  margin-bottom: 0;
}

.faq-cta__body a {
  color: var(--cb-navy);
  text-decoration: underline;
  -webkit-tap-highlight-color: transparent;
  -webkit-transition: color .2s;
  transition: color .2s;
}

.faq-cta__body a:hover {
  color: var(--cb-red);
}


/* ── Scroll reveal ── */
.reveal-item {
  opacity: 0;
  -webkit-transform: translateY(24px);
  transform: translateY(24px);
  -webkit-transition: opacity .55s ease, -webkit-transform .55s ease;
  transition: opacity .55s ease, -webkit-transform .55s ease;
  transition: opacity .55s ease, transform .55s ease;
  transition: opacity .55s ease, transform .55s ease,
    -webkit-transform .55s ease;
}

.reveal-item.revealed {
  opacity: 1;
  -webkit-transform: none;
  transform: none;
}


/* =============================================
   480px — Small phones landscape
============================================= */
@media (min-width: 480px) {
  .faq-hero {
    padding: 36px 20px 28px;
  }

  .faq-hero__title {
    font-size: 24px;
  }

  .faq-hero__subtitle {
    font-size: 14px;
  }

  .faq-tabs {
    gap: 12px;
    margin-bottom: 30px;
  }

  .faq-tab-btn {
    height: 44px;
    padding: 0 20px;
    font-size: 13px;
  }

  .faq-card {
    padding: 22px 22px;
  }

  .faq-card__q {
    font-size: 17px;
    margin-bottom: 12px;
  }

  .faq-card__a {
    font-size: 14px;
  }

  .faq-cta {
    margin: 40px auto 50px;
  }

  .faq-cta__heading {
    font-size: 18px;
  }

  .faq-cta__body {
    font-size: 14px;
  }
}


/* =============================================
   600px — Large phones
============================================= */
@media (min-width: 600px) {
  .faq-hero {
    padding: 38px 24px 30px;
  }

  .faq-hero__title {
    font-size: 26px;
  }

  .faq-tabs {
    overflow-x: visible;
  }

  .faq-tab-btn {
    -ms-flex-negative: unset;
    flex-shrink: unset;
  }

  .faq-card {
    padding: 24px 28px;
  }

  .faq-card__q {
    font-size: 18px;
  }

  /* .faq-section {
    padding: 36px 0 48px;
  } */

  .faq-cta {
    padding: 0 24px;
    margin: 44px auto 50px;
  }
}


/* =============================================
   768px — Tablet
============================================= */
@media (min-width: 768px) {
  .faq-hero {
    padding: 40px auto 32px;
  }

  .faq-hero__title {
    font-size: 30px;
    line-height: 1.3;
  }

  .faq-tabs {
    gap: 14px;
    margin-bottom: 32px;
  }

  .faq-tab-btn {
    height: 46px;
    padding: 0 22px;
    font-size: 14px;
  }

  .faq-card {
    padding: 24px 36px;
  }

  .faq-card+.faq-card {
    margin-top: 14px;
  }

  .faq-card__q {
    font-size: 19px;
    margin-bottom: 12px;
  }

  /* .faq-section {
    padding: 0px 0 52px;
  } */

  .faq-cta {
    padding: 0 32px;
    margin: 46px auto 50px;
  }

  .faq-cta__heading {
    font-size: 19px;
    margin-bottom: 12px;
  }
}


/* =============================================
   992px — Tablet landscape
============================================= */
@media (min-width: 992px) {
  .faq-hero {
    padding: 42px 40px 34px;
  }

  .faq-hero__title {
    font-size: 34px;
    line-height: 1.25;
  }

  .faq-tabs {
    gap: 15px;
    margin-bottom: 34px;
  }

  .faq-tab-btn {
    height: 48px;
    padding: 0 23px;
  }

  .faq-card {
    padding: 26px 42px;
  }

  .faq-card__q {
    font-size: 19px;
    margin-bottom: 13px;
  }

  /* .faq-section {
    padding: 42px 0 56px;
  } */

  .faq-cta {
    padding: 0;
    margin: 48px auto 100px;
  }

  .faq-cta__heading {
    font-size: 20px;
  }
}


/* =============================================
   1024px — Laptop / original desktop values
============================================= */
@media (min-width: 1024px) {
  .faq-hero {
    padding: 44px 0 36px;
  }

  .faq-hero__title {
    font-size: 40px;
    line-height: 55px;
  }

  .faq-hero__subtitle {
    font-size: 14px;
  }

  .faq-tabs {
    gap: 15px;
    margin-bottom: 36px;
  }

  .faq-tab-btn {
    height: 50px;
    padding: 0 30px;
    font-size: 14px;
  }

  .faq-card {
    padding: 28px 48px;
  }

  .faq-card+.faq-card {
    margin-top: 16px;
  }

  .faq-card__q {
    font-size: 20px;
    margin-bottom: 14px;
  }

  .faq-card__a {
    font-size: 14px;
  }

  /* .faq-section {
    padding: 10px 0 60px;
  } */

  .faq-cta {
    margin: 50px auto 100px;
  }

  .faq-cta__heading {
    font-size: 20px;
    margin-bottom: 12px;
  }
}


/* =============================================
   1200px — Large desktop
============================================= */
@media (min-width: 1200px) {
  .faq-hero__title {
    font-size: 40px;
    line-height: 55px;
  }

  .faq-card {
    padding: 28px 48px;
  }
}


.story {
  padding: 20px 16px;
}

@media (min-width: 576px) {
  .story {
    padding: 25px 24px;
  }
}

/* Tablets (≥768px) */
@media (min-width: 768px) {
  .story {
    padding: 30px 40px;
  }
}

/* Laptops (≥992px) */
@media (min-width: 992px) {
  .story {
    padding: 30px 60px;
  }
}

/* Large Screens (≥1200px) */
@media (min-width: 1200px) {
  .story {
    padding: 30px 70px;
  }
}

/* Extra Large Screens (≥1400px) */
@media (min-width: 1400px) {
  .story {
    padding: 40px 100px;
  }
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-body);
  overflow-x: hidden;
}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
.ac-hero {
 background: linear-gradient(180deg, #E6F0FF 0%, rgba(230, 240, 255, 0.00) 97%);
  padding: 24px 16px 32px;
  text-align: center;
}

@media (min-width: 480px) {
  .ac-hero {
    padding: 28px 20px 36px;
  }
}

@media (min-width: 768px) {
  .ac-hero {
    padding: 32px 24px 38px;
  }
}

@media (min-width: 1024px) {
  .ac-hero {
    padding: 30px 0 20px;
  }
}

.ac-hero__heading {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.375;
  margin-bottom: 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .ac-hero__heading {
    font-size: 26px;
    margin-bottom: 10px;
  }
}

@media (min-width: 768px) {
  .ac-hero__heading {
    font-size: 32px;
  }
}

@media (min-width: 1024px) {
  .ac-hero__heading {
    font-size: 40px;
  }
}

.ac-hero__sub {
  font-size: 13px;
  font-weight: 600;
  color: var(--cb-link);
  margin-bottom: 16px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}

@media (min-width: 480px) {
  .ac-hero__sub {
    font-size: 13px;
    max-width: 480px;
    margin-bottom: 18px;
  }
}

@media (min-width: 768px) {
  .ac-hero__sub {
    font-size: 14px;
    max-width: 600px;
    margin-bottom: 20px;
  }
}

.ac-hero__checkout-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--cb-red);
  color: #fff;
  border: 0.5px solid var(--cb-red);
  border-radius: 100px;
  font-size: 14px;
  font-weight: 700;
  height: 38px;
  padding: 0 22px;
  text-decoration: none;
  transition: opacity .2s ease, transform .15s ease;
  text-transform: capitalize;
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  white-space: nowrap;
}

@media (min-width: 480px) {
  .ac-hero__checkout-btn {
    font-size: 15px;
    height: 40px;
    padding: 0 26px;
  }
}

@media (min-width: 768px) {
  .ac-hero__checkout-btn {
    font-size: 16px;
    padding: 0 28px;
  }
}

.ac-hero__checkout-btn:hover {
  opacity: .88;
  color: #fff;
  transform: translateY(-1px);
}

/* ═══════════════════════════════════════
   FILTER TABS
═══════════════════════════════════════ */
.ac-filter-tabs {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 20px 16px 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.ac-filter-tabs::-webkit-scrollbar {
  display: none;
}

@media (max-width: 480px) {
  .ac-filter-tabs {
    padding: 24px 0px 0;
  }

  .au-cta__contact-section {
    align-items: flex-start;
    display: flex;
    flex-direction: column;
  }

  .au-cta__contacts {
    align-items: flex-start;
    /* 🔥 key fix */
  }

  .au-cta__contact-item {
    width: 100%;
    /* full width */
    justify-content: flex-start;
  }

  .au-cta__contact-icon {
    width: 50px;
    /* 🔥 fixed width for alignment */
    min-width: 50px;
    display: flex;
    justify-content: center;
  }

  .au-cta__contact-section {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (min-width: 768px) {
  .ac-filter-tabs {
    justify-content: center;
    padding: 24px 24px 0;
    gap: 12px;
    overflow-x: visible;
    flex-wrap: wrap;
  }
}

@media (min-width: 1024px) {
  .ac-filter-tabs {
    padding: 28px 0 0;
  }
}

.ac-filter-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 0 16px;
  border-radius: 100px;
  border: 1px solid var(--cb-border);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  background: #fff;
  color: var(--cb-navy);
  transition: background .2s ease, color .2s ease, border-color .2s ease;
  white-space: nowrap;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}

@media (min-width: 480px) {
  .ac-filter-tab {
    height: 44px;
    padding: 0 20px;
    font-size: 13px;
  }
}

@media (min-width: 768px) {
  .ac-filter-tab {
    height: 48px;
    padding: 0 22px;
    font-size: 14px;
    flex-shrink: unset;
  }
}

@media (min-width: 1024px) {
  .ac-filter-tab {
    height: 50px;
    padding: 0 30px;
  }
}

.ac-filter-tab:hover {
  background: #f0f2ff;
}

.ac-filter-tab.active {
  background: var(--cb-navy);
  color: #fff;
  border-color: var(--cb-navy);
}

/* ═══════════════════════════════════════
   PRODUCTS SECTION
═══════════════════════════════════════ */
.ac-products {
  padding: 0px 0 48px;
  background: #fff;
}

@media (min-width: 768px) {
  .ac-products {
    padding: 0px 0 60px;
  }
}

@media (min-width: 1024px) {
  .ac-products {
    padding: 20px 0 72px;
  }
}

.ac-products__category-heading {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  text-align: center;
  margin-bottom: 20px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .ac-products__category-heading {
    font-size: 26px;
    margin-bottom: 24px;
  }
}

@media (min-width: 768px) {
  .ac-products__category-heading {
    font-size: 32px;
    margin-bottom: 28px;
  }
}

@media (min-width: 1024px) {
  .ac-products__category-heading {
    font-size: 40px;
    margin-bottom: 32px;
  }
}

/* ═══════════════════════════════════════
   PRODUCT CARD
═══════════════════════════════════════ */
.ac-product-card {
  background: #fff;
  border-radius: 0;
  overflow: visible;
}

.ac-product-card__img-wrap {
  background: var(--cb-grey);
  border-radius: 14px;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  margin-bottom: 8px;
  transition: box-shadow .45s ease;
}

.ac-product-card__img-wrap:hover img {
  transform: scale(1.06);
}
.ac-product-img{
  border-radius: 20px;
  height: auto;
  width: 100%;
  cursor: pointer;
  transition: opacity var(--transition);
  aspect-ratio: 1;
}

@media (min-width: 768px) {
  .ac-product-card__img-wrap {
    border-radius: 16px;
    margin-bottom: 10px;
  }
}

@media (min-width: 1024px) {
  .ac-product-card__img-wrap {
    border-radius: 20px;
  }
}

.ac-product-card:hover .ac-product-card__img-wrap {
  box-shadow: 0 8px 24px rgba(0, 0, 0, .1);
}

.ac-product-card__img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.selection-by-color {
  display: flex;
  gap: 8px;
  margin: 10px 0;
  justify-content: center;
}

.color-trigger {
  display: inline-flex;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid #ddd;
  justify-content: center;
  align-items: center;
}

.color-trigger span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: block;
}

.color-trigger img {
  width: 16px;
  height: 16px;
  border-radius: 50%;
}

.accActive {
  border-color: #000;
}

.ac-product-card__sku {
  font-size: 11px;
  font-weight: 400;
  color: var(--cb-navy);
  margin-bottom: 3px;
}

@media (min-width: 768px) {
  .ac-product-card__sku {
    font-size: 12px;
    margin-bottom: 4px;
  }
}

.ac-product-card__name {
  font-size: 14px;
  font-weight: 700;
  color: var(--cb-body);
  line-height: 1.278;
  margin-bottom: 4px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .ac-product-card__name {
    font-size: 15px;
  }
}

@media (min-width: 768px) {
  .ac-product-card__name {
    font-size: 16px;
    margin-bottom: 6px;
  }
}

@media (min-width: 1024px) {
  .ac-product-card__name {
    font-size: 18px;
  }
}

.ac-product-card__price {
  font-size: 14px;
  font-weight: 700;
  color: var(--cb-red);
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .ac-product-card__price {
    font-size: 15px;
    margin-bottom: 12px;
  }
}

@media (min-width: 1024px) {
  .ac-product-card__price {
    font-size: 16px;
    margin-bottom: 14px;
  }
}
.ac-product-card:hover .ac-product-card__img-wrap img {
    transform: scale(1.1);
}

.ac-product-card:hover .btn-atcb {
    background: #c62828;
    color: #fff;
}

/* ═══════════════════════════════════════
   ADD TO CART BUTTON
═══════════════════════════════════════ */
.btn-atcb {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  width: 100%;
  max-width: 100%;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 700;
  text-transform: capitalize;
  border: 1px solid var(--cb-red);
  cursor: pointer;
  transition: opacity .2s ease, transform .15s ease;
  text-decoration: none;
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
}

@media (min-width: 480px) {
  .btn-atcb {
    height: 38px;
    font-size: 14px;
    max-width: 180px;
  }
}

@media (min-width: 768px) {
  .btn-atcb {
    height: 40px;
    font-size: 15px;
    max-width: 200px;
  }
}

@media (min-width: 1024px) {
  .btn-atcb {
    font-size: 16px;
    max-width: 210px;
  }
}

.btn-atcb:hover {
  opacity: .85;
  transform: translateY(-1px);
}

/* filled button */
.btn-atcb--filled {
  background: var(--cb-red);
  color: #fff;
  border-color: var(--cb-red);
}

/* hover color change */
.btn-atcb--filled:hover {
  background: var(--cb-red-dark);
  border-color: var(--cb-red-dark);
  color: #fff;
}

/* selected state */
.btn-atcb--filled:active,
.btn-atcb--filled.selected {
  background: var(--cb-red-dark);
  border-color: var(--cb-red-dark);
  transform: scale(.98);
}

/* outline button */
.btn-atcb--outline {
  background: #fff;
  color: var(--cb-red);
  border-color: var(--cb-red);
}

.btn-atcb--outline:hover {
  background: var(--cb-red);
  color: #fff;
}

/* ═══════════════════════════════════════
   CATEGORY PANEL
═══════════════════════════════════════ */
.ac-category-panel {
  display: none;
}

.ac-category-panel.active {
  display: block;
}

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-body);
  overflow-x: hidden;
}

.ct-hero {
  background: linear-gradient(180deg, rgba(230, 240, 255, 0.50) 0%, rgba(230, 240, 255, 0.00) 97%);;
  padding: 28px 16px 36px;
  text-align: center;
}



@media (max-width: 991px) {
  .ct-hero {
    padding: 32px 24px 30px;
  }
}

@media (min-width: 1024px) {
  .ct-hero {
    padding: 40px 0 10px;
  }
}

.ct-hero__heading {
  font-size: 22px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.375;
  margin-bottom: 10px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .ct-hero__heading {
    font-size: 26px;
    margin-bottom: 12px;
  }
}

@media (min-width: 768px) {
  .ct-hero__heading {
    font-size: 32px;
  }
}

@media (min-width: 1024px) {
  .ct-hero__heading {
    font-size: clamp(26px, 3.5vw, 40px);
  }
}

.ct-hero__sub {
  font-size: 13px;
  font-weight: 600;
  color: #554343;
}

@media (min-width: 768px) {
  .ct-hero__sub {
    font-size: 14px;
  }
}

/* ═══════════════════════════════════════
   SECTION
═══════════════════════════════════════ */
.ct-section {
  padding: 32px 0 40px;
  background: #fff;
}

@media (min-width: 480px) {
  .ct-section {
    padding: 40px 0 48px;
  }
}

@media (min-width: 768px) {
  .ct-section {
    padding: 52px 0 64px;
  }
}

@media (min-width: 1024px) {
  .ct-section {
    padding: 48px 0 80px;
  }
}

/* ═══════════════════════════════════════
   INFO COLUMN
═══════════════════════════════════════ */
.ct-info__heading {
  font-size: 15px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.3;
  max-width: 100%;
  margin-bottom: 18px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .ct-info__heading {
    font-size: 17px;
    margin-bottom: 22px;
  }
}

@media (min-width: 768px) {
  .ct-info__heading {
    font-size: 20px;
    margin-bottom: 26px;
    max-width: 340px;
  }
}

@media (min-width: 1024px) {
  .ct-info__heading {
    font-size: clamp(18px, 1.8vw, 24px);
    margin-bottom: 32px;
    max-width: 367px;
  }
}

.ct-info__block {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 18px;
  flex-direction: row;
}

@media (min-width: 768px) {
  .ct-info__block {
    gap: 16px;
    margin-bottom: 22px;
  }
}

@media (min-width: 1024px) {
  .ct-info__block {
    gap: 20px;
    margin-bottom: 28px;
  }
}

.ct-info__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
}

@media (min-width: 768px) {
  .ct-info__icon {
    width: 44px;
    height: 44px;
  }
}

@media (min-width: 1024px) {
  .ct-info__icon {
    width: 50px;
    height: 50px;
  }
}

.ct-info__icon img {
  width: 100%;
  height: 100%;
  display: block;
}

.ct-info__icon--fa {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 768px) {
  .ct-info__icon--fa {
    width: 44px;
    height: 44px;
  }
}

@media (min-width: 1024px) {
  .ct-info__icon--fa {
    width: 50px;
    height: 50px;
  }
}

.ct-info__icon--fa svg {
  width: 100%;
  height: 100%;
}

.ct-info__phone {
  font-size: 18px;
  font-weight: 700;
  color: var(--cb-navy);
  line-height: 1.1;
  margin-bottom: 5px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .ct-info__phone {
    font-size: 22px;
  }
}

@media (min-width: 768px) {
  .ct-info__phone {
    font-size: 26px;
    margin-bottom: 6px;
  }
}

@media (min-width: 1024px) {
  .ct-info__phone {
    font-size: clamp(22px, 2.5vw, 32px);
  }
}

.ct-info__hours-label {
  font-size: 10px;
  font-weight: 600;
  color: var(--cb-link);
  margin-bottom: 2px;
}

@media (min-width: 768px) {
  .ct-info__hours-label {
    font-size: 12px;
  }
}

.ct-info__hours-value {
  font-size: 12px;
  font-weight: 700;
  color: var(--cb-red);
  margin-bottom: 2px;
}

@media (min-width: 768px) {
  .ct-info__hours-value {
    font-size: 14px;
  }
}

@media (min-width: 1024px) {
  .ct-info__hours-value {
    font-size: 15px;
  }
}

.ct-info__hours-note {
  font-size: 10px;
  font-weight: 600;
  color: var(--cb-link);
  max-width: 100%;
  line-height: 1.4;
}

@media (min-width: 768px) {
  .ct-info__hours-note {
    font-size: 11px;
    max-width: 260px;
  }
}

@media (min-width: 1024px) {
  .ct-info__hours-note {
    font-size: 12px;
    max-width: 280px;
  }
}

.ct-info__email {
  font-size: 13px;
  font-weight: 700;
  color: var(--cb-navy);
  text-decoration: none;
  transition: color 0.2s ease;
  word-break: break-all;
  -webkit-font-smoothing: antialiased;
  display: inline-block;
}

@media (min-width: 480px) {
  .ct-info__email {
    font-size: 15px;
    word-break: normal;
  }
}

@media (min-width: 768px) {
  .ct-info__email {
    font-size: 17px;
  }
}

@media (min-width: 1024px) {
  .ct-info__email {
    font-size: clamp(15px, 1.5vw, 20px);
  }
}

.ct-info__email:hover {
  color: var(--cb-red);
}

/* ═══════════════════════════════════════
   FORM CARD
═══════════════════════════════════════ */
.ct-form-card {
  background: #fff;
  /* border: 1px solid var(--cb-border); */
  border: none;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  width: 100%;
  max-width: 100%;
  border-radius: 10px;
  padding: 16px 14px 20px;
  box-sizing: border-box;
  margin-top: 28px;
}

@media (min-width: 480px) {
  .ct-form-card {
    padding: 20px 18px 24px;
  }
}

@media (min-width: 768px) {
  .ct-form-card {
    padding: 22px 22px 26px;
    margin-top: 0;
  }
}

@media (min-width: 1024px) {
  .ct-form-card {
    padding: 26px 26px 30px;
    /* cap at Figma design width on large screens */
    /* margin-left: auto; */
  }
}

.ct-form-card__intro {
  font-size: 13px;
  font-weight: 400;
  color: var(--cb-navy);
  line-height: 1.4;
  margin-bottom: 14px;
  max-width: 100%;
}

@media (min-width: 768px) {
  .ct-form-card__intro {
    font-size: 14px;
    margin-bottom: 16px;
  }
}

@media (min-width: 1024px) {
  .ct-form-card__intro {
    font-size: 15px;
    margin-bottom: 18px;
    max-width: 390px;
  }
}

/* ═══════════════════════════════════════
   FLOATING LABEL FIELDS
═══════════════════════════════════════ */
.form-field {
  flex: 1;
  display: flex;
  position: relative;
}

.floating-field label {
  position: absolute;
  left: 12px;
  top: 10px;
  font-size: 12px;
  font-weight: 400;
  color: var(--cb-navy);
  padding: 0 4px;
  transition: top 0.22s ease, font-size 0.22s ease, font-weight 0.22s ease;
  pointer-events: none;
  background: transparent;
  white-space: nowrap;
}

@media (min-width: 768px) {
  .floating-field label {
    left: 14px;
    top: 10px;
    font-size: 13px;
  }
}

@media (min-width: 1024px) {
  .floating-field label {
    top: 14px;
    font-size: 14px;
  }
}

.form-input:focus+label,
.form-input:not(:placeholder-shown)+label,
.ct-textarea:focus+label,
.ct-textarea:not(:placeholder-shown)+label {
  top: -8px;
  left: 10px;
  font-size: 10px;
  font-weight: 300;
  color: var(--cb-navy);
  background: #fff;
}

@media (min-width: 768px) {

  .form-input:focus+label,
  .form-input:not(:placeholder-shown)+label,
  .ct-textarea:focus+label,
  .ct-textarea:not(:placeholder-shown)+label {
    font-size: 11px;
  }
}

@media (min-width: 1024px) {

  .form-input:focus+label,
  .form-input:not(:placeholder-shown)+label,
  .ct-textarea:focus+label,
  .ct-textarea:not(:placeholder-shown)+label {
    font-size: 12px;
  }
}

/* ═══════════════════════════════════════
   FORM INPUT
═══════════════════════════════════════ */
.form-input {
  width: 100%;
  height: 38px;
  background: #fff;
  border: 1px solid var(--cb-border);
  border-radius: 6px;
  padding: 0 12px;
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-navy);
  outline: none;
  transition: border-color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
}

@media (min-width: 480px) {
  .form-input {
    height: 40px;
    font-size: 13px;
    padding: 0 14px;
    border-radius: 8px;
  }
}

@media (min-width: 768px) {
  .form-input {
    height: 40px;
    font-size: 14px;
    padding: 0 16px;
    border-radius: 8px;
  }
}

@media (min-width: 1024px) {
  .form-input {
    height: 40px;
    font-size: 14px;
    padding: 0 14px;
    border-radius: 5px;
  }
}

.form-input:focus {
  border-color: var(--cb-navy);
}

.form-input.error {
  border-color: var(--cb-red);
}

/* ═══════════════════════════════════════
   TEXTAREAS
═══════════════════════════════════════ */
.ct-textarea {
  width: 100%;
  background: #fff;
  border: 1px solid var(--cb-border);
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 12px;
  font-family: 'DM Sans', sans-serif;
  color: var(--cb-navy);
  outline: none;
  transition: border-color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
  resize: vertical;
}

@media (min-width: 480px) {
  .ct-textarea {
    border-radius: 8px;
    font-size: 13px;
    padding: 10px 14px;
  }
}

@media (min-width: 768px) {
  .ct-textarea {
    font-size: 14px;
    padding: 10px 16px;
    border-radius: 8px;
  }
}

@media (min-width: 1024px) {
  .ct-textarea {
    border-radius: 5px;
    font-size: 14px;
    padding: 10px 14px;
  }
}

.ct-textarea:focus {
  border-color: var(--cb-navy);
}

/* Message textarea — right column */
#ctMessage {
  height: 100%;
  min-height: 140px;
  resize: none;
}

@media (min-width: 768px) {
  #ctMessage {
    min-height: 160px;
  }
}

@media (min-width: 1024px) {
  #ctMessage {
    height: 100%;
    min-height: 188px;
    resize: none;
  }
}

/* Subject/note textarea — left column bottom */
#ctSubject {
  height: 60px;
  min-height: 56px;
  resize: none;
}

@media (min-width: 768px) {
  #ctSubject {
    height: 64px;
  }
}

@media (min-width: 1024px) {
  #ctSubject {
    height: 60px;
  }
}

/* ═══════════════════════════════════════
   FORM GRID — MOBILE STACKING
═══════════════════════════════════════ */

/* Stack ALL col-6 inside the form card to full-width on mobile */
@media (max-width: 575px) {
  .ct-form-card .row>[class*="col-6"] {
    width: 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }

  /* Message textarea full width when stacked */
  #ctMessage {
    min-height: 100px;
    height: 100px;
  }
}

/* On tablet (576–1023px), keep 2-col but relax heights */
@media (min-width: 576px) and (max-width: 1023px) {
  .ct-form-card .row>.col-6.form-field.floating-field {
    align-self: flex-start;
  }
}

/* On desktop, right Message column stretches full row height */
@media (min-width: 1024px) {
  .ct-form-card .row>.col-6.form-field.floating-field {
    align-self: stretch;
  }

  .ct-form-card .row>.col-6.form-field.floating-field #ctMessage {
    height: 100%;
    min-height: unset;
  }
}

/* ═══════════════════════════════════════
   FORM BUTTON
═══════════════════════════════════════ */
.ct-form-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: var(--cb-red);
  color: #fff;
  border: 0.5px solid var(--cb-red);
  border-radius: 100px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-transform: capitalize;
  height: 38px;
  padding: 0 20px;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
  -webkit-tap-highlight-color: transparent;
  box-sizing: border-box;
}

@media (min-width: 480px) {
  .ct-form-btn {
    width: auto;
    font-size: 14px;
    height: 40px;
    padding: 0 26px;
  }
}

@media (min-width: 768px) {
  .ct-form-btn {
    font-size: 15px;
    padding: 0 30px;
  }
}

@media (min-width: 1024px) {
  .ct-form-btn {
    font-size: 16px;
    padding: 0 32px;
  }
}

.ct-form-btn:hover {
  opacity: 0.88;
  transform: translateY(-1px);
}

.ct-form-btn:active {
  transform: translateY(0);
}

/* ═══════════════════════════════════════
   TOAST NOTIFICATION
═══════════════════════════════════════ */
.ct-toast {
  position: fixed;
  bottom: 14px;
  right: 14px;
  background: #198754;
  color: #fff;
  padding: 10px 14px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  z-index: 9999;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  pointer-events: none;
  max-width: calc(100vw - 28px);
}

@media (min-width: 480px) {
  .ct-toast {
    bottom: 18px;
    right: 18px;
    padding: 11px 16px;
    font-size: 13px;
    max-width: none;
  }
}

@media (min-width: 768px) {
  .ct-toast {
    bottom: 22px;
    right: 22px;
    padding: 12px 18px;
    font-size: 14px;
  }
}

.ct-toast.show {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

@media (max-width: 991px) {
  .section-header {
    grid-template-columns: 1fr auto;
  }

  .section-header-title {
    grid-column: 1;
    text-align: left;
  }

  .view-all-btn {
    grid-column: 2;
    justify-self: end;
  }
}

.custom-carousel {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.carousel-track {
  display: flex;
  transition: transform 0.4s ease;
}

.carousel-slide {
  min-width: 100%;
}

.carousel-slide img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 20px;
  padding: 10px;
}

/* Buttons */
.carousel-prev,
.carousel-next {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: white;
  border: none;
  border-radius: 50%;
  width: 34px;
  height: 34px;
  font-size: 16px;
  cursor: pointer;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.carousel-prev {
  left: 20px;
}

.carousel-next {
  right: 20px;
}

.page-title {
  color: #434453;
  font-family: "DM Sans";
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.serve-container {
  border-radius: 10px;
  border: 1px solid #878AAA;
  background: #FFF;
}

.cart-heading {
  color: #434453;
  font-family: "DM Sans";
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

.btn-remove {
  text-align: center;
  justify-content: center;
  align-items: center;
}

.divide {
  background: #fff;
  box-shadow: 0 0 8px rgba(0, 0, 0, .2)
}

.mobile-menu {
  padding: 15px 20px;
}

@media (max-width: 991px) {
  .mobile-ctsection {
    justify-content: center;
    align-items: center;
    display: flex;
    flex-direction: column;
  }
}

.auth-title {
  color: #0C1788;
  font-family: "DM Sans";
  font-size: 30px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
}

body {
  font-family: 'DM Sans', sans-serif;
  color: #434453;
  background: #fff;
  overflow-x: hidden;
  margin: 0;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  color: inherit;
}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
.sl-hero {
  background: #ffe2e2;
  min-height: 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 32px 16px;
}

.sl-hero-1{
  background: #F0F6FF;
}

@media (min-width: 480px) {
  .sl-hero {
    min-height: 200px;
    padding: 36px 20px;
  }
}

@media (min-width: 768px) {
  .sl-hero {
    min-height: 220px;
    padding: 40px 24px;
  }
}

@media (min-width: 1024px) {
  .sl-hero {
    min-height: 250px;
    padding: 48px 24px;
  }
}

.sl-hero__title {
  font-family: 'DM Sans', sans-serif;
  font-size: 24px;
  font-weight: 700;
  color: #0c1788;
  line-height: 1.3;
  margin: 0 0 8px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 480px) {
  .sl-hero__title {
    font-size: 28px;
  }
}

@media (min-width: 768px) {
  .sl-hero__title {
    font-size: 34px;
    margin: 0 0 10px;
  }
}

@media (min-width: 1024px) {
  .sl-hero__title {
    font-size: 40px;
    line-height: 1.35;
  }
}

.sl-hero__sub {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: #554343;
  margin: 0;
}

@media (min-width: 768px) {
  .sl-hero__sub {
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .sl-hero__sub {
    font-size: 16px;
  }
}

/* ═══════════════════════════════════════
   INTRO TEXT
═══════════════════════════════════════ */
.sl-intro {
  padding: 32px 16px;
}

@media (min-width: 480px) {
  .sl-intro {
    padding: 40px 20px;
  }
}

@media (min-width: 768px) {
  .sl-intro {
    padding: 48px 24px;
  }
}

@media (min-width: 1024px) {
  .sl-intro {
    padding: 56px 24px 0px;
  }
}

.sl-intro__text {
  font-family: DM Sans;
  font-size: 32px;
  font-weight: 200;
  color: #0c1788;
  text-align: center;
  max-width: 1137px;
  margin: 0 auto;
  line-height: normal;
  -webkit-font-smoothing: antialiased;
}

@media (max-width: 767px) {
  .sl-intro__text {
    font-size: 20px;
  }
  .sl-intro {
    padding: 32px 16px 0px;
  }
}

@media (min-width: 768px) {
  .sl-intro__text {
    font-size: 24px;
  }
}

@media (min-width: 1024px) {
  .sl-intro__text {
    font-size: 32px;
  }
}

/* ═══════════════════════════════════════
   STORE SECTIONS
═══════════════════════════════════════ */
.sl-store-section {
  padding: 36px 0;
}

@media (min-width: 768px) {
  .sl-store-section {
    padding: 48px 0;
  }
}

@media (min-width: 1024px) {
  .sl-store-section {
    padding: 50px 0;
  }
}

.sl-store-section+.sl-store-section {
  padding-top: 0;
}

.sl-img-placeholder {
  background: #d9d9d9;
  border-radius: 10px;
  width: 100%;
  /* max-width: 500px; */
  aspect-ratio: 500 / 350;
  height: auto;
}

.sl-img-placeholder img {
  border-radius: 10px;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (min-width: 1024px) {

  .sl-img-placeholder,
  .sl-img-placeholder img {
    width: 100%;
    height: 350px;
  }
}

.sl-body-text {
  font-size: 14px;
  font-weight: 500;
  color: #50547c;
  line-height: 1.6;
  margin-bottom: 14px;
}

@media (min-width: 768px) {
  .sl-body-text {
    font-size: 17px;
    line-height: 24px;
    margin-bottom: 16px;
  }
}

@media (min-width: 1024px) {
  .sl-body-text {
    font-size: 16px;
  }
}

.sl-body-text:last-child {
  margin-bottom: 0;
}

.sl-detail-item {
  display: flex;
  align-items: flex-start;
  gap: 35px;
  margin-bottom: 24px;
}

@media (min-width: 768px) {
  .sl-detail-item {
    gap: 16px;
    margin-bottom: 32px;
  }
}

.sl-detail-item:last-child {
  margin-bottom: 0;
}

.sl-detail-icon {
  width: 36px;
  height: 36px;
  background: #f5f4fd;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #0c1788;
  font-size: 16px;
}

@media (min-width: 768px) {
  .sl-detail-icon {
    width: 40px;
    height: 40px;
    font-size: 18px;
  }
}

.sl-detail-label {
  font-size: 13px;
  font-weight: 500;
  color: #dc2328;
  margin: 0 0 3px;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .sl-detail-label {
    font-size: 15px;
    line-height: 24px;
  }
}

@media (min-width: 1024px) {
  .sl-detail-label {
    font-size: 16px;
  }
}

.sl-detail-value {
  font-size: 16px;
  font-weight: 500;
  color: #0c1788;
  margin: 0;
  line-height: 1.4;
}

@media (min-width: 768px) {
  .sl-detail-value {
    font-size: 18px;
    line-height: 28px;
  }
}

@media (min-width: 1024px) {
  .sl-detail-value {
    font-size: 20px;
  }
}

a.sl-detail-value:hover {
  color: #dc2328;
}

/* ═══════════════════════════════════════
   HOW TO ORDER
═══════════════════════════════════════ */
.sl-how-to-order {
  background: #EDF4FF;
  padding: 40px 0;
}

@media (min-width: 768px) {
  .sl-how-to-order {
    padding: 56px 0;
  }
}

@media (min-width: 1024px) {
  .sl-how-to-order {
    padding: 75px 0;
  }
}

.sl-how-to-order__title {
  font-size: 24px;
  font-weight: 700;
  color: #0c1788;
  line-height: 1.3;
  margin-bottom: 16px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .sl-how-to-order__title {
    font-size: 28px;
  }
}

@media (min-width: 768px) {
  .sl-how-to-order__title {
    font-size: 34px;
    line-height: 1.4;
    margin-bottom: 18px;
  }
}

@media (min-width: 1024px) {
  .sl-how-to-order__title {
    font-size: 40px;
    line-height: 55px;
    margin-bottom: 20px;
  }
}

.sl-how-to-order__text {
  font-size: 14px;
  font-weight: 500;
  color: #0c1788;
  line-height: 1.6;
  margin-bottom: 14px;
}

@media (min-width: 768px) {
  .sl-how-to-order__text {
    font-size: 17px;
    line-height: 1.65;
    margin-bottom: 16px;
  }
}

@media (min-width: 1024px) {
  .sl-how-to-order__text {
    font-size: 20px;
    line-height: 28px;
  }
}

.sl-how-to-order__text .red {
  color: #dc2328;
  font-size: inherit;
  font-weight: 700;
}

@media (min-width: 1024px) {
  .sl-how-to-order__text .red {
    font-size: 20px;
  }
}

.sl-how-to-order__text .note {
  font-size: 13px;
  line-height: 1.5;
}

@media (min-width: 768px) {
  .sl-how-to-order__text .note {
    font-size: 14px;
  }
}

@media (min-width: 1024px) {
  .sl-how-to-order__text .note {
    font-size: 16px;
    line-height: 20px;
  }
}

.sl-how-to-order__text:last-child {
  margin-bottom: 0;
}

.sl-order-card {
  background: #fff;
  border-radius: 10px;
  /* width: 500px;
      min-height: 460px; */
}

@media (min-width: 1024px) {
  .sl-order-card img {
    border-radius: 10px;
    width: 500px;
    min-height: 460px;
  }
}



/* ═══════════════════════════════════════
   SAME DAY DELIVERY
═══════════════════════════════════════ */
/* .sl-sameday {
      padding: 40px 0 32px;
    }

    @media (min-width: 768px) {
      .sl-sameday {
        padding: 56px 0 44px;
      }
    }

    @media (min-width: 1024px) {
      .sl-sameday {
        padding: 30px;
      }
    } */

.sl-sameday__row {
  display: flex;
 flex-direction: row;
  align-items: stretch;
  gap: 0;
}

@media (max-width: 1023px) {
  .sl-sameday__row {
    /* padding-top: 10px; */
    flex-direction: column;
    align-items: center;
  }

}

.sl-sameday__col {
  flex: 1;
  padding: 0px;
  display: flex;
  align-items: center;
  gap: 20px;
}

 .sl-sameday__col:first-child {
    padding-left: 0;
    justify-content: center;
    background-color: #FFF5E9 !important;
    padding-top: 45px;
    padding-bottom: 30px;
  }

  .sl-sameday__col:last-child {
    padding-right: 0;
    background-color: #FFFCF7;
    padding-top: 45px;
    padding-bottom: 30px;
  }

.delivery-van-image{
width: 100% !important;
height: 100%!important;
}

.right-collection-section{
  background-color: #FFFCF7;
}

.right-delivery-section{
  background-color: #FFF5E9;
}

.right-image-padding{
  padding-left: 10%;
}

@media (max-width: 1023px) {
  .right-image-padding{
  padding-left: 0% !important;
}
}







@media (max-width: 767px) {
.right-delivery-section{
  padding-top: 25px;
}
}



.sl-sameday__icon {
 width: 196.658px;
height: 118.737px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0;
}

@media (max-width: 767px) {
  .sl-sameday__icon {
  width: 80px;
height: 80px;
  }
}

.sl-sameday__heading {
  font-size: 22px;
  font-weight: 700;
  /* line-height: 1.25; */
  margin: 0 0 12px;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .sl-sameday__heading {
    font-size: 26px;
  }
}

@media (min-width: 768px) {
  .sl-sameday__heading {
    font-size: 28px;
    margin: 0 0 14px;
  }
}

@media (min-width: 1024px) {

  .sl-sameday__heading,
  .sl-sameday__heading .red,
  .sl-sameday__heading .navy {
    font-size: 32px;
  }
}

.sl-sameday__heading .red {
  color: #dc2328;

  display: block;
}

.sl-sameday__heading .navy {
  color: #0c1788;
  display: block;
}

.sl-sameday__desc {
  font-size: 13px;
  font-weight: 500;
  color: #0c1788;
  line-height: 1.6;
  max-width: 100%;
}

@media (min-width: 768px) {
  .sl-sameday__desc {
    font-size: 15px;
  }
}

@media (min-width: 1024px) {
  .sl-sameday__desc {
    font-size: 16px;
    line-height: 20px;
    max-width: 313px;
  }
}

.sl-divider-1 {
  width: 1px;
  height: 280px;
  background: rgba(135, 138, 170, 0.20);
}

@media (max-width: 767px) {
  .sl-divider-1 {
    display: none;
  }
}

.sl-divider {
  width: 1440px;
  height: 1px;
  background: rgba(135, 138, 170, 0.20);
}

/* ═══════════════════════════════════════
   CAKE DELIVERY NEAR YOU
═══════════════════════════════════════ */
.sl-delivery {
  padding: 40px 0 48px;
}

@media (min-width: 768px) {
  .sl-delivery {
    padding: 56px 0 68px;
  }
}

@media (min-width: 1024px) {
  .sl-delivery {
    padding: 50px 0px 90px;
  }
}

.sl-delivery__title {
  font-size: 24px;
  font-weight: 700;
  color: #0C1788;
  text-align: center;
  -webkit-font-smoothing: antialiased;
}

@media (min-width: 480px) {
  .sl-delivery__title {
    font-size: 28px;
  }
}

@media (min-width: 768px) {
  .sl-delivery__title {
    font-size: 34px;
  }
}

@media (min-width: 1024px) {
  .sl-delivery__title {
    font-size: 40px;
  }
}

.sl-delivery__sub {
  font-size: 13px;
  font-weight: 600;
  color: #554343;
  line-height: 1.6;
  text-align: center;
  margin-bottom: 28px;
}

@media (min-width: 768px) {
  .sl-delivery__sub {
    font-size: 15px;
    margin-bottom: 36px;
  }
}

@media (min-width: 1024px) {
  .sl-delivery__sub {
    font-size: 16px;
    line-height: 28px;
    margin-bottom: 40px;
  }
}

.sl-pills-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-bottom: 10px;
}

@media (min-width: 768px) {
  .sl-pills-row {
    gap: 14px;
    margin-bottom: 14px;
  }
}

@media (min-width: 1024px) {
  .sl-pills-row {
    gap: 16px;
    margin-bottom: 16px;
  }
}

.sl-pills-row:last-child {
  margin-bottom: 0;
}

.sl-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 130px;
  height: 42px;
  padding: 0 16px;
  /* background: #ffe2e2; */
  background: #DADDFF;
  border-radius: 100px;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: #0c1788;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
}

@media (min-width: 480px) {
  .sl-pill {
    min-width: 150px;
    height: 46px;
    font-size: 16px;
    padding: 0 20px;
  }
}

@media (min-width: 768px) {
  .sl-pill {
    min-width: 170px;
    height: 48px;
    font-size: 18px;
    padding: 0 22px;
  }
}

@media (min-width: 1024px) {
  .sl-pill {
    min-width: 185px;
    height: 50px;
    font-size: 20px;
    padding: 0 24px;
  }
}

.sl-pill:hover {
  background: #0c1788;
  color: #fff;
  transform: translateY(-2px);
}

.bg-auth {
  background-color: #FEE8D5 !important
}

.news-letter-form {
  background-color: white;
  padding: 40px;
  margin: 40px 0px;
}

@media (max-width: 991px) {
  .news-letter-form {
    padding: 30px;
    margin: 40px 20px;
  }
}

.was-price {
  color: var(--cb-red);
  text-decoration: line-through;
  font-size: 16px;
font-style: normal;
font-weight: 700;
}

.discount {
  color: var(--cb-navy);
}

.error{
  color: var(--cb-red);
}
@media (min-width: 992px) and (max-width: 1199.98px) { 
  total-val {
    font-size: 16px;
}
.config-textarea {
    font-size: 12px;
}
.radio-opts {
   margin-bottom: 10px;
}
.config-section {
  padding: 20px 20px;
}
  .product-title-padding {
    padding: 20px 20px;
    width: 100%;
}
.size-grid {
  gap: 10px;
}
}

@media (max-width: 480px) {
.config-section {
  padding: 20px 15px;
}
  .product-title-padding {
    padding: 20px 15px;
    width: 100%;
}
.size-grid {
  gap: 10px;
}
}
@media (max-width: 480px){
.ci-title {
  font-size: 16px;
}
}
@media (max-width: 768px){
.newsletter-form-button {
 margin-top: 15px;
}
}
.wedding-cake-form{
  background: rgba(236, 237, 249, 0.4);
  padding: 4rem 0px;
}
.wedding-cake-form-row{
gap: 2rem;;
}
.wedding-form{
  background-color: white;
  padding: 30px;
  border-radius: 20px;
}
.wedding-form .form-control{
  padding: 0.75rem;
  border: 2px solid #D3D6F4;
}
.btn-radius{
  border-radius: 100px;
}
.wedding-cake-image{
width: 100%;
height: 100%;
border-radius: 10px;
overflow: hidden;
background-color: white;
}
.wedding-cake-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  border-radius: 10px;

}
.wedding-cake-title{
  color: #0C1788;
font-size: 40px;
font-style: normal;
font-weight: 700;
}
.wedding-cake-description{
  color: #434453;
font-size: 16px;
font-style: normal;
font-weight: 600;
line-height: normal;
margin-bottom: 0px;
}


/*corporate*/
.corporate-sub-section-heading {
    color: #0C1788;
    font-family: "DM Sans";
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
  }

  .corporate-sub-section-text {
    color: #554343;
    text-align: center;
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    width: 720px;
    margin-top: 15px;
  }

  .corporate-title-section {
    padding: 30px 0 45px;
    background-color: white;
  }

  .corporate-heading-section {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .what-offer-section {
    background-color: #FFEBEB;
    padding: 30px 0 50px 0;

  }
  .what-offer-section-1 {
    background-color: #ECEDF9;
  }
  .what-offer-section-2 {
    background-color: rgba(250, 212, 186, 0.3);
  }
  

  .what-offer-title {
    color: #0C1788;
    font-size: 40px;
    font-style: normal;
    font-weight: 700;
    line-height: 55px;
    /* 137.5% */
  }

  .what-product-image {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 10px;
  }

  .offer-category-name {
    color: #DC2328;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    margin-bottom: 0px;
    margin-top: 10px;
  }

  .offer-category-text {
    color: #554343;
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-bottom: 0px;
    margin-top: 8px;
  }

  .why-card {
    border: 1px solid #ddd;
    border-radius: 10px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 15px 0px;
  }
  .corporate-heading-section .col-lg-4:nth-child(1) .why-card {
    background: rgba(255, 197, 197, 1);
  }

  .corporate-heading-section .col-lg-4:nth-child(2) .why-card {
    background: rgba(226, 228, 255, 1);
  }

  .corporate-heading-section .col-lg-4:nth-child(3) .why-card {
    background: rgba(250, 212, 186, 1);
  }

  .corporate-heading-section .col-lg-4:nth-child(4) .why-card {
    background: rgba(197, 219, 196, 1);
  }

  .corporate-heading-section .col-lg-4:nth-child(5) .why-card {
    background: rgba(236, 237, 249, 1);
  }

  .why-card-title {
    color: #554343;
    text-align: center;
    font-family: "DM Sans";
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    width: 233px;
    margin-bottom: 0px;
  }

  .how-title {
    color: #0C1788;
    text-align: center;
    font-size: 24px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-bottom: 0px;
  }

  .how-text {
    color: #554343;
    text-align: center;
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    width: 233px;
    margin-bottom: 0px;
  }


  .step-number span {
    width: 77px;
    height: 77px;
    border-radius: 50%;
    /* background-color: #ffffff; */
    display: flex;
    align-items: center;
    justify-content: center;
    color: #FFFFFF;
    font-size: 40px;
    font-style: normal;
    font-weight: 700;
    margin-bottom: 5px;
  }
  .what-offer-section .how-section:nth-child(1) .step-number span {
    background-color: #D2D5FF;
  }

  .what-offer-section .how-section:nth-child(3) .step-number span {
    background-color: #979FFE;
  }

  .what-offer-section .how-section:nth-child(5) .step-number span {
    background-color: #4C53AB;
  }

  .how-section {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
  }

  .connector-line {
    width: 233px;
  }

  .business-image {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 10px;
  }

  .businees-title {
    color: #0C1788;
    font-size: 40px;
    font-style: normal;
    font-weight: 700;
    line-height: 41px;
    margin-bottom: 9px;
  }
  @media (max-width: 575.98px) {
    .businees-title {
        font-size: 30px;
    }
  }

  .custom-list {
    padding-left: 1.25rem;
    /* ADD THIS - gives space for bullets */
    margin: 0;

  }

  .custom-list li::before {
    color: #554343;
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
    line-height: 28px;
    margin-right: 8px;
  }

  .business-item {
    color: #554343;
    font-size: 18px;
    font-style: normal;
    font-weight: 600;
  }

  .business-section-gap {
    gap: 2rem;
    margin: 20px 0px;
  }

  .bussiness-create-text {
    color: #554343;
    font-size: 14px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin: 20px 0px;
  }
  .company-number{
   color: #0C1788;
font-size: 30px;
font-style: normal;
font-weight: 600;
line-height: normal;
margin-bottom: 0px;
  }
  .company-phone-lines{
    color: #554343;
font-family: "DM Sans";
font-size: 14px;
font-style: normal;
font-weight: 600;
line-height: normal;
margin-bottom: 0px;
  }
  .company-email-contact{
  color: #DC2328;
  font-size: 24px;
  font-style: normal;
  font-weight: 600;
  line-height: normal;
  margin-top: 20px;
  margin-bottom: 0px;
  }
  .contact-form-section{
    background-color: white;
    border-radius: 20px;
  }
  .corporate-main-heading-section{
    background-color: rgba(240, 246, 255, 1);
    padding: 20px 0 35px;
  }
  .corporate-main-section-text{
    color: #554343;
font-size: 14px;
font-style: normal;
font-weight: 600;
line-height: normal;
  }
  .btn-touch-btn{
    color: white;
font-size: 16px;
font-style: normal;
font-weight: 700;
line-height: normal;
    border-radius: 100px;
    background-color: #DC2328;
  }
  .btn-touch-btn:hover {
    background: #EE2938;
   
}
  @media (min-width: 991px) and (max-width: 1360px) { 
  .step-number span {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background-color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #DC2328;
    font-size: 30px;
    font-style: normal;
    font-weight: 700;
    margin-bottom: 5px;
  }
   .how-text {
    font-size: 12px;
    max-width: 180px;
  }
  }
    @media (min-width: 991px) and (max-width: 1151px) { 
      .connector-line {
    width: 150px;
  }
  .how-title {
    font-size: 20px;
  }
  }
   @media (max-width: 990px) { 
      .connector-line {
    width: 100px;
  }
  .how-title {
    font-size: 18px;
  }
  .step-number span {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #DC2328;
    font-size: 20px;
    font-style: normal;
    font-weight: 700;
    margin-bottom: 5px;
  }
   .how-text {
    font-size: 10px;
    max-width: 100px;
  }
  }
    @media (max-width: 575.98px) {
 .connector-line {
    display: none;
  }
    .how-text {
    font-size: 8px;
    max-width: 100px;
  }
   .how-title {
    font-size: 15px;
  }
  .what-offer-title {
    font-size: 30px;
  }
    .corporate-sub-section-text {
   
    width: 100%;
    margin-top: 15px;
  }
  .what-product-image{
    margin-top: 10px;
  }
  .offer-category-text {
    margin-top: 2px;
  }
     }
  .send-btn{
    width: 100%;
  }
  .corporate-form{
    max-width: 100%;
  }
  .corporate-form .form-textarea {
    border: 2px solid #D3D6F4;
  }
   .corporate-form .form-input {
    border: 2px solid #D3D6F4;
  }
  .corporate-form .text-danger {
    margin-bottom: 0px;
  }
  @media (max-width: 370px) {
  .navbar-brand {
    margin-right: 5px;
  }
 .container-xl, .topbar-container, .sl-sameday__col {
        padding-left: 3%;
        padding-right: 3%;
    }
     .wave-text-container{
     padding-left: 3% !important;
  }
  }
  @media (max-width: 1340px){
.nav-link{
      padding: 16px 0px !important;
}
.nav-item {
  
  padding: 16px 10px !important;
}
  }
    @media (min-width: 992px) and  (max-width: 1120px){
.nav-link{
      padding: 16px 0px !important;
    font-size: 12.5px;
}
.nav-item {
  font-size: 12.5px;
  padding: 16px 10px !important;
}
    .nav-icons {
        gap: 10px;
    }
  }
  .search-input:-webkit-autofill,
.search-input:-webkit-autofill:hover,
.search-input:-webkit-autofill:focus,
.search-input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0px 1000px #ffffff inset !important;
  box-shadow: 0 0 0px 1000px #ffffff inset !important;
  -webkit-text-fill-color: #000 !important;
  background-color: #ffffff !important;
}
.size-image{
  width:80%;
}
.cart-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.50); /* page goes to ~25% visibility */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 1040;
 
}

.cart-overlay.active {
  opacity: 1;
  visibility: visible;
}
.key-update-icing{
  margin-top: -5px;
}
.desktop-icing{
  display: block;
}
.mobile-icing{
  display: none !important;
}
.tab-icing{
  display: none !important;
}
   @media (max-width: 991px){
.desktop-icing{
  display: none !important;
}
.signup-text{
  width: 100% !important;
}

   }


@media (max-width:767px) {
   .mobile-icing{
  display: block !important;
}
.newsletter-form input, .newsletter-form-button{
   width: 100% !important;
   padding: 1rem;
}
}
@media (min-width:768px) and (max-width: 991px){
   .tab-icing{
  display: block !important;
}
.newsletter-section {
  padding: 30px 0 30px;
}
.newsletter-form-button{
  width: 100% !important;
   padding: 1rem;
}
.newsletter-form input{
  padding: 1rem;
}
  .signup-text {
    margin-top: 15px;
    margin-bottom: 15px;
    margin-left: 0px;
  }
   }
.postcode-popup-heading{
  color: #434453;
    font-family: Poppins;
    font-size: 30px;
    font-style: normal;
    font-weight: 600;
    line-height: normal;
    margin-bottom: 20px;
    display: flex;
    justify-self: center;
}
.postcode-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.5);
  /* backdrop-filter: blur(4px);          
  -webkit-backdrop-filter: blur(4px);    */
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  z-index: 9999;
}

.postcode-overlay.active {
  opacity: 1;
  visibility: visible;
  /* background: rgba(255, 255, 255, 0.5); */
}
.drawer-top-actions{
  display:flex;
  width:100%;
  /* border-top:1px solid #eee;
  border-bottom:1px solid #eee; */
}

.top-action{
  flex:1;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:14px 10px;
  background:#FFF4EA;
  color: #554343;
  font-size: 18px;
  font-style: normal;
  font-weight: 600;
  line-height: 20px; 
}


.top-account-action{
  background: #FFF4EA;
}
.drawer-logo{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  
}
/* Inline expandable section (secondary panel) */
.drawer-inline-section .drawer-inline-trigger {
  display: block;
  cursor: pointer;
  padding: 10px 72px 10px 20px;
  color: #554343;
  font-family: "DM Sans";
  font-size: 24px;
  font-style: normal;
  font-weight: 700;
}

.drawer-inline-trigger .arrow {
  font-style: normal;
  margin-right: 6px;
  color: #0C1788;
}

.drawer-inline-sublist {
  list-style: none;
  padding: 0 0 0 20px;
  margin: 0;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}

.drawer-inline-section.open .drawer-inline-sublist {
  max-height: 700px; 
}
.drawer-inline-section.open .drawer-inline-trigger {
  color:#DC2328;
}

.drawer-inline-sublist li a {
  display: block;
  padding: 6px 70px 6px 20px;
  text-decoration: none;
  color: #554343;
font-family: "DM Sans";
font-size: 20px;
font-style: normal;
font-weight: 700;

}

/* Bold links for items without children on secondary panel */
.drawer-panel--secondary .drawer-nav > li > a {
  color: #554343;
font-size: 24px;
font-style: normal;
font-weight: 700;
}
 .xptile-wrapper {
      width: 100%;
      margin-bottom: 15px;
    }

    .xptile-header {
      padding-bottom: 10px;
      background: white;
      cursor: pointer;
      display: flex;
      justify-content: space-between;
      align-items: center;
      border-bottom: 1px solid #DCDCDC;
      color: #DC2328;
      font-size: 22px;
      font-style: normal;
      font-weight: 600;
      line-height: normal;
    }

    .xptile-content {
      max-height: 0;
      overflow: hidden;
      transition: max-height 0.3s ease;
      padding: 0 16px;
      background: #ffffff;
    }
    .xptile-content ul{
      list-style: none;
      padding-left: 0;
    }

    .xptile-content ul li {
      color: #655A57;
      font-family: "DM Sans";
      font-size: 16px;
      font-style: normal;
      font-weight: 600;
    }

    .xptile-wrapper.xp-open .xptile-content {
      max-height: 200px;
    }

    .xptile-icon {
      transition: transform 0.3s ease;
    }

    .xptile-wrapper.xp-open .xptile-icon {
      transform: rotate(180deg);
    }
     .xptile-wrapper.xp-open .xptile-header {
      border-bottom: none;
    }
    .reach-us-header{
      border-bottom: none;
      margin-bottom: 0px;
    }
  .wedding-desc{
    color: #0C1788;
    text-align: center;
    /* font-size: 18px; */
    font-size: clamp(14px, 2vw, 14px);
    font-style: normal;
    font-weight: 200;
    line-height: normal;
  }
  /* @media (max-width: 575.98px) {
    .wedding-desc{
      font-size: 14px;
       font-weight: 200;
    }
  } */

  .new-arriavls-heading{
    text-align: center !important;
  }
  @media (min-width: 769px) and (max-width: 1279px){
    .hero-content {
      padding-top: 60px !important;
    }
  }
  .break-banner-container {
    position: relative;
}

.break-banner-content {
    position: absolute;
    top: 15%;
    left: 20%;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px; /* spacing between logo and text */
}

.break-banner-logo {
    display: block;
    max-width: 150px; /* adjust to your logo's actual size */
    height: auto;
}

.break-banner-text {
    color: #786345;
text-align: center;
font-size: 40px;
font-style: normal;
font-weight: 600;
    margin: 0; 
    padding-top: 20px;
     line-height: 1.3;   
}
.banner-hero-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: white;
  padding: 0 clamp(3rem, 5vw, 5rem);
  border-radius: 50px;
  text-decoration: none;
  transition: all 0.3s ease;
  margin-top: 20px;
  height: 60px;
  color: #786345;
text-align: center;
font-size: 20px;
font-style: normal;
font-weight: 600;
}

.banner-hero-btn:hover {
  background: #786345;
  color: white;
}

.banner-hero-btn:active {
  transform: scale(0.95);
}

@media (min-width: 1200px) and (max-width: 1399.98px) {
  .break-banner-content {
    top: 10%;
    left: 10%;
  }
.break-banner-text {
font-size: 35px;
}
}
@media (min-width: 992px) and (max-width: 1199.98px) {
    .break-banner-content {
    top: 10%;
    left: 8%;
  }
.break-banner-text {
font-size: 32px;
}
}
@media (min-width: 768px) and (max-width: 991.98px) {
       .break-banner-content {
    top: 10%;
    left: 8%;
  }
.break-banner-text {
font-size: 28px;
}
.break-banner-logo {
  height: 80px;
}
.banner-hero-btn {
height: 50px;
  font-size: 16px;
}
}
@media (max-width: 767.98px) {
    .break-banner-content{
    display: none !important;
    }
}
.gallery-thumb video {
    width: 100%;
    height: 100%;
    object-fit: cover; /* fills the box without distorting, crops if needed */
    display: block;    /* removes inline bottom gap */
}
video::-webkit-media-controls {
    display: none !important;
}

video::-webkit-media-controls-panel {
    display: none !important;
}

video {
    -webkit-user-select: none;
    user-select: none;
}