  body {
      font-family: 'Comic Sans MS', 'Arial', sans-serif;
      margin: 0;
      padding: 0;
      display: flex;
      flex-direction: column;
      min-height: 100vh;
      background-color: #f9ecf5;
  }

  header,
  footer,
  section,
  .ul-services {
      background: #fff;
      margin: 0.5rem;
      padding: 2rem;
      border-radius: 8px;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  }

  header {
      text-align: center;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 10px;
  }

  .title {
      font-family: 'Georgia', serif;
      font-size: 48px;
      color: #6c38a7;
      text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  }

  .title-2 {
      font-family: 'Georgia', serif;
      font-size: 36px;
      color: #6c38a7;
      text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  }

  .content {
      flex: 1;
      padding: 1rem;
  }

  .body-sections {
      text-align: center;
  }

  h2 {
      color: #333;
  }

  p {
      color: #666;
  }

  .services-list,
  .prices-list {
      list-style: none;
      padding: 0;
  }

  .services-list li,
  .prices-list li {
      background: #f9f9f9;
      margin: 0.5rem 0;
      padding: 0.5rem;
      border-radius: 4px;
  }

  .social-media {
      text-align: center;
  }

  .social-media img {
      height: 40px;
      width: 40px;
      margin: 0 10px;
  }

  .pawprint {
      height: 25px;
      display: inline;
  }

  .container {
      display: flex;
      flex-wrap: wrap;
  }

  .box {
      background: #fff;
      margin: 0.5rem;
      padding: 2rem;
      border-radius: 8px;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  }

  .sm-box {
      flex: 0 0 15%;
  }

  .md-box {
      flex: 0 0 40%;
  }

  .lg-box {
      flex: 0 0 44%;
  }

  .modal {
      display: none;
      position: fixed;
      z-index: 1;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%;
      overflow: auto;
      background-color: rgba(0, 0, 0, 0.4);
  }

  .modal-content {
      background-color: #f9ecf5;
      margin: 15% auto;
      padding: 20px;
      border: 1px solid #888;
      width: 80%;
  }

  .span-service-cost {
      padding-left: 5px;
  }

  .modal-close {
      color: #aaa;
      float: right;
      font-size: 28px;
      font-weight: bold;
  }

  .modal-close:hover,
  .modal-close:focus {
      color: black;
      text-decoration: none;
      cursor: pointer;
  }

  .carousel {
      display: flex;
      overflow: hidden;
      /* Hide overflowing slides */
      width: 100%;
      /* Adjust as needed */
  }

  .slide {
      flex: 0 0 20%;
      /* Each slide takes up 50% width */
      box-sizing: border-box;
      transition: transform 0.3s ease;
      /* Smooth slide transition */
  }

  .slide img {
      width: 290px;
  }

  .no-slide img {
      width: 390px;
      padding-right: 5px;
  }

  .nav {
      width: 245px;
      background: #fff;
      margin: 0.5rem;
      border-radius: 8px;
      box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
      left: 0px;
      position: fixed;
      top: 0px;
      height: 100%;
      overflow-x: hidden;
      transition: 0.3s;
  }

  .nav a {
      padding: 15px;
      text-decoration: none;
      color: #000000;
      display: block;
      transition: 0.2s;
  }

  .nav a:hover {
      background-color: #f9ecf5;
  }

  .hamburger {
      display: none;
      cursor: pointer;
      position: fixed;
  }

  article {
      margin-left: 250px;
  }

  .graphic-border {
      width: 200px;
      padding: 1px;
      border: 1px solid #e692ee;
      background-color: #053761;
  }

  .hero {
      background-image: url('graphics/bubbles.png');
      height: 30vh;
      background-position: center;
      background-repeat: no-repeat;
      background-size: cover;
      position: relative;
  }

  .hero-txt {
      text-align: center;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      color: #6c38a7;
      font-size: 2.5em;
      background-color: rgba(228, 220, 220, 0.5);
      /* Optional: adds a semi-transparent background to the text */
      padding: 20px;
      border-radius: 10px;
      font-family: 'Georgia', serif;
      text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  }

  .img-lg {
      /* padding: 1px;
      border: 1px solid #e692ee;
      background-color: #053761; */
      max-width: 900px;
  }

  .img-md {
      /* padding: 1px;
      border: 1px solid #e692ee;
      background-color: #053761; */
      max-width: 450px;
  }

  .slide-in {
      position: relative;
      animation: slideIn 1s ease-out forwards;
      opacity: 0;
  }

.reviews-section { margin: 2em auto; max-width: 900px; text-align: center; }
.reviews-title { margin-bottom: 1em; font-size: 1.5em; }
.reviews-carousel { display: flex; align-items: center; justify-content: center; position: relative; }
.carousel-arrow { background: none; border: none; font-size: 2em; cursor: pointer; display: none; }
.carousel-track { display: flex; gap: 1em; overflow: visible; width: 100%; justify-content: center; }
.review-slide { background: #f8f8f8; border-radius: 10px; padding: 1.2em 1em; min-width: 250px; max-width: 320px; box-shadow: 0 2px 8px rgba(0,0,0,0.07); flex: 0 0 100%; transition: transform 0.3s; }
.review-author { display: block; margin-top: 0.7em; font-size: 0.95em; color: #555; }


  @keyframes slideIn {
      from {
          transform: translateX(-100%);
          opacity: 0;
      }

      to {
          transform: translateX(0);
          opacity: 1;
      }
  }


  /* Responsive design */
@media (min-width: 600px) {
    .carousel-track { gap: 1.5em; }
    .review-slide { flex: 0 0 48%; }
}
@media (min-width: 900px) {
    .review-slide { flex: 0 0 32%; }
    .carousel-arrow { display: none !important; }
}
@media (max-width: 899px) {
    .carousel-arrow { display: block; }
}
  
  @media (max-width: 600px) {

      header,
      footer,
      section {
          margin: 0.5rem;
          padding: 1rem;
      }

      .box,
      .md-box,
      .sm-box {
          flex: 0 0 100%;
      }

      .hamburger {
          display: block;
          z-index: 2;
      }

      .nav {
          left: -250px;
          z-index: 1;
      }

      .nav-home {
          padding-left: 25px !important;
      }

      article {
          margin-left: 0px;
      }

      header {
          flex-direction: column;
          text-align: center;
      }

      header img {
          max-width: 100%;
          margin-bottom: 10px;
      }

      .container {
          max-width: min-content;
      }

      .img-lg {
          max-width: 100%;
      }

      .img-md {
          max-width: 100%;
      }

  }