/* =============================================
   RESOLVETRASH2CASH — SITE-WIDE ENHANCEMENTS
   ============================================= */

/* ──────────────────────────────────────────────
   1. HERO BANNER SLIDER
   ────────────────────────────────────────────── */
.wsus__single_slider {
  position: relative;
  min-height: 500px;
}

/* Dark-to-transparent gradient from the left for text legibility */
.wsus__single_slider::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0, 0, 0, 0.60) 0%,
    rgba(0, 0, 0, 0.30) 55%,
    transparent 100%
  );
  z-index: 0;
  pointer-events: none;
}

.wsus__single_slider_text {
  position: relative;
  z-index: 1;
}

.wsus__single_slider_text h3 {
  font-size: 13px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #f8c8d9;
}

/* ── <em> tag inside slider h3 (e.g. "Sustainability") ── */
.wsus__single_slider_text h3 em {
  font-style: normal;
  background: linear-gradient(90deg, #ff6da0 0%, #ffb347 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  font-weight: 800;
  letter-spacing: 4px;
  position: relative;
  display: inline-block;
}
/* Glowing underline */
.wsus__single_slider_text h3 em::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #ff6da0 0%, #ffb347 100%);
  border-radius: 2px;
  box-shadow: 0 0 8px rgba(255, 109, 160, 0.60);
}

.wsus__single_slider_text h1 {
  color: #fff;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.30);
  line-height: 1.15;
}

.wsus__single_slider_text h6 {
  color: rgba(255, 255, 255, 0.90);
}

.wsus__single_slider_text .common_btn {
  border-radius: 50px;
  padding: 13px 36px;
  font-weight: 700;
  letter-spacing: 0.5px;
  box-shadow: 0 4px 20px rgba(171, 30, 86, 0.45);
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
}

.wsus__single_slider_text .common_btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(60, 121, 121, 0.45);
}

/* ──────────────────────────────────────────────
   2. SECTION HEADERS — coloured left accent bar
   ────────────────────────────────────────────── */
.wsus__section_header h3 {
  position: relative;
  padding-left: 14px;
  font-size: 22px;
  font-weight: 700;
}

.wsus__section_header h3::before {
  content: '';
  position: absolute;
  left: 0;
  top: 3px;
  bottom: 3px;
  width: 4px;
  background: #ab1e56;
  border-radius: 4px;
}

/* ──────────────────────────────────────────────
   3. CATEGORY / PRODUCT-TYPE FILTER BUTTONS
   ────────────────────────────────────────────── */
.monthly_top_filter button,
.monthly_top_filter2 button {
  border-radius: 50px !important;
  border: 1.5px solid #e2e2e2 !important;
  padding: 6px 20px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin: 3px 4px !important;
  transition: all 0.22s ease !important;
}

.monthly_top_filter button:hover,
.monthly_top_filter button.active,
.monthly_top_filter2 button:hover,
.monthly_top_filter2 button.active {
  border-color: #ab1e56 !important;
  box-shadow: 0 3px 12px rgba(171, 30, 86, 0.20) !important;
  transform: translateY(-1px) !important;
}

/* ──────────────────────────────────────────────
   4. SERVICES CARDS
   ────────────────────────────────────────────── */
.home_service_single_2 {
  border-radius: 14px !important;
  padding: 36px 24px 28px !important;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.06) !important;
  transition: box-shadow 0.30s ease, transform 0.30s ease !important;
}

.home_service_single_2:hover {
  box-shadow: 0 10px 32px rgba(171, 30, 86, 0.14) !important;
  transform: translateY(-5px) !important;
}

/* Icon in a circular coloured pill */
.home_service_single_2 i {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 62px !important;
  height: 62px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #fce4ec 0%, #f8bbd0 100%) !important;
  font-size: 24px !important;
  color: #ab1e56 !important;
  margin-bottom: 20px !important;
  transition: background 0.30s ease, color 0.30s ease, transform 0.30s ease !important;
}

.home_service_single_2:hover i {
  background: linear-gradient(135deg, #ab1e56 0%, #d63384 100%) !important;
  color: #fff !important;
  transform: scale(1.08) !important;
}

.home_service_single_2 h5 {
  font-size: 15px !important;
  font-weight: 700 !important;
  margin-bottom: 8px !important;
}

/* ──────────────────────────────────────────────
   5. PRODUCT CARDS — lift & shadow on hover
   ────────────────────────────────────────────── */
.wsus__product_item {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
  border-radius: 10px !important;
  transition: box-shadow 0.28s ease, transform 0.28s ease !important;
}

.wsus__product_item:hover {
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12) !important;
  transform: translateY(-4px) !important;
}

/* ──────────────────────────────────────────────
   6. POPULAR CATEGORY ITEM CARDS
   ────────────────────────────────────────────── */
.wsus__monthly_top_2 .wsus__hot_deals__single {
  border-radius: 10px !important;
  transition: box-shadow 0.28s ease, transform 0.28s ease !important;
}

.wsus__monthly_top_2 .wsus__hot_deals__single:hover {
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12) !important;
  transform: translateY(-4px) !important;
}

/* ──────────────────────────────────────────────
   7. BLOG CARDS — lift & image zoom on hover
   ────────────────────────────────────────────── */
.wsus__single_blog_2 {
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06) !important;
  border-radius: 10px !important;
  overflow: hidden;
  transition: box-shadow 0.28s ease, transform 0.28s ease !important;
}

.wsus__single_blog_2:hover {
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12) !important;
  transform: translateY(-4px) !important;
}

.wsus__single_blog_2 .wsus__blog_img img {
  transition: transform 0.40s ease;
}

.wsus__single_blog_2:hover .wsus__blog_img img {
  transform: scale(1.05);
}

/* ──────────────────────────────────────────────
   7b. HOME BLOG SECTION — enhanced card typography
   ────────────────────────────────────────────── */

/* Section spacing */
.home_blogs {
  padding: 60px 0 70px;
  background: #FBFBEE; /* Good Earth light cream */
}

/* Card shell — extends §7 base */
.home_blogs .wsus__home_blog_card {
  background: #fff;
  border-radius: 14px !important;
  display: flex;
  flex-direction: column;
  height: 100%;
}

/* Thumbnail — fixed height + zoom */
.home_blogs .wsus__hb_img {
  display: block;
  overflow: hidden;
  height: 195px;
  flex-shrink: 0;
}
.home_blogs .wsus__hb_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Text body */
.home_blogs .wsus__hb_body {
  padding: 16px 18px 20px !important;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Category badge — override inline style */
.home_blogs .wsus__hb_cat {
  background: #f5e8ed !important;
  color: #ab1e56 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 4px 12px !important;
  border-radius: 50px !important;
  margin-bottom: 12px !important;
  display: inline-block !important;
  text-decoration: none;
  width: fit-content;
  transition: background 0.2s ease, color 0.2s ease;
  position: static !important;
  top: auto !important;
}
.home_blogs .wsus__hb_cat:hover {
  background: #ab1e56 !important;
  color: #fff !important;
}
.home_blogs .wsus__hb_cat em {
  font-style: normal;
}

/* Title */
.home_blogs .wsus__hb_title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 15.5px !important;
  font-weight: 700 !important;
  line-height: 1.45;
  color: #191919 !important;
  text-decoration: none;
  margin-bottom: 10px;
  transition: color 0.2s ease;
}
.home_blogs .wsus__hb_title:hover {
  color: #ab1e56 !important;
}

/* Date */
.home_blogs .wsus__hb_date {
  font-size: 12px !important;
  color: #999 !important;
  display: flex !important;
  align-items: center;
  gap: 6px;
  margin-bottom: 14px !important;
  padding: 0 !important;
}
.home_blogs .wsus__hb_date i {
  color: #ab1e56;
  font-size: 11px;
  position: static !important;
}

/* Read more */
.home_blogs .wsus__hb_read_more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: #ab1e56;
  text-decoration: none;
  margin-top: auto;
  transition: gap 0.22s ease, color 0.2s ease;
}
.home_blogs .wsus__hb_read_more:hover {
  gap: 10px;
  color: #3C7979;
}
.home_blogs .wsus__hb_read_more i {
  font-size: 11px;
  transition: transform 0.22s ease;
}
.home_blogs .wsus__hb_read_more:hover i {
  transform: translateX(3px);
}

/* ──────────────────────────────────────────────
   8. PROMOTIONAL BANNER IMAGES — hover zoom
   ────────────────────────────────────────────── */
.wsus__single_banner_content {
  border-radius: 10px !important;
  overflow: hidden !important;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  transition: box-shadow 0.30s ease, transform 0.30s ease;
}

.wsus__single_banner_content:hover {
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.14) !important;
  transform: translateY(-3px);
}

.wsus__single_banner_content img {
  transition: transform 0.40s ease;
}

.wsus__single_banner_content:hover img {
  transform: scale(1.04);
}

/* =============================================
   FOOTER — GOOD EARTH STYLE
   Warm dark charcoal, Lora serif headings,
   clean minimal links, refined details
   ============================================= */

/* ── 9. Shell & top cerise accent ── */
.footer_2 {
  background: #1c1c1a !important; /* warm dark charcoal */
  border-top: 3px solid #ab1e56 !important;
  margin-top: 0;
}

/* Column padding */
.footer_2 .wsus__footer_content {
  padding-top: 40px;
  padding-bottom: 32px;
}

/* ── 10. Logo ── */
.wsus__footer_2_logo {
  display: block !important;          /* block so it takes its own line */
  padding: 0 !important;
  margin-bottom: 18px !important;
  line-height: 1;
}

.wsus__footer_2_logo img {
  display: block !important;
  width: auto !important;
  max-width: 170px !important;
  max-height: 58px !important;         /* constrain height for tall logos */
  object-fit: contain !important;
  object-position: left center !important;
  opacity: 1 !important;               /* full opacity — logo must be clearly visible */
}

/* Tagline — override the flex rule that applies to all footer p elements */
.footer_2 .wsus__footer_tagline {
  display: block !important;
  font-family: "Lora", Georgia, serif !important;
  font-style: italic !important;
  font-size: 12px !important;
  letter-spacing: 0.3px !important;
  color: rgba(251, 251, 238, 0.35) !important;
  line-height: 1.65 !important;
  margin-top: 2px !important;
  margin-bottom: 20px !important;
  padding-left: 0 !important;
  gap: 0 !important;
}

/* ── 11. Contact info rows ── */
.footer_2 .wsus__footer_content .action,
.footer_2 .wsus__footer_content p {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
  font-family: "Montserrat", sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 0.2px;
  margin-top: 10px;
  line-height: 1.65;
  color: rgba(251, 251, 238, 0.58) !important; /* cream at 58% */
  padding-left: 0 !important;
  text-decoration: none;
}

/* Minimal icon — no heavy circle */
.footer_2 .wsus__footer_content .action i,
.footer_2 .wsus__footer_content p i {
  flex-shrink: 0;
  width: auto !important;
  height: auto !important;
  border-radius: 0 !important;
  background: none !important;
  font-size: 12px;
  color: #ab1e56;
  margin-top: 3px;
  position: static !important;
  top: auto !important;
  left: auto !important;
}

.footer_2 .wsus__footer_content .action:hover {
  color: #FBFBEE !important;
  text-decoration: none;
}

/* ── 12. Social icons ── */
.footer_2 .wsus__footer_social {
  display: flex;
  gap: 6px;
  margin-top: 24px;
}

.footer_2 .wsus__footer_social li a {
  width: 34px !important;
  height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 13px;
  background: transparent !important;
  border: 1px solid rgba(251, 251, 238, 0.18) !important;
  color: rgba(251, 251, 238, 0.55) !important;
  border-radius: 50% !important;
  transition: border-color 0.24s ease, color 0.24s ease, background 0.24s ease !important;
  text-decoration: none;
}

.footer_2 .wsus__footer_social li a:hover {
  background: #ab1e56 !important;
  border-color: #ab1e56 !important;
  color: #fff !important;
  transform: none !important;
}

/* ── 13. Column headings — Lora italic, refined ── */
.footer_2 .wsus__footer_content h5 {
  font-family: "Lora", Georgia, serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  font-style: italic !important;
  letter-spacing: 0.5px !important;
  text-transform: none !important;
  color: #FBFBEE !important; /* Good Earth cream */
  border: none !important;
  padding-bottom: 12px !important;
  margin-bottom: 20px !important;
  display: block !important;
  position: relative;
}

/* Thin 1px rule below heading — minimal Good Earth style */
.footer_2 .wsus__footer_content h5::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(251, 251, 238, 0.12);
  border-radius: 0;
}

/* ── 14. Navigation links — clean, no carets ── */
.footer_2 .wsus__footer_menu li {
  margin-bottom: 0;
}

.footer_2 .wsus__footer_menu li a {
  font-family: "Montserrat", sans-serif !important;
  font-size: 12.5px !important;
  font-weight: 400 !important;
  letter-spacing: 0.4px !important;
  color: rgba(251, 251, 238, 0.52) !important;
  display: block !important;
  padding: 6px 0 !important;
  text-decoration: none;
  position: relative;
  transition: color 0.22s ease !important;
}

/* Hide caret icons in footer nav — Good Earth uses clean links */
.footer_2 .wsus__footer_menu li a i {
  display: none !important;
}

/* Underline slide-in on hover */
.footer_2 .wsus__footer_menu li a::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: 0;
  width: 0;
  height: 1px;
  background: #ab1e56;
  transition: width 0.28s ease;
}

.footer_2 .wsus__footer_menu li a:hover {
  color: #FBFBEE !important;
  padding-left: 0 !important;
}

.footer_2 .wsus__footer_menu li a:hover::after {
  width: 100%;
}

/* ── 15. Newsletter column ── */
.wsus__footer_content_2 h3 {
  font-family: "Lora", Georgia, serif !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  font-style: italic !important;
  letter-spacing: 0.2px !important;
  color: #FBFBEE !important;
  position: relative;
  padding-bottom: 12px;
  margin-bottom: 0;
}

/* Thin 1px rule below newsletter heading */
.wsus__footer_content_2 h3::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background: rgba(251, 251, 238, 0.12);
  border-radius: 0;
}

.wsus__footer_content_2 p {
  font-family: "Montserrat", sans-serif !important;
  margin-top: 14px !important;
  padding: 0 !important;
  font-size: 12.5px !important;
  letter-spacing: 0.2px;
  color: rgba(251, 251, 238, 0.50) !important;
  line-height: 1.7;
}

/* Newsletter form — stacked layout */
.footer_2 form {
  margin: 16px 0 0 !important;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer_2 form input {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(251, 251, 238, 0.22) !important;
  border-radius: 0 !important;
  color: #FBFBEE !important;
  font-family: "Montserrat", sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 0.3px;
  padding: 10px 0 10px 0 !important;
  transition: border-color 0.25s ease;
  width: 100%;
}

.footer_2 form input::placeholder {
  color: rgba(251, 251, 238, 0.32);
  font-size: 12px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
}

.footer_2 form input:focus {
  border-bottom-color: #ab1e56 !important;
  background: transparent !important;
  outline: none;
  box-shadow: none !important;
}

/* Subscribe button — outlined minimal style */
.footer_2 form button.subscribe_btn {
  align-self: flex-start;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: transparent !important;
  border: 1px solid rgba(251, 251, 238, 0.30) !important;
  border-radius: 8px !important;
  color: #FBFBEE !important;
  font-family: "Montserrat", sans-serif !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 10px 26px !important;
  position: static !important;
  right: auto !important;
  top: auto !important;
  width: auto !important;
  transition: background 0.24s ease, border-color 0.24s ease, color 0.24s ease !important;
}

.footer_2 form button.subscribe_btn i {
  font-size: 11px !important;
  transition: transform 0.22s ease !important;
}

.footer_2 form button.subscribe_btn:hover {
  background: #ab1e56 !important;
  border-color: #ab1e56 !important;
  color: #fff !important;
}

.footer_2 form button.subscribe_btn:hover i {
  transform: translate(3px, -3px) !important;
}

/* ── 16. Bottom bar ── */
.wsus__footer_bottom {
  margin-top: 0 !important;
  padding: 22px 0 !important;
  background: rgba(0, 0, 0, 0.30) !important;
  border-top: 1px solid rgba(251, 251, 238, 0.07) !important;
}

.wsus__copyright p {
  font-family: "Montserrat", sans-serif !important;
  font-size: 11px !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  color: rgba(251, 251, 238, 0.30) !important;
}

/* =============================================
   SCROLL-TO ANIMATIONS
   ============================================= */

/* ──────────────────────────────────────────────
   17. Scroll-animate — initial & revealed states
   JS adds .scroll-animate to elements; IntersectionObserver adds .in-view
   Content is always visible if JS is disabled (classes never applied)
   ────────────────────────────────────────────── */

/* Default: slide up */
.scroll-animate {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.62s ease, transform 0.62s ease;
}

/* Slide in from left */
.scroll-animate.from-left {
  transform: translateX(-36px);
}

/* Slide in from right */
.scroll-animate.from-right {
  transform: translateX(36px);
}

/* Revealed state — all directions resolve to this */
.scroll-animate.in-view {
  opacity: 1;
  transform: translate(0, 0);
}

/* =============================================
   PRODUCTS PAGE — JQUERY ANIMATIONS
   ============================================= */

/* ──────────────────────────────────────────────
   18. Entry animation classes
   JS sets .anim-ready (hidden); then adds .anim-visible to play
   ────────────────────────────────────────────── */
.anim-ready {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.42s ease, transform 0.42s ease;
}

.anim-ready.anim-from-left {
  transform: translateX(-26px);
}

.anim-ready.anim-visible {
  opacity: 1;
  transform: translate(0, 0);
}

/* ──────────────────────────────────────────────
   19. Add-to-cart button pulse
   ────────────────────────────────────────────── */
@keyframes cartPulse {
  0%   { transform: scale(1); }
  28%  { transform: scale(1.10); }
  60%  { transform: scale(0.95); }
  100% { transform: scale(1); }
}

.cart-pulse {
  animation: cartPulse 0.48s ease forwards;
}

/* ──────────────────────────────────────────────
   20. Topbar — keep opacity transition smooth
   ────────────────────────────────────────────── */
.wsus__product_topbar {
  transition: opacity 0.35s ease;
}

/* ──────────────────────────────────────────────
   21. Pagination fade-out target area
   ────────────────────────────────────────────── */
#wsus__product_page .col-xl-9.col-lg-8 {
  transition: opacity 0.22s ease;
}

/* =============================================
   PRODUCTS PAGE — IMAGE HOVER EFFECTS
   ============================================= */

/* 22. Grid — img_1 zooms slightly while fading out */
#wsus__product_page .wsus__product_item .wsus__pro_link .img_1 {
  transition: opacity 0.38s ease, transform 0.38s ease !important;
}
#wsus__product_page .wsus__product_item:not(.wsus__list_view):hover .wsus__pro_link .img_1 {
  opacity: 0 !important;
  visibility: hidden !important;
  transform: scale(1.07) !important;
}

/* 23. Grid — img_2 starts large, zooms back to 1.0 (depth entry) */
#wsus__product_page .wsus__product_item:not(.wsus__list_view) .wsus__pro_link .img_2 {
  transform: scale(1.12) !important;
  transition: opacity 0.44s ease, transform 0.52s ease !important;
}
#wsus__product_page .wsus__product_item:not(.wsus__list_view):hover .wsus__pro_link .img_2 {
  opacity: 1 !important;
  visibility: visible !important;
  transform: scale(1.0) !important;
}

/* 24. Gradient overlay slides up from the bottom on hover */
#wsus__product_page .wsus__product_item .wsus__pro_link {
  overflow: hidden;
}
#wsus__product_page .wsus__product_item .wsus__pro_link::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(11, 44, 61, 0.68) 0%,
    rgba(11, 44, 61, 0.22) 42%,
    transparent 100%
  );
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 0.36s ease, transform 0.36s ease;
  z-index: 1;
  pointer-events: none;
}
#wsus__product_page .wsus__product_item:hover .wsus__pro_link::after {
  opacity: 1;
  transform: translateY(0);
}

/* 25. Quick-action icons — staggered slide-in from right, above overlay */
#wsus__product_page .wsus__single_pro_icon { z-index: 2; }
#wsus__product_page .wsus__single_pro_icon li {
  opacity: 0;
  transform: translateX(16px);
  transition: opacity 0.26s ease, transform 0.26s ease;
}
#wsus__product_page .wsus__product_item:hover .wsus__single_pro_icon li {
  opacity: 1;
  transform: translateX(0);
}
#wsus__product_page .wsus__single_pro_icon li:nth-child(1) { transition-delay: 0.05s; }
#wsus__product_page .wsus__single_pro_icon li:nth-child(2) { transition-delay: 0.13s; }
#wsus__product_page .wsus__single_pro_icon li:nth-child(3) { transition-delay: 0.21s; }

/* 26. List view — zoom img_1, no swap */
#wsus__product_page .wsus__list_view .wsus__pro_link .img_1 {
  transition: transform 0.48s ease !important;
}
#wsus__product_page .wsus__list_view:hover .wsus__pro_link .img_1 {
  opacity: 1 !important;
  visibility: visible !important;
  transform: scale(1.07) !important;
}
#wsus__product_page .wsus__list_view:hover .wsus__pro_link .img_2 {
  opacity: 0 !important;
  visibility: hidden !important;
}
#wsus__product_page .wsus__list_view .wsus__pro_link::after {
  background: linear-gradient(to right, rgba(11,44,61,0.28) 0%, transparent 70%) !important;
}

/* 27. Badges stay above overlay */
#wsus__product_page .wsus__product_item .wsus__new,
#wsus__product_page .wsus__product_item .wsus__minus { z-index: 2; }

/* =============================================
   LOGIN / REGISTER PAGE
   ============================================= */

/* ── Outer wrapper fills viewport height ── */
#wsus__login_register {
  padding: 0 !important;
  min-height: calc(100vh - 160px);
  display: flex;
  align-items: stretch;
}

.wsus__auth_outer {
  width: 100%;
  min-height: calc(100vh - 160px);
}

/* ── Left brand panel ── */
.wsus__auth_brand {
  background: linear-gradient(148deg, #0f3347 0%, #061a26 65%, #1c0a2e 100%);
  position: relative;
  overflow: hidden;
  align-items: center;
  justify-content: center;
  padding: 60px 48px;
}

.wsus__auth_brand_inner {
  position: relative;
  z-index: 2;
  text-align: center;
}

.wsus__auth_logo {
  width: 150px;
  margin-bottom: 44px;
  filter: brightness(1.1);
}

.wsus__auth_brand_inner h2 {
  font-size: 40px;
  font-weight: 800;
  color: #fff;
  line-height: 1.18;
  margin-bottom: 18px;
  letter-spacing: -0.5px;
}

.wsus__auth_brand_inner h2 span {
  color: #e05585;
}

.wsus__auth_brand_inner > p {
  font-size: 15px;
  color: rgba(255, 255, 255, 0.62);
  line-height: 1.75;
  max-width: 290px;
  margin: 0 auto 28px;
}

/* Feature list */
.wsus__auth_features {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
  display: inline-block;
}

.wsus__auth_features li {
  font-size: 14px;
  color: rgba(255, 255, 255, 0.72);
  padding: 5px 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.wsus__auth_features li i {
  color: #e05585;
  font-size: 13px;
  flex-shrink: 0;
}

/* Decorative background blobs */
.wsus__auth_deco {
  position: absolute;
  border-radius: 50%;
  background: #ab1e56;
  opacity: 0.09;
  pointer-events: none;
}
.deco_a { width: 400px; height: 400px; top: -90px; right: -110px; }
.deco_b { width: 260px; height: 260px; bottom: -70px; left: -80px; background: #e05585; opacity: 0.07; }
.deco_c { width: 120px; height: 120px; bottom: 18%; right: 10%; opacity: 0.06; }

/* ── Right form panel ── */
.wsus__auth_form_panel {
  background: #f9f8f5; /* Good Earth warm beige */
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 56px 40px;
}

.wsus__auth_form_inner {
  width: 100%;
  max-width: 430px;
}

/* Mobile-only logo */
.wsus__auth_mobile_logo {
  display: block;
  text-align: center;
  margin-bottom: 24px;
}
.wsus__auth_mobile_logo img {
  width: 120px;
}

/* ── Validation errors ── */
.wsus__auth_errors {
  background: #fdf4f7;
  border: 1px solid #f0d0de;
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 18px;
}
.wsus__auth_errors p {
  font-size: 13px;
  color: #ab1e56;
  margin: 0;
  padding: 3px 0;
  display: flex !important;
  align-items: center;
  gap: 7px;
}
.wsus__auth_errors p i {
  flex-shrink: 0;
  font-size: 12px;
  color: #ab1e56;
  position: static !important;
}

/* ── Tab switcher ── */
.wsus__auth_tabs {
  display: flex;
  list-style: none;
  padding: 4px;
  margin: 0 0 30px;
  background: #e6e6e9;
  border-radius: 50px;
  gap: 0;
}

.wsus__auth_tab {
  flex: 1;
  background: transparent;
  border: none;
  border-radius: 50px;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 600;
  color: #777;
  cursor: pointer;
  transition: background 0.24s ease, color 0.24s ease, box-shadow 0.24s ease;
  text-align: center;
}

.wsus__auth_tab.active,
.wsus__auth_tab[aria-selected="true"] {
  background: #ab1e56 !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(171, 30, 86, 0.32);
}

/* ── Form heading ── */
.wsus__auth_heading {
  font-size: 22px;
  font-weight: 700;
  color: #191919;
  margin-bottom: 4px;
}

.wsus__auth_sub {
  font-size: 13px;
  color: #999;
  margin-bottom: 26px;
}

/* ── Field groups ── */
.wsus__auth_field {
  margin-bottom: 16px;
}

.wsus__auth_field label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #555;
  margin-bottom: 6px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.wsus__auth_input_wrap {
  position: relative;
}

.wsus__auth_input_wrap i {
  position: absolute;
  left: 15px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  color: #ab1e56;
  pointer-events: none;
}

.wsus__auth_input_wrap input {
  width: 100%;
  padding: 13px 16px 13px 42px;
  border: 1.5px solid #ddd;
  border-radius: 10px;
  font-size: 14px;
  color: #353535;
  background: #fff;
  transition: border-color 0.22s ease, box-shadow 0.22s ease;
  outline: none;
  font-family: inherit;
}

.wsus__auth_input_wrap input:focus {
  border-color: #ab1e56;
  box-shadow: 0 0 0 3px rgba(171, 30, 86, 0.10);
}

.wsus__auth_input_wrap input::placeholder {
  color: #bbb;
  font-weight: 400;
}

/* ── Remember / Forgot row ── */
.wsus__auth_row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 16px 0 22px;
}

/* ── Remember me ── */
.wsus__auth_remember {
  display: flex;
  align-items: center;
  gap: 8px;
}

.wsus__remember_input {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 2px solid #ccc;
  border-radius: 4px;
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: border-color 0.2s ease, background 0.2s ease;
}

.wsus__remember_input:checked {
  background: #ab1e56;
  border-color: #ab1e56;
}

.wsus__remember_input:checked::after {
  content: '';
  position: absolute;
  left: 3px;
  top: 0px;
  width: 5px;
  height: 9px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}

.wsus__remember_label {
  font-size: 13px;
  color: #555;
  font-weight: 500;
  cursor: pointer;
  user-select: none;
  display: flex;
  align-items: center;
  gap: 5px;
  margin: 0;
}

.wsus__remember_label i {
  font-size: 12px;
  color: #ab1e56;
}

.wsus__auth_forgot {
  font-size: 13px;
  font-weight: 500;
  color: #ab1e56;
  transition: color 0.2s ease;
}

.wsus__auth_forgot:hover {
  color: #3C7979;
  text-decoration: underline;
}

/* ── Submit button ── */
.wsus__auth_btn {
  width: 100%;
  padding: 14px 20px;
  background: #ab1e56;
  color: #fff;
  border: none;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.3px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: background 0.24s ease, box-shadow 0.24s ease, transform 0.18s ease;
  font-family: inherit;
  margin-top: 4px;
}

.wsus__auth_btn:hover {
  background: #3C7979;
  box-shadow: 0 6px 20px rgba(60, 121, 121, 0.28);
  transform: translateY(-2px);
}

.wsus__auth_btn i {
  font-size: 12px;
  transition: transform 0.22s ease;
}

.wsus__auth_btn:hover i {
  transform: translateX(5px);
}

/* ── Responsive — mobile ── */
@media (max-width: 991px) {
  .wsus__auth_form_panel {
    padding: 40px 20px;
    min-height: calc(100vh - 160px);
  }
  .wsus__auth_form_inner {
    max-width: 100%;
  }
}

/* ============================================================
   §29 — BLOG LISTING PAGE  (#wsus__blogs)
   ============================================================ */

/* ── Section spacing ── */
#wsus__blogs {
  padding: 60px 0 80px;
}

/* ── Filter / search label ── */
.wsus__blog_filter_label {
  font-size: 15px;
  color: #555;
  margin-bottom: 24px;
  padding: 10px 16px;
  background: #f8f8f8;
  border-left: 4px solid #ab1e56;
  border-radius: 0 6px 6px 0;
  display: inline-block;
}
.wsus__blog_filter_label span {
  font-weight: 700;
  color: #ab1e56;
}

/* ── Blog card shell ── */
#wsus__blogs .wsus__blog_card {
  border-radius: 14px;
  overflow: hidden;
  background: #fff;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.07);
  display: flex;
  flex-direction: column;
  height: 100%;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}
#wsus__blogs .wsus__blog_card:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.13);
}

/* ── Thumbnail ── */
#wsus__blogs .wsus__blog_card .wsus__blog_img {
  display: block;
  overflow: hidden;
  height: 210px;
  flex-shrink: 0;
}
#wsus__blogs .wsus__blog_card .wsus__blog_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.42s ease;
}
#wsus__blogs .wsus__blog_card:hover .wsus__blog_img img {
  transform: scale(1.07);
}

/* ── Text body ── */
#wsus__blogs .wsus__blog_card .wsus__blog_text {
  padding: 18px 20px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
  position: relative;
}

/* ── Category badge ── */
#wsus__blogs .wsus__blog_cat_badge {
  position: static !important;
  display: inline-block;
  background: #f5e8ed !important;
  color: #ab1e56 !important;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 50px;
  margin-bottom: 12px;
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
  width: fit-content;
}
#wsus__blogs .wsus__blog_cat_badge:hover {
  background: #ab1e56 !important;
  color: #fff !important;
}
#wsus__blogs .wsus__blog_cat_badge em {
  font-style: normal;
}

/* ── Title ── */
#wsus__blogs .wsus__blog_title {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.45;
  color: #191919;
  text-decoration: none;
  margin-bottom: 10px;
  transition: color 0.2s ease;
}
#wsus__blogs .wsus__blog_title:hover {
  color: #ab1e56;
}

/* ── Date ── */
#wsus__blogs .wsus__blog_date {
  font-size: 12px;
  color: #888;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 6px;
}
#wsus__blogs .wsus__blog_date i {
  color: #ab1e56;
  font-size: 11px;
}

/* ── Read-more link ── */
#wsus__blogs .wsus__blog_read_more {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: #ab1e56;
  text-decoration: none;
  margin-top: auto;
  transition: gap 0.22s ease, color 0.2s ease;
}
#wsus__blogs .wsus__blog_read_more:hover {
  gap: 10px;
  color: #3C7979;
}
#wsus__blogs .wsus__blog_read_more i {
  font-size: 11px;
  transition: transform 0.22s ease;
}
#wsus__blogs .wsus__blog_read_more:hover i {
  transform: translateX(3px);
}

/* ── Empty state ── */
#wsus__blogs .card {
  border: none;
  border-radius: 14px;
  background: #f8f8f8;
  padding: 40px;
}
#wsus__blogs .card h3 {
  font-size: 20px;
  color: #555;
  font-weight: 600;
}

/* ── Responsive ── */
@media (max-width: 767px) {
  #wsus__blogs .wsus__blog_card .wsus__blog_img {
    height: 180px;
  }
}

/* ============================================================
   §30 — BLOG DETAIL PAGE  (#wsus__blog_details)
   ============================================================ */

#wsus__blog_details {
  padding: 60px 0 80px;
}

/* ── Article shell ── */
.wsus__bd_article {
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.07);
  padding-bottom: 10px;
}

/* ── Hero image with hover zoom ── */
.wsus__bd_img_wrap {
  overflow: hidden;
  max-height: 480px;
  border-radius: 0;
}
.wsus__bd_img_wrap img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  display: block;
  transition: transform 0.50s ease;
}
.wsus__bd_img_wrap:hover img {
  transform: scale(1.04);
}

/* ── Meta bar ── */
.wsus__bd_meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  padding: 18px 28px 4px;
  margin: 0;
}
.wsus__bd_meta_item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  font-weight: 600;
  color: #666;
  background: #f5f5f5;
  padding: 5px 14px;
  border-radius: 50px;
}
.wsus__bd_meta_item i {
  color: #ab1e56;
  font-size: 11px;
}

/* ── Article body typography ── */
.wsus__bd_body {
  padding: 24px 28px 28px;
}
.wsus__bd_title {
  font-size: clamp(22px, 4vw, 32px);
  font-weight: 800;
  line-height: 1.3;
  color: #191919;
  margin-bottom: 24px;
  letter-spacing: -0.3px;
}
.wsus__bd_content {
  font-size: 16px;
  line-height: 1.85;
  color: #444;
}
.wsus__bd_content p {
  margin-bottom: 18px;
}
.wsus__bd_content h2,
.wsus__bd_content h3,
.wsus__bd_content h4 {
  font-weight: 700;
  color: #191919;
  margin-top: 32px;
  margin-bottom: 12px;
  line-height: 1.35;
}
.wsus__bd_content h2 { font-size: 24px; }
.wsus__bd_content h3 { font-size: 20px; }
.wsus__bd_content h4 { font-size: 17px; }
.wsus__bd_content a {
  color: #ab1e56;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.wsus__bd_content a:hover {
  color: #3C7979;
}
.wsus__bd_content img {
  max-width: 100%;
  border-radius: 10px;
  margin: 20px 0;
  transition: transform 0.40s ease, box-shadow 0.30s ease;
}
.wsus__bd_content img:hover {
  transform: scale(1.02);
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.14);
}
.wsus__bd_content ul,
.wsus__bd_content ol {
  padding-left: 22px;
  margin-bottom: 18px;
}
.wsus__bd_content li {
  margin-bottom: 8px;
}
.wsus__bd_content blockquote {
  border-left: 4px solid #ab1e56;
  background: #fdf4f7;
  margin: 24px 0;
  padding: 16px 22px;
  border-radius: 0 10px 10px 0;
  font-style: italic;
  color: #555;
}
.wsus__bd_content code {
  background: #f0f0f0;
  border-radius: 4px;
  padding: 2px 7px;
  font-size: 14px;
  color: #ab1e56;
}
.wsus__bd_content pre {
  background: #1a1a2e;
  color: #e0e0e0;
  border-radius: 10px;
  padding: 20px 24px;
  overflow-x: auto;
  font-size: 14px;
  line-height: 1.7;
  margin: 20px 0;
}

/* ── Share bar ── */
.wsus__bd_share {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 28px;
  border-top: 1px solid #f0f0f0;
  border-bottom: 1px solid #f0f0f0;
  margin: 0 0 30px;
  flex-wrap: wrap;
}
.wsus__bd_share_label {
  font-size: 13px;
  font-weight: 700;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin: 0;
}
.wsus__bd_share ul {
  display: flex;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.wsus__bd_share ul li a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  font-size: 13px;
  color: #fff;
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  text-decoration: none;
}
.wsus__bd_share ul li a:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18);
}
.wsus__bd_share ul li a.facebook  { background: #1877f2; }
.wsus__bd_share ul li a.twitter   { background: #1da1f2; }
.wsus__bd_share ul li a.linkedin  { background: #0a66c2; }

/* ── Section title with accent bar ── */
.wsus__bd_section_title {
  font-size: 20px;
  font-weight: 800;
  color: #191919;
  padding-left: 14px;
  border-left: 4px solid #ab1e56;
  margin-bottom: 22px;
  line-height: 1.2;
}

/* ── Related posts wrapper ── */
.wsus__bd_related {
  padding: 0 28px 28px;
}

/* ── Comments section ── */
.wsus__bd_comments {
  padding: 28px 28px 20px;
  border-top: 1px solid #f0f0f0;
}
.wsus__bd_count_badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  background: #ab1e56;
  color: #fff;
  border-radius: 50%;
  font-size: 13px;
  font-weight: 700;
  vertical-align: middle;
  margin-left: 6px;
}
.wsus__bd_comment_item {
  display: flex;
  gap: 16px;
  padding: 18px 0;
  border-bottom: 1px solid #f5f5f5;
}
.wsus__bd_comment_item:last-of-type {
  border-bottom: none;
}
.wsus__comment_img img {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid #f0e0e8;
}
.wsus__comment_text h6 {
  font-size: 14px;
  font-weight: 700;
  color: #191919;
  margin-bottom: 6px;
}
.wsus__comment_text h6 span {
  font-size: 12px;
  font-weight: 400;
  color: #999;
  margin-left: 8px;
}
.wsus__comment_text p {
  font-size: 14px;
  color: #555;
  line-height: 1.65;
  margin: 0;
}
.wsus__bd_no_comments {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #999;
  font-style: italic;
  padding: 20px 0;
}
.wsus__bd_no_comments i {
  color: #ab1e56;
  font-size: 18px;
}

/* ── Post a comment form ── */
.wsus__bd_post_comment {
  padding: 28px 28px 32px;
  border-top: 1px solid #f0f0f0;
}
.wsus__bd_post_comment .wsus__single_com textarea {
  width: 100%;
  border: 1.5px solid #e8e8e8;
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 14px;
  font-family: inherit;
  color: #333;
  resize: vertical;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  outline: none;
}
.wsus__bd_post_comment .wsus__single_com textarea:focus {
  border-color: #ab1e56;
  box-shadow: 0 0 0 3px rgba(171, 30, 86, 0.10);
}
.wsus__bd_submit_btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  margin-top: 14px;
  padding: 12px 28px;
  background: linear-gradient(135deg, #ab1e56 0%, #3C7979 100%);
  color: #fff;
  border: none;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: box-shadow 0.24s ease, transform 0.18s ease;
}
.wsus__bd_submit_btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(171, 30, 86, 0.30);
}
.wsus__bd_submit_btn i {
  font-size: 13px;
  transition: transform 0.22s ease;
}
.wsus__bd_submit_btn:hover i {
  transform: translateX(4px) rotate(-30deg);
}
.wsus__bd_login_prompt {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  background: #fdf4f7;
  border: 1px solid #f0d8e4;
  border-radius: 10px;
  padding: 20px 24px;
}
.wsus__bd_login_prompt i {
  font-size: 22px;
  color: #ab1e56;
}
.wsus__bd_login_prompt p {
  margin: 0;
  color: #555;
  font-size: 14px;
}
.wsus__bd_login_btn {
  display: inline-flex;
  align-items: center;
  padding: 9px 24px;
  background: #ab1e56;
  color: #fff;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: background 0.2s ease, transform 0.18s ease;
}
.wsus__bd_login_btn:hover {
  background: #3C7979;
  transform: translateY(-2px);
  color: #fff;
}

/* ── SIDEBAR ── */
.wsus__blog_sidebar {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.wsus__bd_widget {
  background: #fff;
  border-radius: 14px;
  padding: 22px 22px 24px;
  box-shadow: 0 2px 14px rgba(0, 0, 0, 0.07);
}
.wsus__bd_widget_title {
  font-size: 16px;
  font-weight: 800;
  color: #191919;
  padding-left: 12px;
  border-left: 4px solid #ab1e56;
  margin-bottom: 18px;
  line-height: 1.2;
}

/* Search widget */
.wsus__bd_search_form {
  display: flex;
  gap: 0;
  border: 1.5px solid #e8e8e8;
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s ease;
}
.wsus__bd_search_form:focus-within {
  border-color: #ab1e56;
}
.wsus__bd_search_form input {
  flex: 1;
  border: none;
  padding: 10px 14px;
  font-size: 13.5px;
  font-family: inherit;
  color: #333;
  outline: none;
  background: transparent;
}
.wsus__bd_search_form button {
  background: #ab1e56;
  border: none;
  padding: 0 16px;
  color: #fff;
  cursor: pointer;
  font-size: 14px;
  transition: background 0.2s ease;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100%;
}
.wsus__bd_search_form button:hover {
  background: #3C7979;
}

/* Category list */
.wsus__bd_cat_list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.wsus__bd_cat_list li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 8px;
  font-size: 13.5px;
  color: #444;
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease, padding-left 0.18s ease;
}
.wsus__bd_cat_list li a:hover {
  background: #fdf4f7;
  color: #ab1e56;
  padding-left: 18px;
}
.wsus__bd_cat_list li a i {
  font-size: 10px;
  color: #ab1e56;
  flex-shrink: 0;
}

/* More posts widget */
.wsus__bd_more_post {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 0;
  border-bottom: 1px solid #f5f5f5;
}
.wsus__bd_more_post:last-child {
  border-bottom: none;
  padding-bottom: 0;
}
.wsus__bd_more_thumb {
  display: block;
  width: 72px;
  height: 72px;
  flex-shrink: 0;
  border-radius: 8px;
  overflow: hidden;
}
.wsus__bd_more_thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.36s ease;
}
.wsus__bd_more_thumb:hover img {
  transform: scale(1.10);
}
.wsus__blog_post_text {
  flex: 1;
}
.wsus__blog_post_text a {
  font-size: 13.5px;
  font-weight: 600;
  color: #191919;
  text-decoration: none;
  line-height: 1.4;
  display: block;
  margin-bottom: 5px;
  transition: color 0.2s ease;
}
.wsus__blog_post_text a:hover {
  color: #ab1e56;
}
.wsus__blog_post_text p {
  font-size: 12px;
  color: #999;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
}
.wsus__blog_post_text p i {
  color: #ab1e56;
  font-size: 11px;
}

/* ── Responsive ── */
@media (max-width: 991px) {
  .wsus__bd_img_wrap {
    max-height: none;
  }
  .wsus__bd_img_wrap img {
    height: 320px;
  }
  .wsus__bd_body,
  .wsus__bd_share,
  .wsus__bd_related,
  .wsus__bd_comments,
  .wsus__bd_post_comment {
    padding-left: 18px;
    padding-right: 18px;
  }
  .wsus__bd_meta {
    padding-left: 18px;
    padding-right: 18px;
  }
}

/* Switch to fluid aspect-ratio below tablet so the image never clips */
@media (max-width: 767px) {
  .wsus__bd_img_wrap {
    max-height: none;
    aspect-ratio: 16 / 9;
  }
  .wsus__bd_img_wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}

@media (max-width: 575px) {
  .wsus__bd_img_wrap {
    aspect-ratio: 4 / 3;
  }
  .wsus__bd_img_wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .wsus__bd_title {
    font-size: 22px;
  }
  .wsus__bd_body,
  .wsus__bd_share,
  .wsus__bd_related,
  .wsus__bd_comments,
  .wsus__bd_post_comment {
    padding-left: 14px;
    padding-right: 14px;
  }
  .wsus__bd_meta {
    padding-left: 14px;
    padding-right: 14px;
    gap: 6px;
  }
}

@media (max-width: 400px) {
  .wsus__bd_img_wrap {
    aspect-ratio: 1 / 1;
  }
}

/* ============================================================
   §31 — CONTACT PAGE  (#wsus__contact)
   ============================================================ */

#wsus__contact {
  padding: 60px 0 80px;
}

/* ── Info cards (left column) ── */
.wsus__contact_single {
  position: relative;
  overflow: hidden;
  background: #fff;
  border-radius: 14px;
  padding: 30px 24px 24px;
  margin-bottom: 24px;
  box-shadow: 0 3px 18px rgba(0, 0, 0, 0.07);
  transition: transform 0.26s ease, box-shadow 0.26s ease;
  text-align: center;
}
.wsus__contact_single:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.12);
}

/* Main icon */
.wsus__contact_single > i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: linear-gradient(135deg, #ab1e56 0%, #3C7979 100%);
  color: #fff;
  font-size: 20px;
  margin-bottom: 14px;
  transition: transform 0.26s ease;
}
.wsus__contact_single:hover > i {
  transform: scale(1.12) rotate(-6deg);
}

/* Heading */
.wsus__contact_single h5 {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.9px;
  color: #999;
  margin-bottom: 8px;
}

/* Link / value */
.wsus__contact_single a {
  font-size: 14.5px;
  font-weight: 600;
  color: #191919;
  text-decoration: none;
  word-break: break-word;
  line-height: 1.5;
  transition: color 0.2s ease;
}
.wsus__contact_single a:hover {
  color: #ab1e56;
}

/* Decorative watermark icon */
.wsus__contact_single > span {
  position: absolute;
  bottom: -10px;
  right: -10px;
  font-size: 72px;
  color: rgba(171, 30, 86, 0.05);
  line-height: 1;
  pointer-events: none;
}

/* ── Form panel (right column) ── */
.wsus__contact_question {
  background: #fff;
  border-radius: 16px;
  padding: 36px 36px 40px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
  height: 100%;
}
.wsus__contact_question > h5 {
  font-size: 22px;
  font-weight: 800;
  color: #191919;
  padding-left: 14px;
  border-left: 4px solid #ab1e56;
  margin-bottom: 24px;
  line-height: 1.2;
}

/* ── Form fields ── */
.wsus__con_form_single {
  margin-bottom: 16px;
}
.wsus__con_form_single input,
.wsus__con_form_single textarea {
  width: 100%;
  border: 1.5px solid #e8e8e8 !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  font-size: 14px;
  font-family: inherit;
  color: #333;
  background: #fafafa !important;
  outline: none;
  transition: border-color 0.22s ease, box-shadow 0.22s ease, background 0.18s ease;
}
.wsus__con_form_single input:focus,
.wsus__con_form_single textarea:focus {
  border-color: #ab1e56 !important;
  box-shadow: 0 0 0 3px rgba(171, 30, 86, 0.10) !important;
  background: #fff !important;
}
.wsus__con_form_single textarea {
  resize: vertical;
  min-height: 130px;
}

/* ── Submit button ── */
#wsus__contact #form-submit.common_btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 13px 34px;
  background: linear-gradient(135deg, #ab1e56 0%, #3C7979 100%);
  color: #fff;
  border: none;
  border-radius: 50px;
  font-size: 15px;
  font-weight: 700;
  text-transform: capitalize;
  letter-spacing: 0.3px;
  font-family: inherit;
  cursor: pointer;
  margin-top: 8px;
  transition: transform 0.22s ease, box-shadow 0.24s ease, opacity 0.2s ease;
}
#wsus__contact #form-submit.common_btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(171, 30, 86, 0.32);
}
#wsus__contact #form-submit.common_btn:disabled {
  opacity: 0.70;
  cursor: not-allowed;
}

/* ── Map ── */
.wsus__con_map {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.10);
  margin-top: 50px;
}
.wsus__con_map iframe {
  display: block;
  width: 100% !important;
}

/* ── Responsive ── */
@media (max-width: 991px) {
  .wsus__contact_question {
    padding: 28px 22px 32px;
  }
}
@media (max-width: 575px) {
  .wsus__contact_question > h5 {
    font-size: 18px;
  }
}

/* ============================================================
   GOOD EARTH TYPOGRAPHY — Lora serif headings
   Applied to editorial / content headings across the site
   ============================================================ */

/* Blog card titles (home + listing) */
.home_blogs .wsus__hb_title,
#wsus__blogs .wsus__blog_title,
#wsus__blogs .wsus__blog_card .wsus__blog_text .wsus__blog_title {
  font-family: "Lora", Georgia, serif !important;
  font-weight: 600 !important;
}

/* Blog detail article title */
.wsus__bd_title {
  font-family: "Lora", Georgia, serif !important;
  font-weight: 700 !important;
  letter-spacing: -0.2px;
}

/* Blog detail in-article headings */
.wsus__bd_content h2,
.wsus__bd_content h3,
.wsus__bd_content h4 {
  font-family: "Lora", Georgia, serif !important;
}

/* Section headers / widget titles */
.wsus__section_header h3,
.wsus__bd_widget_title,
.wsus__bd_section_title,
.wsus__contact_question > h5,
.wsus__footer_content_2 h3 {
  font-family: "Lora", Georgia, serif !important;
}

/* Hero slider headline */
.wsus__single_slider_text h1 {
  font-family: "Lora", Georgia, serif !important;
  font-style: italic;
  letter-spacing: -0.3px;
}

/* Auth panel headline */
.wsus__auth_brand_inner h2,
.wsus__auth_heading {
  font-family: "Lora", Georgia, serif !important;
}

/* Service card headings */
.home_service_single_2 h5 {
  font-family: "Lora", Georgia, serif !important;
  font-weight: 600 !important;
}

/* Related / sidebar post links */
.wsus__blog_post_text a {
  font-family: "Lora", Georgia, serif !important;
  font-weight: 500 !important;
}

/* ============================================================
   MAIN NAV — STYLE & TYPOGRAPHY ENHANCEMENTS
   ============================================================ */

/* ── Nav bar shell ── */
.wsus__main_menu {
  height: 58px !important;
  box-shadow: 0 3px 18px rgba(0, 0, 0, 0.09) !important;
  border-top: 3px solid #ab1e56 !important;
}

/* ── Category toggle button ── */
.wsus_menu_category_bar {
  height: 58px !important;
  width: 58px !important;
  line-height: 55px !important;
  font-size: 18px !important;
  border-right: 1px solid rgba(255, 255, 255, 0.18) !important;
  transition: background 0.24s ease !important;
}
.wsus_menu_category_bar:hover {
  background: #8a1745 !important;
}

/* ── Nav link line-height matches new height ── */
.wsus__menu_item {
  line-height: 58px !important;
}

/* ── Main nav link typography ── */
.wsus__menu_item li a {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 11.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.9px !important;
  text-transform: uppercase !important;
  color: #2c2c2c !important;
}

/* Animated gradient underline — left nav items only */
.wsus__menu_item:not(.wsus__menu_item_right) > li > a {
  background-image: linear-gradient(#ab1e56, #ab1e56);
  background-size: 0 2px;
  background-repeat: no-repeat;
  background-position: left bottom 10px;
  transition: background-size 0.28s ease, color 0.22s ease !important;
}
.wsus__menu_item:not(.wsus__menu_item_right) > li:hover > a,
.wsus__menu_item:not(.wsus__menu_item_right) > li > a.active {
  background-size: 100% 2px !important;
  color: #ab1e56 !important;
}

/* ── Right nav: "track order" subdued ── */
.wsus__menu_item_right > li:first-child > a {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: #666 !important;
  letter-spacing: 0.6px !important;
  background-image: none !important;
}
.wsus__menu_item_right > li:first-child > a:hover {
  color: #ab1e56 !important;
}

/* ── Right nav: login / account — brand pill ── */
.wsus__menu_item_right > li:last-child > a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: #ab1e56 !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.8px !important;
  text-transform: uppercase !important;
  padding: 7px 18px !important;
  border-radius: 20px !important;
  line-height: normal !important;
  background-image: none !important;
  transition: background 0.24s ease, box-shadow 0.24s ease !important;
}
.wsus__menu_item_right > li:last-child > a:hover {
  background: #3C7979 !important;
  box-shadow: 0 4px 14px rgba(60, 121, 121, 0.35) !important;
  color: #fff !important;
}

/* ── Mega menu enhancements ── */
.wsus__mega_menu {
  top: 58px !important;
  padding: 28px 28px 26px !important;
  border-top: 3px solid #ab1e56 !important;
  border-radius: 0 0 14px 14px !important;
  box-shadow: 0 14px 44px rgba(0, 0, 0, 0.13) !important;
  transition: opacity 0.25s ease, transform 0.25s ease !important;
}

/* Column heading */
.wsus__mega_menu_colum h4 {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 10.5px !important;
  font-weight: 800 !important;
  letter-spacing: 1.3px !important;
  text-transform: uppercase !important;
  color: #ab1e56 !important;
  border-bottom: 2px solid #f2dce6 !important;
  padding-bottom: 10px !important;
  margin-bottom: 10px !important;
}

/* Sub-items */
.wsis__mega_menu_item {
  line-height: 30px !important;
}
.wsis__mega_menu_item li a {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: #555 !important;
  display: block !important;
  padding-left: 10px !important;
  border-left: 2px solid transparent !important;
  transition: color 0.2s ease, border-color 0.2s ease, padding-left 0.2s ease !important;
  background-image: none !important;
}
.wsis__mega_menu_item li a:hover {
  color: #ab1e56 !important;
  border-left-color: #ab1e56 !important;
  padding-left: 15px !important;
}

/* ── Category sidebar list typography ── */
.wsus_menu_cat_item li a {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.2px !important;
}

/* ── Category sub-dropdown links ── */
.wsus_menu_cat_droapdown li a {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}

/* ============================================================
   HEADER TOP SECTION — BACKGROUND, TYPOGRAPHY & ANIMATIONS
   ============================================================ */

/* ── Keyframes ── */
@keyframes hdrFadeDown {
  from { opacity: 0; transform: translateY(-14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes hdrIconPop {
  0%   { transform: scale(0.7); opacity: 0; }
  70%  { transform: scale(1.1); }
  100% { transform: scale(1);   opacity: 1; }
}
@keyframes hdrShimmer {
  0%   { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}
@keyframes callWobble {
  0%, 100% { transform: rotate(0deg) scale(1); }
  20%       { transform: rotate(-12deg) scale(1.1); }
  40%       { transform: rotate(10deg) scale(1.1); }
  60%       { transform: rotate(-6deg) scale(1.05); }
  80%       { transform: rotate(4deg) scale(1.05); }
}

/* ── Header shell — gradient background ── */
header {
  background:
    linear-gradient(135deg, #7c1540 0%, #ab1e56 52%, #bf2460 100%) !important;
  box-shadow: 0 4px 24px rgba(139, 21, 64, 0.38) !important;
  border-bottom: none !important;
  animation: hdrFadeDown 0.55s ease both !important;
  position: relative !important;
  overflow: visible !important;
}

/* ── Mobile: restore fixed positioning so responsive.css offsets work ── */
@media (max-width: 991.99px) {
  header {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    z-index: 999 !important;
    overflow: hidden !important;
  }
}

/* Subtle moving shimmer strip across the header */
header::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(
    105deg,
    transparent 35%,
    rgba(255, 255, 255, 0.06) 50%,
    transparent 65%
  );
  background-size: 800px 100%;
  animation: hdrShimmer 5s linear infinite;
}

/* ── Logo — entrance animation ── */
.wsus_logo_area {
  animation: hdrFadeDown 0.6s 0.1s ease both !important;
}
.wsus__header_logo img {
  transition: transform 0.3s ease, filter 0.3s ease !important;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,0.18)) !important;
}
.wsus__header_logo:hover img {
  transform: scale(1.04) !important;
  filter: drop-shadow(0 4px 14px rgba(0,0,0,0.28)) !important;
}

/* ── Search bar — glassmorphism style ── */
.wsus__search {
  animation: hdrFadeDown 0.6s 0.15s ease both !important;
}
.wsus__search form {
  background: rgba(255, 255, 255, 0.14) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.32) !important;
  backdrop-filter: blur(6px) !important;
  -webkit-backdrop-filter: blur(6px) !important;
  border-radius: 30px !important;
  transition: border-color 0.25s ease, box-shadow 0.25s ease !important;
}
.wsus__search form:focus-within {
  border-color: rgba(255, 255, 255, 0.72) !important;
  box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.14) !important;
}
.wsus__search input {
  background: transparent !important;
  color: #fff !important;
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.3px !important;
}
.wsus__search input::placeholder {
  color: rgba(255, 255, 255, 0.62) !important;
  font-weight: 400 !important;
}
.wsus__search button {
  background: rgba(255, 255, 255, 0.18) !important;
  color: #fff !important;
  transition: background 0.24s ease !important;
}
header .wsus__search button:hover {
  background: rgba(255, 255, 255, 0.35) !important;
  color: #fff !important;
}

/* ── Contact / call area ── */
.wsus__call_icon_area {
  animation: hdrFadeDown 0.6s 0.2s ease both !important;
  align-items: center !important;
}
.wsus__call {
  font-size: 30px !important;
  color: rgba(255, 255, 255, 0.9) !important;
  margin-right: 12px !important;
  transition: color 0.2s ease !important;
  cursor: default !important;
}
.wsus__call_area:hover .wsus__call {
  animation: callWobble 0.65s ease !important;
  color: #fff !important;
}
.wsus__call_text p {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.7px !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.72) !important;
  margin-bottom: 2px !important;
  line-height: 1.2 !important;
}
.wsus__call_text a {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: 0.3px !important;
  transition: opacity 0.22s ease !important;
}
.wsus__call_text a:hover,
header .wsus__call_text a:hover {
  color: rgba(255, 255, 255, 0.82) !important;
  opacity: 1 !important;
}

/* ── Cart & wishlist icons ── */
.wsus__icon_area li {
  animation: hdrIconPop 0.5s ease both !important;
}
.wsus__icon_area li:nth-child(1) { animation-delay: 0.25s !important; }
.wsus__icon_area li:nth-child(2) { animation-delay: 0.35s !important; }

.wsus__icon_area li a {
  width: 44px !important;
  height: 44px !important;
  line-height: 44px !important;
  font-size: 20px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: rgba(255, 255, 255, 0.13) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.3) !important;
  color: #fff !important;
  transition: background 0.25s ease, transform 0.22s ease,
              border-color 0.25s ease, box-shadow 0.25s ease !important;
}
.wsus__icon_area li a:hover {
  background: rgba(255, 255, 255, 0.26) !important;
  border-color: rgba(255, 255, 255, 0.65) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.18) !important;
}

/* Badge count — inverted brand colours */
.wsus__icon_area li a span {
  background: #fff !important;
  color: #ab1e56 !important;
  font-family: 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 10px !important;
  width: 18px !important;
  height: 18px !important;
  line-height: 18px !important;
  top: -3px !important;
  right: -3px !important;
}

/* ── Mobile hamburger ── */
.wsus__mobile_menu_icon {
  color: #fff !important;
  font-size: 22px !important;
  transition: transform 0.22s ease !important;
}
.wsus__mobile_menu_icon:hover {
  transform: scale(1.15) !important;
}

/* ============================================================
   BREADCRUMB — CONTENT ANIMATION & TYPOGRAPHY
   ============================================================ */

/* ── Entrance keyframes ── */
@keyframes bcFadeDown {
  from { opacity: 0; transform: translateY(-22px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes bcFadeUp {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes bcLineGrow {
  from { width: 0; opacity: 0; }
  to   { width: 56px; opacity: 1; }
}
@keyframes bcCrumbSlide {
  from { opacity: 0; transform: translateX(-14px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ── Overlay — tighten padding slightly ── */
.wsus_breadcrumb_overlay {
  padding: 80px 0 !important;
}

/* ── Page title ── */
#wsus__breadcrumb h4 {
  font-family: 'Lora', Georgia, serif !important;
  font-size: 38px !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: 0.4px !important;
  text-transform: capitalize !important;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.55) !important;
  animation: bcFadeDown 0.65s cubic-bezier(0.22, 1, 0.36, 1) both !important;
  position: relative !important;
  display: inline-block !important;
}

/* ── Decorative accent line under title ── */
#wsus__breadcrumb h4::after {
  content: '' !important;
  display: block !important;
  height: 3px !important;
  border-radius: 2px !important;
  background: linear-gradient(90deg, #fff 0%, rgba(255,255,255,0.25) 100%) !important;
  margin-top: 10px !important;
  animation: bcLineGrow 0.7s 0.4s cubic-bezier(0.22, 1, 0.36, 1) both !important;
}

/* ── Breadcrumb trail list ── */
#wsus__breadcrumb ul {
  margin-top: 18px !important;
  animation: bcFadeUp 0.65s 0.2s cubic-bezier(0.22, 1, 0.36, 1) both !important;
}

/* ── Trail links ── */
#wsus__breadcrumb ul li a {
  font-family: 'Montserrat', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 0.6px !important;
  text-transform: uppercase !important;
  color: rgba(255, 255, 255, 0.82) !important;
  transition: color 0.22s ease, letter-spacing 0.22s ease !important;
}
#wsus__breadcrumb ul li a:hover {
  color: #fff !important;
  letter-spacing: 0.9px !important;
}

/* ── Active (current page) crumb ── */
#wsus__breadcrumb ul li:last-child a {
  color: #ffb6d3 !important;
  font-weight: 700 !important;
  text-shadow: 0 0 12px rgba(255, 182, 211, 0.55) !important;
}

/* ── Separator arrow ── */
#wsus__breadcrumb ul li a::after {
  color: rgba(255, 255, 255, 0.50) !important;
  font-size: 12px !important;
}

/* ── Mobile: correct spacing (no topbar in layout, only 60px fixed header) ── */
@media (max-width: 991.99px) {
  /* Home page banner — responsive.css adds 105–125px assuming a topbar; correct to 60px */
  #wsus__banner {
    margin-top: 60px !important;
  }

  /* Breadcrumb overlay — reset the 80px desktop override to a tighter mobile value */
  .wsus_breadcrumb_overlay {
    padding: 50px 0 !important;
  }

  /* Breadcrumb title — scale down from 38px desktop */
  #wsus__breadcrumb h4 {
    font-size: 26px !important;
  }

  /* Decorative underline line — hide on small screens */
  #wsus__breadcrumb h4::after {
    display: none !important;
  }

  /* Trail list — tighten top gap */
  #wsus__breadcrumb ul {
    margin-top: 8px !important;
  }
}

@media (max-width: 575.99px) {
  .wsus_breadcrumb_overlay {
    padding: 38px 0 !important;
  }

  #wsus__breadcrumb h4 {
    font-size: 22px !important;
  }
}

