@charset "UTF-8";
:root {
  --mainColor1: #3dd2e9;
  --mainColor1RGB: 61, 210, 233;
  --mainColor2: #2bc6e0;
  --mainColor2RGB: 43, 198, 224;
  --mainColor3: #10bfd7;
  --mainColor3RGB: 16, 191, 215;
  --baseColor: #f5efec;
  --baseColorRGB: 245, 239, 236;
  --textColor1: #2c2e35;
  --textColor2: #fff;
  --textColor2RGB: 255, 255, 255;
  --accentColor: #ffdb4b;
  --accentColor2: #fbc700;
  --font-size-sm: clamp(0.38rem, 0.9vw + 0.05rem, 0.77rem);
  --font-size-base: clamp(0.48rem, 1.13vw + 0.06rem, 0.96rem);
  --font-size-md: clamp(0.6rem, 1.41vw + 0.07rem, 1.2rem);
  --font-size-lg: clamp(0.75rem, 1.76vw + 0.09rem, 1.5rem);
}

.controls::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

.controls::-webkit-scrollbar-thumb {
  background: var(--mainColor3);
  border-radius: 5px;
}

.priceContainer {
  position: absolute;
  color: var(--textColor1);
  top: 5%;
  right: 2%;
  z-index: 50;
  background-color: rgba(var(--textColor2RGB), 0.6);
}
.priceContainer .priceTitle,
.priceContainer .billingTitle {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  color: var(--textColor2);
  font-size: var(--font-size-md);
  background: var(--mainColor1);
  background: linear-gradient(
    120deg,
    rgb(61, 210, 233) 25%,
    rgb(43, 198, 224) 25%,
    rgb(43, 198, 224) 76%,
    rgb(16, 191, 215) 76%
  );
  padding: 8px var(--font-size-lg);
  font-weight: 400;
}
.priceContainer .priceTitle .subTitle,
.priceContainer .billingTitle .subTitle {
  font-weight: 300;
  font-size: var(--font-size-sm);
  display: block;
  margin-left: var(--font-size-sm);
  margin-right: var(--font-size-sm);
}
.priceContainer .priceTitle .gradeIcon,
.priceContainer .billingTitle .gradeIcon {
  display: flex;
  justify-content: center;
  align-items: center;
  color: var(--textColor2);
  font-size: var(--font-size-sm);
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  margin-right: var(--font-size-sm);
  padding-right: 1px;
  padding-bottom: 1px;
}
.priceContainer .priceTitle .gradeIcon.gold,
.priceContainer .billingTitle .gradeIcon.gold {
  background-color: #ecbc4b;
}
.priceContainer .priceTitle .gradeIcon.silver,
.priceContainer .billingTitle .gradeIcon.silver {
  background-color: #b3b2b2;
}
.priceContainer .priceTitle .gradeIcon.bronze,
.priceContainer .billingTitle .gradeIcon.bronze {
  background-color: #ad7c63;
}
.priceContainer .priceTitle div,
.priceContainer .billingTitle div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.priceContainer .decoration {
  position: absolute;
  top: 0;
  right: 0;
  height: calc(var(--font-size-lg) + var(--font-size-lg));
  width: 32px;
  background-color: var(--accentColor);
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
  clip-path: polygon(0 0, 100% 100%, 100% 0);
}
.priceContainer .decoration2 {
  position: absolute;
  top: 0;
  right: 0;
  height: calc(var(--font-size-lg) + var(--font-size-lg));
  width: 16px;
  background-color: var(--accentColor2);
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
  clip-path: polygon(0 0, 100% 100%, 100% 0);
}
.priceContainer .closePrice {
  display: none;
  position: absolute;
  top: 8px;
  left: 16px;
  color: var(--textColor2);
  cursor: pointer;
}
.priceContainer .presentation {
  display: flex;
  justify-content: space-between;
}
.priceContainer .presentation .screenshots {
  display: none;
  width: 36%;
  margin-bottom: 32px;
}
.priceContainer .presentation .screenshots figure {
  position: relative;
  filter: drop-shadow(10px 10px 0 rgb(var(--baseColorRGB)));
  margin-bottom: 32px;
}
.priceContainer .presentation .screenshots figure figcaption {
  position: absolute;
  right: 0;
  bottom: -2px;
  font-family: "Oswald", sans-serif;
  font-size: var(--font-size-lg);
  font-weight: 300;
  color: var(--textColor2);
}
.priceContainer .presentation .screenshots figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  filter: drop-shadow(3px 3px 3px rgba(0, 0, 0, 0.2));
}
.priceContainer .presentation .screenshots figure .decoration3 {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 50;
  background-color: var(--accentColor);
  height: 24px;
  width: 24px;
  -webkit-clip-path: polygon(0 0, 100% 100%, 100% 0);
  clip-path: polygon(0 0, 100% 100%, 100% 0);
}
.priceContainer .presentation .billing {
  width: 100%;
}
.priceContainer .presentation .billing h3 span {
  font-size: var(--font-size-sm);
}
.priceContainer .presentation .billingSection {
  display: none;
  margin-bottom: 24px;
}
.priceContainer .presentation .billingSection .billingTitle {
  justify-content: flex-start;
  gap: 16px;
  padding: 4px 16px;
}
.priceContainer .presentation .billingSection .billingTitle .titleName {
  font-size: var(--font-size-md);
}
.priceContainer
  .presentation
  .billingSection
  .billingTitle
  .material-icons-outlined {
  font-size: var(--font-size-md);
  padding-top: 4px;
}
.priceContainer .presentation .billingList {
  margin-bottom: 16px;
}
.priceContainer .presentation .billingList li div {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--textColor1);
}
.priceContainer .presentation .billingList li h4 {
  background-color: var(--baseColor);
  font-size: var(--font-size-sm);
  padding: 6px 8px;
  text-align: center;
  font-weight: 400;
  width: 15%;
  align-self: stretch;
  display: flex;
  align-items: center;
  justify-content: center;
}
.priceContainer .presentation .billingList li p {
  font-size: var(--font-size-sm);
  padding-left: 16px;
  font-weight: 300;
  flex: 2;
}
.priceContainer .presentation .billingList li figure {
  flex: 1;
  align-self: stretch;
}
.priceContainer .presentation .billingList li figure img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.priceContainer .presentation .subtotalDisplay div {
  margin-left: 16%;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: 1px solid var(--textColor1);
}
.priceContainer .presentation .subtotalDisplay div p {
  padding-left: 16px;
  font-size: var(--font-size-sm);
}
.priceContainer .presentation .subtotalDisplay div .subtotal {
  font-family: "Oswald", sans-serif;
  font-size: var(--font-size-md);
  font-weight: 300;
}
.priceContainer .presentation .subtotalDisplay .priceNote {
  display: flex;
  justify-content: end;
}
.priceContainer .presentation .subList {
  padding: 8px 0 0 8px;
  margin-left: 24%;
}
.priceContainer .presentation .subList li {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-bottom: 1px;
  border-bottom: 1px solid var(--textColor1);
  margin-bottom: 8px;
}
.priceContainer .presentation .subList li p {
  padding-left: 8px;
  font-size: var(--font-size-sm);
}
.priceContainer .presentation .subList li .price {
  font-family: "Oswald", sans-serif;
  font-size: var(--font-size-base);
  display: flex;
  justify-content: end;
  font-weight: 300;
}
.priceContainer .presentation .subList li:last-of-type {
  margin-bottom: 0;
}
.priceContainer .presentation .priceDisplay {
  width: 100%;
  padding: var(--font-size-lg);
}
.priceContainer .presentation .priceDisplay div {
  display: flex;
  justify-content: flex-start;
  align-items: end;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--textColor1);
  padding-bottom: 4px;
}
.priceContainer .presentation #price {
  font-family: "Oswald", sans-serif;
  font-size: var(--font-size-lg);
  margin-right: 12px;
}
.priceContainer.active {
  width: 800px;
}
.priceContainer.active .closePrice {
  display: block;
  font-size: calc(var(--font-size-lg) + 4px);
}
.priceContainer.active .priceTitle {
  justify-content: center;
  gap: 16px;
}
.priceContainer.active .priceTitle .en {
  font-family: "Oswald", sans-serif;
}
.priceContainer.active .presentation {
  padding: 24px;
}
.priceContainer.active .presentation .screenshots {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.priceContainer.active .presentation .billingSection {
  display: block;
}
.priceContainer.active .presentation .billing {
  width: 60%;
  margin-left: 4%;
}
.priceContainer.active .presentation .priceDisplay {
  padding: 0;
  margin-left: 16%;
  width: 84%;
}
.priceContainer.active .presentation .priceDisplay div {
  flex-direction: column;
  border-bottom: none;
  margin-bottom: 0;
}
.priceContainer.active .presentation .priceDisplay #price {
  margin-right: 0;
  width: 100%;
  border-bottom: 1px solid #000;
  text-align: right;
}
.priceContainer.active .presentation .priceDisplay .priceNote {
  display: flex;
  justify-content: end;
}
.priceContainer .download {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  background-color: var(--textColor1);
  border-radius: 24px 0 0 24px;
  cursor: pointer;
}
.priceContainer .download p {
  font-size: var(--font-size-sm);
  padding: 8px;
}
.priceContainer .download p.en {
  color: var(--textColor2);
  font-family: "Oswald", sans-serif;
  padding-left: 24px;
}
.priceContainer .download p.japan {
  color: var(--textColor1);
  background-color: var(--accentColor);
  display: flex;
  justify-content: space-between;
}
.priceContainer .download p.japan .material-icons-outlined.chevronRight {
  margin-left: 0px;
}

.configContainer {
  position: relative;
  margin-top: 80px;
  height: calc(100vh - 80px);
}

.priceNote {
  font-weight: 300;
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
}
.priceNote .material-icons {
  color: var(--textColor1);
  font-size: var(--font-size-sm);
  margin-right: 4px;
  padding-top: 4px;
}

.iframeContainer {
  width: 100%;
  height: 100%;
}

.iframeContainer > iframe {
  border: 0;
  width: 100%;
  height: 100%;
}

.controls {
  scrollbar-color: var(--mainColor2) var(--mainColor1);
  scrollbar-width: thin;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  padding: 15px 0 0 15px;
  background: var(--mainColor1);
  background: linear-gradient(
    168deg,
    rgba(61, 210, 233, 0.8) 25%,
    rgba(43, 198, 224, 0.8) 25%,
    rgba(43, 198, 224, 0.8) 76%,
    rgba(16, 191, 215, 0.8) 76%
  );
  height: 100%;
  width: clamp(280px, 28.125%, 360px);
  overflow-y: scroll;
}
.controls.close {
  display: none;
}

.controls > * {
  margin-right: 15px;
  margin-bottom: 15px;
}

.configButton {
  display: none;
  justify-content: center;
  align-items: center;
  position: relative;
  border: 2px solid transparent;
  border-radius: 4px;
  padding: 0 13px;
  font-family: "Open Sans", sans-serif;
  font-weight: 600;
  text-align: center;
  text-shadow: none;
  text-transform: uppercase;
  line-height: 1.2;
  cursor: pointer;
  outline: none;
  transition: background 0.2s;
  color: white;
  background-color: #1caad9;
  height: 25px;
  font-size: var(--font-size-sm);
}

.configButton.disabled {
  background-color: #cccccc;
}
.sidemenu {
  padding: 24px 8px;
}
.sidemenu section {
  border-bottom: 1px solid var(--textColor2);
  margin-bottom: 32px;
}
.sidemenu .acnumber {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--accentColor);
  color: var(--textColor1);
  font-size: var(--font-size-md);
  font-family: "Oswald", sans-serif;
  font-weight: 400;
  width: calc(var(--font-size-lg) + 4px);
  height: calc(var(--font-size-lg) + 4px);
  border-radius: 50%;
  margin-right: 8px;
  padding-left: 0;
  margin-left: 0;
}
.sidemenu li.inactive {
  display: none;
}

.summary {
  position: absolute;
  display: flex;
  align-items: center;
  bottom: 8%;
  right: 2%;
  z-index: 50;
  background-color: var(--textColor1);
  border-radius: 24px 0 0 24px;
  cursor: pointer;
}
.summary p {
  font-size: var(--font-size-md);
  padding: var(--font-size-sm);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.summary p.en {
  color: var(--textColor2);
  font-family: "Oswald", sans-serif;
  padding-left: var(--font-size-lg);
}
.summary p.japan {
  color: var(--textColor1);
  background-color: var(--accentColor);
}
.summary.close {
  display: none;
}

/*アコーディオンタイトル*/
.accordionTitle {
  position: relative; /*+マークの位置基準とするためrelative指定*/
  cursor: pointer;
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  color: var(--textColor2);
  font-size: var(--font-size-md);
}
.accordionTitle .configCategory {
  position: relative;
  display: flex;
  justify-content: space-between;
  padding-right: 12px;
}
.accordionTitle .configCategory::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  background-color: var(--textColor2);
  width: 1px;
  height: 100%;
}
.accordionTitle .acsubtitle {
  font-size: var(--font-size-sm);
  font-weight: 300;
  padding-left: var(--font-size-sm);
}
.accordionTitle .material-icons-outlined {
  position: absolute;
  top: 25%;
  right: 0;
  color: var(--textColor2);
  transition: transform 0.3s ease-in-out;
}
.accordionTitle.open .material-icons-outlined {
  transform: rotate(540deg);
}
.accordionTitle img {
  display: none;
}

/*アイコンの＋と×*/
/*アコーディオンで現れるエリア*/
.accordionBox {
  max-height: 0;
  overflow: hidden;
  color: var(--textColor1);
  margin-top: 12px;
  background-color: var(--baseColor);
  transition: max-height 0.2s ease-out;
}
.accordionBox.open {
  display: block;
  max-height: 900px;
}

.accordionItem {
  margin-bottom: 12px;
  padding: 12px;
  cursor: pointer;
}
.accordionItem:first-of-type {
  margin-top: 12px;
}
.accordionItem h4 {
  display: flex;
  align-items: center;
  background-color: var(--mainColor2);
  color: var(--textColor2);
  margin-bottom: 12px;
  margin-left: -12px;
  border-radius: 0 16px 16px 0;
  margin-right: 12px;
}
.accordionItem h4 .en {
  width: 40%;
  font-size: var(--font-size-base);
  font-family: "Oswald";
  background-color: var(--mainColor1);
  font-weight: 400;
  -webkit-clip-path: polygon(0 0, 100% 0%, 90% 100%, 0% 100%);
  clip-path: polygon(0 0, 100% 0%, 90% 100%, 0% 100%);
}
.accordionItem h4 .en.long {
  padding-right: 0;
}
.accordionItem h4 .japan {
  width: 60%;
  font-weight: 300;
}
.accordionItem h4 .japan.long {
  padding: 8px 0;
}
.accordionItem h4 span {
  display: block;
  font-size: var(--font-size-sm);
  padding: 8px;
}
.accordionItem figure {
  margin-bottom: 8px;
}
.accordionItem figure img {
  display: block;
  margin: 0 auto;
}
.accordionItem p {
  color: var(--textColor1);
  display: flex;
  justify-content: space-between;
}
.accordionItem p span {
  font-size: var(--font-size-sm);
  flex: 1;
  display: block;
  text-align: center;
}
.accordionItem .accordionList {
  color: var(--textColor1);
  font-size: var(--font-size-sm);
}
.accordionItem .accordionList li {
  padding: 6px;
  border-top: 1px solid var(--mainColor1);
}
.accordionItem .accordionList li:last-of-type {
  border-bottom: 1px solid var(--mainColor1);
}
.accordionItem.selected h4 {
  background-color: var(--textColor1);
}
.accordionItem.selected h4 .en {
  background-color: var(--accentColor);
  color: var(--textColor1);
}
.accordionItem .gradeButton {
  display: none;
}

.furnitureContainer {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.furnitureContainer figure {
  height: 100px;
  margin-bottom: 32px;
}
.furnitureContainer figure img {
  margin-bottom: 4px;
  -o-object-fit: cover;
  object-fit: cover;
  height: 100%;
  width: 100%;
}
.furnitureContainer figure.invisible img {
  filter: grayscale(80%);
}

.loadingScreen {
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--baseColor);
  width: 100%;
  height: 100%;
  opacity: 1;
  z-index: 75;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  overflow: hidden;
}
.loadingScreen.inactive {
  animation-name: changeopacity;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-in;
}
.loadingScreen.inactive svg {
  animation-name: scaleup;
  animation-duration: 1.5s;
  animation-fill-mode: forwards;
  animation-timing-function: ease-out;
}
.loadingScreen.inactive p {
  opacity: 0;
}
.loadingScreen p {
  color: var(--mainColor1);
  font-weight: 300;
  font-size: var(--font-size-sm);
}

@keyframes changeopacity {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    z-index: -1;
  }
}
@keyframes scaleup {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1);
  }
  100% {
    transform: scale(2);
  }
}
path {
  fill: none;
  stroke: var(--mainColor1);
  stroke-width: 1px;
  stroke-dasharray: 1180px;
  opacity: 0;
}

.material-icons-outlined.chevronRight {
  display: flex;
  align-items: center;
  color: var(--textColor1);
  margin-left: var(--font-size-lg);
  padding-top: 2px;
}

.lightControl {
  position: absolute;
  z-index: 50;
  left: calc(clamp(280px, 28.125%, 360px) + 15px);
  top: 5%;
  display: flex;
  align-items: center;
}
.lightControl .material-icons-outlined {
  display: block;
  color: var(--mainColor1);
  margin-right: 8px;
}
.lightControl.close {
  display: none;
}

#lightRange {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
  background: transparent;
  height: 14px;
  width: 120px;
  border-radius: 7px;
  border: solid 1px var(--mainColor3);
  outline: 0;
}
#lightRange:focus {
  box-shadow: 0 0 3px var(--mainColor3RGB);
}
#lightRange::-webkit-slider-thumb {
  -webkit-appearance: none;
  background: var(--mainColor3);
  width: 10px;
  height: 18px;
  border-radius: 4px;
}
#lightRange::-moz-range-thumb {
  background: var(--mainColor3);
  width: 10px;
  height: 18px;
  border-radius: 8px;
  border: none;
}
#lightRange::-moz-focus-outer {
  border: 0;
}
#lightRange:active::-webkit-slider-thumb {
  box-shadow: 0px 5px 10px -2px rgba(0, 0, 0, 0.2);
}

@media screen and (max-width: 1280px) {
  .configContainer {
    margin-top: 60px;
    height: calc(100vh - 60px);
  }
}

@media screen and (max-width: 834px) {
  .configContainer {
    margin-top: 60px;
    height: 100%; /* Fallback */
    height: calc(var(--vh, 1vh) * 100 - 60px);
  }
  .controls {
    top: auto;
    bottom: 0;
    left: 0;
    z-index: 10;
    padding: 0 8px;
    height: 84px;
    width: 100%;
    overflow-x: scroll;
  }
  .controls .sidemenu {
    padding: 0;
    display: flex;
    height: 100%;
  }
  .controls .sidemenu section {
    border-bottom: none;
    margin-bottom: 0;
    display: flex;
    height: 100%;
  }
  .controls > * {
    margin-right: 0;
    margin-bottom: 0;
  }
  .summary {
    bottom: 100px;
  }
  .accordionTitle {
    width: 82px;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    font-weight: 300;
    padding-bottom: 8px;
    padding-top: 8px;
  }
  .accordionTitle .acnumber {
    display: none;
  }
  .accordionTitle .acsubtitle {
    display: none;
  }
  .accordionTitle .configCategory {
    padding-right: 0;
    margin-top: 8px;
  }
  .accordionTitle .configCategory::after {
    display: none;
  }
  .accordionTitle .material-icons-outlined {
    display: none;
  }
  .accordionTitle img {
    display: block;
  }
  .accordionBox {
    margin-top: 0;
    max-width: 0;
    transition: max-width 0.2s ease-out;
    height: 100%;
  }
  .accordionBox.open {
    display: flex;
    align-items: center;
    max-width: 600px;
    padding: 0 24px;
  }
  .accordionBox ul {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .accordionItem {
    margin-bottom: 0;
    padding: 0;
    margin-left: 16px;
  }
  .accordionItem h4 {
    display: none;
  }
  .accordionItem p {
    display: none;
  }
  .accordionItem figure {
    margin-bottom: 0;
    width: 42px;
    height: 42px;
  }
  .accordionItem figure img {
    border-radius: 50%;
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
  .accordionItem:first-of-type {
    margin-top: 0;
    margin-left: 0;
  }
  .accordionItem .accordionList {
    display: none;
  }
  .accordionItem .gradeButton {
    display: flex;
    justify-content: center;
    align-items: center;
    color: var(--textColor2);
    font-size: 20px;
    font-family: "Oswald", sans-serif;
    width: 42px;
    height: 42px;
    border-radius: 50%;
  }
  .accordionItem .gradeButton.gold {
    background-color: #ecbc4b;
  }
  .accordionItem .gradeButton.silver {
    background-color: #b3b2b2;
  }
  .accordionItem .gradeButton.bronze {
    background-color: #ad7c63;
  }
  .furnitureContainer {
    display: flex;
    gap: 16px;
  }
  .furnitureContainer figure figcaption {
    display: none;
  }
  .priceContainer {
    display: flex;
    top: 10px;
  }
  .priceContainer .decoration,
  .priceContainer .decoration2 {
    height: 100%;
  }
  .priceContainer .presentation {
    position: relative;
    z-index: 10;
  }
  .priceContainer .presentation #price {
    text-align: right;
    margin-right: 0;
  }
  .priceContainer .presentation .priceDisplay {
    padding: 4px 12px;
  }
  .priceContainer .presentation .priceDisplay div {
    flex-direction: column;
    align-items: flex-end;
    margin-bottom: 4px;
  }
  .priceContainer .presentation .billingList li h4 {
    width: 20%;
    font-size: var(--font-size-md);
  }
  .priceContainer .presentation .billingList li p {
    font-size: var(--font-size-md);
  }
  .priceContainer .presentation .subtotalDisplay div .subtotal {
    font-size: var(--font-size-lg);
  }
  .priceContainer .presentation .subtotalDisplay div p {
    font-size: var(--font-size-lg);
  }
  .priceContainer .presentation .billingSection .billingTitle .titleName {
    font-size: var(--font-size-lg);
  }
  .priceContainer .presentation .billing h3 span {
    font-size: var(--font-size-base);
  }
  .priceContainer .presentation .subList li .price {
    font-size: var(--font-size-md);
  }
  .priceContainer .priceTitle {
    font-size: var(--font-size-lg);
    padding: 4px 8px;
    align-items: center;
  }
  .priceContainer .priceTitle div {
    flex-direction: column;
    justify-content: flex-end;
  }
  .priceContainer .priceTitle .titleName {
    font-size: var(--font-size-lg);
  }
  .priceContainer .priceTitle .subTitle {
    margin: 0;
    font-size: var(--font-size-md);
  }
  .priceContainer .priceNote {
    font-size: var(--font-size-base);
  }
  .priceContainer.active {
    width: 100%;
    height: 100%;
    top: 0;
    right: 0;
    flex-direction: column;
    background-color: rgba(var(--textColor2RGB), 0.8);
  }
  .priceContainer.active .decoration,
  .priceContainer.active .decoration2 {
    height: calc(var(--font-size-lg) + var(--font-size-lg) + 12px);
  }
  .priceContainer.active .presentation {
    flex-direction: column-reverse;
  }
  .priceContainer.active .presentation .screenshots {
    width: 100%;
    margin-bottom: 8px;
  }
  .priceContainer.active .presentation .screenshots figure .decoration3 {
    height: calc(var(--font-size-lg) + 24px);
    width: calc(var(--font-size-lg) + 24px);
  }
  .priceContainer.active .presentation .screenshots figure figcaption {
    font-size: calc(var(--font-size-lg) + 16px);
  }
  .priceContainer.active .presentation .billing {
    width: 100%;
    margin-left: 0;
    margin-bottom: 32px;
  }
  .priceContainer.active .priceTitle {
    padding: 8px;
  }
  .summary {
    align-items: center;
  }
  .summary p {
    padding: 4px 8px;
  }
  .summary p.japan {
    align-items: center;
  }
  .summary p.en {
    padding-left: 16px;
  }
  .material-icons-outlined.chevronRight {
    margin-left: 12px;
    padding-top: 4px;
  }
  .lightControl {
    left: 10px;
    bottom: 100px;
    top: auto;
    right: auto;
  }
  #lightRange {
    width: 100px;
  }
  .loadingScreen svg {
    width: 80%;
  }
}
