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

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

@font-face {
  font-family: Didotltpro;
  src: url('../fonts/DidotLTPro-Bold.woff2') format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

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

:root {
  --body-text: #301512;
  --title-red: #942a26;
  --global-padding: min(5vw, 100px);
  --white: white;
  --gold: #d3bda1;
  --beige: #dcd3cc;
  --title-grey: #414042;
  --serif: "Noto Serif TC", sans-serif;
  --zh-serif: "Noto Serif TC", sans-serif;
  --title-color: #b7423c;
}

body {
  color: var(--body-text);
  font-family: Noto Sans TC, sans-serif;
  font-size: 16px;
  line-height: 20px;
}

h2 {
  color: var(--title-red);
  letter-spacing: .1em;
  margin-top: 20px;
  margin-bottom: 10px;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
}

h3 {
  color: var(--title-red);
  letter-spacing: .05em;
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 24px;
  font-weight: 400;
  line-height: 30px;
}

p {
  margin-bottom: 10px;
}

img {
  width: 100%;
  max-width: 100%;
  height: 100%;
  display: inline-block;
}

.background-video {
  width: 100%;
  height: 100%;
  position: absolute;
}

.hero-text {
  color: #fff;
  text-align: center;
  text-transform: uppercase;
  white-space: pre;
  font-size: min(8vw, 57px, 12vh);
  font-weight: 400;
  line-height: 1.2em;
}

.hero-text.small {
  font-size: 28px;
}

.body-headline {
  color: #000;
  font-size: 20px;
  line-height: 1.5em;
  position: relative;
}

.right-arrow-container {
  z-index: 2;
  opacity: 1;
  justify-content: flex-end;
  width: min(min(50vw, 50vh), 300px);
  height: min(min(50vw, 50vh), 300px);
  margin-left: 0;
  margin-right: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  right: 0;
  overflow: hidden;
  transform: translate(0%, -50%);
}

.hero-text-wrapper {
  width: -moz-fit-content;
  width: fit-content;
}

.bottom-above-stroke-wrapper {
  z-index: 1;
  color: #fff;
  text-align: center;
  justify-content: center;
  align-items: flex-end;
  width: 800px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  position: relative;
  bottom: 12vh;
}

.hero-text-container {
  z-index: 2;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: min(min(50vw, 50vh), 300px);
  height: min(min(50vw, 50vh), 300px);
  display: flex;
  position: absolute;
  top: 50%;
  left: 50%;
  overflow: hidden;
  transform: translate(-50%, -50%);
}

.left-arrow-container {
  z-index: 2;
  opacity: 1;
  justify-content: flex-end;
  width: min(min(50vw, 50vh), 300px);
  height: min(min(50vw, 50vh), 300px);
  margin-left: 0;
  margin-right: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  right: 0;
  overflow: hidden;
  transform: translate(-100%, -50%);
}

.left-arrow {
  opacity: 1;
  border: min(20px, min(5vh, 3vw)) solid #fff;
  width: min(min(50vw, 50vh), 300px);
  height: min(min(50vw, 50vh), 300px);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(0%, -50%);
}

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

.white-div {
  z-index: 2;
  background-color: #fff;
  width: 0;
  height: 0;
  transition: border-width .2s;
  position: absolute;
  inset: 50% 0% 0% 50%;
  transform: translate(-50%, -50%);
}

.bottom-stroke {
  z-index: 1;
  background-color: #000;
  width: 3px;
  height: 150px;
  position: absolute;
  top: auto;
  bottom: 0;
  left: 50%;
  transform: translate(-50%);
}

.bottom-stroke.white {
  background-color: #fff;
  transform: translate(0)translate(-50%);
}

.bottom-stroke.white.origin-top {
  transform-origin: 50% 0;
  width: 1px;
  height: 10vh;
  transform: translate(-50%);
}

.hero-section {
  z-index: 12;
  height: 100vh;
  position: relative;
}

.hero-section.snap-section {
  flex-flow: row;
  justify-content: center;
  align-items: flex-end;
  display: flex;
  overflow: hidden;
}

.right-arrow {
  opacity: 1;
  border: min(20px, min(5vh, 3vw)) solid #fff;
  width: min(min(50vw, 50vh), 300px);
  height: min(min(50vw, 50vh), 300px);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-100%, -50%);
}

.animation-trigger {
  width: 10px;
  height: 99%;
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}

.snap-section {
  height: calc(var(--vh, 1vh) * 100);
  width: 100%;
  position: relative;
}

.snap-section.footer {
  padding: 70px var(--global-padding) 30px;
  background-color: #b2332d;
  height: auto;
}

.snap-section.hero-section {
  height: calc(var(--vh, 1vh) * 100);
}

.snap-section.lead-in-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  background-color: #e3e2e1;
}

.snap-section.mvpeak-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
}

.snap-section.prime-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  justify-content: center;
  align-items: center;
  display: flex;
  overflow: hidden;
}

.snap-section.prime-section.desktop-hide {
  display: none;
}

.snap-section.map-section {
  padding-right: var(--global-padding);
  justify-content: flex-start;
  align-items: center;
  padding-left: 0;
  display: flex;
  overflow: hidden;
}

.snap-section.architecture-section, .snap-section.design-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  background-color: #f3f3f3;
}

.snap-section.clubhouse-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  background-color: #f5f5f4;
}

.snap-section.special-unit-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
}

.snap-section.floorplan-section {
  padding-right: var(--global-padding);
  padding-bottom: 50px;
  padding-left: var(--global-padding);
  padding-top: calc(var(--header-height, 70px)  + 30px);
  flex-flow: column;
  display: flex;
}

.snap-section.follow-us-section {
  background-color: #cfc8c2;
  height: auto;
  padding-top: 50px;
  padding-bottom: 50px;
}

.snap-section.palace-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  background-color: #f3f3f3;
}

.snap-section.product-section {
  padding-left: var(--global-padding);
  background-color: #cc4339;
  overflow: hidden;
}

.snap-section.brand-section {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  background-color: #f8f8f8;
  overflow: hidden;
}

.swiper-container {
  width: 100%;
  height: 100%;
  position: absolute;
  overflow: hidden;
}

.swiper-container.fixed-ratio {
  width: auto;
  max-width: 1920px;
  height: 100%;
  max-height: 1080px;
  position: relative;
}

.swiper-container.card-slider {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  width: auto;
  position: relative;
}

.swiper-container.product-scope {
  height: auto;
  position: relative;
}

.swiper-wrapper {
  width: 100%;
  height: 100%;
  display: flex;
}

.swiper-slide.home-slider-scope {
  aspect-ratio: 2;
  color: var(--white);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.swiper-slide.gallery-slider-scope {
  aspect-ratio: 2;
  color: var(--white);
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.swiper-slide.card-scope {
  aspect-ratio: 2;
  color: var(--white);
  border-radius: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 308px;
  height: 308px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.swiper-slide.product-slider-scope {
  color: var(--white);
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: auto;
  display: flex;
  position: relative;
}

.image-background {
  z-index: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
}

.image-background.home-kv {
  object-position: 50% 100%;
}

.home-slider-text-wrapper {
  z-index: 1;
  color: var(--gold);
  bottom: calc(var(--vh, 1vh) * 67);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
}

.home-slider-text-large {
  text-align: center;
  letter-spacing: .1em;
  font-size: 3rem;
}

.kv-slider-text {
  text-align: center;
  letter-spacing: .8em;
  font-family: Noto Serif TC, sans-serif;
  font-size: 1.4rem;
  line-height: 1;
}

.kv-slider-text.font-en-serif {
  color: var(--gold);
  letter-spacing: .05em;
}

.kv-slider-text.font-zh-serif {
  color: var(--gold);
  padding-left: .67em;
}

.kv-logo {
  width: min(800px, 35vw, calc(var(--vh, 1vh) * 40));
  margin-bottom: calc(var(--vh, 1vh) * 7);
  transform: translate(-5%);
}

.toggle-disclaimer {
  z-index: 30;
  padding-bottom: 15px;
  padding-left: calc(var(--global-padding) / 2);
  padding-right: calc(var(--global-padding) / 2);
  flex-flow: column;
  width: 100%;
  transition-property: background-color;
  transition-duration: .5s;
  transition-timing-function: ease;
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
}

.toggle-disclaimer.inside-image {
  justify-content: center;
  align-items: flex-end;
  padding-bottom: 10px;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
}

.toggle-disclaimer_toggle {
  z-index: 1;
  color: var(--white);
  text-transform: uppercase;
  text-shadow: 0 1px 4px #000000b3;
  cursor: pointer;
  align-items: center;
  width: auto;
  padding-top: 5px;
  padding-bottom: 5px;
  padding-left: 0;
  text-decoration: none;
  display: inline-flex;
}

.toggle-disclaimer_toggle.black {
  color: var(--body-text);
  text-shadow: none;
}

.wb_section-disclaimer-indicator {
  width: 10px;
  margin-top: -1px;
  margin-right: 8px;
  position: relative;
  transform: rotate(-90deg);
}

.toggle-disclaimer_toggle_label {
  pointer-events: none;
  letter-spacing: .15em;
  text-transform: none;
  font-size: .8rem;
  text-decoration: none;
}

.toggle-disclaimer_toggle_label.font-en-sans {
  letter-spacing: .05em;
}

.toggle-disclaimer_content-wrapper {
  z-index: 1;
  opacity: 0;
  pointer-events: none;
  background-color: #00000080;
  width: 385px;
  max-width: calc(100% - 20px);
  max-height: 183px;
  padding: 20px;
  transition-property: opacity;
  transition-duration: .5s;
  transition-timing-function: ease;
  display: flex;
  position: absolute;
  bottom: calc(100% + 10px);
  overflow: hidden;
}

.toggle-disclaimer_content-wrapper.scrollable-wrapper {
  max-height: 150px;
  padding: 20px;
  position: absolute;
}

.toggle-disclaimer_content {
  text-shadow: 0 1px 1px #000000b3;
}

.toggle-disclaimer_content.scrollable-wrapper {
  color: var(--beige);
  font-family: Noto Sans TC, sans-serif;
  font-size: .8rem;
  line-height: 1.5;
  position: relative;
  overflow: hidden;
}

.paragraph-8 {
  margin-bottom: 0;
}

.image {
  pointer-events: none;
}

.section-content-grid {
  z-index: 1;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  padding-top: var(--header-height, 100px);
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  height: 100%;
  display: grid;
  position: relative;
}

.section-content-grid.col-6 {
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
}

.lead-in-tagline {
  color: #e0c7b3;
  text-align: center;
  letter-spacing: .05em;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  padding-left: 3vw;
  padding-right: 3vw;
  font-family: Didotltpro, Times New Roman, sans-serif;
  font-size: 2.6vw;
  line-height: 1.2;
  display: flex;
}

.body-text {
  letter-spacing: .05em;
  margin-bottom: 15px;
  font-family: Noto Sans TC, sans-serif;
  font-size: max(min(1rem, 1vw), 12px);
  line-height: 1.6;
}

.body-text.lead-in-scope {
  line-height: 2.7;
}

.lead-in-tagline-for {
  width: 5vw;
  height: auto;
  margin-top: 1.6vw;
  margin-bottom: 1.6vw;
}

.lead-in-text {
  color: var(--body-text);
  text-align: center;
  letter-spacing: .05em;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  font-family: Didot, Georgia, sans-serif;
  font-size: min(1.2rem, 1.3vw);
  line-height: 3.2;
  display: flex;
}

.background-pattern {
  z-index: 0;
  pointer-events: none;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
}

.background-pattern.half {
  width: 200%;
}

.background-pattern.half.pale {
  opacity: .5;
}

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

.title-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.title-wrapper.mobile-align-center.brand-scope {
  margin-top: 50px;
}

.subtitle {
  margin-bottom: 0;
  font-size: min(1.4rem, 1.4vw);
}

.subtitle.font-zh-serif {
  color: var(--title-red);
}

.subtitle.font-en-serif {
  color: var(--title-red);
  letter-spacing: 0;
}

.font-zh-serif {
  color: var(--title-grey);
  font-family: Noto Serif TC, sans-serif;
  font-size: min(1.5rem, 1.4vw);
  line-height: 1.5;
}

.font-zh-serif.red {
  color: var(--title-red);
}

.font-en-serif {
  color: var(--title-grey);
  font-family: Didotltpro, Times New Roman, sans-serif;
  font-size: min(1.5rem, 1.5vw);
  line-height: 1.35;
}

.font-en-serif.large {
  font-size: min(1.9rem, 1.7vw);
}

.font-en-serif.large.red {
  color: var(--title-red);
}

.title-mv {
  color: var(--title-red);
  letter-spacing: 0;
  margin-bottom: -.2em;
  font-family: Carilos, Georgia, sans-serif;
  font-weight: 400;
}

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

.title-p {
  font-family: Carilos, Georgia, sans-serif;
}

.title-remain {
  color: var(--title-grey);
  letter-spacing: 0;
  margin-bottom: -.22em;
  font-family: Didotltpro, Times New Roman, sans-serif;
  font-size: 136%;
  font-weight: 400;
}

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

.prime-wrapper {
  margin-top: calc(var(--header-height, 80px) / 2);
  width: calc(100% - 405px - var(--global-padding)  - 50px);
  height: calc(var(--vh, 1vh) * 100);
  justify-content: flex-start;
  align-items: center;
  max-width: 1800px;
  display: flex;
  position: absolute;
  right: -2%;
}

.prime-circle-image {
  object-fit: cover;
  object-position: 0% 32%;
}

.image-3 {
  object-fit: cover;
}

.map-wrapper {
  z-index: 1;
  margin-top: calc(var(--header-height, 80px) / 2);
  width: calc(100% - 405px - var(--global-padding)  - 50px);
  height: calc(var(--vh, 1vh) * 100);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
  position: absolute;
  top: 0;
  left: 0;
}

.map-image {
  object-fit: contain;
  object-position: 50% 50%;
  min-height: calc(var(--vh, 1vh) * 100);
}

.train-image {
  max-width: 400px;
  height: auto;
  margin-top: 10px;
}

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

.vertical-space-between-wrapper {
  flex-flow: column;
  justify-content: space-between;
  height: 100%;
  padding-top: 30px;
  padding-bottom: 80px;
  display: flex;
}

.vertical-space-between-wrapper.left {
  padding-right: 30px;
}

.section-content-wrapper {
  z-index: 1;
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  padding-top: calc(var(--header-height, 70px)  + 30px);
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.section-content-wrapper.col-6 {
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
}

.section-content-wrapper.align-right {
  justify-content: flex-end;
  align-items: center;
}

.section-content-wrapper.horizontal-space-between-wrapper {
  justify-content: space-between;
  align-items: flex-start;
}

.section-content-wrapper.align-center {
  justify-content: center;
  align-items: center;
}

.text-wrapper {
  width: max(500px, 30vw);
  max-width: 100%;
  height: 100%;
  max-height: 1080px;
  position: relative;
}

.text-wrapper.right-side {
  padding-left: 80px;
}

.text-wrapper.left-side {
  padding-right: 30px;
}

.text-wrapper.map-scope {
  z-index: 1;
  width: min(500px, 30vw);
  position: static;
}

.div-block {
  flex: 1;
}

.side-slider {
  z-index: 1;
  flex: 1;
  justify-content: center;
  align-items: center;
  width: 0;
  height: 100%;
  padding-top: 50px;
  padding-bottom: 50px;
  display: flex;
  position: relative;
}

.side-slider.plan-scope {
  flex: 1;
  width: 100%;
  height: 0;
  position: relative;
}

.align-center-wrapper {
  flex-flow: column;
  justify-content: center;
  height: 100%;
  padding-top: 50px;
  padding-bottom: 100px;
  display: flex;
}

.align-center-wrapper.product-scope {
  padding-right: 30px;
}

.align-center-wrapper.half {
  width: 50%;
}

.small {
  font-size: 3.6rem;
}

.footer-row {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: center;
  display: grid;
}

.logo-emperor {
  width: 220px;
  height: auto;
  margin-left: auto;
}

.footer-logo {
  width: 240px;
  height: auto;
  margin-left: auto;
  margin-right: auto;
}

.footer-contact {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: var(--gold);
  flex-flow: column;
  display: flex;
}

.kv-header {
  z-index: 100;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.header-wrapper {
  padding: 10px var(--global-padding);
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: minmax(100px, min-content) minmax(auto, 1fr) minmax(100px, min-content);
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: grid;
}

.header-nav {
  grid-column-gap: max(15px, 2vw);
  grid-row-gap: max(15px, 2vw);
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 1300px;
  margin-bottom: 0;
  margin-left: auto;
  margin-right: auto;
  padding-left: 0;
  display: flex;
}

.header-nav.align-right {
  justify-content: flex-end;
  align-items: center;
}

.header-nav.align-left {
  justify-content: flex-start;
}

.header-nav-item {
  text-align: center;
}

.header-nav-link {
  font-family: var(--serif);
  color: var(--gold);
  text-decoration: none;
}

.header-left-wrapper {
  height: -moz-fit-content;
  height: fit-content;
}

.header-right-wrapper {
  z-index: 10;
  justify-content: flex-end;
  align-items: center;
  display: flex;
  position: relative;
}

.header-center-wrapper {
  justify-content: center;
  align-items: center;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.language-switch {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.language-switch.mobile-hide {
  display: flex;
}

.language-switch.desktop-hide {
  display: none;
}

.language-button {
  color: var(--gold);
  font-size: .8rem;
  text-decoration: none;
}

.language-button.font-en-serif {
  font-family: Noto Serif TC, sans-serif;
}

.hamburger {
  z-index: 101;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 25px;
  height: 9px;
  margin-right: 10px;
  position: relative;
}

.hamburger-top {
  background-color: var(--gold);
  width: 24px;
  height: 1px;
}

.hamburger-middle {
  background-color: var(--gold);
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 1px;
  margin-top: 3px;
  margin-bottom: 3px;
  display: flex;
}

.hamburger-middle-inner {
  width: 4px;
  height: 0;
}

.hamburger-bottom {
  background-color: var(--gold);
  width: 24px;
  height: 1px;
}

.side-menu-nav {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  color: #fff;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  height: 100%;
  margin-bottom: 0;
  padding-left: 0;
  display: flex;
  position: static;
}

.side-menu {
  z-index: 100;
  height: calc(var(--vhr, 1vh) * 100);
  padding-top: var(--header-height, 80px);
  background-color: #24070ae6;
  flex-direction: column;
  flex: 0 auto;
  order: 0;
  justify-content: flex-start;
  align-self: auto;
  align-items: flex-start;
  width: 100%;
  transition-property: transform;
  transition-duration: .8s;
  transition-timing-function: cubic-bezier(.165, .84, .44, 1);
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  overflow: hidden;
  transform: translate(0%, -100%);
}

.side-menu-item {
  color: #d3bda1;
  letter-spacing: .05em;
  text-transform: none;
  justify-content: center;
  align-items: flex-start;
  font-size: 1.3rem;
  line-height: 1;
  text-decoration: none;
  display: flex;
}

.side-menu-item.w--current {
  color: #cd552c;
}

.side-menu-list-wrapper {
  padding: 30px;
}

.side-menu-list-wrapper.sub-menu {
  flex-flow: column;
  height: 100%;
  display: flex;
}

.side-menu-list-wrapper.sales-menu {
  flex-flow: column;
  height: 100%;
  display: none;
}

.side-menu-wrapper {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
}

.side-menu-list-item.has-children {
  grid-column-gap: min(30px, 4vh);
  grid-row-gap: min(30px, 4vh);
  flex-flow: column;
  display: flex;
}

.mobile-submenu-list {
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  height: 100%;
  margin-bottom: 0;
  display: flex;
}

.header {
  z-index: 105;
  background-color: var(--title-red);
  width: 100%;
  transition: transform .8s;
  position: fixed;
  top: 0;
  transform: translate(0, -100%);
}

.header-logo {
  width: 150px;
  height: auto;
}

.footer-contact-title {
  font-size: 1rem;
}

.footer-contact-title.font-en-serif {
  color: var(--gold);
  text-transform: uppercase;
}

.footer-contact-title.font-zh-serif {
  color: var(--gold);
}

.footer-contact-content {
  letter-spacing: .1em;
  font-family: Open Sans, sans-serif;
  font-size: 1.6rem;
}

.side-menu-item-mvp {
  margin-top: .4em;
  font-family: Carilos, Georgia, sans-serif;
}

.side-menu-item-remain {
  margin-top: .1em;
  font-family: Didot, Georgia, sans-serif;
  font-size: 136%;
}

.side-menu-item-chinese {
  font-family: var(--zh-serif);
  letter-spacing: .1em;
  margin-left: 5px;
  font-size: 120%;
  font-weight: 300;
}

.background-half {
  z-index: 0;
  background-color: var(--title-red);
  pointer-events: none;
  width: 50vw;
  height: 100%;
  position: absolute;
  inset: 0% auto auto 0%;
  overflow: hidden;
}

.swiper-slide-image {
  z-index: 0;
  object-fit: cover;
  flex: 1;
  width: 100%;
  height: 100%;
}

.swiper-slide-image.home-kv {
  object-position: 50% 100%;
}

.swiper-slide-image-wrapper {
  aspect-ratio: 3 / 2;
  width: 100%;
  height: auto;
  max-height: calc(100% - 30px);
  position: relative;
}

.slider-caption {
  margin-top: 5px;
  font-size: min(1rem, 1vw);
}

.slider-caption.black {
  color: var(--body-text);
}

.heading {
  justify-content: flex-start;
  align-items: flex-end;
  display: flex;
}

.floor-name {
  margin-top: 5px;
}

.floorplan-image {
  z-index: 0;
  object-fit: contain;
  flex: 1;
  width: 100%;
  height: 100%;
}

.floorplan-image.home-kv {
  object-position: 50% 100%;
}

.small-light-pattern {
  z-index: 0;
  object-fit: contain;
  object-position: 50% 0%;
  width: max(400px, 20vw);
  height: 25vh;
  position: absolute;
  top: 0;
  right: -50px;
}

.footer-contact-copy {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  color: var(--gold);
  flex-flow: column;
  display: flex;
}

.spacer_50h {
  height: 50px;
}

.footer-disclaimer-button {
  color: var(--gold);
  text-align: center;
  text-decoration: none;
}

.footer-disclaimer-button.font-en-serif, .footer-disclaimer-button.font-zh-serif {
  font-size: 14px;
}

.text-block-2 {
  color: var(--gold);
}

.text-block-2.font-en-serif, .text-block-2.font-zh-serif {
  font-size: 14px;
}

.share-heading {
  padding-right: var(--global-padding);
  padding-left: var(--global-padding);
  font-family: var(--zh-serif);
}

.card-list {
  margin-top: 20px;
}

.card-name-wrapper {
  background-color: #350308;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding: 20px 15px;
  display: flex;
}

.card-name {
  letter-spacing: .2em;
  font-size: 1rem;
}

.social-icon {
  width: 20px;
  height: 20px;
  margin-right: 10px;
}

.section-title {
  font-size: min(4.375rem, 4vw);
}

.section-title.small {
  font-size: min(3.6rem, 3.5vw);
}

.large {
  font-size: min(2.1825rem, 2vw);
  line-height: 1.25;
}

.club-title {
  color: var(--title-red);
  letter-spacing: -.01em;
  font-family: Didotltpro, Times New Roman, sans-serif;
  font-size: 2.5rem;
  line-height: .95;
}

.landing-disclaimer-popup {
  z-index: 10000;
  padding-top: 80px;
  padding-right: var(--global-padding);
  padding-bottom: 80px;
  padding-left: var(--global-padding);
  height: calc(var(--vh, 1vh) * 100);
  background-color: #942a26;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
  position: fixed;
  inset: 0% auto auto 0%;
}

.landing-disclaimer-popup.closed {
  display: none;
}

.landing-disclaimer-box {
  background-color: #420405b3;
  flex: 1;
  width: 100%;
  max-width: 1280px;
  height: 0;
  max-height: 800px;
  margin-left: auto;
  margin-right: auto;
  padding: 70px;
  position: relative;
}

.landing-disclaimer-logo {
  width: min(350px, 20vw);
  margin-bottom: 30px;
  margin-left: auto;
  margin-right: auto;
}

.landing-disclaimer-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 1280px;
  height: 100%;
  max-height: 900px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.landing-disclaimer-content {
  color: var(--white);
  width: 100%;
  height: 100%;
  padding-right: 20px;
  font-family: Didot, Georgia, sans-serif;
  line-height: 2;
  position: relative;
  overflow: hidden;
}

.close-button {
  background-color: #0000;
  width: 25px;
  height: 25px;
  padding: 0;
  position: absolute;
  top: 30px;
  right: 60px;
}

.close-button.document-scope, .close-button.section-menu-scope {
  top: 100px;
  right: 30px;
}

.cross-line-1 {
  pointer-events: none;
  transform-origin: 0 0;
  background-color: #fff;
  width: 1px;
  height: 34px;
  position: absolute;
  inset: 0% auto auto 0%;
  transform: rotate(-45deg);
}

.cross-line-2 {
  pointer-events: none;
  transform-origin: 100% 0;
  background-color: #fff;
  width: 1px;
  height: 34px;
  position: absolute;
  inset: 0% 0% auto auto;
  transform: rotate(45deg);
}

.document-popup {
  z-index: 10000;
  padding-top: 80px;
  padding-right: var(--global-padding);
  padding-bottom: 80px;
  padding-left: var(--global-padding);
  opacity: 1;
  outline-offset: 0px;
  height: calc(var(--vh, 1vh) * 100);
  background-color: #420405f2;
  outline: 3px #301512;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  transition-property: opacity;
  transition-duration: 1s;
  transition-timing-function: ease;
  display: flex;
  position: fixed;
  inset: 0% auto auto 0%;
}

.document-popup.closed {
  opacity: 0;
  pointer-events: none;
}

.document-wrapper {
  flex-flow: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 900px;
  height: 100%;
  max-height: 900px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: relative;
}

.document-box {
  opacity: 0;
  pointer-events: none;
  width: 100%;
  max-width: 1280px;
  height: 100%;
  max-height: 800px;
  margin-left: auto;
  margin-right: auto;
  padding: 70px;
  transition: opacity 1s;
  position: absolute;
}

.document-box.active {
  opacity: 1;
  pointer-events: auto;
}

.document-content {
  color: var(--white);
  width: 100%;
  height: 100%;
  padding-right: 20px;
  font-family: Didot, Georgia, sans-serif;
  line-height: 2;
  position: relative;
  overflow: hidden;
}

.document-row {
  border-bottom: 1px solid #fff;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  padding-bottom: 10px;
  font-size: 1.2rem;
  display: flex;
}

.document-name {
  flex: 1;
  padding-right: 30px;
}

.document-download-button {
  color: var(--white);
  text-decoration: none;
}

.document-title {
  color: var(--white);
  text-align: center;
  margin-bottom: 50px;
  font-size: 3rem;
  line-height: 1.5;
}

.document-first-line {
  border-bottom: 1px solid #fff;
}

.card-image-wrapper {
  aspect-ratio: 3 / 2;
  width: 100%;
  height: 100%;
  position: relative;
}

.animation-mask {
  position: relative;
  overflow: hidden;
}

.animation-flex-wrapper {
  justify-content: center;
  align-items: flex-start;
  display: flex;
  transform: none;
}

.header-center-grid {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  grid-template-rows: auto;
  grid-template-columns: 1fr minmax(150px, 150px) 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  display: grid;
}

.school-list {
  padding-left: var(--global-padding);
  color: var(--white);
  font-size: 15px;
  line-height: 1.5;
  position: absolute;
  top: 50px;
  left: 0;
}

.school-heading {
  font-weight: 600;
}

.school-sub-list {
  margin-bottom: 30px;
}

.scroll-hint {
  z-index: 1;
  opacity: .5;
  bottom: 20px;
  right: calc(var(--global-padding) / 2);
  width: 10px;
  position: absolute;
}

.coming-soon {
  justify-content: center;
  align-items: center;
  height: 80%;
  font-size: 2rem;
  display: flex;
}

.side-menu-item-en {
  font-family: var(--zh-serif);
  letter-spacing: .1em;
  margin-left: 5px;
  font-size: 120%;
  font-weight: 300;
}

.side-menu-title {
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.document-date {
  padding-right: 30px;
}

.back-to-top {
  width: 46px;
  height: 46px;
  position: fixed;
  bottom: 30px;
  right: 30px;
}

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

.title-club {
  color: var(--title-grey);
  letter-spacing: 0;
  margin-bottom: -.2em;
  font-family: Didotltpro, Times New Roman, sans-serif;
  font-size: 136%;
  font-weight: 400;
}

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

.title-club-mvp {
  color: var(--title-red);
  letter-spacing: 0;
  margin-bottom: -.22em;
  padding-left: .05em;
  font-family: Carilos, Georgia, sans-serif;
  font-weight: 400;
}

.title-club-mvp.white {
  color: var(--white);
}

.product-slider {
  z-index: 1;
  flex-flow: column;
  flex: 1;
  justify-content: center;
  align-items: flex-start;
  width: 0;
  height: 100%;
  padding-top: 30px;
  padding-bottom: 30px;
  display: flex;
  position: relative;
}

.product-slider.plan-scope {
  flex: 1;
  width: 100%;
  height: 0;
  position: relative;
}

.product-card {
  background-color: #fff;
  border-radius: 20px;
  flex-flow: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 360px;
  height: 530px;
  padding: 30px;
  display: flex;
  overflow: hidden;
}

.swiper-control {
  padding-right: var(--global-padding);
  grid-column-gap: 80px;
  grid-row-gap: 80px;
  text-align: right;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  margin-top: 20px;
  display: flex;
}

.product-card-image-wrapper {
  width: 300px;
  height: 300px;
}

.product-card-image {
  object-fit: contain;
}

.product-card-title {
  color: var(--title-color);
  margin-top: 0;
  margin-bottom: 20px;
  font-weight: 400;
}

.product-card-content-wrapper {
  color: var(--body-text);
  letter-spacing: .05em;
  flex: 1;
  width: 100%;
  font-size: 1rem;
  line-height: 1.6;
  overflow: auto;
}

.swiper-button-prev2 {
  width: 26px;
}

.swiper-button-next2 {
  width: 26px;
  transform: rotate(180deg);
}

.large-light-pattern {
  z-index: 0;
  object-fit: cover;
  object-position: 50% 0%;
  width: max(400px, 40vw);
  height: auto;
  position: absolute;
  top: 0;
  left: 0;
}

.tower-image {
  object-fit: contain;
}

.wheat-wrapper {
  justify-content: space-between;
  align-items: center;
  margin-top: 20px;
  padding-left: 3vw;
  padding-right: 3vw;
  display: flex;
}

.wheat-image {
  opacity: .4;
  width: 4.5vw;
  height: auto;
}

.wheat-image.reversed {
  transform-style: preserve-3d;
  transform: rotateX(0)rotateY(180deg)rotateZ(0);
}

.wheat-content {
  font-family: var(--serif);
  color: #cdb59e;
  text-align: center;
  letter-spacing: .3em;
  flex: 1;
  padding-left: 1vw;
  padding-right: 1vw;
  font-size: 1.2vw;
  line-height: 2;
}

.wheat-content.font-en-serif {
  letter-spacing: .1em;
  font-size: 1vw;
}

.brand-gold-pattern {
  z-index: 0;
  object-fit: cover;
  object-position: 50% 0%;
  width: max(500px, 60vw);
  height: auto;
  position: absolute;
  bottom: 0;
  left: 0;
}

.water-mark-wrapper {
  color: #f0efef;
  text-transform: uppercase;
  flex-flow: column;
  font-family: Didotltpro, Times New Roman, sans-serif;
  font-size: min(6vw, 7vh, 10rem);
  line-height: .8;
  display: inline-flex;
}

.water-mark-wrapper.brand-scope {
  z-index: 0;
  position: absolute;
  bottom: 8%;
}

.water-mark-wrapper.place-scope {
  left: var(--global-padding);
  z-index: 0;
  font-size: min(6vw, 7vh, 10rem);
  position: absolute;
  bottom: -2%;
}

.water-mark-wrapper.design-scope {
  z-index: 0;
  color: #e9e9e9;
  position: absolute;
  bottom: 8%;
}

.water-mark-line-1 {
  transform: translate(-7%);
}

.water-mark-line-2 {
  transform: translate(10%);
}

.water-mark-line-3 {
  transform: translate(0%);
}

.brand-wrapper {
  z-index: 1;
  flex-flow: column;
  flex: 1;
  justify-content: center;
  align-items: flex-start;
  width: 0;
  height: 100%;
  padding-top: 50px;
  padding-bottom: 50px;
  display: flex;
  position: relative;
}

.brand-wrapper.plan-scope {
  flex: 1;
  width: 100%;
  height: 0;
  position: relative;
}

.section-title-2 {
  letter-spacing: 0;
  margin-top: 10px;
  font-family: Didot, Georgia, sans-serif;
  font-size: min(3.2rem, 2.7vw);
  font-weight: 400;
}

.section-title-2.small {
  font-size: min(3.6rem, 3.5vw);
}

.section-logo {
  width: min(300px, 15vw);
  height: auto;
  margin-top: 20px;
  transform: translate(-7%);
}

.footer-contact-link {
  color: var(--gold);
  text-decoration: none;
}

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

.prime-disclaimer {
  z-index: 31;
  font-size: max(min(1rem, 1vw), 12px);
  position: absolute;
  inset: auto 0% 20px auto;
}

.mtr-disclaimer {
  z-index: 31;
  font-size: max(min(1rem, 1vw), 12px);
  position: relative;
}

@media screen and (max-width: 1024px) {
  .hero-text {
    font-size: min(8vw, 45px, 12vh);
  }

  .hero-text.small {
    font-size: 25px;
  }

  .hero-section.snap-section {
    overflow: hidden;
  }

  .snap-section.footer {
    padding-top: 40px;
  }

  .snap-section.lead-in-section {
    height: auto;
    padding-bottom: 90px;
  }

  .snap-section.prime-section {
    flex-flow: column;
    height: auto;
  }

  .snap-section.prime-section.desktop-hide {
    display: flex;
  }

  .snap-section.map-section {
    height: auto;
    padding-left: 0;
    padding-right: 0;
  }

  .snap-section.architecture-section, .snap-section.design-section, .snap-section.clubhouse-section, .snap-section.special-unit-section, .snap-section.floorplan-section, .snap-section.palace-section {
    height: auto;
  }

  .snap-section.product-section {
    height: auto;
    padding-left: 0;
  }

  .snap-section.brand-section {
    height: auto;
  }

  .swiper-container {
    position: relative;
  }

  .swiper-container.fixed-ratio {
    width: 100%;
    height: auto;
  }

  .swiper-container.product-scope {
    padding-left: var(--global-padding);
  }

  .swiper-slide.home-slider-scope, .swiper-slide.gallery-slider-scope, .swiper-slide.card-scope {
    aspect-ratio: 3 / 2;
  }

  .home-slider-text-large {
    font-size: 2rem;
  }

  .kv-slider-text {
    font-size: 1rem;
  }

  .kv-slider-text.font-en-serif {
    font-size: min(2rem, 2.5vw);
  }

  .kv-logo {
    width: min(310px, 40vw);
  }

  .toggle-disclaimer_toggle.mobile-black {
    color: var(--body-text);
    text-shadow: none;
  }

  .section-content-grid {
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
  }

  .lead-in-tagline {
    font-size: 5vw;
  }

  .body-text {
    font-size: max(min(1rem, 1.8vw), 12px);
  }

  .lead-in-tagline-for {
    width: 10vw;
  }

  .background-pattern {
    width: 100%;
    height: 100%;
  }

  .title-wrapper.mobile-align-center {
    text-align: center;
    justify-content: center;
    align-items: center;
  }

  .title-wrapper.mobile-align-center.brand-scope {
    margin-top: 0;
  }

  .subtitle {
    margin-bottom: 10px;
  }

  .font-zh-serif, .font-en-serif {
    font-size: min(2.4rem, 3.2vw);
  }

  .font-en-serif.large {
    font-size: min(3.8rem, 4vw);
  }

  .prime-wrapper {
    width: 150vw;
    position: relative;
    right: auto;
  }

  .prime-wrapper.mobile-hide {
    display: none;
  }

  .map-wrapper {
    width: 100%;
    height: auto;
    min-height: auto;
    margin-top: 60px;
    margin-bottom: 50px;
    position: relative;
    top: auto;
    left: auto;
  }

  .map-image {
    min-height: auto;
  }

  .train-image {
    max-width: 600px;
    margin-top: 30px;
  }

  .vertical-space-between-wrapper {
    justify-content: flex-start;
    align-items: center;
    height: auto;
    padding-bottom: 30px;
  }

  .section-content-wrapper {
    flex-flow: column;
  }

  .section-content-wrapper.align-right {
    height: auto;
    padding-bottom: 80px;
  }

  .section-content-wrapper.horizontal-space-between-wrapper {
    justify-content: flex-start;
    align-items: center;
    height: -moz-fit-content;
    height: fit-content;
  }

  .section-content-wrapper.mobile-reverse {
    flex-flow: column-reverse;
  }

  .text-wrapper {
    text-align: center;
    width: 100%;
  }

  .text-wrapper.right-side {
    padding-left: 0;
  }

  .text-wrapper.left-side {
    padding-right: 0;
  }

  .text-wrapper.map-scope {
    width: 100%;
    max-height: none;
  }

  .text-wrapper.mobile-align-center {
    text-align: center;
    width: 100%;
  }

  .side-slider {
    flex: 0 auto;
    width: 100%;
    height: auto;
    margin-bottom: 60px;
    padding-top: 0;
    padding-bottom: 0;
  }

  .side-slider.plan-scope {
    flex: 0 auto;
    height: auto;
    padding-bottom: 0;
  }

  .align-center-wrapper {
    padding-bottom: 30px;
  }

  .align-center-wrapper.half {
    width: 100%;
    padding-top: 30px;
  }

  .footer-row {
    grid-template-rows: auto auto auto;
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .footer-row.bottom {
    grid-template-rows: auto auto;
  }

  .logo-emperor {
    margin-right: auto;
  }

  .footer-logo {
    width: 200px;
  }

  .footer-contact {
    text-align: center;
    margin-top: 20px;
    margin-bottom: 40px;
  }

  .header-nav, .language-switch.mobile-hide {
    display: none;
  }

  .language-switch.desktop-hide {
    display: flex;
  }

  .language-button.font-en-serif, .language-button.font-zh-serif {
    font-size: .8rem;
  }

  .hamburger {
    flex-direction: column;
    justify-content: center;
    align-self: center;
    align-items: center;
    display: flex;
  }

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

  .hamburger-middle-inner {
    width: 4px;
    height: 0;
    padding-bottom: 0;
    padding-right: 0;
  }

  .side-menu-nav {
    justify-content: flex-start;
    align-items: flex-start;
  }

  .side-menu {
    justify-content: space-between;
    padding-top: 100px;
    padding-bottom: 30px;
    transition: transform .8s cubic-bezier(.165, .84, .44, 1);
    display: flex;
    transform: translate(0%, -100%);
  }

  .side-menu-footer {
    display: none;
  }

  .side-menu-item {
    font-size: 1rem;
  }

  .side-menu-list-wrapper.sub-menu, .side-menu-list-wrapper.sales-menu {
    display: flex;
  }

  .side-menu-wrapper {
    padding-right: var(--global-padding);
    padding-left: var(--global-padding);
  }

  .side-menu-list-item {
    flex-flow: column;
    display: flex;
  }

  .mobile-submenu-list {
    height: 0;
    overflow: hidden;
  }

  .footer-contact-title.font-en-serif {
    color: var(--gold);
  }

  .image-4 {
    object-fit: cover;
  }

  .background-half {
    height: calc(var(--vh, 1vh) * 40);
    width: auto;
  }

  .slider-caption {
    font-size: min(1rem, 1.8vw);
  }

  .section-title {
    margin-top: 0;
    font-size: min(4.375rem, 6vw);
  }

  .section-title.small {
    font-size: min(4.375rem, 6vw);
  }

  .club-title {
    margin-top: 30px;
    font-size: 2.4rem;
  }

  .landing-disclaimer-popup {
    padding-top: 50px;
    padding-bottom: 30px;
  }

  .landing-disclaimer-box {
    padding-left: 30px;
    padding-right: 30px;
  }

  .landing-disclaimer-logo {
    width: min(350px, 30vw);
  }

  .close-button {
    width: 25px;
    height: 25px;
    right: 21px;
  }

  .document-popup {
    padding-top: 50px;
    padding-bottom: 30px;
  }

  .document-box {
    padding-left: 30px;
    padding-right: 30px;
  }

  .text-block-3 {
    font-size: min(1.2rem, 5vw);
  }

  .div-block-2 {
    text-align: center;
  }

  .header-center-grid {
    grid-template-columns: 1fr;
  }

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

  .text-align-right {
    text-align: center;
    margin-top: 30px;
  }

  .product-slider {
    flex: 0 auto;
    width: 100%;
    height: auto;
    margin-bottom: 60px;
    padding-top: 0;
    padding-bottom: 0;
  }

  .product-slider.plan-scope {
    flex: 0 auto;
    height: auto;
    padding-bottom: 0;
  }

  .swiper-control {
    padding-left: var(--global-padding);
    justify-content: center;
    align-items: center;
  }

  .large-light-pattern {
    opacity: .4;
    width: 100%;
  }

  .wheat-image {
    width: 9vw;
  }

  .wheat-content {
    font-size: 2.5vw;
  }

  .wheat-content.font-en-serif {
    font-size: 2vw;
  }

  .brand-gold-pattern {
    width: max(400px, 80vw);
  }

  .water-mark-wrapper.brand-scope {
    bottom: 0%;
    right: 10%;
  }

  .water-mark-wrapper.place-scope, .water-mark-wrapper.design-scope {
    display: none;
  }

  .brand-wrapper {
    flex: 0 auto;
    width: 100%;
    height: auto;
    margin-bottom: 130px;
    padding-top: 50px;
    padding-bottom: 0;
  }

  .brand-wrapper.plan-scope {
    flex: 0 auto;
    height: auto;
    padding-bottom: 0;
  }

  .section-title-2 {
    font-size: min(4.5rem, 6vw);
  }

  .section-title-2.small {
    font-size: min(4.375rem, 6vw);
  }

  .section-logo {
    width: min(600px, 35vw);
  }

  .padded {
    padding-right: var(--global-padding);
    padding-left: var(--global-padding);
  }
}

@media screen and (max-width: 767px) {
  .hero-text {
    font-size: min(8vw, 45px, 12vh);
  }

  .hero-text.small {
    font-size: min(4vw, 25px);
  }

  .body-headline {
    font-size: 12px;
  }

  .right-arrow-container {
    width: min(min(50vw, 50vh), 250px);
    height: min(min(50vw, 50vh), 250px);
  }

  .hero-text-container {
    width: min(50vw, 250px);
    height: min(50vw, 250px);
  }

  .left-arrow-container {
    width: min(min(50vw, 50vh), 250px);
    height: min(min(50vw, 50vh), 250px);
  }

  .left-arrow, .right-arrow {
    border-width: min(12px, min(3vh, 3vw));
    width: min(min(50vw, 50vh), 250px);
    height: min(min(50vw, 50vh), 250px);
  }

  .swiper-slide.home-slider-scope, .swiper-slide.card-scope {
    aspect-ratio: 1;
  }

  .kv-slider-text.font-en-serif {
    font-size: min(2rem, 3vw);
  }

  .kv-slider-text.font-zh-serif {
    font-size: max(min(1.4rem, 2.6vw), 16px);
  }

  .kv-logo {
    width: min(310px, 50vw);
  }

  .toggle-disclaimer {
    padding-right: 0;
    padding-left: calc(var(--global-padding) / 2);
  }

  .toggle-disclaimer.inside-image {
    padding-bottom: 5px;
    padding-left: 10px;
    padding-right: 10px;
  }

  .toggle-disclaimer_content {
    max-height: 50vh;
  }

  .font-en-serif.large {
    font-size: min(1.9rem, 4vw);
  }

  .prime-wrapper {
    width: 200vw;
  }

  .train-image {
    max-width: min(500px, 80vw);
  }

  .header-wrapper {
    grid-template-columns: 1fr minmax(150px, 150px) 1fr;
  }

  .hamburger {
    align-self: center;
    margin-top: 0;
    margin-right: 0;
  }

  .side-menu-nav {
    justify-content: flex-start;
    align-items: flex-start;
  }

  .side-menu {
    padding-left: 30px;
    padding-right: 30px;
  }

  .side-menu-list-wrapper {
    background-color: #0000;
    margin-top: 50px;
    padding-left: 20px;
    padding-right: 20px;
    display: flex;
  }

  .side-menu-list-wrapper.sub-menu {
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 0;
    padding-left: 0;
    display: flex;
  }

  .side-menu-list-wrapper.sales-menu {
    margin-top: 0;
    padding-top: 0;
    padding-bottom: 0;
    padding-right: 0;
    display: flex;
  }

  .side-menu-wrapper {
    width: 100%;
    margin-bottom: 30px;
  }

  .header-logo {
    width: 120px;
  }

  .slider-caption.black.mobile-white {
    color: var(--white);
  }

  .document-name, .document-download-button {
    font-size: 1.2rem;
  }

  .document-title {
    font-size: 2rem;
  }

  .side-menu-item-en {
    font-family: Didot, Georgia, sans-serif;
    font-size: 100%;
  }

  .document-date {
    font-size: 1.2rem;
  }

  .body-text-wrapper.padding {
    padding-right: var(--global-padding);
    padding-left: var(--global-padding);
  }

  .back-to-top {
    position: fixed;
    bottom: 30px;
    right: 30px;
  }

  .brand-wrapper {
    padding-top: 30px;
  }

  .section-logo {
    margin-top: 10px;
  }
}

@media screen and (max-width: 479px) {
  .hero-text {
    font-size: 8vw;
  }

  .hero-text.small {
    font-size: 4vw;
  }

  .body-headline {
    font-size: 14px;
  }

  .hero-text-container {
    width: 50vw;
  }

  .left-arrow {
    border-width: 3vw;
  }

  .hero-section.snap-section {
    overflow: hidden;
  }

  .right-arrow {
    border-width: 3vw;
  }

  .snap-section.lead-in-section {
    padding-bottom: 60px;
  }

  .snap-section.floorplan-section {
    padding-top: var(--header-height, 70px);
  }

  .kv-slider-text.font-en-serif {
    font-size: min(2rem, 4vw);
  }

  .kv-slider-text.font-zh-serif {
    font-size: min(1.4rem, 4vw);
  }

  .kv-logo {
    width: min(310px, 60vw);
  }

  .toggle-disclaimer_content-wrapper {
    max-height: 100px;
    padding-top: 10px;
    padding-bottom: 10px;
  }

  .section-content-grid {
    padding-top: var(--header-height, 70px);
  }

  .lead-in-tagline {
    font-size: 6vw;
  }

  .body-text {
    font-size: max(min(1rem, 2.8vw), 12px);
  }

  .lead-in-tagline-for {
    width: 10vw;
  }

  .lead-in-text {
    font-size: min(1.2rem, 3vw);
  }

  .subtitle {
    font-size: min(1.4rem, 2vw);
  }

  .subtitle.font-zh-serif {
    font-size: max(min(1.4rem, 4vw), 12px);
  }

  .font-zh-serif, .font-en-serif {
    font-size: max(min(1.4rem, 4vw), 14px);
  }

  .prime-wrapper {
    width: 180vw;
    height: 150vw;
    margin-top: 50px;
  }

  .prime-circle-image {
    object-position: 50% 50%;
  }

  .section-content-wrapper {
    padding-top: var(--header-height, 70px);
  }

  .side-menu-item {
    font-size: .9rem;
  }

  .side-menu-list-wrapper.sub-menu, .side-menu-list-wrapper.sales-menu {
    width: 100%;
  }

  .slider-caption {
    font-size: max(min(1rem, 2.8vw), 12px);
  }

  .small-light-pattern {
    left: -20%;
    right: auto;
  }

  .section-title {
    font-size: max(min(4.375rem, 8vw), 30px);
  }

  .large.font-en-serif {
    font-size: min(1.4rem, 5vw);
  }

  .club-title {
    font-size: min(4.375rem, 6vw);
  }

  .landing-disclaimer-logo {
    width: min(350px, 40vw);
  }

  .close-button.section-menu-scope {
    right: 15px;
  }

  .document-box {
    padding-left: 0;
    padding-right: 0;
  }

  .animation-flex-wrapper.en-scope {
    flex-flow: column;
    justify-content: center;
    align-items: center;
  }

  .side-menu-item-en {
    text-align: center;
  }

  .back-to-top {
    bottom: 20px;
    right: 20px;
  }

  .text-align-right {
    margin-top: 20px;
  }

  .large-light-pattern {
    left: -20%;
    right: auto;
  }

  .wheat-content {
    font-size: 2.8vw;
  }

  .brand-gold-pattern {
    left: -20%;
    right: auto;
  }

  .section-title-2 {
    font-size: max(min(4.375rem, 8vw), 30px);
  }
}

#w-node-_924560a7-d709-4319-3da9-79ebf0938861-30a4fa55 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

#w-node-_924560a7-d709-4319-3da9-79ebf0938862-30a4fa55 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  justify-self: stretch;
}

#w-node-_85c4004d-3d8c-183e-fa6c-1fa9b53019b1-30a4fa55 {
  justify-self: center;
}

#w-node-_924560a7-d709-4319-3da9-79ebf0938879-30a4fa55 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  justify-self: end;
}

#w-node-_131f504c-1d4d-7c81-a952-cb97a32a6e7f-30a4fa55 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  justify-self: start;
}

#w-node-f09f61f7-32ed-12d3-9dd9-919101d61af7-30a4fa55 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  justify-self: stretch;
}

#w-node-f26200f5-bab2-259f-8ead-2a8c99b621cf-30a4fa55 {
  grid-area: span 1 / span 1 / span 1 / span 1;
  justify-self: end;
}

#w-node-bce65358-5500-22ae-20a8-81ea984e3efa-30a4fa55, #w-node-_0cdfe732-288f-33d6-dd2c-5ca600856e83-30a4fa55 {
  grid-area: span 1 / span 4 / span 1 / span 4;
}

#w-node-_597b0dd0-1092-053d-961d-c99f0282c53a-30a4fa55, #w-node-_3643c81c-ea40-cd83-a0d2-9c0f376c3185-30a4fa55, #w-node-ea4247aa-1573-3538-1674-843020347a47-30a4fa55 {
  grid-area: span 1 / span 2 / span 1 / span 2;
}

@media screen and (max-width: 1024px) {
  #w-node-_924560a7-d709-4319-3da9-79ebf0938861-30a4fa55 {
    justify-self: start;
  }

  #w-node-e75ccd14-83cd-11fd-ebbc-00a3c99965e2-30a4fa55 {
    order: -9999;
  }

  #w-node-_53bd9f8f-8631-8289-184e-edf100565d78-30a4fa55 {
    order: 9999;
  }
}

@media screen and (max-width: 767px) {
  #w-node-_924560a7-d709-4319-3da9-79ebf0938862-30a4fa55 {
    justify-self: center;
  }
}


@font-face {
  font-family: 'Carilos';
  src: url('../fonts/Carilos.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Didotltpro';
  src: url('../fonts/DidotLTPro-Roman.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Didotltpro';
  src: url('../fonts/DidotLTPro-Bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Didot';
  src: url('../fonts/Didot.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}