@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;600;700&family=Playfair+Display:ital,wght@0,600;0,700;1,600&display=swap');

:root {
  /* Emerald & Charcoal Palette */
  --primary-color: #10B981; /* Emerald 500 */
  --secondary-color: #047857; /* Emerald 700 */
  --accent-color: #34D399; /* Emerald 400 */
  --light-color: #ECFDF5; /* Emerald 50 */
  --dark-color: #1F2937; /* Gray 800 */
  --gradient-primary: linear-gradient(135deg, #059669 0%, #10B981 100%);
  --hover-color: #059669; /* Emerald 600 */
  --background-color: #FAFAF9; /* Stone 50 */
  --text-color: #4B5563; /* Gray 600 */
  --border-color: rgba(16, 185, 129, 0.2);
  --divider-color: rgba(31, 41, 55, 0.1);
  --shadow-color: rgba(16, 185, 129, 0.15);
  
  /* Fonts */
  --main-font: 'Nunito', sans-serif;
  --alt-font: 'Playfair Display', serif;
}

body {
  font-family: var(--main-font);
  background-color: var(--background-color);
  color: var(--text-color);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--alt-font);
  color: var(--dark-color);
  letter-spacing: -0.02em;
}

/* Custom Tailwind Overrides & Utilities */
.text-primary { color: var(--primary-color); }
.text-secondary { color: var(--secondary-color); }
.text-accent { color: var(--accent-color); }
.bg-primary { background-color: var(--primary-color); }
.bg-secondary { background-color: var(--secondary-color); }
.bg-light { background-color: var(--light-color); }
.bg-dark { background-color: var(--dark-color); }

.gradient-bg {
  background: var(--gradient-primary);
}

.btn-primary {
  background-color: var(--secondary-color);
  color: #FFFFFF;
  transition: all 0.3s ease;
  border-radius: 9999px; /* Pill shape */
  font-weight: 700;
  font-family: var(--main-font);
  box-shadow: 0 4px 14px 0 var(--shadow-color);
}

.btn-primary:hover {
  background-color: var(--dark-color);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(31, 41, 55, 0.2);
}

/* Cookie Banner (JS Version) */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: var(--dark-color);
  color: #F3F4F6;
  padding: 1.25rem 2rem;
  text-align: center;
  z-index: 9999;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.15);
  border-top: 4px solid var(--primary-color);
}

.cookie-btn {
  cursor: pointer;
  padding: 0.6rem 2rem;
  margin: 0.25rem 0.5rem;
  background-color: var(--primary-color);
  color: #ffffff;
  border-radius: 9999px;
  border: none;
  display: inline-block;
  font-weight: 700;
  font-family: var(--main-font);
  transition: all 0.2s ease;
}

.cookie-btn:hover {
  background-color: var(--accent-color);
}

.cookie-btn-alt {
  background-color: transparent;
  color: #D1D5DB;
  border: 1px solid #6B7280;
}

.cookie-btn-alt:hover {
  background-color: #374151;
  color: #FFFFFF;
}