@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

:root {
  --color-forest: #2D4739;
  --color-sage: #7A9E7E;
  --color-cream: #FAF7F2;
  --color-stone: #E8E2D9;
  --color-terra: #C4754B;
  --color-dark: #2B2B2B;
  --color-light: #FEFEFE;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', sans-serif;
  background-color: var(--color-cream);
  color: var(--color-dark);
}

h1,
h2,
h3,
h4,
h5,
h6,
.font-serif {
  font-family: 'Playfair Display', serif;
}

/* Reviews Marquee */
.animate-marquee {
  display: flex;
  width: max-content;
  animation: marquee 40s linear infinite;
}

.animate-marquee>a {
  flex-shrink: 0;
}

.animate-marquee:hover {
  animation-play-state: paused;
}

@keyframes marquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(calc(-50% - 1.5rem));
  }
}

/* Animations */
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fade-in-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Organic Shapes */
.shape-pill {
  border-radius: 500px;
}

.shape-organic-1 {
  border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%;
}

.shape-organic-2 {
  border-radius: 40% 60% 70% 30% / 40% 50% 60% 50%;
}

.shape-organic-3 {
  border-radius: 50% 50% 30% 70% / 50% 50% 70% 30%;
}

.shape-organic-4 {
  border-radius: 60% 40% 50% 50% / 40% 40% 60% 60%;
}

.bg-forest {
  background-color: var(--color-forest);
}

.bg-sage {
  background-color: var(--color-sage);
}

.bg-cream {
  background-color: var(--color-cream);
}

.bg-stone {
  background-color: var(--color-stone);
}

.bg-terra {
  background-color: var(--color-terra);
}

.text-forest {
  color: var(--color-forest);
}

.text-sage {
  color: var(--color-sage);
}

.text-cream {
  color: var(--color-cream);
}

.text-stone {
  color: var(--color-stone);
}

.text-terra {
  color: var(--color-terra);
}

/* Custom button */
.btn-primary {
  background-color: var(--color-terra);
  color: var(--color-light);
  padding: 0.75rem 1.75rem;
  border-radius: 500px;
  font-weight: 500;
  transition: background-color 0.3s ease, transform 0.2s ease, box-shadow 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-primary:hover {
  background-color: #a8623e;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(196, 117, 75, 0.3);
}

.btn-secondary {
  background-color: var(--color-forest);
  color: var(--color-light);
  padding: 0.75rem 1.75rem;
  border-radius: 500px;
  font-weight: 500;
  transition: background-color 0.3s ease, transform 0.2s ease, box-shadow 0.2s ease;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.btn-secondary:hover {
  background-color: #1e3026;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(45, 71, 57, 0.3);
}

/* Service Cards */
.service-card {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.service-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 20px 40px rgba(45, 71, 57, 0.1);
}

.service-card img {
  transition: transform 0.7s cubic-bezier(0.4, 0, 0.2, 1);
}

.service-card:hover img {
  transform: scale(1.05);
}

/* Form Inputs */
.input-minimal {
  width: 100%;
  background: transparent;
  border: none;
  border-bottom: 2px solid var(--color-stone);
  padding: 1rem 0;
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  color: var(--color-dark);
  transition: border-color 0.3s ease;
}

.input-minimal:focus {
  outline: none;
  border-bottom-color: var(--color-forest);
}

.input-minimal::placeholder {
  color: #9CA3AF;
}