*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root {
  --red: #E8192C;
  --red-dark: #B5121F;
  --red-light: #FFF0F1;
  --orange: #FF6B00;
  --orange-light: #FFF4EC;
  --green: #0A9E60;
  --green-light: #E8F8F0;
  --blue: #0F6FBF;
  --blue-light: #EBF4FF;
  --yellow: #F5A623;
  --yellow-light: #FFFBF0;
  --navy: #1A2332;
  --white: #FFFFFF;
  --bg: #F5F5F5;
  --bg2: #FAFAFA;
  --border: #E8E8E8;
  --border2: #D4D4D4;
  --text: #1A2332;
  --text2: #4A5568;
  --text3: #8A9BB0;
  --shadow-xs: 0 1px 4px rgba(0, 0, 0, 0.07);
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 4px 20px rgba(0, 0, 0, 0.10);
  --shadow-lg: 0 8px 40px rgba(0, 0, 0, 0.12);
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 24px;
}

/* UTILITIES */
.mt-5 {
  margin-top: 5px !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.mt-15 {
  margin-top: 15px !important;
}

.mt-20 {
  margin-top: 20px !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.mt-40 {
  margin-top: 40px !important;
}

.mt-50 {
  margin-top: 50px !important;
}

.mb-5 {
  margin-bottom: 5px !important;
}

.mb-10 {
  margin-bottom: 10px !important;
}

.mb-15 {
  margin-bottom: 15px !important;
}

.mb-20 {
  margin-bottom: 20px !important;
}

.mb-30 {
  margin-bottom: 30px !important;
}

.p-0 {
  padding: 0 !important;
}

.m-0 {
  margin: 0 !important;
}

.w-100 {
  width: 100% !important;
}

.full {
  grid-column: 1 / -1;
}

a {
  text-decoration: none;
  color: inherit;
}

body {
  font-family: 'Inter', 'Noto Sans Bengali', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.6;
  overflow-x: hidden;
}

/* GLOBAL SWIPER PAGINATION */
.swiper-pagination {
  position: relative;
  bottom: 0 !important;
  margin-top: 20px !important;
  text-align: center;
  width: 100% !important;
  left: 0 !important;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4px;
}

.swiper-pagination-bullet {
  background: var(--text3) !important;
  opacity: 0.3 !important;
  width: 8px !important;
  height: 8px !important;
  transition: all 0.3s !important;
  margin: 0 !important;
}

.swiper-pagination-bullet-active {
  background: var(--red) !important;
  opacity: 1 !important;
  width: 24px !important;
  border-radius: 4px !important;
}

/* ══ ANNOUNCE BAR ══ */
.abar {
  background: var(--red);
  color: white;
  text-align: center;
  padding: 7px 16px;
  font-size: 13px;
  font-weight: 700;
}

.abar a {
  color: #FFE066;
  text-decoration: underline;
  margin-left: 8px;
}

/* ══ HEADER ══ */
header {
  background: var(--white);
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: 0;
  z-index: 1000;
  padding: 10px;
}

.h-top {
  padding: 10px 0;
  display: flex;
  align-items: center;
  gap: 24px;
  justify-content: space-between;
}

.logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex: 0 0 auto;
}

.logo img {
  height: 40px;
  width: auto;
  aspect-ratio: 1846 / 336;
  object-fit: contain;
}

.h-menu-btn {
  display: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--navy);
}

.search-bar {
  flex: 0 1 720px;
  display: flex;
  border: 1.5px solid var(--red);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.search-bar select {
  border: none;
  outline: none;
  padding: 0 12px;
  background: #FFF0F1;
  font-size: 13px;
  font-family: inherit;
  color: var(--text2);
  border-right: 1px solid #F0C0C3;
  cursor: pointer;
}

.search-bar input {
  flex: 1;
  border: none;
  outline: none;
  padding: 10px 14px;
  font-size: 14px;
  font-family: inherit;
  color: var(--text);
  background: white;
}

.search-bar button {
  background: var(--red);
  color: white;
  border: none;
  padding: 0 20px;
  font-size: 14px;
  cursor: pointer;
  font-weight: 700;
  transition: background 0.2s;
}

.search-bar button:hover {
  background: var(--red-dark);
}

.h-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1 1 0;
  justify-content: flex-end;
}

.h-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  padding: 0 12px;
  border-radius: var(--r-sm);
  text-decoration: none;
  color: var(--text2);
  font-size: 11px;
  font-weight: 600;
  transition: all 0.2s;
  position: relative;
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

.h-btn:hover {
  color: var(--red);
}

.h-btn .ico {
  font-size: 20px;
}

.h-badge {
  position: absolute;
  top: 2px;
  right: 4px;
  background: var(--red);
  color: white;
  font-size: 10px;
  font-weight: 800;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.h-badge.wishlist-count {
	right: 12px;
}

.h-signin {
  background: var(--red);
  color: white !important;
  border-radius: 999px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
  transition: all 0.2s;
  white-space: nowrap;
}

.h-signin:hover {
  background: var(--red-dark);
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.3);
}


/* ══ HERO SLIDER ══ */
.hero-section {
  background: var(--white);
  padding: 20px 0;
}

.hero-wrap {
  padding: 12px 0;
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 12px;
}

/* Left category sidebar */
.cat-sidebar {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}

.cat-sidebar-head {
  background: var(--red);
  color: white;
  padding: 12px 16px;
  font-size: 14px;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 8px;
}

.cat-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  transition: all 0.2s;
  cursor: pointer;
}

.cat-item:hover {
  background: var(--red-light);
  color: var(--red);
  padding-left: 20px;
}

.cat-item:last-child {
  border-bottom: none;
}

.cat-item .ci {
  font-size: 16px;
  width: 22px;
  text-align: center;
}

/* Slider */
.slider-main {
  position: relative;
  border-radius: var(--r-lg);
  overflow: hidden !important;
  background: #f0f0f0;
  height: 459px;
  min-width: 0;
  /* Prevents grid expansion */
  max-width: 100%;
}

.heroSwiper .swiper-wrapper {
  height: 100%;
}

.hero-slide-image {
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden;
  background: #f1f5f9;
}

.hero-slide-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

@media all and (max-width: 991px) {
  .slider-main {
    height: auto !important;
    aspect-ratio: 1200 / 400 !important;
  }

  .hero-slide-image img {
    object-fit: cover !important;
  }
}

.hero-slide-image a {
  display: block;
  width: 100%;
  height: 100%;
}

.hero-slide {
  height: 100% !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  padding: 40px 48px;
  gap: 40px;
  box-sizing: border-box;
}

.slide-1 {
  background: linear-gradient(135deg, #FFF5F5 0%, #FFE8E8 50%, #FFDADA 100%);
}

.slide-2 {
  background: linear-gradient(135deg, #F0FFF8 0%, #E0FFE8 50%, #C8FFD8 100%);
}

.slide-3 {
  background: linear-gradient(135deg, #F0F8FF 0%, #E0EEFF 50%, #C8DAFF 100%);
}

.slide-4 {
  background: linear-gradient(135deg, #FFFBF0 0%, #FFF5D8 50%, #FFEDB0 100%);
}

.slide-content {
  flex: 1;
}

.slide-tag {
  display: inline-block;
  background: var(--red);
  color: white;
  font-size: 11px;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 999px;
  margin-bottom: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.slide-2 .slide-tag {
  background: var(--green);
}

.slide-3 .slide-tag {
  background: var(--blue);
}

.slide-4 .slide-tag {
  background: var(--orange);
}

.slide-title {
  font-size: 30px;
  font-weight: 900;
  color: var(--navy);
  line-height: 1.2;
  letter-spacing: -0.5px;
  margin-bottom: 10px;
}

.slide-desc {
  font-size: 14px;
  color: var(--text2);
  margin-bottom: 20px;
  line-height: 1.6;
}

.slide-price {
  font-size: 13px;
  color: var(--text3);
  margin-bottom: 4px;
}

.slide-price-big {
  font-size: 28px;
  font-weight: 900;
  color: var(--red);
  margin-bottom: 20px;
}

.slide-2 .slide-price-big {
  color: var(--green);
}

.slide-3 .slide-price-big {
  color: var(--blue);
}

.slide-4 .slide-price-big {
  color: var(--orange);
}

.slide-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--red);
  color: white;
  padding: 12px 24px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
  font-family: inherit;
  border: none;
  cursor: pointer;
  transition: all 0.25s;
}

.slide-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(232, 25, 44, 0.35);
}

.slide-2 .slide-btn {
  background: var(--green);
}

.slide-2 .slide-btn:hover {
  box-shadow: 0 6px 20px rgba(10, 158, 96, 0.35);
}

.slide-3 .slide-btn {
  background: var(--blue);
}

.slide-4 .slide-btn {
  background: var(--orange);
}

.slide-visual {
  flex-shrink: 0;
  filter: drop-shadow(0 8px 24px rgba(0, 0, 0, 0.12));
  display: flex;
  align-items: center;
  justify-content: center;
}

.slide-visual .lucide {
  width: 140px;
  height: 140px;
  stroke-width: 1.2px;
  opacity: 0.8;
}

.hero-next,
.hero-prev {
  width: 35px !important;
  height: 35px !important;
  background: var(--white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 50% !important;
  color: var(--red) !important;
  box-shadow: var(--shadow-sm);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0 !important;
  top: 50% !important;
  transform: translateY(-50%);
}

.hero-next::after,
.hero-prev::after {
  font-size: 16px !important;
  font-weight: 900 !important;
}

.hero-next:hover,
.hero-prev:hover {
  background: var(--red) !important;
  color: var(--white) !important;
  border-color: var(--red) !important;
  box-shadow: 0 4px 15px rgba(232, 25, 44, 0.3);
}

.hero-prev {
  left: 10px;
}

.hero-next {
  right: 10px;
}

.hero-next:active,
.hero-prev:active {
  transform: translateY(-50%) scale(0.95);
}

.hero-pagination {
  bottom: 15px !important;
}


/* Right mini banners */
.mini-banners {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mini-banners .mini-banner {
  border-radius: var(--r-md);
  padding: 16px;
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s;
  text-decoration: none;
}

@media (hover: hover) {
  .mini-banner:hover {
    transform: scale(1.02);
  }
}

.mini-banner-1 {
  background: linear-gradient(135deg, #FFF0E0, #FFD4A0);
}

.mini-banner-2 {
  background: linear-gradient(135deg, #E8F4FF, #B8D8FF);
}

.mini-banner-3 {
  background: linear-gradient(135deg, #F0FFF4, #B8FFD8);
}

.mini-banners .mini-banner-4 {
  background: linear-gradient(135deg, #F9F5FF, #E9D5FF);
  display: none !important;
}

.mini-emo {
  font-size: 36px;
  margin-bottom: 4px;
}

.mini-emo .lucide {
  width: 32px;
  height: 32px;
}

.mini-sub {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--text3);
  letter-spacing: 0.05em;
}

.mini-title {
  font-size: 14px;
  font-weight: 800;
  color: var(--navy);
  line-height: 1.2;
}

.mini-off {
  font-size: 12px;
  font-weight: 700;
  color: var(--red);
  margin-top: 2px;
}

/* ══ TRUST BAR ══ */
.trust {
  background: var(--white);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 16px 0;
}

.trust-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

.trust-slider .swiper-slide {
  height: auto;
  display: flex;
  justify-content: center;
  width: auto;
  /* Required for slidesPerView: 'auto' */
}

/* ══ CSS MARQUEE FOR TRUST BAR ══ */
.trust-marquee {
  overflow: hidden;
  width: 100%;
}

.trust-marquee-track {
  display: flex;
  align-items: center;
  gap: 60px;
  width: max-content;
  animation: trustMarquee 40s linear infinite;
}

.trust-marquee-track:hover {
  animation-play-state: running;
}

@keyframes trustMarquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

.trustSwiper .swiper-wrapper {
  transition-timing-function: linear !important;
}

.trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
  white-space: nowrap;
}

.trust-ico {
  width: 38px;
  height: 38px;
  background: var(--red-light);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

/* ══ FLASH SALE ══ */
.flash {
  background: var(--white);
  border-top: 3px solid var(--red);
}

.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
}

.section-title-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
}

.section-badge {
  background: var(--red);
  color: white;
  font-size: 12px;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.section-title {
  font-size: 22px;
  font-weight: 900;
  color: var(--navy);
  letter-spacing: -0.3px;
}

.see-all {
  font-size: 13px;
  font-weight: 700;
  color: var(--red);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 4px;
  border: 1.5px solid var(--red);
  padding: 6px 14px;
  border-radius: 999px;
  transition: all 0.2s;
}

.see-all:hover {
  background: var(--red);
  color: white;
}

.countdown {
  display: flex;
  align-items: center;
  gap: 6px;
}

.cd-box {
  background: var(--navy);
  color: white;
  border-radius: var(--r-sm);
  padding: 6px 10px;
  text-align: center;
  min-width: 48px;
}

.cd-n {
  font-size: 20px;
  font-weight: 900;
  line-height: 1;
}

.cd-l {
  font-size: 9px;
  color: rgba(255, 255, 255, 0.5);
  text-transform: uppercase;
  margin-top: 1px;
}

.cd-sep {
  font-size: 18px;
  font-weight: 900;
  color: var(--red);
}

/* ══ PRODUCT GRID (5 cols) ══ */
.pgrid5 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}

.pgrid6 {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
}

.pgrid4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

/* ══ PRODUCT CARD ══ */
.pcard {
  background: var(--white);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: all 0.28s;
  cursor: pointer;
  position: relative;
  display: flex;
  flex-direction: column;
}

@media (hover: hover) {
  .pcard:hover {
    box-shadow: var(--shadow-md);
    border-color: #FFB3B8;
  }
}

.pcard-img {
  position: relative;
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1;
  overflow: hidden;
}

.pcard-emoji {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.3s;
}

.pcard-emoji .lucide {
  width: 72px;
  height: 72px;
  stroke-width: 1.5px;
  color: var(--text3);
}

.pcard:hover .pcard-emoji {
  transform: scale(1.1);
}

.pcard-disc {
  position: absolute;
  top: 8px;
  left: 8px;
  background: var(--red);
  color: white;
  font-size: 10px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 4px;
}

.pcard-disc.new {
  background: var(--green);
}

.pcard-disc.hot {
  background: var(--orange);
}

.pcard-wish {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 30px;
  height: 30px;
  z-index: 5;
}

.pcard-wish a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background: white;
  border: 1px solid var(--border);
  border-radius: 50%;
  transition: all 0.2s;
  box-shadow: var(--shadow-xs);
  text-decoration: none;
  color: var(--text3);
}

.pcard-wish a:hover {
  background: var(--red-light);
  border-color: var(--red);
  color: var(--red);
}

.pcard-wish a.active {
  border-color: var(--red) !important;
}

.pcard-body {
  padding: 15px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.pcard-actions {
  margin-top: 12px;
  display: flex;
  gap: 8px;
  opacity: 1;
  transform: none;
  transition: all 0.2s;
}

.btn-qv,
.btn-ac,
.woocommerce a.button.btn-ac,
.woocommerce-page a.button.btn-ac {
  padding: 8px 4px !important;
  border-radius: var(--r-sm) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  font-family: inherit !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  line-height: 1 !important;
  height: 36px !important;
  box-sizing: border-box !important;
  text-decoration: none !important;
  margin: 0 !important;
}

.btn-qv,
.btn-qv.button {
  flex: 1 !important;
  background: white !important;
  color: var(--navy) !important;
  border: 1px solid var(--border2) !important;
}

.btn-qv:hover,
.btn-qv.button:hover {
  background: var(--bg) !important;
  color: var(--navy) !important;
}

.btn-ac,
.btn-ac.button,
.woocommerce a.button.btn-ac,
.woocommerce-page a.button.btn-ac {
  flex: 1.5 !important;
  background: var(--red) !important;
  color: white !important;
  border: none !important;
}

.btn-ac:hover,
.btn-ac.button:hover,
.woocommerce a.button.btn-ac:hover,
.woocommerce-page a.button.btn-ac:hover {
  background: var(--red-dark) !important;
  color: white !important;
}

.added_to_cart {
  display: none !important;
}

/* Prevent WooCommerce default checkmarks and loading spinners in cart buttons */
.btn-ac::after,
.btn-ac.button::after,
.single_add_to_cart_button::after,
.single_add_to_cart_button.button::after,
.woocommerce a.button.btn-ac.loading::after,
.woocommerce a.button.btn-ac.added::after,
.woocommerce button.button.single_add_to_cart_button.loading::after,
.woocommerce button.button.single_add_to_cart_button.added::after {
  display: none !important;
  content: none !important;
}

.pcard-cat {
  font-size: 10px;
  color: var(--text3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: 3px;
}

.pcard-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.4;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  flex: 1;
}

.pcard-stars-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}

.pcard-stars {
  color: var(--yellow);
  margin-bottom: 0 !important;
  font-size: 14px;
}

.pcard-stars span {
  font-size: 16px;
}

.pcard-stars span.pcard-rev-count {
  color: var(--text3);
  font-size: 13px;
  margin-left: 2px;
}

.stars-desktop {
  display: inline-block;
  letter-spacing: -0.5px;
}

.stars-mobile {
  display: none;
}

.pcard-sold {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  line-height: 1;
}

.pcard-sold svg {
  width: 12px;
  height: 12px;
  stroke-width: 2.5;
}

.pcard-price {
  display: flex;
  align-items: baseline;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: auto;
}

.p-new {
  font-size: 17px;
  font-weight: 900;
  color: var(--red);
}

.p-old {
  font-size: 12px;
  color: var(--text3);
  text-decoration: line-through;
}

.p-save {
  font-size: 10px;
  font-weight: 700;
  color: var(--green);
  background: var(--green-light);
  padding: 2px 7px;
  border-radius: 999px;
}

/* ══ SECTION WRAPPER ══ */
.sec {
  padding: 20px 0;
}

.container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 20px;
}

.sec-bg-white {
  background: var(--white);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: 8px 0;
}

.sec-bg-gray {
  background: var(--bg2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin: 8px 0;
}

/* ══ TAB SECTION ══ */
.tab-bar {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border);
  margin-bottom: 20px;
}

.tab-btn {
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text3);
  border: none;
  background: none;
  font-family: inherit;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all 0.2s;
}

.tab-btn.active {
  color: var(--red);
  border-bottom-color: var(--red);
}

.tab-btn:hover {
  color: var(--red);
}

.tab-pane {
  display: none;
}

.tab-pane.active {
  display: grid;
}

/* ══ COLLECTION BANNERS ══ */
.col-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}

.col-grid-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
}

.col-banner {
  border-radius: var(--r-lg);
  padding: 24px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
  overflow: hidden;
  position: relative;
  min-height: 140px;
}

.col-banner:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}

.col-banner.a {
  background: linear-gradient(135deg, #FFF0E8, #FFD8C0);
}

.col-banner.b {
  background: linear-gradient(135deg, #E8F8FF, #C0E4FF);
}

.col-banner.c {
  background: linear-gradient(135deg, #F0FFFE, #C0F0EB);
}

.col-banner.d {
  background: linear-gradient(135deg, #FFF8E8, #FFE8B0);
}

.col-banner.e {
  background: linear-gradient(135deg, #F8E8FF, #E8C0FF);
}

.col-banner-text {}

.col-banner-sup {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text3);
  margin-bottom: 4px;
}

.col-banner-title {
  font-size: 20px;
  font-weight: 900;
  color: var(--navy);
  margin-bottom: 6px;
  line-height: 1.2;
}

.col-banner-off {
  font-size: 13px;
  font-weight: 700;
  color: var(--red);
  margin-bottom: 12px;
}

.col-banner-cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--red);
  color: white;
  font-size: 12px;
  font-weight: 700;
  padding: 7px 16px;
  border-radius: 999px;
  font-family: inherit;
  border: none;
  cursor: pointer;
  transition: 0.3s ease-in-out;
}

.col-banner-cta:hover {
  background: var(--red-dark);
}

.col-banner-emo {
  opacity: 0.9;
  display: flex;
  align-items: center;
  justify-content: center;
}

.col-banner-emo .lucide {
  width: 70px;
  height: 70px;
  stroke-width: 1.5px;
  color: var(--navy);
}

.col-banner-sm {
  min-height: 110px;
}

.col-banner-sm .col-banner-emo {
  font-size: 48px;
}

.col-banner-sm .col-banner-title {
  font-size: 15px;
}

/* ══ BEST SELLERS with sidebar ══ */
.bs-grid {
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 16px;
}

.bs-products {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

.bs-sidebar {}

.bs-rank-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}

.bs-rank-head {
  background: var(--navy);
  color: white;
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 8px;
}

.bs-rank-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  transition: background 0.2s;
  cursor: pointer;
}

.bs-rank-item:hover {
  background: var(--bg);
}

.bs-rank-item:last-child {
  border-bottom: none;
}

.bs-rank-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--red);
  color: white;
  font-size: 11px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.bs-rank-num.gold {
  background: #F5A623;
}

.bs-rank-num.silver {
  background: #8A9BB0;
}

.bs-rank-num.bronze {
  background: #C07843;
}

.bs-rank-emo {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  border-radius: 4px;
  overflow: hidden;
}

.bs-rank-emo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bs-rank-info {
  flex: 1;
  min-width: 0;
}

.bs-rank-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.bs-rank-price {
  font-size: 13px;
  font-weight: 900;
  color: var(--red);
  margin-top: 2px;
}

/* ══ RECENTLY VIEWED / RECOMMEND ══ */
.scroll-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}

/* ══ PROMO FULL-WIDTH ══ */
.promo-full {
  border-radius: var(--r-xl);
  padding: 40px 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, var(--red) 0%, #FF6B6B 100%);
  margin: 16px 0;
  overflow: hidden;
  position: relative;
}

.promo-full::before {
  content: '';
  position: absolute;
  right: -40px;
  top: -40px;
  width: 240px;
  height: 240px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 50%;
}

.promo-full::after {
  content: '';
  position: absolute;
  right: 80px;
  bottom: -60px;
  width: 160px;
  height: 160px;
  background: rgba(255, 255, 255, 0.05);
  border-radius: 50%;
}

.promo-full-text {}

.promo-full h2 {
  font-size: 28px;
  font-weight: 900;
  color: white;
  margin-bottom: 6px;
  line-height: 1.2;
}

.promo-full p {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 20px;
}

.promo-full-actions {
  display: flex;
  gap: 10px;
}

.btn-white {
  background: white;
  color: var(--red);
  padding: 12px 24px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 800;
  border: none;
  cursor: pointer;
  font-family: inherit;
  transition: all 0.2s;
}

.btn-white:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

.btn-outline-white {
  background: transparent;
  color: white;
  padding: 12px 24px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 700;
  border: 2px solid rgba(255, 255, 255, 0.5);
  cursor: pointer;
  font-family: inherit;
  transition: all 0.2s;
}

.btn-outline-white:hover {
  border-color: white;
  background: rgba(255, 255, 255, 0.1);
}

.promo-full-emos {
  display: flex;
  gap: 0;
  z-index: 1;
}

.promo-full-emos span {
  font-size: 64px;
  filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.15));
}

/* ══ CATEGORY SHOWCASE ══ */
.catshow-grid {
  gap: 10px;
}

.catshow-tile {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 8px;
  border-radius: var(--r-lg);
  cursor: pointer;
  transition: all 0.25s;
  text-decoration: none;
  border: 2px solid transparent;
  width: 100%;
  height: 120px;
}

.catSwiper {
  padding: 0px 0px 30px !important;
}

.ct-1 {
  background: #FFF0F1;
}

.ct-1:hover {
  border-color: var(--red);
}

.ct-2 {
  background: #FFF8E8;
}

.ct-2:hover {
  border-color: var(--yellow);
}

.ct-3 {
  background: #F0FFF8;
}

.ct-3:hover {
  border-color: var(--green);
}

.ct-4 {
  background: #F0F4FF;
}

.ct-4:hover {
  border-color: var(--blue);
}

.ct-5 {
  background: #FFF4EC;
}

.ct-5:hover {
  border-color: var(--orange);
}

.ct-6 {
  background: #F8F0FF;
}

.ct-6:hover {
  border-color: #9B59B6;
}

.ct-7 {
  background: #F0FFFE;
}

.ct-7:hover {
  border-color: #1ABC9C;
}

.ct-8 {
  background: #FFF5F0;
}

.ct-8:hover {
  border-color: #E67E22;
}

.ct-9 {
  background: #E8F4FF;
}

.ct-9:hover {
  border-color: #3498DB;
}

.ct-10 {
  background: #F0FFF4;
}

.ct-10:hover {
  border-color: #2ECC71;
}

.ct-11 {
  background: #FFF0E0;
}

.ct-11:hover {
  border-color: #E67E22;
}

.ct-emo {
  font-size: 30px;
}

.ct-name {
  font-size: 12px;
  font-weight: 800;
  color: var(--text2);
  text-align: center;
  line-height: 1.3;
}

.ct-count {
  font-size: 12px;
  color: var(--text3);
}

/* ══ REVIEWS SLIDER (SWIPER) ══ */
.revSwiper {
  padding: 0px 5px 30px !important;
}

.swiper-slide {
  height: auto;
  display: flex;
}

.rev-card {
  background: white;
  border-radius: 16px;
  padding: 30px;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  transition: all 0.3s;
  width: 100%;
  display: flex;
  flex-direction: column;
}

.rev-card:hover {
  box-shadow: var(--shadow-md);
  border-color: var(--blue);
}

.rev-stars {
  color: #FFB800;
  font-size: 16px;
  margin-bottom: 12px;
}

.rev-text {
  font-size: 15px;
  color: var(--text2);
  line-height: 1.6;
  font-style: italic;
  margin-bottom: 24px;
  flex: 1;
}

.rev-author {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: auto;
}

.rev-av {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-weight: 800;
  font-size: 18px;
}

.av-r {
  background: #FF4D4D;
}

.av-g {
  background: #00B894;
}

.av-b {
  background: #0984E3;
}

.av-o {
  background: #E17055;
}

.av-p {
  background: #6C5CE7;
}

.rev-name {
  font-weight: 800;
  color: var(--navy);
  font-size: 14px;
}

.rev-loc {
  font-size: 12px;
  color: var(--text3);
}

.rev-verified {
  font-size: 10px;
  color: #00B894;
  font-weight: 800;
  margin-top: 2px;
}

@media (max-width: 768px) {
  .rev-card {
    padding: 20px;
  }
}

/* ══ NEWSLETTER ══ */
.newsletter {
  background: var(--navy);
  padding: 50px 20px;
}

.newsletter-inner {
  max-width: 560px;
  margin: 0 auto;
  text-align: center;
}

.newsletter h2 {
  font-size: 26px;
  font-weight: 900;
  color: white;
  margin-bottom: 8px;
}

.newsletter p {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 24px;
}

.nl-form {
  display: flex;
  background: white;
  border-radius: 999px;
  overflow: hidden;
  padding: 4px 4px 4px 20px;
}

.nl-form input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 14px;
  font-family: inherit;
  color: var(--text);
  background: transparent;
}

.nl-form button {
  background: var(--red);
  color: white;
  border: none;
  padding: 10px 22px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 800;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s;
}

.nl-form button:hover {
  background: var(--red-dark);
}

/* ══ FOOTER ══ */
footer {
  background: #0F1923;
}

.footer-top {
  padding: 40px 0;
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: 40px;
}

@media all and (max-width: 991px) {
  .footer-top {
    grid-template-columns: 1fr 1fr !important;
    gap: 30px !important;
    padding: 30px 0 !important;
  }

  /* f-brand spans full width */
  .footer-top .f-brand {
    grid-column: 1 / -1 !important;
  }

  /* f-col items: 2 per row (categories + help side by side) */
  /* Last f-col (যোগাযোগ) spans both columns */
  .footer-top .f-col:last-child {
    grid-column: 1 / -1 !important;
  }
}

.f-brand .logo {
  margin-bottom: 12px;
}

.f-brand p {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.4);
  margin: 12px 0 20px;
  line-height: 1.7;
  max-width: 240px;
}

.f-socials {
  display: flex;
  gap: 10px;
}

.f-soc {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.45);
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s;
}

.f-soc .lucide,
.f-soc svg {
  width: 16px !important;
  height: 16px !important;
  color: rgba(255, 255, 255, 0.45) !important;
  display: inline-block !important;
  transition: color 0.2s !important;
}

.f-soc:hover .lucide,
.f-soc:hover svg {
  color: white !important;
}

.f-soc:hover {
  background: var(--red);
  border-color: var(--red);
  color: white;
  transform: translateY(-3px);
}

.f-col h5 {
  font-size: 13px;
  font-weight: 800;
  color: white;
  margin-bottom: 14px;
}

.f-col ul {
  list-style: none;
}

.f-col ul li {
  margin-bottom: 8px;
}

.f-col ul li a {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.4);
  text-decoration: none;
  transition: color 0.2s;
}

.f-col ul li a:hover {
  color: var(--yellow);
}

.footer-bot {
  border-top: 1px solid rgba(255, 255, 255, 0.07);
  padding: 16px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}

.footer-bot p {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.25);
}

.pay-row {
  display: flex;
  gap: 6px;
}

.pay {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.4);
}

/* ══ UTILITY ══ */
.mt8 {
  margin-top: 8px;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* ══ ANIMATIONS ══ */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.hero-wrap {
  animation: fadeUp 0.5s ease both;
}

/* ══ HELPER CLASSES (REPLACING INLINE STYLES) ══ */
.text-xs-muted {
  font-size: 12px;
  color: var(--text3);
  margin-top: 2px;
}

.flex-items-center-gap {
  display: flex;
  align-items: center;
  gap: 16px;
}

.btn-sm-cta {
  font-size: 11px;
  padding: 6px 14px;
}

.tab-hidden {
  display: none;
}

.bg-orange {
  background: var(--orange) !important;
}

.bg-text3 {
  background: var(--text3) !important;
}

.bg-blue {
  background: var(--blue) !important;
}

.rev-summary {
  font-size: 13px;
  color: var(--text3);
}

.text-white {
  color: white !important;
}

.nl-icon {
  font-size: 36px;
  margin-bottom: 10px;
}

.nl-note {
  font-size: 11px;
  color: rgba(255, 255, 255, 0.25);
  margin-top: 10px;
}

/* ══ LUCIDE ICONS ══ */
.lucide,
[data-lucide] {
  width: 20px;
  height: 20px;
  stroke-width: 2px;
  vertical-align: middle;
  display: inline-block;
}

.h-btn .ico .lucide,
.h-btn .ico [data-lucide] {
  width: 22px;
  height: 22px;
}

.h-signin .lucide,
.h-signin [data-lucide] {
  width: 18px;
  height: 18px;
}

.search-bar button .lucide,
.search-bar button [data-lucide] {
  width: 18px;
  height: 18px;
  margin-right: 4px;
}

.trust-ico .lucide,
.trust-ico [data-lucide] {
  width: 22px;
  height: 22px;
  color: var(--red);
}

.oc-link {
  display: flex;
  align-items: center;
}

.oc-link .lucide,
.oc-link [data-lucide] {
  width: 18px;
  height: 18px;
  margin-right: 12px;
  color: var(--text3);
}

.oc-close .lucide,
.oc-close [data-lucide] {
  width: 24px;
  height: 24px;
}

.pcard-wish .lucide,
.pcard-wish [data-lucide] {
  width: 16px;
  height: 16px;
  color: var(--text3);
}

.pcard-wish:hover .lucide,
.pcard-wish:hover [data-lucide] {
  color: var(--red);
}

.btn-ac .lucide,
.btn-ac [data-lucide] {
  width: 14px;
  height: 14px;
  margin-right: 4px;
  vertical-align: -2px;
}

/* ══ OFFCANVAS ══ */
.offcanvas {
  position: fixed;
  top: 0;
  left: -300px;
  width: 300px;
  height: 100%;
  background: white;
  z-index: 2000;
  transition: all 0.3s ease;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
}

.offcanvas.active {
  left: 0;
}

.offcanvas-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}

.offcanvas-overlay.active {
  opacity: 1;
  visibility: visible;
}

.oc-head {
  padding: 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.oc-close {
  font-size: 20px;
  cursor: pointer;
  color: var(--text3);
}

.oc-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

.oc-section {
  margin-bottom: 24px;
}

/* Off-canvas mobile search layout override */
.oc-search {
  display: flex !important;
  width: 100% !important;
  flex-direction: row !important;
  align-items: stretch !important;
  border: 1.5px solid var(--red) !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  background: white !important;
}

.oc-search input[type="text"] {
  flex: 1 !important;
  width: 100% !important;
  border: none !important;
  outline: none !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  background: white !important;
  color: var(--text) !important;
  height: auto !important;
  border-radius: 12px;
}

.oc-search button {
  background: var(--red) !important;
  color: white !important;
  border: none !important;
  outline: none !important;
  padding: 0 15px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
}

.oc-search button svg {
  width: 18px !important;
  height: 18px !important;
  stroke: white !important;
}

.oc-title {
  font-size: 12px;
  font-weight: 800;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 12px;
}

.oc-link {
  display: block;
  padding: 10px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text2);
  text-decoration: none;
  border-bottom: 1px solid var(--bg);
}

.oc-link:hover {
  color: var(--red);
}

.oc-foot {
  padding: 20px;
  border-top: 1px solid var(--border);
}

.btn-signin.w-100 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  width: 100%;
  background: var(--red);
  color: white !important;
  border-radius: 999px;
  padding: 12px;
  font-weight: 700;
  text-decoration: none;
}

/* -- BREADCRUMBS -- */
.bc-section {
  background: var(--white);
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}

.bc {
  display: flex;
  align-items: center;
  gap: 8px;
  list-style: none;
  font-size: 13px;
  font-weight: 600;
  flex-wrap: nowrap;
  overflow: hidden;
  width: 100%;
}

.bc li {
  white-space: nowrap;
  flex-shrink: 0;
}

.bc li:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex-shrink: 1;
  min-width: 0;
  color: var(--text);
}

.bc li a {
  color: var(--text3);
  text-decoration: none;
  transition: color 0.2s;
}

.bc li a:hover {
  color: var(--red);
}

.bc li.active {
  color: var(--text);
}

.bc li i,
.bc li [data-lucide] {
  width: 14px;
  height: 14px;
  color: var(--text3);
}

/* -- SHOP LAYOUT -- */


.shop-wrap {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 30px;
  align-items: start;
}

.shop-sidebar {
  position: sticky;
  top: 90px;
}

.sw-widget {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 20px;
  margin-bottom: 20px;
}

.sw-title {
  font-size: 16px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 2px solid var(--red-light);
  position: relative;
}

.sw-title::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 40px;
  height: 2px;
  background: var(--red);
}

.sw-cat-list {
  list-style: none;
}

.sw-cat-list li a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text2);
  text-decoration: none;
  transition: all 0.2s;
}

.sw-cat-list li a span {
  font-size: 12px;
  color: var(--text3);
  background: var(--bg);
  padding: 2px 8px;
  border-radius: 999px;
}

.sw-cat-list li a:hover,
.sw-cat-list li a.active {
  color: var(--red);
  padding-left: 5px;
}

.sw-cat-list li a.active span {
  background: var(--red-light);
  color: var(--red);
}

.sw-check-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.sw-check {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
}

.sw-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--red);
  cursor: pointer;
}

.stars {
  color: #FFB800;
  letter-spacing: 2px;
}

.sw-promo {
  background: var(--red);
  border-radius: var(--r-md);
  padding: 30px 20px;
  color: white;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 200px;
}

.sw-promo-text h6 {
  font-size: 12px;
  text-transform: uppercase;
  opacity: 0.8;
  margin-bottom: 5px;
}

.sw-promo-text h4 {
  font-size: 24px;
  font-weight: 900;
  margin-bottom: 15px;
}

.sw-promo-text a {
  display: inline-block;
  background: white;
  color: var(--red);
  padding: 6px 16px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 800;
  text-decoration: none;
}

.sw-promo .lucide {
  position: absolute;
  right: -20px;
  bottom: -20px;
  width: 120px;
  height: 120px;
  opacity: 0.15;
  transform: rotate(-15deg);
}

/* -- PRICE RANGE UI -- */
.price-range-ui {
  padding-top: 10px;
}

.pr-track {
  height: 6px;
  background: var(--bg);
  border-radius: 3px;
  position: relative;
  margin-bottom: 20px;
}

.pr-fill {
  position: absolute;
  height: 100%;
  background: var(--red);
  border-radius: 3px;
}

.pr-handle {
  width: 16px;
  height: 16px;
  background: var(--white);
  border: 2px solid var(--red);
  border-radius: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
}

.pr-labels {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
}

.btn-red-sm {
  background: var(--red);
  color: white;
  border: none;
  padding: 10px;
  border-radius: var(--r-sm);
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s;
  text-decoration: none;
}

.btn-red-sm:hover {
  background: var(--red-dark);
}

/* -- SHOP MAIN -- */
.shop-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--white);
  padding: 15px 20px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  margin-bottom: 25px;
}

.shop-toolbar p,
.shop-toolbar form,
.shop-toolbar select,
.shop-toolbar button,
.woocommerce-result-count,
.woocommerce-ordering {
  margin: 0 !important;
}

.st-left p {
  font-size: 14px;
  color: var(--text2);
  font-weight: 600;
}

.st-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.st-sort {
  display: flex;
  align-items: center;
  gap: 10px;
}

.st-sort label {
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
}

.st-sort select {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  border: 1px solid var(--border) !important;
  height: 34px !important;
  padding: 0 32px 0 12px !important;
  border-radius: var(--r-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  outline: none !important;
  font-family: inherit !important;
  box-sizing: border-box !important;
  background-color: white !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234A5568' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  background-size: 14px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  box-shadow: var(--shadow-xs) !important;
}

.st-sort select:hover {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(232, 25, 44, 0.1) !important;
}

.st-sort select:focus {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(232, 25, 44, 0.15) !important;
}

.st-view {
  display: flex;
  gap: 5px;
}

.st-view button {
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  color: var(--text3);
  cursor: pointer;
  transition: all 0.2s;
}

.st-view button.active,
.st-view button:hover {
  background: var(--red);
  color: white;
  border-color: var(--red);
}

.st-view button i {
  width: 18px;
  height: 18px;
}

.pgrid-shop {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 40px;
}

/* -- PAGINATION -- */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
}

.pagination a {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--text2);
  font-weight: 700;
  text-decoration: none;
  transition: all 0.2s;
}

.pagination a.active,
.pagination a:hover:not(.disabled) {
  background: var(--red);
  color: white;
  border-color: var(--red);
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.25);
}

.pagination a.disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: var(--bg);
}

.pagination a i {
  width: 18px;
  height: 18px;
}


/* -- PRODUCT DETAILS -- */
.pd-wrap {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 50px;
  align-items: start;
}

.pd-gallery {
  min-width: 0;
  overflow: hidden;
}

.pdMainSwiper {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.pdThumbSwiper {
  width: 100%;
  max-width: 100%;
  overflow: hidden;
  margin-top: 10px;
}

.pd-main-slide {
  background: #fff;
  aspect-ratio: 1;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--border);
}

.pd-main-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.pd-thumb-slide {
  background: #fff;
  aspect-ratio: 1;
  display: flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  cursor: pointer;
  border: 1px solid var(--border);
  transition: all 0.3s ease;
  overflow: hidden;
}

.pd-thumb-slide:hover {
  border-color: var(--red);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.pd-thumb-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pd-thumb-slide.swiper-slide-thumb-active {
  border-color: var(--red);
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.15);
}

.pd-thumb-slide i {
  width: 40px;
  height: 40px;
  color: var(--text3);
}

.pd-badges {
  display: flex;
  gap: 8px;
  margin-bottom: 15px;
}

.pdb-item {
  padding: 4px 12px;
  border-radius: 999px;
  color: white;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.bg-red {
  background: var(--red);
}

.bg-green {
  background: var(--green);
}

.pd-title {
  font-size: 28px;
  font-weight: 900;
  color: var(--navy);
  line-height: 1.3;
  margin-bottom: 10px;
}

.pd-rating {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 20px;
}

.pd-rev-count {
  font-size: 13px;
  color: var(--text3);
}

.pd-price-wrap {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 25px;
  background: var(--bg);
  padding: 15px 20px;
  border-radius: var(--r-md);
  width: fit-content;
}

.pd-price-wrap .p-new {
  font-size: 30px;
  font-weight: 900;
  color: var(--red);
}

.pd-price-wrap .p-old {
  font-size: 18px;
  color: var(--text3);
  text-decoration: line-through;
}

.pd-price-wrap .p-save {
  background: #FFEFEE;
  color: var(--red);
  font-size: 12px;
  font-weight: 800;
  padding: 4px 10px;
  border-radius: 4px;
}

.pd-short-desc {
  font-size: 15px;
  color: var(--text2);
  margin-bottom: 30px;
  line-height: 1.7;
}

.pd-v-item {
  margin-bottom: 20px;
}

.pd-v-label {
  display: block;
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 10px;
}

.pd-v-options {
  display: flex;
  gap: 10px;
}

.pd-v-opt {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 2px solid transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  box-shadow: var(--shadow-xs);
}

.pd-v-opt.color.active {
  border-color: var(--red);
  transform: scale(1.1);
}

.pd-v-opt.size {
  width: auto;
  min-width: 60px;
  border-radius: 8px;
  background: var(--bg);
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
}

.pd-v-opt.size.active {
  background: var(--red);
  color: white;
  border-color: var(--red);
}

.pd-actions {
  display: flex;
  gap: 15px;
  margin-bottom: 30px;
  flex-wrap: wrap;
}

.pd-qty {
  display: flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  overflow: hidden;
  height: 48px;
}

.qty-btn {
  width: 40px;
  height: 100%;
  background: var(--bg);
  border: none;
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
}

.pd-qty input {
  width: 50px;
  border: none;
  text-align: center;
  font-weight: 700;
  font-family: inherit;
  outline: none;
}

.btn-red,
.btn-navy {
  border: none;
  padding: 12px 24px;
  border-radius: var(--r-sm);
  font-weight: 800;
  font-size: 15px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all 0.2s;
}


.btn-red {
  background: var(--red);
  color: white;
}

.btn-red:hover {
  background: var(--red-dark);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
}

.btn-navy {
  background: var(--navy);
  color: white;
}

.btn-navy:hover {
  opacity: 0.9;
  transform: translateY(-2px);
}

.pd-meta {
  border-top: 1px solid var(--border);
  padding-top: 20px;
  margin-bottom: 20px;
}

.pd-meta p {
  font-size: 13px;
  color: var(--text3);
  margin-bottom: 5px;
}

.pd-meta a {
  color: var(--text2);
  text-decoration: none;
  font-weight: 600;
}

.pd-meta a:hover {
  color: var(--red);
}

.pd-share {
  display: flex;
  align-items: center;
  gap: 15px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text2);
}

.pd-share-links {
  display: flex;
  gap: 10px;
}

.pd-share-links a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bg);
  color: var(--text2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.pd-share-links a .lucide,
.pd-share-links a svg {
  width: 16px !important;
  height: 16px !important;
  color: var(--text2) !important;
  display: inline-block !important;
}

.pd-share-links a:hover {
  background: var(--red);
  color: white;
}

.pd-share-links a:hover .lucide,
.pd-share-links a:hover svg {
  color: white !important;
}

/* -- PRODUCT TABS -- */
.pd-tabs {
  display: flex;
  gap: 30px;
  border-bottom: 2px solid var(--bg);
  margin-bottom: 30px;
}

.pd-tab-btn {
  background: none;
  border: none;
  padding: 15px 0;
  font-size: 16px;
  font-weight: 800;
  color: var(--text3);
  cursor: pointer;
  position: relative;
  transition: all 0.2s;
}

.pd-tab-btn.active {
  color: var(--red);
}

.pd-tab-btn.active::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--red);
}

.pd-tab-pane {
  display: none;
  animation: fadeIn 0.4s ease;
}

.pd-tab-pane.active {
  display: block;
}

.pd-tab-pane h3 {
  font-size: 20px;
  margin-bottom: 15px;
}

.pd-list {
  list-style: disc;
  margin-left: 20px;
  margin-top: 15px;
  color: var(--text2);
}

.pd-list li {
  margin-bottom: 10px;
}

.pd-info-table {
  width: 100%;
  max-width: 600px;
  border-collapse: collapse;
}

.pd-info-table th,
.pd-info-table td {
  padding: 12px 20px;
  border: 1px solid var(--border);
  text-align: left;
}

.pd-info-table th {
  background: var(--bg);
  width: 150px;
  font-weight: 800;
  color: var(--navy);
}

.pd-info-table td {
  color: var(--text2);
}

/* -- REVIEWS UI -- */
.rev-summary-box {
  display: flex;
  background: var(--bg);
  padding: 30px;
  border-radius: var(--r-md);
  gap: 40px;
}

.rs-left {
  text-align: center;
  padding-right: 40px;
  border-right: 1px solid var(--border2);
}

.rs-left h2 {
  font-size: 48px;
  font-weight: 900;
  color: var(--red);
  line-height: 1;
  margin-bottom: 5px;
}

.rs-right {
  flex: 1;
}

.rs-bar-item {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 10px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text2);
}

.rs-bar-item span {
  width: 50px;
}

.rs-bar {
  flex: 1;
  height: 8px;
  background: var(--white);
  border-radius: 4px;
  overflow: hidden;
}

.rs-fill {
  height: 100%;
  background: #FFB800;
}

.rev-form h4 {
  font-size: 20px;
  margin-bottom: 10px;
}

.rating-input {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
}

.stars-input {
  display: flex;
  gap: 5px;
  color: var(--text3);
}

.stars-input i {
  cursor: pointer;
  width: 20px;
}

.stars-input i:hover,
.stars-input i.active {
  color: #FFB800;
  fill: #FFB800;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.form-grid textarea {
  grid-column: span 2;
  height: 120px;
  padding: 15px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: inherit;
  outline: none;
}

.form-grid input {
  padding: 12px 15px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: inherit;
  outline: none;
}

.form-grid button {
  grid-column: span 2;
  width: fit-content;
}

/* ══ CART PAGE ══ */
.cart-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 350px;
  gap: 40px;
  align-items: start;
}

.cart-table {
  width: 100%;
  border-collapse: collapse;
}

.cart-table th {
  text-align: left;
  padding: 15px;
  border-bottom: 2px solid var(--bg);
  font-size: 14px;
  font-weight: 800;
  color: var(--navy);
}

.cart-table td {
  padding: 20px 15px;
  border-bottom: 1px solid var(--bg);
  vertical-align: middle;
}

.cp-item {
  display: flex;
  align-items: center;
  gap: 15px;
}

.cp-img {
  width: 70px;
  height: 70px;
  background: var(--bg);
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
}

.cp-img i {
  width: 32px;
  height: 32px;
  color: var(--text3);
}

.cp-info a {
  display: block;
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  margin-bottom: 4px;
}

.cp-info a:hover {
  color: var(--red);
}

.cp-info span {
  font-size: 12px;
  color: var(--text3);
}

.td-price,
.td-subtotal {
  font-weight: 700;
  color: var(--text);
}

.btn-remove {
  background: none;
  border: none;
  color: var(--text3);
  cursor: pointer;
  transition: color 0.2s;
}

.btn-remove:hover {
  color: var(--red);
}

.cart-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.coupon-box {
  display: flex;
  gap: 10px;
}

.coupon-box input {
  padding: 10px 15px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  outline: none;
}

.btn-outline {
  background: none;
  border: 1px solid var(--border2);
  padding: 10px 20px;
  border-radius: var(--r-sm);
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
}

.btn-outline:hover {
  border-color: var(--red);
  color: var(--red);
}

/* ══ CART SUMMARY ══ */
.cs-box {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 25px;
  box-shadow: var(--shadow-sm);
}

.cs-title {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--bg);
}

.cs-row {
  display: flex;
  justify-content: space-between;
  padding: 12px 0;
  font-size: 14px;
  font-weight: 600;
  color: var(--text2);
}

.cs-row.total {
  border-top: 2px solid var(--bg);
  margin-top: 10px;
  padding-top: 20px;
  font-size: 20px;
  font-weight: 900;
  color: var(--red);
}

.shipping-opts {
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: right;
}

.shipping-opts label {
  font-size: 12px;
  cursor: pointer;
}

.shipping-opts input {
  accent-color: var(--red);
}

.justify-center {
  justify-content: center;
}

/* Simple Footer */
.footer-simple {
  padding: 30px 0;
  text-align: center;
  font-size: 13px;
  color: var(--text3);
  border-top: 1px solid var(--border);
}

/* ══ CHECKOUT PAGE ══ */
.checkout-wrap {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 400px;
  gap: 40px;
  align-items: start;
}

.ck-title {
  font-size: 20px;
  font-weight: 800;
  margin-bottom: 15px;
  color: var(--navy);
}

.ck-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.form-group.full {
  grid-column: span 2;
}

.form-group label {
  display: block;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--text2);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 12px 15px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: 14px;
  outline: none;
}

.form-group textarea {
  height: 100px;
}

.ck-items {
  border-bottom: 1px solid var(--bg);
  padding-bottom: 15px;
}

.ck-item {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
  margin-bottom: 10px;
}

.payment-methods {
  background: var(--bg);
  padding: 20px;
  border-radius: var(--r-sm);
}

.pm-title {
  font-size: 14px;
  font-weight: 800;
  margin-bottom: 15px;
  color: var(--navy);
}

.pm-item {
  display: flex;
  gap: 12px;
  margin-bottom: 15px;
  cursor: pointer;
}

.pm-item:last-child {
  margin-bottom: 0;
}

.pm-item input {
  margin-top: 4px;
  accent-color: var(--red);
}

.pm-name {
  font-size: 14px;
  font-weight: 800;
  color: var(--text);
}

.pm-desc {
  font-size: 12px;
  color: var(--text3);
  line-height: 1.4;
}

.ck-terms {
  font-size: 12px;
  color: var(--text3);
  margin-top: 20px;
  line-height: 1.5;
}

.ck-terms a {
  color: var(--red);
  text-decoration: none;
  font-weight: 700;
}

.h-50 {
  height: 50px;
}

/* ══ MY ACCOUNT ══ */
.shop-main {
  min-width: 0;
}

.account-wrap {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 40px;
  align-items: start;
}

@media (max-width: 991px) {
  .account-wrap {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}


.account-nav {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}

.an-user {
  padding: 25px;
  background: var(--bg2);
  display: flex;
  align-items: center;
  gap: 15px;
  border-bottom: 1px solid var(--border);
}

.an-av {
  width: 50px;
  height: 50px;
  background: var(--red);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 800;
}

.an-info h6 {
  font-size: 15px;
  font-weight: 800;
  color: var(--navy);
}

.an-info span {
  font-size: 11px;
  color: var(--text3);
}

.an-list {
  list-style: none;
}

.an-list li a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 15px 25px;
  font-size: 14px;
  font-weight: 700;
  color: var(--text2);
  text-decoration: none;
  border-bottom: 1px solid var(--bg);
  transition: all 0.2s;
}

.an-list li a i {
  width: 18px;
  height: 18px;
  color: var(--text3);
}

.an-list li a:hover,
.an-list li a.active {
  background: var(--red-light);
  color: var(--red);
  padding-left: 30px;
}

.an-list li a.active i {
  color: var(--red);
}

.an-list li a.logout {
  color: var(--text3);
}

.an-list li a.logout:hover {
  color: var(--red);
}

.account-pane {
  display: none;
  animation: fadeIn 0.4s ease;
  width: 100%;
}



.account-pane.active {
  display: block;
}



.account-main {
  min-width: 0;
}


/* Dashboard Stats */
.ac-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.stat-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 25px;
  display: flex;
  align-items: center;
  gap: 20px;
  box-shadow: var(--shadow-xs);
  transition: transform 0.3s ease;
}

.stat-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-sm);
}

.stat-card i {
  font-size: 28px;
  width: 40px;
  height: 40px;
}

.stat-info h4 {
  font-size: 26px;
  font-weight: 900;
  line-height: 1.2;
}

.stat-info span {
  font-size: 13px;
  color: var(--text3);
  font-weight: 700;
}

.text-red {
  color: var(--red);
}

.text-blue {
  color: var(--blue);
}

.text-orange {
  color: var(--orange);
}

.recent-orders {
  margin-top: 40px;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

.ac-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 600px;
}

.table-responsive {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 20px;
  border-radius: var(--r-md);
}


.ac-table th {
  text-align: left;
  padding: 15px;
  background: var(--bg);
  font-size: 13px;
  font-weight: 800;
  color: var(--navy);
}

.ac-table td {
  padding: 15px;
  border-bottom: 1px solid var(--bg);
  font-size: 14px;
  font-weight: 600;
  color: var(--text2);
}

.st-badge {
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.st-badge.processing {
  background: #EBF4FF;
  color: var(--blue);
}

.st-badge.completed {
  background: #E8F8F0;
  color: var(--green);
}

.btn-outline-sm {
  font-size: 12px;
  padding: 6px 12px;
  border: 1px solid var(--border2);
  border-radius: 4px;
  color: var(--text2);
  text-decoration: none;
  font-weight: 700;
}

.btn-outline-sm:hover {
  border-color: var(--red);
  color: var(--red);
}

/* Addresses */
.addr-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.addr-card {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 20px;
}

.addr-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--bg);
}

.addr-head h5 {
  font-size: 15px;
  font-weight: 800;
  color: var(--navy);
}

.addr-head a {
  color: var(--text3);
}

.addr-head a:hover {
  color: var(--red);
}

.addr-body p {
  font-size: 14px;
  color: var(--text2);
  margin-bottom: 5px;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/* -- MINI CART DRAWER -- */
.cart-drawer {
  position: fixed;
  top: 0;
  right: -400px;
  width: 400px;
  height: 100%;
  background: var(--white);
  z-index: 3000;
  box-shadow: -5px 0 30px rgba(0, 0, 0, 0.1);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
}

.cart-drawer.active {
  right: 0;
}

.cd-head {
  padding: 20px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.cd-head h4 {
  font-size: 18px;
  font-weight: 800;
  color: var(--navy);
  display: flex;
  align-items: center;
  gap: 10px;
}

.cd-close {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text3);
  transition: all 0.2s;
}

.cd-close:hover {
  color: var(--red);
  transform: rotate(90deg);
}

.cd-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

.cd-item {
  display: flex;
  gap: 15px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px dotted var(--border);
}

.cd-item:last-child {
  border-bottom: none;
}

.cd-item-img {
  width: 70px;
  height: 70px;
  background: var(--bg);
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.cd-item-img i {
  width: 30px;
  height: 30px;
  color: var(--text3);
}

.cd-item-info {
  flex: 1;
}

.cd-item-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  display: block;
  margin-bottom: 5px;
  line-height: 1.4;
}

.cd-item-name:hover {
  color: var(--red);
}

.cd-item-price {
  font-size: 15px;
  font-weight: 800;
  color: var(--red);
}

.cd-item-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 8px;
}

.cd-item-meta .cd-qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--border);
  padding: 0;
  border-radius: 4px;
  background: var(--white);
  font-size: 12px;
  font-weight: 700;
  color: var(--text2);
}

.cd-item-remove {
  color: var(--text3);
  cursor: pointer;
  transition: color 0.2s;
}

.cd-item-remove:hover {
  color: var(--red);
}

.cd-foot {
  padding: 20px;
  border-top: 1px solid var(--border);
  background: var(--bg2);
}

.cd-subtotal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
  font-weight: 800;
}

.cd-subtotal .label {
  color: var(--text2);
  font-size: 14px;
}

.cd-subtotal .val {
  color: var(--red);
  font-size: 20px;
}

.cd-btns {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.cd-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
  border-radius: var(--r-sm);
  font-weight: 800;
  font-size: 14px;
  text-decoration: none;
  transition: all 0.2s;
  gap: 10px;
}

.cd-btn-outline {
  border: 2px solid var(--border);
  color: var(--text);
}

.cd-btn-outline:hover {
  border-color: var(--red);
  color: var(--red);
}

.cd-btn-red {
  background: var(--red);
  color: white;
}

.cd-btn-red:hover {
  background: var(--red-dark);
}

@media (max-width: 480px) {
  .cart-drawer {
    width: 90%;
    right: -100%;
  }
}


/* MINI CART QUANTITY */
.cd-qty {
  display: flex;
  align-items: center;
  border: 1px solid var(--border);
  border-radius: 4px;
  width: fit-content;
  margin-top: 8px;
  height: 28px;
}

.cd-qty-btn {
  width: 24px;
  height: 100%;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text2);
}

.cd-qty input {
  width: 30px;
  height: 100%;
  border: none;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  background: transparent;
  outline: none;
}


/* REMOVE NUMBER INPUT ARROWS */
.pd-qty input::-webkit-outer-spin-button,
.pd-qty input::-webkit-inner-spin-button,
.cd-qty input::-webkit-outer-spin-button,
.cd-qty input::-webkit-inner-spin-button,
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  display: none !important;
  margin: 0 !important;
}

.pd-qty input,
.cd-qty input,
input[type=number] {
  -moz-appearance: textfield !important;
  appearance: none !important;
}






/* MINI CART META (Qty Left, Price Right) */
.cd-item-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 10px;
}

.cd-item-meta .cd-qty {
  margin-top: 0;
  /* Override previous margin */
}

.cd-item-price {
  margin-bottom: 0;
  font-size: 15px;
}


/* PRODUCT IMAGE STYLES */
.pcard-img img,
.cp-img img,
.cd-item-img img,
.wi-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .2s ease;
}


.pcard-img img:hover {
  transform: scale(1.05);
}

/* ══ QUICK CHECKOUT MODAL ══ */
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
  z-index: 4000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.modal-overlay.active {
  opacity: 1;
  visibility: visible;
}

.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -45%);
  width: 95%;
  max-width: 450px;
  background: var(--white);
  border-radius: var(--r-md);
  z-index: 4001;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  opacity: 0;
  visibility: hidden;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.2);
}

.modal.active {
  opacity: 1;
  visibility: visible;
  transform: translate(-50%, -50%);
}

.modal-head {
  padding: 20px 25px;
  border-bottom: 1px solid var(--bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal-head h5 {
  font-size: 18px;
  font-weight: 800;
  color: var(--navy);
  margin: 0;
}

.modal-close {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text3);
  padding: 5px;
  transition: color 0.2s;
}

.modal-close:hover {
  color: var(--red);
}

.modal-body {
  padding: 25px;
  overflow-y: auto;
  flex: 1;
}

#checkoutModal input[type="radio"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  position: absolute !important;
  z-index: -9999 !important;
  margin: 0 !important;
  padding: 0 !important;
}

.modal-body .form-group label {
  font-weight: 700;
  font-size: 14px;
  margin-bottom: 8px;
}

.modal-body .form-group input,
.modal-body .form-group textarea {
  border: 1px solid var(--border);
  padding: 14px;
  background: var(--bg);
  transition: border-color 0.2s;
}

.modal-body .form-group input:focus,
.modal-body .form-group textarea:focus {
  border-color: var(--red);
  background: var(--white);
}

@media (max-width: 576px) {
  .modal {
    width: calc(100% - 30px);
  }

  .modal-body {
    padding: 20px;
  }
}

/* ══ EXACT QUICK CHECKOUT UI ══ */
.checkout-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 15px;
}

.checkout-input-group {
  display: flex;
  align-items: center;
  background: var(--white);
  border: 1.5px solid #eee;
  border-radius: 10px;
  padding: 6px 12px;
  transition: all 0.3s;
}

.checkout-input-group:focus-within {
  border-color: var(--red);
  box-shadow: 0 3px 8px rgba(220, 20, 60, 0.08);
}

.cig-icon {
  width: 32px;
  height: 32px;
  background: var(--bg);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--red);
  margin-right: 12px;
  flex-shrink: 0;
}

.cig-icon svg {
  width: 14px;
  height: 14px;
}

.checkout-input-group input {
  border: none !important;
  background: transparent !important;
  padding: 6px 0 !important;
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  width: 100%;
}

.checkout-input-group input:focus {
  outline: none;
}

.checkout-products-list-fragment {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 165px;
  overflow-y: auto;
  padding-right: 6px;
  margin-bottom: 15px;
}

.checkout-products-list-fragment::-webkit-scrollbar {
  width: 5px;
}

.checkout-products-list-fragment::-webkit-scrollbar-track {
  background: rgba(0, 0, 0, 0.03);
  border-radius: 10px;
}

.checkout-products-list-fragment::-webkit-scrollbar-thumb {
  background: rgba(220, 20, 60, 0.2);
  border-radius: 10px;
}

.checkout-products-list-fragment::-webkit-scrollbar-thumb:hover {
  background: rgba(220, 20, 60, 0.4);
}

.checkout-product-card {
  display: flex;
  align-items: center;
  background: var(--white);
  border: 1.5px solid #f5f5f5;
  border-radius: 12px;
  padding: 8px 12px;
  gap: 12px;
}

.cpc-img {
  width: 50px;
  height: 50px;
  position: relative;
  border-radius: 8px;
  overflow: visible;
  border: 1px solid #eee;
  flex-shrink: 0;
}

.cpc-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 8px;
}

.cpc-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  background: var(--red);
  color: var(--white);
  width: 18px;
  height: 18px;
  border-radius: 50%;
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--white);
}

.cpc-info h6 {
  font-size: 12px;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 3px;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.cpc-price {
  font-size: 14px;
  font-weight: 800;
  color: var(--red);
}

.checkout-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 10px;
}

.delivery-options {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 15px;
}

.delivery-option {
  display: flex;
  align-items: center;
  background: var(--white);
  border: 1.5px solid #eee;
  border-radius: 10px;
  padding: 10px 15px;
  cursor: pointer;
  transition: all 0.3s;
}

.delivery-option:hover {
  border-color: var(--red);
  background: var(--bg);
}

.do-radio {
  width: 16px;
  height: 16px;
  border: 2px solid #ccc;
  border-radius: 50%;
  margin-right: 7px;
  position: relative;
  transition: all 0.2s;
  box-sizing: border-box;
}

.delivery-option input[type="radio"]:checked+.do-radio {
  border-color: #d35400;
}

.delivery-option input[type="radio"]:checked+.do-radio::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 8px;
  height: 8px;
  background: #d35400;
  border-radius: 50%;
  box-sizing: border-box;
}

.do-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  flex: 1;
}

.do-price {
  font-size: 13px;
  font-weight: 800;
  color: var(--red);
}

.payment-options {
  display: flex;
  gap: 10px;
  margin-bottom: 15px;
}

.payment-option {
  flex: 1;
  display: flex;
  align-items: center;
  background: var(--white);
  border: 1.5px solid #eee;
  border-radius: 10px;
  padding: 10px;
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
}

.payment-option:hover {
  border-color: var(--navy);
  background: var(--bg);
}

.payment-option.active {
  border-color: var(--navy);
  background: #f4f6f8;
}

.payment-option.bkash-option.active {
  border-color: #E2136E;
  background: #fff0f5;
}

.po-radio {
  width: 16px;
  height: 16px;
  border: 2px solid #ccc;
  border-radius: 50%;
  margin-right: 7px;
  position: relative;
  transition: all 0.2s;
  box-sizing: border-box;
}

.payment-option input[type="radio"]:checked+.po-radio {
  border-color: var(--navy);
}

.payment-option input[type="radio"]:checked+.po-radio::after {
  content: '';
  position: absolute;
  top: 2px;
  left: 2px;
  width: 8px;
  height: 8px;
  background: var(--navy);
  border-radius: 50%;
  box-sizing: border-box;
}

.payment-option.bkash-option input[type="radio"]:checked+.po-radio {
  border-color: #E2136E;
}

.payment-option.bkash-option input[type="radio"]:checked+.po-radio::after {
  background: #E2136E;
}

.po-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
}

.payment-option.bkash-option .po-label {
  color: #E2136E;
}

/* bKash Instructions */
.bkash-instructions {
  background: #fff8fafc;
  border: 1.5px solid #ffccd9;
  border-radius: 12px;
  padding: 15px;
  margin-bottom: 20px;
  animation: slideDown 0.3s ease-out;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.bkash-instruction-box {
  margin-bottom: 15px;
}

.bkash-step {
  font-size: 12.5px;
  line-height: 1.5;
  color: #555;
  margin-bottom: 6px;
}

.bkash-step strong {
  color: #E2136E;
}

.bkash-inputs .checkout-input-group {
  border-color: #ffccd9;
}

.bkash-inputs .checkout-input-group:focus-within {
  border-color: #E2136E;
  box-shadow: 0 0 0 3px rgba(226, 19, 110, 0.1);
}

.bkash-inputs .checkout-input-group input {
  font-size: 12px !important;
}

.bkash-inputs .checkout-input-group input::placeholder {
  color: #c0a0a8;
  font-size: 12px !important;
}

.checkout-total-box {
  background: #fafaf8;
  border: 1.5px solid #f0f0e8;
  border-radius: 12px;
  padding: 12px 15px;
  margin-bottom: 15px;
}

.ctb-line {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ctb-line span:first-child {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
}

.ctb-line span:last-child {
  font-size: 13px;
  font-weight: 800;
  color: var(--text);
}

.ctb-divider {
  margin: 10px 0;
  border-top: 1.5px dashed #e0e0d0;
}

.ctb-line.total span:first-child {
  font-size: 18px;
  font-weight: 900;
  color: var(--red);
}

.ctb-line.total span:last-child {
  font-size: 18px;
  font-weight: 900;
  color: #f39c12;
}

@media (max-width: 480px) {
  #checkoutModal {
    max-height: 90vh;
  }

  .ctb-line.total span {
    font-size: 16px;
  }
}

/* Success Screen */
.success-body {
  text-align: center;
  padding: 40px 25px !important;
}

.success-icon {
  width: 80px;
  height: 80px;
  background: #e8f5e9;
  color: #2e7d32;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
}

.success-icon svg {
  width: 40px;
  height: 40px;
}

.success-body h3 {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 10px;
}

.success-body p {
  color: var(--text2);
  font-size: 15px;
  line-height: 1.6;
  margin-bottom: 30px;
}

/* ══ WOOCOMMERCE SINGLE PRODUCT OVERRIDES ══ */
.pd-woocommerce-add-to-cart form.cart {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-top: 25px;
  margin-bottom: 25px;
  flex-wrap: wrap;
}

.pd-woocommerce-add-to-cart form.cart .quantity {
  margin: 0;
  display: flex;
  align-items: center;
}

.pd-woocommerce-add-to-cart form.cart .single_add_to_cart_button.button {
  background: var(--red);
  color: white;
  border: none;
  padding: 12px 30px;
  border-radius: var(--r-sm);
  font-weight: 800;
  font-size: 15px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all 0.2s;
  height: 48px;
  line-height: 1;
}

.pd-woocommerce-add-to-cart form.cart .single_add_to_cart_button.button:hover {
  background: var(--red-dark);
  box-shadow: var(--shadow-sm);
}

/* Hide WooCommerce native spin buttons for quantity input */
.quantity input[type="number"]::-webkit-outer-spin-button,
.quantity input[type="number"]::-webkit-inner-spin-button,
.pd-qty input[type="number"]::-webkit-outer-spin-button,
.pd-qty input[type="number"]::-webkit-inner-spin-button,
input.qty[type="number"]::-webkit-outer-spin-button,
input.qty[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}

.quantity input[type="number"],
.pd-qty input[type="number"],
input.qty[type="number"] {
  -moz-appearance: textfield !important;
}

/* Style WooCommerce variable product fields if present */
.pd-woocommerce-add-to-cart form.cart .variations {
  width: 100%;
  margin-bottom: 20px;
  border: none;
}

.pd-woocommerce-add-to-cart form.cart .variations td {
  padding: 8px 0;
  border: none;
  background: transparent;
}

.pd-woocommerce-add-to-cart form.cart .variations label {
  font-weight: 700;
  font-size: 14px;
  color: var(--navy);
}

.pd-woocommerce-add-to-cart form.cart .variations select {
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  outline: none;
  font-family: inherit;
  font-size: 13px;
  color: var(--text2);
  background: var(--bg);
  min-width: 150px;
}

/* ══ PRODUCT DETAILS DESCRIPTION CONTENT STYLING ══ */
.pd-description-content {
  line-height: 1.8;
  font-size: 15px;
  color: var(--text2);
}

.pd-description-content p {
  margin-bottom: 15px;
}

.pd-description-content ul {
  list-style: none !important;
  padding-left: 0 !important;
  margin-bottom: 20px;
}

.pd-description-content ul li {
  position: relative;
  padding-left: 0 !important;
  margin-bottom: 10px;
  list-style-type: none !important;
}

.pd-description-content ol {
  padding-left: 20px;
  margin-bottom: 20px;
}

.pd-description-content ol li {
  margin-bottom: 10px;
}

.pd-description-content h1,
.pd-description-content h2,
.pd-description-content h3,
.pd-description-content h4,
.pd-description-content h5,
.pd-description-content h6 {
  color: var(--navy);
  font-weight: 800;
  margin-top: 25px;
  margin-bottom: 15px;
}

.pd-description-content h3 {
  font-size: 20px;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

.animate-spin {
  animation: spin 1s linear infinite;
  display: inline-block;
}

/* WordPress Default Search Widget Styling */
.sw-widget.widget_search form,
.sw-widget.widget_product_search form {
  display: flex;
  gap: 8px;
}

.sw-widget.widget_search input[type="search"],
.sw-widget.widget_search input[type="text"],
.sw-widget.widget_product_search input[type="search"],
.sw-widget.widget_product_search input[type="text"] {
  flex: 1;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  font-family: inherit;
  font-size: 14px;
  outline: none;
  width: 100%;
}

.sw-widget.widget_search button,
.sw-widget.widget_search input[type="submit"],
.sw-widget.widget_product_search button,
.sw-widget.widget_product_search input[type="submit"],
.sw-widget button.wp-block-search__button {
  background: var(--red) !important;
  color: white !important;
  border: none !important;
  padding: 8px 16px !important;
  border-radius: var(--r-sm) !important;
  font-weight: 700 !important;
  font-family: inherit !important;
  font-size: 14px !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
}

.sw-widget.widget_search button:hover,
.sw-widget.widget_search input[type="submit"]:hover,
.sw-widget.widget_product_search button:hover,
.sw-widget.widget_product_search input[type="submit"]:hover,
.sw-widget button.wp-block-search__button:hover {
  background: var(--red-dark) !important;
}

/* WordPress Default List Widgets Styling */
.sw-widget ul:not(.sw-cat-list) {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.sw-widget ul:not(.sw-cat-list) li {
  padding: 10px 0 !important;
  border-bottom: 1px solid var(--border) !important;
  font-size: 14px !important;
  color: var(--text2) !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.sw-widget ul:not(.sw-cat-list) li:last-child {
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.sw-widget ul:not(.sw-cat-list) li a {
  color: var(--text) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  transition: color 0.2s !important;
}

.sw-widget ul:not(.sw-cat-list) li a:hover {
  color: var(--red) !important;
}

/* -- LIST VIEW STYLING -- */
.pgrid-shop.list-view {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
}

.pgrid-shop.list-view .pcard {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 24px !important;
  padding: 20px !important;
  text-align: left !important;
}

.pgrid-shop.list-view .pcard .pcard-img {
  width: 160px !important;
  height: 160px !important;
  flex-shrink: 0 !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
}

.pgrid-shop.list-view .pcard .pcard-body {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 0 !important;
  align-items: flex-start !important;
}

.pgrid-shop.list-view .pcard .pcard-name {
  font-size: 15px !important;
  font-weight: 700 !important;
  margin-bottom: 6px !important;
  height: auto !important;
  line-height: 1.4 !important;
  display: block !important;
}

.pgrid-shop.list-view .pcard .pcard-price {
  margin-bottom: 8px !important;
}

.pgrid-shop.list-view .pcard .pcard-actions {
  margin-top: 10px !important;
  width: auto !important;
  display: flex !important;
  gap: 10px !important;
}

.pgrid-shop.list-view .pcard .pcard-actions .btn-ac,
.pgrid-shop.list-view .pcard .pcard-actions .btn-qv {
  flex: none !important;
  width: 130px !important;
}

@media all and (max-width: 575px) {
  .pgrid-shop.list-view .pcard {
    gap: 12px !important;
    padding: 12px !important;
  }

  .pgrid-shop.list-view .pcard .pcard-img {
    width: 100px !important;
    height: 100px !important;
  }

  .pgrid-shop.list-view .pcard .pcard-name {
    font-size: 13px !important;
    line-height: 1.3 !important;
  }

  .pgrid-shop.list-view .pcard .pcard-actions {
    flex-wrap: wrap !important;
    gap: 6px !important;
    width: 100% !important;
  }

  .pgrid-shop.list-view .pcard .pcard-actions .btn-ac,
  .pgrid-shop.list-view .pcard .pcard-actions .btn-qv {
    width: 100% !important;
    display: flex !important;
  }
}

/* -- PREMIUM CUSTOM SELECT DROPDOWN -- */
.custom-select-container {
  position: relative;
  display: inline-block;
  user-select: none;
  z-index: 100;
}

.custom-select-trigger {
  border: 1px solid var(--border) !important;
  height: 34px !important;
  padding: 0 32px 0 12px !important;
  border-radius: var(--r-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text) !important;
  background-color: white !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234A5568' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19.5 8.25l-7.5 7.5-7.5-7.5'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  background-size: 14px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  box-shadow: var(--shadow-xs) !important;
  display: flex !important;
  align-items: center !important;
}

.custom-select-container:hover .custom-select-trigger {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(232, 25, 44, 0.1) !important;
}

.custom-select-container.open .custom-select-trigger {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(232, 25, 44, 0.15) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%234A5568' stroke-width='2.5'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M4.5 15.75l7.5-7.5 7.5 7.5'/%3E%3C/svg%3E") !important;
}

.custom-options-wrap {
  position: absolute !important;
  top: calc(100% + 5px) !important;
  left: 0 !important;
  width: 200px !important;
  background: white !important;
  border-radius: var(--r-sm) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--shadow-md) !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transform: translateY(-8px) !important;
  transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1) !important;
  z-index: 101 !important;
  overflow: hidden !important;
}

.custom-select-container.open .custom-options-wrap {
  opacity: 1 !important;
  visibility: visible !important;
  transform: translateY(0) !important;
}

.custom-options {
  list-style: none !important;
  padding: 5px 0 !important;
  margin: 0 !important;
}

.custom-option {
  padding: 10px 16px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--text2) !important;
  cursor: pointer !important;
  transition: all 0.15s ease !important;
  text-align: left !important;
}

.custom-option:hover {
  background: var(--bg2) !important;
  color: var(--red) !important;
}

.custom-option.active {
  background: var(--red-light) !important;
  color: var(--red) !important;
  font-weight: 700 !important;
}

/* Header Search Bar Custom Select Overrides */
.search-bar {
  overflow: visible !important;
}

.search-bar .custom-select-container {
  display: flex !important;
  align-items: stretch;
}

.search-bar .custom-select-trigger {
  border: none !important;
  border-right: 1px solid #F0C0C3 !important;
  border-radius: 0 !important;
  border-top-left-radius: var(--r-lg) !important;
  border-bottom-left-radius: var(--r-lg) !important;
  height: 100% !important;
  background-color: #FFF0F1 !important;
  color: var(--text2) !important;
  box-shadow: none !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  padding: 0 32px 0 16px !important;
  white-space: nowrap !important;
  align-self: center;
}

.search-bar button {
  border-top-right-radius: var(--r-md) !important;
  border-bottom-right-radius: var(--r-md) !important;
}

.search-bar .custom-select-container:hover .custom-select-trigger,
.search-bar .custom-select-container.open .custom-select-trigger {
  border-color: #F0C0C3 !important;
  box-shadow: none !important;
  background-color: #ffe6e8 !important;
}

.search-bar .custom-options-wrap {
  width: 220px !important;
  top: calc(100% + 4px) !important;
  left: 0 !important;
}

/* Live AJAX Search Results Styling */
.search-bar {
  position: relative;
}

.ajax-search-results {
  position: absolute !important;
  top: calc(100% + 5px) !important;
  left: 0 !important;
  right: 0 !important;
  background: white !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--shadow-lg) !important;
  z-index: 999 !important;
  max-height: 420px !important;
  overflow-y: auto !important;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-10px);
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.ajax-search-results.active {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.ajax-search-loading {
  padding: 20px !important;
  text-align: center !important;
  font-size: 14px !important;
  color: var(--text3) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.ajax-search-no-results {
  padding: 25px 20px !important;
  text-align: center !important;
  font-size: 14px !important;
  color: var(--text2) !important;
  font-weight: 500 !important;
}

.ajax-search-list {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.ajax-search-item {
  border-bottom: 1px solid var(--border) !important;
  transition: background 0.15s ease !important;
}

.ajax-search-item:last-child {
  border-bottom: none !important;
}

.ajax-search-item a {
  display: flex !important;
  align-items: center !important;
  padding: 12px 16px !important;
  text-decoration: none !important;
}

.ajax-search-item:hover {
  background-color: var(--bg2) !important;
}

.asi-img {
  width: 48px !important;
  height: 48px !important;
  flex-shrink: 0 !important;
  margin-right: 12px !important;
  border-radius: var(--r-sm) !important;
  overflow: hidden !important;
  background: var(--bg) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.asi-img img {
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
}

.asi-info {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  min-width: 0 !important;
}

.asi-title {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: var(--navy) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  display: block !important;
  text-align: left !important;
}

.asi-price {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--red) !important;
  display: block !important;
  text-align: left !important;
}

.asi-price ins {
  text-decoration: none !important;
  font-weight: 700 !important;
}

.asi-price del {
  font-size: 11px !important;
  color: var(--text3) !important;
  margin-left: 6px !important;
  font-weight: 400 !important;
}

.ajax-search-more {
  background: var(--bg2) !important;
  border-top: 1px solid var(--border) !important;
  text-align: center !important;
  padding: 10px !important;
}

.ajax-search-more a {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--red) !important;
  text-decoration: none !important;
  display: block !important;
  transition: color 0.15s ease !important;
}

.ajax-search-more a:hover {
  color: var(--red-dark) !important;
}

/* Product Gallery Swiper Navigation & Cursor Tweaks */
.pdMainSwiper {
  position: relative;
}

.pdMainSwiper .swiper-button-prev,
.pdMainSwiper .swiper-button-next {
  background: white !important;
  color: var(--navy) !important;
  width: 35px !important;
  height: 35px !important;
  border-radius: 50% !important;
  box-shadow: var(--shadow-md) !important;
  border: 1px solid var(--border) !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.pdMainSwiper .swiper-button-prev::after,
.pdMainSwiper .swiper-button-next::after {
  font-size: 14px !important;
  font-weight: 700 !important;
}

.pdMainSwiper .swiper-button-prev:hover,
.pdMainSwiper .swiper-button-next:hover {
  background: var(--red) !important;
  color: white !important;
  border-color: var(--red) !important;
}

.pd-main-slide img {
  cursor: pointer !important;
}

/* ==========================================================================
   WOOCOMMERCE MY ACCOUNT STYLING
   ========================================================================== */
.woocommerce-account.logged-in .woocommerce {
  display: flex;
  gap: 30px;
  margin-top: 20px;
  align-items: start;
}

/* ══ PREMIUM LOGOUT LOGIN/REGISTER FORM ══ */
.woocommerce-account:not(.logged-in) .sec-bg-white.sec {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

.woocommerce-account:not(.logged-in) .sec-bg-white.sec>.container {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.woocommerce-account:not(.logged-in) .woocommerce {
  max-width: 480px;
  margin: 15px auto;
  padding: 0;
}

.woocommerce-account:not(.logged-in) #customer_login {
  display: block;
  margin-top: 0;
}

.woocommerce-account:not(.logged-in) #customer_login .col-1,
.woocommerce-account:not(.logged-in) #customer_login .col-2 {
  width: 100%;
  max-width: 100%;
  padding: 0;
}

.woocommerce-account:not(.logged-in) .woocommerce h2,
.woocommerce-account:not(.logged-in) .ck-title,
.woocommerce-account:not(.logged-in) .entry-title,
.woocommerce-account:not(.logged-in) .page-title {
  display: none !important;
}

.woocommerce-account form .form-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  margin-top: 0;
  margin-bottom: 5px;
  text-align: center;
}

.woocommerce-account .toggle-form-link {
  text-align: center;
  margin-top: 15px;
  margin-bottom: 0;
  font-size: 13.5px;
  color: var(--text2);
}

.woocommerce-account .toggle-form-link a {
  color: var(--red);
  font-weight: 700;
  text-decoration: none;
  margin-left: 4px;
  transition: color 0.2s;
}

.woocommerce-account .toggle-form-link a:hover {
  color: var(--red-dark);
  text-decoration: underline;
}

/* Lost/Reset Password Form Styling */
.woocommerce-account form.lost_reset_password {
  background: var(--white);
  border: 1px solid #e2e8f0 !important;
  border-radius: var(--r-lg) !important;
  padding: 40px 35px !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03) !important;
  max-width: 480px;
  margin: 15px auto !important;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  text-align: left;
}

.woocommerce-account form.lost_reset_password p {
  font-size: 13.5px;
  color: var(--text2);
  line-height: 1.6;
  margin-bottom: 10px;
}

.woocommerce-account form.login,
.woocommerce-account form.register {
  background: var(--white);
  border: 1px solid #e2e8f0 !important;
  border-radius: var(--r-lg) !important;
  padding: 40px 35px !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.03) !important;
  text-align: left;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

/* Center login form if it is the only child (registration disabled) */
.woocommerce-account:not(.logged-in) form.login:only-child,
.woocommerce-account:not(.logged-in) .woocommerce>form.login {
  max-width: 450px;
  margin: 0 auto !important;
}

/* Form Row Layouts */
.woocommerce-account form.login .form-row,
.woocommerce-account form.register .form-row,
.woocommerce-account form.lost_reset_password .form-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  float: none !important;
  clear: both !important;
}

.woocommerce-account form.login .form-row label,
.woocommerce-account form.register .form-row label,
.woocommerce-account form.lost_reset_password .form-row label {
  font-size: 12px;
  font-weight: 700;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.woocommerce-account form.login .form-row input.input-text,
.woocommerce-account form.register .form-row input.input-text,
.woocommerce-account form.lost_reset_password .form-row input.input-text {
  border: 1.5px solid #cbd5e1 !important;
  border-radius: var(--r-md) !important;
  padding: 12px 16px !important;
  font-size: 14px !important;
  background: #f8fafc !important;
  color: var(--navy) !important;
  outline: none !important;
  transition: all 0.2s !important;
  box-sizing: border-box;
  width: 100% !important;
}

.woocommerce-account form.login .form-row input.input-text:focus,
.woocommerce-account form.register .form-row input.input-text:focus,
.woocommerce-account form.lost_reset_password .form-row input.input-text:focus {
  border-color: var(--red) !important;
  background: var(--white) !important;
  box-shadow: 0 0 0 4px rgba(232, 25, 44, 0.08) !important;
}

/* Button Customization */
.woocommerce-account form.login button.button,
.woocommerce-account form.register button.button,
.woocommerce-account form.lost_reset_password button.button {
  background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%) !important;
  color: white !important;
  border: none !important;
  border-radius: 999px !important;
  padding: 14px 28px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.2) !important;
  width: 100% !important;
  margin-top: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.woocommerce-account form.login button.button:hover,
.woocommerce-account form.register button.button:hover,
.woocommerce-account form.lost_reset_password button.button:hover {
  transform: translateY(-1.5px);
  box-shadow: 0 6px 16px rgba(232, 25, 44, 0.3) !important;
}

/* Remember Me Checkbox */
.woocommerce-account form.login .woocommerce-form-login__rememberme {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  color: var(--text2);
  cursor: pointer;
  margin: 5px 0;
}

.woocommerce-account form.login .woocommerce-form-login__rememberme input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--red);
  cursor: pointer;
}

/* Lost Password Link */
.woocommerce-account form.login .lost_password {
  text-align: center;
  margin-top: 15px;
  margin-bottom: 0;
}

.woocommerce-account form.login .lost_password a {
  font-size: 13.5px;
  color: var(--navy);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s;
}

.woocommerce-account form.login .lost_password a:hover {
  color: var(--red);
  text-decoration: underline;
}

.woocommerce-account .woocommerce::before,
.woocommerce-account .woocommerce::after {
  content: none !important;
  display: none !important;
}

/* Navigation Menu */
.woocommerce-MyAccount-navigation {
  flex: 0 0 260px;
  background: white;
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  overflow: hidden;
  padding: 10px 0;
}

.woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.woocommerce-MyAccount-navigation li {
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce-MyAccount-navigation li a {
  display: block;
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text2);
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: all 0.2s ease;
}

.woocommerce-MyAccount-navigation li a:hover {
  background: var(--bg2);
  color: var(--red);
  padding-left: 24px;
}

.woocommerce-MyAccount-navigation li.is-active a {
  background: var(--red-light);
  color: var(--red);
  border-left-color: var(--red);
}

/* Content Area */
.woocommerce-MyAccount-content {
  flex: 1;
  background: white;
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border);
  padding: 30px;
  min-width: 0;
}

.woocommerce-MyAccount-content p {
  line-height: 1.8;
  color: var(--text2);
  font-size: 14px;
  margin-bottom: 20px;
}

.woocommerce-MyAccount-content a {
  color: var(--red);
  text-decoration: none;
  font-weight: 600;
}

.woocommerce-MyAccount-content a:hover {
  color: var(--red-dark);
  text-decoration: underline;
}

/* Tables (Orders) */
.woocommerce-MyAccount-content table.shop_table {
  border-collapse: collapse;
  width: 100% !important;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 1px solid var(--border);
}

.woocommerce-MyAccount-content table.shop_table th {
  background: var(--bg2);
  color: var(--navy);
  font-weight: 700;
  padding: 12px 16px;
  font-size: 13px;
  border: none;
  text-align: left;
}

.woocommerce-MyAccount-content table.shop_table td {
  padding: 16px;
  font-size: 13px;
  border-top: 1px solid var(--border);
  color: var(--text2);
}

.woocommerce-MyAccount-content table.shop_table td.woocommerce-orders-table__cell-order-actions a.button {
  background: var(--red) !important;
  color: white !important;
  padding: 6px 12px !important;
  border-radius: var(--r-sm) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-decoration: none;
  display: inline-block;
  transition: background 0.2s;
}

.woocommerce-MyAccount-content table.shop_table td.woocommerce-orders-table__cell-order-actions a.button:hover {
  background: var(--red-dark) !important;
}

/* Addresses */
.woocommerce-Addresses {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 15px;
}

.woocommerce-Address {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 20px;
  background: var(--bg);
}

.woocommerce-Address-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}

.woocommerce-Address-title h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  margin: 0;
}

.woocommerce-Address address {
  font-style: normal;
  line-height: 1.6;
  font-size: 13px;
  color: var(--text2);
}

/* Form Styles inside Account Details */
.woocommerce-MyAccount-content form.edit-account,
.woocommerce-MyAccount-content form.woocommerce-form-login {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.woocommerce-MyAccount-content .form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0;
}

.woocommerce-MyAccount-content .form-row label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
}

.woocommerce-MyAccount-content .form-row input.input-text {
  border: 1.5px solid var(--border) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  width: 100% !important;
  outline: none !important;
  transition: all 0.2s !important;
}

.woocommerce-MyAccount-content .form-row input.input-text:focus {
  border-color: var(--red) !important;
  box-shadow: 0 0 0 3px rgba(220, 20, 60, 0.08) !important;
}

.woocommerce-MyAccount-content button.button {
  background: var(--red) !important;
  color: white !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 20px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer !important;
  transition: background 0.2s !important;
  width: fit-content;
}

.woocommerce-MyAccount-content button.button:hover {
  background: var(--red-dark) !important;
}

/* Responsive adjustment */
@media (max-width: 768px) {
  .woocommerce-account .woocommerce {
    flex-direction: column;
  }

  .woocommerce-MyAccount-navigation {
    flex: 1;
    width: 100%;
  }

  .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }
}

/* ══ CUSTOM TOAST NOTIFICATIONS ══ */
#bb-toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 380px;
  width: calc(100% - 40px);
  pointer-events: none;
}

.bb-toast {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: white;
  border-left: 4px solid var(--red);
  border-radius: var(--r-md);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  pointer-events: auto;
  transform: translateX(120%);
  opacity: 0;
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

.bb-toast.show {
  transform: translateX(0);
  opacity: 1;
}

.bb-toast.hide {
  transform: translateY(-20px);
  opacity: 0;
  transition: all 0.25s ease-in;
}

.bb-toast-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.bb-toast-icon .lucide,
.bb-toast-icon [data-lucide] {
  width: 20px;
  height: 20px;
}

.bb-toast-error {
  border-left-color: var(--red);
  background: var(--red-light);
}

.bb-toast-error .bb-toast-icon {
  color: var(--red);
}

.bb-toast-success {
  border-left-color: var(--green);
  background: var(--green-light);
}

.bb-toast-success .bb-toast-icon {
  color: var(--green);
}

.bb-toast-warning {
  border-left-color: var(--yellow);
  background: var(--yellow-light);
}

.bb-toast-warning .bb-toast-icon {
  color: var(--yellow);
}

.bb-toast-content {
  flex-grow: 1;
  line-height: 1.4;
}

.bb-toast-close {
  cursor: pointer;
  color: var(--text3);
  font-size: 20px;
  line-height: 1;
  transition: color 0.15s;
}

.bb-toast-close:hover {
  color: var(--text);
}

@media all and (max-width: 575px) {
  #bb-toast-container {
    top: 15px;
    right: 20px;
    left: 20px;
    width: auto;
    max-width: none;
  }

  .bb-toast {
    transform: translateY(-120%);
  }

  .bb-toast.show {
    transform: translateY(0);
  }
}

/* ══ RELATED PRODUCTS SWIPER OVERRIDES ══ */
.relatedSwiper {
  width: 100% !important;
  margin: 0 !important;
  padding: 10px 0 !important;
}

.related-products .related-arrow {
  position: absolute !important;
  background: white !important;
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  box-shadow: var(--shadow-sm) !important;
  color: var(--navy) !important;
  transition: all 0.3s ease !important;
  top: 55% !important;
  transform: translateY(-50%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  z-index: 10 !important;
}

.related-products .related-arrow .lucide,
.related-products .related-arrow [data-lucide] {
  width: 16px !important;
  height: 16px !important;
}

.related-products .related-arrow:hover {
  background: var(--red) !important;
  color: white !important;
  box-shadow: 0 6px 20px rgba(232, 25, 44, 0.3) !important;
}

.related-products .related-prev {
  left: -16px !important;
}

.related-products .related-next {
  right: -16px !important;
}

@media all and (max-width: 767px) {
  .relatedSwiper {
    padding: 10px 0 !important;
  }

  .related-products .related-arrow {
    display: none !important;
    /* Hide arrows on mobile for swipe gesture space */
  }
}

/* ══ RELATED PRODUCTS STATIC GRID ══ */
.related-static-grid {
  display: grid;
  gap: 20px;
  width: 100%;
  padding: 10px 0;
}

/* Center and adjust columns based on counts */
.related-static-grid.related-grid-1 {
  grid-template-columns: minmax(200px, 300px);
}

.related-static-grid.related-grid-2 {
  grid-template-columns: repeat(2, minmax(200px, 300px));
}

.related-static-grid.related-grid-3 {
  grid-template-columns: repeat(3, minmax(200px, 300px));
}

.related-static-grid.related-grid-4 {
  grid-template-columns: repeat(4, minmax(200px, 300px));
}

@media all and (max-width: 1023px) {
  .related-static-grid.related-grid-4 {
    grid-template-columns: repeat(3, minmax(180px, 1fr));
  }
}

@media all and (max-width: 767px) {

  .related-static-grid.related-grid-3,
  .related-static-grid.related-grid-4 {
    grid-template-columns: repeat(2, minmax(140px, 1fr));
    gap: 10px;
  }

  .related-static-grid.related-grid-2 {
    grid-template-columns: repeat(2, minmax(140px, 1fr));
    gap: 10px;
  }

  .related-static-grid.related-grid-1 {
    grid-template-columns: minmax(140px, 300px);
  }
}

/* ══ ORDER TRACKING PAGE ══ */
.track-container {
  max-width: 500px;
  margin: 30px auto;
  background: var(--white);
  padding: 35px 30px;
  border-radius: var(--r-xl);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
  text-align: center;
}

.track-container.track-result-active {
  max-width: 750px;
  padding: 40px 30px;
}

.track-icon {
  width: 48px;
  height: 48px;
  color: var(--red);
  margin: 0 auto 15px auto;
  display: block;
  background: var(--red-light);
  padding: 10px;
  border-radius: 50%;
}

.track-header h3 {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 8px;
  letter-spacing: -0.3px;
}

.track-desc {
  font-size: 13.5px;
  color: var(--text2);
  line-height: 1.5;
  margin-bottom: 22px;
}

/* Customize WooCommerce tracking form style */
form.track_order {
  display: flex;
  flex-direction: column;
  max-width: 100%;
  margin: 0 auto;
}

/* Hide default WooCommerce message and clear-fix elements in the form */
form.track_order>p:first-child,
form.track_order .clear {
  display: none !important;
}

form.track_order .form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100% !important;
  margin: 0 !important;
  float: none !important;
}

.woocommerce form.track_order label {
  font-size: 11.5px !important;
  font-weight: 700 !important;
  color: #475569 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.8px !important;
  text-align: left !important;
  margin-bottom: 2px !important;
  display: block !important;
}

.woocommerce form.track_order input.input-text {
  width: 100% !important;
  padding: 13px 16px !important;
  border: 1px solid #cbd5e1 !important;
  border-radius: var(--r-md) !important;
  font-size: 13.5px !important;
  outline: none !important;
  font-family: inherit !important;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1) !important;
  background: #f8fafc !important;
  color: var(--navy) !important;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.01) !important;
}

.woocommerce form.track_order input.input-text:hover {
  border-color: #94a3b8 !important;
  background: #f1f5f9 !important;
}

.woocommerce form.track_order input.input-text:focus {
  border-color: var(--red) !important;
  background: var(--white) !important;
  box-shadow: 0 0 0 3px rgba(232, 25, 44, 0.08) !important;
}

.woocommerce form.track_order input.input-text::placeholder {
  color: #94a3b8 !important;
  opacity: 0.8 !important;
}

form.track_order button[type="submit"] {
  background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%);
  color: white;
  border: none;
  padding: 14px 28px;
  font-size: 14.5px;
  font-weight: 800;
  border-radius: 999px;
  cursor: pointer;
  width: 100%;
  transition: all 0.2s ease;
  font-family: inherit;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 6px;
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.2);
}

form.track_order button[type="submit"]:hover {
  background: linear-gradient(135deg, var(--red-dark) 0%, var(--red) 100%);
  box-shadow: 0 6px 16px rgba(232, 25, 44, 0.35);
  transform: translateY(-1.5px);
  color: white;
}

form.track_order button[type="submit"]:active {
  transform: translateY(0);
}

/* Custom stepper progress tracker */
.tracking-steps-wrap {
  margin-bottom: 30px;
  background: transparent;
  padding: 0;
  border-radius: 0;
  border: none;
  box-shadow: none;
}

.tracking-steps-title {
  font-size: 20px;
  font-weight: 900;
  color: var(--navy);
  margin-bottom: 35px;
  letter-spacing: -0.3px;
}

.tracking-steps {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
  width: 100%;
}

.tracking-step {
  flex: 1;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 2;
}

.step-icon-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 15px;
}

.step-icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #FFFFFF;
  border: 2px solid #E2E8F0;
  color: #94A3B8;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  box-shadow: var(--shadow-xs);
}

.step-icon svg {
  width: 22px;
  height: 22px;
}

.step-text-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.step-label {
  font-size: 14px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 6px;
}

.step-sub {
  font-size: 11px;
  color: var(--text3);
  max-width: 140px;
  line-height: 1.4;
}

.tracking-step-line {
  flex: 1;
  height: 4px;
  background: #E2E8F0;
  margin-top: 23px;
  /* Aligns horizontally with the middle of 50px icon */
  z-index: 1;
  border-radius: 2px;
}

/* Active Step Styling */
.tracking-step.active .step-icon {
  background: var(--red);
  border-color: var(--red);
  color: var(--white);
  box-shadow: 0 6px 15px rgba(232, 25, 44, 0.25);
}

.tracking-step.active .step-label {
  color: var(--red);
}

.tracking-step.active .step-sub {
  color: var(--text2);
}

.tracking-step-line.active {
  background: var(--red);
}

/* WooCommerce Error and Success Notices */
ul.woocommerce-error,
.woocommerce-error,
.woocommerce-message {
  background: #FEF2F2 !important;
  border: 1px solid #FCA5A5 !important;
  border-left: 4px solid var(--red) !important;
  padding: 14px 16px 14px 44px !important;
  border-radius: var(--r-md) !important;
  color: #991B1B !important;
  font-size: 13.5px !important;
  font-weight: 500 !important;
  text-align: left !important;
  list-style: none !important;
  margin: 0 0 24px 0 !important;
  box-shadow: 0 4px 12px rgba(239, 68, 68, 0.03) !important;
  position: relative !important;
  display: block !important;
  outline: none !important;
}

ul.woocommerce-error::before,
.woocommerce-error::before {
  content: "!" !important;
  font-family: inherit !important;
  font-weight: 800 !important;
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: var(--red) !important;
  color: white !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  line-height: 1 !important;
}

ul.woocommerce-error li,
.woocommerce-error li {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: 1.5 !important;
  display: block !important;
}

.woocommerce-message {
  background: #F0FDF4 !important;
  border: 1px solid #BBF7D0 !important;
  border-left: 4px solid #22C55E !important;
  color: #166534 !important;
  padding: 14px 16px 14px 44px !important;
  box-shadow: 0 4px 12px rgba(34, 197, 94, 0.03) !important;
}

.woocommerce-message::before {
  content: "✓" !important;
  font-family: inherit !important;
  font-weight: 800 !important;
  position: absolute !important;
  left: 14px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: #22C55E !important;
  color: white !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 11px !important;
  line-height: 1 !important;
}

/* WooCommerce notice alert styling - Flat & transparent like screenshot */
.woocommerce-info {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  color: var(--text) !important;
  font-size: 15px !important;
  display: block !important;
  margin: 15px auto 25px auto !important;
  max-width: 100% !important;
  text-align: center !important;
  box-shadow: none !important;
}

.woocommerce-info::before {
  display: none !important;
}

/* Highlighted mark tags - yellow highlights exactly like screenshot */
.woocommerce-info mark {
  background: #FFFF00 !important;
  color: var(--text) !important;
  padding: 2px 4px !important;
  border-radius: 0 !important;
  font-weight: 700 !important;
  box-shadow: none !important;
}

/* Underline and list icon for title */
.woocommerce-order-details h2.woocommerce-order-details__title {
  position: relative !important;
  padding-bottom: 12px !important;
  border-bottom: 3px solid var(--red) !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  font-size: 22px !important;
  font-weight: 900;
  color: var(--navy) !important;
  margin-bottom: 10px !important;
  width: auto !important;
  text-transform: none !important;
  letter-spacing: -0.3px;
}

.woocommerce-order-details h2.woocommerce-order-details__title::before {
  content: "" !important;
  display: inline-block !important;
  width: 24px !important;
  height: 24px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E8192C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='8' y1='6' x2='21' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='12' x2='21' y2='12'%3E%3C/line%3E%3Cline x1='8' y1='18' x2='21' y2='18'%3E%3C/line%3E%3Cline x1='3' y1='6' x2='3.01' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='12' x2='3.01' y2='12'%3E%3C/line%3E%3Cline x1='3' y1='18' x2='3.01' y2='18'%3E%3C/line%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
}

/* Order Details table enhancements - Borderless wrapper */
.woocommerce-order-details {
  margin-top: 25px;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

table.order_details {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  margin-top: 15px !important;
  background: var(--white) !important;
  border: 1.5px solid #E2E8F0 !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
}

/* Round the corner cells to match the table border radius */
table.order_details thead tr:first-child th:first-child {
  border-top-left-radius: var(--r-md) !important;
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

table.order_details thead tr:first-child th:last-child {
  border-top-right-radius: var(--r-md) !important;
  border-bottom-left-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}

table.order_details tfoot tr:last-child th:first-child,
table.order_details tfoot tr:last-child td:first-child {
  border-bottom-left-radius: var(--r-md) !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}

table.order_details tfoot tr:last-child td:last-child {
  border-bottom-right-radius: var(--r-md) !important;
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}

table.order_details th {
  background: var(--navy) !important;
  color: var(--white) !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  font-size: 13px !important;
  letter-spacing: 0.5px !important;
  padding: 16px 20px !important;
  border: none !important;
}

table.order_details td {
  padding: 18px 20px !important;
  border-bottom: 1px solid #E2E8F0 !important;
  color: var(--text2) !important;
  font-size: 14px !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

/* Zebra striping for order items */
table.order_details tbody tr:nth-child(even) {
  background: #FAFAFA !important;
}

table.order_details td a {
  color: var(--red) !important;
  font-weight: 600 !important;
  transition: color 0.2s !important;
}

table.order_details td a:hover {
  color: var(--red-dark) !important;
}

table.order_details tfoot th {
  background: transparent !important;
  border-bottom: 1px solid #E2E8F0 !important;
  font-size: 14px !important;
  text-transform: none !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
  letter-spacing: 0 !important;
  padding: 14px 20px !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

table.order_details tfoot td {
  font-weight: 700 !important;
  color: var(--navy) !important;
  padding: 14px 20px !important;
  border-bottom: 1px solid #E2E8F0 !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
}

/* Make Payment Method row stand out using brand color */
table.order_details tfoot tr:nth-last-child(2) th,
table.order_details tfoot tr:nth-last-child(2) td {
  color: var(--red) !important;
}

/* Highlight the final total row in red background with white text */
table.order_details tfoot tr:last-child th,
table.order_details tfoot tr:last-child td {
  font-size: 18px !important;
  color: var(--white) !important;
  background: var(--red) !important;
  border: none !important;
  border-bottom: none !important;
}


/* Customer details layout - Flat */
.woocommerce-customer-details {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  margin-top: 30px !important;
}

/* Align Billing and Shipping address side by side */
.woocommerce-customer-details .woocommerce-columns--addresses {
  display: flex;
  gap: 24px;
  width: 100%;
  margin-top: 20px;
}

.woocommerce-customer-details .woocommerce-column {
  flex: 1;
}

.woocommerce-customer-details .woocommerce-column__title {
  font-size: 18px !important;
  font-weight: 800 !important;
  color: var(--navy) !important;
  margin-bottom: 12px !important;
  text-align: left;
}

.woocommerce-customer-details address {
  border: 1.5px solid #E2E8F0 !important;
  border-left: 4px solid var(--red) !important;
  padding: 24px !important;
  border-radius: var(--r-md) !important;
  background: #FAFAFA !important;
  color: var(--text2) !important;
  font-style: normal !important;
  box-shadow: var(--shadow-xs) !important;
  text-align: left !important;
  font-size: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
}

.woocommerce-customer-details address br {
  display: none !important;
}

.woocommerce-customer-details address .address-field,
.woocommerce-customer-details address p {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 10px 0 !important;
  margin-left: 0 !important;
  padding: 0 !important;
  padding-left: 0 !important;
  position: relative !important;
  color: var(--text2) !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

/* Force override any high-specificity styles on WooCommerce phone and email elements */
body .woocommerce-customer-details address p.woocommerce-customer-details--phone,
body .woocommerce-customer-details address p.woocommerce-customer-details--email {
  margin: 0 0 10px 0 !important;
  margin-left: 0 !important;
  padding: 0 !important;
  padding-left: 0 !important;
  text-indent: 0 !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}

.woocommerce-customer-details address .address-field:last-child,
.woocommerce-customer-details address p:last-child {
  margin-bottom: 0 !important;
}

/* Ensure pseudo-element icons behave as flex items and are not absolutely positioned */
.woocommerce-customer-details address .address-name::before,
.woocommerce-customer-details address .address-location::before,
.woocommerce-customer-details address .woocommerce-customer-details--phone::before,
.woocommerce-customer-details address .woocommerce-customer-details--email::before {
  position: static !important;
  margin: 0 !important;
  transform: none !important;
  left: auto !important;
  top: auto !important;
}

/* Red brand icons using inline SVG */
.woocommerce-customer-details address .address-name::before {
  content: "" !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E8192C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='12' cy='7' r='4'%3E%3C/circle%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  flex-shrink: 0 !important;
}

.woocommerce-customer-details address .address-location::before {
  content: "" !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E8192C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'%3E%3C/path%3E%3Ccircle cx='12' cy='10' r='3'%3E%3C/circle%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  flex-shrink: 0 !important;
}

.woocommerce-customer-details address .woocommerce-customer-details--phone::before {
  content: "" !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E8192C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'%3E%3C/path%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  flex-shrink: 0 !important;
}

.woocommerce-customer-details address .woocommerce-customer-details--email::before {
  content: "" !important;
  display: inline-block !important;
  width: 16px !important;
  height: 16px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23E8192C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'%3E%3C/path%3E%3Cpolyline points='22,6 12,13 2,6'%3E%3C/polyline%3E%3C/svg%3E") !important;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  flex-shrink: 0 !important;
}

.btn-track-again {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%);
  color: white !important;
  padding: 15px 35px;
  font-size: 15px;
  font-weight: 800;
  border-radius: 999px;
  text-decoration: none;
  transition: all 0.25s ease;
  box-shadow: 0 4px 15px rgba(232, 25, 44, 0.25);
}

.btn-track-again:hover {
  box-shadow: 0 6px 22px rgba(232, 25, 44, 0.45);
  transform: translateY(-2px);
}

.btn-track-again:active {
  transform: translateY(0);
}

/* Responsive adjustments */
@media all and (max-width: 767px) {

  .tracking-steps-title {
    margin-bottom: 20px;
  }

  .tracking-steps {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding-left: 20px;
  }

  .tracking-step {
    flex-direction: row;
    align-items: center;
    text-align: left;
    gap: 15px;
    margin-bottom: 0;
    padding: 6px 0;
  }

  .step-icon-wrap {
    margin-bottom: 0;
  }

  .step-sub {
    max-width: 100%;
  }

  .step-text-wrap {
    align-items: flex-start !important;
    text-align: left !important;
  }

  .tracking-step-line {
    flex: none !important;
    width: 4px !important;
    height: 30px !important;
    margin-left: 23px !important;
    margin-top: -6px !important;
    margin-bottom: -6px !important;
    align-self: flex-start;
    z-index: 1 !important;
  }

  .woocommerce-order-details {
    padding: 0 !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
  }

  .woocommerce-customer-details {
    padding: 0 !important;
  }

  .woocommerce-customer-details .woocommerce-columns--addresses {
    flex-direction: column !important;
    gap: 20px !important;
  }

  table.order_details {
    display: block !important;
    width: 100% !important;
    border-collapse: separate !important;
  }

  table.order_details thead {
    display: none !important;
  }

  table.order_details tbody,
  table.order_details tfoot {
    display: block !important;
    width: 100% !important;
  }

  table.order_details tbody tr {
    display: block !important;
    width: 100% !important;
    padding: 16px !important;
    border-bottom: 1px solid #E2E8F0 !important;
  }

  table.order_details tbody td {
    display: block !important;
    padding: 0 !important;
    width: 100% !important;
    border: none !important;
    text-align: left !important;
    background: transparent !important;
  }

  table.order_details tbody td.product-name {
    margin-bottom: 8px !important;
  }

  table.order_details tbody td.product-name a {
    display: block !important;
    margin-bottom: 4px !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
  }

  table.order_details tbody td.product-name .product-quantity {
    display: inline-block !important;
    font-size: 13px !important;
    color: var(--text3) !important;
    font-weight: 600 !important;
  }

  table.order_details tbody td.product-total {
    font-size: 15px !important;
    color: var(--red) !important;
    font-weight: 700 !important;
    margin-top: 4px !important;
  }

  table.order_details tbody td.product-total::before {
    content: "Price: " !important;
    font-weight: 600 !important;
    color: var(--text2) !important;
    margin-right: 4px !important;
  }

  /* Footer layout adjustments to keep them side by side spanning 100% width */
  table.order_details tfoot tr {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
    padding: 12px 16px !important;
    border-bottom: 1px solid #E2E8F0 !important;
  }

  table.order_details tfoot tr:last-child {
    background: var(--red) !important;
    color: var(--white) !important;
    border-bottom: none !important;
  }

  table.order_details tfoot tr:last-child th,
  table.order_details tfoot tr:last-child td {
    color: var(--white) !important;
    font-size: 14px !important;
  }

  table.order_details tfoot th,
  table.order_details tfoot td {
    display: block !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    width: auto !important;
  }
}

@media all and (max-width: 575px) {

  .track-container,
  .track-container.track-result-active {
    padding: 25px 15px !important;
    margin: 20px auto !important;
    border-radius: var(--r-lg) !important;
  }
}

/* ══ CUSTOM WISHLIST STYLING ══ */
.pcard-wish a.active svg {
  fill: var(--red) !important;
  stroke: var(--red) !important;
}

/* ══ WISHLIST RESPONSIVE ══ */
@media all and (max-width: 991px) {

  /* Hide the table header on mobile */
  .cart-table thead {
    display: none !important;
  }

  /* Each row becomes a card block */
  .cart-table,
  .cart-table tbody,
  .cart-table tr {
    display: block !important;
    width: 100% !important;
  }

  .cart-table tr {
    border: 1px solid var(--border) !important;
    border-radius: var(--r-md) !important;
    margin-bottom: 12px !important;
    padding: 14px !important;
    background: var(--white) !important;
    box-shadow: var(--shadow-xs) !important;
    position: relative !important;
  }

  /* Hide individual td borders, card handles it */
  .cart-table td {
    border-bottom: none !important;
    padding: 0 !important;
    display: block !important;
    width: 100% !important;
  }

  /* Product cell: image left, name right */
  .cart-table .td-product {
    padding-bottom: 10px !important;
    padding-right: 30px !important;
    /* room for trash icon */
  }

  .cp-item {
    align-items: flex-start !important;
  }

  /* Force consistent image size */
  .cart-table .cp-img {
    width: 70px !important;
    min-width: 70px !important;
    height: 70px !important;
    flex-shrink: 0 !important;
    overflow: hidden !important;
  }

  .cart-table .cp-img img {
    width: 70px !important;
    height: 70px !important;
    object-fit: contain !important;
    display: block !important;
  }

  /* Price + Stock inline in one row */
  .cart-table .td-price,
  .cart-table .td-stock {
    display: inline-block !important;
    width: auto !important;
    vertical-align: middle !important;
  }

  .cart-table .td-price {
    font-size: 16px !important;
    font-weight: 800 !important;
    color: var(--red) !important;
    margin-right: 10px !important;
  }

  .cart-table .td-stock {
    font-size: 13px !important;
  }

  /* Price+stock row wrapper */
  .cart-table .td-price::after {
    content: '';
  }

  /* Action button: full width at bottom */
  .cart-table .td-action {
    margin-top: 10px !important;
  }

  .cart-table .td-action .btn-red-sm,
  .cart-table .td-action .btn-outline-sm {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
  }

  /* Remove (trash) button: top-right corner */
  .cart-table .td-remove {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    width: auto !important;
    display: block !important;
  }
}


.error-404-section {
  padding: 100px 0;
  background: #f8fafc;
}

.error-404-wrap {
  max-width: 600px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.error-404-icon-wrap {
  margin-bottom: 15px;
}

.error-404-icon {
  width: 64px;
  height: 64px;
  color: var(--red);
  animation: compass-pulse 2s infinite ease-in-out;
}

@keyframes compass-pulse {

  0%,
  100% {
    transform: scale(1) rotate(0deg);
    opacity: 0.85;
  }

  50% {
    transform: scale(1.08) rotate(15deg);
    opacity: 1;
  }
}

.error-404-title {
  font-size: 84px;
  font-weight: 900;
  color: var(--red);
  line-height: 1;
  margin: 10px 0;
  letter-spacing: -2px;
}

.error-404-subtitle {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 12px;
}

.error-404-text {
  font-size: 13.5px;
  color: var(--text2);
  line-height: 1.6;
  margin-bottom: 30px;
  text-align: center;
}



.error-404-actions {
  display: flex;
  gap: 15px;
  justify-content: center;
  align-items: center;
}

.error-404-actions .btn-red {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 24px;
  font-size: 13.5px;
  font-weight: 700;
  color: white;
  background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%);
  border-radius: 999px;
  text-decoration: none;
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.2);
  transition: all 0.2s;
}

.error-404-actions .btn-red:hover {
  transform: translateY(-1.5px);
  box-shadow: 0 6px 16px rgba(232, 25, 44, 0.3);
}

.error-404-actions .btn-outline-404 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 12px 24px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--navy);
  background: transparent;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  text-decoration: none;
  transition: all 0.2s;
}

.error-404-actions .btn-outline-404:hover {
  background: #f1f5f9;
  border-color: #94a3b8;
  color: var(--red);
}

.error-404-actions svg {
  width: 16px;
  height: 16px;
}

@media all and (max-width: 575px) {
  .error-404-section {
    padding: 50px 0;
  }

  .error-404-wrap {
    padding: 0 15px;
  }

  .error-404-title {
    font-size: 64px;
  }

  .error-404-subtitle {
    font-size: 18px;
  }

  .error-404-text {
    font-size: 13px;
    margin-bottom: 24px;
  }

  .error-404-actions {
    flex-direction: column;
    width: 100%;
    gap: 12px;
  }

  .error-404-actions a {
    width: 100%;
    justify-content: center;
    padding: 11px 20px;
  }
}

/* Single Product Page Wishlist Gallery Icon Styles */
.pd-gallery-wishlist {
  position: absolute;
  top: 15px;
  right: 15px;
  z-index: 10;
}

.pd-gallery-wishlist a.single-add-to-wishlist {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 50%;
  color: var(--text2);
  box-shadow: var(--shadow-sm);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-decoration: none;
}

.pd-gallery-wishlist a.single-add-to-wishlist.active {
  background: var(--white);
  border-color: var(--red);
}

.pd-gallery-wishlist a.single-add-to-wishlist svg {
  width: 20px;
  height: 20px;
  transition: transform 0.3s;
}

.pd-gallery-wishlist a.single-add-to-wishlist.active svg {
  fill: var(--red) !important;
  stroke: var(--red) !important;
}

/* Stock Status Badges */
p.stock.in-stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(10, 158, 96, 0.08) !important;
  color: var(--green) !important;
  padding: 6px 12px !important;
  border-radius: 6px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border: 1px solid rgba(10, 158, 96, 0.15) !important;
}

p.stock.out-of-stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(232, 25, 44, 0.08) !important;
  color: var(--red) !important;
  padding: 6px 12px !important;
  border-radius: 6px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  border: 1px solid rgba(232, 25, 44, 0.15) !important;
}

/* Hide Quantity Wrapper if Hidden Class is Present */
.pd-woocommerce-add-to-cart form.cart .quantity.hidden {
  display: none !important;
}

/* Align Stock Badge Side-by-Side with Order Button */
.pd-woocommerce-add-to-cart {
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  align-items: center;
  gap: 15px;
  flex-wrap: wrap;
}
.pd-woocommerce-add-to-cart form.cart {
  margin: 0 !important;
}
p.stock.in-stock, p.stock.out-of-stock {
  margin: 0 !important;
}

/* ══ WOOCOMMERCE NATIVE REVIEWS & COMMENT FORM ══ */
.woocommerce-reviews-wrapper {
  margin-top: 40px;
  background: var(--white);
  padding: 30px;
  border-radius: var(--r-md);
  border: 1px solid var(--border2);
}

#reviews {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 40px;
  align-items: start;
}

@media (max-width: 991px) {
  #reviews {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

.woocommerce-reviews-wrapper h2 {
  font-size: 20px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 25px;
  border-bottom: 2px solid var(--red);
  padding-bottom: 10px;
  display: inline-block;
}

.commentlist {
  list-style: none;
  padding: 0;
  margin: 0 0 40px 0;
}

.commentlist li.review {
  display: flex;
  gap: 12px;
  padding: 20px 0;
  border-bottom: 1px solid #eef2f5;
  align-items: flex-start;
}

.commentlist li.review img.avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  border: 1.5px solid #e2e8f0;
}

.commentlist li.review .comment-text {
  flex: 1;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  padding: 15px 20px !important;
  border-radius: 8px !important;
  display: flex !important;
  flex-direction: column !important;
}

.commentlist li.review .comment-text .meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 6px !important;
  font-size: 13px;
  color: var(--text3);
  order: 1;
}

.commentlist li.review .comment-text .meta strong {
  color: var(--navy);
  font-size: 14px;
  font-weight: 700;
}

.commentlist li.review .comment-text .meta .woocommerce-review__dash {
  color: #cbd5e1;
}

/* Star Rating Display */
.commentlist li.review .comment-text .star-rating {
  font-size: 12px;
  color: #FFB800;
  float: none !important;
  margin: 0 0 10px 0 !important;
  order: 2;
}

.commentlist li.review .comment-text .description {
  font-size: 14px;
  color: var(--text2);
  line-height: 1.6;
  order: 3;
}

.woocommerce-reviews-wrapper .star-rating {
  font-size: 12px;
  color: #FFB800;
  margin: 0;
}

/* Review Form Styling */
#review_form_wrapper {
  background: #f8fafc;
  padding: 35px;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  margin-top: 0;
}

#review_form h3 {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 6px;
  letter-spacing: -0.3px;
}

.comment-form .comment-notes {
  font-size: 13px;
  color: var(--text3);
  line-height: 1.5;
  margin-bottom: 25px;
  display: block;
}

.comment-form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.comment-form-rating,
.comment-form-comment,
.comment-form-author,
.comment-form-email,
.comment-form-cookies-consent,
.form-submit {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.comment-form-rating {
  grid-column: span 2;
}

.comment-form-comment {
  grid-column: span 2;
  margin-bottom: 10px;
}

.comment-form-author,
.comment-form-email {
  grid-column: span 1;
}

@media (max-width: 768px) {
  .comment-form-author,
  .comment-form-email {
    grid-column: span 2;
  }
}

.comment-form label {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: var(--white);
  font-family: inherit;
  font-size: 14px;
  color: var(--navy);
  outline: none;
  transition: all 0.2s ease-in-out;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.02);
}

.comment-form input[type="text"]:focus,
.comment-form input[type="email"]:focus,
.comment-form textarea:focus {
  border-color: var(--red);
  box-shadow: 0 0 0 3px rgba(232, 25, 44, 0.1), inset 0 1px 2px rgba(0, 0, 0, 0.02);
}

.comment-form textarea {
  height: 120px;
  resize: vertical;
}

.comment-form .comment-form-cookies-consent {
  grid-column: span 2;
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 10px !important;
}

.comment-form .comment-form-cookies-consent input[type="checkbox"] {
  width: auto !important;
  margin: 0 !important;
  cursor: pointer;
}

.comment-form .comment-form-cookies-consent label {
  font-weight: 500 !important;
  font-size: 13px !important;
  color: var(--text2) !important;
  margin: 0 !important;
  cursor: pointer;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.comment-form .form-submit {
  grid-column: span 2;
  margin-top: 15px;
}

.comment-form .form-submit input[type="submit"],
#review_form #submit,
.woocommerce-reviews-wrapper #submit,
.comment-form .submit {
  background: var(--red) !important;
  color: var(--white) !important;
  border: none !important;
  padding: 12px 35px !important;
  border-radius: 8px !important;
  font-weight: 800 !important;
  font-size: 15px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  width: fit-content !important;
  box-shadow: 0 2px 4px rgba(232, 25, 44, 0.15) !important;
  display: inline-block !important;
  text-transform: uppercase !important;
}

.comment-form .form-submit input[type="submit"]:hover,
#review_form #submit:hover,
.woocommerce-reviews-wrapper #submit:hover,
.comment-form .submit:hover {
  background: var(--navy) !important;
  color: var(--white) !important;
  box-shadow: 0 4px 6px rgba(26, 35, 50, 0.2) !important;
}

/* Star rating interactive links styling */
.comment-form-rating .stars span {
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  width: fit-content;
  gap: 2px;
}

.comment-form-rating .stars span a {
  display: inline-block;
  position: relative;
  width: 1.5em;
  height: 1.5em;
  text-indent: -9999px;
  color: transparent;
}

.comment-form-rating .stars span a::before {
  content: "☆";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-indent: 0;
  color: #cbd5e1;
  font-size: 24px;
  text-align: center;
  line-height: 1;
}

.comment-form-rating .stars span a:hover::before,
.comment-form-rating .stars span a:hover ~ a::before,
.comment-form-rating .stars span.selected a.active::before,
.comment-form-rating .stars span.selected a.active ~ a::before {
  content: "★";
  color: #FFB800;
}

/* ══ WISHLIST EMPTY STATE PREMIUM DESIGN ══ */
.wishlist-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  max-width: 500px;
  margin: 50px auto;
  padding: 45px 35px;
  background: var(--white);
  border-radius: 16px;
  border: 1px solid #cbd5e1;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
}

.wishlist-empty-state svg.lucide-heart,
.wishlist-empty-state i[data-lucide="heart"] {
  width: 64px;
  height: 64px;
  stroke: var(--text3);
  stroke-width: 1.5;
  margin-bottom: 20px;
  animation: pulse-heart 2s infinite ease-in-out;
}

@keyframes pulse-heart {
  0% {
    transform: scale(1);
    color: var(--text3);
  }
  50% {
    transform: scale(1.1);
    color: var(--red);
    stroke: var(--red);
  }
  100% {
    transform: scale(1);
    color: var(--text3);
  }
}

.wishlist-empty-state p {
  font-size: 16px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 20px;
}

.wishlist-empty-state .btn-red {
  background: var(--red);
  color: var(--white);
  padding: 12px 35px;
  border-radius: 8px;
  font-weight: 800;
  font-size: 15px;
  text-decoration: none;
  transition: all 0.25s ease;
  box-shadow: 0 4px 12px rgba(232, 25, 44, 0.2);
  display: inline-block;
  border: none;
  cursor: pointer;
}

.wishlist-empty-state .btn-red:hover {
  background: var(--navy);
  box-shadow: 0 6px 16px rgba(26, 35, 50, 0.25);
  transform: translateY(-2px);
  color: var(--white);
}