:root {
  --sv-green: #1f4d36;
  --sv-green-dark: #163828;
  --sv-gold: #c8a24a;
  --sv-gold-dark: #9a7a2f;
  --sv-cream: #f6f1e7;
  --sv-paper: #fffaf2;
  --sv-text: #2a241b;
  --sv-white: #ffffff;
  --sv-border: rgba(31, 77, 54, 0.15);
  --sv-shadow: 0 10px 28px rgba(0, 0, 0, 0.12);

  --primary: #1f4d36;
  --accent: #c8a24a;
  --bg: #f6f1e7;
  --text: #2a241b;
  --header-bg: #163828;
  --surface: rgba(255, 250, 242, 0.96);
  --surface-soft: rgba(255, 248, 238, 0.92);
  --border-soft: rgba(200, 162, 74, 0.22);
  --header-text: #fff8e8;
  --footer-text: rgba(255, 248, 232, 0.92);
  --hero-overlay-1: rgba(18, 45, 32, 0.78);
  --hero-overlay-2: rgba(31, 77, 54, 0.58);
  --hero-overlay-3: rgba(31, 77, 54, 0.10);
}

body.site {
  background: linear-gradient(to bottom, #f8f4ec 0%, #f2eadb 100%);
  color: var(--sv-text);
  font-family: Georgia, "Times New Roman", serif;
}

.site-header {
  background: linear-gradient(135deg, var(--sv-green-dark), var(--sv-green));
  color: var(--sv-white);
  border-bottom: 3px solid var(--sv-gold);
  box-shadow: 0 3px 12px rgba(0, 0, 0, 0.16);
}

.brand__logo {
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.brand__title,
.brand__subtitle,
.menu-horizontal a {
  color: var(--sv-white);
}

.menu-horizontal a:hover,
.menu-horizontal a:focus-visible,
.menu-horizontal .current > a {
  color: #f6e3a8;
}

.hero::after {
  background: linear-gradient(90deg, var(--hero-overlay-1) 0%, var(--hero-overlay-2) 35%, var(--hero-overlay-3) 75%);
}

.hero-content h1,
.hero-content h1 * {
  font-family: Georgia, "Times New Roman", serif;
  color: #fff8e8;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.35);
  letter-spacing: 0.3px;
}

.hero-content p,
.hero-content p * {
  color: rgba(255, 255, 255, 0.94);
}

.hero-cta a,
.hero-cta .btn,
.hero-cta button,
.hero-button,
.btn,
button,
input[type="submit"],
a.btn,
.readmore a {
  background: linear-gradient(180deg, var(--sv-gold), var(--sv-gold-dark));
  color: #1f1a12;
  border: 1px solid rgba(122, 92, 28, 0.55);
  border-radius: 8px;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.16);
  font-weight: 700;
}

.hero-cta a:hover,
.hero-cta .btn:hover,
.hero-cta button:hover,
.hero-button:hover,
.btn:hover,
button:hover,
input[type="submit"]:hover,
a.btn:hover,
.readmore a:hover {
  background: linear-gradient(180deg, #d9b663, #b48934);
  color: #18130c;
  text-decoration: none;
}

.hero-menu {
  background: linear-gradient(135deg, var(--sv-green-dark), var(--sv-green));
  border-bottom: 2px solid var(--sv-gold);
}

.menu-horizontal li > ul,
.menu-horizontal .mod-menu__sub {
  background: #204d37;
}

.card,
.tile-card,
.list-card,
.contact-card,
.component-section .container {
  background: var(--sv-paper);
  border: 1px solid rgba(200, 162, 74, 0.18);
  box-shadow: var(--sv-shadow);
}

.home-block h2,
.mod_events_latest_table td:last-child a {
  color: var(--sv-green-dark);
  font-family: Georgia, "Times New Roman", serif;
}

.home-block h2::after {
  content: "";
  display: block;
  width: 70px;
  height: 3px;
  margin-top: 8px;
  background: linear-gradient(to right, var(--sv-gold), transparent);
  border-radius: 2px;
}

.gallery-auto img,
.tile-card img,
.com-content-article img,
.article-content img {
  border-bottom: 1px solid rgba(200, 162, 74, 0.18);
}

.gallery img,
.mod-custom img,
.com-content-article img {
  border-radius: 8px;
  border: 2px solid rgba(200, 162, 74, 0.28);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.gallery img:hover,
.mod-custom img:hover,
.com-content-article img:hover {
  transform: scale(1.02);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.18);
}

.contact-card address,
.component-section .container,
.com-content-article,
.page-content,
.main-content {
  color: var(--sv-text);
}

a {
  color: var(--sv-green);
}

a:hover {
  color: var(--sv-gold-dark);
}

input[type="text"],
input[type="email"],
input[type="tel"],
textarea,
select {
  background: #fffdf8;
  border: 1px solid rgba(31, 77, 54, 0.22);
  border-radius: 6px;
  color: var(--sv-text);
  padding: 10px 12px;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--sv-gold);
  box-shadow: 0 0 0 3px rgba(200, 162, 74, 0.15);
}

table {
  width: 100%;
  border-collapse: collapse;
  background: rgba(255, 255, 255, 0.78);
}

table th {
  background: var(--sv-green);
  color: white;
}

table th,
table td {
  padding: 12px;
  border: 1px solid rgba(31, 77, 54, 0.15);
}

.site-footer,
footer {
  background: linear-gradient(135deg, #122d20, #1b4330);
  color: rgba(255, 255, 255, 0.9);
  border-top: 3px solid var(--sv-gold);
}

.site-footer a,
footer a {
  color: #f0d78a;
}

.site-footer a:hover,
footer a:hover {
  color: #fff3c7;
}

.hr-gold,
.divider-gold {
  height: 2px;
  background: linear-gradient(to right, transparent, var(--sv-gold), transparent);
  border: 0;
}

@media (max-width: 860px) {
  .hero-content h1,
  .hero-content h1 * {
    font-size: 2.5rem;
  }

  .hero-content p,
  .hero-content p * {
    font-size: 1.15rem;
  }
}
