@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-Black.woff2") format("woff2"), url("../fonts/Lato-Black.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lato Hairline";
  src: url("../fonts/Lato-Hairline.woff2") format("woff2"), url("../fonts/Lato-Hairline.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-Italic.woff2") format("woff2"), url("../fonts/Lato-Italic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-Light.woff2") format("woff2"), url("../fonts/Lato-Light.woff") format("woff");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-BlackItalic.woff2") format("woff2"), url("../fonts/Lato-BlackItalic.woff") format("woff");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-BoldItalic.woff2") format("woff2"), url("../fonts/Lato-BoldItalic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-Regular.woff2") format("woff2"), url("../fonts/Lato-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-Bold.woff2") format("woff2"), url("../fonts/Lato-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Lato Hairline";
  src: url("../fonts/Lato-HairlineItalic.woff2") format("woff2"), url("../fonts/Lato-HairlineItalic.woff") format("woff");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato-LightItalic.woff2") format("woff2"), url("../fonts/Lato-LightItalic.woff") format("woff");
  font-weight: 300;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-Regular.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-MediumItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-MediumItalic.woff") format("woff");
  font-weight: 500;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-ExtraBoldItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-ExtraBoldItalic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-Italic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Italic.woff") format("woff");
  font-weight: normal;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-Bold.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-ExtraBold.woff2") format("woff2"), url("../fonts/PlayfairDisplay-ExtraBold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-Medium.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-BlackItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-BlackItalic.woff") format("woff");
  font-weight: 900;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-Black.woff2") format("woff2"), url("../fonts/PlayfairDisplay-Black.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-BoldItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-BoldItalic.woff") format("woff");
  font-weight: bold;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-SemiBoldItalic.woff2") format("woff2"), url("../fonts/PlayfairDisplay-SemiBoldItalic.woff") format("woff");
  font-weight: 600;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: "Playfair Display";
  src: url("../fonts/PlayfairDisplay-SemiBold.woff2") format("woff2"), url("../fonts/PlayfairDisplay-SemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
:root {
  --color-accent: 78 90% 48%;
  --color-card: 42 30% 99%;
  --color-dark-green: 180 50% 25%;
  --color-light-green: 78 50% 93%;
  --color-light: 42 25% 93%;
  --color-border: 38 22% 84%;
  --color-background: 42 35% 97%;
  --font-color-main: 180 25% 20%;
  --font-color-second: var(--color-dark-green);
  --font-color-third: 180 15% 38%;
  --font-color-accent: 180 50% 15%;
  --font-color-light: 0 0% 100%;
  --button-box-shadow: 0 0 #000, 0 0 #000, 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
  --card-box-shadow: 0 4px 20px -6px hsl(38 35% 35% / .08);
  --nav-transition: cubic-bezier(0.4, 0, 0.2, 1);
}

.float {
  animation: float 6s ease-in-out infinite;
}

@keyframes float {
  0%, to {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}
.medium-icon,
.large-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 0.75rem;
  background-color: hsl(var(--color-dark-green));
  color: #fff;
  margin-bottom: 1.5rem;
}

.large-icon {
  width: 4rem;
  height: 4rem;
}

.large-icon svg {
  width: 2rem;
  height: 2rem;
}

.medium-icon {
  width: 3rem;
  height: 3rem;
}

.medium-icon svg {
  width: 1.5rem;
  height: 1.5rem;
}

.button--right-arrow .ico-arrow-right {
  height: 1rem;
  width: 1rem;
  min-height: 1rem;
  min-width: 1rem;
  margin-left: 0.5rem;
  transition: transform 0.15s cubic-bezier(0.4, 0, 0.2, 1);
}

.button--right-arrow:hover .ico-arrow-right,
.button-hoverer:hover .button--right-arrow .ico-arrow-right {
  transform: translateX(0.25rem);
}

.pulse {
  transform-origin: top left;
  transform: translate(12px, 12px) scale(0);
  opacity: 1;
  animation: pulseAnim 1.2s cubic-bezier(0.52, 0.6, 0.25, 0.99) infinite;
}

.pulse1 {
  animation-delay: 0s;
}

.pulse2 {
  animation-delay: 0.2s;
}

.pulse3 {
  animation-delay: 0.4s;
}

@keyframes pulseAnim {
  0% {
    transform: translate(12px, 12px) scale(0);
    opacity: 1;
  }
  100% {
    transform: translate(0, 0) scale(1);
    opacity: 0;
  }
}
nav {
  position: fixed;
  z-index: 2000;
  top: 0px;
  left: 0px;
  display: flex;
  flex-flow: column;
  justify-content: space-between;
  height: 100%;
  width: 64px;
  border-right: 1px solid hsl(var(--color-border)/0.5);
  transition: 0.3s all var(--nav-transition);
  font-size: 20px;
  backdrop-filter: blur(4px);
}

.nav__logo__link {
  display: flex;
  flex-wrap: nowrap;
  gap: 5px;
  align-items: center;
  color: hsl(var(--font-color-second));
  border-bottom: 1px solid hsl(var(--color-border)/0.5);
  font-family: "Playfair Display";
}

.nav__logo__link .ico-logo {
  height: 64px;
  width: 64px;
  min-width: 64px;
}

.nav__button {
  display: none;
}

.nav__content {
  display: flex;
  flex-flow: column;
  gap: 4px;
  align-items: center;
}

.nav__content__link {
  width: calc(100% - 1rem);
  height: 40px;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-start;
  color: hsl(var(--font-color-second));
  border-radius: 0.75rem;
  padding-left: 12px;
  gap: 4px;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.nav__content__link:hover {
  background-color: hsl(var(--color-accent)/0.15);
}

.nav__content__link--selected,
.nav__content__link--selected:hover {
  background-color: hsl(var(--color-accent)/0.25);
  border-color: hsl(var(--color-accent));
  border-left-width: 4px;
  border-left-style: solid;
  border-top-width: 0px;
  border-bottom-width: 0px;
}

.nav__content__link svg {
  width: 20px;
  height: 20px;
}

.nav__appointment {
  display: flex;
  flex-wrap: nowrap;
  gap: 5px;
  align-items: center;
  justify-content: center;
  border-top: 1px solid hsl(var(--color-border)/0.5);
  height: 64px;
  visibility: hidden;
  opacity: 0;
}

.nav__appointment_link {
  width: calc(100% - 0.75rem);
}

.nav__appointment_link:hover {
  color: hsl(var(--font-color-light));
  background-color: hsl(var(--color-dark-green));
}

.nav__appointment_link .ico-calendar {
  height: 16px;
  width: 16px;
}

.nav__appointment_link .nav__text--long {
  display: none;
}

.nav__text {
  visibility: hidden;
  display: inline-block;
  opacity: 0;
  max-width: 0px;
  white-space: nowrap;
  transition: 0.3s max-width var(--nav-transition), 0.2s opacity var(--nav-transition), 0s visibility linear 0.3s;
}

nav:hover {
  width: 208px;
}

nav:hover .nav__appointment {
  transition: 0.3s opacity var(--nav-transition), 0s visibility linear;
  opacity: 1;
  visibility: visible;
}

nav:hover .nav__text {
  max-width: 100%;
  opacity: 1;
  visibility: visible;
  transition: 0.3s max-width var(--nav-transition), 0.2s opacity var(--nav-transition) 0.1s, 0s visibility linear;
}

@media (max-width: 767px) {
  nav {
    justify-content: flex-start;
    height: 64px;
    width: 100%;
    border-right: none;
    border-bottom: 1px solid hsl(var(--color-border)/0.5);
    background-color: hsla(0, 0%, 100%, 0);
  }
  nav:hover {
    height: 64px;
    width: 100%;
  }
  .nav__button {
    display: inline-flex;
    position: absolute;
    justify-content: center;
    align-items: center;
    top: 0.75rem;
    right: 0.75rem;
    transition: background-color 0.15s cubic-bezier(0.4, 0, 0.2, 1);
    color: hsl(var(--font-color-second));
    background-color: hsl(var(--color-accent)/0.2);
    border-radius: 0.75rem;
    justify-content: center;
    align-items: center;
    width: 2.5rem;
    height: 2.5rem;
    border: none;
    cursor: pointer;
    padding: 0px;
    margin: 0px;
  }
  .nav__button .ico-close {
    display: none;
  }
  .nav__button .ico-close,
  .nav__button .ico-menu {
    width: 20px;
    height: 20px;
  }
  .nav__content {
    gap: 8px;
    padding: 1rem;
  }
  .nav__content,
  .nav__appointment,
  nav:hover .nav__content,
  nav:hover .nav__appointment {
    opacity: 0;
    visibility: hidden;
  }
  .nav__logo__link {
    border-bottom: none;
  }
  .nav__content__link {
    height: 48px;
    font-size: 16px;
    width: 100%;
  }
  .nav__content__link:not(.nav__content__link--selected):not(:hover) {
    background-color: hsl(var(--color-light)/0.5);
  }
  .nav__appointment {
    padding: 1rem 0px;
    margin: 0px 1rem;
    width: calc(100% - 2rem);
    height: auto;
  }
  .nav__appointment_link {
    width: 100%;
  }
  .nav__appointment_link .nav__text--long {
    display: inline-block;
  }
  .nav__appointment_link .nav__text--short,
  .nav__appointment_link .ico-calendar {
    display: none;
  }
  .nav__text {
    visibility: visible;
    opacity: 1;
    max-width: 100%;
  }
  nav.nav--open {
    height: 394px;
    background-color: hsla(0, 0%, 100%, 0.85);
  }
  .nav--open .nav__content,
  .nav--open .nav__appointment,
  nav:hover.nav--open .nav__content,
  nav:hover.nav--open .nav__appointment {
    transition: visibility 0s linear, opacity 0.2s var(--nav-transition) 0.1s;
    opacity: 1;
    visibility: visible;
  }
  .nav--open .nav__button .ico-close {
    display: inline-block;
  }
  .nav--open .nav__button .ico-menu {
    display: none;
  }
}
main {
  background-color: hsl(var(--color-background));
}

section {
  padding-top: 6rem;
  padding-bottom: 6rem;
}

.main-layout {
  display: flex;
  flex-flow: column;
  overflow: hidden;
}

.layout {
  width: 1408px;
  max-width: 100%;
  margin: auto;
  padding-right: 2rem;
  padding-left: 6rem;
}

.section-subtitle {
  color: hsl(var(--font-color-third));
  font-size: 1.125rem;
  line-height: 1.75rem;
  max-width: 42rem;
  margin: auto;
}

.section-label {
  margin-bottom: 1rem;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: hsl(var(--color-dark-green));
}

.section-label::before {
  content: "";
  height: 0.25rem;
  width: 2.5rem;
  border-radius: 0.125rem;
  background: hsl(var(--color-accent));
}

#not-found {
  min-height: calc(100vh - 386px);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (max-width: 767px) {
  .layout {
    padding-left: 16px;
    padding-right: 16px;
  }
}
header {
  background-image: linear-gradient(rgb(250, 248, 245), rgba(242, 239, 233, 0.2), rgb(250, 248, 245));
  padding-top: 3rem;
}

.header {
  display: flex;
  max-width: 1216px;
  margin: auto;
}

.header__content {
  flex: 1;
  align-self: center;
  display: flex;
  flex-flow: column;
  align-items: flex-start;
  max-width: 100%;
}

.hero {
  position: relative;
  z-index: 1000;
}

.hero__image {
  border-radius: 1rem;
  position: relative;
  z-index: 1000;
}

.hero__image__border {
  content: "";
  display: block;
  position: absolute;
  z-index: 900;
  background-color: hsl(var(--color-accent)/0.1);
  border-radius: 1rem;
  transform: translate(0, 0) rotate(2deg) skewX(0) skewY(0) scaleX(1) scaleY(1);
  top: -0.75rem;
  right: -0.75rem;
  bottom: -0.75rem;
  left: -0.75rem;
}

.hero__image__legend {
  position: absolute;
  z-index: 1100;
  padding: 0.75rem 1rem;
  background-color: hsl(var(--color-card));
  border-radius: 0.75rem;
}

.hero__image__legend--main {
  font-family: "Playfair Display";
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.5rem;
  color: hsl(var(--font-color-second));
}

.hero__image__legend--second {
  font-size: 0.875rem;
  line-height: 1.25rem;
  line-height: 1.25rem;
  color: hsl(var(--font-color-third));
}

.header__content__title--first,
.header__content__title--second {
  display: inline-block;
}

.header__content__title--second {
  color: hsl(var(--font-color-second));
}

.header__content__description {
  color: hsl(var(--font-color-third));
  font-size: 1.25rem;
  line-height: 1.75rem;
  margin-bottom: 2.5rem;
}

.header__content__text {
  color: hsl(var(--font-color-third));
  line-height: 1.625;
  margin-bottom: 2rem;
}

.header__content__googlerate {
  margin-bottom: 2rem;
}

.header__content__buttons {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.no-header {
  padding-top: 3rem;
  padding-bottom: 3rem;
  padding-left: 2rem;
}

footer {
  background-color: hsl(var(--color-light)/0.5);
  border-top: 1px solid hsl(var(--color-border)/0.3);
}

.footer {
  display: flex;
  flex-flow: column;
  padding: 3rem 2rem;
}

.footer h3 {
  letter-spacing: 0.025em;
  text-transform: uppercase;
  font-weight: 600;
  font-size: 0.875rem;
  line-height: 1.25rem;
  margin-bottom: 0.75rem;
}

.footer-top {
  display: flex;
  gap: 2.5rem;
  justify-content: space-between;
}

.footer-top > div {
  flex: 1;
  color: hsl(var(--font-color-third));
  line-height: 1.625;
  font-size: 0.875rem;
}

.footer__main-link {
  display: inline-block;
  font-family: "Playfair Display";
  color: hsl(var(--font-color-main));
  font-weight: 600;
  font-size: 1.125rem;
  line-height: 1.75rem;
  margin-bottom: 0.5rem;
}

.footer__nav {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer__nav > li {
  margin-top: 0.375rem;
}

.footer__nav__link {
  color: hsl(var(--font-color-third));
  transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.15s;
  line-height: 1.25rem;
}

.footer__nav__link .ico-chevron-right {
  display: inline-block;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 0.15s;
  opacity: 0;
  color: hsl(var(--color-accent));
  width: 0.75rem;
  height: 0.75rem;
  margin-left: -1rem;
}

.footer__nav__link:hover .ico-chevron-right {
  opacity: 1;
  margin-left: 0;
}

.footer__contacts {
  list-style: none;
  margin: 0;
  padding: 0;
}

.footer__contacts li {
  display: flex;
  gap: 0.5rem;
  align-items: flex-start;
  margin-top: 0.375rem;
}

.footer__contacts > li a {
  display: inline-block;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: inherit;
}

.footer__contacts > li svg {
  color: hsl(var(--color-accent));
  width: 1rem;
  height: 1rem;
  margin-top: 0.125rem;
}

.footer .button {
  letter-spacing: 0.025em;
  font-size: 0.875rem;
  line-height: 1.25rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  margin-top: 0.75rem;
  height: 2.25rem;
  border-radius: calc(0.75rem - 2px);
}

.footer .button svg {
  height: 1rem;
  width: 1rem;
}

.footer__bottom {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid hsl(var(--color-border)/0.4);
  font-size: 0.75rem;
  line-height: 1rem;
  color: hsl(var(--font-color-third));
  margin-top: 2rem;
  padding-top: 1.25rem;
}

.footer__bottom__right {
  display: flex;
  gap: 1rem;
}

.footer__bottom__right a {
  cursor: pointer;
}

.cookies__container {
  position: fixed;
  z-index: 1500;
  width: 100%;
  bottom: 0.75rem;
  left: 0px;
  padding-left: 64px;
  visibility: hidden;
}

.cookies__box {
  position: relative;
  margin: auto;
  visibility: visible;
  max-width: 80rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  flex-direction: row;
  box-shadow: rgba(120, 98, 58, 0.12) 0px -2px 24px -6px;
  padding: 0.75rem 1rem;
  background-color: hsl(var(--color-card));
  border: 1px solid hsl(var(--color-border)/0.5);
  border-radius: 0.75rem;
  transform: translateY(0px);
  transition: transform 0.4s ease;
}

.cookies__content {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  position: relative;
  flex: 1;
}

.cookies__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: hsl(var(--color-accent)/0.2);
  border-radius: 9999px;
  width: 2rem;
  height: 2rem;
  color: hsl(var(--font-color-third));
}

.cookies__icon .ico-cookie {
  height: 1rem;
  width: 1rem;
}

.cookies__content__text {
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: hsl(var(--font-color-third));
}

.cookies__buttons {
  display: flex;
  gap: 0.75rem;
}

.cookies__close .ico-close {
  cursor: pointer;
  width: 1rem;
  height: 1rem;
  color: hsl(var(--font-color-third));
}

.cookies__hidden .cookies__box {
  transform: translateY(calc(100% + 2rem));
  transition: none;
}

@media (max-width: 1408px) {
  .footer {
    padding: 3rem calc(100vw - 1376px);
  }
}
@media (max-width: 1376px) {
  .footer {
    padding: 3rem 0px;
  }
}
@media (max-width: 1023px) {
  .footer-top {
    flex-wrap: wrap;
  }
  .footer-top > div {
    min-width: calc(50% - 1.25rem);
  }
}
@media (max-width: 767px) {
  .cookies__buttons .button {
    font-size: 0.75rem;
    line-height: 1rem;
    padding: 0px 0.75rem;
    height: 2.25rem;
  }
}
@media (max-width: 639px) {
  .footer-top > div {
    min-width: 100%;
  }
  .footer .button {
    width: unset;
  }
  .footer__bottom {
    flex-flow: column;
    align-items: center;
    gap: 0.75rem;
  }
  .cookies__container {
    padding: 0px 1rem;
  }
  .cookies__box {
    flex-flow: column;
    align-items: center;
  }
  .cookies__close {
    position: absolute;
    top: 0.25rem;
    right: 0.25rem;
  }
}
* {
  box-sizing: border-box;
}

html {
  font-size: 16px;
}

body {
  margin: 0px;
  padding: 0px;
  font-family: "Lato";
  font-weight: 400;
  color: hsl(var(--font-color-main));
}

h1 {
  font-size: 3.75rem;
  line-height: 3.75rem;
  color: hsl(var(--font-color-main));
  font-family: "Playfair Display";
  letter-spacing: -1.5px;
  font-weight: 500;
  margin: 0px 0px 2rem 0px;
  padding: 0px;
}

h2 {
  font-size: 3rem;
  line-height: 1;
  color: hsl(var(--font-color-main));
  font-family: "Playfair Display";
  letter-spacing: -0.025em;
  font-weight: 500;
  margin: 0px 0px 1.5rem 0px;
  padding: 0px;
}

h2 span {
  color: hsl(var(--font-color-second));
  display: block;
  margin-top: 0.25rem;
}

h3 {
  font-size: 1.25rem;
  line-height: 1.75rem;
  color: hsl(var(--font-color-main));
  font-family: "Playfair Display";
  letter-spacing: -0.5px;
  font-weight: 500;
  margin: 0px 0px 0.5rem 0px;
  padding: 0px;
}

p {
  padding: 0px;
  margin: 0px;
}

a {
  text-decoration: none;
}

.text-center {
  text-align: center;
}

.background-decoration {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
}

.background-decoration--first {
  filter: blur(64px);
  background-color: hsl(var(--color-accent)/0.1);
  width: 8rem;
  height: 8rem;
  top: 5rem;
  right: 5rem;
}

.background-decoration--second {
  filter: blur(40px);
  background-color: hsl(var(--color-accent)/0.15);
  width: 6rem;
  height: 6rem;
  bottom: 10rem;
  left: 2.5rem;
}

.location {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background-color: hsl(var(--color-accent)/0.15);
  border: 1px solid hsl(var(--color-accent)/0.3);
  border-radius: 21px;
  margin-bottom: 1.5rem;
  color: hsl(var(--font-color-second));
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.location .ico-location {
  width: 1rem;
  height: 1rem;
}

.caption {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background-color: hsl(var(--color-accent)/0.2);
  border: 2px solid hsl(var(--color-accent)/0.5);
  border-radius: 21px;
  margin-bottom: 1.5rem;
  color: hsl(var(--font-color-second));
  font-size: 0.875rem;
  line-height: 1.25rem;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: 0.025em;
}

.caption svg {
  color: hsl(var(--color-accent));
  height: 1rem;
  width: 1rem;
}

.enumeration {
  display: flex;
  flex-flow: column;
  gap: 1rem;
  list-style: none;
  margin: 0px;
  padding: 0px;
  align-items: flex-start;
}

.enumeration > li {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

.enumeration__dot {
  background-color: hsl(var(--color-accent));
  border-radius: 9999px;
  flex-shrink: 0;
  width: 0.375rem;
  height: 0.375rem;
}

.enumeration__dot > svg {
  height: 14px;
  width: 14px;
}

.enumeration-accent {
  list-style: none;
  margin: 0;
  padding: 0;
}

.button {
  display: inline-flex;
  font-family: "Lato";
  transition-duration: 300ms;
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  letter-spacing: 0.025em;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.5rem;
  padding: 0px 2.5rem;
  white-space: nowrap;
  border-radius: 0.75rem;
  gap: 0.5rem;
  height: 3rem;
  justify-content: center;
  align-items: center;
  border: none;
  cursor: pointer;
}

.button--large {
  font-size: 1.125rem;
  line-height: 1.75rem;
  height: 3.5rem;
}

.button--small {
  font-size: 0.75rem;
  line-height: 1rem;
  padding: 0px 0.75rem;
  height: 2.25rem;
}

.button--filled {
  color: hsl(var(--font-color-accent));
  background-color: hsl(var(--color-accent));
  border-width: 2px;
}

.button--filled:hover,
.button-hoverer:hover .button--filled {
  color: hsl(var(--font-color-light));
  background-color: hsl(var(--color-dark-green));
}

.button--outlined {
  color: hsl(var(--font-color-second));
  background-color: transparent;
  border: 2px solid hsl(var(--color-dark-green));
  font-weight: 600;
}

.button--outlined:hover,
.button-hoverer:hover .button--outlined {
  color: hsl(var(--font-color-accent));
  background-color: hsl(var(--color-accent)/0.2);
  border-color: hsl(var(--color-accent));
}

.button--shadowed {
  box-shadow: var(--button-box-shadow);
}

.uppercase {
  text-transform: uppercase;
}

.field {
  transition: all 0.15s cubic-bezier(0.4, 0, 0.2, 1);
  padding: 0.75rem 1rem;
  background-color: hsl(var(--color-card));
  border: 2px solid hsl(var(--color-border));
  border-radius: 0.75rem;
  font-family: inherit;
  font-feature-settings: inherit;
  font-variation-settings: inherit;
  font-size: 100%;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  color: inherit;
  margin: 0;
}

.field:focus {
  outline: 2px solid transparent;
  outline-offset: 2px;
  border-color: hsl(var(--color-accent));
  box-shadow: hsl(var(--color-accent)) 0px 0px 0px 2px;
}

.frame {
  max-width: 80rem;
  margin-left: auto;
  margin-right: auto;
  box-shadow: var(--card-box-shadow);
  border: 2px solid hsl(var(--color-accent)/0.4);
  border-radius: 1.5rem;
  background-color: hsl(var(--color-card));
  overflow: hidden;
  position: relative;
}

.frame::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  height: 0.375rem;
  top: 0px;
  left: 0px;
  background-color: hsl(var(--color-accent));
}

.googlerate {
  display: flex;
  justify-content: flex-start;
  gap: 0.75rem;
  align-items: center;
}

.googlerate__stars__container {
  position: relative;
  width: 100px;
}

.googlerate__stars__background {
  display: flex;
  width: 100px;
  position: absolute;
  z-index: 999;
  top: 0px;
  left: 0px;
}

.googlerate__stars__background .ico-star {
  width: 1.25rem;
  height: 1.25rem;
  color: #bbbbbb;
  fill: #dddddd;
}

.googlerate__stars__mask {
  position: relative;
  width: calc(var(--rating) * 20px);
  overflow: hidden;
  z-index: 1000;
}

.googlerate__stars {
  display: flex;
  width: 100px;
}

.googlerate__stars .ico-star {
  width: 1.25rem;
  height: 1.25rem;
  color: hsl(var(--color-accent));
  fill: hsl(var(--color-accent));
}

.googlerate__content {
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: hsl(var(--font-color-third));
}

.accordion-content {
  overflow: hidden;
  height: 0;
  transition: height 0.3s ease;
}

.simple-link {
  color: inherit;
  text-decoration: none;
}

.simple-link:hover {
  text-decoration: underline;
}

.small-link {
  text-decoration: none;
  font-size: 0.875rem;
  line-height: 1.25rem;
  color: hsl(var(--font-color-second));
}

.small-link:hover {
  text-decoration: underline;
}

.large-link {
  color: hsl(var(--font-color-second));
  font-weight: 600;
  font-size: 1.125rem;
  line-height: 1.75rem;
}

.large-link:hover {
  color: hsl(var(--font-color-second)/0.8);
}

.small-link:hover {
  text-decoration: underline;
}

.ico-drop-down-arrow {
  height: 1rem;
  width: 1rem;
  color: hsl(var(--font-color-third));
}

.back-link {
  color: hsl(var(--font-color-second));
}

.back-link .ico-arrow-left {
  height: 16px;
  width: 16px;
  vertical-align: bottom;
  margin-right: 0.5rem;
}

*.no-ptop {
  padding-top: 0px;
}

.half-blocks {
  display: flex;
  gap: 3rem;
  flex-wrap: wrap;
}

.half-block {
  flex: 1;
  min-width: calc(50% - 1.5rem);
  max-width: calc(50% - 1.5rem);
}

.card-white,
.card-green {
  padding: 2rem;
  box-shadow: 0 2px 12px -4px hsla(38, 35%, 35%, 0.06);
  border-radius: 1rem;
}

.card-white {
  background-color: #fff;
  border: 1px solid hsl(var(--color-border)/0.5);
}

.card-green {
  background-color: hsl(var(--color-light-green));
  border: 2px solid hsl(var(--color-accent)/0.4);
}

@media (max-width: 1023px) {
  h1 {
    font-size: 3rem;
    line-height: 1;
  }
  h2 {
    font-size: 3rem;
    line-height: 1;
  }
  .half-block {
    min-width: 100%;
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  .button {
    width: 100%;
  }
  .button--small {
    font-size: 1rem;
    line-height: 1.5rem;
    padding: 0px 2rem;
    height: 3rem;
  }
}
.faq {
  text-align: center;
  max-width: 56rem;
  margin: auto;
}

.faq__subtitle {
  color: hsl(var(--font-color-third));
  font-size: 1.125rem;
  line-height: 1.75rem;
  margin-bottom: 3rem;
}

.faq__container {
  display: flex;
  flex-flow: column;
  gap: 1rem;
}

.faq__item {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  background-color: hsl(var(--color-card));
  border: 1px solid hsl(var(--color-border));
  border-radius: 0.75rem;
  text-align: left;
  transition: border-color ease 0.3s;
}

.faq__item.accordion-expanded {
  border-color: hsl(var(--color-accent)/0.4);
}

.faq__question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: none;
  background: none;
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-family: "Playfair Display";
  font-size: 1.125rem;
  line-height: 1.75rem;
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
}

.faq__answer {
  color: hsl(var(--font-color-third));
  line-height: 1.625;
  padding-bottom: 1.25rem;
  font-size: 0.875rem;
}

.faq__other-question {
  margin-top: 3rem;
  text-align: center;
  color: hsl(var(--font-color-third));
}

.faq--small h2 {
  font-size: 1.875rem;
  line-height: 2.25rem;
  margin-bottom: 2.5rem;
}

.faq--small .faq__item {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

.faq--small .faq__question {
  font-size: 1rem;
  line-height: 1.5rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.header__contact {
  display: flex;
  align-items: center;
  gap: 3.5rem;
  justify-content: space-between;
}

.header__contact h1 {
  font-size: 3rem;
  line-height: 1;
}

.header__contact__first {
  width: 50%;
}

.header__contact__second {
  width: 50%;
}

.header__contact__second .hero {
  height: 18rem;
}

.header__contact__second .hero__image {
  width: 100%;
  height: 100%;
  -o-object-position: center 25%;
     object-position: center 25%;
  -o-object-fit: cover;
     object-fit: cover;
}

.contact h2 {
  font-size: 1.875rem;
  line-height: 2.25rem;
}

.my-details-items {
  display: flex;
  flex-flow: column;
  gap: 1rem;
  margin-bottom: 2rem;
}

.my-details-item {
  display: flex;
  gap: 1rem;
}

.my-details-item-icon {
  display: flex;
  background-color: hsl(var(--color-accent)/0.25);
  border: 2px solid hsl(var(--color-accent)/0.5);
  border-radius: 0.75rem;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
}

.my-details-item h3 {
  font-size: 1rem;
  line-height: 1.5rem;
}

.my-details-item-description {
  color: hsl(var(--font-color-third));
}

.my-details-item-description .small-link {
  display: inline-block;
  margin-top: 0.375rem;
}

.my-details-map-container {
  position: relative;
  height: 400px;
}

.my-details-map {
  position: relative;
  z-index: 1000;
}

.my-details-iframe {
  border: 0px;
  min-height: 400px;
  height: 100%;
  width: 100%;
  filter: grayscale(1);
  transition: filter 0.3s ease;
}

.my-details-iframe:hover {
  filter: grayscale(0);
}

.intervention-area-card {
  max-width: 56rem;
  margin: auto;
  padding: 1.5rem;
}

.intervention-area-items {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.5rem;
  text-align: center;
  flex-wrap: wrap;
}

.intervention-area-item {
  transition: background-color cubic-bezier(0.4, 0, 0.2, 1) 0.15s;
  padding: 0.625rem 0.75rem;
  background-color: hsl(var(--color-accent)/0.15);
  border: 2px solid hsl(var(--color-accent)/0.4);
  border-radius: 0.75rem;
  color: hsl(var(--foreground));
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.25rem;
  width: calc(25% - 0.5625rem);
}

.intervention-area-item:hover {
  background-color: hsl(var(--color-accent)/0.25);
}

@media (max-width: 1023px) {
  .header__contact__first {
    text-align: center;
    width: 100%;
    padding-top: 4rem;
  }
  .header__contact__second {
    display: none;
  }
}
@media (max-width: 639px) {
  .intervention-area-item {
    width: calc(50% - 0.375rem);
  }
}/*# sourceMappingURL=contact.css.map */