:root {
  --color-primary: #BFA145;        /* Gold */
  --color-accent: #31513A;         /* Deep Green */
  --color-accent-light: #6CA88E;   /* Soft accent green */
  --color-bg: #F8F5F0;             /* Soft cream */
  --color-white: #fff;
  --color-card: #fff;
  --color-text: #31513A;			/* Deep Green */
  --color-text-gold: #BFA145;        /* Gold */
  --color-shadow: rgba(191,161,69,0.08);
}

/* Body & Typography */
body {
  background: var(--color-bg);
  color: var(--color-text);
  font-family: 'Poppins', 'Inter', Arial, sans-serif;
  margin: 0;
  padding: 0;
  font-size: 1.06rem;
}

h1, h2, h3, h4, .text-accent {
  color: var(--color-text) !important;
  font-family: 'Poppins', Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 0.01em;
}

.text-gold {
  color: var(--color-primary) !important;
}

a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.16s;
}
a:hover {
  color: var(--color-primary);
  text-decoration: none;
}

/* Navbar */
.custom-navbar {
  background: var(--color-bg) !important;
  border-bottom: 1.5px solid #e6dcc0;
}

.navbar-logo {
  height: 38px;
}

.navbar-brand span {
  color: var(--color-primary);
  letter-spacing: 1.5px;
}

.nav-link, .dropdown-item {
  font-family: 'Poppins', Arial, sans-serif;
  font-weight: 600;
  color: var(--color-accent) !important;
}
.nav-link.active, .nav-link:hover, .dropdown-item:hover {
  color: var(--color-primary) !important;
  background: none;
}

/* Category Bar */
.category-bar .category-btn {
  border-radius: 2em;
  border: 2px solid var(--color-primary);
  font-weight: 500;
  color: var(--color-accent);
  background: var(--color-white);
  padding: 0.45em 1.2em;
  margin: 0 0.18em;
  transition: background 0.16s, color 0.16s, border 0.16s;
}
.category-bar .category-btn:hover,
.category-bar .category-btn:focus {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-accent);
}

/* Product Cards */
.dog-card {
  border-radius: 1.2rem;
  background: var(--color-card);
  box-shadow: 0 4px 32px var(--color-shadow);
  border: 1.5px solid #e6dcc0;
  transition: transform 0.14s, box-shadow 0.14s, border 0.13s;
}
.dog-card:hover {
  transform: translateY(-5px) scale(1.018);
  box-shadow: 0 8px 48px rgba(191,161,69,0.20);
  border-color: var(--color-primary);
}
.card-img-top {
  object-fit: cover;
  height: 220px;
  border-top-left-radius: 1.2rem;
  border-top-right-radius: 1.2rem;
  background: #f1e9d9;
}

.card-body .h5 {
  font-family: 'Poppins', Arial, sans-serif;
  font-size: 1.13em;
  font-weight: 700;
  color: var(--color-accent);
  margin-bottom: 0.3em;
}

/* Price below buttons: deep green */
.dog-card .text-center span,
.dog-card .product-price {
  color: var(--color-accent);
  font-weight: 600;
  font-size: 1.07em;
}

/* Buttons */
.btn-primary, .btn-primary:focus {
  background: var(--color-primary);
  border: none;
  border-radius: 2em;
  color: var(--color-white);
  font-weight: 600;
  box-shadow: 0 1px 8px rgba(191,161,69,0.08);
  transition: background 0.14s, color 0.12s;
}
.btn-primary:hover {
  background: var(--color-accent);
  color: var(--color-primary);
}

.btn-outline-primary {
  border: 2px solid var(--color-primary);
  color: var(--color-accent);
  background: var(--color-white);
  border-radius: 2em;
  transition: background 0.14s, color 0.13s, border 0.14s;
}
.btn-outline-primary:hover, .btn-outline-primary:focus {
  background: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-accent);
}

.product-description p,
.product-description ul,
.product-description ol,
.product-description li {
  margin-top: 0;
  margin-bottom: 0.45em;
}

.product-description ul,
.product-description ol {
  padding-left: 1.1em;
  margin-bottom: 0.7em;
}

.product-description li {
  margin-bottom: 0.30em;
}

.product-description > *:first-child {
  margin-top: 0;
}
.product-description > *:last-child {
  margin-bottom: 0;
}


.product-description-section {
  background: var(--color-card);
  box-shadow: 0 1px 12px var(--color-shadow);
  border-radius: 1rem;
}

.badge-gold {
  background: var(--color-primary) !important;
  color: var(--color-white) !important;
  font-size: 1em;
  font-weight: 500;
  border-radius: 2em;
  padding: 0.6em 1.2em;
}

.badge-green {
  background: var(--color-accent-light) !important;
  color: var(--color-accent) !important;
  font-size: 1em;
  font-weight: 500;
  border-radius: 2em;
  padding: 0.6em 1.2em;
}

.badge-shipping {
  background: var(--color-card) !important;
  color: var(--color-accent) !important;
  border: 1.5px solid var(--color-primary);
  font-size: 1em;
  font-weight: 500;
  border-radius: 2em;
  padding: 0.6em 1.2em;
}

@media (max-width: 767px) {
  .product-description {
    padding: 1em;
    font-size: 1.03em;
  }
  .badge-gold,
  .badge-green,
  .badge-shipping {
    font-size: 0.96em;
    padding: 0.48em 0.8em;
  }
}


/* Load More Button */
#load-more-btn {
  padding: 0.7em 2.2em;
  font-size: 1.12em;
  border-radius: 2em;
  background: var(--color-accent);
  color: var(--color-white);
  border: none;
  font-weight: 600;
}
#load-more-btn:hover {
  background: var(--color-primary);
  color: var(--color-accent);
}

/* Floating Checkout Button */
#floating-checkout-btn {
  position: fixed;
  bottom: 2.5em;
  right: 2.2em;
  z-index: 20;
  box-shadow: 0 4px 24px var(--color-shadow);
  display: none;
  opacity: 0;
  background: var(--color-primary);
  color: var(--color-white);
  font-weight: 600;
  border-radius: 2em;
  transition: opacity 0.19s, background 0.14s;
}
#floating-checkout-btn.show {
  display: block;
  opacity: 1;
}

/* Footer */
.custom-footer {
  background: var(--color-bg);
  color: var(--color-accent);
  border-top: 1px solid #e6dcc0;
  font-family: 'Poppins', Arial, sans-serif;
  font-size: 1.03em;
}

/* Toasts */
#toast-container .toast-header {
  background: var(--color-accent);
  color: var(--color-white);
  border-radius: 0.5em 0.5em 0 0;
}

.toast {
  background: var(--color-card);
  color: var(--color-text);
  min-width: 210px;
  box-shadow: 0 1px 14px rgba(191,161,69,0.09);
  border-radius: 0.5em;
}

/* Cookie Consent */
.cookie-consent-banner {
  position: fixed;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 2000;
  background: var(--color-white);
  color: var(--color-accent);
  padding: 1.1em 1em;
  border-top: 2px solid var(--color-primary);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1.2em;
  box-shadow: 0 -2px 16px rgba(191,161,69,0.11);
}




/* Responsive tweaks */
@media (max-width: 575px) {
  .category-bar .category-btn {
    font-size: 0.97em;
    padding: 0.37em 0.75em;
    margin-bottom: 0.22em;
  }
  .dog-card {
    border-radius: 1em;
  }
  .card-img-top {
    height: 145px;
  }
}
/* For the search result "not found" box */
.alert-info {
  background: var(--color-card) !important;
  color: var(--color-accent) !important;
  border: 1.5px solid #e6dcc0;
  border-radius: 1.2rem;
  box-shadow: 0 2px 18px var(--color-shadow);
  font-family: 'Poppins', Arial, sans-serif;
}


#toast-container {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 1055;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.toast {
  background: var(--color-accent) !important;
  color: var(--color-white) !important;
  border: none !important;
  border-radius: 0.8rem !important;
  box-shadow: 0 4px 18px var(--color-shadow);
  min-width: 250px;
  max-width: 350px;
  margin-bottom: 0.8rem;
  overflow: hidden;
}

.toast-header {
  background: transparent !important;
  color: var(--color-white) !important;
  border-bottom: none !important;
  border-radius: 0.8rem 0.8rem 0 0;
  font-weight: 600;
  font-size: 1.07em;
  align-items: center;
  padding: 0.9rem 1.2rem !important;
  gap: 0.7em;
}

.toast-icon {
  color: var(--color-primary);
  font-size: 1.2em;
  display: flex;
  align-items: center;
}

.toast-message {
  color: var(--color-white);
  font-weight: 500;
  letter-spacing: 0.01em;
}

.toast .btn-close {
  filter: invert(1);
  opacity: 0.7;
}

@media (max-width: 600px) {
  #toast-container {
    left: 0;
    right: 0;
    bottom: 1rem;
    top: unset;
    align-items: center;
    padding: 0 1rem;
  }
  .toast {
    max-width: 100%;
    min-width: 0;
    font-size: 1rem;
    margin-left: 0;
    margin-right: 0;
  }
}



.image-upload-group {
  margin-bottom: 1.5em;
}

.custom-upload-card {
  position: relative;
  border: 2px dashed var(--color-primary);
  background: var(--color-white);
  border-radius: 1.1em;
  padding: 1.2em 1em 1em 1em;
  min-height: 130px;
  display: flex;
  align-items: center;
  gap: 1.2em;
  box-shadow: 0 2px 12px var(--color-shadow);
}

.img-preview {
  width: 100px;
  height: 100px;
  object-fit: cover;
  border-radius: 0.9em;
  border: 1.5px solid var(--color-primary);
  background: #f8f5f0;
  display: block;
}

.file-input {
  display: none;
}

.upload-btn {
  display: inline-block;
  background: var(--color-primary);
  color: var(--color-white);
  border-radius: 2em;
  padding: 0.5em 1.5em;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.12s;
  margin-left: 0.5em;
}
.upload-btn:hover {
  background: var(--color-accent);
  color: var(--color-primary);
}

.remove-btn {
  background: var(--color-accent);
  color: var(--color-white);
  border: none;
  border-radius: 50%;
  width: 2.2em;
  height: 2.2em;
  font-size: 1.15em;
  position: absolute;
  top: 8px;
  right: 8px;
  display: none;
  cursor: pointer;
  transition: background 0.11s;
  z-index: 2;
}
.custom-upload-card:hover .remove-btn,
.img-preview:not(.d-none) + .remove-btn {
  display: block;
}

.product-detail-img, .modal .carousel-item img {
  cursor: pointer;
  border-radius: 1.1em;
  box-shadow: 0 2px 16px rgba(0,0,0,0.06);
}
.carousel-control-prev-icon,
.carousel-control-next-icon {
  filter: invert(68%) sepia(97%) saturate(698%) hue-rotate(7deg) brightness(1.2);
  width: 2.5rem;
  height: 2.5rem;
  box-shadow: 0 2px 10px rgba(191,161,69,0.22);
  border-radius: 50%;
}
