/**
 * Homepage — Gill Sweets and Dairy identity (distinct from reference template) + motion.
 */

/* ----- Atmosphere & section rhythm ----- */
body.home {
  --gs-home-glow: rgba(200, 138, 43, 0.14);
  --gs-home-ink: #2f1a10;
  --gs-reveal-duration: 1.25s;
  --gs-reveal-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --gs-grid-reveal-duration: 1.15s;
  --gs-grid-stagger-step: 0.14s;
}

/* Reference hero (old template) overlaps image + copy — do not clip on production until DB is restored */
body.home .page-content:has(.gs-reference-hero) {
  overflow: visible;
}

body.home .page-content {
  position: relative;
  background:
    radial-gradient(ellipse 80% 50% at 10% 0%, rgba(247, 215, 181, 0.35), transparent 55%),
    radial-gradient(ellipse 60% 40% at 95% 20%, rgba(184, 92, 56, 0.08), transparent 50%),
    linear-gradient(180deg, #fffaf5 0%, #fff4e8 48%, #faf0e4 100%);
}

body.home .page-content::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.45;
  background-image: radial-gradient(rgba(71, 40, 24, 0.07) 0.8px, transparent 0.8px);
  background-size: 22px 22px;
  mask-image: linear-gradient(180deg, #000 0%, transparent 92%);
}

body.home .site-main {
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
}

body.home .page-content {
  overflow: clip;
}

/* ----- Section rhythm (real class names from Elementor) ----- */
body.home .gs-page > .e-con-inner > .e-con.gs-section-light,
body.home .gs-page > .e-con-inner > .e-con.gs-section-cream,
body.home .elementor-element.gs-section-light,
body.home .elementor-element.gs-section-cream,
body.home .elementor-element.gs-sweets-section,
body.home .elementor-element.gs-kaju-section {
  padding: clamp(48px, 6vw, 72px) 0 !important;
}

body.home .elementor-element.gs-section-light {
  position: relative !important;
  isolation: isolate;
  background:
    linear-gradient(165deg, #fffdf9 0%, #faf3e8 55%, #f3e6d4 100%) !important;
  overflow: hidden !important;
}

body.home .elementor-element.gs-section-light::before {
  content: "";
  position: absolute;
  top: -120px;
  right: -80px;
  width: min(420px, 55vw);
  height: min(420px, 55vw);
  border-radius: 50%;
  background: radial-gradient(circle, var(--gs-home-glow), transparent 68%);
  pointer-events: none;
  z-index: 0;
}

body.home .elementor-element.gs-section-cream {
  background: linear-gradient(165deg, #fff8f0 0%, #f5e8d6 100%) !important;
}

body.home .elementor-element.gs-sweets-section {
  position: relative !important;
  isolation: isolate;
  background:
    linear-gradient(145deg, #3b2417 0%, #5c3424 38%, #7a4530 100%) !important;
  color: #fff8ef;
  overflow: hidden !important;
}

body.home .elementor-element.gs-sweets-section::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.2;
  background-image:
    repeating-linear-gradient(
      -12deg,
      transparent,
      transparent 18px,
      rgba(255, 248, 239, 0.04) 18px,
      rgba(255, 248, 239, 0.04) 19px
    );
  z-index: 0;
}

body.home .elementor-element.gs-sweets-section .elementor-heading-title,
body.home .elementor-element.gs-sweets-section .elementor-widget-text-editor,
body.home .elementor-element.gs-sweets-section .elementor-widget-container {
  color: #fff8ef !important;
}

body.home .elementor-element.gs-sweets-section .elementor-widget-text-editor,
body.home .elementor-element.gs-sweets-section .gs-centered-copy .elementor-widget-container {
  opacity: 0.9;
  color: rgba(255, 248, 239, 0.92) !important;
}

body.home .elementor-element.gs-kaju-section {
  position: relative !important;
  background:
    linear-gradient(180deg, #f8f6ef 0%, #f2f7e8 42%, #faf4e6 100%) !important;
  overflow: hidden !important;
}

body.home .elementor-element.gs-kaju-section::before {
  content: "";
  position: absolute;
  bottom: -60px;
  left: -40px;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(111, 127, 66, 0.16), transparent 70%);
  pointer-events: none;
}

/* Sweets section — full-bleed background, centred content */
body.home .elementor-element.gs-sweets-section {
  width: 100% !important;
  max-width: 100% !important;
  margin-inline: 0 !important;
  overflow: hidden !important;
}

body.home .elementor-element.gs-section-light > .elementor-element,
body.home .elementor-element.gs-section-light > .e-con,
body.home .elementor-element.gs-sweets-section > .elementor-element,
body.home .elementor-element.gs-kaju-section > .elementor-element,
body.home .elementor-element.gs-kaju-section > .e-con {
  position: relative;
  z-index: 1;
}

body.home .elementor-element.gs-sweets-section > .elementor-element {
  width: min(calc(100% - 32px), 1240px) !important;
  max-width: 1240px !important;
  margin-inline: auto !important;
}

/* Sweets carousel — gutter arrows, 4 slides, equal card height */
body.home .elementor-element.gs-sweets-gallery {
  position: relative !important;
  width: 100%;
  max-width: 1240px;
  margin-inline: auto !important;
  padding: 0 58px 6px !important;
  box-sizing: border-box;
}

body.home .elementor-element.gs-sweets-gallery .elementor-widget-container {
  position: relative;
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body.home .elementor-element.gs-sweets-gallery .elementor-image-carousel-wrapper.swiper {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 0 10px !important;
  overflow: hidden !important;
  position: relative !important;
}

/* Vertically center on full slide (image + caption), not image-only */
body.home .elementor-element.gs-sweets-gallery .elementor-swiper-button {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 48px !important;
  height: 48px !important;
  margin: 0 !important;
  border-radius: 999px;
  background: #8a2f25 !important;
  color: #fff !important;
  box-shadow: 0 10px 22px rgba(138, 47, 37, 0.18);
  z-index: 4;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.home .elementor-element.gs-sweets-gallery.elementor-pagination-position-outside .elementor-swiper-button {
  top: calc(50% - 8px) !important;
}

body.home .elementor-element.gs-sweets-gallery .elementor-swiper-button-prev {
  left: 0 !important;
  right: auto !important;
}

body.home .elementor-element.gs-sweets-gallery .elementor-swiper-button-next {
  right: 0 !important;
  left: auto !important;
}

body.home .elementor-element.gs-sweets-gallery .elementor-swiper-button svg {
  width: 22px;
  height: 22px;
}

body.home .elementor-element.gs-sweets-gallery .swiper-pagination {
  position: relative !important;
  bottom: auto !important;
  margin-top: 12px !important;
}

body.home .elementor-element.gs-sweets-gallery .swiper-pagination-bullet-active {
  background: #8a2f25 !important;
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide {
  height: auto;
  box-sizing: border-box;
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide-inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  border-radius: 22px;
  background: linear-gradient(180deg, #fff 0%, #fff6ea 100%);
  border: 1px solid rgba(255, 248, 239, 0.35);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.08) inset,
    0 16px 36px rgba(0, 0, 0, 0.22);
  transition:
    transform 0.35s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.35s ease;
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide:hover .swiper-slide-inner {
  transform: translateY(-6px);
  box-shadow:
    0 0 0 1px rgba(255, 248, 239, 0.2) inset,
    0 22px 44px rgba(0, 0, 0, 0.28);
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide-image {
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide:hover .swiper-slide-image {
  transform: scale(1.05);
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide-image {
  display: block;
  width: 100%;
  height: 200px;
  min-height: 200px;
  max-height: 200px;
  object-fit: cover;
  object-position: center center;
}

body.home .elementor-element.gs-sweets-gallery .swiper-slide-inner {
  min-height: 280px;
}

body.home .elementor-element.gs-sweets-gallery .elementor-image-carousel-caption {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 5.25em;
  margin: 0;
  padding: 14px 12px 18px;
  text-align: center;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(20px, 2vw, 26px);
  font-style: italic;
  line-height: 1.15;
  color: var(--gs-home-ink);
}

@media (max-width: 767px) {
  body.home .elementor-element.gs-sweets-gallery {
    padding: 0 44px 6px !important;
  }

  body.home .elementor-element.gs-sweets-gallery .elementor-swiper-button {
    width: 40px !important;
    height: 40px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
  }

  body.home .elementor-element.gs-sweets-gallery.elementor-pagination-position-outside .elementor-swiper-button {
    top: calc(50% - 6px) !important;
  }

  body.home .elementor-element.gs-sweets-gallery .swiper-slide-image {
    height: 180px;
    min-height: 180px;
    max-height: 180px;
  }
}

body.home .elementor-element.gs-section-light > .e-con-inner,
body.home .elementor-element.gs-section-cream > .e-con-inner,
body.home .elementor-element.gs-kaju-section > .e-con-inner {
  width: min(calc(100% - 32px), 1240px) !important;
  max-width: 1240px;
  margin-inline: auto !important;
}

/* Kaju grid — square images, aligned labels (see theme.css .gs-kaju-image) */
body.home .elementor-element.gs-kaju-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 22px !important;
  align-items: stretch !important;
}

@media (max-width: 1100px) {
  body.home .elementor-element.gs-kaju-grid > .e-con-inner {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767px) {
  body.home .elementor-element.gs-kaju-grid > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 479px) {
  body.home .elementor-element.gs-kaju-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
    max-width: 320px;
    margin-inline: auto !important;
  }
}

/* ----- Section headings (Gill ornament, not generic reference) ----- */
body.home .elementor-element.gs-centered-title,
body.home .elementor-element.gs-kaju-title {
  position: relative;
  z-index: 1;
}

body.home .elementor-element.gs-centered-title::before,
body.home .elementor-element.gs-kaju-title::before {
  display: block;
  width: fit-content;
  margin: 0 auto 12px;
  padding: 6px 14px;
  border-radius: 999px;
  font-family: "Manrope", sans-serif;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gs-gold-deep);
  background: rgba(255, 252, 247, 0.92);
  border: 1px solid rgba(200, 138, 43, 0.28);
  box-shadow: 0 8px 20px rgba(71, 40, 24, 0.06);
}

/* Brand label: set via wp_head from gill_sweets_brand_name() (inc/brand.php). */

body.home .elementor-element.gs-kaju-title::before {
  content: "Premium Kaju";
}

body.home .elementor-element.gs-sweets-section .elementor-element.gs-centered-title::before {
  color: #f7d7b5;
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 248, 239, 0.22);
}

body.home .elementor-element.gs-centered-title .elementor-heading-title,
body.home .elementor-element.gs-kaju-title .elementor-heading-title {
  margin: 0 0 10px !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: clamp(36px, 4.6vw, 58px) !important;
  font-weight: 600 !important;
  line-height: 1.04 !important;
  text-align: center !important;
  color: var(--gs-brown) !important;
  text-wrap: balance;
}

body.home .elementor-element.gs-sweets-section .gs-centered-title .elementor-heading-title {
  color: #fff8ef !important;
}

body.home .elementor-element.gs-centered-title .elementor-heading-title::after,
body.home .elementor-element.gs-kaju-title .elementor-heading-title::after {
  content: "";
  display: block;
  width: 72px;
  height: 3px;
  margin: 14px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--gs-gold), transparent);
}

body.home .elementor-element.gs-sweets-section .gs-centered-title .elementor-heading-title::after {
  background: linear-gradient(90deg, transparent, #f7d7b5, transparent);
}

body.home .elementor-element.gs-centered-copy .elementor-widget-container,
body.home .elementor-element.gs-kaju-copy .elementor-widget-container {
  max-width: 40rem !important;
  margin: 0 auto 28px !important;
  text-align: center !important;
  font-family: "Manrope", sans-serif !important;
  font-size: clamp(15px, 1.7vw, 17px) !important;
  font-weight: 500 !important;
  line-height: 1.75 !important;
  color: var(--gs-brown-soft) !important;
}

/* Bestsellers heading — space between letters */
body.home .elementor-element-gst012 .elementor-heading-title {
  letter-spacing: 0.14em;
  word-spacing: 0.28em;
}

/* ----- Bestsellers + gifting grids (gs-grid-4 / gs-reference-grid) ----- */
body.home .elementor-element.gs-reference-grid.e-con,
body.home .elementor-element.gs-grid-4.gs-reference-grid.e-con,
body.home .elementor-element.gs-reference-grid > .e-con-inner,
body.home .elementor-element.gs-grid-4.gs-reference-grid > .e-con-inner,
body.home .elementor-element-gst014.e-con {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.2vw, 26px) !important;
  align-items: stretch !important;
  width: min(calc(100% - 32px), 1240px) !important;
  max-width: 1240px;
  margin-inline: auto !important;
}

/* ----- Bestsellers — arched portrait frames (reference layout) ----- */
body.home .elementor-element-gst014.e-con {
  gap: clamp(12px, 1.8vw, 20px) !important;
  align-items: start !important;
}

body.home .elementor-element-gst014 > .e-con.e-child,
body.home .elementor-element-gst014 > .e-con.e-child > .e-con-inner,
body.home .elementor-element.gs-image-card.e-con,
body.home .elementor-element.gs-image-card > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}

body.home .elementor-element-gst014 .elementor-widget-text-editor {
  display: block !important;
  flex: 0 0 auto !important;
  width: 100% !important;
  max-width: min(100%, 260px) !important;
  margin: 0 auto !important;
  padding: 10px 6px 0 !important;
  text-align: center !important;
}

body.home .elementor-element-gst014 .elementor-widget-text-editor .elementor-widget-container {
  padding: 0 !important;
}

body.home .elementor-element-gst014 .gs-bestseller-name h3,
body.home .elementor-element-gst014 .gs-image-caption h3 {
  margin: 0 !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: clamp(20px, 2.1vw, 26px) !important;
  font-weight: 600 !important;
  line-height: 1.15 !important;
  color: var(--gs-brown) !important;
}

body.home .elementor-element-gst014 .gs-image-caption p {
  display: none !important;
}

body.home .elementor-element-gst014 .elementor-widget-image {
  position: relative !important;
  flex: 0 0 auto !important;
  width: 100% !important;
  max-width: min(100%, 260px);
  margin-inline: auto !important;
  aspect-ratio: 3 / 4 !important;
  overflow: hidden !important;
  line-height: 0 !important;
  /* Flatter arch than 50% semicircle */
  border-radius: 38% 38% 0 0 / 20% 20% 0 0 !important;
  border: 2px solid var(--gs-gold) !important;
  background: var(--gs-cream-strong);
  box-shadow:
    0 0 0 1px rgba(154, 99, 22, 0.22),
    0 16px 34px rgba(71, 40, 24, 0.12) !important;
  transition:
    transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.45s ease !important;
}

body.home .elementor-element-gst014 > .e-con.e-child:hover .elementor-widget-image {
  transform: translateY(-10px);
  box-shadow:
    0 0 0 1px rgba(154, 99, 22, 0.35),
    0 24px 44px rgba(71, 40, 24, 0.16) !important;
}

body.home .elementor-element-gst014 .elementor-widget-image > img,
body.home .elementor-element-gst014 .elementor-widget-image img {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

body.home .elementor-element-gst014 > .e-con.e-child:hover .elementor-widget-image img {
  transform: scale(1.04);
}

body.home .gs-sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* ----- Luxury gifting cards (Festive / Wedding / Hampers) ----- */
body.home .elementor-element.gs-gallery-card.e-con,
body.home .elementor-element.gs-gallery-card > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  height: 100% !important;
  gap: 12px !important;
  padding: 14px 14px 18px !important;
  border-radius: 22px !important;
  background: linear-gradient(165deg, #ffffff 0%, #fff8ef 100%) !important;
  border: 1px solid rgba(200, 138, 43, 0.22) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.92) inset,
    0 14px 34px rgba(71, 40, 24, 0.09) !important;
  overflow: hidden !important;
  transition:
    transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.32s ease !important;
}

body.home .gs-grid-visible .elementor-element-gst053 > .e-con.e-child:nth-child(even),
body.home .gs-grid-visible .elementor-element.gs-gallery-card.e-con:nth-child(even) {
  transform: translateY(-4px);
}

body.home .elementor-element.gs-gallery-card.e-con:hover,
body.home .elementor-element.gs-gallery-card > .e-con-inner:hover {
  transform: translateY(-7px);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 22px 48px rgba(71, 40, 24, 0.13) !important;
}

body.home .elementor-element.gs-gallery-card .elementor-widget-image {
  flex: 0 0 auto !important;
  position: relative !important;
  width: 100% !important;
  margin: 0 !important;
  aspect-ratio: 1 / 1 !important;
  overflow: hidden !important;
  border-radius: 16px !important;
  line-height: 0 !important;
  box-shadow: 0 6px 18px rgba(71, 40, 24, 0.1);
}

body.home .elementor-element.gs-gallery-card .elementor-widget-image > img,
body.home .elementor-element.gs-gallery-card .elementor-widget-image img {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

body.home .elementor-element.gs-gallery-card.e-con:hover .elementor-widget-image img {
  transform: scale(1.05);
}

body.home .elementor-element.gs-gallery-card .elementor-widget-text-editor {
  flex: 1 1 auto !important;
  width: 100% !important;
  margin: 0 !important;
}

body.home .elementor-element.gs-gallery-card .elementor-widget-text-editor .elementor-widget-container {
  padding: 0 !important;
}

/* Caption lives inside text-editor HTML (.gs-gallery-caption), not on the widget */
body.home .elementor-element.gs-gallery-card .gs-gallery-caption {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  text-align: left;
}

body.home .elementor-element.gs-gallery-card .gs-gallery-caption h3 {
  margin: 0 0 10px;
  padding-bottom: 10px;
  font-family: "Cormorant Garamond", serif !important;
  font-size: clamp(22px, 2.35vw, 28px) !important;
  font-weight: 600 !important;
  line-height: 1.12 !important;
  color: var(--gs-brown) !important;
  position: relative;
}

body.home .elementor-element.gs-gallery-card .gs-gallery-caption h3::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--gs-gold), rgba(200, 138, 43, 0.15));
}

body.home .elementor-element.gs-gallery-card .gs-gallery-caption p {
  margin: 0;
  min-height: 3.25em;
  font-family: "Manrope", sans-serif !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
  color: var(--gs-brown-soft) !important;
}

/* ----- Blog section (stories & guides) ----- */
body.home .elementor-element.gst082.e-con,
body.home .elementor-element.gs-blog-section.e-con {
  position: relative !important;
  isolation: isolate;
}

body.home .elementor-element.gst082.e-con::before,
body.home .elementor-element.gs-blog-section.e-con::before {
  content: "";
  position: absolute;
  top: 12%;
  left: 50%;
  width: min(520px, 70vw);
  height: 240px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(ellipse, rgba(200, 138, 43, 0.1), transparent 70%);
  pointer-events: none;
  z-index: 0;
}

body.home .elementor-element.gs-blog-row.e-con,
body.home .elementor-element.gs-grid-3.gs-blog-row.e-con,
body.home .elementor-element.gs-blog-row.e-con > .e-con-inner,
body.home .elementor-element.gs-blog-row > .e-con-inner,
body.home .elementor-element.gs-grid-3.gs-blog-row > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.2vw, 28px) !important;
  align-items: stretch !important;
  width: min(calc(100% - 32px), 1240px) !important;
  max-width: 1240px;
  margin-inline: auto !important;
  position: relative;
  z-index: 1;
}

body.home .elementor-element.gs-blog-card-v2.e-con,
body.home .elementor-element.gs-blog-card-v2 > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  height: 100% !important;
  gap: 12px !important;
  padding: 14px 14px 18px !important;
  border-radius: 22px !important;
  background: linear-gradient(165deg, #ffffff 0%, #fff9f2 100%) !important;
  border: 1px solid rgba(200, 138, 43, 0.22) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.92) inset,
    0 14px 34px rgba(71, 40, 24, 0.09) !important;
  overflow: hidden !important;
  transition:
    transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.32s ease,
    border-color 0.32s ease !important;
}

body.home .elementor-element.gs-blog-card-v2.e-con::before {
  content: "";
  position: absolute;
  top: 0;
  left: 14px;
  right: 14px;
  height: 3px;
  border-radius: 0 0 6px 6px;
  background: linear-gradient(90deg, var(--gs-gold), var(--gs-rose), var(--gs-green));
  opacity: 0.85;
  z-index: 2;
  pointer-events: none;
}

body.home .gs-grid-visible .elementor-element-gst085 > .e-con.e-child:nth-child(2),
body.home .gs-grid-visible .elementor-element.gs-blog-card-v2.e-con:nth-child(2) {
  transform: translateY(-5px);
}

body.home .elementor-element.gs-blog-card-v2.e-con:hover,
body.home .elementor-element.gs-blog-card-v2 > .e-con-inner:hover {
  transform: translateY(-7px);
  border-color: rgba(200, 138, 43, 0.38) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 22px 48px rgba(71, 40, 24, 0.13) !important;
}

/* Nested visual container — flatten so only the image frame shows */
body.home .elementor-element.gs-blog-card-v2 .elementor-element.gs-blog-visual.e-con,
body.home .elementor-element.gs-blog-card-v2 .gs-blog-visual.e-con,
body.home .elementor-element.gs-blog-card-v2 .gs-blog-visual > .e-con-inner {
  flex: 0 0 auto !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

body.home .elementor-element.gs-blog-card-v2 .gs-blog-visual .elementor-widget-image {
  position: relative !important;
  width: 100% !important;
  margin: 0 !important;
  aspect-ratio: 16 / 10 !important;
  overflow: hidden !important;
  border-radius: 16px !important;
  line-height: 0 !important;
  box-shadow: 0 8px 22px rgba(71, 40, 24, 0.12);
}

body.home .elementor-element.gs-blog-card-v2 .gs-blog-visual .elementor-widget-image > img,
body.home .elementor-element.gs-blog-card-v2 .gs-blog-visual .elementor-widget-image img {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center center !important;
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

body.home .elementor-element.gs-blog-card-v2.e-con:hover .gs-blog-visual .elementor-widget-image img {
  transform: scale(1.05);
}

body.home .elementor-element.gs-blog-card-v2 .elementor-widget-text-editor {
  flex: 1 1 auto !important;
  width: 100% !important;
  margin: 0 !important;
}

body.home .elementor-element.gs-blog-card-v2 .elementor-widget-text-editor .elementor-widget-container {
  padding: 0 !important;
}

/* Caption is HTML inside text-editor (.gs-blog-copy), not a widget class */
body.home .elementor-element.gs-blog-card-v2 .gs-blog-copy {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  text-align: left;
}

body.home .elementor-element.gs-blog-card-v2 .gs-blog-copy h3 {
  margin: 0 0 10px;
  padding-bottom: 10px;
  font-family: "Cormorant Garamond", serif !important;
  font-size: clamp(21px, 2.25vw, 27px) !important;
  font-weight: 600 !important;
  line-height: 1.18 !important;
  color: var(--gs-brown) !important;
  position: relative;
  transition: color 0.25s ease;
}

body.home .elementor-element.gs-blog-card-v2.e-con:hover .gs-blog-copy h3 {
  color: var(--gs-gold-deep) !important;
}

body.home .elementor-element.gs-blog-card-v2 .gs-blog-copy h3::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--gs-gold), rgba(200, 138, 43, 0.12));
}

body.home .elementor-element.gs-blog-card-v2 .gs-blog-copy p {
  margin: 0;
  flex: 1 1 auto;
  min-height: 3.1em;
  font-family: "Manrope", sans-serif !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  color: var(--gs-brown-soft) !important;
}

body.home .elementor-element.gs-blog-card-v2 .gs-blog-read-more {
  margin-top: auto;
  padding-top: 4px;
}

/* ----- Hero → content ----- */
body.home .elementor-element.gs-slider-section {
  margin-bottom: 0 !important;
  padding: 0 !important;
}

body.home .gs-page > .e-con-inner > .elementor-element.gs-section-light:first-of-type {
  padding-top: clamp(36px, 5vw, 56px) !important;
}

/* ----- Responsive ----- */
@media (max-width: 1100px) {
  body.home .elementor-element.gs-reference-grid.e-con,
  body.home .elementor-element.gs-grid-4.gs-reference-grid.e-con,
  body.home .elementor-element.gs-reference-grid > .e-con-inner,
  body.home .elementor-element.gs-grid-4.gs-reference-grid > .e-con-inner,
  body.home .elementor-element-gst014.e-con,
  body.home .elementor-element.gs-blog-row.e-con,
  body.home .elementor-element.gs-grid-3.gs-blog-row.e-con,
  body.home .elementor-element.gs-blog-row.e-con > .e-con-inner,
  body.home .elementor-element.gs-blog-row > .e-con-inner,
  body.home .elementor-element.gs-grid-3.gs-blog-row > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767px) {
  body.home .elementor-element.gs-section-light,
  body.home .elementor-element.gs-section-cream,
  body.home .elementor-element.gs-sweets-section,
  body.home .elementor-element.gs-kaju-section {
    padding: 40px 0 !important;
  }

  body.home .elementor-element.gs-reference-grid.e-con,
  body.home .elementor-element.gs-grid-4.gs-reference-grid.e-con,
  body.home .elementor-element.gs-reference-grid > .e-con-inner,
  body.home .elementor-element.gs-grid-4.gs-reference-grid > .e-con-inner,
  body.home .elementor-element-gst014.e-con,
  body.home .elementor-element.gs-blog-row.e-con,
  body.home .elementor-element.gs-grid-3.gs-blog-row.e-con,
  body.home .elementor-element.gs-blog-row > .e-con-inner,
  body.home .elementor-element.gs-grid-3.gs-blog-row > .e-con-inner {
    grid-template-columns: 1fr !important;
    gap: 18px !important;
  }

  body.home .gs-grid-visible .elementor-element-gst053 > .e-con.e-child:nth-child(even),
  body.home .gs-grid-visible .elementor-element.gskaju003 > .e-con.e-child:nth-child(odd),
  body.home .gs-grid-visible .elementor-element.gs-kaju-card.e-con:nth-child(odd),
  body.home .gs-grid-visible .elementor-element-gst085 > .e-con.e-child:nth-child(2),
  body.home .gs-grid-visible .elementor-element.gs-blog-card-v2.e-con:nth-child(2) {
    transform: none;
  }
}

/* ----- Kaju product cards (aligned with gifting cards) ----- */
body.home .elementor-element.gs-kaju-card.e-con,
body.home .elementor-element.gs-kaju-card > .e-con-inner {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  height: 100% !important;
  padding: 14px 14px 16px !important;
  gap: 0 !important;
  border-radius: 22px !important;
  background: linear-gradient(165deg, #ffffff 0%, #f6faf0 100%) !important;
  border: 1px solid rgba(111, 127, 66, 0.2) !important;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 14px 34px rgba(47, 56, 28, 0.08) !important;
  overflow: hidden !important;
  transition:
    transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.32s ease !important;
}

body.home .gs-grid-visible .elementor-element.gskaju003 > .e-con.e-child:nth-child(odd),
body.home .gs-grid-visible .elementor-element.gs-kaju-card.e-con:nth-child(odd) {
  transform: translateY(-3px);
}

body.home .elementor-element.gs-kaju-card.e-con:hover,
body.home .elementor-element.gs-kaju-card > .e-con-inner:hover {
  transform: translateY(-7px);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.95) inset,
    0 22px 48px rgba(47, 56, 28, 0.12) !important;
}

body.home .elementor-element.gs-kaju-card .elementor-element.gs-kaju-image .elementor-widget-container,
body.home .elementor-element.gs-kaju-card .gs-kaju-image .elementor-widget-container {
  border-radius: 16px !important;
  overflow: hidden !important;
}

body.home .elementor-element.gs-kaju-card .gs-kaju-image img {
  transition: transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}

body.home .elementor-element.gs-kaju-card.e-con:hover .gs-kaju-image img {
  transform: scale(1.05);
}

body.home .elementor-element.gs-kaju-card .gs-kaju-label {
  padding-top: 12px !important;
  text-align: center !important;
}

body.home .elementor-element.gs-kaju-card .gs-kaju-label .elementor-heading-title {
  font-size: clamp(20px, 2vw, 24px) !important;
}

body.home .elementor-element.gs-kaju-card .gs-kaju-label .elementor-heading-title::after {
  content: "";
  display: block;
  width: 36px;
  height: 2px;
  margin: 8px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, var(--gs-gold), transparent);
}

/* ----- Tradition / story block ----- */
body.home .elementor-element.gs-trad-section {
  position: relative;
  border-radius: clamp(20px, 3vw, 32px);
  background: linear-gradient(135deg, #fffdf9 0%, #f8efe2 100%) !important;
  box-shadow: 0 24px 60px rgba(71, 40, 24, 0.08);
  overflow: hidden;
}

body.home .elementor-element.gs-trad-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--gs-gold), var(--gs-rose), var(--gs-green));
}

/* ----- Hero banner motion (shortcode / slider) ----- */
body.home .gs-hero-banner-slide.is-active img {
  animation: gsHomeHeroZoom 16s ease-out forwards;
}

@keyframes gsHomeHeroZoom {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(1.07);
  }
}

/* ----- Scroll reveal animations (varied per block) ----- */
html.gs-motion-enabled body.home .gs-reveal {
  opacity: 0;
  transition:
    opacity var(--gs-reveal-duration) var(--gs-reveal-ease),
    transform var(--gs-reveal-duration) var(--gs-reveal-ease),
    filter var(--gs-reveal-duration) var(--gs-reveal-ease);
  will-change: opacity, transform, filter;
}

html.gs-motion-enabled body.home .gs-reveal--up {
  transform: translate3d(0, 40px, 0);
}

html.gs-motion-enabled body.home .gs-reveal--down {
  transform: translate3d(0, -32px, 0);
}

html.gs-motion-enabled body.home .gs-reveal--left {
  transform: translate3d(-48px, 0, 0);
}

html.gs-motion-enabled body.home .gs-reveal--right {
  transform: translate3d(48px, 0, 0);
}

html.gs-motion-enabled body.home .gs-reveal--scale {
  transform: scale(0.9);
}

html.gs-motion-enabled body.home .gs-reveal--blur {
  transform: translate3d(0, 24px, 0);
  filter: blur(10px);
}

html.gs-motion-enabled body.home .gs-reveal.is-visible {
  opacity: 1;
  transform: none;
  filter: none;
}

/* Grid cards — different entrance per column */
html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child,
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child {
  opacity: 0;
  animation-duration: var(--gs-grid-reveal-duration);
  animation-timing-function: var(--gs-reveal-ease);
  animation-fill-mode: forwards;
}

html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child:nth-child(6n + 1),
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child:nth-child(6n + 1) {
  animation-name: gsRevealLeft;
  animation-delay: calc(var(--gs-grid-stagger-step) * 0.5);
}

html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child:nth-child(6n + 2),
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child:nth-child(6n + 2) {
  animation-name: gsRevealUp;
  animation-delay: calc(var(--gs-grid-stagger-step) * 1.5);
}

html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child:nth-child(6n + 3),
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child:nth-child(6n + 3) {
  animation-name: gsRevealRight;
  animation-delay: calc(var(--gs-grid-stagger-step) * 2.5);
}

html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child:nth-child(6n + 4),
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child:nth-child(6n + 4) {
  animation-name: gsRevealScale;
  animation-delay: calc(var(--gs-grid-stagger-step) * 3.5);
}

html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child:nth-child(6n + 5),
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child:nth-child(6n + 5) {
  animation-name: gsRevealBlur;
  animation-delay: calc(var(--gs-grid-stagger-step) * 4.5);
}

html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child:nth-child(6n + 6),
html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child:nth-child(6n + 6) {
  animation-name: gsRevealDown;
  animation-delay: calc(var(--gs-grid-stagger-step) * 5.5);
}

@keyframes gsRevealUp {
  from {
    opacity: 0;
    transform: translate3d(0, 36px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes gsRevealDown {
  from {
    opacity: 0;
    transform: translate3d(0, -28px, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes gsRevealLeft {
  from {
    opacity: 0;
    transform: translate3d(-44px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes gsRevealRight {
  from {
    opacity: 0;
    transform: translate3d(44px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

@keyframes gsRevealScale {
  from {
    opacity: 0;
    transform: scale(0.88);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes gsRevealBlur {
  from {
    opacity: 0;
    filter: blur(12px);
    transform: translate3d(0, 20px, 0);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translate3d(0, 0, 0);
  }
}

/* Section atmosphere — gentle motion */
html.gs-motion-enabled body.home .elementor-element.gs-section-light::before {
  animation: gsHomeFloat 9s ease-in-out infinite alternate;
}

html.gs-motion-enabled body.home .elementor-element.gs-sweets-section::after {
  animation: gsHomeDrift 14s ease-in-out infinite alternate;
}

html.gs-motion-enabled body.home .elementor-element.gs-kaju-section::before {
  animation: gsHomeFloat 11s ease-in-out infinite alternate-reverse;
}

html.gs-motion-enabled body.home .elementor-element.gst082.e-con::before,
html.gs-motion-enabled body.home .elementor-element.gs-blog-section.e-con::before {
  animation: gsHomePulse 8s ease-in-out infinite alternate;
}

@keyframes gsHomeFloat {
  from {
    transform: translate(0, 0);
  }
  to {
    transform: translate(-18px, 22px);
  }
}

@keyframes gsHomeDrift {
  from {
    opacity: 0.16;
    transform: translateX(0);
  }
  to {
    opacity: 0.24;
    transform: translateX(24px);
  }
}

@keyframes gsHomePulse {
  from {
    opacity: 0.55;
    transform: translateX(-50%) scale(1);
  }
  to {
    opacity: 0.85;
    transform: translateX(-50%) scale(1.08);
  }
}

/* ----- Testimonials ----- */
body.home .elementor-element.gst085 > .e-con-inner > .gs-testimonials-section,
body.home .elementor-element.gs-blog-row > .e-con-inner > .elementor-element-gst090 {
  flex: 0 0 100% !important;
  width: 100% !important;
  max-width: 100% !important;
  grid-column: 1 / -1 !important;
}

body.home .elementor-element.gs-testimonials-section {
  position: relative;
  padding: clamp(48px, 6vw, 72px) 0 !important;
}

body.home .elementor-element.gs-testimonials-section .elementor-heading-title {
  text-align: center;
}

body.home .gs-testimonials-lead {
  max-width: 640px;
  margin: 0 auto 28px;
  text-align: center;
  font-family: "Manrope", sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: var(--gs-brown-soft);
}

body.home .elementor-element.gs-testimonials-grid > .e-con-inner {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: clamp(18px, 2.2vw, 28px) !important;
  width: min(calc(100% - 32px), 1240px) !important;
  max-width: 1240px;
  margin-inline: auto !important;
}

body.home .elementor-element.gs-testimonial-card-wrap > .e-con-inner {
  height: 100%;
  padding: 22px 20px !important;
  border-radius: 22px !important;
  background: linear-gradient(165deg, #ffffff 0%, #fff9f2 100%) !important;
  border: 1px solid rgba(200, 138, 43, 0.22) !important;
  box-shadow: 0 14px 34px rgba(71, 40, 24, 0.09) !important;
}

.gs-testimonial-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  height: 100%;
  margin: 0;
}

.gs-testimonial-card__quote {
  margin: 0;
  flex: 1 1 auto;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(20px, 2vw, 24px);
  font-weight: 500;
  line-height: 1.45;
  color: var(--gs-brown);
  font-style: italic;
}

.gs-testimonial-card__meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(200, 138, 43, 0.2);
}

.gs-testimonial-card__meta strong {
  font-family: "Manrope", sans-serif;
  font-size: 14px;
  font-weight: 800;
  color: var(--gs-gold-deep);
}

.gs-testimonial-card__meta span {
  font-family: "Manrope", sans-serif;
  font-size: 12px;
  color: var(--gs-brown-soft);
}

@media (max-width: 1100px) {
  body.home .elementor-element.gs-testimonials-grid > .e-con-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767px) {
  body.home .elementor-element.gs-testimonials-grid > .e-con-inner {
    grid-template-columns: 1fr !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.home .gs-hero-banner-slide.is-active img,
  html.gs-motion-enabled body.home .elementor-element.gs-section-light::before,
  html.gs-motion-enabled body.home .elementor-element.gs-sweets-section::after,
  html.gs-motion-enabled body.home .elementor-element.gs-kaju-section::before,
  html.gs-motion-enabled body.home .elementor-element.gst082.e-con::before {
    animation: none !important;
  }

  html.gs-motion-enabled body.home .gs-reveal {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }

  html.gs-motion-enabled body.home .gs-grid-visible > .e-con.e-child,
  html.gs-motion-enabled body.home .gs-grid-visible > .e-con-inner > .e-con.e-child {
    animation: none !important;
    opacity: 1;
    transform: none;
    filter: none;
  }
}
