:root {
  --site-green: #05bd6b;
  --site-gold: #fca311;
  --site-brown: #7e4a13;
  --site-ink: #24150d;
  --site-soft: #fffaf1;
}

body {
  text-rendering: optimizeLegibility;
}

.section-title,
.mbr-section-title,
.history-title,
.contact-subtitle,
.month-header,
.gallery-section h2,
.album-intro h1,
.hero-section h1 {
  letter-spacing: 0;
}

.section-subtitle,
.mbr-section-subtitle,
.page-support-text,
.history-hero p,
.contact-text,
.location-house-copy p,
.gallery-section p {
  color: #5a4737;
  font-weight: 700;
  line-height: 1.7;
}

.page-support-text {
  max-width: 760px;
  margin: 0.75rem auto 0;
  font-size: 1.08rem;
}

.page-support-text strong {
  color: var(--site-brown);
}

.album-intro,
.gallery-section,
.contact-section,
#contacts3-18,
.history-content,
.container.mt-5 {
  scroll-margin-top: 105px;
}

.album-intro,
.gallery-section,
.contact-section,
#contacts3-18 {
  position: relative;
}

.album-intro::before,
.gallery-section::before,
.contact-section::before,
#contacts3-18::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 0%, rgba(252, 163, 17, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(255, 250, 241, 0.55), rgba(255, 255, 255, 0));
}

.album-intro > .container,
.gallery-section > .container,
.contact-section > .container,
#contacts3-18 > .container {
  position: relative;
  z-index: 1;
}

.history-card,
.contact-card,
.location-house-card,
.month-card,
.gallery-item,
.gallery a,
.card {
  border-radius: 14px !important;
  border-color: rgba(126, 74, 19, 0.12) !important;
  box-shadow: 0 18px 42px rgba(64, 38, 18, 0.1) !important;
}

.history-image,
.profile-img,
.contact-image,
.location-house-photo img,
.gallery-img-container img,
.gallery-item img,
.gallery a img,
.carousel-inner img {
  filter: saturate(1.06) contrast(1.04);
}

.history-image,
.contact-image,
.gallery-img-container img,
.gallery-item img,
.gallery a img {
  object-fit: cover;
}

.gallery-img-container,
.location-house-photo,
.profile-img,
.history-image {
  background: #f7efe5;
}

.gallery-overlay {
  background: linear-gradient(180deg, transparent 0%, rgba(20, 11, 6, 0.86) 100%) !important;
  color: #ffffff !important;
  font-weight: 900;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.5);
}

.gallery-category,
.badge-custom,
.location-house-note {
  letter-spacing: 0;
}

.album-filter button,
.btn-primary,
.btn-home {
  font-weight: 900;
}

.event-list li {
  align-items: flex-start;
  gap: 0.65rem;
}

.event-date {
  flex: 0 0 auto;
}

.event-desc {
  line-height: 1.45;
}

.contact-card,
.location-house-card {
  overflow: hidden;
}

.contact-image {
  min-height: 420px;
}

.location-house-photo img {
  padding: 0.35rem;
}

.history-card {
  background: rgba(255, 255, 255, 0.96) !important;
}

.history-copy p,
.contact-text,
.location-house-copy p {
  font-size: 1.08rem;
}

@media (max-width: 768px) {
  .contact-image {
    min-height: 320px;
  }

  .section-subtitle,
  .mbr-section-subtitle,
  .page-support-text,
  .history-hero p,
  .contact-text,
  .location-house-copy p {
    font-size: 1rem;
  }

  .history-card,
  .contact-card,
  .location-house-card,
  .month-card,
  .gallery-item,
  .gallery a {
    border-radius: 12px !important;
  }
}
