/**
 * YUI 3.5.0 - reset.css (http://developer.yahoo.com/yui/3/cssreset/)
 * https://cssdeck.com/blog/
 * Copyright 2012 Yahoo! Inc. All rights reserved.
 * http://yuilibrary.com/license/
 */
/*
	TODO will need to remove settings on HTML since we can't namespace it.
	TODO with the prefix, should I group by selector or property for weight savings?
*/
html {
  color: #000;
  background: #FFF;
}

/*
	TODO remove settings on BODY since we can't namespace it.
*/
/*
	TODO test putting a class on HEAD.
		- Fails on FF.
*/
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
pre,
code,
form,
fieldset,
legend,
input,
textarea,
p,
blockquote,
th,
td {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset,
img {
  border: 0;
}

/*
	TODO think about hanlding inheritence differently, maybe letting IE6 fail a bit...
*/
address,
caption,
cite,
code,
dfn,
em,
strong,
th,
var {
  font-style: normal;
  font-weight: normal;
}

ol,
ul {
  list-style: none;
}

caption,
th {
  text-align: left;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
}

q:before,
q:after {
  content: "";
}

abbr,
acronym {
  border: 0;
  font-variant: normal;
}

/* to preserve line-height and selector appearance */
sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

input,
textarea,
select {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
}

/*to enable resizing for IE*/
input,
textarea,
select {
  *font-size: 100%;
}

/*because legend doesn't inherit in IE */
legend {
  color: #000;
}

/* YUI CSS Detection Stamp */
#yui3-css-stamp.cssreset {
  display: none;
}

a {
  text-decoration: none;
  color: inherit;
}

@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-Thin.ttf) format("truetype"), url(../fonts/outfit/Outfit-Thin.woff) format("woff"), url(../fonts/outfit/Outfit-Thin.svg) format("svg"), url(../fonts/outfit/Outfit-Thin.eot) format("embedded-opentype");
  font-weight: 100;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-ExtraLight.ttf) format("truetype"), url(../fonts/outfit/Outfit-ExtraLight.woff) format("woff"), url(../fonts/outfit/Outfit-ExtraLight.svg) format("svg"), url(../fonts/outfit/Outfit-ExtraLight.eot) format("embedded-opentype");
  font-weight: 200;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-Light.ttf) format("truetype"), url(../fonts/outfit/Outfit-Light.woff) format("woff"), url(../fonts/outfit/Outfit-Light.svg) format("svg"), url(../fonts/outfit/Outfit-Light.eot) format("embedded-opentype");
  font-weight: 300;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-Regular.ttf) format("truetype"), url(../fonts/outfit/Outfit-Regular.woff) format("woff"), url(../fonts/outfit/Outfit-Regular.svg) format("svg"), url(../fonts/outfit/Outfit-Regular.eot) format("embedded-opentype");
  font-weight: 400;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-Medium.ttf) format("truetype"), url(../fonts/outfit/Outfit-Medium.woff) format("woff"), url(../fonts/outfit/Outfit-Medium.svg) format("svg"), url(../fonts/outfit/Outfit-Medium.eot) format("embedded-opentype");
  font-weight: 500;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-SemiBold.ttf) format("truetype"), url(../fonts/outfit/Outfit-SemiBold.woff) format("woff"), url(../fonts/outfit/Outfit-SemiBold.svg) format("svg"), url(../fonts/outfit/Outfit-SemiBold.eot) format("embedded-opentype");
  font-weight: 600;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-Bold.ttf) format("truetype"), url(../fonts/outfit/Outfit-Bold.woff) format("woff"), url(../fonts/outfit/Outfit-Bold.svg) format("svg"), url(../fonts/outfit/Outfit-Bold.eot) format("embedded-opentype");
  font-weight: 700;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-ExtraBold.ttf) format("truetype"), url(../fonts/outfit/Outfit-ExtraBold.woff) format("woff"), url(../fonts/outfit/Outfit-ExtraBold.svg) format("svg"), url(../fonts/outfit/Outfit-ExtraBold.eot) format("embedded-opentype");
  font-weight: 800;
}
@font-face {
  font-family: "Outfit";
  src: url(../fonts/outfit/Outfit-Black.ttf) format("truetype"), url(../fonts/outfit/Outfit-Black.woff) format("woff"), url(../fonts/outfit/Outfit-Black.svg) format("svg"), url(../fonts/outfit/Outfit-Black.eot) format("embedded-opentype");
  font-weight: 900;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-Regular.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-Regular.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-Regular.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-Regular.eot) format("embedded-opentype");
  font-weight: 400;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-Italic.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-Italic.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-Italic.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-Italic.eot) format("embedded-opentype");
  font-weight: 400;
  font-style: italic;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-Book.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-Book.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-Book.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-Book.eot) format("embedded-opentype");
  font-weight: 300;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-BookItalic.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-BookItalic.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-BookItalic.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-BookItalic.eot) format("embedded-opentype");
  font-weight: 300;
  font-style: italic;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-Medium.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-Medium.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-Medium.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-Medium.eot) format("embedded-opentype");
  font-weight: 500;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-MediumItalic.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-MediumItalic.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-MediumItalic.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-MediumItalic.eot) format("embedded-opentype");
  font-weight: 500;
  font-style: italic;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-Bold.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-Bold.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-Bold.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-Bold.eot) format("embedded-opentype");
  font-weight: 700;
}
@font-face {
  font-family: "SuisseWorks";
  src: url(../fonts/suisseworks/SuisseWorks-BoldItalic.ttf) format("truetype"), url(../fonts/suisseworks/SuisseWorks-BoldItalic.woff) format("woff"), url(../fonts/suisseworks/SuisseWorks-BoldItalic.svg) format("svg"), url(../fonts/suisseworks/SuisseWorks-BoldItalic.eot) format("embedded-opentype");
  font-weight: 700;
  font-style: italic;
}
html, body {
  color: #333;
  font-family: "Outfit", sans-serif;
  font-size: 16px;
  line-height: 20px;
}

.container {
  margin: 0 auto;
  max-width: 1280px;
  padding: 0 20px;
}

h1 {
  font-size: 3.75rem;
  font-weight: 600;
  line-height: 1.2;
  color: #315f5e;
}
h1 em {
  opacity: 0.7;
  font-family: "SuisseWorks", serif;
  font-weight: 400;
  font-style: normal;
}
@media only screen and (max-width: 767px) {
  h1 {
    font-size: 2.25rem;
  }
}

h2 {
  font-size: 2.25rem;
  font-weight: 600;
  line-height: 1.3;
  color: #315f5e;
}
h2 em {
  opacity: 0.7;
  font-family: "SuisseWorks", serif;
  font-weight: 400;
  font-style: normal;
}
@media only screen and (max-width: 767px) {
  h2 {
    font-size: 1.75rem;
  }
}

h3 {
  font-size: 1.875rem;
  font-weight: 600;
  line-height: 1.4;
  color: #315f5e;
}
h3 em {
  opacity: 0.7;
  font-family: "SuisseWorks", serif;
  font-weight: 400;
  font-style: normal;
}
@media only screen and (max-width: 767px) {
  h3 {
    font-size: 1.4rem;
  }
}

h4 {
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.4;
  color: #315f5e;
}
h4 em {
  opacity: 0.7;
  font-family: "SuisseWorks", serif;
  font-weight: 400;
  font-style: normal;
}

.subheading {
  color: #315f5e;
  margin-bottom: 12px;
  line-height: 1.5;
  font-weight: 700;
  text-transform: uppercase;
}

.hactions {
  font-size: 1rem;
  margin: 30px 0 0;
  display: flex;
  gap: 0.75rem;
}
@media only screen and (max-width: 767px) {
  .hactions {
    flex-direction: column;
    text-align: center;
  }
}
.hactions .button {
  display: block;
}

.button, button {
  -webkit-appearance: none;
  outline: none;
  cursor: pointer;
  display: inline-block;
  line-height: 24px;
  padding: 10px 18px;
  border: 1px solid #359e9c;
  background: #359e9c;
  transition: 0.3s;
  border-radius: 8px;
  color: #ffffff;
  font-weight: 600;
}
.button:hover, button:hover {
  background: #315f5e;
}

.h-newsletter {
  font-size: 1rem;
}
.h-newsletter .row {
  display: flex;
  gap: 12px;
}
@media only screen and (max-width: 767px) {
  .h-newsletter .row {
    flex-direction: column;
  }
  .h-newsletter .row input {
    height: 44px;
  }
}
.h-newsletter input {
  display: block;
  flex-grow: 1;
  -webkit-appearance: none;
  padding: 0 12px;
  border: 1px solid #d0d5dd;
  background: #ffffff;
  border-radius: 8px;
}
.h-newsletter button {
  display: block;
  flex-shrink: 0;
}
.h-newsletter .note {
  margin-top: 12px;
  font-size: 0.875rem;
  color: #203c3b;
}
.h-newsletter .note a {
  text-decoration: underline;
}

.content-share {
  display: flex;
  gap: 0.5rem;
}
.content-share > a {
  display: block;
  box-sizing: border-box;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  border: 1px solid #d0d5dd;
  overflow: hidden;
  text-indent: -10000px;
  position: relative;
}
.content-share > a::before {
  position: absolute;
  width: 20px;
  height: 20px;
  top: calc(50% - 10px);
  left: calc(50% - 10px);
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
}
.content-share > a.copy::before {
  background-image: url("../img/soc-copy.svg");
}
.content-share > a.x::before {
  background-image: url("../img/soc-x.svg");
}
.content-share > a.fb::before {
  background-image: url("../img/soc-fb.svg");
}
.content-share > a.in::before {
  background-image: url("../img/soc-in.svg");
}

.text-content {
  margin-bottom: 4rem;
  color: #203c3b;
}
.text-content h2, .text-content h3, .text-content h4 {
  color: #203c3b;
  margin: 2rem 0;
}
.text-content h2:first-child, .text-content h3:first-child, .text-content h4:first-child {
  margin-top: 0;
}
.text-content p {
  line-height: 1.5;
  margin: 1.5rem 0;
}
.text-content blockquote {
  font-size: 1.125rem;
  font-style: italic;
  font-weight: 500;
}

.btn {
  color: #ffffff;
  text-align: center;
  white-space: nowrap;
  cursor: pointer;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
  display: inline-block;
  background: #359e9c;
  transition: 0.3s;
  border-radius: 0.5rem;
  padding: 0.625rem 1.125rem;
}
.btn:hover {
  background: #315f5e;
}

.gen-list {
  padding: 4rem 0;
}
.gen-list .list-filter {
  display: flex;
  justify-content: center;
  margin-bottom: 4rem;
  gap: 0.75rem;
  font-weight: 600;
  color: #7e735d;
}
.gen-list .list-items {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}
.gen-list .list-items > li {
  width: calc(33.333% - 1.667rem);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.gen-list .list-items > li .img {
  position: relative;
  width: 100%;
  padding-top: 100%;
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: 1rem;
}
.gen-list .list-items > li .img img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: 0;
  left: 0;
  transform-origin: 50% 50%;
  transform: scale(1);
  transition: 0.3s;
}
.gen-list .list-items > li .cat {
  background: #f6f5f1;
  border-radius: 30px;
  padding: 0.25rem 0.75rem 0.25rem 0.25rem;
}
.gen-list .list-items > li .cat .category {
  padding: 0.25rem 0.75rem;
  border-radius: 30px;
  margin-right: 0.75rem;
  color: #315f5e;
  background: #deebe8;
}
.gen-list .list-items > li .title {
  color: #203c3b;
  margin: 1rem 0;
  font-weight: 600;
  line-height: 1.4;
  font-size: 1.5rem;
}
.gen-list .list-items > li .text {
  color: #203c3b;
  margin-bottom: 1rem;
  line-height: 1.5;
}
.gen-list .list-items > li .more {
  display: inline-block;
  line-height: 20px;
  font-weight: 600;
  color: #359e9c;
  font-size: 1.125rem;
  padding-right: 28px;
  position: relative;
}
.gen-list .list-items > li .more::after {
  width: 20px;
  height: 20px;
  background: url("../img/more.svg") no-repeat 50% 50%/contain;
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  transition: 0.3s;
  transform-origin: 50% 50%;
  transform: rotate(-45deg);
}
.gen-list .list-items > li:hover .img img {
  transform: scale(1.05);
}
.gen-list .list-items > li:hover .more::after {
  transform: rotate(0deg);
}
@media only screen and (max-width: 767px) {
  .gen-list .list-items > li {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .gen-list .list-items {
    flex-direction: column;
  }
}
.gen-list.alt1 .list-items > li .more {
  color: #7e735d;
}
.gen-list.alt1 .list-items > li .more::after {
  background-image: url("../img/more3.svg");
}

header {
  position: relative;
  height: 76px;
}
header > div {
  display: flex;
  height: 76px;
  align-items: center;
}
header .logo {
  flex-shrink: 0;
  margin-right: 2.5rem;
}
header .logo a {
  display: block;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  background: #359e9c;
  position: relative;
  overflow: hidden;
  text-indent: -10000px;
  padding: 4px;
  border: 0.1px solid #dae0e8;
}
header .logo a::before {
  position: absolute;
  top: 4px;
  left: 4px;
  bottom: 4px;
  right: 4px;
  content: "";
  background: url("../img/logo.svg") no-repeat 50% 50%/contain;
}
header nav > ul {
  display: flex;
}
header nav > ul > li > a {
  color: #203c3b;
  font-weight: 600;
  display: block;
  padding: 0 0.75rem 0 0.75rem;
  display: flex;
  align-items: center;
}
header nav > ul > li.has-children > a::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url("../img/dd.svg") no-repeat 50% 50%/contain;
  margin: 0 5px;
  transition: 0.3s;
  transform-origin: 50% 50%;
}
header nav > ul > li.has-children:hover a::after {
  transform: rotate(180deg);
}
header nav > ul > li:hover .subnav {
  opacity: 1;
  visibility: visible;
}
header nav > ul > li .subnav {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  background: #ffffff;
  border-top: 1px solid rgba(107, 112, 148, 0.5);
  box-shadow: 0 12px 16px 0px rgba(0, 0, 0, 0.08), 0 4px 6px 0px rgba(16, 24, 40, 0.03);
  padding-top: 20px;
  padding-bottom: 20px;
  transition: 0.3s;
  opacity: 0;
  visibility: hidden;
}
header nav > ul > li .subnav > div {
  display: flex;
}
header nav > ul > li .subnav .cat {
  width: 100%;
  max-width: 15rem;
  flex-shrink: 0;
  color: #101828;
}
header nav > ul > li .subnav .cat .title {
  font-weight: 600;
  color: #315f5e;
  margin-bottom: 6px;
  font-size: 0.875rem;
}
header nav > ul > li .subnav .cat > ul > li {
  margin-bottom: 2px;
}
header nav > ul > li .subnav .cat > ul > li > a {
  display: inline-block;
  background: transparent;
  padding: 0.75rem;
  border-radius: 0.5rem;
  font-weight: 600;
  font-size: 0.875rem;
  transition: 0.3s;
}
header nav > ul > li .subnav .cat > ul > li > a:hover {
  background: #f9fafb;
}
header nav > ul > li .subnav .cou > ul {
  display: flex;
  flex-wrap: wrap;
}
header nav > ul > li .subnav .cou > ul > li {
  width: 50%;
  display: flex;
  position: relative;
  position: relative;
  box-sizing: border-box;
  padding: 0.75rem;
  border-radius: 0.5rem;
  transition: 0.3s;
}
header nav > ul > li .subnav .cou > ul > li:hover {
  background: #f9fafb;
}
header nav > ul > li .subnav .content {
  flex-grow: 1;
  color: #203c3b;
  font-size: 0.875rem;
  line-height: 1.5;
}
header nav > ul > li .subnav .content .title {
  margin-bottom: 0.25rem;
  font-weight: 600;
  color: #101828;
}
header nav > ul > li .subnav .wlink {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  text-indent: -10000px;
}
header nav > ul > li .subnav .img {
  width: 150px;
  height: 150px;
  overflow: hidden;
  flex-shrink: 0;
  margin-right: 1rem;
  border-radius: 0.375rem;
}
header nav > ul > li .subnav .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
header nav > ul > li .subnav.programs {
  padding-top: 0;
  padding-bottom: 0;
}
header nav > ul > li .subnav.programs::before {
  top: 0;
  left: 50%;
  right: 0;
  bottom: 0;
  background: #f9fafb;
  content: "";
  position: absolute;
}
header nav > ul > li .subnav.programs > .container {
  position: relative;
}
header nav > ul > li .subnav.programs .cat {
  width: 60%;
  max-width: 60%;
  background: #ffffff;
  padding-top: 20px;
  padding-bottom: 20px;
}
header nav > ul > li .subnav.programs .cat > ul > li > a {
  font-weight: 400;
  padding-left: 50px;
  position: relative;
}
header nav > ul > li .subnav.programs .cat > ul > li > a::before {
  position: absolute;
  width: 24px;
  height: 24px;
  content: "";
  top: 0.75rem;
  left: 0.75rem;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
}
header nav > ul > li .subnav.programs .cat > ul > li.pr1 a::before {
  background-image: url("../img/pr1.svg");
}
header nav > ul > li .subnav.programs .cat > ul > li.pr2 a::before {
  background-image: url("../img/pr2.svg");
}
header nav > ul > li .subnav.programs .cat > ul > li.pr3 a::before {
  background-image: url("../img/pr3.svg");
}
header nav > ul > li .subnav.programs .cat strong {
  font-weight: 600;
  display: block;
  margin-bottom: 4px;
}
header nav > ul > li .subnav.programs .join {
  width: 40%;
  background: #f9fafb;
  padding-top: 20px;
  padding-bottom: 20px;
  box-sizing: border-box;
  padding-left: 20px;
}
header nav > ul > li .subnav.programs .join .title {
  font-weight: 600;
  color: #315f5e;
  margin-bottom: 6px;
  font-size: 0.875rem;
}
header nav > ul > li .subnav.programs .join .item {
  position: relative;
  background: transparent;
  padding: 0.75rem;
  border-radius: 0.5rem;
  transition: 0.3s;
  display: flex;
}
header nav > ul > li .subnav.programs .join .item:hover {
  background: #ffffff;
}
header nav > ul > li .subnav.programs .join .item .wlink {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  text-indent: -10000px;
}
header nav > ul > li .subnav.programs .join .item .img {
  width: 185px;
  height: 104px;
  border-radius: 0.375rem;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}
header nav > ul > li .subnav.programs .join .item .img img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
header nav > ul > li .subnav.programs .join .item .content {
  font-size: 0.875rem;
  color: #101828;
}
header nav > ul > li .subnav.programs .join .item .content strong {
  display: block;
  font-weight: 600;
}
header nav > ul > li .subnav.programs .join .item .content strong em {
  font-size: 0.75rem;
  padding: 0 3px;
  margin-left: 4px;
  border-radius: 4px;
  font-weight: 400;
  display: inline-block;
  background: #ecfdf3;
  color: #027a48;
}
header nav > ul > li .subnav.programs .join .item .content div {
  line-height: 1.5;
  margin: 0.5rem 0;
}
header nav > ul > li .subnav.programs .join .item .content .more {
  color: #027a48;
  font-weight: 600;
}
@media only screen and (max-width: 767px) {
  header nav {
    display: none;
  }
}

.user-panel {
  display: flex;
  margin-left: auto;
}
.user-panel a {
  display: block;
  border: 1px solid #d0d5dd;
  background-color: white;
  color: #344054;
  text-align: center;
  white-space: nowrap;
  border-radius: 0.5rem;
  justify-content: center;
  align-items: center;
  margin-bottom: 0;
  padding: 0.625rem 1.125rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, Oxygen, Fira Sans, Droid Sans, sans-serif;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.5;
  text-decoration: none;
  transition: all 0.3s;
  display: flex;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.05);
}
.user-panel a:hover, .user-panel a:focus {
  background-color: #f9fafb;
  color: #1d2939;
}
.user-panel a + a {
  margin-left: 10px;
}
.user-panel a.primary {
  border: 1px solid #35939c;
  background-color: #35939c;
  color: white;
  border-radius: 0.5rem;
}
.user-panel a.primary:hover, .user-panel a.primary:focus {
  background-color: #315f5e;
  border-color: #315f5e;
}

.login-split {
  display: flex;
  min-height: calc(100vh - 50px);
  align-items: center;
}
.login-split > .img-wrapper {
  height: calc(100vh - 50px);
  align-self: stretch;
  width: 45%;
  margin-right: 5%;
}
.login-split > .img-wrapper img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 5%;
     object-position: 50% 5%;
}
.login-split .login-form {
  max-width: 400px;
}
.login-split .login-form h5 {
  color: #315f5e;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Outfit, sans-serif;
  font-size: 2.25rem;
  font-weight: 600;
  line-height: 1.3;
}
.login-split .login-form > form > a {
  display: block;
  margin: 12px 0;
}
.login-split .login-form .error {
  margin: 12px 0;
  color: red;
}
.login-split .login-form .form-field {
  margin-bottom: 12px;
  margin-top: 12px;
}
.login-split .login-form .form-field label {
  display: block;
  color: #344054;
  margin-bottom: 0.5rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, Oxygen, Fira Sans, Droid Sans, sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
}
.login-split .login-form .form-field input {
  width: 100%;
  box-sizing: border-box;
  display: block;
  height: auto;
  min-height: 2.75rem;
  border: 1px solid #d0d5dd;
  background-color: white;
  color: #101828;
  border-radius: 0.5rem;
  margin-bottom: 0;
  padding: 0.5rem 0.875rem;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Noto Sans, Ubuntu, Cantarell, Helvetica Neue, Oxygen, Fira Sans, Droid Sans, sans-serif;
  font-size: 1rem;
  line-height: 1.5;
  transition: all 0.3s;
  box-shadow: 0 1px 2px rgba(16, 24, 40, 0.05);
}

.user-profile-wrapper {
  background: #f6f5f1;
  padding: 80px 0 50px;
}
.user-profile-wrapper .user-profile-container {
  display: flex;
}
.user-profile-wrapper .user-profile-container .content-list {
  margin: 16px 0;
}
.user-profile-wrapper .user-profile-container .content-list li {
  margin-bottom: 8px;
}
.user-profile-wrapper .user-profile-container .user-profile {
  flex-grow: 1;
}
.user-profile-wrapper .user-profile-container .user-profile .profile-settings {
  margin-top: 16px;
}
.user-profile-wrapper .user-profile-container .user-profile-image {
  margin-left: 4rem;
  flex-shrink: 0;
  width: 600px;
  max-width: 50%;
}
.user-profile-wrapper .user-profile-container .user-profile-image .uui-heroheader_image-background {
  border-radius: 20rem 20rem 1.5rem 1.5rem;
  height: 30rem;
  width: 600px;
  max-width: 100%;
  flex-shrink: 0;
  overflow: hidden;
}
.user-profile-wrapper .user-profile-container .user-profile-image .uui-heroheader_image-background img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.pi-video iframe {
  width: 100%;
  height: 100%;
  display: block;
  border: none;
}

.payment-method-list {
  text-align: center;
}

footer {
  padding: 4rem 0;
}
footer .f-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #667085;
  padding-top: 2rem;
  margin-top: 4rem;
  border-top: 1px solid #eaecf0;
  font-size: 0.875rem;
  line-height: 1.5;
}
@media only screen and (max-width: 767px) {
  footer .f-bottom {
    flex-direction: column;
    gap: 1rem;
  }
}
footer .policy {
  display: flex;
  gap: 1rem;
}
footer .flogo {
  align-items: center;
  display: flex;
  margin-bottom: 2rem;
}
footer .flogo .logo {
  flex-shrink: 0;
  margin-right: 0.75rem;
}
footer .flogo .logo a {
  display: block;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  background: #359e9c;
  position: relative;
  overflow: hidden;
  text-indent: -10000px;
  padding: 4px;
  border: 0.1px solid #dae0e8;
}
footer .flogo .logo a::before {
  position: absolute;
  top: 4px;
  left: 4px;
  bottom: 4px;
  right: 4px;
  content: "";
  background: url("../img/logo.svg") no-repeat 50% 50%/contain;
}
footer .flogo .logoe > a {
  width: 160px;
  height: 48px;
  display: block;
  overflow: hidden;
  text-indent: -10000px;
  background: url("../img/flogoe.png") no-repeat 50% 50%/contain;
}
footer .f-top {
  display: flex;
  gap: 100px;
}
footer .f-top > div {
  max-width: 512px;
  width: 100%;
}
footer .f-top .text {
  line-height: 1.5;
  color: #203c3b;
  margin: 2rem 0;
}
footer .f-top nav {
  flex-grow: 1;
  min-height: 10px;
}
footer .f-top nav > ul {
  display: flex;
  justify-content: space-between;
}
footer .f-top nav > ul > li .title {
  font-size: 0.875rem;
  margin-bottom: 1rem;
  font-weight: 600;
  color: #667085;
}
footer .f-top nav > ul > li > ul > li {
  font-weight: 600;
  margin: 1rem 0;
  color: #203c3b;
}
@media only screen and (max-width: 767px) {
  footer .f-top {
    flex-direction: column;
    gap: 40px;
  }
}

.home-intro {
  background: #f6f5f1;
}
.home-intro .hi-container {
  padding: 7rem 0;
  display: flex;
  justify-content: space-between;
}
.home-intro .hi-container .hi-text {
  width: calc(55% - 40px);
}
.home-intro .hi-container .hi-text.ht2 {
  width: calc(50% - 40px);
}
@media only screen and (max-width: 767px) {
  .home-intro .hi-container .hi-text.ht2 {
    width: 100%;
  }
}
.home-intro .hi-container .hi-text.ht2 h1 {
  font-size: 3rem;
}
@media only screen and (max-width: 767px) {
  .home-intro .hi-container .hi-text.ht2 h1 {
    font-size: 2.5rem;
  }
}
.home-intro .hi-container .hi-graph {
  width: calc(45% - 40px);
}
.home-intro .hi-container .hi-graph.hg2 {
  width: calc(50% - 40px);
}
.home-intro .hi-container h1 {
  padding-bottom: 60px;
  margin-bottom: 40px;
  background: url("../img/head1.svg") no-repeat 0% 100%;
}
.home-intro .hi-container p {
  font-size: 1.25rem;
  line-height: 1.5;
  margin-bottom: 1.75rem;
  color: #203c3b;
}
.home-intro .hi-container .hi-glyphc {
  width: 100%;
  height: 640px;
  border-radius: 20rem 20rem 1.5rem 1.5rem;
  background: #deebe8;
  overflow: hidden;
}
.home-intro .hi-container .hi-glyphc2 {
  border-radius: 0;
  width: 100%;
  background: transparent;
}
@media only screen and (max-width: 767px) {
  .home-intro .hi-container {
    flex-direction: column;
    gap: 2rem;
  }
  .home-intro .hi-container .hi-text, .home-intro .hi-container .hi-graph {
    width: 100%;
  }
  .home-intro .hi-container .hi-text.hg2, .home-intro .hi-container .hi-graph.hg2 {
    width: 100%;
  }
}

.ibtn {
  display: inline-block;
  position: relative;
  background: #ffffff;
  border: 1px solid #d0d5dd;
  font-size: 16px;
  font-weight: 600;
  padding: 16px 28px 16px 64px;
  border-radius: 8px;
}
.ibtn::before {
  position: absolute;
  content: "";
  width: 24px;
  height: 24px;
  left: 28px;
  top: calc(50% - 12px);
  background: url("../img/pr1.svg") no-repeat 50% 50%/contain;
}

.ireviews {
  margin: 48px 0 0;
  display: flex;
  align-items: center;
}
.ireviews .people {
  display: flex;
  padding-left: 16px;
  margin-right: 16px;
}
.ireviews .people > li {
  margin-left: -16px;
  overflow: hidden;
  box-sizing: border-box;
  width: 44px;
  height: 44px;
  border-radius: 22px;
  border: 2px solid #ffffff;
  background: #ffffff;
}
.ireviews .people > li img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.ireviews .rating strong {
  font-weight: 600;
  display: inline-block;
  vertical-align: middle;
}
.ireviews .rating .stars {
  display: inline-block;
  vertical-align: middle;
  margin-right: 6px;
}
.ireviews .rating .stars i {
  display: inline-block;
  width: 20px;
  height: 20px;
  background: url("../img/star.svg") no-repeat 50% 50%/contain;
  margin-right: 4px;
}
.ireviews .rating .note {
  line-height: 20px;
}

.intro-scr {
  padding-top: 16px;
}
.intro-scr .scroller .inner {
  display: flex;
  gap: 16px;
  margin-bottom: 16px;
  width: 1088px;
}
.intro-scr .scroller .inner img {
  display: block;
  width: 260px;
  height: 160px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8px;
}

.hi-grid > ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: repeat(4, 1fr);
  grid-column-gap: 2px;
  grid-row-gap: 2px;
  height: 815px;
  width: 100%;
}
.hi-grid > ul > li {
  overflow: hidden;
}
.hi-grid > ul > li > img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.hi-grid > ul > li:nth-of-type(1) {
  grid-area: 1/1/2/2;
}
.hi-grid > ul > li:nth-of-type(2) {
  grid-area: 1/2/2/3;
}
.hi-grid > ul > li:nth-of-type(3) {
  grid-area: 1/3/2/4;
}
.hi-grid > ul > li:nth-of-type(4) {
  grid-area: 2/1/3/2;
}
.hi-grid > ul > li:nth-of-type(5) {
  grid-area: 2/2/3/3;
}
.hi-grid > ul > li:nth-of-type(6) {
  grid-area: 2/3/3/4;
}
.hi-grid > ul > li:nth-of-type(7) {
  grid-area: 3/1/4/2;
}
.hi-grid > ul > li:nth-of-type(8) {
  grid-area: 3/2/4/4;
}
.hi-grid > ul > li:nth-of-type(9) {
  grid-area: 4/1/5/2;
}
.hi-grid > ul > li:nth-of-type(10) {
  grid-area: 4/2/5/3;
}
.hi-grid > ul > li:nth-of-type(11) {
  grid-area: 4/3/5/4;
}
.hi-grid > ul > li:nth-of-type(1) {
  border-radius: 0% 50% 0% 0%;
}
.hi-grid > ul > li:nth-of-type(2) {
  border-radius: 0% 0% 0% 50%;
}
.hi-grid > ul > li:nth-of-type(3) {
  border-radius: 50% 0% 0% 0%;
}
.hi-grid > ul > li:nth-of-type(4) {
  border-radius: 50%;
}
.hi-grid > ul > li:nth-of-type(5) {
  border-radius: 50% 0% 0% 50%;
}
.hi-grid > ul > li:nth-of-type(6) {
  border-radius: 0% 50% 0% 50%;
}
.hi-grid > ul > li:nth-of-type(7) {
  border-radius: 0% 0% 50% 50%;
}
.hi-grid > ul > li:nth-of-type(8) {
  border-radius: 0% 100px 0% 100px;
}
.hi-grid > ul > li:nth-of-type(9) {
  border-radius: 0% 50% 0% 0%;
}
.hi-grid > ul > li:nth-of-type(10) {
  border-radius: 50%;
}
.hi-grid > ul > li:nth-of-type(11) {
  border-radius: 50% 0% 50% 0%;
}
@media only screen and (max-width: 767px) {
  .hi-grid > ul {
    height: 450px;
  }
}

.h-sec {
  padding-top: 7rem;
  padding-bottom: 7rem;
}

.h-split > div {
  display: flex;
  gap: 80px;
}
.h-split > div > div {
  width: calc(45% - 40px);
}
.h-split > div > div:nth-of-type(1) {
  width: calc(55% - 40px);
}
@media only screen and (max-width: 767px) {
  .h-split > div {
    flex-direction: column-reverse;
    gap: 40px;
  }
  .h-split > div > div {
    width: 100% !important;
  }
}

.h-sec-text {
  font-size: 1.125rem;
  line-height: 1.5;
  color: #203c3b;
}
.h-sec-text p {
  margin: 1.5rem 0;
}
.h-sec-text ul li {
  padding-left: 12px;
  margin: 1.5rem 0;
  position: relative;
}
.h-sec-text ul li em {
  font-style: italic;
}
.h-sec-text ul.check li {
  padding-left: 36px;
}
.h-sec-text ul.check li::before {
  content: "";
  width: 24px;
  height: 24px;
  border-radius: 12px;
  background: #deebe8;
  background: url("../img/hcheck.svg") no-repeat 50% 50%/contain;
  position: absolute;
  top: 0;
  left: 0;
}

.h-sec-img {
  display: flex;
  align-items: center;
}
.h-sec-img img {
  border-radius: 1rem;
  display: block;
  width: 100%;
}

.h-ic {
  background: #f6f5f1;
}

.h-center .h-sec-text {
  max-width: 52rem;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.h-center .h-sec-text h2 {
  font-size: 2rem;
}

.programlist {
  display: flex;
  margin: 4rem 0;
  gap: 2rem;
}
.programlist > li {
  width: 33%;
  box-sizing: border-box;
  box-shadow: 0 12px 16px -4px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(16, 24, 40, 0.03);
  position: relative;
  border-radius: 1rem;
  padding: 2rem;
  border: 1px solid #eaecf0;
  display: flex;
  flex-direction: column;
}
.programlist > li > i {
  display: block;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 100%;
  background: url("../img/prog.svg") no-repeat 50% 50%;
  background-color: #deebe8;
  box-sizing: border-box;
  border: 0.5rem solid #ecfdf3;
}
.programlist > li h2 {
  margin: 0.5rem 0 1.5rem;
  font-family: "SuisseWorks", serif;
  color: #101828;
  font-size: 2.2rem;
}
.programlist > li p {
  color: #203c3b;
  line-height: 1.5;
}
.programlist > li .featurelist {
  padding-top: 2rem;
  margin-top: 2rem;
  border-top: 1px solid #eaecf0;
  padding-bottom: 2rem;
  line-height: 1.5;
  color: #203c3b;
}
.programlist > li .featurelist ul {
  margin-top: 1.5rem;
}
.programlist > li .featurelist ul > li {
  position: relative;
  padding-left: calc(24px + 0.75rem);
  margin-bottom: 1rem;
}
.programlist > li .featurelist ul > li::before {
  width: 24px;
  height: 24px;
  background: url("../img/listcheck.svg") no-repeat 50% 50%/contain;
  content: "";
  position: absolute;
  top: 0;
  left: 0;
}
.programlist > li .actions {
  margin-top: auto;
}
.programlist > li .actions .button {
  display: block;
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .programlist {
    flex-direction: column;
  }
  .programlist > li {
    width: 100%;
  }
}

.h-infobox {
  margin: 0rem 0 7rem;
}
.h-infobox .h-infoboxcont {
  background: #f6f5f1;
  padding: 4rem;
  border-radius: 1rem;
}
@media only screen and (max-width: 767px) {
  .h-infobox .h-infoboxcont {
    padding: 2rem;
  }
}
.h-infobox .split {
  display: flex;
}
.h-infobox .split > div:nth-of-type(2) {
  flex-shrink: 0;
  margin-left: 4rem;
}
@media only screen and (max-width: 767px) {
  .h-infobox .split {
    flex-direction: column;
  }
  .h-infobox .split > div:nth-of-type(2) {
    margin-left: auto;
    margin-right: auto;
    margin-top: 1rem;
  }
}
.h-infobox .ibtn {
  padding-left: 28px;
}
.h-infobox .ibtn::before {
  display: none;
}
.h-infobox h3 {
  margin-bottom: 1rem;
  color: #7e735d;
}
.h-infobox p {
  color: #203c3b;
  font-size: 1.125rem;
  line-height: 1.5;
}

.h-courses {
  margin: 7rem 0;
}
.h-courses .container {
  display: flex;
  gap: 4rem;
}
@media only screen and (max-width: 767px) {
  .h-courses .container {
    flex-direction: column;
  }
}
.h-courses .h-coursestext {
  max-width: 520px;
  position: sticky;
  top: 0;
}
@media only screen and (max-width: 767px) {
  .h-courses .h-coursestext {
    position: relative;
  }
}
.h-courses .h-courseslist {
  max-width: 520px;
  flex-shrink: 0;
  width: 50%;
}
@media only screen and (max-width: 767px) {
  .h-courses .h-courseslist {
    width: 100%;
  }
}

.h-clist > li {
  margin-bottom: 2rem;
}
.h-clist > li > img {
  display: block;
  width: 100%;
  height: 520px;
  border-radius: 0.5rem;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 1rem;
}
@media only screen and (max-width: 767px) {
  .h-clist > li > img {
    height: 240px;
  }
}
.h-clist > li .category {
  margin-bottom: 0.7rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: #7e735d;
}
.h-clist > li p {
  color: #203c3b;
  line-height: 1.5;
}
.h-clist > li h4 {
  margin-bottom: 0.7rem;
}
.h-clist > li .auth {
  margin-top: 1rem;
  display: flex;
  align-items: center;
}
.h-clist > li .auth img {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  flex-shrink: 0;
  margin-right: 0.75rem;
}
.h-clist > li .auth .text {
  font-size: 0.875rem;
}
.h-clist > li .auth .text span {
  display: block;
  font-weight: 600;
}

.h-events {
  padding: 7rem 0;
  background: #f6f5f1;
}
.h-events .intro {
  max-width: 768px;
  margin: 0 auto 4rem;
  text-align: center;
}
.h-events .intro h2 {
  margin-bottom: 1rem;
}
.h-events .intro p {
  font-size: 1.125rem;
  line-height: 1.5;
}
.h-events .split {
  gap: 4rem;
  display: flex;
}
.h-events .split .previews {
  width: calc(50% - 40px);
}
.h-events .split .previews img {
  display: block;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .h-events .split {
    flex-direction: column;
  }
  .h-events .split .previews {
    width: 100%;
  }
}
.h-events .evlist {
  width: calc(50% - 40px);
}
.h-events .evlist > ul > li {
  border: 1px solid #eaecf0;
  border-radius: 1rem;
  padding: 1.5rem;
  margin-bottom: 1.5rem;
}
.h-events .evlist h3 {
  font-weight: 500;
  font-size: 1.125rem;
  color: #101828;
  margin-bottom: 0.5rem;
}
.h-events .evlist .text {
  line-height: 1.5rem;
  margin: 0.5rem 0;
}
.h-events .evlist .loctime {
  margin: 1.5rem 0;
  display: flex;
  font-size: 0.875rem;
}
.h-events .evlist .loctime span, .h-events .evlist .loctime time {
  margin-right: 1.5rem;
  line-height: 1.5rem;
  display: flex;
  align-items: center;
}
.h-events .evlist .loctime span::before, .h-events .evlist .loctime time::before {
  margin-right: 8px;
  width: 20px;
  height: 20px;
  display: block;
  background: url("../img/pin.svg") no-repeat 50% 50%/contain;
  content: "";
}
.h-events .evlist .loctime time::before {
  background-image: url("../img/time.svg");
}
@media only screen and (max-width: 767px) {
  .h-events .evlist .loctime {
    flex-direction: column;
    gap: 0.5rem;
  }
}
.h-events .evlist .ibtn {
  padding: 16px 28px 16px 28px;
}
.h-events .evlist .ibtn::before {
  display: none;
}
@media only screen and (max-width: 767px) {
  .h-events .evlist {
    width: 100%;
  }
}

.h-features {
  margin: 7rem 0;
}
.h-features ul {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.h-features ul > li {
  width: calc(33.33% - 1.333rem);
  margin-bottom: 3rem;
}
.h-features ul > li .img {
  display: flex;
  margin-bottom: 1.5rem;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  width: 3.5rem;
  height: 3.5rem;
  border: 0.5rem solid #ecfdf3;
  background-color: #deebe8;
  box-sizing: border-box;
}
.h-features ul > li .img img {
  display: block;
  width: 24px;
  height: 24px;
  -o-object-fit: contain;
     object-fit: contain;
}
.h-features ul > li h4 {
  color: #203c3b;
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.h-features ul > li .text {
  line-height: 1.5;
  color: #203c3b;
}
@media only screen and (max-width: 767px) {
  .h-features ul {
    flex-direction: column;
  }
  .h-features ul > li {
    width: 100%;
  }
}

.h-imgsep {
  margin: 4rem 0;
}
.h-imgsep .split {
  display: flex;
  gap: 2rem;
}
.h-imgsep .split > div {
  width: calc(50% - 1rem);
}
@media only screen and (max-width: 767px) {
  .h-imgsep .split {
    flex-direction: column;
  }
  .h-imgsep .split > div {
    width: 100%;
  }
}
.h-imgsep .img img {
  display: block;
  height: 40rem;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 1rem;
}
@media only screen and (max-width: 767px) {
  .h-imgsep .img img {
    height: 20rem;
  }
}

.h-reviews {
  padding: 7rem 0;
  background: #f6f5f1;
}
.h-reviews .h-reviewsintro {
  margin: 0 auto;
  padding-bottom: 3.5rem;
  margin-bottom: 4rem;
  position: relative;
  text-align: center;
  max-width: 48rem;
}
.h-reviews .h-reviewsintro p {
  line-height: 1.5;
}
.h-reviews .h-reviewsintro::after {
  content: "";
  width: 170px;
  height: 10px;
  position: absolute;
  bottom: 0;
  left: calc(50% - 85px);
  background: url("../img/hreviewsglyph.svg") no-repeat 50% 50%/contain;
}
.h-reviews .h-reviewslist {
  overflow-x: auto;
}
.h-reviews .h-reviewslist ul {
  display: flex;
  gap: 2rem;
  padding: 0 2rem;
}
.h-reviews .h-reviewslist ul > li {
  display: flex;
  flex-direction: column;
  width: 344px;
  flex-shrink: 0;
  box-sizing: border-box;
  padding: 2rem;
  background: #ffffff;
  border-radius: 1rem;
}
.h-reviews .h-reviewslist ul > li .rating {
  display: inline-block;
  vertical-align: middle;
  margin-right: 6px;
  margin-bottom: 1rem;
}
.h-reviews .h-reviewslist ul > li .rating span {
  display: inline-block;
  width: 20px;
  height: 20px;
  background: url("../img/star.svg") no-repeat 50% 50%/contain;
  margin-right: 4px;
}
.h-reviews .h-reviewslist ul > li > .text {
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.5;
  margin: auto 0;
}
.h-reviews .h-reviewslist .auth {
  margin-top: 1rem;
  display: flex;
  align-items: center;
}
.h-reviews .h-reviewslist .auth img {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  flex-shrink: 0;
  margin-right: 0.75rem;
}
.h-reviews .h-reviewslist .auth .text {
  font-size: 0.875rem;
}
.h-reviews .h-reviewslist .auth .text span {
  display: block;
  font-weight: 600;
}

.h-tabbed {
  margin: 7rem 0;
}
.h-tabbed .split {
  display: flex;
  gap: 40px;
}
.h-tabbed .split > ul {
  width: calc(50% - 20px);
}
.h-tabbed .split .htab-img {
  position: relative;
}
.h-tabbed .split .htab-img > li {
  position: absolute;
  height: 100%;
  width: 100%;
  visibility: hidden;
  opacity: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.h-tabbed .split .htab-img > li.active {
  visibility: visible;
  opacity: 1;
}
.h-tabbed .split .htab-img > li img {
  width: 100%;
  height: calc(100% - 80px);
  display: block;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 1rem;
}
@media only screen and (max-width: 767px) {
  .h-tabbed .split .htab-img {
    height: 340px;
  }
}
.h-tabbed .split .htab-content > li {
  padding: 1.5rem 0 1.5rem 2rem;
  border-left: 4px solid #f2f4f7;
  cursor: pointer;
}
.h-tabbed .split .htab-content > li h4 {
  margin-bottom: 0.5rem;
  color: #203c3b;
}
.h-tabbed .split .htab-content > li.active {
  border-color: #315f5e;
}
@media only screen and (max-width: 767px) {
  .h-tabbed .split {
    flex-direction: column;
  }
  .h-tabbed .split > ul {
    width: 100%;
  }
}

.h-faq {
  padding: 7rem 0;
  background: #f6f5f1;
}
.h-faq .h-faqintro {
  color: #315f5e;
  text-align: center;
  max-width: 48rem;
  margin: 0 auto 4rem;
}
.h-faq .h-faqintro .text {
  margin-top: 1rem;
  color: #203c3b;
  font-size: 1.125rem;
  line-height: 1.5;
}
.h-faq .h-faqcontent {
  display: flex;
  flex-wrap: wrap;
  gap: 4rem;
}
.h-faq .h-faqcontent > li {
  width: calc(50% - 2rem);
  box-sizing: border-box;
  border-bottom: 1px solid #eaecf0;
  padding-bottom: 2rem;
}
.h-faq .h-faqcontent > li .head {
  margin-bottom: 1rem;
  display: flex;
  cursor: pointer;
}
.h-faq .h-faqcontent > li .head i {
  display: block;
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  border: 2px solid #98a2b3;
  border-radius: 50%;
  position: relative;
}
.h-faq .h-faqcontent > li .head i::before, .h-faq .h-faqcontent > li .head i::after {
  content: "";
  position: absolute;
  top: calc(50% - 1px);
  left: calc(50% - 6px);
  height: 2px;
  width: 12px;
  background: #98a2b3;
  transform-origin: 50% 50%;
  transition: 0.3s;
}
.h-faq .h-faqcontent > li h5 {
  font-size: 1.125rem;
  line-height: 1.5;
  font-weight: 500;
  color: #101828;
  flex-grow: 1;
}
.h-faq .h-faqcontent > li .text {
  line-height: 1.5;
  color: #203c3b;
}
@media only screen and (max-width: 767px) {
  .h-faq .h-faqcontent > li {
    width: 100%;
  }
}

.h-nlbox {
  margin-top: 4rem;
  border-radius: 1rem;
  padding: 2rem;
  background: #f9fafb;
  text-align: center;
}
.h-nlbox > div {
  max-width: 560px;
  margin: 0 auto;
}
.h-nlbox h4 {
  margin-bottom: 2rem;
}
.h-nlbox .imgs {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  margin-bottom: 1rem;
}
.h-nlbox .imgs img {
  display: block;
  width: 2.75rem;
  height: 2.75rem;
  -o-object-fit: cover;
     object-fit: cover;
  position: relative;
  border-radius: 50%;
  box-sizing: border-box;
  border: 2px solid #ffffff;
}
.h-nlbox .imgs > li:nth-of-type(2) {
  margin: 0 -0.5rem;
}
.h-nlbox .imgs > li:nth-of-type(2) img {
  width: 3.5rem;
  height: 3.5rem;
  z-index: 1;
}

.program-intro {
  margin: 7rem 0;
}
.program-intro .pi-itext {
  display: flex;
  gap: 4rem;
  align-items: center;
  margin-bottom: 2rem;
}
.program-intro .pi-itext > div {
  width: calc(50% - 2rem);
}
.program-intro .pi-itext .heading {
  color: #315f5e;
  line-height: 1.3;
  font-weight: 600;
  font-size: 2rem;
}
.program-intro .pi-itext .text {
  font-size: 1.125rem;
  line-height: 1.5;
  color: #203c3b;
}
@media only screen and (max-width: 767px) {
  .program-intro .pi-itext {
    flex-direction: column;
  }
  .program-intro .pi-itext > div {
    width: 100%;
  }
}

.pi-introbox {
  background: #f6f5f1;
  border-radius: 1rem;
  padding: 2rem;
}
.pi-introbox .nav {
  margin-bottom: 0.75rem;
}
.pi-introbox .nav .back {
  position: relative;
  display: inline-block;
  line-height: 24px;
  font-size: 18px;
  font-weight: 600;
  padding-left: 32px;
  color: #7e735d;
}
.pi-introbox .nav .back::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 24px;
  height: 24px;
  content: "";
  background: url("../img/back.svg") no-repeat 50% 50%/contain;
}
.pi-introbox .split {
  display: flex;
  gap: 2rem;
}
@media only screen and (max-width: 767px) {
  .pi-introbox .split {
    flex-direction: column-reverse;
  }
}
.pi-introbox .pi-content {
  max-width: 340px;
  width: 100%;
  flex-shrink: 0;
}
.pi-introbox .pi-content .duration {
  color: #7e735d;
  mix-blend-mode: multiply;
  background-color: #f6f5f1;
  border-radius: 10rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: 0.25rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  display: inline-block;
}
.pi-introbox .pi-content time {
  color: #315f5e;
  background-color: #ffffff;
  border-radius: 10rem;
  align-items: center;
  margin-bottom: 1rem;
  padding: 0.25rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  display: inline-block;
}
.pi-introbox .pi-content .button {
  display: inline-block;
  padding: 0.625rem 1.125rem;
  line-height: 1.5;
  border-radius: 0.5rem;
  font-weight: 600;
  background: #359e9c;
  color: #ffffff;
  margin: 2.5rem 0 1.5rem;
}
.pi-introbox .pi-content .button:hover {
  background: #315f5e;
}
.pi-introbox .pi-content p {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #203c3b;
}
.pi-introbox .pi-content p a {
  text-decoration: underline;
}
.pi-introbox .pi-video {
  flex-grow: 1;
  background: yellow;
  min-height: 240px;
}
@media only screen and (max-width: 767px) {
  .pi-introbox {
    padding: 1.5rem;
  }
}

.pi-chapters {
  margin-top: 2.5rem;
}
.pi-chapters .head {
  color: #315f5e;
  font-weight: 600;
  margin-bottom: 1.5rem;
}
.pi-chapters .scrollc {
  max-height: 350px;
  overflow-y: auto;
}
.pi-chapters .scrollc > ul {
  color: #203c3b;
  padding-right: 8px;
}
.pi-chapters .scrollc > ul > li a {
  display: block;
  position: relative;
  font-weight: 600;
  padding: 16px 0;
}
.pi-chapters .scrollc > ul > li a::after {
  content: "";
  background: url("../img/dd.svg") no-repeat 100% 50%/contain;
  position: absolute;
  right: 0;
  width: 28px;
  height: 24px;
  top: calc(50% - 12px);
}
.pi-chapters .scrollc > ul > li > a {
  font-size: 18px;
}
.pi-chapters .scrollc > ul > li > ul {
  background: #ffffff;
  padding: 4px 16px;
  border-radius: 0.75rem;
}
.pi-chapters .scrollc > ul > li > ul > li > ul {
  background: #f6f5f1;
  padding: 4px 16px;
  border-radius: 0.75rem;
}
.pi-chapters .scrollc > ul > li .video-list > li > a {
  padding-left: 32px;
  transition: 0.3s;
  border-radius: 0.75rem;
}
.pi-chapters .scrollc > ul > li .video-list > li > a:hover {
  background: #ffffff;
}
.pi-chapters .scrollc > ul > li .video-list > li > a::after {
  display: none;
}
.pi-chapters .scrollc > ul > li .video-list > li > a::before {
  content: "";
  background: url("../img/listplay.svg") no-repeat 100% 50%/contain;
  position: absolute;
  left: 0;
  width: 32px;
  height: 32px;
  top: calc(50% - 16px);
}
.pi-chapters .scrollc > ul.disabled .video-list > li > a {
  opacity: 0.4;
}

.prog-desc {
  margin: 7rem 0;
}
.prog-desc .pd-list > li {
  margin-bottom: 2rem;
  display: flex;
  gap: 4rem;
  flex-direction: row-reverse;
  align-items: center;
}
.prog-desc .pd-list > li:nth-of-type(2n) {
  flex-direction: row;
}
@media only screen and (max-width: 767px) {
  .prog-desc .pd-list > li {
    flex-direction: column !important;
  }
}
.prog-desc .pd-list > li .img {
  width: calc(50% - 2rem);
}
@media only screen and (max-width: 767px) {
  .prog-desc .pd-list > li .img {
    width: 100%;
  }
}
.prog-desc .pd-list > li .img img {
  display: block;
  height: 512px;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 1rem;
}
@media only screen and (max-width: 767px) {
  .prog-desc .pd-list > li .img img {
    height: 400px;
  }
}
.prog-desc .pd-list > li .textc {
  width: calc(50% - 2rem);
}
@media only screen and (max-width: 767px) {
  .prog-desc .pd-list > li .textc {
    width: 100%;
  }
}
.prog-desc .pd-list > li .textc .text {
  line-height: 1.5;
  font-size: 1.125rem;
  color: #203c3b;
  margin-top: 2.25rem;
}
.prog-desc .pd-list > li .textc .text p {
  margin-bottom: 1.5rem;
}

.program-get {
  padding: 7rem 0;
  background: #f6f5f1;
}
.program-get .container {
  position: relative;
}
.program-get .container::after {
  position: absolute;
  top: -3rem;
  right: 0;
  content: "";
  width: 250px;
  height: 250px;
  background: url("../img/sectbg1.svg") no-repeat 50% 50%/contain;
  pointer-events: none;
}
.program-get .pget-intro {
  max-width: 48rem;
  margin-bottom: 7rem;
  position: relative;
  z-index: 1;
}
.program-get .pget-intro p {
  margin-top: 1.5rem;
  line-height: 1.5;
  font-size: 1.125rem;
  color: #203c3b;
}
.program-get .pget-split {
  display: flex;
  gap: 4rem;
}
.program-get .pget-split > ul, .program-get .pget-split > div {
  width: calc(50% - 2rem);
}
@media only screen and (max-width: 767px) {
  .program-get .pget-split {
    flex-direction: column;
  }
  .program-get .pget-split > ul, .program-get .pget-split > div {
    width: 100%;
  }
}
.program-get .pget-list > li {
  position: relative;
  padding-left: 80px;
  margin-bottom: 3rem;
}
.program-get .pget-list > li:last-of-type {
  margin-bottom: 0;
}
.program-get .pget-list i {
  width: 40px;
  height: 40px;
  position: absolute;
  background: #ecfdf3;
  border-radius: 40px;
  left: 0;
  top: 0;
  border: 0.5rem solid #ecfdf3;
  background: #deebe8;
  background-size: 20px 20px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
.program-get .pget-list i.train {
  background-image: url("../img/ico-train.svg");
}
.program-get .pget-list i.guide {
  background-image: url("../img/ico-guide.svg");
}
.program-get .pget-list i.approach {
  background-image: url("../img/ico-approach.svg");
}
.program-get .pget-list h4 {
  font-size: 1.25rem;
  color: #101828;
  margin-bottom: 0.5rem;
}
.program-get .pget-list .text {
  line-height: 1.5;
  color: #203c3b;
}
.program-get .pget-list .text p {
  margin-bottom: 1.5rem;
}
.program-get .pget-pbox {
  width: 100%;
  box-sizing: border-box;
  background: #ffffff;
  border-radius: 1rem;
  padding: 2rem;
  box-shadow: 0 12px 16px -4px rgba(0, 0, 0, 0.08), 0 4px 6px -2px rgba(16, 24, 40, 0.03);
}
.program-get .pbox-act {
  padding-top: 2rem;
  margin-top: 2rem;
  border-top: 1px solid #eaecf0;
}
.program-get .pbox-act .button {
  display: inline-block;
  padding: 0.625rem 1.125rem;
  line-height: 1.5;
  border-radius: 0.5rem;
  font-weight: 600;
  background: #359e9c;
  color: #ffffff;
  margin: 2.5rem 0 1.5rem;
  margin-top: 0;
  display: block;
  text-align: center;
}
.program-get .pbox-act .button:hover {
  background: #315f5e;
}
.program-get .pbox-act p {
  font-size: 0.875rem;
  line-height: 1.5;
  color: #203c3b;
}
.program-get .pbox-act p a {
  text-decoration: underline;
}
.program-get .pbox-head {
  display: flex;
  gap: 2rem;
  align-items: center;
}
.program-get .pbox-head .title {
  flex-grow: 1;
}
.program-get .pbox-head .title h4 {
  display: flex;
  align-items: center;
  color: #101828;
  margin-bottom: 0.5rem;
}
.program-get .pbox-head .title span {
  padding: 0.125rem 0.625rem;
  border-radius: 30px;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.5;
  background: #f6f5f1;
  color: #7e735d;
  margin-left: 6px;
}
.program-get .pbox-head .title p {
  color: #203c3b;
  line-height: 1.5;
}
.program-get .pbox-head .price {
  flex-shrink: 0;
  color: #101828;
  font-size: 3.75rem;
  font-weight: 600;
}
@media only screen and (max-width: 767px) {
  .program-get .pbox-head {
    flex-direction: column;
  }
}
.program-get .pbox-feat {
  padding-top: 2rem;
  margin-top: 2rem;
  border-top: 1px solid #eaecf0;
}
.program-get .pbox-feat .title {
  color: #101828;
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
}
.program-get .pbox-feat ul {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}
.program-get .pbox-feat ul > li {
  width: calc(50% - 0.5rem);
  color: #203c3b;
  line-height: 1.5;
  padding-left: 32px;
  box-sizing: border-box;
  position: relative;
}
.program-get .pbox-feat ul > li::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  background: url("../img/listcheck2.svg") no-repeat 50% 50%/contain;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 767px) {
  .program-get .pbox-feat ul {
    flex-direction: column;
  }
  .program-get .pbox-feat ul > li {
    width: 100%;
  }
}

.prog-feat {
  padding: 7rem 0;
}
.prog-feat .pfeat-list {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.prog-feat .pfeat-list > li {
  width: calc(33.333% - 1.333rem);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.prog-feat .pfeat-list > li i {
  width: 40px;
  height: 40px;
  background: #ecfdf3;
  border-radius: 40px;
  background: #deebe8;
  background-size: 20px 20px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  display: block;
  border: 0.5rem solid #ecfdf3;
  margin-bottom: 1rem;
}
.prog-feat .pfeat-list > li i.train {
  background-image: url("../img/ico-train.svg");
}
.prog-feat .pfeat-list > li i.guide {
  background-image: url("../img/ico-guide.svg");
}
.prog-feat .pfeat-list > li i.approach {
  background-image: url("../img/ico-approach.svg");
}
.prog-feat .pfeat-list > li h4 {
  color: #101828;
  margin-bottom: 0.5rem;
  flex-shrink: 0;
}
.prog-feat .pfeat-list > li .text {
  color: #203c3b;
  line-height: 1.5;
  flex-grow: 1;
}
.prog-feat .pfeat-list > li .more {
  display: flex;
  align-items: center;
  margin-top: 1.5rem;
  flex-shrink: 0;
  color: #359e9c;
  font-weight: 600;
}
.prog-feat .pfeat-list > li .more::after {
  content: "";
  margin-left: 0.5rem;
  display: block;
  width: 24px;
  height: 24px;
  background: url("../img/more.svg") no-repeat 50% 50%/contain;
}
@media only screen and (max-width: 767px) {
  .prog-feat .pfeat-list {
    flex-direction: column;
  }
  .prog-feat .pfeat-list > li {
    width: 100%;
  }
}

.prog-details {
  padding: 7rem 0;
}
.prog-details .pd-split {
  display: flex;
  gap: 4rem;
}
@media only screen and (max-width: 767px) {
  .prog-details .pd-split {
    flex-direction: column;
  }
}
.prog-details .pd-split > aside {
  flex-shrink: 0;
  width: 100%;
  max-width: 20rem;
}
.prog-details .pd-split > div {
  flex-grow: 1;
}
.prog-details .teach-list .title {
  margin-bottom: 1rem;
  font-size: 1rem;
  color: #203c3b;
  font-weight: 600;
}
.prog-details .teach-list ul {
  margin-bottom: 2rem;
}
.prog-details .teach-list ul li {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}
.prog-details .teach-list ul li img {
  display: block;
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  border-radius: 1.5rem;
  -o-object-fit: cover;
     object-fit: cover;
}
.prog-details .teach-list ul li .det {
  flex-grow: 1;
}
.prog-details .teach-list ul li .det .name {
  font-weight: 600;
  margin-bottom: 0.3rem;
  font-size: 1.125rem;
}
.prog-details .teach-list ul li .det .role {
  color: #203c3b;
}
.prog-details .content-share {
  padding-top: 2rem;
  margin-top: 2rem;
  border-top: 1px solid #eaecf0;
}

.prog-related {
  background: #ecfdf3;
  padding: 2rem 0;
}
.prog-related .prog-r-box {
  padding: 6rem 2rem;
  background: #deebe8;
  border-radius: 1rem;
}
.prog-related .prog-r-box h2 {
  margin-bottom: 2rem;
}
.prog-related .prog-r-list {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.prog-related .prog-r-list > li {
  width: calc(33.333% - 1.3334rem);
  color: #203c3b;
  display: flex;
  flex-direction: column;
}
.prog-related .prog-r-list > li .img {
  position: relative;
  width: 100%;
  padding-top: 66%;
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: 2rem;
}
.prog-related .prog-r-list > li .img img {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 20%;
     object-position: 50% 20%;
  transition: 0.3s;
  transform-origin: 50% 50%;
  transform: scale(1);
}
.prog-related .prog-r-list > li .title {
  margin-bottom: 0.5rem;
  font-family: "Outfit", sans-serif;
  font-size: 1.5rem;
  font-weight: 600;
  line-height: 1.4;
  display: flex;
}
.prog-related .prog-r-list > li .title a {
  display: flex;
  align-items: center;
}
.prog-related .prog-r-list > li .title a::after {
  margin-left: 0.5rem;
  height: 1.5rem;
  width: 1.5rem;
  display: block;
  content: "";
  background: url("../img/more2.svg") no-repeat 50% 50%/contain;
  transform-origin: 50% 50%;
  transition: 0.3s;
  transform: rotate(-45deg);
}
.prog-related .prog-r-list > li .text {
  line-height: 1.5;
  margin-bottom: 1.5rem;
}
.prog-related .prog-r-list > li .auth {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-top: auto;
}
.prog-related .prog-r-list > li .auth img {
  display: block;
  width: 3rem;
  height: 3rem;
  flex-shrink: 0;
  border-radius: 1.5rem;
  -o-object-fit: cover;
     object-fit: cover;
}
.prog-related .prog-r-list > li .auth .det {
  flex-grow: 1;
}
.prog-related .prog-r-list > li .auth .det .name {
  font-weight: 600;
  margin-bottom: 0.3rem;
  font-size: 1.125rem;
}
.prog-related .prog-r-list > li .auth .det .detail {
  color: #203c3b;
  display: flex;
  align-items: baseline;
}
.prog-related .prog-r-list > li .auth .det .detail > date {
  display: block;
  margin-right: 0.25rem;
}
.prog-related .prog-r-list > li .auth .det .detail > div {
  margin-left: 0.25rem;
}
@media only screen and (max-width: 767px) {
  .prog-related .prog-r-list > li .auth .det .detail {
    flex-direction: column;
  }
  .prog-related .prog-r-list > li .auth .det .detail > date, .prog-related .prog-r-list > li .auth .det .detail > div {
    margin: 5px 0;
  }
}
.prog-related .prog-r-list > li:hover .title a::after {
  transform: rotate(0deg);
}
.prog-related .prog-r-list > li:hover .img img {
  transform: scale(1.05);
}
@media only screen and (max-width: 767px) {
  .prog-related .prog-r-list {
    flex-direction: column;
  }
  .prog-related .prog-r-list > li {
    width: 100%;
  }
}

.list-intro {
  padding: 7rem 0;
  background: linear-gradient(to bottom, #ecfdf3, #ffffff);
  border-top: 1px solid #f2f4f7;
}
.list-intro .container {
  max-width: 48rem;
  text-align: center;
}
.list-intro h1 {
  font-family: "SuisseWorks", serif;
  font-size: 3.75rem;
  font-weight: 400;
  margin-bottom: 1.5rem;
}
@media only screen and (max-width: 767px) {
  .list-intro h1 {
    font-size: 2.5rem;
  }
}
.list-intro .text {
  color: #203c3b;
  font-size: 1.25rem;
  line-height: 1.5;
  padding-bottom: 60px;
  margin-bottom: 1.5rem;
  position: relative;
}
.list-intro .text::after {
  content: "";
  height: 36px;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: url("../img/head1.svg") no-repeat 50% 50%/contain;
}

.programs-list-sec {
  padding: 7rem 0;
}
.programs-list-sec .programs-list > li {
  display: flex;
  flex-direction: row-reverse;
  gap: 2rem;
  margin-bottom: 6rem;
}
.programs-list-sec .programs-list > li:nth-of-type(2n) {
  flex-direction: row;
}
@media only screen and (max-width: 767px) {
  .programs-list-sec .programs-list > li {
    flex-direction: column !important;
  }
}
.programs-list-sec .programs-list > li .img {
  width: calc(50% - 1rem);
  background: #f2f4f7;
  border-radius: 1rem;
  padding: 1rem;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
}
.programs-list-sec .programs-list > li .img img {
  display: block;
  max-width: 100%;
  max-height: 400px;
}
@media only screen and (max-width: 767px) {
  .programs-list-sec .programs-list > li .img {
    width: 100%;
  }
}
.programs-list-sec .programs-list > li .det {
  width: calc(50% - 1rem);
}
@media only screen and (max-width: 767px) {
  .programs-list-sec .programs-list > li .det {
    width: 100%;
  }
}
.programs-list-sec .programs-list > li .det h2 {
  margin-bottom: 1rem;
}
.programs-list-sec .programs-list > li .det .text {
  color: #203c3b;
  font-size: 1.125rem;
  line-height: 1.5;
  margin-bottom: 1.5rem;
}
.programs-list-sec .programs-list > li .det .text p {
  margin-bottom: 1.5rem;
}

.list-title {
  display: flex;
  align-items: center;
  margin-bottom: 2rem;
}
.list-title h1 {
  flex-grow: 1;
}
.list-title .button {
  flex-shrink: 0;
}

.events-intro {
  padding: 7rem 0;
  position: relative;
  border-top: 1px solid #f2f4f7;
}
.events-intro .container {
  max-width: 48rem;
  text-align: center;
  position: relative;
}
.events-intro .text {
  color: #203c3b;
  font-size: 1.25rem;
  line-height: 1.5;
  padding-bottom: 60px;
  margin-bottom: 1.5rem;
  position: relative;
}
.events-intro::before {
  position: absolute;
  content: "";
  right: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  max-width: 48rem;
  background: url("../img/events-bg.svg") no-repeat 100% 50%/cover;
}
@media only screen and (max-width: 767px) {
  .events-intro::before {
    background-position: 0% 50%;
  }
}
@media only screen and (max-width: 767px) {
  .events-intro {
    padding: 4rem 0;
  }
}

.events-upcoming {
  padding: 7rem 0;
}
.events-upcoming .text-content {
  max-width: 48rem;
  color: #203c3b;
  font-size: 1.125rem;
  line-height: 1.5;
  margin-bottom: 1.5rem;
}
.events-upcoming .text-content p {
  margin-bottom: 1.5rem;
}
.events-upcoming .events-usplit {
  margin-top: 4rem;
  display: flex;
  gap: 2rem;
  align-items: center;
}
.events-upcoming .events-usplit > div, .events-upcoming .events-usplit ul {
  width: calc(50% - 1rem);
}
@media only screen and (max-width: 767px) {
  .events-upcoming .events-usplit {
    flex-direction: column;
  }
  .events-upcoming .events-usplit > ul, .events-upcoming .events-usplit > div {
    width: 100%;
  }
}
.events-upcoming .events-usplit .img {
  display: flex;
  justify-content: center;
  align-items: center;
}
.events-upcoming .events-usplit .img img {
  width: 100%;
  border-radius: 1rem;
}
.events-upcoming .events-ulist > li {
  box-sizing: border-box;
  border: 1px solid #eaecf0;
  padding: 1.5rem;
  border-radius: 1rem;
  margin-bottom: 2rem;
}
.events-upcoming .events-ulist > li .title {
  margin-bottom: 0.5rem;
  font-weight: 500;
  font-size: 1.125rem;
}
.events-upcoming .events-ulist > li .text {
  color: #203c3b;
  line-height: 1.5;
  margin-bottom: 1rem;
}
.events-upcoming .events-ulist > li .det {
  margin-bottom: 1rem;
  margin-top: 1rem;
  display: flex;
  color: #203c3b;
  align-items: center;
}
.events-upcoming .events-ulist > li .det > span, .events-upcoming .events-ulist > li .det > date {
  margin-right: 1.5rem;
  padding-left: 28px;
  position: relative;
  line-height: 20px;
}
.events-upcoming .events-ulist > li .det > span::before, .events-upcoming .events-ulist > li .det > date::before {
  position: absolute;
  top: 0;
  left: 0;
  height: 20px;
  width: 20px;
  content: "";
  background-size: contain;
  background-position: 50% 50%;
  background-repeat: no-repeat;
}
.events-upcoming .events-ulist > li .det span::before {
  background-image: url("../img/ico-loc.svg");
}
.events-upcoming .events-ulist > li .det date::before {
  background-image: url("../img/ico-time.svg");
}
@media only screen and (max-width: 767px) {
  .events-upcoming .events-ulist > li .det {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }
}
.events-upcoming .events-ulist > li .ibtn {
  padding-left: 28px;
}
.events-upcoming .events-ulist > li .ibtn::before {
  display: none;
}

.blog-intro {
  padding: 7rem 0;
  position: relative;
  border-top: 1px solid #f2f4f7;
  background: #f6f5f1;
}
.blog-intro .container {
  max-width: 48rem;
  text-align: center;
  position: relative;
  z-index: 1;
}
.blog-intro .text {
  color: #203c3b;
  font-size: 1.25rem;
  line-height: 1.5;
  padding-bottom: 60px;
  margin-bottom: 1.5rem;
  position: relative;
}
.blog-intro::before {
  position: absolute;
  content: "";
  right: 5rem;
  top: 5rem;
  bottom: 5rem;
  width: 100%;
  max-width: 20rem;
  background: url("../img/blog-head.svg") no-repeat 100% 50%/contain;
}
@media only screen and (max-width: 767px) {
  .blog-intro::before {
    background-position: 0% 50%;
  }
}
@media only screen and (max-width: 767px) {
  .blog-intro {
    padding: 4rem 0;
  }
}
.blog-intro.single::before {
  top: 0;
  left: 0;
  bottom: 0;
  width: 100%;
  background: rgba(0, 0, 0, 0.5);
  max-width: 100%;
  z-index: 1;
}
.blog-intro.single > img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.blog-intro.single .container, .blog-intro.single h1, .blog-intro.single .text {
  color: #ffffff;
}
.blog-intro.single .text {
  margin-top: 1rem;
}

.blog-post {
  padding: 7rem 0;
}
.blog-post .container {
  max-width: 48rem;
}
.blog-post .act-title {
  text-align: center;
  color: #101828;
  font-weight: 600;
  margin: 2rem 0 1rem;
}
.blog-post .content-share {
  justify-content: center;
}

.courses-intro {
  padding: 7rem 0;
  position: relative;
  border-top: 1px solid #f2f4f7;
  background: #f6f5f1;
}
.courses-intro .container {
  max-width: 62rem;
  text-align: center;
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.courses-intro .text {
  color: #203c3b;
  font-size: 1.25rem;
  line-height: 1.5;
  margin-bottom: 1.5rem;
  position: relative;
  max-width: 48rem;
  margin: 1rem auto;
}
.courses-intro .ireviews {
  margin: 1rem 0;
}
.courses-intro .abhead {
  display: flex;
  padding: 4px 4px 6px 4px;
  border-radius: 30px;
  background: #ecfdf3;
  margin-bottom: 0.5rem;
  align-items: center;
}
.courses-intro .abhead > em, .courses-intro .abhead > a {
  display: block;
}
.courses-intro .abhead em {
  padding: 4px 6px;
  border-radius: 30px;
  background: #203c3b;
  color: #ffffff;
  margin-right: 8px;
}
.courses-intro .abhead a {
  display: flex;
  align-items: center;
}
.courses-intro .abhead a::after {
  width: 16px;
  height: 16px;
  display: block;
  flex-shrink: 0;
  background: url("../img/more2.svg") no-repeat 50% 50%/contain;
  content: "";
  margin-left: 4px;
}
.courses-intro::before {
  position: absolute;
  content: "";
  right: 5rem;
  top: 5rem;
  bottom: 5rem;
  width: 100%;
  max-width: 20rem;
  background: url("../img/blog-head.svg") no-repeat 100% 50%/contain;
}
@media only screen and (max-width: 767px) {
  .courses-intro::before {
    background-position: 0% 50%;
  }
}
@media only screen and (max-width: 767px) {
  .courses-intro {
    padding: 4rem 0;
  }
}

.course-itext {
  padding: 7rem 0 3rem;
}
.course-itext .course-it-content {
  max-width: 48rem;
}
.course-itext h1, .course-itext h2 {
  margin-bottom: 2rem;
}
.course-itext .text {
  margin-bottom: 1.5rem;
  line-height: 1.5;
  font-size: 1.125rem;
  color: #203c3b;
  padding-bottom: 2rem;
  background: url("../img/curvedsep1.svg") no-repeat 0% 100%;
}
.course-itext .text p {
  margin-bottom: 1.5rem;
}
.course-itext.alt2 {
  background: #f6f5f1;
}

.teacher-list {
  background: #f6f5f1;
  padding: 0.5rem 0 7rem;
}
.teacher-list .tl-content {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
}
.teacher-list .tl-content > li {
  width: calc(33.333% - 1.667rem);
}
.teacher-list .tl-content > li .img {
  width: 100%;
  padding-top: 130%;
  position: relative;
  overflow: hidden;
  margin-bottom: 1rem;
  border-radius: 1rem;
}
.teacher-list .tl-content > li .img img {
  position: absolute;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  top: 0;
  left: 0;
}
.teacher-list .tl-content > li .det {
  margin: 1rem 0;
}
.teacher-list .tl-content > li .det .name {
  font-size: 1.125rem;
  font-weight: 600;
  line-height: 1.5;
  color: #101828;
}
.teacher-list .tl-content > li .det .loc {
  color: #203c3b;
}
.teacher-list .tl-content > li .soc {
  display: flex;
  gap: 1.5rem;
}
.teacher-list .tl-content > li .soc > a {
  display: block;
  width: 24px;
  height: 24px;
  overflow: hidden;
  text-indent: -10000px;
  background-position: 50% 50%;
  background-repeat: no-repeat;
  background-size: contain;
}
.teacher-list .tl-content > li .soc > a.ig {
  background-image: url("../img/soc-ig.svg");
}
.teacher-list .tl-content > li .soc > a.in {
  background-image: url("../img/soc-in.svg");
}
.teacher-list .tl-content > li .soc > a.yt {
  background-image: url("../img/soc-yt.svg");
}
.teacher-list .tl-content > li .soc > a.fb {
  background-image: url("../img/soc-fb.svg");
}
.teacher-list .tl-content > li .soc > a.x {
  background-image: url("../img/soc-x.svg");
}
@media only screen and (max-width: 767px) {
  .teacher-list .tl-content > li {
    width: 100%;
  }
}

/*# sourceMappingURL=app.css.map*/