@font-face {
  font-family: Playfairdisplay;
  src: url('../fonts/PlayfairDisplay-Regular.woff2') format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Playfairdisplay;
  src: url('../fonts/PlayfairDisplay-Italic.woff2') format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Poppins;
  src: url('../fonts/Poppins-Regular.woff2') format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Poppins;
  src: url('../fonts/Poppins-Medium.woff2') format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

:root {
  --pudra-500: #221e20;
  --white: white;
  --green: #909c87;
  --pudra-100: #f9f7f6;
  --border-radius-animation: 0px;
  --pudra: #ece8e7;
  --gray-100: #ebebeb;
  --green-secondary: #636d5c;
  --pudra-200: #e2d7d2;
  --gray-300: #514f56;
  --gray-200: #949191;
  --black: #18171b;
  --gray: #efefef;
  --header-text-color: white;
  --header-background: #ffffff1f;
  --plan-card-border: 20px;
  --font-family-second: Playfairdisplay, sans-serif;
  --font-family-main: Poppins, sans-serif;
}

body {
  color: var(--pudra-500);
  letter-spacing: -.03em;
  font-family: Poppins, sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5em;
}

h1 {
  letter-spacing: -.07em;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Playfairdisplay, sans-serif;
  font-size: 6rem;
  font-weight: 400;
  line-height: 1em;
}

h2 {
  letter-spacing: -.06em;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Playfairdisplay, sans-serif;
  font-size: 4.25rem;
  font-weight: 400;
  line-height: 1.1em;
}

h3 {
  letter-spacing: -.05em;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Poppins, sans-serif;
  font-size: 2.25rem;
  font-weight: 400;
  line-height: 1em;
}

h4 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 24px;
}

p {
  margin-bottom: 0;
}

a {
  text-decoration: none;
}

ul {
  margin-top: 0;
  margin-bottom: 0;
  padding-left: 40px;
}

.main {
  z-index: 1;
  flex: 1;
  position: relative;
}

.container {
  width: 100%;
  max-width: 90rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}

.container.hero-container {
  z-index: 1;
  grid-column-gap: 1rem;
  grid-row-gap: 2.5rem;
  flex-direction: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr .5fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  place-items: center start;
  display: grid;
  position: relative;
}

.container.experts-conainer {
  grid-column-gap: 5.62rem;
  justify-content: center;
  align-items: center;
  display: flex;
}

.container.experts-conainer.is-gap-smaller {
  grid-column-gap: 4rem;
}

.container.contact-conainer {
  grid-column-gap: 5.62rem;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.container.contact-conainer.is-home-page {
  justify-content: center;
  align-items: center;
}

.container.sessions-container {
  margin-bottom: 2.5rem;
}

.container.session-progressbar {
  margin-top: 2.5rem;
}

.button {
  background-color: var(--white);
  color: var(--pudra-500);
  text-align: center;
  border-radius: 5rem;
  justify-content: center;
  align-items: center;
  padding: 1.625rem 2.5rem 1.375rem;
  font-size: 1.125rem;
  transition: background-color .3s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.button.button-green {
  background-color: var(--green);
  color: var(--pudra-100);
}

.button.button-green.form-button {
  margin-top: 1.25rem;
}

.button.button-green.subscribe-button {
  height: 4.5625rem;
  position: absolute;
  inset: .5rem .5rem auto auto;
}

.button.button-green.is-small {
  padding: .8125rem 1.25rem .6875rem;
  font-size: 1rem;
}

.button.button-smoke {
  background-color: var(--pudra-100);
}

.button.button-gost {
  border: 1px solid var(--green);
  color: var(--green);
  background-color: #fff0;
}

.section {
  padding-top: 10rem;
  padding-bottom: 10rem;
}

.section.sessions {
  background-color: var(--white);
  height: 300vh;
  position: relative;
}

.section.section-padding-small {
  z-index: 1;
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.section.section-padding-small.contact {
  border-bottom-left-radius: var(--border-radius-animation);
  border-bottom-right-radius: var(--border-radius-animation);
  background-color: var(--pudra-100);
  margin-bottom: -80px;
  padding-top: 2.5rem;
  position: relative;
}

.section.section-padding-small.content-yogatherapie {
  z-index: 1;
  border-bottom-left-radius: var(--border-radius-animation);
  border-bottom-right-radius: var(--border-radius-animation);
  background-color: var(--pudra);
  color: var(--pudra-500);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  padding-top: 3rem;
  padding-bottom: 3rem;
  display: flex;
  position: relative;
  overflow: hidden;
}

.section.section-padding-small.intro {
  z-index: 1;
  border-bottom-left-radius: var(--border-radius-animation);
  border-bottom-right-radius: var(--border-radius-animation);
  background-color: var(--gray-100);
  color: var(--pudra-500);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.section.section-padding-small.yoga-cta {
  z-index: 1;
  border-bottom-left-radius: var(--border-radius-animation);
  border-bottom-right-radius: var(--border-radius-animation);
  background-color: var(--green-secondary);
  color: var(--white);
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.section.instructors {
  background-color: var(--white);
  padding-top: 5rem;
  padding-bottom: 5rem;
  overflow: hidden;
}

.section.reviews {
  background-color: #edebea;
}

.section.plans {
  background-color: var(--pudra-100);
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

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

.section.inner {
  padding-bottom: 5rem;
}

.section.hero-yogatherapie {
  background-color: var(--green);
  color: var(--white);
}

.colors {
  grid-column-gap: 1.25rem;
  grid-row-gap: 3.25rem;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  margin-top: 3.25rem;
  display: grid;
}

.color-card {
  flex-direction: column;
  display: flex;
}

.color {
  aspect-ratio: 1;
  background-color: #000;
  border-radius: 32px;
  margin-bottom: 1.25rem;
}

.typography {
  width: 100%;
  margin-top: 2.5rem;
}

.typography-item-wrapper {
  border-top: 1px solid var(--pudra-200);
  margin-top: 2.5rem;
  padding-top: 2.5rem;
}

.rich-text {
  flex-direction: column;
  display: flex;
}

.rich-text ul {
  grid-row-gap: .625rem;
  letter-spacing: -.02em;
  flex-direction: column;
  padding-left: 1.25rem;
  font-size: 1.125rem;
  line-height: 1.4em;
  display: flex;
}

.rich-text h2 {
  margin-top: .5em;
  margin-bottom: .5em;
}

.buttons {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  margin-top: 5rem;
  display: grid;
}

.button-card {
  grid-row-gap: .5rem;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.button-wrapper {
  flex-direction: column;
  align-items: center;
}

.content-vertical-left {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.content-horizontal-left {
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.content-horizontal-left.header-content {
  border-radius: 0;
  padding: .5rem;
  position: relative;
}

.body {
  background-color: var(--white);
  flex-direction: column;
  display: flex;
}

.header {
  z-index: 10;
  width: 100%;
  height: 0;
  position: absolute;
  inset: 1.25rem auto auto 0%;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  min-height: 100vh;
  max-height: 100%;
  padding: 10rem 5vw;
  display: flex;
}

.utility-page-content {
  grid-row-gap: 3.125rem;
  text-align: center;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.text-large {
  letter-spacing: -.02em;
  font-size: 1.375rem;
  line-height: 1.4em;
}

.text-large.schedule-card-value {
  align-items: center;
  width: 100%;
  display: flex;
}

.text {
  letter-spacing: -.02em;
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.4em;
}

.text.color-white.hero-text {
  max-width: 28.5556em;
}

.text.text-center.timetable-description {
  max-width: 42em;
}

.text.color-gray-200.text-font-medium {
  letter-spacing: 0;
  text-transform: uppercase;
  font-size: 1rem;
  font-weight: 500;
}

.text.small-p, .text-extra-small {
  font-size: 1rem;
}

.text-italic {
  font-style: italic;
}

.heading-medium {
  letter-spacing: -.06em;
  font-size: 4.25rem;
  line-height: 1.1em;
}

.heading-small {
  letter-spacing: -.05em;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Poppins, sans-serif;
  font-size: 2.25rem;
  line-height: 1em;
}

.gray-300 {
  background-color: var(--gray-300);
}

.gray-200 {
  background-color: var(--gray-200);
}

.gray-100 {
  background-color: var(--gray-100);
}

.pudra-500 {
  background-color: var(--pudra-500);
}

.pudra-200 {
  background-color: var(--pudra-200);
}

.pudra-100 {
  background-color: var(--pudra-100);
}

.green {
  background-color: var(--green);
}

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

.black {
  background-color: var(--black);
}

.green-secondary {
  background-color: var(--green-secondary);
}

.pudra {
  background-color: var(--pudra);
}

.gray {
  background-color: var(--gray);
}

.text-gray-200 {
  color: var(--gray-200);
}

.text-pudra-500 {
  color: var(--pudra-500);
}

.style-guide-title {
  margin-bottom: 5rem;
}

.footer {
  background-color: var(--pudra-500);
  padding-top: 8.75rem;
  padding-bottom: 1.25rem;
}

.header-navigation {
  margin-left: auto;
}

.header-list {
  grid-column-gap: 3.25vw;
  align-items: center;
  display: flex;
}

.link {
  color: var(--white);
  letter-spacing: -.02em;
  font-size: 1.125rem;
  line-height: 1.4em;
  transition: opacity .3s;
}

.link:hover {
  opacity: .8;
}

.link.navigation-link {
  color: var(--header-text-color);
}

.link.link-small {
  font-size: 1rem;
  line-height: 1.5em;
}

.hero {
  background-image: linear-gradient(#0003, #0003), url('../images/hero-bg2x.webp');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 100vh;
  padding-top: 10rem;
  padding-bottom: 10vh;
  display: flex;
  position: relative;
}

.header-logo {
  flex: none;
  justify-content: flex-start;
  align-items: center;
  transition: opacity .3s;
  display: flex;
  position: relative;
}

.header-logo:hover {
  opacity: .8;
}

.header-logo.w--current {
  color: var(--white);
  justify-content: flex-start;
  align-items: center;
  min-width: 25%;
  font-size: 18px;
  display: flex;
  position: relative;
}

.header-blur {
  z-index: -1;
  background-color: var(--header-background);
  -webkit-backdrop-filter: blur(60px);
  backdrop-filter: blur(60px);
  border-radius: 100px;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
}

.header-logo-image {
  z-index: 1;
  object-fit: scale-down;
  object-position: 50% 50%;
  border-radius: 999px;
  width: auto;
  max-height: 100%;
  position: relative;
}

.header-logo-image.tablet-hide {
  opacity: 1;
  display: block;
}

.tablet-visible {
  display: none;
}

.tablet-hide {
  display: block;
}

.socials {
  grid-column-gap: .625rem;
  align-items: center;
  padding-left: 0;
  display: flex;
}

.socials-link {
  background-color: var(--gray-300);
  color: var(--white);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 4.5rem;
  height: 4.5rem;
  transition: background-color .3s, color .3s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.socials-link:hover {
  background-color: var(--white);
  color: var(--pudra-500);
}

.svg {
  justify-content: center;
  align-items: center;
  display: flex;
}

.svg.button-icon {
  z-index: 1;
  position: relative;
}

.heading-large {
  letter-spacing: -.03em;
  font-family: Playfairdisplay, sans-serif;
  font-size: 6vw;
  font-weight: 400;
  line-height: 1em;
}

.color-white {
  color: var(--white);
}

.hero-video-wrapper {
  aspect-ratio: 1 / 1.34;
  border-radius: 162px;
  width: 100%;
  max-width: 20.25rem;
  position: relative;
  overflow: hidden;
}

.hero-video {
  z-index: 1;
  perspective-origin: 50% 0;
  transform-origin: 50% 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: none;
  position: absolute;
  inset: 0% auto auto 0%;
}

.section-header {
  grid-row-gap: 2rem;
  flex-direction: column;
  align-items: center;
  margin-bottom: 4rem;
  display: flex;
}

.section-header.content-horizontal-left, .section-header.content-vertical-left {
  align-items: flex-start;
}

.heading-max-width {
  max-width: 14.1176em;
}

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

.text-center.section-header-text {
  max-width: 43.25em;
}

.text-center.plans-title {
  max-width: 15em;
}

.sessions-wrapper {
  flex: none;
  overflow: hidden;
}

.sessions-list {
  grid-column-gap: 1.25rem;
  display: flex;
}

.sessions-item {
  flex: none;
  width: 100%;
  max-width: 26.25rem;
}

.session-card {
  grid-row-gap: 1.25rem;
  background-color: var(--green);
  color: var(--white);
  background-image: none;
  border-radius: 16px;
  flex-direction: column;
  align-items: flex-start;
  height: 100%;
  min-height: 29.25rem;
  padding: 2rem;
  display: flex;
}

.session-card-logo {
  background-color: var(--white);
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 3.75rem;
  height: 3.75rem;
  display: flex;
}

.session-card-description {
  margin-top: auto;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.5em;
}

.sessions-sticky {
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  margin-top: 19rem;
  margin-bottom: -14.6rem;
  display: flex;
  position: sticky;
  top: 50vh;
  overflow: hidden;
  transform: translate(0, -50%);
}

.sessions-sticky-wrapper {
  flex: 0 auto;
  justify-content: flex-start;
  width: 100%;
  max-width: 90rem;
  margin-left: auto;
  margin-right: auto;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  display: flex;
}

.experts-content {
  grid-row-gap: 1.5rem;
  flex-direction: column;
  align-items: center;
  max-width: 29.5em;
  display: flex;
}

.experts-content.is-align-left {
  text-align: left;
  justify-content: center;
  align-items: flex-start;
  padding-top: 16px;
  padding-bottom: 16px;
}

.experts-content.is-align-left.is-parcours {
  max-width: 40em;
}

.experts-content.is-samedi-yoga {
  text-align: center;
  flex: 1;
  justify-content: center;
  align-items: center;
  max-width: none;
  padding-left: 25px;
  padding-right: 25px;
}

.experts-image-wrapper {
  aspect-ratio: 1 / 1.36;
  border-radius: 500px;
  width: 100%;
  max-width: 25rem;
  position: relative;
  overflow: hidden;
}

.experts-image {
  object-fit: cover;
  width: 100%;
  height: 110%;
}

.experts-image.is-pratique-audio {
  filter: brightness(85%);
}

.hidden {
  display: none;
}

.instructors-wrapper {
  justify-content: center;
  align-items: center;
  display: flex;
}

.instructors-collection {
  justify-content: center;
  display: flex;
}

.instructors-list {
  grid-column-gap: 1.25rem;
  grid-row-gap: 2.5rem;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 100%;
  display: flex;
}

.instructors-item {
  text-align: center;
  flex: none;
  width: 100%;
  max-width: 31%;
}

.instructor-card {
  grid-row-gap: 2rem;
  cursor: pointer;
  flex-direction: column;
  display: flex;
}

.instructor-card-image-wrapper {
  aspect-ratio: 1 / 1.44;
  border-radius: 200px;
  justify-content: center;
  align-items: flex-start;
  display: flex;
  overflow: hidden;
}

.instructor-card-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.instructor-card-info {
  grid-row-gap: .625rem;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.instructor-card-experience {
  display: flex;
}

.instructors-inner {
  justify-content: center;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  display: flex;
}

.reviews-title {
  max-width: 13.5em;
}

.reviews-wrapper {
  display: flex;
}

.reviews-list {
  grid-row-gap: 1.25rem;
  flex-direction: column;
  flex: 1;
  display: flex;
}

.reviews-item {
  width: 100%;
  max-width: 26.25rem;
}

.review {
  grid-row-gap: 2rem;
  background-color: var(--white);
  border-radius: 32px;
  flex-direction: column;
  align-items: flex-start;
  padding: 2rem;
  display: flex;
}

.review-stars {
  color: var(--green);
  align-items: center;
  display: flex;
}

.review-content {
  grid-row-gap: 2.5rem;
  border-bottom: 1px solid var(--pudra-200);
  flex-direction: column;
  align-items: flex-start;
  padding-bottom: 2.5rem;
  display: flex;
}

.color-gray-200 {
  color: var(--gray-200);
}

.reviews-inner {
  grid-column-gap: 1.25rem;
  grid-row-gap: 1.25rem;
  display: flex;
}

.plans-list {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
  display: flex;
}

.plans-item {
  flex: 1;
  min-width: 27rem;
}

.plan {
  background-color: var(--header-background);
  border-radius: 20px;
  height: 100%;
  overflow: hidden;
}

.plan.plan-left {
  background-color: var(--header-background);
  border-radius: 20px;
}

.plan-wrapper {
  border-radius: var(--plan-card-border);
  background-color: var(--white);
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  height: 100%;
  padding: 2.5rem;
  display: flex;
  overflow: hidden;
}

.plan-wrapper.background-green {
  color: var(--white);
  justify-content: space-between;
  align-items: center;
  overflow: hidden;
}

.tag {
  background-color: var(--green);
  color: var(--white);
  border-radius: 100px;
  height: 2.5rem;
  padding: .625rem 1.25rem .375rem;
  overflow: hidden;
}

.plan-features {
  grid-row-gap: 1rem;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 2.5rem;
  margin-bottom: 2.5rem;
  padding-left: 0;
  display: flex;
}

.plan-feature.custom-marker-item {
  width: 100%;
  padding: 0;
}

.custom-marker-item {
  padding-left: .75rem;
  position: relative;
}

.background-green {
  background-color: var(--green);
}

.tag-white {
  background-color: var(--pudra-100);
  color: var(--pudra-500);
  border-radius: 100px;
  height: 2.5rem;
  padding: .625rem 1.25rem .375rem;
  overflow: hidden;
}

.tabs-menu {
  grid-column-gap: .5rem;
  justify-content: center;
  align-items: center;
  padding-bottom: .5rem;
  display: flex;
  overflow: auto;
}

.tab {
  border: 1px solid var(--green);
  color: var(--green);
  background-color: #fff0;
  border-radius: 100px;
  flex: none;
  height: 3rem;
  margin-bottom: .5rem;
  padding: .75rem 2rem;
  transition: background-color .3s, color .3s;
}

.tab:hover, .tab.w--current {
  background-color: var(--green);
  color: var(--white);
}

.tab.is-yogatherapie {
  color: var(--green);
  background-color: #909c8726;
}

.tab.is-yogatherapie.w--current {
  background-color: var(--green-secondary);
  color: var(--white);
  text-align: center;
}

.tabs {
  margin-left: -2.5rem;
  margin-right: -2.5rem;
}

.tabs-content {
  margin-top: 2.5rem;
}

.timetable-item:first-child {
  border-top: 1px solid var(--pudra-200);
}

.schedule-card {
  grid-column-gap: 1.25rem;
  grid-row-gap: 16px;
  border-bottom: 1px solid var(--pudra-200);
  grid-template-rows: auto;
  grid-template-columns: .5fr 1fr minmax(20rem, .5fr);
  grid-auto-columns: 1fr;
  align-items: center;
  padding-top: 2rem;
  padding-bottom: 2rem;
  display: grid;
}

.schedule-card-field {
  grid-column-gap: .75rem;
  grid-row-gap: .25rem;
  flex-direction: column;
  align-items: flex-start;
  display: flex;
}

.schedule-card-field.schedule-card-field-horizontal {
  flex-direction: row;
  align-items: center;
}

.schedule-card-field.mobile-hidden {
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
}

.schedule-card-image-wrapper {
  border-radius: 50%;
  flex: none;
  width: 4.125rem;
  height: 4.125rem;
  overflow: hidden;
}

.mobile-hidden {
  display: flex;
}

.schedule-card-image {
  object-fit: cover;
  object-position: 50% 100%;
}

.text-small {
  font-size: 1.125rem;
}

.mobile-visible {
  display: none;
}

.contact-content {
  grid-row-gap: 2.5rem;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 29em;
  display: flex;
}

.contact-content.sticky {
  position: sticky;
  top: 160px;
}

.form {
  width: 100%;
  margin-bottom: 0;
}

.form-field {
  width: 100%;
}

.text-field {
  background-color: var(--gray-100);
  outline-offset: 0px;
  color: var(--pudra-500);
  border: 1px #000;
  border-radius: 10px;
  outline: 0 #221e20;
  height: 4.625rem;
  margin-bottom: 0;
  padding: 1.75rem;
}

.text-field::placeholder {
  color: var(--pudra-500);
}

.form-wrapper {
  grid-row-gap: 1.25rem;
  flex-direction: column;
  align-items: center;
  display: flex;
}

.contact-image {
  object-fit: cover;
  width: 100%;
  height: 110%;
}

.contact-image-wrapper {
  aspect-ratio: 1 / 1.36;
  border-radius: 500px;
  width: 100%;
  max-width: 33.75rem;
  overflow: hidden;
}

.footer-top {
  border-bottom: 1px solid var(--gray-300);
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 5rem;
  padding-bottom: 5rem;
  display: flex;
}

.subscribe {
  grid-row-gap: 2rem;
  color: var(--white);
  flex-direction: column;
  display: flex;
}

.form-subscribe {
  width: 100%;
  max-width: 33.125rem;
  margin-bottom: 0;
}

.form-subscribe-wrapper {
  position: relative;
}

.text-field-subscribe {
  background-color: var(--gray-300);
  outline-offset: 0px;
  color: var(--white);
  border: 1px #000;
  border-radius: 72px;
  outline: 3px #d9d9d9;
  height: 5.5625rem;
  margin-bottom: 0;
  padding-left: 2.25rem;
  padding-right: 11.5rem;
  font-size: 1.125rem;
}

.text-field-subscribe::placeholder {
  color: var(--white);
}

.success-message {
  background-color: var(--pudra);
  border-radius: 50px;
}

.success-message-2 {
  background-color: #ddd0;
  min-height: 5.5625rem;
  padding-top: 1.75rem;
  padding-bottom: 1.75rem;
  padding-left: 0;
}

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

.link-to-top {
  background-color: var(--white);
  color: var(--pudra-500);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 4.5rem;
  height: 4.5rem;
  transition: background-color .3s, color .3s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.link-to-top:hover {
  background-color: var(--gray-300);
  color: var(--white);
}

.link-to-top.mobile-visible, .link-to-top.mobile-small-visible {
  display: none;
}

.footer-content {
  grid-column-gap: 2.5rem;
  grid-row-gap: 2.5rem;
  color: var(--white);
  flex-wrap: wrap;
  align-items: flex-end;
  display: flex;
}

.footer-info {
  grid-row-gap: 2.25rem;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  max-width: 21rem;
  display: flex;
}

.footer-logo-wrapper {
  justify-content: space-between;
  display: flex;
}

.footer-logo {
  width: 4.5rem;
  height: 4.5rem;
  transition: opacity .3s;
}

.footer-logo:hover {
  opacity: .8;
}

.footer-logo-image {
  object-fit: cover;
  border-radius: 999px;
  width: 100%;
  height: 100%;
}

.color-pudra-100 {
  color: var(--pudra-100);
}

.footer-navigation {
  grid-column-gap: 5rem;
  margin-left: auto;
  display: flex;
}

.footer-list {
  grid-row-gap: .8rem;
  flex-direction: column;
  display: flex;
}

.footer-navigation-item {
  grid-row-gap: 1.5rem;
  flex-direction: column;
  display: flex;
}

.font-weight-medium {
  font-weight: 500;
}

.footer-bootom {
  border-top: 1px solid var(--gray-300);
  justify-content: space-between;
  margin-top: 6.25rem;
  padding-top: 1.25rem;
  display: flex;
}

.link-dark {
  color: var(--gray-200);
  transition: color .3s;
}

.link-dark:hover {
  color: var(--white);
}

.mobile-small-visible {
  display: none;
}

.plans-wrapper {
  justify-content: center;
  align-items: center;
  margin-left: -2.5rem;
  margin-right: -2.5rem;
  padding-bottom: 1.5rem;
  display: flex;
  overflow: auto;
}

.modal {
  z-index: 30;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100dvh;
  display: none;
  position: fixed;
  inset: 0% auto auto 0%;
}

.modal.modal-instructor {
  cursor: auto;
  display: none;
}

.modal-overlay {
  cursor: pointer;
  background-image: linear-gradient(#3f3d44b3, #3f3d44b3);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
}

.modal-wrapper {
  z-index: 1;
  max-width: 100%;
  max-height: 100%;
  padding-left: 1rem;
  padding-right: 1rem;
  position: relative;
  overflow: auto;
}

.modal-content {
  background-color: var(--pudra-100);
  border-radius: 60px;
  width: 100%;
  max-width: 46.875rem;
  padding: 5rem;
}

.modal-close {
  z-index: 2;
  background-color: var(--gray-100);
  color: var(--pudra-500);
  border-radius: 50%;
  justify-content: center;
  align-items: center;
  width: 3rem;
  height: 3rem;
  transition: opacity .3s;
  display: flex;
  position: absolute;
  inset: 2rem 3rem auto auto;
}

.modal-close:hover {
  opacity: .8;
}

.button-hover {
  background-color: var(--gray-300);
  border-radius: 100px;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
  transform: translate(0, 101%);
}

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

.button-content {
  z-index: 1;
  position: relative;
}

.background-green-secondary {
  background-color: var(--green-secondary);
}

.background-pudra {
  background-color: var(--pudra);
}

.background-gray {
  background-color: var(--gray);
}

.header-logo-dark {
  z-index: 0;
  object-fit: contain;
  width: 100%;
  height: 100%;
  max-height: 100%;
  display: none;
  position: absolute;
  inset: 0% auto auto 0%;
}

.header-logo-small {
  z-index: 1;
  width: auto;
  max-height: 100%;
  position: relative;
}

.header-logo-small.tablet-visible {
  display: none;
}

.font-family-main {
  font-family: Poppins, sans-serif;
}

.font-family-main.utility-page-title {
  margin-bottom: -2.5rem;
  font-size: 25rem;
}

.footer-sticky {
  background-color: var(--pudra-500);
  padding-top: 5rem;
  position: sticky;
  bottom: 0;
}

.inner-list {
  width: 100%;
}

.inner-item {
  grid-row-gap: 1.25rem;
  border-top: 1px solid var(--pudra-200);
  border-bottom: 1px solid var(--pudra-200);
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: -1px;
  padding-top: 2.75rem;
  padding-bottom: 2.75rem;
  display: flex;
}

.underline {
  text-decoration: underline;
}

.rich-text-block {
  flex-direction: column;
  display: flex;
}

.rich-text-block h2 {
  margin-top: 3.25rem;
  margin-bottom: 2rem;
  font-family: Poppins, sans-serif;
  font-size: 2.25rem;
  line-height: 1em;
}

.rich-text-block p {
  color: var(--gray-200);
  margin-top: .5rem;
  margin-bottom: .5rem;
}

.rich-text-block ul {
  grid-row-gap: 1rem;
  flex-direction: column;
  margin-top: 1.5rem;
  margin-bottom: 1.5rem;
  display: flex;
}

.rich-text-block h3 {
  margin-top: .5rem;
  margin-bottom: .25rem;
  font-size: 1.25rem;
  line-height: 1.6em;
}

.instructor-info {
  grid-row-gap: 2.5rem;
  flex-direction: column;
  display: flex;
}

.instructor-info-field {
  grid-row-gap: 1.25rem;
  flex-direction: column;
  display: flex;
}

.font-family-second {
  font-family: var(--font-family-second);
  font-weight: 400;
}

.sticky-space {
  flex: none;
  width: 0%;
}

.hero-background-slider {
  width: 100%;
  height: 100%;
}

.hero-background-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.hero-background {
  z-index: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
}

.hero-overlay {
  z-index: 1;
  background-color: #0003;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
}

.progressbar {
  background-color: var(--gray-100);
  border-radius: 10px;
  width: 100%;
  height: 3px;
  position: relative;
  overflow: hidden;
}

.progressbar-line {
  background-color: var(--green);
  border-radius: 10px;
  width: 100%;
  height: 100%;
}

.logo-title {
  color: var(--white);
  margin-top: 4px;
  padding-left: 16px;
  padding-right: 16px;
  line-height: 1.2;
  text-decoration: none;
}

.wrapper-dual-button {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.html-embed {
  background-color: var(--green);
}

.contact-image-wrapper-cal {
  border-radius: 8px;
  flex: 1;
  max-width: 400px;
  overflow: hidden;
}

.h2-smaller {
  font-size: 3.25rem;
}

.h2-smaller.cta-tarifs {
  text-align: center;
  letter-spacing: -.03em;
  margin-top: 2.5rem;
  margin-bottom: .25em;
  font-size: 2.5rem;
}

.h2-smaller.even-smaller {
  font-size: 2.5rem;
}

.text-dual-col {
  letter-spacing: -.02em;
  column-count: 2;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4em;
}

.opacity-50 {
  opacity: .5;
}

.text-mono-col {
  letter-spacing: -.02em;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.4em;
}

.text-mono-col.is-green {
  color: var(--green-secondary);
}

.placehoalder {
  background-color: #ff6767;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 150px;
  display: flex;
}

.wrapper-tarif-1 {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.wrapper-txt-tarifs-lieux {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  min-width: 13rem;
  display: flex;
}

.img-tarifs-lieux {
  object-fit: cover;
  border-radius: 999px;
  width: 64px;
  height: 64px;
}

.img-tarifs-lieux.is-prez-lieux {
  object-fit: cover;
  border-radius: 4px;
  width: 88px;
  height: 88px;
}

.img-tarifs-lieux.is-prez-lieux.is-in-planning {
  border-radius: 999px;
}

.small-txt-centered {
  opacity: .5;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  padding-top: 8px;
  padding-bottom: 8px;
  font-size: .9em;
  font-weight: 400;
  line-height: 1.25em;
}

.wrapper-tarif-yogat {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
}

.wrapper-btn-tarifs {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  margin-top: 16px;
  display: flex;
}

.div-block-2 {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  display: flex;
}

.img-absolut {
  object-fit: cover;
  object-position: 50% 0%;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.h3-smaller {
  letter-spacing: -.03em;
  font-size: 1.75rem;
}

.h3-smaller.is-green {
  color: var(--green-secondary);
}

.txt-ville-yoga {
  opacity: .5;
  letter-spacing: -.01em;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.25em;
}

.txt-ville-yoga.is-centered {
  text-align: center;
}

.txt-lieu-yoga {
  letter-spacing: -.01em;
  font-size: 17px;
  line-height: 1.25em;
}

.txt-lieu-yoga.is-playfair {
  letter-spacing: .02em;
  font-family: Playfairdisplay, sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.1em;
}

.txt-prix-yoga {
  letter-spacing: -.01em;
  padding-left: 8px;
  padding-right: 8px;
  font-size: 20px;
}

.wrapper-pres-lieux {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  justify-content: flex-start;
  align-items: stretch;
  width: 100%;
  display: flex;
}

.wrapper-lieux {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  background-color: #ece8e780;
  border-radius: 12px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding: 8px;
  display: flex;
}

.wrapper-lieux.is-in-planning {
  background-color: #ece8e700;
}

.wrapper-samedi-yoga {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  background-color: var(--green);
  color: var(--white);
  border-radius: 24px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 65rem;
  margin-top: 5rem;
  padding: 16px 40px 16px 16px;
  display: flex;
}

.experts-image-wrapper-samedi-yoga {
  aspect-ratio: 1 / 1.33;
  border-radius: 16px;
  width: 100%;
  max-width: 22rem;
  overflow: hidden;
}

.wrapper-pillars {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  background-color: var(--green);
  color: var(--white);
  border-radius: 12px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  min-height: 88px;
  padding: 12px;
  display: flex;
}

.wrapper-pillars.is-centered {
  text-align: center;
  justify-content: center;
  align-items: center;
}

.wrapper-pillars.is-pillars {
  justify-content: center;
  align-items: center;
  min-height: auto;
}

.wrapper-pillars.is-protocols {
  padding-top: 16px;
  padding-bottom: 16px;
}

.wrapper-txt-pillars {
  grid-column-gap: 4px;
  grid-row-gap: 4px;
  flex-flow: column;
  justify-content: space-between;
  align-items: flex-start;
  height: 100%;
  display: flex;
}

.wrapper-txt-pillars.is-centered {
  text-align: center;
  justify-content: center;
  align-items: center;
}

.wrapper-protocos {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  flex-flow: column;
  width: 100%;
  display: flex;
}

.wrapper-absolut-audio {
  color: var(--white);
  text-align: center;
  flex-flow: column;
  justify-content: space-between;
  align-items: center;
  padding: 20%;
  display: flex;
  position: absolute;
  inset: 0%;
}

.wrapper-img-ambiance {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  padding-top: 40px;
  display: grid;
}

.img-amabiance {
  object-fit: cover;
  border-radius: 24px;
  height: 100%;
}

.img-amabiance.is-brighter {
  filter: brightness(140%);
}

.img-amabiance.is-crop-1 {
  object-position: 20% 50%;
}

.div-navigation {
  background-color: var(--green);
  min-height: 128px;
}

.valerie {
  opacity: .75;
  letter-spacing: 0;
  font-size: .9em;
  line-height: 1;
}

.titre-horaire {
  text-align: center;
  padding-top: 8px;
  padding-bottom: 8px;
  font-size: 18px;
}

.elapsed-time {
  opacity: .5;
}

.time-wrapper {
  flex: 1;
  justify-content: space-between;
  width: 100%;
  display: flex;
}

.alert {
  color: var(--green);
}

.chapeau-footerlink {
  opacity: .75;
  font-size: .9em;
}

.p-50 {
  opacity: .5;
}

@media screen and (min-width: 1440px) {
  .container {
    padding-left: 4.25rem;
    padding-right: 4.25rem;
  }

  .header {
    top: 2vh;
  }

  .header-list {
    grid-column-gap: 3.125rem;
  }

  .heading-large {
    font-size: 5rem;
  }

  .sessions-sticky-wrapper, .instructors-inner {
    padding-left: 4.25rem;
    padding-right: 4.25rem;
  }

  .plan-wrapper {
    padding: 3.75rem;
  }

  .footer-content {
    grid-column-gap: 8.75rem;
    grid-row-gap: 2.5rem;
  }

  .modal {
    display: none;
  }
}

@media screen and (max-width: 991px) {
  h3 {
    font-size: 2rem;
  }

  .container {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .container.hero-container {
    flex-direction: column;
    justify-content: flex-start;
    display: flex;
  }

  .container.experts-conainer {
    grid-column-gap: 5vw;
  }

  .container.experts-conainer.is-gap-smaller {
    grid-column-gap: 2rem;
  }

  .container.contact-conainer {
    grid-column-gap: 5vw;
  }

  .section.sessions {
    padding-top: 7.5rem;
    padding-bottom: 7.5rem;
  }

  .section.section-padding-small.contact {
    border-radius: 0;
    margin-bottom: 0;
  }

  .header {
    height: 4.75rem;
  }

  .utility-page-content {
    grid-row-gap: 2.5rem;
  }

  .text.color-white.hero-text {
    text-align: center;
  }

  .footer {
    padding-top: 5rem;
    position: static;
  }

  .header-navigation {
    z-index: -1;
    grid-row-gap: 2.5rem;
    background-color: var(--pudra-500);
    flex-direction: column;
    align-items: stretch;
    width: 100vw;
    height: 100vh;
    margin-left: 0;
    padding: 9.75rem 1rem 4rem;
    display: flex;
    position: fixed;
    inset: 0% auto auto 0%;
    overflow: auto;
    transform: translate(0, -100%);
  }

  .header-list {
    grid-row-gap: 2.5rem;
    flex-direction: column;
  }

  .header-item.header-button-wrapper {
    margin-top: 1.25rem;
  }

  .link.navigation-link {
    letter-spacing: -.06em;
    font-family: Playfairdisplay, sans-serif;
    font-size: 2.625rem;
    font-weight: 400;
    line-height: 1em;
  }

  .hero {
    justify-content: center;
  }

  .tablet-visible {
    display: block;
  }

  .tablet-hide {
    display: none;
  }

  .header-socials.tablet-visible {
    border-top: 1px solid var(--gray-300);
    justify-content: center;
    padding-top: 2.5rem;
    display: flex;
  }

  .burger-wrapper {
    margin-left: auto;
    position: relative;
  }

  .burger {
    border-radius: 50%;
    justify-content: center;
    align-items: center;
    width: 3.75rem;
    height: 3.75rem;
    display: flex;
    position: relative;
    overflow: hidden;
  }

  .burger-line {
    background-color: var(--pudra-500);
    border-radius: 10px;
    width: 2.25rem;
    height: 2px;
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%);
  }

  .burger-line.burger-line-top {
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -7px);
  }

  .burger-line.burger-line-bottom {
    transform: translate(-50%, 7px);
  }

  .burger-close {
    background-color: #f0f0f000;
    border-radius: 50%;
    width: 100%;
    height: 100%;
    display: none;
    position: absolute;
    inset: 0% auto auto 0%;
  }

  .heading-large.color-white.hero-title {
    text-align: center;
  }

  .hero-title-text {
    display: inline-block;
  }

  .sessions-wrapper {
    padding-top: 0;
  }

  .sessions-sticky-wrapper {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .experts-content.is-align-left.is-pillars {
    max-width: none;
  }

  .experts-content.is-samedi-yoga {
    padding-left: 0;
    padding-right: 0;
  }

  .experts-image-wrapper.is-idden-on-tablet {
    display: none;
  }

  .instructors-inner {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .reviews-wrapper {
    margin-left: -2rem;
    margin-right: -2rem;
    padding-bottom: 2rem;
    overflow: auto;
  }

  .reviews-list {
    grid-column-gap: 1.25rem;
    flex-direction: row;
    flex: none;
  }

  .review {
    grid-row-gap: 1.25rem;
  }

  .review-content {
    grid-row-gap: 1.25rem;
    padding-bottom: 1.25rem;
  }

  .reviews-inner {
    flex: none;
    padding-left: 2rem;
    padding-right: 2rem;
    display: flex;
  }

  .plans-list {
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .plans-item {
    width: 100%;
    max-width: 35rem;
  }

  .tabs-menu {
    flex-flow: wrap;
    justify-content: center;
    align-items: center;
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .tabs {
    margin-left: -2rem;
    margin-right: -2rem;
  }

  .schedule-card {
    grid-template-columns: minmax(160px, .5fr) 1fr minmax(272px, .5fr);
  }

  .schedule-card-field.mobile-hidden {
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .footer-content {
    grid-column-gap: 4rem;
    flex-wrap: wrap;
    justify-content: space-between;
  }

  .footer-navigation {
    margin-left: 0;
  }

  .plans-wrapper {
    justify-content: center;
    align-items: center;
    margin-left: -2rem;
    margin-right: -2rem;
  }

  .font-family-main.utility-page-title {
    font-size: 20rem;
  }

  .footer-sticky {
    padding-top: 0;
    position: static;
  }

  .img-tarifs-lieux.is-prez-lieux.is-in-planning {
    width: 72px;
    height: 72px;
  }

  .wrapper-tarif-yogat {
    text-align: center;
  }

  .wrapper-pres-lieux {
    flex-flow: column;
    justify-content: center;
    align-items: stretch;
    max-width: 400px;
  }

  .wrapper-samedi-yoga {
    grid-column-gap: 24px;
    grid-row-gap: 24px;
    padding-right: 24px;
  }

  .elapsed-time {
    display: none;
  }
}

@media screen and (max-width: 767px) {
  h1 {
    font-size: 3.625rem;
  }

  h2 {
    font-size: 2.625rem;
  }

  h3 {
    font-size: 1.625rem;
    line-height: 1.1em;
  }

  .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .container.experts-conainer {
    grid-row-gap: 2.5rem;
    flex-flow: column;
  }

  .container.experts-conainer.is-inverted-on-mobile {
    flex-flow: column-reverse;
  }

  .container.contact-conainer {
    grid-row-gap: 2.5rem;
    flex-direction: column-reverse;
    justify-content: center;
    align-items: center;
  }

  .container.session-progressbar {
    display: none;
  }

  .button.button-smoke.plan-button {
    margin-top: 2.5rem;
  }

  .button.button-smoke.plan-button.is-samedi {
    margin: 0;
  }

  .section {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .section.sessions {
    height: auto;
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .section.section-padding-small.contact {
    margin-bottom: 0;
  }

  .section.section-padding-small.content-yogatherapie, .section.section-padding-small.intro, .section.section-padding-small.yoga-cta {
    min-height: auto;
  }

  .section.inner {
    padding-top: 6.5rem;
  }

  .section.hero-yogatherapie {
    padding-top: 8rem;
  }

  .buttons {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-wrap: wrap;
    display: flex;
  }

  .text-large.schedule-card-value.schedule-card-value-small-text {
    font-size: 1.125rem;
  }

  .heading-medium {
    font-size: 2.625rem;
  }

  .heading-small {
    font-size: 1.625rem;
    line-height: 1.1em;
  }

  .heading-large {
    font-size: 3.625rem;
  }

  .hero-title-text {
    display: inline;
  }

  .hero-video-wrapper {
    max-width: 18.125rem;
  }

  .section-header {
    margin-bottom: 2.5rem;
  }

  .sessions-wrapper {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .sessions-sticky {
    flex-direction: row;
    justify-content: flex-start;
    padding-bottom: 2rem;
    position: static;
    overflow: auto;
  }

  .sessions-sticky-wrapper {
    flex: none;
    justify-content: flex-start;
    padding-left: 0;
    padding-right: 0;
  }

  .experts-content {
    grid-row-gap: 1.25rem;
  }

  .experts-content.is-align-left {
    text-align: center;
    justify-content: center;
    align-items: center;
  }

  .experts-image-wrapper {
    max-width: 18.125rem;
  }

  .experts-image-wrapper.is-audio {
    max-width: 25rem;
  }

  .instructors-wrapper {
    justify-content: flex-start;
    margin-left: -1rem;
    margin-right: -1rem;
    padding-bottom: 2rem;
    overflow: auto;
  }

  .instructors-list {
    flex-flow: wrap;
    max-width: 95vw;
  }

  .instructors-item {
    max-width: 90%;
  }

  .instructor-card {
    grid-column-gap: 2rem;
    flex-flow: row;
    justify-content: flex-start;
    align-items: center;
  }

  .instructor-card-info {
    text-align: left;
    justify-content: flex-start;
    align-items: flex-start;
    min-width: 50%;
  }

  .instructors-inner {
    flex: none;
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .reviews-wrapper {
    margin-left: -1rem;
    margin-right: -1rem;
  }

  .plans-list {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .plans-item {
    min-width: 24rem;
  }

  .plan-wrapper {
    padding: 2rem;
  }

  .plan-features {
    margin-top: 2rem;
    padding-top: 2rem;
  }

  .tabs-menu {
    flex-flow: row;
    justify-content: flex-start;
    align-items: center;
    padding-bottom: .75rem;
    padding-left: 1rem;
    padding-right: 1rem;
    overflow: scroll;
  }

  .tabs {
    margin-left: -1rem;
    margin-right: -1rem;
  }

  .tabs-content {
    margin-top: 1.75rem;
  }

  .schedule-card {
    grid-template-columns: 1fr;
    justify-content: space-between;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
  }

  .schedule-card-field {
    justify-content: center;
    align-items: center;
  }

  .schedule-card-field.mobile-hidden {
    justify-content: space-between;
    align-items: center;
    display: flex;
  }

  .mobile-hidden {
    display: none;
  }

  .text-small {
    font-size: .875rem;
    line-height: 1em;
  }

  .text-small.text-font-medium.mobile-visible {
    display: none;
  }

  .mobile-visible {
    display: flex;
  }

  .contact-content {
    grid-row-gap: 1.25rem;
  }

  .contact-image-wrapper {
    max-width: 18.125rem;
  }

  .footer-top {
    margin-bottom: 2.5rem;
    padding-bottom: 2.5rem;
  }

  .link-to-top.mobile-visible {
    margin-left: auto;
    display: flex;
  }

  .footer-bootom.color-gray-200 {
    grid-row-gap: .625rem;
    flex-direction: column;
    align-items: center;
    margin-top: 2.5rem;
  }

  .plans-wrapper {
    margin-left: -1rem;
    margin-right: -1rem;
  }

  .modal-content {
    border-radius: 40px;
    padding: 3.75rem 2.5rem 2.5rem;
  }

  .modal-close {
    top: 1rem;
    right: 2rem;
  }

  .font-family-main.utility-page-title {
    font-size: 15rem;
  }

  .contact-image-wrapper-cal {
    max-width: 18.125rem;
  }

  .h2-smaller {
    font-size: 2.25rem;
  }

  .text-dual-col {
    column-count: 1;
  }

  .wrapper-txt-tarifs-lieux {
    justify-content: center;
    align-items: center;
  }

  .wrapper-txt-tarifs-lieux.is-not-in-planning {
    justify-content: center;
    align-items: flex-start;
  }

  .img-tarifs-lieux.is-prez-lieux.is-in-planning {
    display: none;
  }

  .div-block-2 {
    flex-flow: column;
  }

  .wrapper-lieux.is-in-planning {
    justify-content: center;
    align-items: center;
  }

  .wrapper-samedi-yoga {
    flex-flow: column;
    padding-left: 24px;
  }

  .experts-image-wrapper-samedi-yoga {
    max-width: 18.125rem;
  }

  .wrapper-pillars {
    text-align: left;
  }

  .wrapper-img-ambiance {
    grid-template-columns: 1fr;
  }

  .img-amabiance {
    border-radius: 16px;
  }

  .img-amabiance.is-brighter.is-hidden-on-mobile {
    display: none;
  }

  .time-wrapper {
    justify-content: center;
    font-size: .8em;
  }
}

@media screen and (max-width: 479px) {
  .button.button-green.subscribe-button {
    align-self: stretch;
    position: relative;
    top: 0;
    right: 0;
  }

  .text-large.schedule-card-value {
    font-size: 1.125rem;
  }

  .text-italic.subscribe-title {
    text-align: center;
  }

  .sessions-item {
    width: 90vw;
    max-width: 20rem;
  }

  .instructor-card {
    flex-flow: column;
  }

  .instructor-card-image-wrapper {
    aspect-ratio: 1.44;
    width: 100%;
    position: relative;
  }

  .instructor-card-image {
    position: absolute;
    inset: 0%;
  }

  .instructor-card-info {
    text-align: center;
    justify-content: center;
    align-items: center;
  }

  .reviews-item {
    max-width: 21.5rem;
  }

  .reviews-inner {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .plans-list {
    flex: none;
  }

  .plans-item {
    flex: none;
    width: 21.5rem;
    min-width: auto;
    max-width: 90vw;
  }

  .plan-wrapper {
    padding: 1rem;
  }

  .plan-features {
    grid-row-gap: 3rem;
  }

  .plan-features.is-test {
    grid-row-gap: 1rem;
  }

  .schedule-card {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    align-content: center;
    align-items: center;
  }

  .schedule-card-image-wrapper {
    display: none;
  }

  .subscribe {
    width: 100%;
  }

  .form-subscribe-wrapper {
    grid-row-gap: .625rem;
    flex-direction: column;
    align-items: center;
    display: flex;
  }

  .text-field-subscribe {
    height: 4.5625rem;
    padding-right: 2.25rem;
  }

  .link-to-top.mobile-visible {
    display: none;
  }

  .link-to-top.mobile-small-visible {
    transition: color .3s;
    display: flex;
  }

  .footer-content {
    justify-content: center;
  }

  .footer-info {
    max-width: none;
  }

  .footer-navigation {
    grid-column-gap: 2rem;
    flex: 1;
    justify-content: space-between;
  }

  .mobile-small-visible {
    display: flex;
  }

  .modal-content {
    border-radius: 50px;
    padding-bottom: 2rem;
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }

  .font-family-main.utility-page-title {
    font-size: 10rem;
  }

  .wrapper-tarif-1 {
    background-color: var(--pudra-100);
    border-radius: 16px;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    padding: 16px;
  }

  .wrapper-txt-tarifs-lieux {
    text-align: center;
  }

  .img-tarifs-lieux.is-prez-lieux {
    width: 72px;
    height: 72px;
  }

  .wrapper-pres-lieux {
    flex-flow: column;
  }

  .wrapper-lieux {
    flex-flow: row;
  }

  .wrapper-samedi-yoga {
    padding-left: 16px;
    padding-right: 16px;
  }

  .wrapper-pillars {
    text-align: center;
    flex-flow: column;
    justify-content: center;
    align-items: center;
  }

  .wrapper-txt-pillars {
    text-align: center;
    justify-content: center;
    align-items: center;
  }
}

#w-node-d14a3a77-1228-168f-6539-8daceb9b22ce-3767c1c3 {
  grid-area: 1 / 2 / 4 / 3;
  justify-self: end;
}

#w-node-a4292ff9-0fa9-a816-f65d-40b2ecfc0c9c-3767c1c3 {
  grid-area: 2 / 1 / 3 / 2;
}

#w-node-_8471499b-fddb-3aeb-be12-50dcdd601729-3767c1c3, #w-node-_5a87a1e5-d43e-2b4e-52c7-0c2d8b417248-3767c1c3 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_73390dcd-ad09-de84-43c0-f41b68edcd8e-3767c1c3, #w-node-d04b7f6e-40ae-0f42-2074-829006388a0f-3767c1c3 {
  grid-area: span 2 / span 1 / span 2 / span 1;
}

#w-node-_1a112436-727c-4862-5fe8-85033cb3531c-3767c1c3, #w-node-_1a112436-727c-4862-5fe8-85033cb35324-3767c1c3, #w-node-_9990c2a9-c720-a181-f51d-1289025ca0da-3767c1c3, #w-node-df18febd-52d8-d60c-05da-e28f245910a0-3767c1c3, #w-node-df18febd-52d8-d60c-05da-e28f245910ab-3767c1c3, #w-node-df18febd-52d8-d60c-05da-e28f245910b0-3767c1c3, #w-node-e3546655-7b8f-a3d4-3d6e-9a5cbf9273ad-3767c1c3, #w-node-e3546655-7b8f-a3d4-3d6e-9a5cbf9273b6-3767c1c3, #w-node-e3546655-7b8f-a3d4-3d6e-9a5cbf9273bb-3767c1c3, #w-node-_3b09c23d-85f0-bfb5-f948-8108f876ec92-3767c1c3, #w-node-_3b09c23d-85f0-bfb5-f948-8108f876ec9d-3767c1c3, #w-node-_3b09c23d-85f0-bfb5-f948-8108f876eca2-3767c1c3, #w-node-_5b307ebc-c6f0-eaa3-1c5b-d742043bcf1e-3767c1c3, #w-node-_5b307ebc-c6f0-eaa3-1c5b-d742043bcf29-3767c1c3, #w-node-_5b307ebc-c6f0-eaa3-1c5b-d742043bcf2e-3767c1c3, #w-node-_33d7d44c-65de-6c92-e804-c4cc545334ff-3767c1c3, #w-node-_33d7d44c-65de-6c92-e804-c4cc5453350a-3767c1c3, #w-node-_33d7d44c-65de-6c92-e804-c4cc5453350f-3767c1c3, #w-node-_50b96b2b-3711-994e-dadd-0d88f1d36f6b-3767c1c3, #w-node-_50b96b2b-3711-994e-dadd-0d88f1d36f74-3767c1c3, #w-node-_50b96b2b-3711-994e-dadd-0d88f1d36f79-3767c1c3, #w-node-fb4bcff7-8ab6-70ae-8a49-70c1279de64c-3767c1c3, #w-node-fb4bcff7-8ab6-70ae-8a49-70c1279de655-3767c1c3, #w-node-fb4bcff7-8ab6-70ae-8a49-70c1279de65a-3767c1c3, #w-node-_1ebf23c9-e27b-dd38-3748-66195946a5b6-3767c1c3, #w-node-_1ebf23c9-e27b-dd38-3748-66195946a5c1-3767c1c3, #w-node-_1ebf23c9-e27b-dd38-3748-66195946a5c6-3767c1c3, #w-node-_957f1c62-6e9a-43a6-e3bc-302db349d701-3767c1c3, #w-node-_957f1c62-6e9a-43a6-e3bc-302db349d70c-3767c1c3, #w-node-_957f1c62-6e9a-43a6-e3bc-302db349d711-3767c1c3, #w-node-c85a2673-d63f-56ef-a89b-b8a93f141886-3767c1c3, #w-node-c85a2673-d63f-56ef-a89b-b8a93f14188f-3767c1c3, #w-node-c85a2673-d63f-56ef-a89b-b8a93f141894-3767c1c3, #w-node-dac00dc2-b5df-47d3-23df-08c844175a0e-3767c1c3, #w-node-dac00dc2-b5df-47d3-23df-08c844175a19-3767c1c3, #w-node-dac00dc2-b5df-47d3-23df-08c844175a1e-3767c1c3, #w-node-_7c2e2896-0421-8f41-f35b-0b5b6dd3ef1f-3767c1c3, #w-node-_7c2e2896-0421-8f41-f35b-0b5b6dd3ef2a-3767c1c3, #w-node-_7c2e2896-0421-8f41-f35b-0b5b6dd3ef2f-3767c1c3, #w-node-f480ca7c-2839-ae3b-7f2b-78eaffcfc62e-3767c1d2, #w-node-b2bf0dc4-5ef8-78e2-b626-bcd6a90a3513-3767c1d2, #w-node-_76162cae-dce0-b4c8-ac63-25324722e19a-3767c1d2, #w-node-_2b3aaff7-e40b-1440-29dd-e4c680b8fe66-3767c1d2, #w-node-aaf0cf1c-6960-0be4-3fcb-62c10e628bc6-3767c1d2, #w-node-ecd58bea-f4c3-2074-5883-973c635087f1-3767c1d2, #w-node-_83d64447-8e41-a611-a12d-da911fe72436-3767c1d2, #w-node-_9deb6472-9baa-aea6-eca8-ee6c9d9ba246-3767c1d2, #w-node-_715bd7d5-18fe-9598-d8ed-13397a7913c5-3767c1d2, #w-node-_9f91efa6-ceee-0f8f-e256-e3162267ac3b-3767c1d2, #w-node-_0e057f6b-1a5b-54b6-11a3-33d85d6ede81-3767c1d2, #w-node-ae25bdb5-dcd8-638e-32f1-6d64c482bb7e-3767c1d2, #w-node-_347fa478-4d29-3889-1cf2-b49c3a201dbc-3767c1d2, #w-node-d6678321-cb6e-7be5-75d6-3f80abdf7fe3-3767c1d2, #w-node-_1b0da09f-3d16-0348-0113-0a38bbca1eb4-3767c1d2 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}


@font-face {
  font-family: 'Playfairdisplay';
  src: url('../fonts/PlayfairDisplay-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Playfairdisplay';
  src: url('../fonts/PlayfairDisplay-Italic.woff2') format('woff2');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Poppins';
  src: url('../fonts/Poppins-Regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Poppins';
  src: url('../fonts/Poppins-Medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}