:root {
  --primary: #D4AF37;
  --secondary: #F5F5DC;
  --background: #FFFFFF;
  --footer-bg: #556B2F;
  --button: #D4AF37;
  --section-bg-1: #F5F5DC;
  --section-bg-2: #E8E8E8;
  --section-bg-3: #D4AF37;
  --section-bg-4: #556B2F;
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Montserrat', sans-serif;
  --texture-wood: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiPjxyZWN0IHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9IiNGNUY1QkMiLz48cGF0aCBkPSJNMCAwTDEwMCAxMDAiIHN0cm9rZT0iI0Q0QUYzNyIgc3Ryb2tlLXdpZHRoPSIxIiBzdHJva2Utb3BhY2l0eT0iMC4xIi8+PHBhdGggZD0iTTEwMCAwTDAgMTAwIiBzdHJva2U9IiNENEFGMzciIHN0cm9rZS13aWR0aD0iMSIgc3Ryb2tlLW9wYWNpdHk9IjAuMSIvPjwvc3ZnPg==');
  --texture-stone: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiPjxyZWN0IHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIGZpbGw9IiNFOEU4RTgiLz48Y2lyY2xlIGN4PSIxMCUiIGN5PSIxMCUiIHI9IjIlIiBmaWxsPSIjRjVGNUIjIiBvcGFjaXR5PSIwLjMiLz48Y2lyY2xlIGN4PSIzMCUiIGN5PSI3MCUiIHI9IjMlIiBmaWxsPSIjRjVGNUIjIiBvcGFjaXR5PSIwLjMiLz48Y2lyY2xlIGN4PSI3MCUiIGN5PSIzMCUiIHI9IjQlIiBmaWxsPSIjRjVGNUIjIiBvcGFjaXR5PSIwLjMiLz48L3N2Zz4=');
}

body {
  font-family: var(--font-body);
  background-color: var(--background);
  color: #333;
  line-height: 1.8;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-bottom: 1.5rem;
  color: var(--primary);
}

h1 {
  font-size: 2.5rem;
  line-height: 1.2;
}

h2 {
  font-size: 2rem;
}

p {
  margin-bottom: 1.5rem;
}

a {
  color: var(--primary);
  text-decoration: none;
  transition: all 0.3s ease;
}

a:hover {
  color: darken(var(--primary), 10%);
  text-decoration: underline;
}

.btn {
  display: inline-block;
  padding: 0.8rem 1.8rem;
  background-color: var(--button);
  color: white;
  border-radius: 0;
  font-family: var(--font-heading);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.3s ease;
  border: 2px solid var(--button);
}

.btn:hover {
  background-color: transparent;
  color: var(--button);
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.section {
  padding: 5rem 0;
}

.section-bg-1 {
  background-color: var(--section-bg-1);
  background-image: var(--texture-wood);
}

.section-bg-2 {
  background-color: var(--section-bg-2);
  background-image: var(--texture-stone);
}

.section-bg-3 {
  background-color: var(--section-bg-3);
  color: white;
}

.section-bg-4 {
  background-color: var(--section-bg-4);
  color: white;
}

.card {
  background-color: white;
  border-radius: 0;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
}

footer {
  background-color: var(--footer-bg);
  color: white;
  padding: 3rem 0;
}

footer a {
  color: white;
}

footer a:hover {
  color: var(--primary);
}

.navbar {
  background-color: transparent;
  transition: all 0.3s ease;
}

.navbar.scrolled {
  background-color: white;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

@media (max-width: 768px) {
  h1 {
    font-size: 2rem;
  }
  
  .section {
    padding: 3rem 0;
  }
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.fade-in {
  animation: fadeIn 0.8s ease forwards;
}