@import url("../../fonts/Inter/Inter.css");
@import url("../../fonts/Montserrat/Montserrat.css");

*,
*:before,
*:after {
  -webkit-box-sizing: inherit;
  -moz-box-sizing: inherit;
  box-sizing: inherit;
  color: inherit;
}

/* Disable chat */
div#Embed,
#launcher {
  display: none !important;
}

html {
  font-size: 62.5%;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  scroll-behavior: smooth;
}

body {
  font-family: "Montserrat", sans-serif;
  font-size: 1.6rem;
  line-height: 1.5;
  background: #fff;
  color: #303030;
  margin: 0;
  padding: 0;
  position: relative;
}

h1, h2, h3, h4, h5, h6 {
  font-family: "Inter", sans-serif;
}

.s-menu {
  background-color: rgb(255 255 255 / 60%) !important;
  backdrop-filter: blur(0.78vw);
}

.s01 {
  position: relative;
  transform: translateY(-3.91vw);
}

.s01-bg {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.s01-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.s01-wrap {
  width: 65.63vw;
  margin: 0 auto;
  padding: 7.03vw 0 3.33vw;
  display: flex;
  flex-direction: column;
}

.s01-info {
  width: 28.13vw;
}

.s01 h1 {
  font-size: 2.86vw;
  font-weight: 700;
  line-height: 1.2;
  color: #AA8431;
}

.s01 p.p01 {
  padding: 1.56vw 0;
  font-size: 1.25vw;
  line-height: 1.5;
  text-align: justify;
  color: #314356;
}

.s01 p.p01 span {
  font-weight: bold;
}

.s01 p.p02 {
  padding: 2.08vw 0 0;
  font-size: 1.04vw;
  line-height: 1.5;
  text-align: justify;
  color: #314356;
}

.s01 p.p02 + p {
  padding: 1.56vw 0 0;
}

.cc-btn {
  padding: 1.04vw 4.69vw;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.52vw;
  font-size: 1.25vw;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  border-radius: 3.39vw;
  color: #FFF;
  background: #AA8431;
  transition: filter 0.3s;
}

.cc-btn:hover {
  filter: brightness(115%);
}

.s02-wrap {
  width: 65.63vw;
  margin: 0 auto;
  padding: 4.17vw 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.s02 h2 {
  font-size: 2.6vw;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
  color: #A58030;
}

.s02 p.p01 {
  width: 55.94vw;
  padding: 0.52vw 0 1.77vw;
  font-size: 1.04vw;
  font-weight: 500;
  line-height: 1.5;
  text-align: center;
  color: #314356;
}

.s02 p.p01 span {
  font-weight: bold;
}

.s02-row {
  display: flex;
  gap: 3.65vw;
}

.s02-img {
  width: 22.5vw;
}

.s02-img img {
  border-radius: 1.04vw;
}

.s02-text {
  width: 39.38vw;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.s02 h3 {
  padding: 0 0 1.04vw;
  font-size: 1.04vw;
  font-weight: 700;
  line-height: 1.5;
  color: #A58030;
}

.s02 p.p02 {
  padding: 0 0 2.08vw;
  font-size: 1.04vw;
  font-weight: 500;
  line-height: 1.5;
  color: #314356;
}

.s02 ul {
  padding: 0.52vw 0 2.6vw 1.56vw;
  display: flex;
  flex-direction: column;
  gap: 0.83vw;
}

.s02 li {
  font-size: 1.04vw;
  line-height: 1.5;
  color: #314356;
}

.s02 li span {
  font-weight: bold;
}

.s02 .cc-btn {
  padding: 1.04vw 2.34vw;
  font-size: 1.04vw;
  background: #314356;
}

.s03 {
  padding: 4.38vw 0 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.s03 h2 {
  padding: 0 0 5.21vw;
  font-size: 2.6vw;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
  color: #A58030;
}

.s03-row {
  width: 65.63vw;
  margin: 0 auto 10.94vw;
  display: flex;
  justify-content: flex-start;
  position: relative;
}

.s03-row.reverse {
  justify-content: flex-end;
}

.s03-info {
  width: 28.13vw;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.s03-img {
  width: 48.96vw;
  max-width: initial;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(1vw, -50%);
  border-radius: 1.04vw 0 0 1.04vw;
}

.s03-row.reverse .s03-img {
  left: initial;
  right: 50%;
  transform: translate(-1vw, -50%);
  border-radius: 0 1.04vw 1.04vw 0;
}

.s03 h3 {
  font-size: 1.56vw;
  font-weight: 700;
  line-height: 1.4;
  color: #A58030;
}

.s03 p {
  padding: 1.04vw 0 2.08vw;
  font-size: 1.04vw;
  font-weight: 500;
  line-height: 1.5;
  color: #314356;
}

.s03 .cc-btn {
  margin: -3.65vw 0 0;
  font-size: 1.04vw;
  background: #314356;
}

.s05 {
  padding: 4.17vw 0;
  background-color: #F1F1F1;
}

.s05 h2 {
  margin: 0 auto 2.08vw;
  font-size: 2.6vw;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  color: #A58030;
}

.s05-row {
  display: flex;
  justify-content: center;
  gap: 1.88vw;
}

.s05-item {
  width: 14.9vw;
  background-color: #314356;
  position: relative;
}

.s05-info {
  padding: 0.94vw 0.89vw 3.96vw;
}

.s05 h3 {
  font-family: 'Montserrat', sans-serif;
  font-size: 0.83vw;
  font-weight: 700;
  line-height: 1.3;
  color: #D0BB8D;
}

.s05-item p {
  padding: 0.52vw 0 1.3vw;
  font-size: 0.83vw;
  line-height: 1.2;
  color: #F1F1F1;
}

.s05-item .cc-btn {
  position: absolute;
  left: 50%;
  bottom: 1.35vw;
  transform: translateX(-50%);
  width: 11.15vw;
  padding: 0.78vw 0.52vw;
  font-size: 0.83vw;
  align-self: center;
}

.s10-wrap {
  width: 65.63vw;
  margin: 0 auto;
  padding: 4.48vw 0 5.21vw;
  display: flex;
  justify-content: space-between;
}

.s10-info {
  width: 17.19vw;
}

.s10 h2 {
  font-family: "Montserrat", sans-serif;
  font-size: 1.56vw;
  font-weight: 700;
  line-height: 1.3;
  color: #A58030;
}

.s10 p.p01 {
  padding: 1.56vw 0 0.52vw;
  font-size: 1.04vw;
  font-weight: 700;
  line-height: 1.5;
  color: #314356;
}

.s10 p.p02 {
  font-size: 1.04vw;
  line-height: 1.5;
  color: #314356;
}

.s10 p.p03 {
  margin: 1.56vw 0 0;
  padding: 1.56vw 0 0;
  font-size: 1.25vw;
  font-weight: 700;
  line-height: 1.5;
  color: #314356;
  position: relative;
}

.s10 p.p03::before {
  position: absolute;
  content: '';
  width: 100%;
  height: 0.1rem;
  top: 0;
  left: 0;
  background: #314356;
}

.s10-map {
  width: 43vw;
}

.hide-desktop {
  display: none;
}

@media screen and (max-width: 600px) {
.s01-wrap {
  width: 84vw;
  padding: 13.33vw 0;
}
.s01 h1 {
  font-size: 8vw;
  line-height: 1.1;
}
.s01 h1 span {
  display: inline-block;
  padding: 0 0 2vw;
  color: #AA8431;
}
.s01 p.p01 {
  width: 74.67vw;
  padding: 13.33vw 0 9.33vw;
  font-size: 5.33vw;
}
.s01-row {
  flex-direction: column;
  gap: 8vw;
}
.s01-item {
  padding: 8vw 6.13vw;
  align-items: center;
  border-radius: 2.67vw;
}
.s01-item p {
  padding: 0 0 5.33vw;
  font-size: 4.8vw;
  text-align: center;
}
.cc-btn {
  padding: 2.67vw 8.53vw;
  font-size: 4.27vw;
  border-radius: 14.93vw;
}
.s01-map {
  margin: 13.33vw 0 0;
}




.s10-wrap {
  width: 84vw;
  padding: 14.4vw 0 21.33vw;
  flex-direction: column;
  align-items: center;
}
.s10-info {
  width: 100%;
}
.s10 h2 {
  font-size: 5.33vw;
  text-align: center;
}
.s10 p.p01 {
  padding: 8vw 0 2.67vw;
  font-size: 5.33vw;
  text-align: center;
}
.s10 p.p02 {
  font-size: 4.8vw;
  text-align: center;
}
.s10 p.p03 {
  margin: 8vw 0 0;
  padding: 8vw 0 5.33vw;
  font-size: 6.4vw;
  text-align: center;
}
.s10-map {
  width: 100%;
  border-radius: 1.07vw;
  overflow: hidden;
}

.hide-desktop {
  display: flex;
}
.hide-mobile {
  display: none;
}
}