.hero-section-banner {
  display: flex;
  flex-direction: column;
  position: relative;
  min-height: 450px;
  align-items: center;
  color: #fff;
  text-align: center;
  justify-content: end;
  padding: 0;
  font: 500 40px / 1.4 Playfair Display , -apple-system , Roboto , Helvetica , sans-serif; }
  .hero-section-banner .hero-background-image {
    position: absolute;
    inset: 0;
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: top; }
  .hero-section-banner .hero-content-wrapper {
    position: relative;
    display: flex;
    max-width: 100%;
    width: 100%;
    flex-direction: column;
    align-items: center;
    justify-content: end;
    padding: 35px 24px;
    background: rgba(0, 0, 0, 0.1);
    height: 450px; }
    .hero-section-banner .hero-content-wrapper .hero-content-container {
      width: 800px;
      max-width: 100%; }
      .hero-section-banner .hero-content-wrapper .hero-content-container .hero-title {
        margin: 0;
        font-weight: inherit;
        font-size: inherit;
        line-height: inherit;
        font-family: inherit;
        color: #ffffff; }
        @media (max-width: 991px) {
          .hero-section-banner .hero-content-wrapper .hero-content-container .hero-title {
            max-width: 100%; } }

/****/
.garden-story-section {
  display: flex;
  flex-direction: column;
  position: relative;
  align-items: stretch;
  color: #800020;
  text-align: center;
  justify-content: center;
  padding: 48px 0px;
  font: 500 20px / 40px 'Playfair Display' , -apple-system , Roboto , Helvetica , sans-serif; }
  .garden-story-section .background-image {
    position: absolute;
    inset: 0;
    height: 100%;
    width: 100%;
    object-fit: cover;
    object-position: center; }
  .garden-story-section .content-wrapper {
    position: relative;
    width: 100%; }
    .garden-story-section .content-wrapper .story-text {
      margin: 0;
      font-weight: 500;
      font-size: 18px;
      line-height: 40px;
      color: #800020;
      font-family: "Roboto", sans-serif !important; }
  @media (max-width: 991px) {
    .garden-story-section .content-wrapper {
      max-width: 100%; }
    .garden-story-section .story-text {
      max-width: 100%;
      font-size: 15px !important; } }

/****/
.featured-services-container {
  display: flex;
  width: 100%;
  padding-bottom: 64px;
  flex-direction: column;
  align-items: center;
  gap: -88px;
  position: relative;
  margin: 0 auto; }
  @media (max-width: 991px) {
    .featured-services-container {
      padding-bottom: 48px; } }
  @media (max-width: 640px) {
    .featured-services-container {
      padding-bottom: 32px; } }
  .featured-services-container .hero-section {
    display: flex;
    height: 348px;
    padding: 68px 218px;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
    background: linear-gradient(0deg, rgba(197, 143, 68, 0.25) 0%, rgba(197, 143, 68, 0.25) 100%), linear-gradient(0deg, rgba(0, 1, 2, 0.45) 0%, rgba(0, 1, 2, 0.45) 100%), url("https://file.hstatic.net/200000985044/file/dichvunoibat.jpg") lightgray 50%/cover no-repeat;
    position: relative; }
    @media (max-width: 991px) {
      .featured-services-container .hero-section {
        height: 280px;
        padding: 48px 32px; } }
    @media (max-width: 640px) {
      .featured-services-container .hero-section {
        height: 240px;
        padding: 32px 16px; } }
    .featured-services-container .hero-section .hero-content {
      display: flex;
      width: 1004px;
      padding: 24px;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      gap: 24px;
      position: relative; }
      @media (max-width: 991px) {
        .featured-services-container .hero-section .hero-content {
          width: 100%;
          max-width: 800px;
          padding: 20px; } }
      @media (max-width: 640px) {
        .featured-services-container .hero-section .hero-content {
          padding: 16px; } }
      .featured-services-container .hero-section .hero-content .hero-text-wrapper {
        display: flex;
        width: 800px;
        flex-direction: column;
        align-items: center;
        gap: 8px;
        position: relative; }
        @media (max-width: 991px) {
          .featured-services-container .hero-section .hero-content .hero-text-wrapper {
            width: 100%;
            max-width: 600px; } }
        .featured-services-container .hero-section .hero-content .hero-text-wrapper .hero-subtitle {
          align-self: stretch;
          color: #fff;
          text-align: center;
          letter-spacing: -0.2px;
          position: relative;
          font: 500 18px/24px Roboto, -apple-system, Roboto, Helvetica, sans-serif; }
          @media (max-width: 991px) {
            .featured-services-container .hero-section .hero-content .hero-text-wrapper .hero-subtitle {
              font-size: 16px;
              line-height: 22px; } }
          @media (max-width: 640px) {
            .featured-services-container .hero-section .hero-content .hero-text-wrapper .hero-subtitle {
              font-size: 14px;
              line-height: 20px; } }
        .featured-services-container .hero-section .hero-content .hero-text-wrapper .hero-title {
          align-self: stretch;
          color: #fff;
          text-align: center;
          position: relative;
          font: 500 40px/56px "Playfair Display", -apple-system, Roboto, Helvetica, sans-serif; }
          @media (max-width: 991px) {
            .featured-services-container .hero-section .hero-content .hero-text-wrapper .hero-title {
              font-size: 32px;
              line-height: 44px; } }
          @media (max-width: 640px) {
            .featured-services-container .hero-section .hero-content .hero-text-wrapper .hero-title {
              font-size: 24px;
              line-height: 32px; } }
  .featured-services-container .services-grid {
    display: flex;
    align-items: center;
    gap: 16px;
    position: relative;
    margin-top: -88px;
    z-index: 1;
    flex-wrap: wrap;
    justify-content: center; }
    @media (max-width: 991px) {
      .featured-services-container .services-grid {
        flex-wrap: wrap;
        gap: 12px;
        margin-top: -60px;
        padding: 0; } }
    @media (max-width: 640px) {
      .featured-services-container .services-grid {
        flex-direction: column;
        gap: 16px;
        margin-top: -40px;
        padding: 0; } }
    .featured-services-container .services-grid .service-card {
      display: flex;
      padding: 24px;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      gap: 24px;
      border-radius: 4px;
      background: linear-gradient(180deg, rgba(255, 221, 126, 0.2) 23.22%, rgba(223, 173, 76, 0.2) 100%), #fff;
      position: relative;
      width: 100%;
      transition: all 0.3s ease;
      aspect-ratio: 4 / 2;
      flex: 1 1 100%;
      max-width: 100%; }
      @media (min-width: 576px) {
        .featured-services-container .services-grid .service-card {
          flex: 1 1 calc(50% - 16px);
          max-width: calc(50% - 16px);
          aspect-ratio: 4 / 3; } }
      @media (min-width: 992px) {
        .featured-services-container .services-grid .service-card {
          flex: 1 1 calc(25% - 16px);
          max-width: calc(25% - 16px);
          aspect-ratio: 4 / 3; }
          .featured-services-container .services-grid .service-card:hover {
            border-radius: 4px;
            border: 2px solid var(--Gardient-stroke, #ECC638);
            background: linear-gradient(180deg, rgba(255, 221, 126, 0.5) 23.22%, rgba(223, 173, 76, 0.5) 100%), #FFF;
            box-shadow: -4px 0 8px 0 rgba(0, 0, 0, 0.1), 4px 4px 8px 0 rgba(0, 0, 0, 0.1); } }
      .featured-services-container .services-grid .service-card .service-content {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        align-self: stretch;
        position: relative; }
        .featured-services-container .services-grid .service-card .service-content .service-title {
          align-self: stretch;
          color: #800020;
          text-align: center;
          position: relative;
          font: 400 20px/24px "Playfair Display", -apple-system, Roboto, Helvetica, sans-serif; }
          @media (max-width: 991px) {
            .featured-services-container .services-grid .service-card .service-content .service-title {
              font-size: 18px;
              line-height: 22px; } }
          @media (max-width: 640px) {
            .featured-services-container .services-grid .service-card .service-content .service-title {
              font-size: 16px;
              line-height: 20px; } }
        .featured-services-container .services-grid .service-card .service-content .service-description {
          align-self: stretch;
          color: #232f4b;
          text-align: center;
          letter-spacing: -0.2px;
          position: relative;
          font: 400 16px/24px Roboto, -apple-system, Roboto, Helvetica, sans-serif; }
          @media (max-width: 991px) {
            .featured-services-container .services-grid .service-card .service-content .service-description {
              font-size: 14px;
              line-height: 20px; } }
          @media (max-width: 640px) {
            .featured-services-container .services-grid .service-card .service-content .service-description {
              font-size: 13px;
              line-height: 18px;
              margin: 0; } }
      .featured-services-container .services-grid .service-card .service-button {
        display: flex;
        width: auto;
        height: 40px;
        padding: 8px 16px;
        justify-content: center;
        align-items: center;
        gap: 8px;
        flex-shrink: 0;
        border-radius: 6px;
        border: 1px solid #ecc638;
        background: linear-gradient(180deg, #ffdd7e 23.22%, #dfad4c 100%);
        position: relative;
        cursor: pointer;
        transition: transform 0.2s ease, box-shadow 0.2s ease; }
        .featured-services-container .services-grid .service-card .service-button .button-text {
          font-family: Roboto;
          font-size: 14px;
          font-style: normal;
          font-weight: 400;
          line-height: 24px;
          /* 150% */
          letter-spacing: -0.2px;
          color: #800020; }
        .featured-services-container .services-grid .service-card .service-button:hover {
          transform: translateY(-2px);
          box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); }
        .featured-services-container .services-grid .service-card .service-button:active {
          transform: translateY(0); }
        @media (max-width: 640px) {
          .featured-services-container .services-grid .service-card .service-button {
            width: auto;
            height: 36px;
            padding: 6px 12px; } }
        .featured-services-container .services-grid .service-card .service-button .arrow-icon {
          width: 20px;
          height: 20px;
          flex-shrink: 0;
          aspect-ratio: 1/1;
          position: relative; }
          @media (max-width: 640px) {
            .featured-services-container .services-grid .service-card .service-button .arrow-icon {
              width: 18px;
              height: 18px; } }

/****/
.event-services-section {
  display: flex;
  align-items: center;
  gap: 40px 108px;
  justify-content: start;
  flex-wrap: wrap;
  padding-bottom: 64px; }
  @media (max-width: 991px) {
    .event-services-section {
      gap: 0px 108px; } }
  .event-services-section .main-image {
    aspect-ratio: 1.68;
    object-fit: contain;
    object-position: center;
    width: 524px;
    align-self: stretch;
    min-width: 240px;
    flex-grow: 1;
    flex-shrink: 1;
    margin: auto 0; }
    @media (max-width: 991px) {
      .event-services-section .main-image {
        max-width: 100%; } }
  .event-services-section .content-container {
    align-self: stretch;
    display: flex;
    min-width: 240px;
    flex-direction: column;
    align-items: stretch;
    justify-content: start;
    flex-grow: 1;
    flex-shrink: 1;
    width: 432px;
    margin: auto 0; }
    @media (max-width: 991px) {
      .event-services-section .content-container {
        max-width: 100%; } }
    .event-services-section .content-container .section-header {
      width: 100%; }
      @media (max-width: 991px) {
        .event-services-section .content-container .section-header {
          max-width: 100%; } }
      .event-services-section .content-container .section-header .icon-container {
        display: flex;
        min-height: 72px;
        width: 72px;
        flex-direction: column;
        align-items: center;
        justify-content: center; }
        .event-services-section .content-container .section-header .icon-container .decorative-icon {
          aspect-ratio: 6/5;
          object-fit: contain;
          object-position: center;
          width: 100%;
          fill: #800020; }
      .event-services-section .content-container .section-header .section-title {
        color: #800020;
        margin-top: 8px;
        font: 400 24px/48px 'Playfair Display', -apple-system, Roboto, Helvetica, sans-serif; }
        @media (max-width: 991px) {
          .event-services-section .content-container .section-header .section-title {
            max-width: 100%; } }
    .event-services-section .content-container .section-description {
      color: #232f4b;
      text-align: justify;
      letter-spacing: -0.2px;
      margin-top: 32px;
      font: 400 16px/24px Roboto, -apple-system, Roboto, Helvetica, sans-serif; }
      @media (max-width: 991px) {
        .event-services-section .content-container .section-description {
          max-width: 100%;
          margin: 0; } }
    .event-services-section .content-container .contact-button {
      justify-content: center;
      align-items: center;
      border-radius: 6px;
      border: 1px solid #ecc638;
      align-self: start;
      display: flex;
      margin-top: 32px;
      gap: 8px;
      color: #800020;
      letter-spacing: -0.2px;
      background: linear-gradient(180deg, #ffdd7e 23.22%, #dfad4c 100%);
      padding: 8px 16px;
      font: 400 14px Roboto, -apple-system, Roboto, Helvetica, sans-serif;
      cursor: pointer;
      transition: transform 0.2s ease, box-shadow 0.2s ease; }
      .event-services-section .content-container .contact-button:hover {
        transform: translateY(-2px);
        box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); }
      .event-services-section .content-container .contact-button:active {
        transform: translateY(1px); }
      .event-services-section .content-container .contact-button .button-text {
        color: #800020;
        align-self: stretch;
        margin: auto 0; }
      .event-services-section .content-container .contact-button .button-icon {
        aspect-ratio: 1;
        object-fit: contain;
        object-position: center;
        width: 20px;
        align-self: stretch;
        flex-shrink: 0;
        margin: auto 0; }

/****/
.vision-mission-container {
  display: flex;
  width: 100%;
  padding: 0 0 64px 0px;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
  margin: 0 auto; }
  .vision-mission-container .background-wrapper {
    display: flex;
    width: 100%;
    padding: 24px;
    flex-direction: column;
    align-items: flex-start;
    border-radius: 4px;
    background: linear-gradient(0deg, rgba(197, 143, 68, 0.1) 0%, rgba(197, 143, 68, 0.1) 100%), linear-gradient(0deg, rgba(0, 0, 0, 0.45) 0%, rgba(0, 0, 0, 0.45) 100%), url("https://file.hstatic.net/200000985044/file/c17041646ab9aff441a5caf4bd47a2833c186e15.jpg") lightgray 50%/cover no-repeat;
    position: relative; }
    .vision-mission-container .background-wrapper .content-container {
      display: flex;
      padding: 48px 64px;
      flex-direction: column;
      align-items: center;
      gap: 32px;
      align-self: stretch;
      border-radius: 4px;
      position: relative;
      background-color: rgba(255, 255, 255, 0.8); }
      .vision-mission-container .background-wrapper .content-container .section-header {
        align-self: stretch;
        text-align: center;
        position: relative; }
        .vision-mission-container .background-wrapper .content-container .section-header .main-title {
          color: #800020;
          font: 400 36px/48px 'Playfair Display', -apple-system, Roboto, Helvetica, sans-serif;
          margin: 0; }
      .vision-mission-container .background-wrapper .content-container .content-sections {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 24px;
        align-self: stretch;
        position: relative; }
        .vision-mission-container .background-wrapper .content-container .content-sections .vision-section,
        .vision-mission-container .background-wrapper .content-container .content-sections .mission-section {
          display: flex;
          flex-direction: column;
          justify-content: center;
          align-items: flex-start;
          gap: 8px;
          align-self: stretch;
          position: relative; }
          .vision-mission-container .background-wrapper .content-container .content-sections .vision-section .section-content,
          .vision-mission-container .background-wrapper .content-container .content-sections .mission-section .section-content {
            width: 100%; }
            .vision-mission-container .background-wrapper .content-container .content-sections .vision-section .section-content .section-label,
            .vision-mission-container .background-wrapper .content-container .content-sections .mission-section .section-content .section-label {
              color: #800020;
              position: relative;
              font: 500 16px/24px 'Playfair Display', -apple-system, Roboto, Helvetica, sans-serif;
              margin: 0 0 8px 0; }
            .vision-mission-container .background-wrapper .content-container .content-sections .vision-section .section-content .section-description,
            .vision-mission-container .background-wrapper .content-container .content-sections .mission-section .section-content .section-description {
              align-self: stretch;
              color: #232f4b;
              letter-spacing: -0.2px;
              position: relative;
              font: 400 16px/24px Roboto, -apple-system, Roboto, Helvetica, sans-serif;
              margin: 0; }
      .vision-mission-container .background-wrapper .content-container .contact-button {
        justify-content: center;
        align-items: center;
        border-radius: 6px;
        border: 1px solid #ecc638;
        align-self: start;
        display: flex;
        margin-top: 32px;
        gap: 8px;
        color: #800020;
        letter-spacing: -0.2px;
        background: linear-gradient(180deg, #ffdd7e 23.22%, #dfad4c 100%);
        padding: 8px 16px;
        font: 400 16px Roboto, -apple-system, Roboto, Helvetica, sans-serif;
        cursor: pointer;
        transition: opacity 0.2s ease; }
        .vision-mission-container .background-wrapper .content-container .contact-button:hover {
          opacity: 0.9; }
        .vision-mission-container .background-wrapper .content-container .contact-button:active {
          transform: translateY(1px); }
        .vision-mission-container .background-wrapper .content-container .contact-button .button-text {
          color: #800020;
          align-self: stretch;
          margin: auto 0; }
        .vision-mission-container .background-wrapper .content-container .contact-button .button-icon {
          aspect-ratio: 1;
          object-fit: contain;
          object-position: center;
          width: 20px;
          align-self: stretch;
          flex-shrink: 0;
          margin: auto 0; }
  @media (max-width: 991px) {
    .vision-mission-container .section-label {
      font-size: 14px;
      line-height: 20px; }
    .vision-mission-container .section-description {
      font-size: 16px;
      line-height: 22px; }
    .vision-mission-container .content-container {
      padding: 32px 40px; }
    .vision-mission-container .vision-mission-container {
      padding: 0 40px 48px 40px; } }
  @media (max-width: 640px) {
    .vision-mission-container .section-label {
      font-size: 14px;
      line-height: 20px; }
    .vision-mission-container .section-description {
      font-size: 14px;
      line-height: 20px; }
    .vision-mission-container .main-title {
      font-size: 28px;
      line-height: 36px; }
    .vision-mission-container .content-container {
      padding: 24px 20px !important;
      gap: 24px !important; }
    .vision-mission-container .background-wrapper {
      padding: 16px !important; }
    .vision-mission-container .content-sections {
      gap: 20px; } }
  @media (max-width: 480px) {
    .vision-mission-container .main-title {
      font-size: 24px !important;
      line-height: 32px !important; }
    .vision-mission-container .content-container {
      padding: 20px 16px !important; } }

.testimonials-section {
  display: flex;
  width: 100%;
  padding-bottom: 64px;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  margin: 0 auto;
  box-sizing: border-box; }
  .testimonials-section .testimonials-container {
    display: flex;
    width: 100%;
    flex-direction: column;
    align-items: center;
    gap: 24px; }
    .testimonials-section .testimonials-container .testimonials-header {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 8px;
      width: 100%; }
      .testimonials-section .testimonials-container .testimonials-header .testimonials-title {
        color: #800020;
        text-align: center;
        letter-spacing: normal;
        font: 400 24px/48px 'Playfair Display', serif;
        margin: 0; }
    .testimonials-section .testimonials-container .testimonials-grid {
      display: flex;
      gap: 16px;
      flex-wrap: wrap;
      width: 100%; }
      .testimonials-section .testimonials-container .testimonials-grid .testimonial-card {
        display: flex;
        padding: 16px;
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
        border-radius: 6px;
        border: 1px solid #ECC638;
        box-sizing: border-box;
        background-color: #FFF;
        flex: 1 1 100%;
        max-width: 100%; }
        @media (min-width: 576px) {
          .testimonials-section .testimonials-container .testimonials-grid .testimonial-card {
            flex: 1 1 100%;
            max-width: 100%; } }
        @media (min-width: 992px) {
          .testimonials-section .testimonials-container .testimonials-grid .testimonial-card {
            flex: 1 1 calc(100%/3 - 20px);
            max-width: calc(100%/3 - 20px); } }
        .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-image {
          height: 350px;
          width: 100%;
          border-radius: 4px;
          object-fit: cover;
          display: block; }
        .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-content {
          display: flex;
          flex-direction: column;
          align-items: flex-start;
          gap: 12px;
          width: 100%; }
          .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-content .testimonial-header {
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            gap: 8px;
            width: 100%; }
            .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-content .testimonial-header .testimonial-event-title {
              color: #800020;
              letter-spacing: -0.2px;
              font: 500 18px/24px 'Roboto', sans-serif;
              margin: 0; }
              .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-content .testimonial-header .testimonial-event-title .star-rating {
                display: flex;
                align-items: center;
                gap: 4px;
                width: 106px;
                height: 18px; }
                .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-content .testimonial-header .testimonial-event-title .star-rating svg {
                  width: 106px;
                  height: 18px; }
          .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-content .testimonial-text {
            color: #232F4B;
            letter-spacing: -0.2px;
            font: 400 16px/24px 'Roboto', sans-serif;
            margin: 0; }
  @media (max-width: 991px) {
    .testimonials-section {
      padding-bottom: 48px;
      gap: 24px; }
    .testimonials-section .testimonials-container {
      max-width: 100%; }
      .testimonials-section .testimonials-container .testimonials-title {
        font-size: 32px;
        line-height: 40px; }
      .testimonials-section .testimonials-container .testimonials-grid {
        gap: 12px; }
        .testimonials-section .testimonials-container .testimonials-grid .testimonial-card {
          width: 100%; }
          .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-event-title {
            font-size: 16px;
            line-height: 22px; }
          .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-text {
            font-size: 14px;
            line-height: 20px; } }
  @media (max-width: 640px) {
    .testimonials-section {
      padding-bottom: 32px;
      gap: 20px; }
    .testimonials-section .testimonials-container .testimonials-title {
      font-size: 28px;
      line-height: 36px; }
    .testimonials-section .testimonials-container .testimonials-grid {
      flex-direction: column;
      gap: 16px; }
      .testimonials-section .testimonials-container .testimonials-grid .testimonial-card {
        width: 100%;
        max-width: none; }
        .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-image {
          height: 200px; }
        .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-event-title {
          font-size: 16px;
          line-height: 22px; }
        .testimonials-section .testimonials-container .testimonials-grid .testimonial-card .testimonial-text {
          font-size: 14px;
          line-height: 20px; } }
