/* =====================================================
   Excel Trading – Professional Theme
   Clean, modern styling for a food trading company
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:wght@400;500;600;700&display=swap');

/* Section title accents */
.section-title h2.related-title::before, .section-title h2.related-title::after {
  background-color: #C8A951 !important;
}

/* Breadcrumb / Banner Area Visibility */
.breadcrumb-area {
  background-color: #f4f6f3 !important; /* Light green-gray tint for separation */
  border-top: 1px solid #e2e8e0;
  border-bottom: 1px solid #e2e8e0;
  padding-top: 45px !important;
  padding-bottom: 45px !important;
}

.breadcrumb-content ul li {
  font-weight: 500;
  color: #707a6d;
}

.breadcrumb-content ul li a {
  color: #3D5A3E;
}

.breadcrumb-content ul li.active {
  color: #2D2D2D;
  font-weight: 600;
}

/* Product Image Sizing & Consistency */
.product-img img {
  height: 320px !important;
  width: 100% !important;
  object-fit: cover !important;
  border-radius: 8px 8px 0 0;
  transition: transform 0.8s cubic-bezier(0.2, 1, 0.2, 1) !important;
}

/* Specific heights for different contexts */
.categories-slider-active .product-img img {
  height: 380px !important;
}

.related-product-active .product-img img {
  height: 260px !important;
}

.shop-bottom-area .product-img img {
  height: 300px !important;
}

/* Detail page main image framing */
.main-image-wrapper {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border: 1px solid #f0f0f0;
  height: 500px;
  margin-bottom: 20px;
}

.main-image-wrapper img {
  max-height: 100%;
  max-width: 100%;
  object-fit: contain;
  padding: 10px;
}

.product-wrap.scroll-zoom {
  background: #fff;
  border: 1px solid #ebebeb;
  border-radius: 8px;
  overflow: hidden;
  height: 100%;
  margin-bottom: 50px !important;
  box-shadow: 0 10px 25px rgba(0,0,0,0.02);
  transition: all 0.3s ease;
}

/* Global spacing for product/category rows */
.shop-area .product-wrap,
.product-area .product-wrap,
.related-product-area .product-wrap {
  margin-bottom: 50px !important;
}

.product-wrap .product-content {
  padding: 10px 15px 25px !important;
}

.product-wrap.scroll-zoom:hover {
  border-color: #3D5A3E;
  box-shadow: 0 15px 35px rgba(0,0,0,0.06);
}


/* ----- Base Typography ----- */
body {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  -webkit-font-smoothing: antialiased;
  color: #2D2D2D;
  background-color: #FAFAF7;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 600;
  color: #2D2D2D;
}

p,
span,
li,
a,
input,
textarea,
button {
  font-family: 'Inter', 'Poppins', sans-serif !important;
  line-height: 1.75;
}

p {
  color: #555;
}


/* =====================================================
   HEADER / NAVIGATION
   ===================================================== */
.sticky-bar.stick {
  background-color: rgba(255, 255, 255, 0.72) !important;
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  box-shadow: 0 1px 20px rgba(0, 0, 0, 0.06);
  border-bottom: 1px solid rgba(255, 255, 255, 0.4);
}

.main-menu nav ul li>a {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  letter-spacing: 0.3px;
  font-size: 14px;
}

/* Contact Us CTA button in nav */
.main-menu nav ul li>a.nav-cta-btn {
  background-color: #3D5A3E;
  color: #fff !important;
  padding: 10px 28px !important;
  border-radius: 3px;
  line-height: 1.5 !important;
  margin-top: 28px;
  display: inline-block;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  transition: all 0.3s ease;
}

.main-menu nav ul li>a.nav-cta-btn:hover {
  background-color: #2D4A2F !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(61, 90, 62, 0.25);
}

.stick .main-menu nav ul li>a.nav-cta-btn {
  margin-top: 18px;
}

/* Section title lines are defined with the H2 styling below */

/* Breadcrumb typography */
.breadcrumb-content ul li,
.breadcrumb-content ul li a {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  font-weight: 400 !important;
}

/* Welcome subtitle / Global Subheadings */
.welcome-content h5,
.section-title h5,
.shop-top-bar h5,
.Blog-area h5 {
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: #C8A951 !important;
  margin-bottom: 15px !important;
  font-family: 'Inter', sans-serif !important;
}

/* Section Main Titles - Overriding theme flex to ensure center stacking on desktop */
.section-title,
.shop-top-bar,
.contact-title {
  display: block !important;
  text-align: center !important;
  width: 100%;
}

.section-title h2,
.shop-top-bar h2,
.Blog-area h2,
.contact-title h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 38px !important;
  font-weight: 600 !important;
  color: #2D2D2D !important;
  display: inline-block;
  position: relative;
  margin-bottom: 20px !important;
  padding: 0 100px;
}

.section-title h2::before,
.section-title h2::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 70px;
  height: 2px;
  background: #C8A951 !important;
}

.section-title h2::before {
  left: 0;
}

.section-title h2::after {
  right: 0;
}

/* =====================================================
   PRODUCT CARDS
   ===================================================== */
.product-wrap {
  border-radius: 8px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
  transition: all 0.35s ease;
}

.product-wrap:hover {
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1);
  transform: translateY(-5px);
  background: rgba(255, 255, 255, 0.9);
}

.product-wrap .product-img img {
  transition: transform 0.4s ease;
}

.product-wrap:hover .product-img img {
  transform: scale(1.03);
}

.product-price {
  margin-top: 8px;
}

.product-price span {
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  color: #3D5A3E !important;
  font-size: 16px;
}

.product-details-price {
  margin-top: 15px;
  margin-bottom: 25px;
}

.product-details-price span {
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  color: #3D5A3E !important;
  font-size: 26px;
  display: block;
}

/* =====================================================
   SUPPORT / STRENGTH CARDS
   ===================================================== */
.support-wrap {
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.6) !important;
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.04);
  transition: all 0.35s ease;

  /* Layout adjustments for home page strength cards */
  display: flex !important;
  flex-direction: column !important;
  align-items: center;
  justify-content: center;
  padding: 40px 20px !important;
  text-align: center;
}

.support-wrap .support-icon {
  flex: 0 0 auto !important;
  margin: 0 0 20px 0 !important;
  display: flex;
  align-items: center;
  justify-content: center;
}

.support-wrap .support-icon i {
  font-size: 54px;
  color: #3D5A3E;
  /* matching primary brand color */
  transition: transform 0.35s ease;
  line-height: 1;
}

.support-wrap .support-content h5 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 22px !important;
  font-weight: 600 !important;
  margin: 0 0 12px 0 !important;
  color: #2D2D2D !important;
}

.support-wrap .support-content p {
  font-family: 'Inter', sans-serif !important;
  color: #555 !important;
  margin: 0 !important;
  line-height: 1.6;
  font-size: 15px !important;
}

.support-wrap:hover {
  background: rgba(255, 255, 255, 0.8) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  transform: translateY(-5px);
}

.support-wrap:hover .support-icon i {
  transform: scale(1.1);
}

/* =====================================================
   BUTTONS
   ===================================================== */
.default-btn,
.btn-hover a {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0.5px;
  border-radius: 3px;
  transition: all 0.3s ease;
}

.default-btn:hover,
.btn-hover a:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

/* Contact form inputs */
.contact-form-style input,
.contact-form-style textarea {
  font-family: 'Inter', sans-serif;
  border-radius: 3px;
  transition: border-color 0.3s ease;
}

.contact-form-style input:focus,
.contact-form-style textarea:focus {
  border-color: #3D5A3E !important;
}

.contact-form-style button.submit {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  letter-spacing: 0.5px;
  border-radius: 3px;
  transition: all 0.3s ease;
}

.contact-form-style button.submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

/* =====================================================
   BRAND LOGOS
   ===================================================== */
.brand-logo-active .single-brand-logo {
  display: flex !important;
  align-items: center;
  justify-content: center;
  height: 100px;
}

.brand-logo-active .single-brand-logo img {
  width: auto !important;
  max-width: 180px;
  max-height: 70px;
  object-fit: contain;
  -webkit-filter: none !important;
  filter: none !important;
  opacity: 1;
  transition: all 0.4s ease;
}

.brand-logo-active .single-brand-logo:hover img {
  -webkit-filter: none !important;
  filter: none !important;
  transform: scale(1.05);
}

/* =====================================================
   MISC CARDS
   ===================================================== */
.about-us-content {
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
  border-radius: 12px;
  padding: 45px;
  position: relative;
  z-index: 5;
  transition: all 0.3s ease;
}

.about-us-content:hover {
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}

.about-us-content.overlap-left {
  margin-right: -40px;
}

.about-us-content.overlap-right {
  margin-left: -40px;
}

@media only screen and (max-width: 991px) {

  .about-us-content.overlap-left,
  .about-us-content.overlap-right {
    margin: 0 0 30px 0;
    padding: 30px 20px;
  }
}

.about-us-content h2 {
  font-size: 36px;
  font-weight: 600;
  margin-bottom: 20px;
  color: #2D2D2D;
}

.about-us-content p {
  margin-bottom: 15px;
  font-size: 16px;
  color: #555;
}

.about-us-list ul {
  list-style: none;
  padding: 0;
  margin: 20px 0 0 0;
}

.about-us-list ul li {
  padding: 8px 0;
  line-height: 1.7;
  position: relative;
  padding-left: 28px;
  font-weight: 500;
  color: #2D2D2D;
}

.about-us-list ul li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 8px;
  color: #C8A951;
  font-weight: bold;
}

.single-count {
  transition: transform 0.3s ease;
}

.single-count:hover {
  transform: translateY(-3px);
}

.single-mission {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 12px;
  padding: 50px 40px;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
  position: relative;
  overflow: hidden;
}

.single-mission:hover {
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
  transform: translateY(-8px);
}

.single-mission .mission-icon {
  margin-bottom: 25px;
}

.single-mission .mission-icon i {
  font-size: 50px;
  color: #C8A951;
  transition: all 0.3s ease;
}

.single-mission:hover .mission-icon i {
  transform: scale(1.1) rotate(5deg);
}

.single-mission h3 {
  font-size: 26px;
  margin-bottom: 15px;
  color: #2D2D2D;
}

.single-mission p {
  color: #666;
  font-size: 15px;
  line-height: 1.8;
}

/* Company Background Section Enhancement */
.company-bg-section {
  position: relative;
  z-index: 1;
}

.about-vision-content h1 {
  font-size: 42px !important;
  margin-bottom: 25px !important;
  position: relative;
  display: inline-block;
}

.about-vision-content p {
  font-size: 18px !important;
  max-width: 800px;
  margin: 0 auto;
  color: #444 !important;
  line-height: 1.8;
}

.about-us-img img {
  border-radius: 12px !important;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  transition: all 0.5s ease;
  width: 100%;
}

.about-us-img:hover img {
  transform: scale(1.02);
  box-shadow: 0 15px 45px rgba(0, 0, 0, 0.15);
}

.logo img,
.footer-logo img {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
}

/* =====================================================
   MODERN FOOTER
   ===================================================== */
.modern-footer {
  margin: 0 !important;
}

.modern-footer .footer-main {
  background-color: #1A271B;
  /* Darker distinct base color for footer */
  padding: 70px 0 30px;
}

.modern-footer .footer-widget {
  margin-bottom: 20px;
}

.modern-footer .footer-desc {
  color: rgba(255, 255, 255, 0.55) !important;
  font-size: 14px;
  line-height: 1.8;
  margin-top: 10px;
  max-width: 300px;
}

/* Footer widget titles */
.modern-footer .footer-widget-title {
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  font-family: 'Inter', sans-serif !important;
  margin-bottom: 22px !important;
  padding-bottom: 12px !important;
  position: relative !important;
}

.modern-footer .footer-widget-title::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 30px;
  height: 2px;
  background: rgba(255, 255, 255, 0.3);
}

/* Footer quick links */
.modern-footer .footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.modern-footer .footer-links li {
  margin-bottom: 10px;
}

.modern-footer .footer-links li a {
  color: rgba(255, 255, 255, 0.55);
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  transition: all 0.25s ease;
  display: inline-block;
}

.modern-footer .footer-links li a:hover {
  color: #C8A951 !important;
  padding-left: 4px;
}

/* Footer contact list */
.modern-footer .footer-contact {
  list-style: none;
  padding: 0;
  margin: 0;
}

.modern-footer .footer-contact li {
  display: flex;
  align-items: flex-start;
  margin-bottom: 16px;
  color: rgba(255, 255, 255, 0.55);
  font-size: 14px;
  font-family: 'Inter', sans-serif;
}

.modern-footer .footer-contact li i {
  color: rgba(255, 255, 255, 0.4);
  margin-right: 12px;
  margin-top: 4px;
  font-size: 15px;
  min-width: 16px;
}

.modern-footer .footer-contact li span {
  color: rgba(255, 255, 255, 0.55);
  line-height: 1.6;
}

/* Footer social icons */
.modern-footer .footer-social-modern a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.5);
  font-size: 14px;
  margin-right: 8px;
  transition: all 0.3s ease;
}

.modern-footer .footer-social-modern a:hover {
  background-color: #C8A951;
  color: #fff !important;
  border-color: #C8A951;
  transform: translateY(-2px);
}

/* Footer bottom bar */
.modern-footer .footer-bottom-bar {
  background-color: #111A12;
  padding: 18px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}

.modern-footer .footer-bottom-bar p {
  color: rgba(255, 255, 255, 0.4) !important;
  margin: 0;
  font-size: 13px;
  font-family: 'Inter', sans-serif;
}

.modern-footer .footer-bottom-bar a {
  color: rgba(255, 255, 255, 0.5);
  transition: color 0.25s ease;
}

.modern-footer .footer-bottom-bar a:hover {
  color: #C8A951 !important;
}

/* mb-40 utility */
.mb-40 {
  margin-bottom: 40px;
}

/* mt-25 utility */
.mt-25 {
  margin-top: 25px;
}

/* mb-20 utility */
.mb-20 {
  margin-bottom: 20px;
}

/* text-md-end for responsive alignment */
@media (min-width: 768px) {
  .text-md-end {
    text-align: right !important;
  }
}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media only screen and (max-width: 991px) {
  .modern-footer .footer-main {
    padding: 50px 0 10px;
  }

}

@media only screen and (max-width: 767px) {
  .modern-footer .footer-bottom-bar .row {
    text-align: center;
  }

  .modern-footer .footer-bottom-bar .text-md-end {
    text-align: center !important;
    margin-top: 5px;
  }

  .main-menu nav ul li>a.nav-cta-btn {
    margin-top: 0;
    line-height: inherit !important;
    padding: 8px 20px !important;
  }
}

/* =====================================================
   GLASS EFFECTS – ADDITIONAL ELEMENTS
   ===================================================== */

/* Breadcrumb area */
.breadcrumb-area {
  background: rgba(245, 245, 242, 0.65) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}

/* Stat/counter cards */
.single-count {
  background: rgba(255, 255, 255, 0.7) !important;
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 12px;
  padding: 40px 20px;
  transition: all 0.35s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.single-count:hover {
  background: rgba(255, 255, 255, 0.9) !important;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.08);
  transform: translateY(-8px);
}

.single-count .count-icon i {
  color: #3D5A3E;
  /* Brand Green */
  transition: all 0.3s ease;
}

.single-count:hover .count-icon i {
  color: #C8A951;
  /* Swaps to gold on hover */
  transform: scale(1.1);
}

.single-count span {
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 1px;
  font-size: 13px;
  color: #888;
}

/* Contact info sidebar */
.contact-info-wrap {
  background: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 8px;
  padding: 40px !important;
}

.contact-map {
  width: 100%;
  background-color: #eee;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}

.contact-map iframe {
  display: block;
  width: 100% !important;
  height: 450px !important;
  border: 0;
}

/* Nav CTA button – glass version */
.main-menu nav ul li>a.nav-cta-btn {
  background: rgba(61, 90, 62, 0.85) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 6px !important;
}

.main-menu nav ul li>a.nav-cta-btn:hover {
  background: rgba(61, 90, 62, 1) !important;
}

/* Submenu dropdowns – glass */
.main-menu nav ul li ul.submenu {
  background: rgba(255, 255, 255, 0.85) !important;
  backdrop-filter: blur(16px) saturate(180%);
  -webkit-backdrop-filter: blur(16px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
}

/* Shopping cart dropdown – glass */
.shopping-cart-content {
  background: rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.5) !important;
  border-radius: 8px !important;
}

/* Account dropdown – glass */
.account-dropdown {
  background: rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: 8px !important;
}

/* =====================================================
   1. HERO BANNER – DARK GRADIENT OVERLAY
   Makes text readable over any slider image
   ===================================================== */
.slider-area .single-slider {
  position: relative;
}

.slider-area .single-slider::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right,
      rgba(0, 0, 0, 0.55) 0%,
      rgba(0, 0, 0, 0.25) 50%,
      transparent 100%);
  z-index: 1;
  pointer-events: none;
}

.slider-area .single-slider>.container,
.slider-area .single-slider>.container-fluid {
  position: relative;
  z-index: 2;
}

.slider-area .slider-content h1,
.slider-area .slider-content h3 {
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}

/* =====================================================
   2. SCROLL-TRIGGERED FADE-IN ANIMATIONS
   CSS-only using @keyframes + animation on load
   ===================================================== */
@keyframes smoothFadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }

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

@keyframes smoothFadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.welcome-content {
  animation: smoothFadeInUp 0.8s ease-out both;
}

.section-title {
  animation: smoothFadeInUp 0.7s ease-out both;
}

.support-wrap {
  animation: smoothFadeInUp 0.7s ease-out both;
}

.col-lg-3:nth-child(1) .support-wrap,
.col-md-6:nth-child(1) .support-wrap {
  animation-delay: 0s;
}

.col-lg-3:nth-child(2) .support-wrap,
.col-md-6:nth-child(2) .support-wrap {
  animation-delay: 0.1s;
}

.col-lg-3:nth-child(3) .support-wrap,
.col-md-6:nth-child(3) .support-wrap {
  animation-delay: 0.2s;
}

.col-lg-3:nth-child(4) .support-wrap,
.col-md-6:nth-child(4) .support-wrap {
  animation-delay: 0.3s;
}

.single-count {
  animation: smoothFadeInUp 0.7s ease-out both;
}

.col-lg-3:nth-child(1) .single-count {
  animation-delay: 0s;
}

.col-lg-3:nth-child(2) .single-count {
  animation-delay: 0.1s;
}

.col-lg-3:nth-child(3) .single-count {
  animation-delay: 0.2s;
}

.col-lg-3:nth-child(4) .single-count {
  animation-delay: 0.3s;
}

.product-wrap {
  animation: smoothFadeInUp 0.6s ease-out both;
}

.single-mission {
  animation: smoothFadeInUp 0.7s ease-out both;
}

.about-us-img {
  animation: smoothFadeIn 1s ease-out both;
  animation-delay: 0.2s;
}

.about-us-content {
  animation: smoothFadeInUp 0.8s ease-out both;
  animation-delay: 0.15s;
}

/* =====================================================
   3. NAV LINK – UNDERLINE SLIDE-IN EFFECT
   ===================================================== */
.main-menu nav ul li>a:not(.nav-cta-btn) {
  position: relative;
}

.main-menu nav ul li>a:not(.nav-cta-btn)::after {
  content: '';
  position: absolute;
  bottom: 28px;
  left: 50%;
  width: 0;
  height: 2px;
  background: #C8A951;
  transition: all 0.3s ease;
  transform: translateX(-50%);
}

.main-menu nav ul li:hover>a:not(.nav-cta-btn)::after {
  width: 70%;
}

.stick .main-menu nav ul li>a:not(.nav-cta-btn)::after {
  bottom: 20px;
}

@media only screen and (max-width: 991px) {
  .main-menu nav ul li>a:not(.nav-cta-btn)::after {
    display: none;
  }
}

/* =====================================================
   4. BETTER SPACING / BREATHING ROOM
   ===================================================== */
.welcome-area {
  padding-top: 110px !important;
  padding-bottom: 100px !important;
}

.support-area {
  padding-top: 80px !important;
  padding-bottom: 70px !important;
}

.funfact-area {
  padding-top: 100px !important;
  padding-bottom: 80px !important;
}

.subscribe-area-3 {
  padding-top: 80px !important;
  padding-bottom: 80px !important;
}

.brand-logo-area {
  padding-top: 50px !important;
  padding-bottom: 50px !important;
}

/* =====================================================
   5. PRODUCT CARD – HOVER OVERLAY WITH "VIEW"
   ===================================================== */
.product-wrap .product-img {
  position: relative;
  overflow: hidden;
}



/* =====================================================
   6. BACK-TO-TOP BUTTON
   ===================================================== */
#scrollUp,
a.scrollup {
  background: rgba(61, 90, 62, 0.85) !important;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff !important;
  width: 44px;
  height: 44px;
  line-height: 44px;
  text-align: center;
  border-radius: 8px;
  font-size: 18px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  transition: all 0.3s ease;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

#scrollUp:hover,
a.scrollup:hover {
  background: #3D5A3E !important;
  transform: translateY(-3px);
  box-shadow: 0 6px 24px rgba(0, 0, 0, 0.18);
}

/* =====================================================
   7. SMOOTH PAGE SCROLL
   ===================================================== */
html {
  scroll-behavior: smooth;
}

/* =====================================================
   8. IMAGE LAZY FADE-IN
   ===================================================== */
img {
  transition: opacity 0.4s ease;
}

.about-us-img img,
.product-wrap .product-img img {
  transition: transform 0.5s ease, opacity 0.4s ease;
}

/* =====================================================
   9. CUSTOM THIN SCROLLBAR
   ===================================================== */
::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: #f5f5f2;
}

::-webkit-scrollbar-thumb {
  background: #bbb;
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: #888;
}

/* Firefox */
* {
  scrollbar-width: thin;
  scrollbar-color: #bbb #f5f5f2;
}

/* =====================================================
   10. TESTIMONIAL AREA FIXES
   ===================================================== */
.testimonial-area .section-title.mb-60 {
  margin-bottom: 20px !important;
}

.single-testimonial {
  background: rgba(255, 255, 255, 0.7) !important;
  backdrop-filter: blur(12px) saturate(150%);
  -webkit-backdrop-filter: blur(12px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.03);
  border-radius: 12px;
  padding: 35px 30px !important;
  margin-top: 15px;
  /* Gives a little room from the title */
  transition: all 0.3s ease;
}

.single-testimonial:hover {
  background: rgba(255, 255, 255, 0.9) !important;
  transform: translateY(-3px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
}

.single-testimonial img {
  width: 90px !important;
  height: 90px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  margin: 0 auto 20px !important;
  display: block;
}

.single-testimonial p {
  margin: 0 0 20px 0 !important;
  font-size: 16px !important;
  color: #555 !important;
  line-height: 1.7 !important;
  font-family: inherit !important;
  font-style: italic;
}

.single-testimonial .client-info {
  margin: 0 !important;
  padding-top: 15px;
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.single-testimonial .client-info i {
  color: #C8A951 !important;
  font-size: 24px !important;
  margin-bottom: 8px;
}

.single-testimonial .client-info h5 {
  color: #2D2D2D !important;
  font-weight: 600 !important;
  margin: 10px 0 5px 0 !important;
}

.single-testimonial .client-info span {
  color: #888 !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}

/* =====================================================
   11. SECTION SEPARATION / ALTERNATING BACKGROUNDS
   ===================================================== */
/* Giving sections distinctive but subtle background colors to separate them clearly */

.bg-gray-3 {
  background: linear-gradient(135deg, #f8fbf8 0%, #eef3ef 100%) !important;
  position: relative;
}

.brand-logo-area {
  background-color: #FFFFFF !important;
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.02);
  position: relative;
  z-index: 2;
}

.welcome-area,
.about-us-area,
.about-mission-area {
  background: linear-gradient(180deg, #FFFFFF 0%, #fcfdfc 100%) !important;
}

.product-area {
  background: radial-gradient(circle at top right, #f2f7f3 0%, #e6efe8 100%) !important;
  padding-top: 100px !important;
  /* added padding top since it wasn't there */
  position: relative;
}

/* Add a subtle visual divider line between products and brand logo */
.product-area::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(to right, transparent, rgba(61, 90, 62, 0.1), transparent);
}

/* Make sure the text on dark CTA section is readable */
.subscribe-area-3 {
  background: linear-gradient(135deg, #2D4A2F 0%, #1f3521 100%) !important;
  position: relative;
  overflow: hidden;
}

/* Subtle overlay pattern/glow for CTA */
.subscribe-area-3::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: radial-gradient(circle, rgba(200, 169, 81, 0.1) 0%, transparent 60%);
  pointer-events: none;
}

.subscribe-area-3 h2,
.subscribe-area-3 p {
  color: #FFFFFF !important;
  position: relative;
  z-index: 2;
}

.subscribe-area-3 a.default-btn {
  background: linear-gradient(135deg, #D4B456 0%, #B89745 100%) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 15px rgba(200, 169, 81, 0.3) !important;
  position: relative;
  z-index: 2;
  padding: 16px 45px !important;
  border-radius: 6px !important;
  display: inline-block !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  transition: all 0.3s ease !important;
}

.subscribe-area-3 a.default-btn:hover {
  background: linear-gradient(135deg, #fff 0%, #f5f5f5 100%) !important;
  color: #2D4A2F !important;
  box-shadow: 0 8px 25px rgba(255, 255, 255, 0.2) !important;
  transform: translateY(-2px) !important;
}

/* Prevent the default theme button slide-in from overlapping our custom gradient */
.subscribe-area-3 .btn-hover a::after,
.subscribe-area-3 .btn-hover a::before,
.subscribe-area-3 a.default-btn::after,
.subscribe-area-3 a.default-btn::before {
  display: none !important;
}

/* =====================================================
   PRODUCT DETAILS PAGE
   ===================================================== */

/* -- Gallery: Main Image -- */
.product-details-img {
  position: relative;
  width: 100%;
}

.main-image-wrapper {
  position: relative;
  width: 100%;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.06);
}

.main-image-wrapper img {
  width: 100%;
  height: auto;
  min-height: 350px;
  max-height: 500px;
  object-fit: cover;
  display: block;
  transition: opacity 0.35s ease;
}

/* -- Gallery: Thumbnails -- */
.product-thumbnails {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 16px;
}

.sub-thumbnail {
  cursor: pointer;
  border-radius: 8px;
  overflow: hidden;
  border: 2px solid #e8e8e8;
  transition: all 0.3s ease;
  background: #fff;
  aspect-ratio: 1 / 1;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04);
}

.sub-thumbnail:hover {
  border-color: #aaa;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.sub-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: opacity 0.3s ease, transform 0.4s ease;
}

.sub-thumbnail:hover img {
  transform: scale(1.05);
}

.sub-thumbnail.active-thumb {
  border-color: #3D5A3E !important;
  box-shadow: 0 0 0 1px #3D5A3E, 0 4px 12px rgba(61, 90, 62, 0.15);
}

.sub-thumbnail.active-thumb img {
  opacity: 0.85;
}

/* -- Product Details Content -- */
.product-details-content h2 {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 28px !important;
  font-weight: 600 !important;
  color: #2D2D2D !important;
  margin-bottom: 10px !important;
  line-height: 1.3 !important;
}

.product-details-content .pro-details-description h4,
.product-details-content .pro-details-list h4 {
  font-family: 'Inter', sans-serif !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  color: #2D2D2D !important;
  margin-bottom: 10px !important;
  text-transform: none !important;
}

.product-details-content .pro-details-description p {
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: #555 !important;
}

.product-details-content .pro-details-list {
  border-bottom: 1px solid #ececec !important;
}

.product-details-content .pro-details-list ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.product-details-content .pro-details-list ul li {
  padding: 5px 0 !important;
  font-size: 15px !important;
  color: #444 !important;
  line-height: 1.7 !important;
}

.product-details-content .pro-details-list ul li strong {
  color: #2D2D2D;
  font-weight: 600;
}

/* -- CTA Buttons -- */
.product-details-content .pro-details-quality {
  flex-wrap: wrap !important;
  gap: 12px;
}

.product-details-content .pro-details-quality .pro-details-cart {
  margin: 0 !important;
}

.product-details-content .pro-details-quality .pro-details-cart a {
  border-radius: 6px !important;
  padding: 16px 30px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  line-height: 1.4 !important;
  transition: all 0.3s ease !important;
}

.product-details-content .pro-details-quality .pro-details-cart a:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15) !important;
}

/* -- Responsive -- */
@media (max-width: 991px) {
  .product-details-content.ml-70 {
    margin-left: 0 !important;
    margin-top: 35px !important;
  }
}

@media (max-width: 767px) {
  .main-image-wrapper img {
    min-height: 250px;
    max-height: 400px;
  }

  .product-thumbnails {
    gap: 8px;
    margin-top: 12px;
  }

  .product-details-content h2 {
    font-size: 24px !important;
  }

  .product-details-content .pro-details-quality {
    flex-direction: column !important;
  }

  .product-details-content .pro-details-quality .pro-details-cart {
    width: 100%;
  }

  .product-details-content .pro-details-quality .pro-details-cart a {
    width: 100%;
    justify-content: center !important;
    padding: 14px 20px !important;
  }

  .product-details-content h2 {
    font-size: 24px !important;
    text-align: center;
  }

  .pro-description-container {
    font-size: 15px !important;
    overflow-x: auto;
  }

  .pro-description-container table {
    width: 100% !important;
    display: block;
    overflow-x: auto;
  }
}

/* =====================================================
   14. MOBILE SPECIFIC RESPONSIVENESS FIXES (HOMEPAGE)
   ===================================================== */

@media only screen and (max-width: 767px) {

  /* Headings Scaling */
  .section-title h2,
  .shop-top-bar h2,
  .Blog-area h2,
  .contact-title h2,
  .welcome-content h1 {
    font-size: 28px !important;
    line-height: 1.3 !important;
  }

  .slider-area .slider-content-2 h1 {
    font-size: 32px !important;
    line-height: 1.2 !important;
    margin-bottom: 20px !important;
  }

  .slider-area .slider-content-2 h3 {
    font-size: 16px !important;
    letter-spacing: 2px !important;
    margin-bottom: 10px !important;
  }

  /* Hero Image Visibility Fix */
  .slider-height-res {
    min-height: 500px !important;
    background-position: center center !important;
    background-size: cover !important;
  }

  .slider-height-res::before {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.2) 0%, rgba(255, 255, 255, 0.7) 100%) !important;
  }

  /* Section Spacing Reductions */
  .pt-100 {
    padding-top: 60px !important;
  }

  .pb-100 {
    padding-bottom: 60px !important;
  }

  .pt-95 {
    padding-top: 55px !important;
  }

  .pb-95 {
    padding-bottom: 55px !important;
  }

  .pt-110 {
    padding-top: 70px !important;
  }

  .welcome-area {
    padding-top: 70px !important;
    padding-bottom: 65px !important;
  }

  .product-area {
    padding-top: 60px !important;
    padding-bottom: 30px !important;
  }

  /* Support / Strength Wraps on mobile */
  .support-wrap {
    padding: 30px 15px !important;
    margin-bottom: 20px !important;
  }

  /* Featured products layout help */
  .product-wrap {
    margin-bottom: 30px !important;
  }

  /* CTA Section for mobile */
  .subscribe-style-3 h2 {
    font-size: 26px !important;
    margin-bottom: 15px !important;
  }

  .subscribe-area-3 {
    padding: 60px 0 !important;
    text-align: center !important;
  }

  .subscribe-area-3 a.default-btn {
    padding: 14px 30px !important;
    font-size: 14px !important;
    width: 100%;
    max-width: 280px;
    margin: 0 auto;
  }

  /* Logo adjustment */
  .logo img {
    max-height: 35px;
  }

  .header-padding-2 {
    padding: 10px 0 !important;
  }

  /* About Us Page Responsive */
  .about-text {
    font-size: 16px !important;
    text-align: justify;
  }

  .key-facts {
    padding: 20px !important;
    margin-top: 30px !important;
  }

  .key-facts li {
    font-size: 15px !important;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .key-facts li i {
    margin-bottom: 10px;
  }

  .promise-item {
    flex-direction: column;
    text-align: center;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    padding-bottom: 25px;
  }

  .promise-item:last-child {
    border-bottom: none;
  }

  .promise-icon {
    margin-right: 0 !important;
    margin-bottom: 15px;
  }

  .about-us-img {
    margin-bottom: 30px;
  }

  /* Clients & Partners Page Responsive */
  .brand-logo-area {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  .testimonial-area {
    padding-top: 60px !important;
    padding-bottom: 65px !important;
  }

  .single-testimonial {
    padding: 25px 15px !important;
  }

  .single-testimonial p {
    font-size: 15px !important;
    line-height: 1.6 !important;
  }

  .single-testimonial img {
    width: 70px !important;
    height: 70px !important;
  }

  .client-info h5 {
    font-size: 16px !important;
  }

  .client-info span {
    font-size: 12px !important;
  }

  /* News & Blog Area Responsive */
  .blog-wrap-2 {
    margin-bottom: 35px !important;
  }

  .blog-content-2 h4 {
    font-size: 18px !important;
    line-height: 1.4 !important;
    margin-top: 15px !important;
    margin-bottom: 15px !important;
  }

  .blog-content-2 p {
    font-size: 14px !important;
    line-height: 1.6 !important;
  }

  .blog-img-2 img {
    border-radius: 8px !important;
  }

  /* Products & Shop Page Responsive */
  .shop-top-bar h2 {
    font-size: 26px !important;
    margin-bottom: 15px !important;
  }

  .shop-top-bar p {
    font-size: 15px !important;
    line-height: 1.6;
  }

  /* Pagination Styling */
  .pro-pagination-style {
    margin-top: 50px;
  }

  .pro-pagination-style ul {
    display: flex;
    justify-content: center;
    list-style: none;
    padding: 0;
    gap: 8px;
    flex-wrap: wrap;
  }

  .pro-pagination-style ul li {
    display: inline-block;
  }

  .pro-pagination-style ul li span,
  .pro-pagination-style ul li a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background: #fff;
    border: 1px solid #e5e5e5;
    color: #2D2D2D;
    font-weight: 500;
    font-size: 14px;
    border-radius: 4px;
    transition: all 0.3s ease;
    text-decoration: none;
  }

  .pro-pagination-style ul li.active span,
  .pro-pagination-style ul li a:hover {
    background: #3D5A3E;
    border-color: #3D5A3E;
    color: #fff !important;
  }

  .pro-pagination-style ul li.disabled span {
    background: #f8f8f8;
    color: #ccc;
    cursor: not-allowed;
  }

  /* Contact Page Responsive */
  .contact-area {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  .contact-title {
    text-align: center;
    margin-bottom: 30px !important;
  }

  .contact-info-wrap {
    padding: 30px 20px !important;
    margin-bottom: 40px !important;
    text-align: center;
  }

  .single-contact-info {
    flex-direction: column;
    align-items: center;
  }

  .single-contact-info .contact-icon {
    margin-bottom: 15px;
  }

  .contact-map iframe {
    height: 300px !important;
  }

  .contact-form {
    text-align: center;
  }

  .contact-form-style input,
  .contact-form-style textarea {
    margin-bottom: 20px !important;
  }

  .contact-form-style button.submit {
    margin-top: 10px;
    width: 100%;
    padding: 15px !important;
  }

  /* Footer Centering on Mobile */
  .modern-footer {
    text-align: center !important;
  }

  .modern-footer .footer-logo {
    display: flex;
    justify-content: center;
    margin-bottom: 20px;
  }

  .modern-footer .footer-desc {
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 100% !important;
  }

  .modern-footer .footer-social-modern {
    display: flex;
    justify-content: center;
    margin-top: 20px;
  }

  .modern-footer .footer-social-modern a {
    margin: 0 5px !important;
  }

  .modern-footer .footer-widget-title::after {
    left: 50% !important;
    transform: translateX(-50%);
  }

  .modern-footer .footer-contact li {
    justify-content: center !important;
    text-align: center;
    flex-direction: column;
    align-items: center;
  }

  .modern-footer .footer-contact li i {
    margin-right: 0 !important;
    margin-bottom: 8px;
  }
}

@media only screen and (max-width: 480px) {
  .section-title h2 {
    font-size: 24px !important;
  }

  .slider-area .slider-content-2 h1 {
    font-size: 28px !important;
  }
}