  :root {
      --taupe:       #b4a28e;
      --taupe-light: #d0c4b4;
      --taupe-dark:  #8a7a68;
      --taupe-pale:  #f5f1ec;
      --white:       #ffffff;
      --off-white:   #faf8f5;
      --ink:         #1a1714;
      --ink-mid:     #3d3530;
      --ink-soft:    #6b5f55;
      --gold:        #c9a96e;
      --gold-light:  #e8d5b0;
      --shadow-sm:   0 2px 20px rgba(180,162,142,.12);
      --shadow-md:   0 8px 40px rgba(180,162,142,.20);
      --shadow-lg:   0 20px 60px rgba(180,162,142,.28);
      --radius:      4px;
      --transition:  .45s cubic-bezier(.25,.8,.25,1);
    }

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

    html { scroll-behavior: smooth; }

    body {
      font-family: 'Jost', sans-serif;
      background: var(--off-white);
      color: var(--ink);
      overflow-x: hidden;
    }

    /* ---- Scrollbar ---- */
    ::-webkit-scrollbar { width: 6px; }
    ::-webkit-scrollbar-track { background: var(--taupe-pale); }
    ::-webkit-scrollbar-thumb { background: var(--taupe); border-radius: 10px; }

    /* ---- Selection ---- */
    ::selection { background: var(--taupe-light); color: var(--ink); }

    /* ---- Typography ---- */
    .font-serif  { font-family: 'Cormorant Garamond', serif; }
    .font-playfair { font-family: 'Playfair Display', serif; }
    ul {
  padding-left: 0rem;;
}
    /* ---- Section Label ---- */
    .section-eyebrow {
      display: inline-block;
      font-family: 'Jost', sans-serif;
      font-size: .7rem;
      font-weight: 600;
      letter-spacing: .25em;
      text-transform: uppercase;
      color: var(--taupe);
      margin-bottom: 1rem;
    }
    .section-eyebrow::before {
      content: '';
      display: inline-block;
      width: 28px;
      height: 1px;
      background: var(--taupe);
      vertical-align: middle;
      margin-right: .6rem;
    }
    .container{
          --bs-gutter-x: 1.5rem;
    --bs-gutter-y: 0;
    width: 100%;
    padding-right: calc(var(--bs-gutter-x) * 1);
    padding-left: calc(var(--bs-gutter-x) * 1);
    margin-left: auto;
    }
    .section-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: clamp(2rem, 4vw, 3.2rem);
      font-weight: 300;
      line-height: 1.15;
      color: var(--ink);
    }

    /* ---- Btn Primary ---- */
.btn-lumiere{
display:inline-flex;
align-items:center;
gap:.6rem;
padding:.9rem 1.6rem;
background:rgba(255,255,255,.12);
backdrop-filter:blur(6px);
border:1px solid rgba(255,255,255,.4);
color:#fff;
font-size:.78rem;
letter-spacing:.12em;
text-transform:uppercase;
transition:.35s;
}

.btn-lumiere:hover{
background:var(--taupe);
border-color:var(--taupe);
color:#fff;
transform:translateY(-2px);
}
    .btn-lumiere::after {
      content: '';
      position: absolute;
      inset: 0;
      background: var(--taupe-dark);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform .4s ease;
    }
    .btn-lumiere:hover::after { transform: scaleX(1); }
    .btn-lumiere span, .btn-lumiere i { position: relative; z-index: 1; }
  

    .btn-lumiere-outline {
      display: inline-flex;
      align-items: center;
      gap: .6rem;
      background: transparent;
      color: var(--taupe);
      border: 1.5px solid var(--taupe);
      padding: .75rem 2.2rem;
      font-family: 'Jost', sans-serif;
      font-size: .75rem;
      font-weight: 600;
      letter-spacing: .18em;
      text-transform: uppercase;
      text-decoration: none;
      transition: var(--transition);
      cursor: pointer;
    }
    .btn-lumiere-outline:hover {
      background: var(--taupe);
      color: var(--white);
    }

    /* ============================================
       TOP BAR
    ============================================ */
    #topbar {
      background: var(--ink);
      color: var(--taupe-light);
      font-size: .72rem;
      font-weight: 400;
      letter-spacing: .08em;
      text-transform: uppercase;
      padding: .55rem 0;
      position: relative;
      z-index: 1100;
    }
    #topbar a { color: var(--taupe-light); text-decoration: none; transition: color .3s; }
    #topbar a:hover { color: var(--gold); }
    .topbar-ticker {
      overflow: hidden;
      flex: 1;
      max-width: 600px;
    }
    .topbar-ticker-inner {
      display: flex;
      animation: tickerMove 22s linear infinite;
      white-space: nowrap;
    }
    .topbar-ticker-inner span { padding-right: 4rem; }
    @keyframes tickerMove {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    /* ============================================
       NAVBAR
    ============================================ */
    #mainNav {
      background: rgba(255,255,255,.92);
      backdrop-filter: blur(18px);
      -webkit-backdrop-filter: blur(18px);
      border-bottom: 1px solid rgba(180,162,142,.15);
      padding: .9rem 0;
      transition: all .4s ease;
      position: sticky;
      top: 0;
      z-index: 1050;
    }
    #mainNav.scrolled {
      padding: .6rem 0;
      box-shadow: var(--shadow-md);
    }
    .navbar-brand-text {
      max-width: 100px;
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.9rem;
      font-weight: 300;
      letter-spacing: .22em;
      color: var(--ink);
      text-transform: uppercase;
      text-decoration: none;
      line-height: 1;
    }
    .navbar-brand-text em {
      font-style: italic;
      color: var(--taupe);
    }
    .navbar-brand-sub {
      font-family: 'Jost', sans-serif;
      font-size: .58rem;
      letter-spacing: .35em;
      text-transform: uppercase;
      color: var(--ink-soft);
      display: block;
      margin-top: 2px;
    }

    .nav-link-custom {
      font-family: 'Jost', sans-serif;
      font-size: .74rem;
      font-weight: 500;
      letter-spacing: .14em;
      text-transform: uppercase;
      color: var(--ink-mid) !important;
      padding: .4rem .9rem !important;
      position: relative;
      transition: color .3s;
    }
    .nav-link-custom::after {
      content: '';
      position: absolute;
      bottom: 0;
      left: .9rem;
      right: .9rem;
      height: 1.5px;
      background: var(--taupe);
      transform: scaleX(0);
      transition: transform .3s ease;
    }
    .nav-link-custom:hover { color: var(--taupe) !important; }
    .nav-link-custom:hover::after { transform: scaleX(1); }

    /* Dropdown */
    .navbar-nav .dropdown-menu {
      border: none;
      border-radius: 0;
      border-top: 2px solid var(--taupe);
      box-shadow: var(--shadow-lg);
      background: var(--white);
      padding: 1.2rem 0;
      min-width: 220px;
      animation: dropIn .3s ease;
    }
    @keyframes dropIn {
      from { opacity: 0; transform: translateY(-8px); }
      to   { opacity: 1; transform: translateY(0); }
    }
    .dropdown-item {
      font-family: 'Jost', sans-serif;
      font-size: .73rem;
      font-weight: 400;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: var(--ink-mid);
      padding: .55rem 1.6rem;
      transition: all .25s;
    }
    .dropdown-item:hover {
      background: var(--taupe-pale);
      color: var(--taupe-dark);
      padding-left: 2rem;
    }

    /* Icon buttons */
    .nav-icon-btn {
      width: 40px;
      height: 40px;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      border: 1.5px solid rgba(180,162,142,.3);
      border-radius: 50%;
      color: var(--ink-mid);
      text-decoration: none;
      font-size: 1rem;
      transition: all .3s;
      position: relative;
    }
    .nav-icon-btn:hover {
      background: var(--taupe);
      border-color: var(--taupe);
      color: var(--white);
      transform: translateY(-2px);
    }
      /* Multi Level Dropdown */
/* HOVER DROPDOWN */
/* DROPDOWN ITEMS */

.dropdown-menu li{
  list-style:none;
}

.dropdown-menu .dropdown-item{
  font-family:var(--font-nav);
  font-size:.9rem;
  font-weight:600;
  letter-spacing:.05em;
  padding:10px 18px;
  color:#222;
  transition:all .25s ease;
  border-left:3px solid transparent;
}

/* HOVER EFFECT */

.dropdown-menu .dropdown-item:hover{
  background:#f8f8f8;
  color:var(--red);
  border-left:3px solid var(--red);
  padding-left:22px;
}

/* CATEGORY TITLE STYLE */

.dropdown-menu .dropdown-header{
  font-weight:700;
  font-size:.85rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:#777;
  padding:8px 18px;
}

/* DIVIDER */

.dropdown-divider{
  margin:6px 0;
}
.navbar .dropdown:hover > .dropdown-menu{
  display:block;
  margin-top:0;
}

.navbar .dropdown-menu{
  display:none;
  border-radius:8px;
  border:none;
  box-shadow:0 10px 25px rgba(0,0,0,0.15);
  padding:8px 0;
}
.dropdown-submenu {
  position: relative;
}

.dropdown-submenu > .dropdown-menu {
  top: 0;
  left: 100%;
  margin-top: -2px;
  display: none;
}

/* show submenu on hover */

.dropdown-submenu:hover > .dropdown-menu {
  display: block;
}

/* arrow alignment */

.dropdown-submenu > a::after {
  float: right;
  margin-top: 6px;
}
 /* NAV LINK STYLE */

.hamii-nav .nav-item > .nav-link {
  font-family: var(--font-nav);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--black) !important;
  padding: 0 0.95rem !important;
  height: var(--navbar-h);
  display: flex;
  align-items: center;
  gap: 0.28rem;
  position: relative;
  transition: color var(--tr);
  white-space: nowrap;
}

.hamii-nav .nav-item > .nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--red);
  transform: scaleX(0);
  transition: transform var(--tr);
}

.hamii-nav .nav-item:hover > .nav-link,
.hamii-nav .nav-item.active > .nav-link {
  color: var(--red) !important;
}

.hamii-nav .nav-item:hover > .nav-link::after {
  transform: scaleX(1);
}

.nav-chevron {
  font-size: 0.55rem;
  opacity: 0.5;
  transition: transform var(--tr), opacity var(--tr);
}

/* MEGA MENU PANEL */

.mega-menu-panel{
  position:absolute;
  left:0;
  top:100%;
  width:100%;
  background:#fff;
  box-shadow:0 15px 40px rgba(0,0,0,.15);
  display:none;
  z-index:999;
}

/* SHOW ON HOVER */

.nav-item.mega-dropdown:hover .mega-menu-panel{
  display:block;
}

/* MEGA PANELS */

.mega-panel{
  display:none;
}

.mega-panel.active{
  display:flex;
  flex-wrap:wrap;
}

/* TABS */

.mega-tab{
  width:100%;
  border:none;
  padding:12px 15px;
  background:#fff;
  text-align:left;
  cursor:pointer;
  font-weight:600;
  border-bottom:1px solid #eee;
  transition:all .25s;
}

.mega-tab:hover{
  background:#f6f6f6;
}

.mega-tab.active{
  background:#f2f2f2;
  color:var(--red);
}

/* SUB LIST */

.mega-sub-list{
  list-style:none;
  padding:0;
  margin:0;
}

.mega-sub-list li{
  margin:5px 0;
}

.mega-link{
  text-decoration:none;
  color:#333;
  font-size:.9rem;
}

.mega-link:hover{
  color:var(--red);
}
    .badge-cart {
      position: absolute;
      top: -4px;
      right: -4px;
      background: var(--taupe-dark);
      color: white;
      font-size: .6rem;
      width: 18px;
      height: 18px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-family: 'Jost', sans-serif;
    }

    /* Search bar */
    .nav-search-wrapper {
      position: relative;
    }
    .nav-search-input {
      border: 1.5px solid rgba(180,162,142,.35);
      border-radius: 2px;
      background: var(--off-white);
      font-family: 'Jost', sans-serif;
      font-size: .73rem;
      padding: .45rem 2.5rem .45rem 1rem;
      outline: none;
      width: 180px;
      transition: all .35s;
      color: var(--ink);
    }
    .nav-search-input:focus {
      width: 240px;
      border-color: var(--taupe);
      background: var(--white);
    }
    .nav-search-icon {
      position: absolute;
      right: .7rem;
      top: 50%;
      transform: translateY(-50%);
      color: var(--taupe);
      font-size: .85rem;
    }

    /* ============================================
       OFFCANVAS MOBILE MENU
    ============================================ */

    /* Hamburger toggler */
    .nav-offcanvas-toggler {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      gap: 5px;
      width: 40px;
      height: 40px;
      background: transparent;
      border: 1.5px solid rgba(180,162,142,.35);
      border-radius: 50%;
      cursor: pointer;
      padding: 0;
      transition: all .3s;
    }
    .nav-offcanvas-toggler span {
      display: block;
      width: 16px;
      height: 1.5px;
      background: var(--ink-mid);
      border-radius: 2px;
      transition: all .35s ease;
    }
    .nav-offcanvas-toggler:hover {
      background: var(--taupe);
      border-color: var(--taupe);
    }
    .nav-offcanvas-toggler:hover span { background: white; }

    /* Offcanvas panel */
    #mobileOffcanvas {
      width: 310px !important;
      background: var(--ink);
      border-left: none;
      display: flex;
      flex-direction: column;
    }
    #mobileOffcanvas.show { box-shadow: -20px 0 60px rgba(0,0,0,.4); }

    /* Offcanvas header */
    .offcanvas-header-custom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 7.6rem 1.6rem 1.2rem;
    border-bottom: 1px solid rgba(180,162,142,.12);
    }
    .oc-brand {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.5rem;
      font-weight: 300;
      letter-spacing: .25em;
      color: var(--white);
      text-transform: uppercase;
    }
    .oc-brand em { font-style: italic; color: var(--taupe); }
    .oc-brand span {
      display: block;
      font-family: 'Jost', sans-serif;
      font-size: .52rem;
      letter-spacing: .35em;
      text-transform: uppercase;
      color: var(--ink-soft);
      margin-top: 2px;
    }
    .oc-close-btn {
      width: 36px; height: 36px;
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(180,162,142,.2);
      border-radius: 50%;
      color: rgba(255,255,255,.6);
      display: flex; align-items: center; justify-content: center;
      cursor: pointer;
      font-size: .9rem;
      transition: all .3s;
    }
    .oc-close-btn:hover { background: var(--taupe); color: white; border-color: var(--taupe); }

    /* Search */
    .oc-search-wrapper {
      position: relative;
      padding: 1rem 1.6rem .8rem;
      border-bottom: 1px solid rgba(180,162,142,.1);
    }
    .oc-search-input {
      width: 100%;
      background: rgba(255,255,255,.06);
      border: 1px solid rgba(180,162,142,.2);
      border-radius: 2px;
      color: white;
      font-family: 'Jost', sans-serif;
      font-size: .78rem;
      padding: .65rem 2.4rem .65rem 1rem;
      outline: none;
      transition: border-color .3s;
    }
    .oc-search-input::placeholder { color: rgba(255,255,255,.3); }
    .oc-search-input:focus { border-color: var(--taupe); }
    .oc-search-icon {
      position: absolute;
      right: 2.4rem; top: 50%;
      transform: translateY(-50%);
      color: var(--taupe);
      font-size: .85rem;
    }

    /* Body */
    .oc-body {
      padding: .6rem 0 1.5rem !important;
      overflow-y: auto;
      flex: 1;
      display: flex;
      flex-direction: column;
    }
    .oc-body::-webkit-scrollbar { width: 3px; }
    .oc-body::-webkit-scrollbar-thumb { background: rgba(180,162,142,.3); border-radius: 10px; }

    /* Nav list */
    .oc-nav-list {
      list-style: none;
      padding: .5rem 0;
      margin: 0;
    }
    .oc-nav-item { border-bottom: 1px solid rgba(180,162,142,.08); }

    .oc-nav-link {
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      padding: .95rem 1.6rem;
      font-family: 'Jost', sans-serif;
      font-size: .75rem;
      font-weight: 500;
      letter-spacing: .16em;
      text-transform: uppercase;
      color: rgba(255,255,255,.75);
      text-decoration: none;
      background: transparent;
      border: none;
      cursor: pointer;
      transition: all .3s;
    }
    .oc-nav-link:hover,
    .oc-nav-link.active-parent {
      color: var(--taupe-light);
      background: rgba(180,162,142,.06);
      padding-left: 2rem;
    }
    .oc-nav-link i.bi-arrow-right {
      font-size: .7rem;
      opacity: .4;
      transition: all .3s;
    }
    .oc-nav-link:hover i.bi-arrow-right { opacity: 1; transform: translateX(4px); }

    /* Chevron rotate */
    .oc-chevron { transition: transform .35s ease; font-size: .75rem; opacity: .5; }
    .oc-chevron.open { transform: rotate(180deg); opacity: 1; }

    /* Submenu */
    .oc-submenu {
      list-style: none;
      padding: 0;
      margin: 0;
      max-height: 0;
      overflow: hidden;
      background: rgba(0,0,0,.2);
      transition: max-height .4s ease;
    }
    .oc-submenu.open { max-height: 300px; }
    .oc-submenu li a {
      display: flex;
      align-items: center;
      gap: .6rem;
      padding: .7rem 1.6rem .7rem 2.4rem;
      font-family: 'Jost', sans-serif;
      font-size: .72rem;
      font-weight: 400;
      letter-spacing: .12em;
      text-transform: uppercase;
      color: rgba(255,255,255,.45);
      text-decoration: none;
      transition: all .25s;
      border-bottom: 1px solid rgba(180,162,142,.06);
    }
    .oc-submenu li a::before {
      content: '';
      width: 16px; height: 1px;
      background: var(--taupe);
      flex-shrink: 0;
      opacity: .5;
    }
    .oc-submenu li a:hover { color: var(--taupe-light); padding-left: 3rem; }

    /* Hot tag */
    .oc-hot-tag {
      font-style: normal;
      font-size: .55rem;
      font-weight: 700;
      letter-spacing: .1em;
      color: var(--gold);
      margin-left: .4rem;
    }

    /* CTA */
    .oc-cta-row {
      padding: 1.2rem 1.6rem .5rem;
      margin-top: auto;
    }
    .oc-cta-row .btn-lumiere {
      width: 100%;
      justify-content: center;
    }

    /* Quick links */
    .oc-quick-links {
      display: flex;
      justify-content: space-around;
      padding: .8rem 1.6rem;
      border-top: 1px solid rgba(180,162,142,.1);
      border-bottom: 1px solid rgba(180,162,142,.1);
      margin: .5rem 0;
    }
    .oc-quick-links a {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: .3rem;
      color: rgba(255,255,255,.45);
      text-decoration: none;
      font-size: .6rem;
      font-weight: 500;
      letter-spacing: .12em;
      text-transform: uppercase;
      transition: color .3s;
    }
    .oc-quick-links a i { font-size: 1.1rem; }
    .oc-quick-links a:hover { color: var(--taupe-light); }

    /* Footer info */
    .oc-footer {
      padding: .8rem 1.6rem 0;
    }
    .oc-footer-info {
      display: flex;
      align-items: center;
      gap: .7rem;
      color: rgba(255,255,255,.3);
      font-size: .7rem;
      margin-bottom: .5rem;
    }
    .oc-footer-info i { color: var(--taupe); font-size: .85rem; }
    .oc-social {
      display: flex;
      gap: .6rem;
      margin-top: 1rem;
    }
    .oc-social a {
      width: 34px; height: 34px;
      border: 1px solid rgba(180,162,142,.2);
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: rgba(255,255,255,.4);
      font-size: .85rem;
      text-decoration: none;
      transition: all .3s;
    }
    .oc-social a:hover { background: var(--taupe); border-color: var(--taupe); color: white; }

    /* Offcanvas backdrop tint */
    .offcanvas-backdrop { background: rgba(26,23,20,.7) !important; backdrop-filter: blur(4px); }

    /* ---- Slide-in animation ---- */
    #mobileOffcanvas {
      transition: transform .4s cubic-bezier(.4,0,.2,1) !important;
    }

    /* Cursor glow */
    .cursor-glow {
      width: 20px; height: 20px;
      border-radius: 50%;
      background: rgba(180,162,142,.25);
      border: 1.5px solid var(--taupe);
      position: fixed;
      pointer-events: none;
      z-index: 9999;
      transition: transform .15s ease;
      transform: translate(-50%, -50%);
    }
    /* ============================================
       HERO SLIDER
    ============================================ */
    #heroSlider {
      position: relative;
      overflow: hidden;
    }
    .hero-swiper {
      height: 92vh;
      min-height: 600px;
    }
    .hero-slide {
      position: relative;
      display: flex;
      align-items: center;
      overflow: hidden;
    }
    .hero-slide-bg {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      transform: scale(1.06);
      transition: transform 8s ease;
    }
    .swiper-slide-active .hero-slide-bg {
      transform: scale(1);
    }
    .hero-slide-bg-1 {
      background: linear-gradient(135deg, #1a1714 0%, #3d3530 40%, #b4a28e 100%);
    }
    .hero-slide-bg-2 {
      background: linear-gradient(135deg, #2c2520 0%, #8a7a68 50%, #d0c4b4 100%);
    }
    .hero-slide-bg-3 {
      background: linear-gradient(135deg, #f5f1ec 0%, #d0c4b4 50%, #8a7a68 100%);
    }
    .hero-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(90deg, rgba(26,23,20,.72) 0%, rgba(26,23,20,.3) 60%, transparent 100%);
    }
    .hero-slide-3 .hero-overlay {
      background: linear-gradient(90deg, rgba(26,23,20,.55) 0%, rgba(26,23,20,.2) 60%, transparent 100%);
    }
    .hero-content {
      margin-left: 5%;
      position: relative;
      z-index: 2;
      max-width: 700px;
    }
    .hero-eyebrow {
      font-family: 'Jost', sans-serif;
      font-size: .68rem;
      font-weight: 600;
      letter-spacing: .38em;
      text-transform: uppercase;
      color: var(--taupe-light);
      margin-bottom: 1.2rem;
      display: flex;
      align-items: center;
      gap: .8rem;
      opacity: 0;
      transform: translateY(20px);
      transition: all .7s .2s ease;
    }
    .hero-eyebrow::before {
      content: '';
      width: 40px;
      height: 1px;
      background: var(--taupe-light);
      flex-shrink: 0;
    }
    .hero-heading {
      font-family: 'Cormorant Garamond', serif;
      font-size: clamp(3rem, 7vw, 6.5rem);
      font-weight: 300;
      line-height: 1.05;
      color: var(--white);
      margin-bottom: 1.6rem;
      opacity: 0;
      transform: translateY(30px);
      transition: all .8s .4s ease;
    }
    .hero-heading em {
      font-style: italic;
      color: var(--taupe-light);
    }
    .hero-desc {
      font-size: .9rem;
      font-weight: 300;
      color: rgba(255,255,255,.78);
      line-height: 1.8;
      max-width: 460px;
      margin-bottom: 2.2rem;
      opacity: 0;
      transform: translateY(20px);
      transition: all .7s .6s ease;
    }
    .hero-cta {
      display: flex;
      gap: 1rem;
      flex-wrap: wrap;
      opacity: 0;
      transform: translateY(20px);
      transition: all .7s .8s ease;
    }
    .swiper-slide-active .hero-eyebrow,
    .swiper-slide-active .hero-heading,
    .swiper-slide-active .hero-desc,
    .swiper-slide-active .hero-cta {
      opacity: 1;
      transform: translateY(0);
    }

    /* Hero Slider Controls */
    .hero-pagination-custom {
      position: absolute;
      right: 3rem;
      top: 50%;
      transform: translateY(-50%);
      z-index: 10;
      display: flex;
      flex-direction: column;
      gap: .8rem;
    }
    .hero-pag-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: rgba(255,255,255,.4);
      cursor: pointer;
      transition: all .4s;
    }
    .hero-pag-dot.active {
      background: var(--taupe-light);
      height: 28px;
      border-radius: 3px;
    }

    .hero-nav-btn {
      position: absolute;
      bottom: 3rem;
      z-index: 10;
      width: 52px;
      height: 52px;
      border: 1.5px solid rgba(255,255,255,.4);
      background: transparent;
      color: white;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: all .3s;
      font-size: 1.1rem;
    }
    .hero-nav-btn:hover {
      background: var(--taupe);
      border-color: var(--taupe);
    }
    .hero-prev { right: 8rem; }
    .hero-next { right: 3rem; }

    .hero-scroll-hint {
      position: absolute;
      bottom: 2.5rem;
      left: 50%;
      transform: translateX(-50%);
      z-index: 10;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: .5rem;
    }
    .hero-scroll-hint span {
      font-size: .6rem;
      letter-spacing: .25em;
      text-transform: uppercase;
      color: rgba(255,255,255,.5);
      font-family: 'Jost', sans-serif;
    }
    .scroll-line {
      width: 1px;
      height: 50px;
      background: linear-gradient(to bottom, rgba(255,255,255,.5), transparent);
      animation: scrollPulse 2s ease infinite;
    }
    @keyframes scrollPulse {
      0%, 100% { opacity: .3; transform: scaleY(1); }
      50%       { opacity: 1; transform: scaleY(1.2); }
    }
@media (max-width:768px){

.hero-swiper{
height:82vh;
min-height:540px;
}

.hero-slide-bg{
background-position:70% center;
}

.hero-overlay{
background:linear-gradient(
180deg,
rgba(0,0,0,.65) 0%,
rgba(0,0,0,.35) 40%,
rgba(0,0,0,.8) 100%
);
}

.hero-content{
margin-left:0;
padding:0 24px;
text-align:center;
max-width:100%;
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
height:100%;
}

.hero-heading{
font-size:2.4rem;
line-height:1.1;
margin-bottom:14px;
}

.hero-desc{
font-size:.85rem;
max-width:300px;
margin-bottom:20px;
}

.hero-eyebrow{
justify-content:center;
font-size:.65rem;
letter-spacing:.3em;
margin-bottom:12px;
}

.hero-eyebrow::before{
display:none;
}

.hero-cta{
justify-content:center;
}

}
@media (max-width:768px){
.hero-slide-bg{
background-position:88% center;
}
}
    /* ============================================
       MARQUEE STRIP
    ============================================ */
    #marqueeStrip {
      background: var(--taupe);
      padding: .8rem 0;
      overflow: hidden;
    }
    .marquee-inner {
      display: flex;
      animation: marqueeMove 30s linear infinite;
      white-space: nowrap;
      align-items: center;
    }
    .marquee-item {
      display: flex;
      align-items: center;
      gap: 1.5rem;
      padding-right: 3.5rem;
      font-family: 'Jost', sans-serif;
      font-size: .7rem;
      font-weight: 600;
      letter-spacing: .22em;
      text-transform: uppercase;
      color: rgba(255,255,255,.85);
    }
    .marquee-item i { color: rgba(255,255,255,.5); font-size: .9rem; }
    @keyframes marqueeMove {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }

    /* ============================================
       CATEGORIES
    ============================================ */
    #categories { padding: 5.5rem 0; }

    .cat-grid {
      display: grid;
      grid-template-columns: 2fr 1fr 1fr;
      grid-template-rows: auto auto;
      gap: 1.2rem;
    }
    .cat-card {
      position: relative;
      overflow: hidden;
      cursor: pointer;
      border-radius: 2px;
    }

    
    .cat-card:first-child { grid-row: span 2; }
    .cat-card-inner {
      position: relative;
      width: 100%;
      padding-top: 100%;
    }
    .cat-card:first-child .cat-card-inner { padding-top: 100%; }
    .cat-card-bg {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      transition: transform .7s ease;
    }
    .cat-card:hover .cat-card-bg { transform: scale(1.06); }
    .cat-bg-1 { background: linear-gradient(145deg, #2c2520, #8a7a68 60%, #b4a28e); }
    .cat-bg-2 { background: linear-gradient(145deg, #3d3530, #b4a28e); }
    .cat-bg-3 { background: linear-gradient(145deg, #8a7a68, #d0c4b4); }
    .cat-bg-4 { background: linear-gradient(145deg, #6b5f55, #b4a28e 70%, #d0c4b4); }
    .cat-bg-5 { background: linear-gradient(145deg, #1a1714, #3d3530 50%, #8a7a68); }
    .cat-overlay {
      position: absolute;
      inset: 0;
      background: linear-gradient(to top, rgba(26,23,20,.75) 0%, transparent 60%);
      transition: background .4s;
    }
    .cat-card:hover .cat-overlay {
      background: linear-gradient(to top, rgba(26,23,20,.85) 0%, rgba(26,23,20,.2) 60%);
    }
    .cat-label {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      padding: 1.5rem 1.4rem;
      color: var(--white);
    }
    .cat-name {
         font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 300;
    display: block;
    line-height: 0.2;
    }
   
    .cat-count {
          font-family: 'Jost', sans-serif;
    font-size: .65rem;
    font-weight: 500;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--taupe-light);
    margin-top: -28px;
    }
    .cat-arrow {
      position: absolute;
      top: 1.2rem;
      right: 1.2rem;
      width: 36px;
      height: 36px;
      border: 1px solid rgba(255,255,255,.4);
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
      font-size: .85rem;
      opacity: 0;
      transform: translate(8px, -8px);
      transition: all .35s;
    }
    .cat-card:hover .cat-arrow { opacity: 1; transform: translate(0, 0); }

    /* ============================================
       PRODUCTS SECTION
    ============================================ */
    #products { padding: 5rem 0; background: var(--white); }

    .product-filter-bar {
      display: flex;
      flex-wrap: wrap;
      gap: .5rem;
      margin-bottom: 3rem;
    }
    .filter-btn {
      border: 1.5px solid rgba(180,162,142,.35);
      background: transparent;
      color: var(--ink-soft);
      font-family: 'Jost', sans-serif;
      font-size: .68rem;
      font-weight: 500;
      letter-spacing: .15em;
      text-transform: uppercase;
      padding: .5rem 1.4rem;
      cursor: pointer;
      transition: all .3s;
      border-radius: 2px;
    }
    .filter-btn.active, .filter-btn:hover {
      background: var(--taupe);
      border-color: var(--taupe);
      color: var(--white);
    }

    .product-card {
      background: var(--off-white);
      border-radius: 2px;
      overflow: hidden;
      position: relative;
      transition: transform .4s ease, box-shadow .4s ease;
      cursor: pointer;
    }
    .product-card:hover {
      transform: translateY(-8px);
      box-shadow: var(--shadow-lg);
    }
    .product-img-wrapper {
      position: relative;
      overflow: hidden;
      padding-top: 120%;
    }
    .product-img-bg {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      transition: transform .6s ease;
    }
    .product-card:hover .product-img-bg { transform: scale(1.05); }

    /* Product gradient placeholders */
    .prod-bg-1 { background: linear-gradient(135deg, #2c2520 0%, #8a7a68 60%, #d0c4b4 100%); }
    .prod-bg-2 { background: linear-gradient(145deg, #3d3530 0%, #b4a28e 100%); }
    .prod-bg-3 { background: linear-gradient(135deg, #6b5f55 0%, #c9a96e 100%); }
    .prod-bg-4 { background: linear-gradient(145deg, #1a1714 0%, #8a7a68 100%); }
    .prod-bg-5 { background: linear-gradient(135deg, #8a7a68 0%, #e8d5b0 100%); }
    .prod-bg-6 { background: linear-gradient(145deg, #2c2520 0%, #d0c4b4 100%); }
    .prod-bg-7 { background: linear-gradient(135deg, #3d3530 0%, #b4a28e 70%, #f5f1ec 100%); }
    .prod-bg-8 { background: linear-gradient(145deg, #6b5f55 0%, #e8d5b0 100%); }

    .product-badge {
      position: absolute;
      top: 1rem;
      left: 1rem;
      background: var(--taupe-dark);
      color: white;
      font-family: 'Jost', sans-serif;
      font-size: .6rem;
      font-weight: 600;
      letter-spacing: .15em;
      text-transform: uppercase;
      padding: .3rem .8rem;
      z-index: 2;
    }
    .product-badge.sale { background: var(--gold); color: var(--ink); }
    .product-badge.new  { background: var(--taupe); }

    .product-actions {
      position: absolute;
      right: .9rem;
      top: .9rem;
      display: flex;
      flex-direction: column;
      gap: .5rem;
      transform: translateX(60px);
      transition: transform .4s ease;
      z-index: 3;
    }
    .product-card:hover .product-actions { transform: translateX(0); }
    .product-action-btn {
      width: 38px;
      height: 38px;
      background: rgba(255,255,255,.9);
      border: none;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      color: var(--ink-mid);
      font-size: .9rem;
      cursor: pointer;
      transition: all .3s;
    }
    .product-action-btn:hover { background: var(--taupe); color: white; }

    .product-quick-add {
      position: absolute;
      bottom: 0;
      left: 0;
      right: 0;
      background: var(--taupe);
      color: white;
      text-align: center;
      padding: .7rem;
      font-family: 'Jost', sans-serif;
      font-size: .68rem;
      font-weight: 600;
      letter-spacing: .18em;
      text-transform: uppercase;
      transform: translateY(100%);
      transition: transform .35s ease;
      cursor: pointer;
      z-index: 2;
      border: none;
      width: 100%;
    }
    .product-card:hover .product-quick-add { transform: translateY(0); }

    .product-info { padding: 1.1rem 1rem .8rem; }
    .product-cat {
      font-size: .62rem;
      font-weight: 500;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--taupe);
      margin-bottom: .35rem;
    }
    .product-name {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.1rem;
      font-weight: 400;
      color: var(--ink);
      margin-bottom: .5rem;
      line-height: 1.3;
    }
    .product-price { display: flex; align-items: center; gap: .6rem; }
    .price-now {
      font-family: 'Jost', sans-serif;
      font-size: .95rem;
      font-weight: 600;
      color: var(--taupe-dark);
    }
    .price-old {
      font-size: .8rem;
      color: var(--ink-soft);
      text-decoration: line-through;
    }
    .product-stars {
      display: flex;
      gap: 2px;
      margin-top: .4rem;
    }
    .product-stars i { font-size: .7rem; color: var(--gold); }
    .product-review-count {
      font-size: .65rem;
      color: var(--ink-soft);
      margin-left: .3rem;
    }

    /* ============================================
       ABOUT / VIDEO SECTION
    ============================================ */
    #about { padding: 6rem 0; background: var(--taupe-pale); overflow: hidden; }

    .about-video-wrapper {
      position: relative;
      border-radius: 2px;
      overflow: hidden;
      box-shadow: var(--shadow-lg);
    }
    .about-video-placeholder {
      width: 100%;
      padding-top: 60%;
      background: linear-gradient(135deg, #1a1714 0%, #3d3530 40%, #8a7a68 80%, #b4a28e 100%);
      position: relative;
    }
    .about-play-btn {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .play-circle {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      background: rgba(255,255,255,.15);
      border: 2px solid rgba(255,255,255,.5);
      display: flex;
      align-items: center;
      justify-content: center;
      color: white;
      font-size: 1.6rem;
      cursor: pointer;
      transition: all .4s;
      animation: pulsePlay 2.5s ease infinite;
    }
    .play-circle:hover { background: var(--taupe); border-color: var(--taupe); transform: scale(1.1); }
    @keyframes pulsePlay {
      0%, 100% { box-shadow: 0 0 0 0 rgba(180,162,142,.4); }
      50%       { box-shadow: 0 0 0 20px rgba(180,162,142,0); }
    }
    .about-video-tag {
      position: absolute;
      bottom: 1.5rem;
      left: 1.5rem;
      background: rgba(255,255,255,.12);
      backdrop-filter: blur(10px);
      border: 1px solid rgba(255,255,255,.2);
      color: white;
      padding: .7rem 1.2rem;
      border-radius: 2px;
    }
    .about-video-tag p {
      font-size: .65rem;
      letter-spacing: .2em;
      text-transform: uppercase;
      margin-bottom: .2rem;
      opacity: .6;
    }
    .about-video-tag strong {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.2rem;
      font-weight: 300;
    }

    .about-stat-card {
      background: var(--white);
      border-radius: 2px;
      padding: 1.8rem 1.4rem;
      border-left: 3px solid var(--taupe);
      box-shadow: var(--shadow-sm);
      transition: transform .35s;
    }
    .about-stat-card:hover { transform: translateY(-4px); }
    .about-stat-num {
      font-family: 'Cormorant Garamond', serif;
      font-size: 2.8rem;
      font-weight: 300;
      color: var(--taupe);
      line-height: 1;
    }
    .about-stat-label {
      font-size: .7rem;
      font-weight: 500;
      letter-spacing: .18em;
      text-transform: uppercase;
      color: var(--ink-soft);
      margin-top: .4rem;
    }

    /* ============================================
       FEATURED PRODUCTS STRIP
    ============================================ */
    #featured { padding: 5.5rem 0; background: var(--ink); }
    #featured .section-eyebrow { color: var(--taupe-light); }
    #featured .section-eyebrow::before { background: var(--taupe-light); }
    #featured .section-title { color: var(--white); }

    .featured-swiper .swiper-slide { height: auto; }
    .featured-card {
      background: rgba(255,255,255,.04);
      border: 1px solid rgba(180,162,142,.2);
      border-radius: 2px;
      overflow: hidden;
      transition: all .4s;
    }
    .featured-card:hover {
      background: rgba(180,162,142,.08);
      border-color: var(--taupe);
      transform: translateY(-6px);
    }
    .featured-card-img {
    
      position: relative;
      overflow: hidden;
    }
    .featured-card-img-bg {
      position: absolute;
      inset: 0;
      background-size: cover;
      background-position: center;
      transition: transform .6s;
    }
    .featured-card:hover .featured-card-img-bg { transform: scale(1.05); }

    .featured-card-body { padding: 1.2rem; }
    .featured-card-name {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.15rem;
      font-weight: 400;
      color: var(--white);
      margin-bottom: .5rem;
    }
    .featured-card-price {
      font-size: .9rem;
      font-weight: 600;
      color: var(--taupe-light);
    }

    .featured-nav-btn {
      width: 50px; height: 50px;
      border: 1.5px solid rgba(180,162,142,.4);
      background: transparent;
      color: var(--taupe-light);
      display: flex; align-items: center; justify-content: center;
      cursor: pointer;
      font-size: 1.1rem;
      transition: all .3s;
    }
    .featured-nav-btn:hover { background: var(--taupe); border-color: var(--taupe); color: white; }

    /* ============================================
       TESTIMONIALS
    ============================================ */
 /* Container & section */
#testimonials { 
  padding: 5.5rem 0; 
  background: var(--white); 
  overflow: hidden;
}

/* Slider wrapper */
#testimonials .row {
  display: flex;
  gap: 2rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 1rem;
}

/* Each testimonial card */
#testimonials .col-md-6.col-lg-4 {
  flex: 0 0 300px; /* fixed width for slider items */
  scroll-snap-align: start;
}

/* Card styling */
.testimonial-card {
  background: var(--off-white);
  border: 1px solid rgba(180,162,142,.2);
  border-radius: 8px;
  padding: 2.5rem 2rem;
  position: relative;
  transition: all .4s;
  height: 100%;
  box-shadow: var(--shadow-sm);
}
.testimonial-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-6px);
  border-color: var(--taupe);
}
.testimonial-card::before {
  content: '"';
  font-family: 'Cormorant Garamond', serif;
  font-size: 6rem;
  font-weight: 300;
  color: var(--taupe-light);
  position: absolute;
  top: .5rem;
  left: 1rem;
  line-height: 1;
  opacity: .2;
}

/* Stars */
.testimonial-stars { 
  display: flex; 
  gap: 4px; 
  margin-bottom: 1rem; 
}
.testimonial-stars i { font-size: .85rem; color: var(--gold); }

/* Text */
.testimonial-text {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  font-style: italic;
  font-weight: 300;
  line-height: 1.75;
  color: var(--ink-mid);
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 1;
}

/* Author block */
.testimonial-author { 
  display: flex; 
  align-items: center; 
  gap: 1rem; 
}
.testimonial-avatar {
  width: 60px; 
  height: 60px;
  border-radius: 50%;
  border: 2px solid var(--taupe-light);
  overflow: hidden;
  flex-shrink: 0;
  display: flex; 
  align-items: center; 
  justify-content: center;
}
.testimonial-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Name, Role, Verified */
.testimonial-name {
  font-family: 'Jost', sans-serif;
  font-size: .9rem;
  font-weight: 600;
  color: var(--ink);
}
.testimonial-role {
  font-size: .72rem;
  color: var(--taupe);
  letter-spacing: .1em;
}
.testimonial-verified {
  margin-left: auto;
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--taupe);
  display: flex;
  align-items: center;
  gap: .3rem;
}

/* Scrollbar hide for modern look */
#testimonials .row::-webkit-scrollbar { display: none; }
#testimonials .row { -ms-overflow-style: none; scrollbar-width: none; }

/* Responsive tweaks */
@media (max-width: 991px) {
  #testimonials .col-md-6.col-lg-4 { flex: 0 0 80%; }
}
@media (max-width: 575px) {
  #testimonials .col-md-6.col-lg-4 { flex: 0 0 95%; }
}
    /* ============================================
       BLOG / REELS
    ============================================ */
    #blog { padding: 5.5rem 0; background: var(--taupe-pale); }

    .blog-card {
      border-radius: 2px;
      overflow: hidden;
      background: var(--white);
      box-shadow: var(--shadow-sm);
      transition: all .4s;
    }
    .blog-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
    .blog-img-wrapper { position: relative; padding-top: 65%; overflow: hidden; }
    .blog-img-bg {
      position: absolute; inset: 0;
      background-size: cover; background-position: center;
      transition: transform .6s;
    }
    .blog-card:hover .blog-img-bg { transform: scale(1.06); }

    .blog-bg-1 { background: linear-gradient(135deg, #2c2520, #b4a28e); }
    .blog-bg-2 { background: linear-gradient(145deg, #3d3530, #d0c4b4); }
    .blog-bg-3 { background: linear-gradient(135deg, #6b5f55, #e8d5b0); }

    .blog-cat-tag {
      position: absolute;
      top: 1rem;
      left: 1rem;
      background: var(--taupe);
      color: white;
      font-size: .6rem;
      font-weight: 600;
      letter-spacing: .18em;
      text-transform: uppercase;
      padding: .3rem .8rem;
    }
    .blog-body { padding: 1.6rem 1.4rem; }
    .blog-meta {
      font-size: .65rem;
      color: var(--taupe);
      letter-spacing: .12em;
      text-transform: uppercase;
      margin-bottom: .7rem;
    }
    .blog-title {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.3rem;
      font-weight: 400;
      line-height: 1.35;
      color: var(--ink);
      margin-bottom: .8rem;
      transition: color .3s;
    }
    .blog-card:hover .blog-title { color: var(--taupe-dark); }
    .blog-excerpt {
      font-size: .82rem;
      color: var(--ink-soft);
      line-height: 1.75;
      margin-bottom: 1.2rem;
    }
    .blog-read-more {
      font-size: .68rem;
      font-weight: 600;
      letter-spacing: .2em;
      text-transform: uppercase;
      color: var(--taupe);
      text-decoration: none;
      display: inline-flex;
      align-items: center;
      gap: .5rem;
      transition: gap .3s;
    }
    .blog-read-more:hover { gap: .9rem; color: var(--taupe-dark); }

    /* Reels row */
    .reel-card {
      position: relative;
      border-radius: 2px;
      overflow: hidden;
      cursor: pointer;
      transition: transform .4s;
    }
    .reel-card:hover { transform: scale(1.02); }
    .reel-card-inner { padding-top: 170%; position: relative; }
    .reel-bg {
      position: absolute; inset: 0;
      background-size: cover; background-position: center;
      transition: transform .5s;
    }
    .reel-card:hover .reel-bg { transform: scale(1.05); }
    .reel-overlay {
      position: absolute; inset: 0;
      background: linear-gradient(to top, rgba(26,23,20,.7) 0%, transparent 50%);
    }
    .reel-play {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 50px; height: 50px;
      border-radius: 50%;
      background: rgba(255,255,255,.15);
      border: 2px solid rgba(255,255,255,.5);
      display: flex; align-items: center; justify-content: center;
      color: white;
      font-size: 1.2rem;
      opacity: 0;
      transition: opacity .3s;
    }
    .reel-card:hover .reel-play { opacity: 1; }
    .reel-info {
      position: absolute;
      bottom: 0; left: 0; right: 0;
      padding: 1rem;
      color: white;
    }
    .reel-info p {
      font-size: .68rem;
      font-weight: 500;
      letter-spacing: .12em;
      text-transform: uppercase;
      opacity: .75;
      margin-bottom: .2rem;
    }
    .reel-info strong {
      font-family: 'Cormorant Garamond', serif;
      font-size: 1.1rem;
      font-weight: 300;
    }
    .reel-bg-1 { background: linear-gradient(135deg, #1a1714, #8a7a68); }
    .reel-bg-2 { background: linear-gradient(145deg, #3d3530, #c9a96e); }
    .reel-bg-3 { background: linear-gradient(135deg, #2c2520, #b4a28e); }
    .reel-bg-4 { background: linear-gradient(145deg, #6b5f55, #d0c4b4); }

    /* ============================================
       CERTIFICATES
    ============================================ */
    #certificates { padding: 4.5rem 0; background: var(--white); }

    .cert-track-wrapper { overflow: hidden; }
    .cert-track {
      display: flex;
      gap: 2.5rem;
      animation: certScroll 28s linear infinite;
      align-items: center;
    }
    .cert-track:hover { animation-play-state: paused; }
    @keyframes certScroll {
      0%   { transform: translateX(0); }
      100% { transform: translateX(-50%); }
    }
    .cert-badge {
      flex-shrink: 0;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: .7rem;
      padding: 1.5rem 2rem;
      border: 1.5px solid rgba(180,162,142,.25);
      border-radius: 2px;
      background: var(--off-white);
      min-width: 160px;
      transition: all .35s;
    }
    .cert-badge:hover { border-color: var(--taupe); background: var(--white); box-shadow: var(--shadow-sm); }
    .cert-icon {
  width: 80px;   /* thoda bara */
  height: 80px;  /* thoda bara */
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--taupe-light), var(--taupe));
}

.cert-icon img {
  width: 70%;    /* image container ke hisaab se */
  height: 70%;
  object-fit: contain;
  border-radius: 50%; /* optional, agar image circle ho to */
}
    .cert-name {
      font-family: 'Jost', sans-serif;
      font-size: .65rem;
      font-weight: 600;
      letter-spacing: .15em;
      text-transform: uppercase;
      color: var(--ink-mid);
      text-align: center;
    }
    .cert-year {
      font-size: .62rem;
      color: var(--taupe);
      letter-spacing: .08em;
    }

    /* ============================================
       NEWSLETTER BANNER
    ============================================ */
    #newsletter {
      padding: 4rem 0;
      background: linear-gradient(135deg, var(--ink) 0%, #3d3530 50%, var(--taupe-dark) 100%);
      position: relative;
      overflow: hidden;
    }
    #newsletter::before {
      content: '';
      position: absolute;
      inset: 0;
      background:
        radial-gradient(circle at 20% 50%, rgba(180,162,142,.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 50%, rgba(201,169,110,.08) 0%, transparent 50%);
      pointer-events: none;
    }
    .newsletter-form {
      display: flex;
      max-width: 520px;
      border: 1.5px solid rgba(180,162,142,.4);
      overflow: hidden;
      border-radius: 2px;
    }
    .newsletter-input {
      flex: 1;
      background: rgba(255,255,255,.07);
      border: none;
      color: white;
      font-family: 'Jost', sans-serif;
      font-size: .8rem;
      padding: .9rem 1.4rem;
      outline: none;
    }
    .newsletter-input::placeholder { color: rgba(255,255,255,.4); }
    .newsletter-submit {
      background: var(--taupe);
      border: none;
      color: white;
      font-family: 'Jost', sans-serif;
      font-size: .7rem;
      font-weight: 600;
      letter-spacing: .18em;
      text-transform: uppercase;
      padding: .9rem 1.8rem;
      cursor: pointer;
      transition: background .3s;
      flex-shrink: 0;
    }
    .newsletter-submit:hover { background: var(--taupe-dark); }

    /* ============================================
       FOOTER
    ============================================ */
    #footer { background: var(--ink); padding: 4.5rem 0 2rem; }
    .footer-brand {
      font-family: 'Cormorant Garamond', serif;
      font-size: 2.2rem;
      font-weight: 300;
      letter-spacing: .25em;
      color: var(--white);
      text-transform: uppercase;
      margin-bottom: 1rem;
    }
    .footer-brand em { font-style: italic; color: var(--taupe); }
    .footer-tagline {
      font-size: .78rem;
      color: rgba(255,255,255,.4);
      line-height: 1.8;
      max-width: 300px;
      margin-bottom: 1.6rem;
    }
    .footer-social {
      display: flex;
      gap: .7rem;
    }
    .footer-social-link {
      width: 38px; height: 38px;
      border: 1px solid rgba(180,162,142,.3);
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      color: rgba(255,255,255,.5);
      font-size: .95rem;
      text-decoration: none;
      transition: all .3s;
    }
    .footer-social-link:hover {
      background: var(--taupe);
      border-color: var(--taupe);
      color: white;
      transform: translateY(-3px);
    }
    .footer-heading {
      font-family: 'Jost', sans-serif;
      font-size: .7rem;
      font-weight: 600;
      letter-spacing: .25em;
      text-transform: uppercase;
      color: var(--taupe-light);
      margin-bottom: 1.5rem;
    }
    .footer-links { list-style: none; }
    .footer-links li { margin-bottom: .65rem; }
    .footer-links a {
      color: rgba(255,255,255,.45);
      text-decoration: none;
      font-size: .78rem;
      letter-spacing: .06em;
      transition: all .3s;
      display: flex;
      align-items: center;
      gap: .5rem;
    }
    .footer-links a::before {
      content: '';
      width: 0;
      height: 1px;
      background: var(--taupe);
      transition: width .3s;
    }
    .footer-links a:hover { color: var(--taupe-light); }
    .footer-links a:hover::before { width: 16px; }

    .footer-contact-item {
      display: flex;
      align-items: flex-start;
      gap: .8rem;
      margin-bottom: 1rem;
      color: rgba(255,255,255,.45);
      font-size: .78rem;
      line-height: 1.6;
    }
    .footer-contact-item i {
      color: var(--taupe);
      font-size: 1rem;
      flex-shrink: 0;
      margin-top: 2px;
    }
    .footer-divider {
      border-color: rgba(180,162,142,.12);
      margin: 2.5rem 0 1.5rem;
    }
    .footer-bottom {
      font-size: .68rem;
      color: rgba(255,255,255,.28);
      letter-spacing: .1em;
    }
    .footer-bottom a { color: var(--taupe); text-decoration: none; }
    .footer-bottom a:hover { text-decoration: underline; }

    .footer-payment-icons {
      display: flex;
      gap: .6rem;
      flex-wrap: wrap;
      justify-content: flex-end;
    }
    .payment-icon {
      background: rgba(255,255,255,.08);
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 2px;
      padding: .3rem .6rem;
      font-size: .62rem;
      letter-spacing: .1em;
      text-transform: uppercase;
      color: rgba(255,255,255,.4);
    }

    /* ============================================
       BACK TO TOP
    ============================================ */
    #backToTop {
      position: fixed;
      bottom: 2rem;
      right: 2rem;
      width: 46px;
      height: 46px;
      background: var(--taupe);
      color: white;
      border: none;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      cursor: pointer;
      z-index: 999;
      opacity: 0;
      transform: translateY(20px);
      transition: all .4s;
      box-shadow: var(--shadow-md);
    }
    #backToTop.show { opacity: 1; transform: translateY(0); }
    #backToTop:hover { background: var(--taupe-dark); transform: translateY(-4px); }

    /* ============================================
       FLOATING CART
    ============================================ */
    #floatingCart {
      position: fixed;
      bottom: 2rem;
      left: 2rem;
      z-index: 999;
    }
    .float-cart-btn {
      width: 52px; height: 52px;
      background: var(--ink);
      color: var(--taupe-light);
      border: 1.5px solid rgba(180,162,142,.3);
      border-radius: 50%;
      display: flex; align-items: center; justify-content: center;
      font-size: 1.2rem;
      cursor: pointer;
      transition: all .4s;
      box-shadow: var(--shadow-md);
    }
    .float-cart-btn:hover { background: var(--taupe); color: white; transform: scale(1.08); }

    /* ============================================
       MISC
    ============================================ */
    .divider-line {
      width: 60px; height: 1.5px; background: var(--taupe);
      margin: 1rem 0 1.5rem;
    }
    .divider-ornament {
      display: flex; align-items: center; gap: 1rem;
      color: var(--taupe);
      margin: 3rem 0;
    }
    .divider-ornament::before, .divider-ornament::after {
      content: ''; flex: 1;
      height: 1px; background: rgba(180,162,142,.3);
    }
    .divider-ornament-icon { font-size: .85rem; }

    /* Responsive tweaks */
    @media (max-width: 991px) {
      .cat-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
      }
      .cat-card:first-child {
        grid-column: span 2;
        grid-row: span 1;
      }
      .hero-swiper { height: 75vh; }
      .hero-pagination-custom { display: none; }
    }
    @media (max-width: 767px) {
      .cat-grid { grid-template-columns: 1fr 1fr; }
      .cat-card:first-child { grid-column: span 2; }
      .hero-nav-btn { display: none; }
      .hero-swiper { height: 85vh; }
      .newsletter-form { flex-direction: column; }
      .footer-payment-icons { justify-content: flex-start; margin-top: 1rem; }
    }
    @media (max-width: 575px) {
      .cat-grid { grid-template-columns: 1fr; }
      .cat-card:first-child { grid-column: span 1; }
    }

    /* Cursor glow */
    .cursor-glow {
      width: 20px; height: 20px;
      border-radius: 50%;
      background: rgba(180,162,142,.25);
      border: 1.5px solid var(--taupe);
      position: fixed;
      pointer-events: none;
      z-index: 9999;
      transition: transform .15s ease;
      transform: translate(-50%, -50%);
    }