:root {
      --brand-teal: #16A34A;
      --brand-teal-dark: #15803D;
      --brand-teal-light: #16A34A;
      --brand-orange: #f47c20;
      --brand-dark: #1b2637;
      --brand-gray: #f5f7fa;
      --brand-border: #e4e8ef;
      --brand-text: #3a4560;
      --brand-muted: #8892a4;
      --card-radius: 14px;
      --btn-radius: 8px;
    }

    * { box-sizing: border-box; }

    body {
      font-family: 'Nunito', sans-serif;
      background: #fff;
      color: var(--brand-text);
      font-size: 0.95rem;
    }

    /* ── Affiliate Notice ── */
/*    .affiliate-bar {
      background: #fffbe6;
      font-size: 0.78rem;
      color: #7a6500;
      padding: 6px 0;
      text-align: center;
      border-bottom: 1px solid #f5e47a;
    }
    .affiliate-bar a { color: var(--brand-teal); text-decoration: underline; }*/

    /* ── Navbar ── */
    .navbar-main {
      background: #15803D;
      /*border-bottom: 2px solid var(--brand-border);*/
      padding: 0.6rem 0;
      position: sticky;
      top: 0;
      z-index: 1030;
      box-shadow: 0 2px 12px rgba(0,0,0,.06);
    }
    /*.navbar-brand-logo {
      background: var(--brand-teal);
      color: #fff !important;
      font-weight: 800;
      font-size: 1.1rem;
      padding: 6px 14px;
      border-radius: 8px;
      letter-spacing: .5px;
      display: inline-flex;
      align-items: center;
      gap: 6px;
      text-decoration: none;
    }*/
    .navbar-brand-logo span.year-badge {
      background: var(--brand-orange);
      font-size: 0.9rem;
      padding: 1px 5px;
      border-radius: 4px;
      /*font-weight: 900;*/
      letter-spacing: .5px;
    }
    .nav-link-main {
      /*color: var(--brand-text) !important;*/
      color:#fff;
      /*font-weight: 700;*/
      font-size: 0.9rem;
      padding: 8px 14px !important;
      border-radius: 6px;
      transition: background .15s, color .15s;
    }
    .nav-link-main:hover { 
      /*background: var(--brand-teal-light); */
      color: var(--brand-teal) !important; 
    }
    .nav-link-main .bi { font-size: 0.75rem; margin-left: 2px; }
    .search-input-nav {
      border: 1px solid var(--brand-border);
      border-radius: 8px;
      padding: 6px 14px;
      font-size: 0.88rem;
      width: 200px;
      outline: none;
      transition: border-color .15s;
      background: transparent;
      color: #fff;
    }
    .search-input-nav::placeholder{color:#fff;opacity:1;}
    .search-input-nav:focus { border-color: var(--brand-teal); }

    /* ── Hero Carousel ── */
    .hero-carousel .carousel-item {
      height: 320px;
      border-radius: 18px;
      overflow: hidden;
      position: relative;
    }
    .hero-slide {
      height: 320px;
      display: flex;
      align-items: center;
      padding: 0 60px;
      border-radius: 18px;
      position: relative;
      overflow: hidden;
    }
    .hero-slide-1 { background: linear-gradient(135deg, #fde8f0 0%, #fff5e0 60%, #e8f7f4 100%); }
    .hero-slide-2 { background: linear-gradient(135deg, #e0f7f4 0%, #fff8e6 60%, #fdeaf5 100%); }
    .hero-slide-3 { background: linear-gradient(135deg, #e8eaff 0%, #f0fde8 60%, #fff3e0 100%); }
    .hero-slide-badge {
      display: inline-block;
      background: var(--brand-teal);
      color: #fff;
      font-size: 0.72rem;
      /*font-weight: 800;*/
      text-transform: uppercase;
      letter-spacing: 1px;
      padding: 4px 10px;
      border-radius: 6px;
      margin-bottom: 10px;
    }
    .hero-slide-title {
      font-size: 2.1rem;
      font-weight: 800;
      color: var(--brand-dark);
      line-height: 1.2;
      margin-bottom: 6px;
    }
    .hero-slide-sub {
      font-size: 0.9rem;
      color: var(--brand-muted);
      margin-bottom: 18px;
    }
    .hero-shop-btn {
      background: var(--brand-teal);
      color: #fff !important;
      /*font-weight: 800;*/
      padding: 10px 26px;
      border-radius: 8px;
      font-size: 0.9rem;
      text-decoration: none;
      display: inline-block;
      transition: background .15s, transform .1s;
    }
    .hero-shop-btn:hover { background: var(--brand-teal-dark); transform: translateY(-1px); }
    .hero-slide-img {
      position: absolute;
      right: 0; bottom: 0;
      height: 110%;
      object-fit: contain;
      opacity: .18;
      pointer-events: none;
    }
    /* Carousel controls */
    .hero-carousel .carousel-indicators [data-bs-target] {
      width: 8px; height: 8px; border-radius: 50%;
      background: var(--brand-teal); opacity: .35;
      border: none;
    }
    .hero-carousel .carousel-indicators .active { opacity: 1; }
    .hero-carousel .carousel-control-prev,
    .hero-carousel .carousel-control-next {
      width: 42px; height: 42px;
      background: #fff;
      border-radius: 50%;
      top: 50%; transform: translateY(-50%);
      border: 2px solid var(--brand-border);
      opacity: 1;
      box-shadow: 0 2px 8px rgba(0,0,0,.08);
    }
    .hero-carousel .carousel-control-prev { left: 10px; }
    .hero-carousel .carousel-control-next { right: 10px; }
    .hero-carousel .carousel-control-prev-icon,
    .hero-carousel .carousel-control-next-icon {
      filter: invert(1) sepia(1) saturate(5) hue-rotate(130deg);
      width: 16px; height: 16px;
    }

    /* ── Brand Logos Strip ── */
    .brands-strip {
      background: #fff;
      border: 1px solid var(--brand-border);
      border-radius: 14px;
      padding: 18px 0;
      margin-top: 28px;
    }
    .brand-logo-item {
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 8px 18px;
      border-right: 1px solid var(--brand-border);
      opacity: .7;
      transition: opacity .15s;
    }
    .brand-logo-item:last-child { border-right: none; }
    .brand-logo-item:hover { opacity: 1; }
    .brand-logo-item span {
      font-size: 1.15rem;
      font-weight: 800;
      letter-spacing: .5px;
    }
    #featured-store-slider .owl-stage{display:flex;align-items:center;}
    /* ── Seasonal Banner ── */
    .seasonal-banner {
      background: linear-gradient(135deg, #1b2637 0%, #2d4a3e 60%, #1aaa8c 100%);
      border-radius: 16px;
      padding: 28px 40px;
      position: relative;
      overflow: hidden;
      margin-top: 28px;
    }
    .seasonal-banner::before {
      content: '';
      position: absolute; inset: 0;
      background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60'%3E%3Ccircle cx='30' cy='30' r='28' fill='none' stroke='rgba(255,255,255,.04)' stroke-width='2'/%3E%3C/svg%3E") repeat;
      pointer-events: none;
    }
    .seasonal-badge {
      background: rgba(255,255,255,.15);
      color: #fff;
      font-size: 0.7rem;
      font-weight: 800;
      text-transform: uppercase;
      letter-spacing: 2px;
      padding: 4px 12px;
      border-radius: 20px;
      display: inline-block;
      /*margin-bottom: 10px;*/
      border: 1px solid rgba(255,255,255,.2);
    }
    .seasonal-title {
      font-size: 2rem;
      font-weight: 800;
      color: #fff;
      line-height: 1.2;
    }
    .seasonal-title em { color: #f5c842; font-style: normal; }
    .seasonal-sub { color: rgba(255,255,255,.75); font-size: 0.9rem; margin-top: 6px; }
    .leaf-decor {
      position: absolute;
      right: 40px; top: 50%;
      transform: translateY(-50%);
      font-size: 5rem;
      opacity: .18;
      pointer-events: none;
    }
    .seasonal-banner .navbar-brand-logo{
        background-color: #158a72;
        padding: 10px;
        color: white;
        text-decoration: none;
        border-radius: 20px ;
      }

    /* ── Section Header ── */
    .section-header {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-bottom: 20px;
      margin-top: 40px;
    }
    .section-title {
      font-size: 1.35rem;
      font-weight: 800;
      color: var(--brand-dark);
      margin: 0;
    }
    .section-arrow {
      width: 26px; height: 26px;
      background: var(--brand-teal);
      border-radius: 50%;
      display: inline-flex;
      align-items: center;
      justify-content: center;
      color: #fff;
      font-size: 0.75rem;
      flex-shrink: 0;
    }

    /* ── Coupon Card ── */
    .coupon-card {
      border: 1.5px solid var(--brand-border);
      border-radius: var(--card-radius);
      padding: 18px 16px 14px;
      background: #fff;
      transition: box-shadow .18s, transform .18s, border-color .18s;
      height: 100%;
      display: flex;
      flex-direction: column;
      gap: 6px;
      cursor: pointer;
    }
    .coupon-card:hover {
      box-shadow: 0 8px 28px rgba(26,170,140,.13);
      transform: translateY(-3px);
      border-color: var(--brand-teal);
    }
    .coupon-card-brand {
      font-size: 1rem;
      font-weight: 800;
      letter-spacing: .3px;
    }
    .coupon-discount {
      font-size: 1.45rem;
      font-weight: 800;
      color: var(--brand-dark);
    }
    .coupon-desc {
      font-size: 0.78rem;
      color: var(--brand-muted);
      line-height: 1.4;
      flex: 1;
    }
    .coupon-code-btn {
      display: inline-block;
      background: #e6f7f4;
      color: var(--brand-teal);
      font-size: 0.78rem;
      font-weight: 600;
      padding: 5px 12px;
      border-radius: 6px;
      border: 1.5px dashed var(--brand-teal);
      text-decoration: none;
      letter-spacing: .3px;
      transition: background .15s, color .15s;
      align-self: flex-start;
    }
    .coupon-code-btn:hover {
      background: var(--brand-teal);
      color: #fff;
    }

    /* ── Newsletter ── */
    .newsletter-section {
      background: linear-gradient(135deg, #16A34A 0%, #15803D 100%);
      border-radius: 18px;
      padding: 48px 40px;
      text-align: center;
      margin-top: 48px;
      position: relative;
      overflow: hidden;
    }
    .newsletter-section::before {
      content: '';
      position: absolute; inset: 0;
      background: radial-gradient(circle at 80% 20%, rgba(255,255,255,.08) 0%, transparent 60%);
      pointer-events: none;
    }
    .newsletter-title {
      font-size: 1.9rem;
      font-weight: 800;
      color: #fff;
      margin-bottom: 6px;
    }
    .newsletter-sub { color: rgba(255,255,255,.82); font-size: 0.9rem; margin-bottom: 24px; }
    .newsletter-form {
      display: flex;
      gap: 0;
      max-width: 440px;
      margin: 0 auto 12px;
      border-radius: 10px;
      overflow: hidden;
      box-shadow: 0 4px 20px rgba(0,0,0,.12);
    }
    .newsletter-input {
      flex: 1;
      border: none;
      padding: 14px 18px;
      font-size: 0.9rem;
      font-family: 'Nunito', sans-serif;
      outline: none;
    }
    .newsletter-btn {
      background: var(--brand-dark);
      color: #fff;
      border: none;
      padding: 14px 24px;
      font-family: 'Nunito', sans-serif;
      font-weight: 800;
      font-size: 0.9rem;
      cursor: pointer;
      transition: background .15s;
    }
    .newsletter-btn:hover { background: var(--brand-orange); }
    .newsletter-terms { font-size: 0.74rem; color: rgba(255,255,255,.65); }
    .newsletter-terms a { color: rgba(255,255,255,.9); }

    /* ── Footer ── */
    .footer-main {
      background: var(--brand-teal-dark);
      color: rgba(255,255,255,.75);
      padding: 52px 0 28px;
      margin-top: 64px;
    }
    .footer-logo-area {
      margin-bottom: 16px;
    }
    .footer-brand-tag {
      font-size: 0.82rem;
      color: rgba(255,255,255,.5);
      line-height: 1.6;
      max-width: 260px;
    }
    .footer-heading {
      font-weight: 800;
      font-size: 0.9rem;
      color: #fff;
      text-transform: uppercase;
      letter-spacing: .8px;
      margin-bottom: 16px;
    }
    .footer-links { list-style: none; padding: 0; margin: 0; }
    /*.footer-links li { margin-bottom: 8px; }*/
    .footer-links a {
      color: rgba(255,255,255,.6);
      text-decoration: none;
      font-size: 0.87rem;
      transition: color .15s;
      text-transform:capitalize;
    }
    .footer-links a:hover { color: var(--brand-teal); }
    .footer-social a {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 34px; height: 34px;
      border-radius: 8px;
      background: rgba(255,255,255,.08);
      color: rgba(255,255,255,.7);
      text-decoration: none;
      font-size: 1rem;
      margin-right: 6px;
      transition: background .15s, color .15s;
    }
    .footer-social a:hover { background: var(--brand-teal); color: #fff; }
    .footer-bottom {
      border-top: 1px solid rgba(255,255,255,.08);
      margin-top: 36px;
      padding-top: 18px;
      font-size: 0.78rem;
      color: rgba(255,255,255,.35);
      text-align: center;
    }
    .footer-links li a {
  text-decoration: none;
  color: white;
  margin-top: 5px;
   }
   .footer-social a {
  color: white;
}
    /* ── Responsive tweaks ── */
    @media (max-width: 768px) {
      .hero-slide { padding: 30px 24px; height: auto; min-height: 220px; }
      .hero-slide-title { font-size: 1.4rem; }
      .seasonal-banner { padding: 24px 20px; }
      .seasonal-title { font-size: 1.4rem; }
      .newsletter-section { padding: 32px 20px; }
      .newsletter-form { flex-direction: column; border-radius: 10px; }
      .newsletter-input, .newsletter-btn { border-radius: 8px; }
    }




.navbar-nav {
  gap: 15px;
}
.nav-link {
  font-weight: 300;
}
.dropdown-toggle::after {
  content: "\f282";
  border: unset;
  font-family: bootstrap-icons !important;
  font-weight: bold;
  display: inline-block;
  width: 13px;
  height: 21px;
  font-size: 15px !important;
}
.form-control::placeholder {
  color: rgba(255, 255, 255, 0.75);
  opacity: 1;
}
.modal-backdrop.fade.show {
  z-index: -1;
  opacity:0;
}
.modal{background:rgba(0, 0, 0, 0.3);}
main#main-content {
  background: #f5f7fa;
}
/*category*/
/* ── Page wrapper ── */
    .page-wrapper {
      max-width: 1200px;
      margin: 0 auto;
      padding: 32px 20px 64px;
    }

    /* ── Category heading ── */
    .category-page-title {
      font-family: 'Syne', sans-serif;
      font-size: 1.75rem;
      /*font-weight: 800;*/
      color: var(--brand-dark);
      margin-bottom: 24px;
    }
    .category-page-title span { color: var(--brand-teal); }

    /* ── SIDEBAR ── */
    .sidebar-card {
      background: #fff;
      border: 1.5px solid var(--brand-border);
      border-radius: var(--card-radius);
      overflow: hidden;
      position: sticky;
      top: 76px;
    }

    /* Filter header */
    .filter-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      background: var(--brand-teal);
      padding: 12px 18px;
    }
    .filter-header-left {
      font-size: 1rem;
      color: #fff;
      display: flex;
      align-items: center;
      gap: 8px;
    }
    .filter-header-right {
      color: rgba(255,255,255,.8);
      font-size: 1.1rem;
      cursor: pointer;
    }

    /* Filter body */
    .filter-body { padding: 18px; }

    .filter-section-title {
      font-family: 'Syne', sans-serif;
      font-size: 0.82rem;
      font-weight: 800;
      color: var(--brand-teal);
      text-transform: uppercase;
      letter-spacing: .8px;
      margin-bottom: 10px;
      display: flex;
      align-items: center;
      justify-content: space-between;
    }
    .clear-link {
      font-family: 'Nunito', sans-serif;
      font-weight: 700;
      font-size: 0.75rem;
      color: var(--brand-muted);
      text-decoration: underline;
      cursor: pointer;
      text-transform: none;
      letter-spacing: 0;
    }
    .clear-link:hover { color: var(--brand-teal); }

    /* Custom checkboxes */
    .filter-check-item {
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 7px 0;
      border-bottom: 1px solid var(--brand-border);
      cursor: pointer;
    }
    .filter-check-item:last-child { border-bottom: none; }
    .filter-check-item input[type="checkbox"] {
      width: 16px; height: 16px;
      accent-color: var(--brand-teal);
      cursor: pointer;
      flex-shrink: 0;
    }
    .filter-check-label {
      font-size: 0.85rem;
      /*font-weight: 700;*/
      color: var(--brand-text);
      flex: 1;
    }
    .filter-count {
      font-size: 0.72rem;
      font-weight: 800;
      background: var(--brand-teal-light);
      color: var(--brand-teal);
      padding: 2px 7px;
      border-radius: 10px;
    }
    .filter-divider {
      border: none;
      border-top: 1.5px solid var(--brand-border);
      margin: 14px 0;
    }

    /* ── DEAL CARDS (category variant - with store logo) ── */
    .deal-card {
      background: #fff;
      border: 1.5px solid var(--brand-border);
      border-radius: var(--card-radius);
      display: flex;
      align-items: stretch;
      overflow: hidden;
      transition: box-shadow .18s, border-color .18s, transform .15s;
      margin-bottom: 14px;
    }
    .deal-card:hover {
      box-shadow: 0 8px 28px rgba(26,170,140,.13);
      border-color: var(--brand-teal);
      transform: translateY(-2px);
    }

    /* Store logo column */
    .deal-store-logo {
  width: 115px;
  min-width: 115px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 10px;
  background: #e6f7f4;
  border-right: 1.5px dashed rgba(26,170,140,.3);
  position: relative;
  flex-shrink: 0;
}
    /* Notch cutouts */
    .deal-store-logo::before,
    .deal-store-logo::after {
      content: '';
      position: absolute;
      width: 16px; height: 16px;
      background: var(--brand-gray);
      border-radius: 50%;
      right: -8px;
      z-index: 1;
    }
    .deal-store-logo::before { top: -8px; }
    .deal-store-logo::after  { bottom: -8px; }

    .store-logo-circle {
  /* width: 52px; */
  /* height: 52px; */
  /* border-radius: 50%; */
  /* background: linear-gradient(135deg, #1b2637 55%, #2a4060 100%); */
  display: flex;
  align-items: center;
  justify-content: center;
  /* border: 2px solid rgba(26,170,140,.25); */
  /* box-shadow: 0 2px 8px rgba(26,170,140,.15); */
}
    .store-logo-circle span {
  font-size: 1.9rem;
  color: #15803d;
  letter-spacing: .3px;
  text-align: center;
  line-height: 1.2;
  font-weight: bold;
}

    /* Middle: deal info */
    .deal-info {
      flex: 1;
      padding: 14px 18px;
      display: flex;
      flex-direction: column;
      justify-content: center;
      gap: 6px;
    }
    .deal-meta {
      display: flex;
      align-items: center;
      gap: 12px;
      flex-wrap: wrap;
    }
    .deal-verified {
      display: inline-flex;
      align-items: center;
      gap: 4px;
      font-size: 0.72rem;
      color: var(--brand-teal);
    }
    .deal-expiry {
      font-size: 0.72rem;
      color: var(--brand-muted);
      font-weight: 700;
    }
    .deal-expiry i { color: #e07c20; margin-right: 3px; }
    .deal-used {
      font-size: 0.72rem;
      color: var(--brand-muted);
      font-weight: 700;
    }
    .deal-used i { color: var(--brand-teal); margin-right: 3px; }
    .deal-title {
      font-size: 1rem;
      color: var(--brand-dark);
      margin: 0;
      line-height: 1.3;
    }
    .deal-subtitle {
      font-size: 0.82rem;
      color: var(--brand-muted);
      margin: 0;
    }

    /* Right: CTA */
    .deal-cta {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      padding: 16px 18px;
      gap: 8px;
      flex-shrink: 0;
      min-width: 130px;
    }
    .deal-get-btn {
      background: var(--brand-teal);
      color: #fff !important;
      font-size: 0.85rem;
      padding: 9px 20px;
      border-radius: 8px;
      text-decoration: none;
      white-space: nowrap;
      transition: background .15s, transform .1s;
      display: inline-block;
      text-align: center;
      width: 100%;
    }
    .deal-get-btn:hover { background: var(--brand-teal-dark); transform: translateY(-1px); }
    .deal-view-link {
      font-size: 0.76rem;
      color: var(--brand-teal);
      text-decoration: underline;
      font-weight: 700;
      cursor: pointer;
      text-align: center;
    }
    .deal-view-link:hover { color: var(--brand-teal-dark); }

    /* Results count bar */
    .results-bar {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 18px;
      flex-wrap: wrap;
      gap: 10px;
    }
    .results-count {
      font-size: 0.85rem;
      color: var(--brand-muted);
      font-weight: 700;
    }
    .results-count strong { color: var(--brand-dark); }
    .sort-select {
      border: 1.5px solid var(--brand-border);
      border-radius: 8px;
      padding: 6px 12px;
      font-size: 0.83rem;
      font-family: 'Nunito', sans-serif;
      font-weight: 700;
      color: var(--brand-text);
      background: #fff;
      outline: none;
      cursor: pointer;
    }
    .sort-select:focus { border-color: var(--brand-teal); }

    /* Active filter pills */
    .active-filters {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-bottom: 16px;
    }
    .filter-pill {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      background: var(--brand-teal-light);
      color: var(--brand-teal);
      font-size: 0.75rem;
      font-weight: 800;
      padding: 4px 10px;
      border-radius: 20px;
      border: 1px solid rgba(26,170,140,.25);
    }
    .filter-pill button {
      background: none;
      border: none;
      color: var(--brand-teal);
      font-size: 0.75rem;
      padding: 0;
      cursor: pointer;
      line-height: 1;
    }


/*store*/
/* ── Page heading ── */
    .store-page-title {
      font-size: 1.9rem;
      /*font-weight: 800;*/
      color: var(--brand-dark);
      margin-bottom: 24px;
    }
    .store-page-title span { color: var(--brand-teal); }

    /* Store logo box */
    .store-logo-box {
      background: linear-gradient(135deg, #f0fdf8 0%, #e6f7f4 100%);
      padding: 28px 20px;
      display: flex;
      align-items: center;
      justify-content: center;
      border-bottom: 1.5px solid var(--brand-border);
      min-height: 160px;
    }
    .store-logo-box img {
      max-width: 120px;
      max-height: 100px;
      object-fit: contain;
    }
    .store-logo-placeholder {
      width: 110px;
      height: 110px;
      border-radius: 50%;
      background: linear-gradient(135deg, #1b2637 60%, #2a4060 100%);
      display: flex;
      align-items: center;
      justify-content: center;
      position: relative;
    }
    .store-logo-placeholder-inner {
      text-align: center;
      color: #fff;
    }
    .store-logo-placeholder-inner .store-name-logo {
      font-family: 'Syne', sans-serif;
      font-size: .85rem;
      font-weight: 800;
      letter-spacing: .5px;
      line-height: 1.2;
    }
    .store-logo-placeholder-inner .store-sub-logo {
      font-size: .65rem;
      color: rgba(255,255,255,.65);
      letter-spacing: 1.5px;
      text-transform: uppercase;
    }
.post-reply-form .quill-container.ql-container.ql-snow {
  height: 200px;
}
/******************  Responsive *********************/
@media only screen and (max-width: 767px){
  .deal-store-logo {
    width: 100%;
    justify-content: flex-start;
  }
}