/* ===================================
   UTILITIES
   Utility classes, accessibility, and base section styles for the dsite theme
   =================================== */

/* ===================================
   SECTIONS
   =================================== */
.about-section,
.services-section,
.testimonials-section,
.appointment-section {
  padding: 4rem 0;
}

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

.services-section {
  background-color: var(--background-light);
}

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

.appointment-section {
  background-color: var(--background-light);
}

section h2 {
  text-align: center;
  font-size: 2.5rem;
  margin-bottom: 1rem;
}

.section-description {
  text-align: center;
  font-size: 1.1rem;
  color: var(--text-light);
  margin-bottom: 3rem;
}

/* ===================================
   UTILITY CLASSES
   =================================== */
.text-center {
  text-align: center;
}

.mt-1 {
  margin-top: 0.5rem;
}
.mt-2 {
  margin-top: 1rem;
}
.mt-3 {
  margin-top: 1.5rem;
}
.mt-4 {
  margin-top: 2rem;
}

.mb-1 {
  margin-bottom: 0.5rem;
}
.mb-2 {
  margin-bottom: 1rem;
}
.mb-3 {
  margin-bottom: 1.5rem;
}
.mb-4 {
  margin-bottom: 2rem;
}

/* ===================================
   ACCESSIBILITY
   =================================== */
.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

.screen-reader-text:focus {
  background-color: var(--background-light);
  border-radius: var(--border-radius);
  box-shadow: var(--shadow);
  clip: auto !important;
  color: var(--text-dark);
  display: block;
  font-size: 0.875rem;
  font-weight: bold;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}
