body {
  font-family: 'Lora', serif;
  background-color: #fdfcf9;
  color: #1a1a1a;
}

h1, h2, .navbar-brand {
  font-family: 'Great Vibes', cursive;
  color: #5b7860;
}

h2 {
  font-size: 2rem;
  margin-bottom: 1rem;
}

.navbar {
  background-color: rgba(255, 255, 255, 0.9);
  border-bottom: 1px solid #dce3df;
  padding: 1rem 2rem;
}

.navbar-nav .nav-link {
  color: #5b7860 !important;
  font-weight: 500;
  margin-left: 1rem;
  transition: color 0.3s ease;
}

.navbar-nav .nav-link:hover {
  color: #90a29c !important;
}

header {
  background: url('../images/header-bg.jpg') center/cover no-repeat;
  padding: 3rem 1rem 2rem;
  text-align: center;
}

header h1 {
  font-size: 3.5rem;
}

header p {
  font-size: 1.25rem;
  color: #444;
}

.notice {
  background-color: #f3f7f5;
  border-left: 5px solid #90a29c;
  padding: 0.75rem 1rem;
  margin: 0 auto 1.5rem;
  width: 90%;
  text-align: center;
  font-weight: 500;
  color: #5b7860;
}

#about {
  background-color: #ffffff;
  border-top: 1px solid #e3e8e4;
  border-bottom: 1px solid #e3e8e4;
  padding: 4rem 1rem;
}

#about p {
  max-width: 800px;
  margin: 0 auto;
  font-size: 1.1rem;
  line-height: 1.75;
  color: #2a2a2a;
}

.card {
  border: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.06);
  transition: transform 0.2s ease;
  transform: scale(0.95);
}

.card:hover {
  transform: translateY(-5px) scale(0.95);
}

.card-title {
  font-family: 'Great Vibes', cursive;
  color: #5b7860;
  font-size: 1.4rem;
}

.btn {
  background-color: transparent;
  border: 2px solid #5b7860;
  color: #5b7860;
  border-radius: 30px;
  padding: 0.5rem 1.25rem;
  transition: background-color 0.3s ease;
}

.btn:hover {
  background-color: #5b7860;
  color: #fff;
}

footer {
  background-color: #f3f7f5;
  text-align: center;
  padding: 1rem;
  font-size: 0.875rem;
  color: #5b7860;
  margin-top: 2rem;
}

iframe {
  border-radius: 8px;
}

a {
  color: #5b7860;
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

.card-img-top {
  width: 100%;
  height: 100%;
  object-fit: cover;  /* or 'contain' if you prefer */
  display: block;
}

/* Carousel Controls */
.carousel-control-prev,
.carousel-control-next {
  width: 5%;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.75;
  transition: opacity 0.3s ease;
  z-index: 10;
}

.carousel-control-prev:hover,
.carousel-control-next:hover {
  opacity: 1;
}

.carousel-control-prev {
  left: -3%;
}

.carousel-control-next {
  right: -3%;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
  background-color: #5b7860;
  border-radius: 50%;
  padding: 0.75rem;
  background-size: 60% 60%;
  padding: 0.4rem; /* smaller carousel nav buttons */
}

#products {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.card-body {
  padding: 1rem;
}

.card-text {
  font-size: 0.95rem;
  line-height: 1.4;
}

.sold-out-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(90, 100, 90, 0.75);
  color: #fff;
  font-size: 2.5rem;
  font-family: 'Lora', serif;
  font-weight: 600;
  padding: 0.75rem 2.5rem;
  border-radius: 18px;
  z-index: 2;
  text-align: center;
  box-shadow: 0 2px 14px rgba(0,0,0,0.12);
  pointer-events: none;
}
.card-img-wrapper {
  width: 100%;
  aspect-ratio: 4 / 3;  /* or 1 / 1 for square, 3 / 4 for portrait */
  overflow: hidden;
  position: relative;
  background: #eee;
}
.card-img-top.sold-out {
  filter: grayscale(1) brightness(0.86);
  opacity: 0.83;
}

/* Override Bootstrap primary button to match site palette */
.btn-primary {
  background-color: #5b7860 !important;
  border-color: #5b7860 !important;
  color: #fff !important;
}
.btn-primary:hover {
  background-color: #90a29c !important;
  border-color: #90a29c !important;
  color: #fff !important;
}

/* --- Subscription typography cleanup --- */
.section-lead {
  font-size: 1.125rem;      /* ~18px */
  line-height: 1.75;
  color: #2a2a2a;
}

/* Consistent subhead look (“Delivery Area”, “How It Works”, etc.) */
h3.subhead {
  font-family: 'Lora', serif;
  font-weight: 700;
  font-size: 1.375rem;      /* ~22px */
  color: #5b7860;
  margin-top: 1.75rem;
  margin-bottom: 0.5rem;
}

/* A lighter hr for section breaks inside the subscription block */
.hr-thin {
  margin: 1.25rem 0;
  border: 0;
  border-top: 1px solid rgba(91, 120, 96, 0.18);
}

/* Fine print under the button */
.fineprint {
  color: #6a7a74;
  font-size: 0.9rem;
}

/* Subtle inline disclaimer styling */
.disclaimer {
  background: #f3f7f5;
  border-left: 4px solid #90a29c;
  padding: 0.75rem 1rem;
  border-radius: 6px;
  color: #3e4a45;
  font-size: 0.95rem;
}

/* Harmonize section typography & spacing */
.section {
  max-width: 960px;
  margin-left: auto;
  margin-right: auto;
}

/* Unify paragraph and list text inside content sections */
.section p,
.section li {
  font-size: 1.0625rem; /* ~17px */
  line-height: 1.7;
  color: #2a2a2a;
}

.section ul {
  padding-left: 1.2rem;
  margin-bottom: 0.75rem;
}

/* Unify the main section title look inside content sections */
.section h2 {
  font-family: 'Great Vibes', cursive;
  color: #5b7860;
  font-size: 2.4rem;
  margin-bottom: 1rem;
}

/* Tighten subheads slightly to reduce jumps between sizes */
.section h3.subhead {
  font-size: 1.25rem; /* ~20px */
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

/* Lead paragraphs just a hair larger than body */
.section .section-lead {
  font-size: 1.125rem;
}

/* Keep disclaimer and fine print consistent inside sections */
.section .disclaimer { font-size: 0.95rem; }
.section .fineprint { font-size: 0.9rem; }