:root {
  /* Palette: #337357, #5CB338, #FEFAE0, #5F6F52 */
  --primary-color: #337357;
  --secondary-color: #24523E;
  --accent-color: #5CB338;
  --light-color: #FEFAE0;
  --dark-color: #1A281F;
  --gradient-primary: linear-gradient(180deg, #5CB338 0%, #337357 100%);
  --hover-color: #285A44;
  --background-color: #F9F9F4;
  --text-color: #2D3A30;
  --border-color: rgba(51, 115, 87, 0.3);
  --divider-color: rgba(92, 179, 56, 0.2);
  --shadow-color: rgba(26, 40, 31, 0.15);
  --highlight-color: #D35400; /* Burnt Orange for contrast */
  --main-font: 'Lato', sans-serif;
  --heading-font: 'Lora', serif;
}

body {
    font-family: var(--main-font);
    color: var(--text-color);
    background-color: var(--background-color);
}
h1, h2, h3, h4 { font-family: var(--heading-font); }

.bg-organic {
    background-image: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23337357' fill-opacity='0.08'%3E%3Cpath d='M50 50c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10s-10-4.477-10-10 4.477-10 10-10zM10 10c0-5.523 4.477-10 10-10s10 4.477 10 10-4.477 10-10 10c0 5.523-4.477 10-10 10S0 25.523 0 20s4.477-10 10-10zm10 8c4.418 0 8-3.582 8-8s-3.582-8-8-8-8 3.582-8 8 3.582 8 8 8zm40 40c4.418 0 8-3.582 8-8s-3.582-8-8-8-8 3.582-8 8 3.582 8 8 8z' /%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}