/* Healing Within Palette-Driven CSS */
:root {
  --color-bg-light: #f6f7f9; /* soft, modern off-white */
  --color-bg-medium: #dbe6e4; /* gentle, airy blue-gray */
  --color-bg-accent: #6a8caf; /* professional, calming blue */
  --color-bg-gradient: linear-gradient(135deg, #f6f7f9 0%, #dbe6e4 100%);
  --color-banner-gradient: linear-gradient(120deg, #dbe6e4 0%, #6a8caf 100%);
  --color-text-dark: #2c2e3a; /* deep slate for text */
  --color-text-medium: #4e6e8e; /* muted blue for secondary text */
}
body {
  background: var(--color-bg-gradient);
  color: var(--color-text-dark);
  font-family: 'Montserrat', 'Quicksand', Arial, sans-serif;
}
header {
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.04);
  padding: 1.5rem 0 1rem 0;
  text-align: center;
}
header h1 {
  margin: 0;
}
nav a {
  color: var(--color-bg-accent);
  text-decoration: none;
  margin: 0 1rem;
  font-weight: 500;
  transition: color 0.2s;
}
nav a:hover {
  color: var(--color-text-medium);
}
.banner {
  width: 100vw;
  max-width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
  padding: 4rem 0 3rem 0;
  text-align: center;
  background: var(--color-banner-gradient);
  border-radius: 0;
  box-shadow: none;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.banner-hero {
  background: linear-gradient(120deg, #e3e0d3 0%, #b8d8d8 100%);
}
.banner-about {
  background: linear-gradient(90deg, #f7f6f2 0%, #e3e0d3 100%);
}
.banner-services {
  background: linear-gradient(90deg, #b8d8d8 0%, #f7f6f2 100%);
}
.banner-how {
  background: linear-gradient(120deg, #e3e0d3 0%, #b8d8d8 100%);
}
.banner-faq {
  background: linear-gradient(90deg, #f7f6f2 0%, #b8d8d8 100%);
}
.banner-cta {
  background: linear-gradient(90deg, #b8d8d8 0%, #e3e0d3 100%);
}
.banner h2, h2 {
  font-size: 2.2rem;
  color: var(--color-bg-accent);
  margin-bottom: 1.2rem;
  font-weight: 700;
}
.banner p, .banner .hero-lead {
  font-size: 1.2rem;
  color: var(--color-text-medium);
  margin-bottom: 2rem;
  max-width: 700px;
}
.btn-primary {
  background-color: var(--color-bg-accent);
  border-color: var(--color-bg-accent);
  color: var(--color-text-dark);
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--color-bg-medium);
  border-color: var(--color-bg-medium);
  color: var(--color-text-dark);
}
.btn-outline-primary {
  color: var(--color-text-dark);
  border-color: var(--color-bg-accent);
}
.btn-outline-primary:hover, .btn-outline-primary:focus {
  background-color: var(--color-bg-accent);
  color: var(--color-text-dark);
}
.cta {
  display: inline-block;
  margin-top: 1.5rem;
  padding: 0.75rem 2rem;
  background: var(--color-bg-accent);
  color: #fff;
  border-radius: 24px;
  font-size: 1.1rem;
  text-decoration: none;
  box-shadow: 0 2px 8px rgba(106,140,175,0.10);
  transition: background 0.2s;
}
.cta:hover {
  background: var(--color-text-medium);
}
footer {
  background: var(--color-bg-accent);
  color: #fff;
  text-align: center;
  padding: 1.5rem 0 1rem 0;
  margin-top: 2rem;
  font-size: 1rem;
  border-top-left-radius: 16px;
  border-top-right-radius: 16px;
}
footer p {
  margin: 0.5rem 0;
}
.about-img {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 2px 12px rgba(106,140,175,0.12);
  border: 4px solid var(--color-bg-accent);
  margin-bottom: 1.5rem;
}
.services-list h3, .faq-list h3, .service-card h3 {
  color: var(--color-bg-accent);
  font-size: 1.15rem;
  font-weight: 700;
}
blockquote {
  font-style: italic;
  background: var(--color-bg-accent);
  border-left: 4px solid var(--color-bg-accent);
  margin: 1.5rem 0;
  padding: 1rem 1.5rem;
  border-radius: 8px;
  color: var(--color-text-dark);
}
cite {
  display: block;
  margin-top: 0.5rem;
  color: var(--color-text-medium);
  font-weight: 500;
}
/* Add more palette-driven rules as needed for other sections/components */
