.desktop {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  background-color: var(--surface-bg);
}

.desktop .navigation {
  display: flex;
  flex-direction: column;
  max-width: var(--design-max-width);
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 var(--design-x-padding);
  width: 100%;
  height: 60px;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 10;
  background-color: var(--surface-bg);
  border-bottom: 1px solid var(--seperator-line);
}

#main, #about, #program, #price, #contact {
  scroll-margin-top: 60px;
}

.desktop .frame {
  display: flex;
  height: 35px;
  align-items: center;
  justify-content: space-between;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.desktop .div {
  flex-grow: 1;
  position: relative;
  width: 74.29px;
  height: 19.62px;
}

.desktop .navbar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  position: relative;
  flex: 0 0 auto;
}

.desktop .link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.desktop .navbar .link .text {
  color: var(--nav-link-default);
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
}

.desktop .navbar .link .text:hover {
  color: var(--nav-link-hover);
}

.desktop .navbar .link.active .text {
  color: var(--nav-link-active);
  border-bottom: 2px solid var(--nav-link-active);
}

.desktop .frame-2 {
  flex-grow: 1;
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
  gap: 28px;
}

.desktop .frame-3 {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  position: relative;
  flex: 0 0 auto;
}

.desktop .icon-box {
  display: flex;
  flex-direction: column;
  width: 32px;
  height: 32px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  background-color: var(--surface-primary);
  border-radius: 48px;
  aspect-ratio: 1;
  transition: all 0.3s ease;
}

.desktop .icon-box:hover {
  background-color: var(--surface-secondary);
}

.sidemenu-hider {
  position: fixed;
  top: 0;
  width: 100vw;
  height: 100vh;
  z-index: 1000;
}

.sidemenu-container {
  background-color: var(--sidemenu-bg);
  display: flex;
  flex-direction: row-reverse;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: all 0.3s ease;
}

.sidemenu {
  padding: 16px;
  display: flex;
  gap: 40px;
  flex-direction: column;
  background-color: var(--sidemenu-surface);
  width: 300px;
  height: 100%;
  /* transform: translate(768px); */
  transform: translate(300px);
  transition: all 0.3s ease;
}

#sidemenu-wrapper {
  display: none;
}

#sidemenu-wrapper.open .sidemenu-container {
  opacity: 1;
}

#sidemenu-wrapper.open .sidemenu {
  transform: translate(0);
}

.sidemenu-nav {
  list-style: none;
  padding: 0;
}

.sidemenu-link {
  margin: 8px 0;
}

.sidemenu-nav > li > a {
  color: var(--sidemenu-text-default);
}

.sidemenu-nav > li.active > a {
  color: var(--sidemenu-text-active);
}

.type-toggle-state {
  display: none;
  flex-direction: column;
  width: 32px;
  height: 32px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  background-color: var(--surface-primary);
  border-radius: 8px;
  aspect-ratio: 1;
  transition: all 0.3s ease;
}

.desktop .type-toggle-state:hover {
  background-color: var(--surface-secondary);
}

.desktop .img {
  position: relative;
  width: 24px;
  height: 24px;
  aspect-ratio: 1;
}

.desktop .main-container {
  width: 100%;
  gap: var(--sections-space);
  padding: var(--sections-space) 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.desktop .div-wrapper {
  display: flex;
  flex-direction: column;
  max-width: var(--design-max-width);
  align-items: center;
  gap: 10px;
  padding: 0 var(--design-x-padding);
  position: relative;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .main {
  justify-content: center;
  gap: var(--content-space-2);
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .div-2 {
  gap: var(--content-space-1);
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .price {
  gap: var(--content-space-2);
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .text-wrapper-2 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  /* font-family: var(--heading-1-font-family);
  font-weight: var(--heading-1-font-weight); */
  color: var(--text-primary);
  /* font-size: var(--heading-1-font-size); */
  text-align: center;
  /* letter-spacing: var(--heading-1-letter-spacing);
  line-height: var(--heading-1-line-height);
  font-style: var(--heading-1-font-style); */
}

.desktop .p {
  padding: 10px 0;
  position: relative;
  align-self: stretch;
  color: var(--text-secondary);
  text-align: center;
}

.desktop .button-primary {
  /* all: unset; */
  box-sizing: border-box;
  width: 180px;
  height: 57px;
  background-color: var(--button-primary-default);
  border-radius: 40px;
  box-shadow: var(--button-shadow);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
}

.desktop .button-primary:hover {
  background-color: var(--button-primary-hover);
}

.desktop .text-wrapper-3 {
  color: var(--text-primary);
  text-align: center;
}

.desktop .frame-wrapper {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .frame-4 {
  position: relative;
  width: 814px;
  height: 167px;
}

.desktop .frame-5 {
  display: flex;
  width: 300px;
  height: 80px;
  align-items: center;
  justify-content: space-between;
  padding: 16px 25px;
  position: absolute;
  top: 79px;
  left: 264px;
  background-color: var(--surface-primary);
  transform: rotate(3.00deg);
  box-shadow: var(--card-shadow-default);
}

.desktop .text-wrapper-4 {
  position: relative;
  width: fit-content;
  font-size: var(--text-lg);
  font-weight: var(--fw-regular);
  color: var(--text-primary);
}

.desktop .icon-park-outline {
  position: relative;
  width: 50.45px;
  height: 50.45px;
  margin-top: -1.22px;
  margin-bottom: -1.22px;
  margin-right: -1.22px;
  transform: rotate(-3.00deg);
  aspect-ratio: 1;
}

.desktop .frame-6 {
  display: flex;
  width: 300px;
  height: 80px;
  align-items: center;
  justify-content: space-between;
  padding: 16px 25px;
  position: absolute;
  top: 38px;
  left: 4px;
  background-color: var(--surface-primary);
  transform: rotate(-7.00deg);
  box-shadow: var(--card-shadow-default);
}

.desktop .icon-park-outline-2 {
  width: 53.49px;
  height: 53.49px;
  margin-top: -2.75px;
  margin-bottom: -2.75px;
  margin-right: -2.75px;
  transform: rotate(7.00deg);
  position: relative;
  aspect-ratio: 1;
}

.desktop .frame-7 {
  display: flex;
  width: 300px;
  height: 80px;
  align-items: center;
  justify-content: space-between;
  padding: 16px 25px;
  position: absolute;
  top: 13px;
  left: 511px;
  background-color: var(--surface-primary);
  transform: rotate(-5.00deg);
  box-shadow: var(--card-shadow-default);
}

.desktop .icon-park-outline-3 {
  width: 52px;
  height: 52px;
  margin-top: -2.00px;
  margin-bottom: -2.00px;
  margin-right: -2.00px;
  transform: rotate(5.00deg);
  position: relative;
  aspect-ratio: 1;
}

.desktop .div-wrapper-2 {
  display: flex;
  flex-direction: column;
  max-width: var(--design-max-width);
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 var(--design-x-padding);
  position: relative;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .about {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--content-space-2);
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .frame-8 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: var(--content-space-1);
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .text-wrapper-5 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  color: var(--text-primary);
}

.desktop .text-wrapper-6 {
  position: relative;
  color: var(--text-secondary);
}

.desktop .frame-9 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-around;
  gap: 48px 24px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .card {
  display: flex;
  flex-direction: column;
  width: 300px;
  height: 380px;
  align-items: center;
  gap: 20px;
  padding: 20px 21px;
  position: relative;
  background-color: var(--surface-primary);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--card-shadow-default);
  transition: all 0.3s ease;
}

.desktop .card:hover {
  box-shadow: var(--card-shadow-hover);
}

.desktop .title {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  color: var(--text-primary);
  text-align: center;
}

.desktop .img-2 {
  position: relative;
  width: 84px;
  height: 84px;
  aspect-ratio: 1;
}

.desktop .content {
  position: relative;
  align-self: stretch;
  color: var(--text-secondary);
}

.desktop .program {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--content-space-2);
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .text-wrapper-7 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  /* font-family: var(--heading-2-font-family);
  font-weight: var(--heading-2-font-weight); */
  color: var(--text-primary);
  /* font-size: var(--heading-2-font-size);
  letter-spacing: var(--heading-2-letter-spacing);
  line-height: var(--heading-2-line-height);
  font-style: var(--heading-2-font-style); */
}

.desktop .frame-10 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 28px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .frame-11 {
  display: flex;
  align-items: start;
  gap: 24px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .img-3 {
  position: relative;
  width: 68px;
  height: 68px;
  aspect-ratio: 1;
}

.desktop .frame-12 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  position: relative;
  flex: 1;
  align-self: stretch;
  flex-grow: 1;
}

.desktop .text-wrapper-8 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  /* font-family: var(--heading-3-font-family);
  font-weight: var(--heading-3-font-weight); */
  color: var(--text-primary);
  /* font-size: var(--heading-3-font-size);
  letter-spacing: var(--heading-3-letter-spacing);
  line-height: var(--heading-3-line-height);
  font-style: var(--heading-3-font-style); */
}

.desktop .text-wrapper-9 {
  position: relative;
  align-self: stretch;
  /* font-family: var(--body-2-font-family);
  font-weight: var(--body-2-font-weight); */
  color: var(--text-secondary);
  /* font-size: var(--body-2-font-size);
  letter-spacing: var(--body-2-letter-spacing);
  line-height: var(--body-2-line-height);
  font-style: var(--body-2-font-style); */
}

.desktop .text-wrapper-10 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  /* font-family: var(--heading-1-font-family);
  font-weight: var(--heading-1-font-weight); */
  color: var(--text-primary);
  /* font-size: var(--heading-1-font-size); */
  text-align: center;
  /* letter-spacing: var(--heading-1-letter-spacing);
  line-height: var(--heading-1-line-height);
  font-style: var(--heading-1-font-style); */
}

.desktop .price-cards {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-around;
  gap: 48px 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .price-card {
  display: flex;
  flex-direction: column;
  width: 350px;
  height: 830px;
  align-items: center;
  justify-content: space-between;
  padding: 24px 16px;
  position: relative;
  background-color: var(--surface-primary);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--card-shadow-default);
}

.desktop .frame-13 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 30px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .frame-14 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .text-wrapper-11 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  color: var(--text-primary);
  text-align: center;
}

.desktop .text-wrapper-12 {
  position: relative;
  width: fit-content;
  color: var(--text-secondary);
  text-align: center;
}

.desktop .line {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 1px;
  object-fit: cover;
}

.desktop .text-wrapper-13 {
  display: flex;
  align-items: center;
  position: relative;
  align-self: stretch;
  color: var(--text-primary);
}
.text-wrapper-13 svg * {
  fill: var(--text-primary);
}

.price-number {
  display: inline-flex;
}

.desktop .frame-15 {
  display: flex;
  width: 100%;
  align-items: flex-start;
  gap: 14px;
  position: relative;
  flex: 0 0 auto;
}

.desktop .text-wrapper-14 {
  position: relative;
  flex: 1;
  margin-top: -1.00px;
  color: var(--text-secondary);
}

.desktop .price-button {
  width: 100%;
}

.desktop .BUY {
  color: var(--text-primary);
  text-align: center;
}

.desktop .contact-2 {
  gap: var(--content-space-2);
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .footer-wrapper {
  max-width: var(--design-max-width);
  gap: 18px;
  padding: 0 var(--design-x-padding);
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .footer {
  gap: 12px;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .frame-16 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .text-wrapper-15 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  /* font-family: var(--heading-2-font-family);
  font-weight: var(--heading-2-font-weight); */
  color: var(--text-primary);
  /* font-size: var(--heading-2-font-size); */
  text-align: center;
  /* letter-spacing: var(--heading-2-letter-spacing);
  line-height: var(--heading-2-line-height);
  font-style: var(--heading-2-font-style); */
}

.desktop .frame-17 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .vertical-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 24px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  border-radius: 18px;
  transition: all 0.3s ease;
}

.desktop .vertical-card:hover {
  background-color: var(--surface-primary);}

.desktop .img-wrapper {
  display: flex;
  width: 48px;
  height: 48px;
  padding: 12px;
  background-color: var(--surface-secondary);
  border-radius: 48px;
  aspect-ratio: 1;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
}

.desktop .text-wrapper-16 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  /* font-family: var(--body-2-font-family);
  font-weight: var(--body-2-font-weight); */
  color: var(--text-secondary);
  /* font-size: var(--body-2-font-size); */
  /* letter-spacing: var(--body-2-letter-spacing);
  line-height: var(--body-2-line-height);
  font-style: var(--body-2-font-style); */
}

.desktop .frame-18 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px 0;
  gap: 28px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.desktop .text-wrapper-17 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  color: var(--text-secondary);
  text-align: center;
}

.desktop .frame-19 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 32px;
  position: relative;
  flex: 0 0 auto;
}

.desktop .icon-box-2 {
  display: inline-flex;
  padding: 8px;
  flex: 0 0 auto;
  background-color: var(--surface-primary);
  border-radius: 12px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  transition: all 0.3s ease;
}

.desktop .icon-box-2:hover {
  background-color: var(--surface-secondary);
}

.desktop .img-4 {
  position: relative;
  width: 48px;
  height: 48px;
  aspect-ratio: 1;
}

.horizontal-line {
  width: 100%;
  height: 1px;
  background-color: var(--seperator-line);
}

.desktop .text-wrapper-contact {
  position: relative;
  color: var(--text-primary);
  word-break: break-all;
}

.desktop .text-wrapper-contact:hover {
  text-decoration: underline;
  color: var(--text-brand)
}











