@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Noto+Sans+JP:wght@400&family=Noto+Serif+JP:wght@200..900&family=Roboto:wght@600&text=0123456789&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200");
* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
  font-optical-sizing: auto;
  font-style: normal;
  /*
  -webkit-transform: rotate(0.02deg);
  transform: rotate(0.02deg);
  */
}
*:before, *:after {
  pointer-events: none;
}

html {
  font-size: 62.5%;
}

body {
  font-size: 1.3rem;
  line-height: 1.9;
  position: relative;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  letter-spacing: -0.05em;
  font-feature-settings: "palt";
  letter-spacing: 0.12em;
  background: white;
}

.jp {
  font-family: "Noto Serif JP", serif;
}

.en {
  font-family: "EB Garamond", serif;
}

.sansserif {
  font-family: "Noto Sans JP", sans-serif;
}

ul li {
  list-style: none;
}

table {
  border-collapse: collapse;
}

picture {
  display: block;
}
picture.caption {
  position: relative;
  display: inline-block;
  z-index: 1;
}
picture.caption::before, picture.caption::after {
  color: #000;
  text-shadow: -1px 0 8px #FFF, 1px 0 8px #FFF, 0 -1px 8px #FFF, 0 1px 8px #FFF, -1px 0 8px #FFF, 1px 0 8px #FFF, 0 -1px 8px #FFF, 0 1px 8px #FFF;
  font-size: 1.2rem;
  font-weight: bold;
  position: absolute;
  bottom: 3px;
  letter-spacing: -0.015em;
}
picture.caption::before {
  content: attr(data-left);
  left: 8px;
}
picture.caption::after {
  content: attr(data-right);
  right: 8px;
}
picture.caption.blackshadow::before, picture.caption.blackshadow::after {
  color: #FFF;
  text-shadow: -1px 0 8px rgba(0, 0, 0, 0.3), 1px 0 8px rgba(0, 0, 0, 0.3), 0 -1px 8px rgba(0, 0, 0, 0.3), 0 1px 8px rgba(0, 0, 0, 0.3);
}
picture.caption.nonshadow::before, picture.caption.nonshadow::after {
  text-shadow: none !important;
}
picture.caption.nonshadowwhite::before, picture.caption.nonshadowwhite::after {
  color: #FFF;
  text-shadow: none !important;
}

img {
  vertical-align: bottom;
  max-width: 100%;
}

sup {
  font-size: 50%;
}

.pc,
.tb,
.sp {
  display: none;
}

@media screen and (min-width: 1384.3333333333px) {
  .pc {
    display: inline-block;
  }
}
@media screen and (min-width: 931px) and (max-width: 1383.3333333333px) {
  .pc {
    display: inline-block;
  }
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .tb {
    display: inline-block;
  }
}
@media screen and (max-width: 768px) {
  .sp {
    display: inline-block;
  }
}
.large {
  font-size: 2.4rem;
}
@media screen and (max-width: 768px) {
  .large {
    font-size: 1.8rem;
  }
}

.larger {
  font-size: 150%;
}

.medium {
  font-size: 1.3rem;
}

.small {
  font-size: 1.1rem;
}

.smaller {
  font-size: 76%;
}

.initBox,
.initBox2,
.initBox3 {
  margin: 0 auto;
  width: 90%;
  max-width: 1245px;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .initBox,
  .initBox2,
  .initBox3 {
    width: 95%;
  }
}
@media screen and (max-width: 768px) {
  .initBox,
  .initBox2,
  .initBox3 {
    width: 90%;
  }
}

.initBox2 {
  margin: 0 auto;
  width: 80%;
  max-width: 996px;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .initBox2 {
    width: 95%;
  }
}
@media screen and (max-width: 768px) {
  .initBox2 {
    width: 90%;
  }
}

.initBox3 {
  margin: 0 auto;
  width: 80%;
  max-width: 930px;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .initBox3 {
    width: 95%;
  }
}
@media screen and (max-width: 768px) {
  .initBox3 {
    width: 90%;
  }
}

.inlineBox {
  display: inline-block;
}

.flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.flex.itemcenter {
  align-items: center;
}
.flex.left {
  justify-content: left;
  align-items: center;
}
.flex.left > *:not(:last-child) {
  margin-right: 1em;
}
.flex.center {
  justify-content: center;
}
.flex.center > * {
  margin-right: 0.5em;
  margin-left: 0.5em;
}
.flex.c2 > * {
  width: 48%;
  margin-bottom: 1rem;
}
.flex.c2 > *:nth-last-child(1), .flex.c2 > *:nth-last-child(2) {
  margin-bottom: 0;
}
.flex.c3 > * {
  width: 30%;
}
.flex.c3 > *.wide2 {
  width: 65%;
}
.flex.c4 > * {
  width: 22%;
}
.flex.c4 > *.wide2 {
  width: 47%;
}
@media screen and (max-width: 768px) {
  .flex.c2.spone > *, .flex.c3.spone > *, .flex.c4.spone > * {
    width: 100%;
  }
  .flex.c2.spone > * + *, .flex.c3.spone > * + *, .flex.c4.spone > * + * {
    margin-top: 1em;
  }
}

.grid {
  display: grid;
}
.grid.g2 {
  grid-template-columns: repeat(2, 1fr);
}
.grid.g3 {
  grid-template-columns: repeat(3, 1fr);
}
.grid.g4 {
  grid-template-columns: repeat(4, 1fr);
}
.grid.g2 > *.wide2, .grid.g3 > *.wide2, .grid.g4 > *.wide2 {
  grid-column: span 2;
}
.grid.g2 > *.wide3, .grid.g3 > *.wide3, .grid.g4 > *.wide3 {
  grid-column: span 3;
}
.grid.g2 > *.wide4, .grid.g3 > *.wide4, .grid.g4 > *.wide4 {
  grid-column: span 4;
}
@media screen and (max-width: 768px) {
  .grid.g2.spone, .grid.g3.spone, .grid.g4.spone {
    grid-template-columns: repeat(1, 1fr);
  }
  .grid.g2.spone > *.wide2, .grid.g2.spone > *.wide3, .grid.g2.spone > *.wide4, .grid.g3.spone > *.wide2, .grid.g3.spone > *.wide3, .grid.g3.spone > *.wide4, .grid.g4.spone > *.wide2, .grid.g4.spone > *.wide3, .grid.g4.spone > *.wide4 {
    grid-column: span 1;
  }
}

.mt0 {
  margin-top: 0;
}

.mt1 {
  margin-top: 1em;
}

.mt2 {
  margin-top: 2em;
}

.mb0 {
  margin-bottom: 0;
}

.mb05 {
  margin-bottom: 0.5em;
}

.mb1 {
  margin-bottom: 1em;
}

.mb2 {
  margin-bottom: 2em;
}

.mb3 {
  margin-bottom: 3em;
}

.mb4 {
  margin-bottom: 4em;
}

.mbL {
  margin-bottom: 7rem;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .mbL {
    margin-bottom: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .mbL {
    margin-bottom: 4rem;
  }
}

.mbM {
  margin-bottom: 4rem;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .mbM {
    margin-bottom: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .mbM {
    margin-bottom: 2rem;
  }
}

.mbS {
  margin-bottom: 1rem;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  .mbS {
    margin-bottom: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .mbS {
    margin-bottom: 0.5rem;
  }
}

.bold {
  font-weight: bold;
}

.maincolor {
  color: black;
}

.subcolor1 {
  color: #595757;
}

.subcolor2 {
  color: #9b9b9b;
}

.subcolor3 {
  color: #0f3056;
}

.left {
  text-align: left;
}

.center {
  text-align: center;
}

.right {
  text-align: right;
}

.w25 {
  width: 25%;
}
@media screen and (max-width: 768px) {
  .w25 {
    width: 50%;
  }
}

.cautionUl li {
  text-align: left;
  list-style: none;
  margin-left: 1em;
  text-indent: -1em;
  line-height: 1.5;
}

a {
  transition: 0.5s;
}
a.tel {
  text-decoration: none;
  pointer-events: none;
  color: black;
}
@media screen and (max-width: 768px) {
  a.tel {
    text-decoration: underline;
    color: #595757;
    pointer-events: all;
  }
}
a.lineboxbtn {
  text-decoration: none;
  display: inline-block;
  border: 1px solid black;
  padding: 0.5em 2em;
  color: black;
  text-align: center;
}
a.lineboxbtn:hover {
  background: rgba(0, 0, 0, 0.75);
  color: white;
}

.linebtn a {
  text-decoration: none;
  display: inline-block;
  position: relative;
}
.linebtn a::before {
  content: "";
  width: 0;
  border-bottom: 1px solid black;
  position: absolute;
  bottom: 0;
  left: 0;
  transition: 0.5s;
}
.linebtn a:hover::before {
  width: 100%;
}

.ggmap {
  height: 0;
  overflow: hidden;
  padding-bottom: 56.25%;
  position: relative;
}
@media screen and (max-width: 768px) {
  .ggmap {
    padding-bottom: 75%;
  }
}
.ggmap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .spscroll {
    position: relative;
    width: 100%;
    overflow-x: scroll;
  }
  .spscroll img {
    max-width: none;
  }
  .spscroll::before, .spscroll::after {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .spscroll::before {
    content: "";
    width: 7rem;
    height: 7rem;
    background: rgba(0, 0, 0, 0.75);
  }
  .spscroll::after {
    font-family: "Material Symbols Outlined";
    content: "\e9ec";
    vertical-align: middle;
    font-weight: 200;
    font-size: 5rem;
    color: white;
    animation: spscrollicon_after ease-in 1s infinite;
  }
  .spscroll.isactive::before, .spscroll.isactive::after {
    animation: spscrollicon 1s forwards;
  }
}
@keyframes spscrollicon_after {
  0% {
    transform: translate(-50%, -50%) rotate(-20deg);
  }
  50% {
    transform: translate(-50%, -50%) rotate(20deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(-20deg);
  }
}
@keyframes spscrollicon {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
.modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  z-index: 10;
}
.modal-overlay .modal-content {
  position: relative;
  background: white;
  border-radius: 12px;
  padding: 2rem;
  max-width: 800px;
  width: 90%;
  box-shadow: 0 2rem 4rem rgba(0, 0, 0, 0.2);
  transform: translateY(-3rem);
  opacity: 0;
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.modal-overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.modal-overlay.active .modal-content {
  transform: translateY(0);
  opacity: 1;
}
.modal-overlay .modal-close {
  position: absolute;
  top: 1rem;
  right: 1.5rem;
  font-size: 1.5rem;
  color: rgba(0, 0, 0, 0.3);
  cursor: pointer;
  transition: color 0.5s;
}
.modal-overlay .modal-close:hover {
  color: rgba(0, 0, 0, 0.8);
}

#headerBox h1 {
  background: white;
  font-weight: 500;
  font-size: 1.4rem;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
  padding: 0.5em 0 0.1em;
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  z-index: 10;
}
#headerBox h1 a {
  color: black;
  text-decoration: none;
}
#headerBox #spmenuchecklabel {
  cursor: pointer;
  position: fixed;
  top: calc(2.66rem + 5vw);
  right: 5vw;
  display: inline-block;
  z-index: 10;
  line-height: 1;
  mix-blend-mode: exclusion;
}
#headerBox #spmenuchecklabel::before, #headerBox #spmenuchecklabel::after {
  content: "";
  width: 100%;
  height: 3px;
  background: white;
  position: absolute;
  top: 1em;
  left: 0;
  transition: 0.5s;
}
#headerBox #spmenuchecklabel::before {
  transform: translateY(calc(3px - 1em));
}
#headerBox #spmenuchecklabel::after {
  transform: translateY(1px);
}
#headerBox #spmenuchecklabel span {
  color: white;
  display: block;
  margin-top: 2em;
  letter-spacing: 0;
  border-top: 3px solid white;
  padding-top: 0.5em;
  font-size: 1.2rem;
  transition: 0.5s;
}
#headerBox nav {
  opacity: 0;
  position: fixed;
  z-index: -9;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.8);
  transition: 0.8s;
}
#headerBox nav .globalnav {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0 3rem;
  padding: 20vh 5%;
  grid-auto-rows: calc((60vh - 6rem) / 3);
}
#headerBox nav .globalnav li a {
  text-decoration: none;
  text-align: left;
  display: block;
  line-height: 1;
  color: white;
}
#headerBox nav .globalnav li a::before {
  content: attr(data-english) "";
  font-family: "EB Garamond", serif;
  font-size: 1.8rem;
  display: block;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  margin-bottom: 1rem;
}
#headerBox nav .globalnav li a.nowpage {
  font-weight: bold;
}
#headerBox nav .globalnav li a.closebtn {
  pointer-events: none !important;
  cursor: default;
  opacity: 0.3;
}
@media screen and (max-width: 768px) {
  #headerBox nav .globalnav {
    padding: 15vh 5%;
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: calc((70vh - 0.5rem) / 7);
    gap: 0 1rem;
  }
  #headerBox nav .globalnav li a::before {
    font-size: 1rem;
    padding-bottom: 0;
    margin-bottom: 0.5rem;
  }
  #headerBox nav .globalnav li a:hover {
    color: #9b9b9b;
  }
  #headerBox nav .globalnav li.tel {
    grid-column: span 2;
  }
}
#headerBox #spmenucheck {
  display: none;
}
#headerBox #spmenucheck:checked ~ #spmenuchecklabel::before {
  transform: rotate(45deg);
}
#headerBox #spmenucheck:checked ~ #spmenuchecklabel::after {
  transform: rotate(-45deg);
}
#headerBox #spmenucheck:checked ~ #spmenuchecklabel span {
  border-top-color: transparent;
}
#headerBox #spmenucheck:checked ~ nav {
  opacity: 1;
  z-index: 9;
  background: rgba(0, 0, 0, 0.8);
}
#headerBox #spmenucheck:checked ~ nav .globalnav li a {
  pointer-events: all;
}

#footerBox {
  margin-top: 3.125vw;
  background: black;
  padding: 4.1666666667vw 0 12rem;
  text-align: left;
  color: #9b9b9b;
}
@media screen and (max-width: 768px) {
  #footerBox {
    padding-bottom: 15rem;
  }
}
#footerBox:has(.footerggbox) {
  padding-top: 0;
}
#footerBox .ggmapTitle {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  background: white;
  padding: 0 0 0.5em 2em;
  line-height: 1;
  font-weight: 400;
}
#footerBox .ggmapTitle .en {
  font-size: 3rem;
}
#footerBox .ggmapTitle .ja::before {
  content: "[";
  display: inline-block;
  margin: 0 0.5em 0 1em;
}
#footerBox .ggmapTitle .ja::after {
  content: "]";
  display: inline-block;
  margin-left: 0.5em;
}
#footerBox .footerggbox {
  margin-bottom: 4.1666666667vw;
}
#footerBox .footerggbox iframe {
  width: 100%;
  -moz-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  filter: grayscale(100%);
}
#footerBox #pagetop {
  position: fixed;
  bottom: 2em;
  right: 2em;
  z-index: 10;
}
#footerBox a {
  color: #9b9b9b;
  text-decoration: none;
}
#footerBox .linebtn li a::before {
  border-bottom-color: #9b9b9b;
}
#footerBox .linebtn li a.closebtn {
  pointer-events: none !important;
  cursor: default;
  opacity: 0.3;
}
#footerBox .linebtn li:has(.closebtn)::before {
  opacity: 0.3;
}
#footerBox .flex .lefttext h2 {
  margin-bottom: 1em;
}
#footerBox .flex .lefttext h2 img {
  width: 150px;
}
@media screen and (max-width: 768px) {
  #footerBox .flex .lefttext {
    order: 1;
    width: 100%;
    padding-bottom: 1rem;
    border-bottom: 1px solid #9b9b9b;
    margin-bottom: 1rem;
  }
}
#footerBox .flex .righttext ul li {
  margin-bottom: 0.5em;
}
#footerBox .flex .righttext ul li::before {
  font-family: "Material Symbols Outlined";
  content: "\e037";
  vertical-align: middle;
  font-weight: 200;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}
#footerBox .flex .righttext ul li span {
  margin-right: 1em;
}
@media screen and (max-width: 768px) {
  #footerBox .flex .righttext {
    order: 2;
    width: 100%;
  }
}
#footerBox small {
  margin-top: 5.2083333333vw;
  display: block;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #footerBox small {
    font-size: 1rem;
    letter-spacing: 0;
  }
}

.scrollin.blur {
  opacity: 0;
  filter: blur(1.5rem);
  transform: translateY(1em);
}
.scrollin.blur.isactive {
  animation: blur 2s ease 0s 1 normal forwards;
}
.scrollin.lineup {
  display: inline-block;
  height: 1em;
  line-height: 1em;
  overflow: hidden;
  position: relative;
}
.scrollin.lineup::after {
  content: "";
  display: block;
  width: 0;
  border-bottom: 1px solid white;
  position: absolute;
  bottom: 0;
  left: 0;
}
.scrollin.lineup span {
  display: inline-block;
  transform: translateY(1em);
}
.scrollin.lineup.isactive::after {
  animation: widthleft 1s linear 0s 1 normal forwards;
}
.scrollin.lineup.isactive span {
  animation: lineup 3s ease 0s 1 normal forwards;
}
.scrollin.zoomin {
  transform: scale(0.8);
  opacity: 0;
}
.scrollin.zoomin.isactive {
  animation: zoomin 0.5s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}
.scrollin.slidein {
  transform: translateX(1rem);
  opacity: 0;
}
.scrollin.slidein.isactive {
  animation: slidein 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
}

@keyframes blur {
  from {
    opacity: 0;
    filter: blur(1.5rem);
    transform: translateY(1em);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0);
  }
}
@keyframes widthleft {
  0% {
    width: 0;
    opacity: 0.5;
  }
  50% {
    width: 100%;
    transform: translateX(0);
    opacity: 1;
  }
  100% {
    width: 100%;
    transform: translateX(100%);
    opacity: 0.5;
  }
}
@keyframes lineup {
  from {
    transform: translateY(1em);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes zoomin {
  0% {
    transform: scale(0.8);
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes slidein {
  0% {
    transform: translateX(1rem);
    opacity: 0;
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
#mainContentsBox.pageContent {
  color: #595757;
  text-align: left;
}
#mainContentsBox.pageContent h3.jp {
  font-size: clamp(2.4rem, 4vw, 4rem);
  font-weight: normal;
}
#mainContentsBox.pageContent h3.en {
  font-size: clamp(3rem, 5vw, 5rem);
  font-weight: normal;
  color: #9b9b9b;
}
#mainContentsBox.pageContent h4 {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
}
#mainContentsBox.pageContent section + section {
  margin-top: 7rem;
}
#mainContentsBox.pageContent section#pagetitle + section, #mainContentsBox.pageContent section#breadcrumb + section {
  margin-top: 0;
}
#mainContentsBox .btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
  padding: 0.5em 0;
  text-align: center;
  position: relative;
  z-index: 1;
  text-decoration: none;
  color: black;
  line-height: 1.5;
}
#mainContentsBox .btn a::before, #mainContentsBox .btn a::after {
  content: "";
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transition: 0.5s;
}
#mainContentsBox .btn a::after {
  width: 0;
}
#mainContentsBox .btn a:hover {
  box-shadow: none;
  color: white;
}
#mainContentsBox .btn a:hover::after {
  width: 100%;
}
#mainContentsBox .btn.request a, #mainContentsBox .btn.conversion a {
  font-size: 2rem;
}
#mainContentsBox .btn.request a span.en, #mainContentsBox .btn.conversion a span.en {
  padding-right: 0.5rem;
}
@media screen and (max-width: 768px) {
  #mainContentsBox .btn.request a span.en, #mainContentsBox .btn.conversion a span.en {
    padding-right: 0;
  }
}
#mainContentsBox .btn.request a::before, #mainContentsBox .btn.conversion a::before {
  background: linear-gradient(45deg, #9d897d, #dcc99e 50%, #9d897d 100%);
}
#mainContentsBox .btn.request a::after, #mainContentsBox .btn.conversion a::after {
  background: black;
}
#mainContentsBox .btn.request + p, #mainContentsBox .btn.conversion + p {
  text-align: center;
  margin-top: 2.5rem;
}
@media screen and (max-width: 768px) {
  #mainContentsBox .btn.request + p, #mainContentsBox .btn.conversion + p {
    text-align: left;
  }
}
#mainContentsBox .btn.request.membership span, #mainContentsBox .btn.conversion.membership span {
  line-height: 1.3;
  margin: 0.5em 0;
  display: inline-block;
}
#mainContentsBox .btn.request a::before {
  background: linear-gradient(45deg, #9a9a9a, #b8b8b8 50%, #9a9a9a 100%);
}
#mainContentsBox .btn.special a {
  font-size: 2rem;
}
#mainContentsBox .btn.special a::before {
  background: linear-gradient(45deg, #841b20, #ce3b29 50%, #841b20 100%);
}
#mainContentsBox .btn.special a::after {
  background: black;
}
#mainContentsBox .btn.link a {
  border: 1px solid rgba(0, 0, 0, 0.1);
}
#mainContentsBox .btn.link a:hover {
  color: black;
  letter-spacing: 0.25em;
}
#mainContentsBox .btn.nonbtn a {
  pointer-events: none;
}
#mainContentsBox .btn.nonbtn a span {
  background: #f0f0f0;
  padding: 0 1em;
  margin-left: 0.5em;
}
#mainContentsBox .viewmorebtn a {
  border: 1px solid black;
  padding: 0.5em 3em;
  color: black;
  text-decoration: none;
}
#mainContentsBox .viewmorebtn a:hover {
  color: white;
  background: black;
}
#mainContentsBox .togglebox {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s ease, opacity 0.5s ease;
  opacity: 0;
}
#mainContentsBox .togglebox.show {
  opacity: 1;
}
#mainContentsBox .kerning {
  letter-spacing: -0.1em;
}
#mainContentsBox .fixconversion {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
}
#mainContentsBox .fixconversion > .btn > a {
  padding-top: 0.3rem;
}
#mainContentsBox .fixconversion .btn {
  width: min(36.4583333333%, 600px);
  margin: 0 1em 2.5rem;
  z-index: 11;
}
#mainContentsBox .fixconversion .btn.special a {
  color: white;
}
#mainContentsBox .fixconversion .caption {
  display: none;
}
#mainContentsBox .fixconversion:has(.modal-overlay.active) {
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  bottom: auto;
  transform: translateX(0);
}
#mainContentsBox .fixconversion:has(.modal-overlay.active) > .btn {
  display: none;
}
#mainContentsBox .fixconversion:has(.modal-overlay.active) .btn {
  width: min(62.5%, 820px);
}
@media screen and (max-width: 768px) {
  #mainContentsBox .fixconversion:has(.modal-overlay.active) .btn {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  #mainContentsBox .fixconversion {
    flex-wrap: wrap;
  }
  #mainContentsBox .fixconversion > .btn {
    width: 100%;
    margin: 0 0 1rem;
  }
  #mainContentsBox .fixconversion > .btn a {
    font-size: 1.4rem;
  }
}
#mainContentsBox #pagetitle {
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
}
#mainContentsBox #pagetitle h2 {
  mix-blend-mode: exclusion;
  padding: 7rem 0 2rem;
}
#mainContentsBox #pagetitle h2 img {
  min-height: min(7.8125vw, 150px);
}
@media screen and (max-width: 768px) {
  #mainContentsBox #pagetitle h2 {
    padding: 5rem 0 1rem;
  }
  #mainContentsBox #pagetitle h2 img {
    min-height: min(13.0208333333vw, 150px);
  }
}
#mainContentsBox #mv + #breadcrumb {
  margin-top: 0 !important;
}
#mainContentsBox #breadcrumb {
  text-align: left;
}
#mainContentsBox #breadcrumb ul {
  padding: 2rem 0 3rem;
  display: flex;
  flex-wrap: nowrap;
  justify-content: left;
}
#mainContentsBox #breadcrumb ul li {
  color: rgba(0, 0, 0, 0.5);
  font-size: 1.2rem;
}
#mainContentsBox #breadcrumb ul li a {
  text-decoration: none;
  color: rgba(0, 0, 0, 0.5);
}
#mainContentsBox #breadcrumb ul li a:after {
  font-family: "Material Symbols Outlined";
  content: "\e5cc";
  vertical-align: middle;
  font-weight: 200;
  margin: 0 0.25em;
}
#mainContentsBox #breadcrumb ul li a:hover {
  color: #595757;
}
@media screen and (max-width: 768px) {
  #mainContentsBox #breadcrumb ul {
    padding: 1rem 0 2rem;
  }
}
#mainContentsBox #footercomment {
  font-family: "Noto Sans JP", sans-serif;
  background: #808080;
  color: white;
  padding: 4rem 0;
  font-size: 1.5rem;
}
@media screen and (max-width: 768px) {
  #mainContentsBox #footercomment {
    font-size: 1.3rem;
  }
}
#mainContentsBox #footercontact {
  text-align: center;
  margin: 7.8125vw 0;
}
#mainContentsBox #footercontact h5 {
  font-size: 2.6rem;
}
#mainContentsBox #footercontact .telbox {
  font-size: 8rem;
  line-height: 1;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  #mainContentsBox #footercontact .telbox {
    font-size: 12vw;
  }
  #mainContentsBox #footercontact .telbox + p {
    font-size: 1rem;
  }
}
#mainContentsBox #footercontact .telbox .tel {
  color: #595757;
}
#mainContentsBox #advancenoticeads {
  display: flex;
  justify-content: center;
  flex-wrap: nowrap;
  line-height: 1;
  color: #595757;
  max-width: 90%;
  margin: 0 auto 3rem;
}
#mainContentsBox #advancenoticeads dt {
  width: 8em;
  border: 1px solid #595757;
  padding: 0.25em 0;
  white-space: nowrap;
  display: flex;
  justify-content: center;
  align-items: center;
}
#mainContentsBox #advancenoticeads dd {
  padding: calc(0.25em + 1px) 0 0 1em;
  text-align: left;
}
@media screen and (max-width: 768px) {
  #mainContentsBox #advancenoticeads dt {
    width: 6em;
  }
  #mainContentsBox #advancenoticeads dd {
    padding-top: 0;
    flex: 1;
  }
}
#mainContentsBox .planningnav ul li a {
  font-size: 1.8rem;
  font-family: "EB Garamond", serif;
  display: block;
  text-decoration: none;
  text-align: center;
  padding: 1em 0;
  border: 1px solid #595757;
  color: black;
  line-height: 1.5;
}
#mainContentsBox .planningnav ul li a:hover {
  background: #f0f0f0;
}
#mainContentsBox .planningnav ul li a::before {
  font-size: 1.2rem;
  content: "EXECUTIVE FLOOR";
  display: block;
}
#mainContentsBox .planningnav ul li a span.jp {
  font-family: "Noto Serif JP", serif;
  font-size: 1.4rem;
}
#mainContentsBox .planningnav ul li.premium a::before {
  content: "PREMIUM FLOOR";
}
#mainContentsBox .planningnav ul li.nowpage a {
  background: #595757;
  color: white;
  pointer-events: none;
}
#mainContentsBox .rightImage {
  width: 38%;
  margin-left: 1em;
  float: right;
}
#mainContentsBox .rightImage.wideS {
  width: 25%;
}
@media screen and (max-width: 768px) {
  #mainContentsBox .rightImage {
    width: 100%;
    margin-left: 0;
    float: none;
  }
}

#home section {
  display: block;
  overflow: hidden;
  position: relative;
}
#home section h1,
#home section h2,
#home section h3,
#home section h4,
#home section h5 {
  font-weight: 400;
}
#home section h1.bordertitle,
#home section h2.bordertitle,
#home section h3.bordertitle,
#home section h4.bordertitle,
#home section h5.bordertitle {
  border-bottom: 1px solid black;
  margin-bottom: 0.25em;
}
#home section .mainvisual {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100vh;
}
#home section .mainvisual img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
  max-width: none;
}
#home section .mainvisual video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 50%;
     object-position: 50% 50%;
  max-width: none;
}
#home #mainimage {
  color: white;
}
#home #mainimage > .init {
  width: 100%;
}
#home #mainimage > .init .firstview {
  padding-top: 15vh;
  min-height: 100vh;
}
#home #mainimage > .init .firstview .logo {
  mix-blend-mode: exclusion;
}
#home #mainimage > .init .firstview .logo svg,
#home #mainimage > .init .firstview .logo img {
  width: clamp(150px, 14.5833333333%, 280px);
  margin-bottom: 4rem;
}
#home #mainimage > .init .firstview h1 {
  font-size: 3.2rem;
  line-height: 0.8;
  margin-bottom: 2rem;
}
#home #mainimage > .init .firstview h1 .ja {
  font-size: 1.6rem;
}
#home #mainimage > .init .firstview h1.pc.tb {
  display: block;
}
#home #mainimage > .init .firstview h1.sp {
  display: none;
}
@media screen and (max-width: 768px) {
  #home #mainimage > .init .firstview h1.pc.tb {
    display: none;
  }
  #home #mainimage > .init .firstview h1.sp {
    display: block;
  }
}
#home #mainimage > .init .firstview h2 {
  font-size: 3.8rem;
  line-height: 1.25;
}
#home #mainimage > .init .firstview h2 span.small {
  font-size: 50%;
}
@media screen and (max-width: 768px) {
  #home #mainimage > .init .firstview h2 {
    font-size: 2.4rem;
  }
}
#home #mainimage > .init .firstview .centercautionbox {
  display: inline-block;
  margin: 0 auto;
  max-width: 580px;
}
@media screen and (max-width: 768px) {
  #home #mainimage > .init .firstview .centercautionbox {
    width: 90%;
  }
}
#home #mainimage > .init .firstview .centercautionbox a {
  color: white;
  text-decoration: underline;
}
#home #mainimage > .init .firstview .centercautionbox a:hover {
  color: #dcc99e;
}
#home #mainimage > .init .firstview .strongpoint {
  margin: 7rem 0 50vh;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 150vh; /**/
}
#home #mainimage > .init .firstview .strongpoint .initBox2 {
  padding-bottom: 50vh;
}
#home #mainimage > .init .firstview .strongpoint .initBox2 h3 img {
  width: min(52.0833333333%, 1124px);
}
@media screen and (max-width: 768px) {
  #home #mainimage > .init .firstview .strongpoint .initBox2 h3 img {
    width: 100%;
    max-width: 300px;
  }
}
#home #mainimage > .init .firstview .strongpoint .initBox2 h3 + p {
  font-size: 1.6rem;
  padding: 3rem;
}
#home #mainimage > .init .firstview .strongpoint .initBox2 .grid.g4 li:not(:last-child) {
  border-right: 1px solid white;
}
@media screen and (max-width: 768px) {
  #home #mainimage > .init .firstview .strongpoint .initBox2 .grid.g4 li:not(:last-child) {
    border-right: none;
    padding-bottom: 1rem;
    border-bottom: 1px solid white;
    margin-bottom: 1rem;
  }
}
#home #concept .target {
  padding-bottom: 50vh;
}
#home #concept .flex {
  justify-content: center;
  align-items: center;
  color: white;
  height: 100vh;
  /*
  h2 {
  	font-size: clamp(5.5rem, 13vw, 8rem);
  	line-height: 1;
  }
  */
}
#home #concept .flex h3 {
  font-size: clamp(2rem, 5vw, 3.6rem);
  font-weight: 500;
  margin: 0.75em 0;
}
#home #concept .flex h3::before {
  content: "CLUB THE.HOUSE";
  font-family: "EB Garamond", serif;
  font-weight: 400;
  display: block;
  text-align: center;
  font-size: 2rem;
  letter-spacing: 0.2em;
}
@media screen and (max-width: 768px) {
  #home #concept .flex h3 {
    font-weight: bold;
    letter-spacing: 0;
  }
}
#home #concept .flex p {
  line-height: 2.4;
}
#home #access,
#home #philosophy,
#home #onsiteparking,
#home #roomplan,
#home #premiumfoor {
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
}
#home #access > .init,
#home #philosophy > .init,
#home #onsiteparking > .init,
#home #roomplan > .init,
#home #premiumfoor > .init {
  background: white;
}
#home #access > .init .cornerunit,
#home #philosophy > .init .cornerunit,
#home #onsiteparking > .init .cornerunit,
#home #roomplan > .init .cornerunit,
#home #premiumfoor > .init .cornerunit {
  flex-wrap: nowrap;
  position: relative;
}
#home #access > .init .cornerunit::after,
#home #philosophy > .init .cornerunit::after,
#home #onsiteparking > .init .cornerunit::after,
#home #roomplan > .init .cornerunit::after,
#home #premiumfoor > .init .cornerunit::after {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  position: absolute;
  top: 0;
  left: 0;
  transition: 0.5s;
}
#home #access > .init .cornerunit nav,
#home #philosophy > .init .cornerunit nav,
#home #onsiteparking > .init .cornerunit nav,
#home #roomplan > .init .cornerunit nav,
#home #premiumfoor > .init .cornerunit nav {
  width: 17.7083333333%;
  text-align: left;
  position: relative;
}
#home #access > .init .cornerunit nav > *,
#home #philosophy > .init .cornerunit nav > *,
#home #onsiteparking > .init .cornerunit nav > *,
#home #roomplan > .init .cornerunit nav > *,
#home #premiumfoor > .init .cornerunit nav > * {
  position: relative;
  z-index: 1;
}
#home #access > .init .cornerunit nav dl,
#home #philosophy > .init .cornerunit nav dl,
#home #onsiteparking > .init .cornerunit nav dl,
#home #roomplan > .init .cornerunit nav dl,
#home #premiumfoor > .init .cornerunit nav dl {
  position: absolute;
  top: 4rem;
  writing-mode: vertical-rl;
  display: inline-block;
  color: #9b9b9b;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit nav dl,
  #home #philosophy > .init .cornerunit nav dl,
  #home #onsiteparking > .init .cornerunit nav dl,
  #home #roomplan > .init .cornerunit nav dl,
  #home #premiumfoor > .init .cornerunit nav dl {
    display: none;
  }
}
#home #access > .init .cornerunit nav dl dt,
#home #philosophy > .init .cornerunit nav dl dt,
#home #onsiteparking > .init .cornerunit nav dl dt,
#home #roomplan > .init .cornerunit nav dl dt,
#home #premiumfoor > .init .cornerunit nav dl dt {
  white-space: nowrap;
  font-size: 1.8rem;
}
#home #access > .init .cornerunit nav dl dd,
#home #philosophy > .init .cornerunit nav dl dd,
#home #onsiteparking > .init .cornerunit nav dl dd,
#home #roomplan > .init .cornerunit nav dl dd,
#home #premiumfoor > .init .cornerunit nav dl dd {
  white-space: nowrap;
  font-size: 1.1rem;
}
#home #access > .init .cornerunit nav ul,
#home #philosophy > .init .cornerunit nav ul,
#home #onsiteparking > .init .cornerunit nav ul,
#home #roomplan > .init .cornerunit nav ul,
#home #premiumfoor > .init .cornerunit nav ul {
  position: absolute;
  bottom: 20vh;
}
#home #access > .init .cornerunit nav ul li a,
#home #philosophy > .init .cornerunit nav ul li a,
#home #onsiteparking > .init .cornerunit nav ul li a,
#home #roomplan > .init .cornerunit nav ul li a,
#home #premiumfoor > .init .cornerunit nav ul li a {
  display: flex;
  flex-wrap: nowrap;
  justify-content: right;
  align-items: center;
  color: black;
  /*
  text-decoration: none;
  display: inline-block;
  position: relative;
  &::before {
  	content: '';
  	width: 0;
  	border-bottom: 1px solid black;
  	position: absolute;
  	bottom: 0;
  	left: 0;
  	transition: .5s;
  }
  &:hover {
  	&::before {
  		width: 100%;
  	}
  }
  */
}
#home #access > .init .cornerunit nav ul li a::after,
#home #philosophy > .init .cornerunit nav ul li a::after,
#home #onsiteparking > .init .cornerunit nav ul li a::after,
#home #roomplan > .init .cornerunit nav ul li a::after,
#home #premiumfoor > .init .cornerunit nav ul li a::after {
  font-family: "Material Symbols Outlined";
  content: "\e037";
  vertical-align: middle;
  font-weight: 200;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
}
#home #access > .init .cornerunit .main,
#home #philosophy > .init .cornerunit .main,
#home #onsiteparking > .init .cornerunit .main,
#home #roomplan > .init .cornerunit .main,
#home #premiumfoor > .init .cornerunit .main {
  flex: 1;
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover;
  padding: clamp(5rem, 6vw, 15rem);
  text-align: left;
  color: white;
  min-height: 90vh;
}
#home #access > .init .cornerunit .main > *,
#home #philosophy > .init .cornerunit .main > *,
#home #onsiteparking > .init .cornerunit .main > *,
#home #roomplan > .init .cornerunit .main > *,
#home #premiumfoor > .init .cornerunit .main > * {
  position: relative;
  z-index: 1;
}
#home #access > .init .cornerunit .main h2,
#home #philosophy > .init .cornerunit .main h2,
#home #onsiteparking > .init .cornerunit .main h2,
#home #roomplan > .init .cornerunit .main h2,
#home #premiumfoor > .init .cornerunit .main h2 {
  font-size: 2.2rem;
}
#home #access > .init .cornerunit .main h3,
#home #philosophy > .init .cornerunit .main h3,
#home #onsiteparking > .init .cornerunit .main h3,
#home #roomplan > .init .cornerunit .main h3,
#home #premiumfoor > .init .cornerunit .main h3 {
  font-size: 2.4rem;
  margin: 0.5em 0 1em;
}
#home #access > .init .cornerunit .main .btn.conversion a, #home #access > .init .cornerunit .main .btn.special a,
#home #philosophy > .init .cornerunit .main .btn.conversion a,
#home #philosophy > .init .cornerunit .main .btn.special a,
#home #onsiteparking > .init .cornerunit .main .btn.conversion a,
#home #onsiteparking > .init .cornerunit .main .btn.special a,
#home #roomplan > .init .cornerunit .main .btn.conversion a,
#home #roomplan > .init .cornerunit .main .btn.special a,
#home #premiumfoor > .init .cornerunit .main .btn.conversion a,
#home #premiumfoor > .init .cornerunit .main .btn.special a {
  font-size: 1.4rem;
  text-align: left;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit .main,
  #home #philosophy > .init .cornerunit .main,
  #home #onsiteparking > .init .cornerunit .main,
  #home #roomplan > .init .cornerunit .main,
  #home #premiumfoor > .init .cornerunit .main {
    padding-right: 3rem;
    padding-left: 3rem;
  }
  #home #access > .init .cornerunit .main h3,
  #home #philosophy > .init .cornerunit .main h3,
  #home #onsiteparking > .init .cornerunit .main h3,
  #home #roomplan > .init .cornerunit .main h3,
  #home #premiumfoor > .init .cornerunit .main h3 {
    font-size: 2rem;
  }
}
#home #access > .init .cornerunit .viewmorebtn,
#home #philosophy > .init .cornerunit .viewmorebtn,
#home #onsiteparking > .init .cornerunit .viewmorebtn,
#home #roomplan > .init .cornerunit .viewmorebtn,
#home #premiumfoor > .init .cornerunit .viewmorebtn {
  position: absolute;
  bottom: 10vh;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
}
#home #access > .init .cornerunit .viewmorebtn a,
#home #philosophy > .init .cornerunit .viewmorebtn a,
#home #onsiteparking > .init .cornerunit .viewmorebtn a,
#home #roomplan > .init .cornerunit .viewmorebtn a,
#home #premiumfoor > .init .cornerunit .viewmorebtn a {
  border-color: white;
  color: white;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit .viewmorebtn a,
  #home #philosophy > .init .cornerunit .viewmorebtn a,
  #home #onsiteparking > .init .cornerunit .viewmorebtn a,
  #home #roomplan > .init .cornerunit .viewmorebtn a,
  #home #premiumfoor > .init .cornerunit .viewmorebtn a {
    display: block;
    white-space: nowrap;
  }
}
#home #access > .init .cornerunit .viewmorebtn.accordion a::after,
#home #philosophy > .init .cornerunit .viewmorebtn.accordion a::after,
#home #onsiteparking > .init .cornerunit .viewmorebtn.accordion a::after,
#home #roomplan > .init .cornerunit .viewmorebtn.accordion a::after,
#home #premiumfoor > .init .cornerunit .viewmorebtn.accordion a::after {
  content: "";
  animation: linedown 2s infinite;
  position: absolute;
  bottom: -10vh;
  left: 50%;
  width: 0;
  height: 9vh;
  border-right: 1px solid white;
}
#home #access > .init .cornerunit.leftnav::after,
#home #philosophy > .init .cornerunit.leftnav::after,
#home #onsiteparking > .init .cornerunit.leftnav::after,
#home #roomplan > .init .cornerunit.leftnav::after,
#home #premiumfoor > .init .cornerunit.leftnav::after {
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%);
}
#home #access > .init .cornerunit.leftnav nav,
#home #philosophy > .init .cornerunit.leftnav nav,
#home #onsiteparking > .init .cornerunit.leftnav nav,
#home #roomplan > .init .cornerunit.leftnav nav,
#home #premiumfoor > .init .cornerunit.leftnav nav {
  border-left: 1px solid white;
}
#home #access > .init .cornerunit.leftnav nav dl,
#home #philosophy > .init .cornerunit.leftnav nav dl,
#home #onsiteparking > .init .cornerunit.leftnav nav dl,
#home #roomplan > .init .cornerunit.leftnav nav dl,
#home #premiumfoor > .init .cornerunit.leftnav nav dl {
  left: 4rem;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit.leftnav nav dl,
  #home #philosophy > .init .cornerunit.leftnav nav dl,
  #home #onsiteparking > .init .cornerunit.leftnav nav dl,
  #home #roomplan > .init .cornerunit.leftnav nav dl,
  #home #premiumfoor > .init .cornerunit.leftnav nav dl {
    left: 0;
  }
}
#home #access > .init .cornerunit.leftnav nav ul,
#home #philosophy > .init .cornerunit.leftnav nav ul,
#home #onsiteparking > .init .cornerunit.leftnav nav ul,
#home #roomplan > .init .cornerunit.leftnav nav ul,
#home #premiumfoor > .init .cornerunit.leftnav nav ul {
  right: 4rem;
}
#home #access > .init .cornerunit.leftnav nav ul li,
#home #philosophy > .init .cornerunit.leftnav nav ul li,
#home #onsiteparking > .init .cornerunit.leftnav nav ul li,
#home #roomplan > .init .cornerunit.leftnav nav ul li,
#home #premiumfoor > .init .cornerunit.leftnav nav ul li {
  text-align: right;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit.leftnav nav ul,
  #home #philosophy > .init .cornerunit.leftnav nav ul,
  #home #onsiteparking > .init .cornerunit.leftnav nav ul,
  #home #roomplan > .init .cornerunit.leftnav nav ul,
  #home #premiumfoor > .init .cornerunit.leftnav nav ul {
    display: none;
  }
}
#home #access > .init .cornerunit.leftnav:hover::after,
#home #philosophy > .init .cornerunit.leftnav:hover::after,
#home #onsiteparking > .init .cornerunit.leftnav:hover::after,
#home #roomplan > .init .cornerunit.leftnav:hover::after,
#home #premiumfoor > .init .cornerunit.leftnav:hover::after {
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
#home #access > .init .cornerunit.leftnav:hover nav ul li a,
#home #philosophy > .init .cornerunit.leftnav:hover nav ul li a,
#home #onsiteparking > .init .cornerunit.leftnav:hover nav ul li a,
#home #roomplan > .init .cornerunit.leftnav:hover nav ul li a,
#home #premiumfoor > .init .cornerunit.leftnav:hover nav ul li a {
  color: white;
}
#home #access > .init .cornerunit.leftnav:hover nav ul li a::before,
#home #philosophy > .init .cornerunit.leftnav:hover nav ul li a::before,
#home #onsiteparking > .init .cornerunit.leftnav:hover nav ul li a::before,
#home #roomplan > .init .cornerunit.leftnav:hover nav ul li a::before,
#home #premiumfoor > .init .cornerunit.leftnav:hover nav ul li a::before {
  border-bottom-color: white;
}
#home #access > .init .cornerunit.rightnav::after,
#home #philosophy > .init .cornerunit.rightnav::after,
#home #onsiteparking > .init .cornerunit.rightnav::after,
#home #roomplan > .init .cornerunit.rightnav::after,
#home #premiumfoor > .init .cornerunit.rightnav::after {
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 100% 100%);
}
#home #access > .init .cornerunit.rightnav nav,
#home #philosophy > .init .cornerunit.rightnav nav,
#home #onsiteparking > .init .cornerunit.rightnav nav,
#home #roomplan > .init .cornerunit.rightnav nav,
#home #premiumfoor > .init .cornerunit.rightnav nav {
  border-right: 1px solid white;
  order: 2;
}
#home #access > .init .cornerunit.rightnav nav dl,
#home #philosophy > .init .cornerunit.rightnav nav dl,
#home #onsiteparking > .init .cornerunit.rightnav nav dl,
#home #roomplan > .init .cornerunit.rightnav nav dl,
#home #premiumfoor > .init .cornerunit.rightnav nav dl {
  right: 4rem;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit.rightnav nav dl,
  #home #philosophy > .init .cornerunit.rightnav nav dl,
  #home #onsiteparking > .init .cornerunit.rightnav nav dl,
  #home #roomplan > .init .cornerunit.rightnav nav dl,
  #home #premiumfoor > .init .cornerunit.rightnav nav dl {
    right: auto;
    left: 0;
  }
}
#home #access > .init .cornerunit.rightnav nav ul,
#home #philosophy > .init .cornerunit.rightnav nav ul,
#home #onsiteparking > .init .cornerunit.rightnav nav ul,
#home #roomplan > .init .cornerunit.rightnav nav ul,
#home #premiumfoor > .init .cornerunit.rightnav nav ul {
  left: 4rem;
}
#home #access > .init .cornerunit.rightnav nav ul li,
#home #philosophy > .init .cornerunit.rightnav nav ul li,
#home #onsiteparking > .init .cornerunit.rightnav nav ul li,
#home #roomplan > .init .cornerunit.rightnav nav ul li,
#home #premiumfoor > .init .cornerunit.rightnav nav ul li {
  text-align: left;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit.rightnav nav ul,
  #home #philosophy > .init .cornerunit.rightnav nav ul,
  #home #onsiteparking > .init .cornerunit.rightnav nav ul,
  #home #roomplan > .init .cornerunit.rightnav nav ul,
  #home #premiumfoor > .init .cornerunit.rightnav nav ul {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit.rightnav nav,
  #home #philosophy > .init .cornerunit.rightnav nav,
  #home #onsiteparking > .init .cornerunit.rightnav nav,
  #home #roomplan > .init .cornerunit.rightnav nav,
  #home #premiumfoor > .init .cornerunit.rightnav nav {
    order: 1;
  }
}
#home #access > .init .cornerunit.rightnav .main,
#home #philosophy > .init .cornerunit.rightnav .main,
#home #onsiteparking > .init .cornerunit.rightnav .main,
#home #roomplan > .init .cornerunit.rightnav .main,
#home #premiumfoor > .init .cornerunit.rightnav .main {
  order: 1;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit.rightnav .main,
  #home #philosophy > .init .cornerunit.rightnav .main,
  #home #onsiteparking > .init .cornerunit.rightnav .main,
  #home #roomplan > .init .cornerunit.rightnav .main,
  #home #premiumfoor > .init .cornerunit.rightnav .main {
    order: 2;
  }
}
#home #access > .init .cornerunit.rightnav:hover::after,
#home #philosophy > .init .cornerunit.rightnav:hover::after,
#home #onsiteparking > .init .cornerunit.rightnav:hover::after,
#home #roomplan > .init .cornerunit.rightnav:hover::after,
#home #premiumfoor > .init .cornerunit.rightnav:hover::after {
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
#home #access > .init .cornerunit.rightnav:hover nav ul li a,
#home #philosophy > .init .cornerunit.rightnav:hover nav ul li a,
#home #onsiteparking > .init .cornerunit.rightnav:hover nav ul li a,
#home #roomplan > .init .cornerunit.rightnav:hover nav ul li a,
#home #premiumfoor > .init .cornerunit.rightnav:hover nav ul li a {
  color: white;
}
#home #access > .init .cornerunit.rightnav:hover nav ul li a::before,
#home #philosophy > .init .cornerunit.rightnav:hover nav ul li a::before,
#home #onsiteparking > .init .cornerunit.rightnav:hover nav ul li a::before,
#home #roomplan > .init .cornerunit.rightnav:hover nav ul li a::before,
#home #premiumfoor > .init .cornerunit.rightnav:hover nav ul li a::before {
  border-bottom-color: white;
}
@media screen and (max-width: 768px) {
  #home #access > .init .cornerunit,
  #home #philosophy > .init .cornerunit,
  #home #onsiteparking > .init .cornerunit,
  #home #roomplan > .init .cornerunit,
  #home #premiumfoor > .init .cornerunit {
    flex-wrap: wrap;
  }
  #home #access > .init .cornerunit nav,
  #home #philosophy > .init .cornerunit nav,
  #home #onsiteparking > .init .cornerunit nav,
  #home #roomplan > .init .cornerunit nav,
  #home #premiumfoor > .init .cornerunit nav {
    width: 100%;
  }
  #home #access > .init .cornerunit .main,
  #home #philosophy > .init .cornerunit .main,
  #home #onsiteparking > .init .cornerunit .main,
  #home #roomplan > .init .cornerunit .main,
  #home #premiumfoor > .init .cornerunit .main {
    width: 100%;
    text-shadow: 0 0 8px rgba(0, 0, 0, 0.5);
  }
}
#home #philosophy #forplanning,
#home #roomplan #roomplandetail,
#home #premiumfoor #premiumfoordetail {
  display: none;
  padding: 10vh 0;
  text-align: left;
  background: white;
}
#home #philosophy #forplanning h4,
#home #roomplan #roomplandetail h4,
#home #premiumfoor #premiumfoordetail h4 {
  font-size: 2rem;
  color: #9b9b9b;
  margin-bottom: 3.125vw;
  text-align: center;
}
#home #philosophy #forplanning .initBox,
#home #roomplan #roomplandetail .initBox,
#home #premiumfoor #premiumfoordetail .initBox {
  width: 64.5833333333%;
  max-width: 1245px;
}
@media screen and (max-width: 1200px) {
  #home #philosophy #forplanning .initBox,
  #home #roomplan #roomplandetail .initBox,
  #home #premiumfoor #premiumfoordetail .initBox {
    width: 90%;
  }
}
#home #philosophy #forplanning .premiumplan,
#home #roomplan #roomplandetail .premiumplan,
#home #premiumfoor #premiumfoordetail .premiumplan {
  border-top: 1px solid #841b20;
  padding: 0.5rem 0;
  border-bottom: 1px solid #841b20;
  margin: 3rem 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
#home #philosophy #forplanning .premiumplan h3,
#home #roomplan #roomplandetail .premiumplan h3,
#home #premiumfoor #premiumfoordetail .premiumplan h3 {
  color: white;
  font-size: 2.7rem;
  line-height: 1.25;
  text-align: center;
  background: linear-gradient(45deg, #841b20, #ce3b29 50%, #841b20 100%);
  padding: 1rem 0;
  text-align: center;
  width: 40%;
}
#home #philosophy #forplanning .premiumplan h3 span,
#home #roomplan #roomplandetail .premiumplan h3 span,
#home #premiumfoor #premiumfoordetail .premiumplan h3 span {
  font-size: 1.4rem;
}
#home #philosophy #forplanning .premiumplan div,
#home #roomplan #roomplandetail .premiumplan div,
#home #premiumfoor #premiumfoordetail .premiumplan div {
  display: inline-block;
}
#home #philosophy #forplanning .premiumplan div.floor span,
#home #roomplan #roomplandetail .premiumplan div.floor span,
#home #premiumfoor #premiumfoordetail .premiumplan div.floor span {
  display: inline-block;
  width: 3em;
  text-align: center;
  background: #f0f0f0;
  margin-right: 0.5em;
  border-bottom: 1px solid white;
}
#home #philosophy #forplanning .premiumplan div.check p,
#home #roomplan #roomplandetail .premiumplan div.check p,
#home #premiumfoor #premiumfoordetail .premiumplan div.check p {
  line-height: 1.25;
  margin-bottom: 0.3rem;
  text-align: left;
}
#home #philosophy #forplanning .premiumplan strong,
#home #roomplan #roomplandetail .premiumplan strong,
#home #premiumfoor #premiumfoordetail .premiumplan strong {
  color: white;
  background: #6f0012;
  display: block;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .premiumplan,
  #home #roomplan #roomplandetail .premiumplan,
  #home #premiumfoor #premiumfoordetail .premiumplan {
    flex-wrap: wrap;
  }
  #home #philosophy #forplanning .premiumplan h3,
  #home #roomplan #roomplandetail .premiumplan h3,
  #home #premiumfoor #premiumfoordetail .premiumplan h3 {
    width: 100%;
  }
  #home #philosophy #forplanning .premiumplan div,
  #home #roomplan #roomplandetail .premiumplan div,
  #home #premiumfoor #premiumfoordetail .premiumplan div {
    width: 100%;
  }
  #home #philosophy #forplanning .premiumplan div.floor,
  #home #roomplan #roomplandetail .premiumplan div.floor,
  #home #premiumfoor #premiumfoordetail .premiumplan div.floor {
    margin: 1rem 0;
  }
}
#home #access .init .cornerunit .main {
  background-image: url(../img/home/access.jpg);
}
#home #philosophy .init .cornerunit .main {
  background-image: url(../img/home/philosophy.jpg);
}
#home #philosophy #forplanning .initBox .flex {
  /*
  &#roomplan {
  	> * {
  		h3 {
  			font-size: 2.7rem;
  			span {
  				font-size: 2rem;
  			}
  			@include resp(sp){
  				font-size: 2rem;
  				span {
  					display: block;
  					font-size: 1.4rem;
  				}
  			}
  		}
  		p {
  			font-size: 1.6rem;
  			@include resp(sp){
  				font-size: 1.4rem;
  			}
  		}
  		.btn.special a {
  			color: white(1);
  		}
  	}
  	@include resp(sp){
  		flex-wrap: wrap;
  		margin-bottom: 5rem;
  		> * {
  			width: 100%;
  			+ * {
  				margin-top: 3rem;
  			}
  		}
  	}
  }
  */
}
#home #philosophy #forplanning .initBox .flex h3 {
  font-size: 2.6rem;
  margin-bottom: 0.25em;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox .flex h3 {
    font-size: 2rem;
  }
}
#home #philosophy #forplanning .initBox .flex .leftbox {
  width: 50%;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox .flex .leftbox {
    width: 100%;
  }
}
#home #philosophy #forplanning .initBox .flex .rightbox {
  width: 42.2489959839%;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox .flex .rightbox {
    width: 100%;
    text-align: left;
  }
}
#home #philosophy #forplanning .initBox .flex#forplanning01 .rightbox img {
  /*margin-top: calc((3rem * 1.9) + (3rem * 0.25));*/
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox .flex#forplanning01 .rightbox img {
    margin-top: 1rem;
  }
}
#home #philosophy #forplanning .initBox .flex#forplanning02 {
  align-items: flex-end;
  margin: -8em 0 15vh;
}
#home #philosophy #forplanning .initBox .flex#forplanning02 .rightbox {
  text-align: left;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox .flex#forplanning02 {
    margin: 3rem 0 5rem;
  }
  #home #philosophy #forplanning .initBox .flex#forplanning02 .rightbox {
    margin-top: 3rem;
  }
}
#home #philosophy #forplanning .initBox #forroomplan h3 {
  font-size: 2.7rem;
}
#home #philosophy #forplanning .initBox #forroomplan h3 span {
  font-size: 2rem;
}
#home #philosophy #forplanning .initBox #forroomplan h3 + p {
  font-size: 1.6rem;
  display: flex;
  justify-content: left;
  align-items: center;
  flex-wrap: nowrap;
}
#home #philosophy #forplanning .initBox #forroomplan h3 + p .eyecatch {
  color: white;
  background: linear-gradient(45deg, #841b20, #ce3b29 50%, #841b20 100%);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
  padding: 0.25em 1em;
  display: inline-block;
  margin-right: 1em;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox #forroomplan h3 {
    font-size: 2rem;
    text-align: center;
    margin-bottom: 1.5rem;
  }
  #home #philosophy #forplanning .initBox #forroomplan h3 span {
    display: block;
    font-size: 1.4rem;
  }
  #home #philosophy #forplanning .initBox #forroomplan h3 + p {
    font-size: 1.4rem;
    justify-content: center;
    flex-wrap: wrap;
  }
  #home #philosophy #forplanning .initBox #forroomplan h3 + p .eyecatch {
    margin-bottom: 1rem;
    margin-right: 0;
  }
  #home #philosophy #forplanning .initBox #forroomplan h3 + p .eyecatch + span {
    display: block;
  }
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 {
  color: white;
  background: #231815;
  font-size: 1.4rem;
  /* margin-bottom: 3rem; */
  margin-bottom: 0;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4::first-letter {
  font-size: 2.4rem;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 + .spec {
  padding: 1rem 0;
  margin-bottom: 3rem;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 + .spec table {
  width: 100%;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 + .spec table tr td {
  padding: 0 1em;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 + .spec table tr td:nth-child(2) {
  text-align: right;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 + .spec table tr:last-child td {
  padding-bottom: 0.5rem;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li h4 + .spec table tfoot tr td {
  border-top: 1px solid #231815;
  /*
  border-bottom: 1px solid #231815;
  font-weight: bold;
  padding: 0.5rem 1em;
  */
  padding: 0.5rem 1em 0;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li label {
  display: inline-block;
  cursor: pointer;
  transition: 0.5s;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li input {
  display: none;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li input:checked ~ label {
  position: fixed;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.8);
  width: 100%;
  height: 100%;
  text-align: center;
  z-index: 8;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li input:checked ~ label picture {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: inline-block;
  width: 90%;
  max-height: 90%;
  margin: 0 auto;
  background: white;
  padding: 1em;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
  display: block;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li input:checked ~ label picture::after {
  font-family: "Material Symbols Outlined";
  content: "\e5c9";
  vertical-align: middle;
  font-weight: 200;
  font-variation-settings: "FILL" 1, "wght" 400, "GRAD" 0, "opsz" 24;
  font-size: 3rem;
  position: fixed;
  line-height: 1;
  bottom: 1rem;
  left: 1rem;
}
#home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li input:checked ~ label picture img {
  max-height: 80vh;
}
@media screen and (max-width: 768px) {
  #home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li {
    width: 100%;
  }
  #home #philosophy #forplanning .initBox #forroomplan ul.flex.c2 > li:not(:first-child) {
    margin-top: 1rem;
  }
}
#home #onsiteparking .init .cornerunit::after {
  content: none;
}
#home #onsiteparking .init .cornerunit .main {
  background-image: url(../img/home/onsiteparking.jpg);
  display: flex;
  align-items: flex-end;
}
@media screen and (max-width: 768px) {
  #home #onsiteparking .init .cornerunit .main {
    align-items: flex-start;
  }
}
#home #roomplan .init .cornerunit .main {
  background-image: url(../img/home/roomplan.jpg);
  display: flex;
  align-items: flex-end;
  position: relative;
}
#home #roomplan .init .cornerunit .main::after {
  content: "image";
  color: white;
  position: absolute;
  bottom: 1em;
  right: 1em;
  font-size: 1.2rem;
  letter-spacing: 0;
}
#home #roomplan .init .cornerunit .main > div {
  margin-bottom: 12vh;
}
#home #roomplan .init .cornerunit .main > div.viewmorebtn {
  margin-bottom: 0;
}
#home #roomplan .init .cornerunit .main .viewmorebtn {
  left: calc(50% + 8.8541666667vw);
}
@media screen and (max-width: 768px) {
  #home #roomplan .init .cornerunit .main {
    align-items: flex-start;
  }
  #home #roomplan .init .cornerunit .main > div {
    margin-bottom: 0;
  }
  #home #roomplan .init .cornerunit .main .viewmorebtn {
    left: 50%;
  }
}
#home #roomplan #roomplandetail {
  text-align: center;
}
#home #roomplan #roomplandetail .initBox {
  width: 64.5833333333%;
  max-width: 1245px;
}
@media screen and (max-width: 1200px) {
  #home #roomplan #roomplandetail .initBox {
    width: 90%;
  }
}
#home #roomplan #roomplandetail .initBox .executiveplan h3 {
  font-size: 2.7rem;
  text-align: left;
}
#home #roomplan #roomplandetail .initBox .executiveplan h3 span {
  font-size: 2rem;
}
#home #roomplan #roomplandetail .initBox .executiveplan h3 + p {
  font-size: 1.6rem;
  display: flex;
  justify-content: left;
  align-items: center;
  flex-wrap: nowrap;
}
#home #roomplan #roomplandetail .initBox .executiveplan h3 + p .eyecatch {
  color: white;
  background: linear-gradient(45deg, #841b20, #ce3b29 50%, #841b20 100%);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
  padding: 0.25em 1em;
  display: inline-block;
  margin-right: 1em;
}
@media screen and (max-width: 768px) {
  #home #roomplan #roomplandetail .initBox .executiveplan h3 {
    font-size: 2rem;
    text-align: center;
    margin-bottom: 1.5rem;
  }
  #home #roomplan #roomplandetail .initBox .executiveplan h3 span {
    display: block;
    font-size: 1.4rem;
  }
  #home #roomplan #roomplandetail .initBox .executiveplan h3 + p {
    font-size: 1.4rem;
    justify-content: center;
    flex-wrap: wrap;
  }
  #home #roomplan #roomplandetail .initBox .executiveplan h3 + p .eyecatch {
    margin-bottom: 1rem;
    margin-right: 0;
  }
  #home #roomplan #roomplandetail .initBox .executiveplan h3 + p .eyecatch + span {
    display: block;
  }
}
#home #roomplan #roomplandetail .initBox h5 {
  display: inline-block;
  font-size: 1.8rem;
  background: #595757;
  color: white;
  width: 25%;
  text-align: center;
}
#home #roomplan #roomplandetail .initBox .flex.c2 {
  align-items: center;
}
#home #roomplan #roomplandetail .initBox .flex.c2 .leftbox ul li {
  margin: 2rem 0;
}
#home #roomplan #roomplandetail .initBox .flex.c2 .rightbox {
  position: relative;
}
#home #roomplan #roomplandetail .initBox .flex.c2 .rightbox picture {
  position: relative;
  z-index: 1;
}
#home #roomplan #roomplandetail .initBox .flex.c2 .rightbox #roomplandetail_zumen {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
}
@media screen and (max-width: 768px) {
  #home #roomplan #roomplandetail .initBox .flex.c2 {
    flex-wrap: wrap;
  }
  #home #roomplan #roomplandetail .initBox .flex.c2 .leftbox {
    width: 100%;
    order: 2;
  }
  #home #roomplan #roomplandetail .initBox .flex.c2 .rightbox {
    width: 100%;
    order: 1;
    margin-bottom: 1em;
  }
}
#home #premiumfoor .init .cornerunit .main {
  background-image: url(../img/home/premiumfoor.jpg);
  display: flex;
  align-items: flex-end;
  position: relative;
}
#home #premiumfoor .init .cornerunit .main::after {
  content: "image";
  color: white;
  position: absolute;
  bottom: 1em;
  right: 1em;
  font-size: 1.2rem;
  letter-spacing: 0;
}
#home #premiumfoor .init .cornerunit .main > div {
  margin-bottom: 12vh;
}
#home #premiumfoor .init .cornerunit .main > div.viewmorebtn {
  margin-bottom: 0;
}
#home #premiumfoor .init .cornerunit .main .viewmorebtn {
  left: calc(50% - 8.8541666667vw);
}
@media screen and (max-width: 768px) {
  #home #premiumfoor .init .cornerunit .main {
    align-items: flex-start;
  }
  #home #premiumfoor .init .cornerunit .main > div {
    margin-bottom: 0;
  }
  #home #premiumfoor .init .cornerunit .main .viewmorebtn {
    left: 50%;
  }
}
#home #premiumfoor #premiumfoordetail {
  padding-top: 0;
  text-align: center;
}
#home #premiumfoor #premiumfoordetail .point {
  padding: 8rem 0 5rem;
  background: linear-gradient(90deg, #a08b7d, #e1cea2 50%, #a08b7d 100%);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  #home #premiumfoor #premiumfoordetail .point {
    padding: 6rem 0 3rem;
  }
}
#home #premiumfoor #premiumfoordetail .point h4 {
  margin-bottom: 0.5em;
  color: black;
}
#home #premiumfoor #premiumfoordetail .point ul li {
  font-size: 2rem;
  padding: 0.25em 0;
  text-align: center;
}
#home #premiumfoor #premiumfoordetail .point ul li:not(:last-child) {
  border-bottom: 1px solid rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 768px) {
  #home #premiumfoor #premiumfoordetail .point ul li {
    font-size: 1.8rem;
  }
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex {
  flex-wrap: nowrap;
  position: relative;
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .textbox {
  width: 29.6875%;
  background: #3e3a39;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  padding: 0 1em 20vh;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  #home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .textbox {
    width: 34.8958333333%;
    padding: 1em;
  }
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .textbox div {
  text-align: left;
  color: white;
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .textbox div h5 {
  font-size: 2.4rem;
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .imagebox {
  flex: 1;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  #home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .imagebox picture {
    overflow: hidden;
    width: 100%;
    height: 100%;
  }
  #home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .imagebox picture img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex.righttext .textbox {
  order: 2;
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex.righttext .imagebox {
  order: 1;
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex:nth-child(1) {
  z-index: 3;
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex:nth-child(2) {
  z-index: 2;
}
#home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex:nth-child(3) {
  z-index: 1;
}
@media screen and (max-width: 768px) {
  #home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex {
    flex-wrap: wrap;
  }
  #home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .textbox {
    width: 100%;
    order: 2;
    padding: 1em 1em 2em;
  }
  #home #premiumfoor #premiumfoordetail .premiumfoorimagelists .flex .imagebox {
    order: 1;
    flex: auto;
  }
}
#home #premiumfoor #premiumfoordetail .initBox {
  width: 64.5833333333%;
  max-width: 1245px;
  /*
  .executiveplan {
  	h3 {
  		font-size: 2.7rem;
  		text-align: left;
  		span {
  			font-size: 2rem;
  		}
  		+ p {
  			font-size: 1.6rem;
  			display: flex;
  			justify-content: left;
  			align-items: center;
  			flex-wrap: nowrap;
  			.eyecatch {
  				color: white(1);
  				background: linear-gradient(45deg, #841b20, #ce3b29 50%, #841b20 100%);
  				box-shadow: 0 0 8px black(0.3);
  				padding: 0.25em 1em;
  				display: inline-block;
  				margin-right: 1em;
  			}
  		}
  		@include resp(sp){
  			font-size: 2rem;
  			text-align: center;
  			margin-bottom: 1.5rem;
  			span {
  				display: block;
  				font-size: 1.4rem;
  			}
  			+ p {
  				font-size: 1.4rem;
  				justify-content: center;
  				flex-wrap: wrap;
  				.eyecatch {
  					margin-bottom: 1rem;
  					margin-right: 0;
  					+ span {
  						display: block;
  					}
  				}
  			}
  		}
  	}
  }
  h5 {
  	display: inline-block;
  	font-size: 1.8rem;
  	background: subcolor1(1);
  	color: white(1);
  	width: 25%;
  	text-align: center;
  }
  .flex.c2 {
  	align-items: center;
  	.leftbox {
  		ul {
  			li {
  				margin: 2rem 0;
  			}
  		}
  	}
  	.rightbox {
  		position: relative;
  		picture {
  			position: relative;
  			z-index: 1;
  		}
  		#roomplandetail_zumen {
  			width: 100%;
  			height: 100%;
  			position: absolute;
  			top: 0;
  			left: 0;
  			z-index: 0;
  			background-repeat: no-repeat;
  			background-position: 0 0;
  			background-size: contain;
  		}
  	}
  	@include resp(sp){
  		flex-wrap: wrap;
  		.leftbox {
  			width: 100%;
  			order: 2;
  		}
  		.rightbox {
  			width: 100%;
  			order: 1;
  			margin-bottom: 1em;
  		}
  	}
  }
  */
}
@media screen and (max-width: 1200px) {
  #home #premiumfoor #premiumfoordetail .initBox {
    width: 90%;
  }
}
#home #information {
  padding-top: 3.125vw;
}
#home #information h5 {
  font-size: 1.6rem;
  letter-spacing: 0.25em;
  margin-bottom: 2.0833333333vw;
  display: flex;
  justify-content: center;
  flex-wrap: nowrap;
  align-items: center;
}
#home #information h5::before {
  content: "[";
  margin-right: 0.5em;
}
#home #information h5::after {
  content: "]";
  margin-left: 0.5em;
}
#home #information .informationlists dl {
  display: flex;
  flex-wrap: nowrap;
  padding-bottom: 0.5em;
  border-bottom: 1px solid rgba(0, 0, 0, 0.5);
  text-align: left;
}
#home #information .informationlists dl + dl {
  margin-top: 1.5em;
}
#home #information .informationlists dl dt {
  width: 8.5em;
}
#home #information .informationlists dl dd {
  flex: 1;
}
@media screen and (max-width: 768px) {
  #home #information .informationlists dl {
    flex-wrap: wrap;
  }
  #home #information .informationlists dl dt {
    width: 100%;
    margin-bottom: 0.5rem;
  }
  #home #information .informationlists dl dd {
    width: 100%;
    flex: auto;
  }
}

#fukuoka .tenjinbigbang .logo,
#fukuoka .hakataconnected .logo {
  text-align: center;
}
#fukuoka .tenjinbigbang .logo img,
#fukuoka .hakataconnected .logo img {
  max-height: 150px;
}
#fukuoka .tenjinbigbang ol,
#fukuoka .hakataconnected ol {
  margin-left: 2em;
}
@media screen and (max-width: 768px) {
  #fukuoka .paradise {
    flex-wrap: wrap;
  }
  #fukuoka .paradise > * {
    width: 48%;
  }
  #fukuoka .paradise > *.textbox {
    width: 100%;
    margin-top: 1rem;
  }
  #fukuoka .tenjinbigbang .flex.c2,
  #fukuoka .hakataconnected .flex.c2 {
    flex-wrap: wrap;
  }
  #fukuoka .tenjinbigbang .flex.c2 .imagebox,
  #fukuoka .hakataconnected .flex.c2 .imagebox {
    width: 100%;
    margin-bottom: 1rem;
  }
  #fukuoka .tenjinbigbang .flex.c2 .textbox,
  #fukuoka .hakataconnected .flex.c2 .textbox {
    width: 100%;
  }
  #fukuoka .tenjinbigbang .flex.c2 .textbox .logo img,
  #fukuoka .hakataconnected .flex.c2 .textbox .logo img {
    max-height: 100px;
  }
}

@media screen and (max-width: 768px) {
  #access #accessContent p.spscroll img {
    height: 200px;
  }
}
#access #lifeinformation {
  color: #9b9b9b;
}
#access #lifeinformation .grid {
  gap: 3.5rem;
  letter-spacing: 0;
}
#access #lifeinformation .grid img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  #access #lifeinformation .grid {
    gap: 1rem;
  }
}
#access #lifeinformation .miniset {
  color: #595757;
}
#access #lifeinformation .miniset h5.en {
  text-align: center;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  font-weight: normal;
  color: #9b9b9b;
}
#access #lifeinformation .miniset picture img {
  margin-bottom: 0.5rem;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  #access #lifeinformation .miniset .grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (max-width: 768px) {
  #access #lifeinformation .miniset .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
#access #lifeinformation .textset {
  color: #595757;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3rem;
}
#access #lifeinformation .textset .unit1 {
  order: 1;
}
#access #lifeinformation .textset .unit2 {
  order: 4;
  grid-row: span 3;
}
#access #lifeinformation .textset .unit3 {
  order: 2;
  grid-row: span 3;
}
#access #lifeinformation .textset .unit4 {
  order: 6;
}
#access #lifeinformation .textset .unit5 {
  order: 3;
  grid-row: span 2;
}
#access #lifeinformation .textset .unit6 {
  order: 5;
  grid-row: span 2;
}
#access #lifeinformation .textset div p {
  margin-left: -0.5em;
}
#access #lifeinformation .textset div dl {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  position: relative;
  font-size: 1.2rem;
  letter-spacing: 0;
}
#access #lifeinformation .textset div dl::after {
  content: "・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・・";
  width: 100%;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
#access #lifeinformation .textset div dl dt,
#access #lifeinformation .textset div dl dd {
  background: white;
}
#access #lifeinformation .textset div dl dd {
  padding-left: 0.5em;
}
@media only screen and (min-width: 769px) and (max-width: 930px) {
  #access #lifeinformation .textset {
    grid-template-columns: repeat(2, 1fr);
  }
  #access #lifeinformation .textset .unit1 {
    order: 1;
  }
  #access #lifeinformation .textset .unit2 {
    order: 2;
  }
  #access #lifeinformation .textset .unit3 {
    order: 3;
  }
  #access #lifeinformation .textset .unit4 {
    order: 4;
  }
  #access #lifeinformation .textset .unit5 {
    order: 5;
  }
  #access #lifeinformation .textset .unit6 {
    order: 6;
  }
}
@media screen and (max-width: 768px) {
  #access #lifeinformation .textset {
    grid-template-columns: repeat(1, 1fr);
  }
  #access #lifeinformation .textset .unit1 {
    order: 1;
  }
  #access #lifeinformation .textset .unit2 {
    order: 2;
  }
  #access #lifeinformation .textset .unit3 {
    order: 3;
  }
  #access #lifeinformation .textset .unit4 {
    order: 4;
  }
  #access #lifeinformation .textset .unit5 {
    order: 5;
  }
  #access #lifeinformation .textset .unit6 {
    order: 6;
  }
}

#planning strong {
  color: #6f0012;
}
#planning .planningOl {
  counter-reset: planningnum;
}
#planning .planningOl li {
  list-style: none;
  position: relative;
  margin-left: 5rem;
}
#planning .planningOl li:before {
  font-family: "Roboto", sans-serif;
  counter-increment: planningnum;
  content: counter(planningnum) "";
  position: absolute;
  top: 1.08rem;
  left: -5rem;
  width: 3rem;
  height: 3rem;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #005078;
  color: white;
  font-size: 2rem;
  font-weight: 600;
  letter-spacing: -0.1em;
  padding-right: 0.1em;
}
#planning .planningOl li + li {
  margin-top: 1em;
}
@media screen and (max-width: 768px) {
  #planning .planningOl li {
    margin-left: 3rem;
  }
  #planning .planningOl li:before {
    top: 0.81rem;
    left: -3rem;
    width: 2rem;
    height: 2rem;
    font-size: 1.6rem;
  }
}

#publicspace #slickMain h5 {
  font-size: 2.2rem;
  text-align: center;
  color: #595757;
}
#publicspace #slickMain .slick-dots {
  position: relative;
  margin-top: 3em;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 1rem;
}
#publicspace #slickMain .slick-dots li {
  width: calc((100% - 6rem) / 4);
  height: 5px;
  margin: 0;
}
@media screen and (max-width: 768px) {
  #publicspace #slickMain .slick-dots li {
    width: calc((100% - 6rem) / 4);
  }
}
#publicspace #slickMain .slick-dots li button {
  width: 100%;
  height: 5px;
  background: #f0f0f0;
  padding: 0;
}
#publicspace #slickMain .slick-dots li button::before {
  content: "";
  display: block;
  line-height: 1;
  width: 0%;
  height: 5px;
  background: #595757;
  opacity: 1;
  font-family: "Noto Serif JP", serif;
}
#publicspace #slickMain .slick-dots li.slick-active button::before {
  transition: 6s;
  width: 100%;
}
#publicspace #slickSub .slick-track {
  transform: translate(0) !important;
}
#publicspace #slickSub .slick-track .slick-slide {
  margin: 0 1rem;
}

#proprietary #proprietarynav {
  background: linear-gradient(-45deg, #111213 0%, #4b4954 50%, #111213 100%);
}
#proprietary #proprietarynav ul {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  margin-bottom: 7rem;
}
#proprietary #proprietarynav ul li a {
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 5em;
  color: white;
  position: relative;
}
#proprietary #proprietarynav ul li a::before, #proprietary #proprietarynav ul li a::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0.5rem;
  background: white;
  display: block;
  transition: 0.5s;
}
#proprietary #proprietarynav ul li a::before {
  top: 0;
  left: 0;
}
#proprietary #proprietarynav ul li a::after {
  right: 0;
  bottom: 0;
}
#proprietary #proprietarynav ul li a:hover {
  letter-spacing: 0.2em;
}
#proprietary #proprietarynav ul li a:hover::before, #proprietary #proprietarynav ul li a:hover::after {
  width: 100%;
}
#proprietary #proprietarynav ul li.nowpage a {
  background: white;
  color: black;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarynav ul {
    grid-template-columns: repeat(1, 1fr);
  }
  #proprietary #proprietarynav ul li a {
    height: auto;
    padding: 1em 0;
  }
}
#proprietary #proprietarycontent2 #conceptroom,
#proprietary #proprietarycontent #conceptroom {
  background: linear-gradient(-45deg, #111213 0%, #4b4954 50%, #111213 100%);
  padding: 10rem 0;
}
#proprietary #proprietarycontent2 #conceptroom .types,
#proprietary #proprietarycontent #conceptroom .types {
  display: flex;
  flex-wrap: nowrap;
  box-shadow: 0 0 8px black;
}
#proprietary #proprietarycontent2 #conceptroom .types > *,
#proprietary #proprietarycontent #conceptroom .types > * {
  width: 50%;
}
#proprietary #proprietarycontent2 #conceptroom .types picture img,
#proprietary #proprietarycontent #conceptroom .types picture img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
#proprietary #proprietarycontent2 #conceptroom .types .textbox,
#proprietary #proprietarycontent #conceptroom .types .textbox {
  display: flex;
  align-items: center;
  padding: 0 5rem;
  color: white;
  background: linear-gradient(90deg, #111213 0%, #4b4954 50%, #111213 100%);
  position: relative;
}
#proprietary #proprietarycontent2 #conceptroom .types .textbox > *,
#proprietary #proprietarycontent #conceptroom .types .textbox > * {
  position: relative;
  z-index: 1;
}
#proprietary #proprietarycontent2 #conceptroom .types .textbox h4,
#proprietary #proprietarycontent #conceptroom .types .textbox h4 {
  font-weight: 400;
  margin-bottom: 0.5em;
}
#proprietary #proprietarycontent2 #conceptroom .types .textbox h4 small,
#proprietary #proprietarycontent #conceptroom .types .textbox h4 small {
  display: block;
  font-size: 1.4rem;
  text-align: right;
  line-height: 1;
}
#proprietary #proprietarycontent2 #conceptroom .types .textbox p,
#proprietary #proprietarycontent #conceptroom .types .textbox p {
  width: 60%;
}
#proprietary #proprietarycontent2 #conceptroom .types .textbox::after,
#proprietary #proprietarycontent #conceptroom .types .textbox::after {
  content: "";
  display: block;
  position: absolute;
  width: calc(50% - 6rem);
  height: calc(100% - 6rem);
  top: 3rem;
  right: 3rem;
  z-index: 0;
  background-repeat: no-repeat;
  background-position: 100% 50%;
  background-size: contain;
}
#proprietary #proprietarycontent2 #conceptroom .types.typeb .textbox::after,
#proprietary #proprietarycontent #conceptroom .types.typeb .textbox::after {
  background-image: url(../img/proprietary/conceptroom/btype_zumen.png);
}
#proprietary #proprietarycontent2 #conceptroom .types.typec .textbox::after,
#proprietary #proprietarycontent #conceptroom .types.typec .textbox::after {
  background-image: url(../img/proprietary/conceptroom/ctype_zumen.png);
}
#proprietary #proprietarycontent2 #conceptroom .types.typed .textbox::after,
#proprietary #proprietarycontent #conceptroom .types.typed .textbox::after {
  background-image: url(../img/proprietary/conceptroom/dtype_zumen.png);
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2 #conceptroom .types,
  #proprietary #proprietarycontent #conceptroom .types {
    flex-wrap: wrap;
  }
  #proprietary #proprietarycontent2 #conceptroom .types > *,
  #proprietary #proprietarycontent #conceptroom .types > * {
    width: 100%;
  }
  #proprietary #proprietarycontent2 #conceptroom .types .textbox,
  #proprietary #proprietarycontent #conceptroom .types .textbox {
    padding: 2rem;
    padding-right: 0;
  }
  #proprietary #proprietarycontent2 #conceptroom .types .textbox::after,
  #proprietary #proprietarycontent #conceptroom .types .textbox::after {
    content: "";
    display: block;
    position: absolute;
    width: calc(50% - 2rem);
    height: calc(100% - 2rem);
    top: 1rem;
    right: 1rem;
  }
}
#proprietary #proprietarycontent2 picture.line,
#proprietary #proprietarycontent picture.line {
  border: 1px solid rgba(0, 0, 0, 0.3);
}
#proprietary #proprietarycontent2 h5,
#proprietary #proprietarycontent h5 {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 1rem;
}
#proprietary #proprietarycontent2 h5.bluetitle,
#proprietary #proprietarycontent h5.bluetitle {
  padding: 0.5em 0;
  background: #005078;
  text-align: center;
  color: white;
}
#proprietary #proprietarycontent2 h5.bluetitle span,
#proprietary #proprietarycontent h5.bluetitle span {
  display: inline-block;
  font-size: 1.4rem;
  padding: 0.2rem 1em;
  border: 1px solid white;
  margin-left: 1em;
}
#proprietary #proprietarycontent2 h5.graytitle,
#proprietary #proprietarycontent h5.graytitle {
  padding: 0.25em 0;
  background: rgba(155, 155, 155, 0.25);
  text-align: center;
  border-radius: 1em;
}
#proprietary #proprietarycontent2 h6,
#proprietary #proprietarycontent h6 {
  font-size: 1.6rem;
  line-height: 1.5;
  margin: 0.5rem 0;
}
#proprietary #proprietarycontent2 p,
#proprietary #proprietarycontent2 ul.cautionUl,
#proprietary #proprietarycontent p,
#proprietary #proprietarycontent ul.cautionUl {
  letter-spacing: 0;
  font-size: 1.4rem;
  line-height: 1.5;
}
#proprietary #proprietarycontent2 p.small,
#proprietary #proprietarycontent2 ul.cautionUl.small,
#proprietary #proprietarycontent p.small,
#proprietary #proprietarycontent ul.cautionUl.small {
  font-size: 1.1rem;
}
#proprietary #proprietarycontent2.kitchen .grid,
#proprietary #proprietarycontent.kitchen .grid {
  gap: 5rem;
}
#proprietary #proprietarycontent2.kitchen .grid > * .beforecontent,
#proprietary #proprietarycontent.kitchen .grid > * .beforecontent {
  margin-bottom: 1rem;
}
#proprietary #proprietarycontent2.kitchen .grid > * .aftercontent,
#proprietary #proprietarycontent.kitchen .grid > * .aftercontent {
  margin-top: 1rem;
}
#proprietary #proprietarycontent2.kitchen .grid > *.type2,
#proprietary #proprietarycontent.kitchen .grid > *.type2 {
  display: flex;
  flex-direction: column;
}
#proprietary #proprietarycontent2.kitchen .grid > *.type2 picture,
#proprietary #proprietarycontent.kitchen .grid > *.type2 picture {
  margin-top: auto;
}
#proprietary #proprietarycontent2.kitchen .grid > *.type2 h5,
#proprietary #proprietarycontent.kitchen .grid > *.type2 h5 {
  padding: 0.25em 0;
  background: #005078;
  text-align: center;
  color: white;
}
#proprietary #proprietarycontent2.kitchen .grid > *.type2 .subcomment,
#proprietary #proprietarycontent.kitchen .grid > *.type2 .subcomment {
  position: relative;
  z-index: 2;
  letter-spacing: 0;
}
#proprietary #proprietarycontent2.kitchen .grid > *.type2 .subcomment span,
#proprietary #proprietarycontent.kitchen .grid > *.type2 .subcomment span {
  width: 100%;
  display: block;
  font-size: 1rem;
  padding: 0.25em 1em;
  border-radius: 8px;
  line-height: 1.25;
  background: #9b9b9b;
  color: white;
  font-weight: 600;
  position: absolute;
  bottom: -1.5em;
  left: 0;
  font-family: "Noto Sans JP", sans-serif;
}
#proprietary #proprietarycontent2.kitchen .grid > *.type3 h5,
#proprietary #proprietarycontent.kitchen .grid > *.type3 h5 {
  padding: 0.25em 0;
  background: rgba(155, 155, 155, 0.25);
  text-align: center;
  border-radius: 1em;
}
#proprietary #proprietarycontent2.kitchen .grid > *.item18 h5,
#proprietary #proprietarycontent.kitchen .grid > *.item18 h5 {
  font-size: 1.6rem;
  padding: calc(0.25em + 0.19rem) 0;
  letter-spacing: 0;
}
#proprietary #proprietarycontent2.kitchen .sciencewater .points ul,
#proprietary #proprietarycontent.kitchen .sciencewater .points ul {
  display: grid;
  grid-template-columns: 38% 24% 38%;
}
#proprietary #proprietarycontent2.kitchen .sciencewater .points ul li:nth-child(2),
#proprietary #proprietarycontent.kitchen .sciencewater .points ul li:nth-child(2) {
  grid-column: 2/3;
  grid-row: 1/3;
  padding: 0 1em;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.kitchen .sciencewater .points ul,
  #proprietary #proprietarycontent.kitchen .sciencewater .points ul {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
  #proprietary #proprietarycontent2.kitchen .sciencewater .points ul li:nth-child(2),
  #proprietary #proprietarycontent.kitchen .sciencewater .points ul li:nth-child(2) {
    display: none;
  }
  #proprietary #proprietarycontent2.kitchen .sciencewater .points ul li h5,
  #proprietary #proprietarycontent.kitchen .sciencewater .points ul li h5 {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.kitchen .sciencewater .flex .leftImage,
  #proprietary #proprietarycontent.kitchen .sciencewater .flex .leftImage {
    width: 35%;
  }
  #proprietary #proprietarycontent2.kitchen .sciencewater .flex .leftImage + p,
  #proprietary #proprietarycontent.kitchen .sciencewater .flex .leftImage + p {
    width: 60%;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *,
#proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > * {
  width: 40%;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *,
  #proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > * {
    width: 100%;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *.wide2,
#proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > *.wide2 {
  width: 58%;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *.wide2,
  #proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > *.wide2 {
    width: 100%;
    margin-bottom: 1em;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *.wide2 > .flex.c3 > *,
#proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > *.wide2 > .flex.c3 > * {
  width: calc((100% - 2rem) / 3);
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *.wide2 > .flex.c3 > *.caption,
  #proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > *.wide2 > .flex.c3 > *.caption {
    margin-bottom: 2em;
  }
  #proprietary #proprietarycontent2.bathroom .bathroom-2 > .flex.c3 > *.wide2 > .flex.c3 > *.caption::before,
  #proprietary #proprietarycontent.bathroom .bathroom-2 > .flex.c3 > *.wide2 > .flex.c3 > *.caption::before {
    left: 0;
    bottom: -2em;
    font-size: 1rem;
    line-height: 1.25;
    color: black;
    white-space: nowrap;
  }
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-2 .rightImage,
  #proprietary #proprietarycontent.bathroom .bathroom-2 .rightImage {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5em;
  }
  #proprietary #proprietarycontent2.bathroom .bathroom-2 .rightImage > *,
  #proprietary #proprietarycontent.bathroom .bathroom-2 .rightImage > * {
    width: 48%;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-2 .ultrafinebubbles,
#proprietary #proprietarycontent.bathroom .bathroom-2 .ultrafinebubbles {
  background: rgba(240, 240, 240, 0.5);
  padding: 2em;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-2 .ultrafinebubbles,
  #proprietary #proprietarycontent.bathroom .bathroom-2 .ultrafinebubbles {
    padding: 1em;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-3 h6,
#proprietary #proprietarycontent.bathroom .bathroom-3 h6 {
  padding-bottom: 0.5rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.3);
  margin-bottom: 1.5rem;
  letter-spacing: 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-4 .rightImage,
  #proprietary #proprietarycontent.bathroom .bathroom-4 .rightImage {
    text-align: center;
  }
  #proprietary #proprietarycontent2.bathroom .bathroom-4 .rightImage img,
  #proprietary #proprietarycontent.bathroom .bathroom-4 .rightImage img {
    max-width: 230px;
    margin: 0 auto;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-4 .imagebox,
#proprietary #proprietarycontent.bathroom .bathroom-4 .imagebox {
  width: 35%;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-4 .imagebox,
  #proprietary #proprietarycontent.bathroom .bathroom-4 .imagebox {
    width: 100%;
    margin-bottom: 0.5em;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-4 .textbox,
#proprietary #proprietarycontent.bathroom .bathroom-4 .textbox {
  width: 60%;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-4 .textbox,
  #proprietary #proprietarycontent.bathroom .bathroom-4 .textbox {
    width: 100%;
  }
}
#proprietary #proprietarycontent2.bathroom .bathroom-6 .grid,
#proprietary #proprietarycontent.bathroom .bathroom-6 .grid {
  grid-template-columns: repeat(5, 1fr);
  gap: 2rem;
}
#proprietary #proprietarycontent2.bathroom .bathroom-6 .grid h5,
#proprietary #proprietarycontent.bathroom .bathroom-6 .grid h5 {
  font-size: 1.6rem;
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-6 .grid h5,
  #proprietary #proprietarycontent.bathroom .bathroom-6 .grid h5 {
    font-size: 1.2rem;
    letter-spacing: 0;
  }
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.bathroom .bathroom-6 .grid,
  #proprietary #proprietarycontent.bathroom .bathroom-6 .grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}
#proprietary #proprietarycontent2.powderroom div.small.right,
#proprietary #proprietarycontent.powderroom div.small.right {
  font-size: 1.2rem;
  letter-spacing: 0;
  font-weight: 600;
}
#proprietary #proprietarycontent2.powderroom .powderroom-1 .flex.c2,
#proprietary #proprietarycontent.powderroom .powderroom-1 .flex.c2 {
  align-items: center;
}
#proprietary #proprietarycontent2.powderroom .powderroom-4 .flex .leftbox,
#proprietary #proprietarycontent.powderroom .powderroom-4 .flex .leftbox {
  width: 60%;
}
#proprietary #proprietarycontent2.powderroom .powderroom-4 .flex .rightbox,
#proprietary #proprietarycontent.powderroom .powderroom-4 .flex .rightbox {
  width: 36%;
}
#proprietary #proprietarycontent2.powderroom .powderroom-4 .flex .rightbox .logo,
#proprietary #proprietarycontent.powderroom .powderroom-4 .flex .rightbox .logo {
  text-align: center;
}
#proprietary #proprietarycontent2.powderroom .powderroom-4 .flex .rightbox .logo img,
#proprietary #proprietarycontent.powderroom .powderroom-4 .flex .rightbox .logo img {
  height: 3.7rem;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.powderroom .powderroom-4 .flex .leftbox,
  #proprietary #proprietarycontent.powderroom .powderroom-4 .flex .leftbox {
    width: 100%;
    margin-bottom: 1em;
  }
  #proprietary #proprietarycontent2.powderroom .powderroom-4 .flex .rightbox,
  #proprietary #proprietarycontent.powderroom .powderroom-4 .flex .rightbox {
    width: 100%;
  }
}
#proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4,
#proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 {
  gap: 2rem;
}
#proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4 > *:nth-child(4),
#proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 > *:nth-child(4) {
  grid-column: 4/5;
  grid-row: 1/3;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4 > *:nth-child(4),
  #proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 > *:nth-child(4) {
    grid-column: 2/3;
    grid-row: 1/3;
  }
}
#proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4 > *:nth-child(4) picture,
#proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 > *:nth-child(4) picture {
  overflow: hidden;
  height: calc(100% - 3.7rem);
}
#proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4 > *:nth-child(4) picture img,
#proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 > *:nth-child(4) picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4,
  #proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 {
    grid-template-columns: repeat(2, 1fr);
  }
  #proprietary #proprietarycontent2.powderroom .powderroom-5.grid.g4 h5,
  #proprietary #proprietarycontent.powderroom .powderroom-5.grid.g4 h5 {
    font-size: 1.4rem;
  }
}
#proprietary #proprietarycontent2.lavatory h3,
#proprietary #proprietarycontent.lavatory h3 {
  padding-top: 1rem;
  border-top: 4px solid #005078;
}
#proprietary #proprietarycontent2.lavatory .lavatory-2 .grid,
#proprietary #proprietarycontent2.lavatory .lavatory-3 .grid,
#proprietary #proprietarycontent.lavatory .lavatory-2 .grid,
#proprietary #proprietarycontent.lavatory .lavatory-3 .grid {
  grid-template-columns: repeat(5, 1fr);
  gap: 2rem;
}
#proprietary #proprietarycontent2.lavatory .lavatory-2 .grid h5,
#proprietary #proprietarycontent2.lavatory .lavatory-3 .grid h5,
#proprietary #proprietarycontent.lavatory .lavatory-2 .grid h5,
#proprietary #proprietarycontent.lavatory .lavatory-3 .grid h5 {
  font-size: 1.6rem;
  font-weight: normal;
  background: #595757;
  color: white;
  padding: 0.25em 0;
  text-align: center;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.lavatory .lavatory-2 .grid h5,
  #proprietary #proprietarycontent2.lavatory .lavatory-3 .grid h5,
  #proprietary #proprietarycontent.lavatory .lavatory-2 .grid h5,
  #proprietary #proprietarycontent.lavatory .lavatory-3 .grid h5 {
    font-size: 1.2rem;
    letter-spacing: 0;
  }
}
#proprietary #proprietarycontent2.lavatory .lavatory-2 .grid picture,
#proprietary #proprietarycontent2.lavatory .lavatory-3 .grid picture,
#proprietary #proprietarycontent.lavatory .lavatory-2 .grid picture,
#proprietary #proprietarycontent.lavatory .lavatory-3 .grid picture {
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.lavatory .lavatory-2 .grid,
  #proprietary #proprietarycontent2.lavatory .lavatory-3 .grid,
  #proprietary #proprietarycontent.lavatory .lavatory-2 .grid,
  #proprietary #proprietarycontent.lavatory .lavatory-3 .grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table,
#proprietary #proprietarycontent.lavatory .lavatory-4 table {
  border-collapse: separate;
  border-spacing: 0 calc(0.5rem + 2px + 0.5rem) !important;
  width: 100%;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr {
  position: relative;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr::after,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 0;
  border-bottom: 2px solid rgba(0, 0, 0, 0.3);
  bottom: calc(-0.5rem - 2px);
  left: 0;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr th,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr th {
  text-align: left;
  vertical-align: top;
  white-space: nowrap;
  padding-right: 1em;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr td ul,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr td ul {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr td ul li,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr td ul li {
  text-align: center;
  color: white;
  padding: 0.5rem 0;
  letter-spacing: 0;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr td ul,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr td ul {
    grid-template-columns: repeat(1, 1fr);
  }
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(1) th,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(1) th {
  color: #717071;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(1) td ul li,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(1) td ul li {
  background: #ae859b;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(1) td ul li:nth-child(1),
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(1) td ul li:nth-child(1) {
  background: #646983;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(1) td ul li:nth-child(2),
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(1) td ul li:nth-child(2) {
  font-size: 1.1rem;
  letter-spacing: -0.05em;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(2) th,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(2) th {
  color: #626293;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(2) td ul li,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(2) td ul li {
  background: #646983;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(3) th,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(3) th {
  color: #c2a67e;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(3) td ul li,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(3) td ul li {
  background: #c2a67e;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(4) th,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(4) th {
  color: #6a9380;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(4) td ul li,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(4) td ul li {
  background: #6a9380;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(5) th,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(5) th {
  color: #ae859b;
}
#proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody tr:nth-child(5) td ul li,
#proprietary #proprietarycontent.lavatory .lavatory-4 table tbody tr:nth-child(5) td ul li {
  background: #ae859b;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table tbody,
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table tr,
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table th,
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table td,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table tbody,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table tr,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table th,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table td {
    display: block;
  }
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table tr:not(:first-child) th,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table tr:not(:first-child) th {
    padding-top: 2em;
  }
  #proprietary #proprietarycontent2.lavatory .lavatory-4 table tr th,
  #proprietary #proprietarycontent.lavatory .lavatory-4 table tr th {
    border-bottom: 1px dotted black;
    margin-bottom: 0.5em;
  }
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.others .others-2 .logo,
  #proprietary #proprietarycontent.others .others-2 .logo {
    text-align: center;
  }
  #proprietary #proprietarycontent2.others .others-2 .logo img,
  #proprietary #proprietarycontent.others .others-2 .logo img {
    margin: 0 auto;
    max-width: 200px;
  }
}
#proprietary #proprietarycontent2.others .others-3,
#proprietary #proprietarycontent.others .others-3 {
  border-top: 1px solid #005078;
  padding-top: 2em;
}
#proprietary #proprietarycontent2.others .others-3 .internetoptionservice,
#proprietary #proprietarycontent.others .others-3 .internetoptionservice {
  color: #005078;
}
#proprietary #proprietarycontent2.others .others-3 .internetoptionservice h5,
#proprietary #proprietarycontent.others .others-3 .internetoptionservice h5 {
  border: 1px solid #005078;
  text-align: center;
  padding: 0.5em 0;
}
#proprietary #proprietarycontent2.others .others-4 .flex.c4 h5,
#proprietary #proprietarycontent.others .others-4 .flex.c4 h5 {
  background: #808080;
  color: white;
  text-align: center;
  font-size: 1.4rem;
  padding: 0.25em 0;
  text-align: center;
  letter-spacing: 0;
}
#proprietary #proprietarycontent2.others .others-5 .logo2,
#proprietary #proprietarycontent.others .others-5 .logo2 {
  text-align: center;
}
#proprietary #proprietarycontent2.others .others-5 .logo2 img,
#proprietary #proprietarycontent.others .others-5 .logo2 img {
  max-height: 15vh;
}
#proprietary #proprietarycontent2.others .others-5 .aftercontent,
#proprietary #proprietarycontent.others .others-5 .aftercontent {
  margin-top: 0.5rem;
}
@media screen and (max-width: 768px) {
  #proprietary #proprietarycontent2.others .others-5 .logo1,
  #proprietary #proprietarycontent.others .others-5 .logo1 {
    text-align: center;
  }
  #proprietary #proprietarycontent2.others .others-5 .logo1 img,
  #proprietary #proprietarycontent.others .others-5 .logo1 img {
    max-width: 250px;
  }
  #proprietary #proprietarycontent2.others .others-5 .logo2,
  #proprietary #proprietarycontent.others .others-5 .logo2 {
    width: 25%;
    float: right;
    margin-left: 1em;
  }
}

#roomplan #roomplancontent h5 {
  font-size: 2.2rem;
  text-align: center;
  color: #595757;
}
#roomplan #roomplancontent .flex.c3 {
  align-items: center;
}
#roomplan #roomplancontent .flex.c3 .wide2 {
  color: #595757;
  border-left: 1px solid #595757;
  padding-left: 2.5em;
}
#roomplan #roomplancontent .flex.c3 .wide2 h4 {
  font-weight: normal;
  line-height: 1.5;
  font-size: clamp(2rem, 3vw, 3rem);
  margin-bottom: 1rem;
}
#roomplan #roomplancontent .flex.c3 .wide2 .area {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
#roomplan #roomplancontent .flex.c3 .wide2 .area li.total {
  margin-top: 1rem;
  grid-column: span 2;
}
@media screen and (max-width: 768px) {
  #roomplan #roomplancontent .flex.c3 {
    flex-wrap: wrap;
  }
  #roomplan #roomplancontent .flex.c3 .wide2 {
    width: 100%;
    order: 2;
    border-left: none;
    padding-left: 0;
  }
  #roomplan #roomplancontent .flex.c3 .wide2 h4.en {
    padding-bottom: 0.5em;
    border-bottom: 1px solid #595757;
  }
  #roomplan #roomplancontent .flex.c3 .wide2 .area {
    display: block;
    padding-bottom: 0.5em;
    border-bottom: 1px solid #595757;
  }
  #roomplan #roomplancontent .flex.c3 .wide2 .area li {
    width: 100%;
  }
  #roomplan #roomplancontent .flex.c3 .imagebox {
    width: 100%;
    max-width: 250px;
    margin: 0 auto 2em;
    order: 1;
    text-align: left;
  }
  #roomplan #roomplancontent .flex.c3 .imagebox img {
    max-width: 250px;
  }
}
#roomplan #roomplancontent .planningnav {
  margin-top: 2rem;
}
#roomplan #roomplancontent .planningnav ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
#roomplan #roomplancontent .planningnav ul li.nowpage {
  background: #f0f0f0;
}
@media screen and (max-width: 768px) {
  #roomplan #roomplancontent .planningnav ul {
    display: block;
  }
  #roomplan #roomplancontent .planningnav ul li + li {
    margin-top: 2rem;
  }
}
#roomplan #roomplanPcontent h4 {
  font-weight: 400;
}
#roomplan #roomplanPcontent h5 {
  font-size: 2.2rem;
  text-align: center;
  color: #595757;
}
#roomplan #roomplanPcontent .flex.c3 {
  align-items: center;
}
#roomplan #roomplanPcontent .flex.c3 .wide2 {
  border-left: 1px solid rgba(0, 0, 0, 0.5);
  padding-left: 2em;
}
#roomplan #roomplanPcontent .flex.c3 .wide2 h4.en {
  font-size: 3.6rem;
  line-height: 1.25;
}
#roomplan #roomplanPcontent .flex.c3 .wide2 h4.en .larger.num {
  font-size: 175%;
  color: rgba(0, 0, 0, 0.6);
}
#roomplan #roomplanPcontent .flex.c3 .wide2 .area {
  margin-top: 1em;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  font-size: 1.6rem;
  gap: 0.5rem 2rem;
}
@media screen and (max-width: 768px) {
  #roomplan #roomplanPcontent .flex.c3 .wide2 {
    padding-left: 1.5em;
    margin-bottom: 1em;
  }
  #roomplan #roomplanPcontent .flex.c3 .wide2 h4.en {
    font-size: 2rem;
  }
  #roomplan #roomplanPcontent .flex.c3 .wide2 .area {
    grid-template-columns: repeat(1, 1fr);
    font-size: 1.4rem;
    gap: 0.25rem;
  }
}

#orderplan #orderplannav ul li a {
  min-width: 250px;
  display: block;
  background: #dde5ea;
  color: white;
  text-align: center;
  padding: 0.25em 0;
  text-decoration: none;
  margin: 0 auto;
}
#orderplan #orderplannav ul li a:hover {
  background: rgba(15, 48, 86, 0.5);
  box-shadow: 0 0 8px rgba(0, 0, 0, 0.3);
}
#orderplan #orderplannav ul li.nowpage a {
  pointer-events: none;
  background: #0f3056;
}
#orderplan #slickImage .slick-slide {
  margin-right: 1rem;
}
#orderplan .orderplanpoint li {
  width: 33.3333333333%;
  border-right: 1px solid rgba(0, 0, 0, 0.3);
}
#orderplan .orderplanpoint li:first-child {
  border-left: 1px solid rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 768px) {
  #orderplan .orderplanpoint li {
    width: 100%;
    padding: 1em 0;
    border: none;
    border-bottom: 1px solid rgba(0, 0, 0, 0.3);
  }
  #orderplan .orderplanpoint li:first-child {
    border-top: 1px solid rgba(0, 0, 0, 0.3);
    border-left: none;
  }
}
#orderplan #ownersselect .inlineblock {
  display: inline-block;
}
@media screen and (max-width: 768px) {
  #orderplan #ownersselect .inlineblock {
    display: block;
  }
}
#orderplan #ownersselect h3 {
  font-size: 2.4rem;
  font-weight: 400;
  margin-bottom: 0.25em;
  color: #9b9b9b;
}
#orderplan #ownersselect h3::before {
  content: "■";
  margin-right: 0.5rem;
}
#orderplan #ownersselect .typeDl {
  border: 2px solid #9b9b9b;
  border-right: none;
  padding: 0.5rem 0;
  display: flex;
  justify-content: left;
  font-size: 1.8rem;
}
#orderplan #ownersselect .typeDl dt,
#orderplan #ownersselect .typeDl dd {
  padding: 0 1em;
}
#orderplan #ownersselect .typeDl dd {
  border-left: 2px solid #9b9b9b;
}
@media screen and (max-width: 768px) {
  #orderplan #ownersselect .typeDl {
    border-left: none;
  }
  #orderplan #ownersselect .typeDl dt {
    padding-right: 0.5em;
    padding-left: 0;
  }
  #orderplan #ownersselect .typeDl dd {
    padding-right: 0;
    padding-left: 0.5em;
  }
}
#orderplan #ownersselect h5 {
  font-size: 1.4rem;
  margin-bottom: 0.5em;
}
#orderplan #ownersselect h5::before {
  content: "＜";
}
#orderplan #ownersselect h5::after {
  content: "＞";
}
#orderplan #ownersselect .grid.g2 {
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
#orderplan #ownersselect .grid.g3 {
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
#orderplan #ownersselect .grid.g4 {
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}
#orderplan #ownersselect .grid.g5 {
  grid-template-columns: repeat(5, 1fr);
  gap: 2rem;
}
#orderplan #ownersselect .grid.g6 {
  grid-template-columns: repeat(6, 1fr);
  gap: 2rem;
}
#orderplan #ownersselect .grid.g6 .aftercontent {
  margin-top: 0.5rem;
  line-height: 1.25;
}
@media screen and (max-width: 768px) {
  #orderplan #ownersselect .grid.g2, #orderplan #ownersselect .grid.g3, #orderplan #ownersselect .grid.g4, #orderplan #ownersselect .grid.g5, #orderplan #ownersselect .grid.g6 {
    grid-template-columns: repeat(2, 1fr);
  }
  #orderplan #ownersselect .grid.g2.spone, #orderplan #ownersselect .grid.g3.spone, #orderplan #ownersselect .grid.g4.spone, #orderplan #ownersselect .grid.g5.spone, #orderplan #ownersselect .grid.g6.spone {
    grid-template-columns: repeat(1, 1fr);
  }
}
@media screen and (max-width: 768px) {
  #orderplan #ownersselect .cross picture {
    aspect-ratio: 275/172;
  }
  #orderplan #ownersselect .cross picture img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
}
#orderplan #ownersselect .lavatory .flex .imagebox {
  width: 27%;
}
#orderplan #ownersselect .lavatory .flex .itembox {
  width: calc(73% - 2rem);
}
@media screen and (max-width: 768px) {
  #orderplan #ownersselect .lavatory .flex .imagebox,
  #orderplan #ownersselect .lavatory .flex .itembox {
    width: 100%;
  }
  #orderplan #ownersselect .lavatory .flex picture {
    aspect-ratio: 275/172;
  }
  #orderplan #ownersselect .lavatory .flex picture img {
    -o-object-fit: cover;
       object-fit: cover;
    width: 100%;
    height: 100%;
  }
}

#structure h5 {
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 1rem;
}
#structure h5.bluetitle {
  font-size: 1.8rem;
  padding: 0.5em 0;
  background: #005078;
  text-align: center;
  color: white;
}
#structure h5.bluetitle span {
  display: inline-block;
  font-size: 1.4rem;
  padding: 0.2rem 1em;
  border: 1px solid white;
  margin-left: 1em;
}
#structure .brownOl {
  counter-reset: planningnum;
}
#structure .brownOl li {
  list-style: none;
  position: relative;
  margin-left: 4.5rem;
  margin-bottom: 0.5em;
}
#structure .brownOl li:before {
  font-family: "Roboto", sans-serif;
  counter-increment: planningnum;
  content: counter(planningnum) "";
  position: absolute;
  top: 0;
  left: -4.5rem;
  width: 3rem;
  height: 3rem;
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #c79f62;
  color: white;
  font-size: 2rem;
  font-weight: 600;
  letter-spacing: -0.1em;
  padding-right: 0.1em;
}
#structure .flex.c3 h4 {
  font-size: clamp(1.6rem, 2.8vw, 2.2rem);
}
@media screen and (max-width: 768px) {
  #structure .flex.c3 > *.spmT2 {
    margin-top: 2em;
  }
}

#zehm h5 {
  font-size: 1.8rem;
}
#zehm h5.greentitle {
  background: #83cc8a;
  color: white;
  text-align: center;
  margin-bottom: 1em;
  line-height: 1.25;
}
@media screen and (max-width: 768px) {
  #zehm h5 {
    font-size: 1.6rem;
  }
  #zehm h5.greentitle {
    padding: 1em;
    text-align: left;
  }
}
#zehm h6 {
  font-size: 1.6rem;
}
#zehm h6.green {
  color: #009c3c;
  font-family: "Noto Sans JP", sans-serif;
}
#zehm h6.bordertitle {
  color: #005078;
  border: 2px solid #005078;
  padding: 0.5rem 0;
  text-align: center;
  line-height: 1.25;
  margin-bottom: 1em;
}
#zehm a {
  overflow-wrap: anywhere;
}
#zehm .aboutzehm ul.point li {
  background: #009c3c;
  color: white;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1em 0;
}
#zehm .aboutzehm ul.point li span.middle {
  display: inline-block;
  line-height: 1.25;
}
#zehm .pointzehm .flex.zehdeveloper {
  align-items: center;
}
#zehm .pointzehm .flex.zehdeveloper picture {
  width: 35%;
  max-width: 170px;
}
#zehm .pointzehm .flex.zehdeveloper .textbox {
  flex: 1;
  padding-left: 4rem;
}
@media screen and (max-width: 768px) {
  #zehm .pointzehm .flex.zehdeveloper picture {
    width: 100%;
    max-width: none;
    margin-bottom: 2em;
    text-align: center;
  }
  #zehm .pointzehm .flex.zehdeveloper picture img {
    max-width: 130px;
    margin: 0 auto;
  }
  #zehm .pointzehm .flex.zehdeveloper .textbox {
    flex: auto;
    width: 100%;
    padding-left: 0;
  }
}
#zehm .healthzehm > .flex .leftbox {
  width: 55%;
}
#zehm .healthzehm > .flex .rightbox {
  width: 44%;
}
@media screen and (max-width: 768px) {
  #zehm .healthzehm > .flex .leftbox {
    width: 100%;
    margin-bottom: 1em;
  }
  #zehm .healthzehm > .flex .rightbox {
    width: 100%;
  }
}
#zehm .financeszehm ul.cautionUl.mt-2 {
  margin-top: -2em;
}
@media screen and (max-width: 768px) {
  #zehm .financeszehm ul.cautionUl.mt-2 {
    margin-top: 0;
  }
}
#zehm .environmentzehm .grid.g4 {
  gap: 2rem;
}
#zehm .environmentzehm .grid.g4 .beforecontent {
  font-size: 1.6rem;
  margin-bottom: 0.5rem;
}
@media screen and (max-width: 768px) {
  #zehm .environmentzehm .grid.g4 {
    grid-template-columns: repeat(2, 1fr);
  }
  #zehm .environmentzehm .grid.g4 .beforecontent {
    font-size: 1.2rem;
  }
}

#outline #headerBox h1 {
  background: #f0f0f0;
  box-shadow: none;
}
#outline #pagetitle {
  margin-bottom: min(10.4166666667vw, 250px);
}
#outline #mainContentsBox.pageContent {
  color: black;
}
#outline #outlinecontent .flex {
  text-align: left;
}
#outline #outlinecontent .flex .titlebox {
  width: 28.8%;
}
#outline #outlinecontent .flex .titlebox h3 {
  border-top: 5px solid #595757;
  color: #595757;
}
#outline #outlinecontent .flex .contentbox {
  width: 61.6%;
}
#outline #outlinecontent .flex .contentbox .tableinit {
  border-left: 2px solid #9b9b9b;
  padding-left: 3.6%;
}
#outline #outlinecontent .flex .contentbox .tableinit th {
  width: 30%;
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  #outline #outlinecontent .flex .titlebox {
    width: 100%;
    margin-bottom: 1rem;
  }
  #outline #outlinecontent .flex .titlebox h3 {
    display: inline-block;
    padding-right: 2em;
  }
  #outline #outlinecontent .flex .contentbox {
    width: 100%;
  }
  #outline #outlinecontent .flex .contentbox .tableinit {
    border-left: none;
    padding-left: 0;
  }
  #outline #outlinecontent .flex .contentbox .tableinit tr,
  #outline #outlinecontent .flex .contentbox .tableinit th,
  #outline #outlinecontent .flex .contentbox .tableinit td {
    display: block;
  }
  #outline #outlinecontent .flex .contentbox .tableinit tr {
    padding-bottom: 0.5em;
    border-bottom: 1px dotted rgba(0, 0, 0, 0.5);
  }
  #outline #outlinecontent .flex .contentbox .tableinit th {
    width: 100%;
  }
  #outline #outlinecontent .flex .contentbox .tableinit td {
    padding-left: 2em;
  }
}

#security h5 {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.5;
  margin-bottom: 1rem;
}
#security h5.bluetitle {
  padding: 0.5em 0;
  background: #005078;
  text-align: center;
  color: white;
}
#security h5.bluetitle span {
  display: inline-block;
  font-size: 1.4rem;
  padding: 0.2rem 1em;
  border: 1px solid white;
  margin-left: 1em;
}
#security p.bluelinebox {
  font-size: 1.6rem;
  border: 1px solid #003f75;
  color: #003f75;
  text-align: center;
  padding: 0.25em;
  margin-bottom: 1em;
}
#security .security-3 .flex.c3 > .leftbox h5 {
  font-size: 1.4rem;
  letter-spacing: 0;
}
@media screen and (max-width: 768px) {
  #security .security-3 .flex.c3 > .wide2 .imagebox {
    display: flex;
    justify-content: space-between;
  }
  #security .security-3 .flex.c3 > .wide2 .imagebox > * {
    width: 48%;
  }
}
@media screen and (max-width: 768px) {
  #security .security-6 .mainentrance > *:nth-child(1) {
    order: 2;
    width: 48%;
  }
  #security .security-6 .mainentrance > *:nth-child(2) {
    order: 1;
    width: 100%;
    margin-bottom: 1em;
  }
  #security .security-6 .mainentrance > *:nth-child(3) {
    order: 3;
    width: 48%;
  }
}

#management h4.borderbox {
  text-align: center;
  border: 2px solid #9b9b9b;
  padding: 0.5em 0;
  letter-spacing: 0.1em;
  margin-bottom: 1em;
}
#management h4.borderbox span {
  font-size: 80%;
}
#management h4.borderbox span::before {
  content: "[ ";
}
#management h4.borderbox span::after {
  content: " ]";
}
#management h5 {
  font-size: 1.6rem;
  margin-bottom: 1em;
}
#management .bluetext {
  color: #006bab;
}
#management dl.happysupport {
  background: #006bab;
  color: white;
  padding: 0.5em 0;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  font-size: 1.6rem;
  line-height: 1.25;
}
#management dl.happysupport img {
  max-height: 5rem;
}
#management dl.happysupport dt {
  padding: 0 0.5em;
  position: relative;
}
#management dl.happysupport dt:not(:has(img)) {
  border-right: 1px solid white;
}
#management dl.happysupport dd {
  padding-left: 0.5em;
  flex: 1;
}
@media screen and (max-width: 768px) {
  #management dl.happysupport {
    flex-wrap: wrap;
  }
  #management dl.happysupport dt {
    width: 100%;
  }
  #management dl.happysupport dt:not(:has(img)) {
    border-right: none;
  }
  #management dl.happysupport dd {
    flex: auto;
    padding: 0 0.5em;
  }
}
#management .servicebox {
  gap: 1.5rem 4rem;
}
#management .servicebox.grid > *.row2 {
  grid-row: 2 span;
}
#management .servicebox dl dt {
  background: #008ad1;
  color: white;
  font-size: 1.8rem;
  margin-bottom: 0.5rem;
  min-height: 2.5em;
  padding: 0 0.5em;
  display: flex;
  align-items: center;
  line-height: 1;
}
#management .servicebox dl dd .point {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  margin: 1em 0;
}
#management .servicebox dl dd .point li {
  border-radius: 1em;
  background: #1ebc5e;
  color: white;
  font-size: 1rem;
  text-align: center;
  font-weight: 600;
  letter-spacing: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1.25;
  min-height: 3em;
}
@media screen and (max-width: 768px) {
  #management .servicebox .spscroll {
    max-width: 90vw;
  }
}
#management #happysupportcontent .flex.c5 {
  display: flex;
}
#management #happysupportcontent .flex.c5 > * {
  width: calc((70% - 8rem) / 4);
}
#management #happysupportcontent .flex.c5 > *.textbox {
  width: 30%;
}
#management #happysupportcontent .flex.c5 > *:not(.textbox) {
  padding: 1em;
  background: rgba(235, 82, 153, 0.77);
}
@media screen and (max-width: 768px) {
  #management #happysupportcontent .flex.c5 {
    flex-wrap: wrap;
  }
  #management #happysupportcontent .flex.c5 > * {
    width: calc((100% - 1rem) / 2);
    margin-bottom: 1rem;
  }
  #management #happysupportcontent .flex.c5 > *.textbox {
    width: 100%;
  }
}
#management #callcentercontent .initBox {
  border-top: 1px dashed #006bab;
  padding-top: 2rem;
}
#management #hapisupocontent .eyecatch {
  background: #fff3d0;
  border: 2px solid #008ad1;
  color: #008ad1;
  padding: 1em;
  border-radius: 1em;
}

#ailife .rightImage {
  max-width: 195px;
  margin: 0 0 2rem 2rem;
}
@media screen and (max-width: 768px) {
  #ailife .rightImage {
    max-width: none;
    text-align: center;
    margin-left: 0;
  }
  #ailife .rightImage img {
    max-width: 125px;
    margin: 0 auto;
  }
}
#ailife .flex.c3 dl dt {
  color: #003f75;
  border: 3px solid #003f75;
  text-align: center;
  padding: 0.25em;
  margin-bottom: 0.5rem;
  font-size: 1.6rem;
}
#ailife .flex.c3 dl:not(:last-child) {
  position: relative;
}
#ailife .flex.c3 dl:not(:last-child)::after {
  content: "";
  width: 0;
  height: 0;
  border: 5rem solid transparent;
  border-right-width: 2rem;
  border-left-width: 2rem;
  border-left-color: #003f75;
  position: absolute;
  top: 50%;
  right: calc(-6rem - 5%);
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  #ailife .flex.c3 dl:not(:last-child) {
    margin-bottom: 4rem;
  }
  #ailife .flex.c3 dl:not(:last-child)::after {
    border: 5rem solid transparent;
    border-top-width: 2rem;
    border-bottom-width: 2rem;
    border-top-color: #003f75;
    top: auto;
    right: auto;
    bottom: -5rem;
    left: 50%;
    transform: translateX(-50%);
  }
}

#flow dl {
  margin-bottom: 2em;
}
#flow dl dt {
  font-weight: 600;
  font-size: 2.4rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.3);
  margin-bottom: 1em;
}
#flow dl dt::before {
  content: "【";
}
#flow dl dt::after {
  content: "】";
}

#modalconversion .modal-content {
  padding: 2rem 4rem;
  /*
  &::before {
  	content: '';
  	display: block;
  	width: 0;
  	height: calc(100% - (2rem * 2));
  	border-left: 1px dotted black(0.3);
  	position: absolute;
  	top: 2rem;
  	left: 50%;
  }
  */
}
#modalconversion .modal-content h3 {
  font-size: 3rem;
  line-height: 1.25;
  margin-bottom: 0.5em;
  font-weight: normal;
}
#modalconversion .modal-content h3 span:not(.pc.tb) {
  font-size: 2.6rem;
}
#modalconversion .modal-content h3 span:not(.pc.tb)::before {
  content: "「";
}
#modalconversion .modal-content h3 span:not(.pc.tb)::after {
  content: "」";
}
@media screen and (max-width: 768px) {
  #modalconversion .modal-content h3 span:not(.pc.tb) {
    position: relative;
    display: inline-block;
    padding: 0 1em;
  }
  #modalconversion .modal-content h3 span:not(.pc.tb)::before, #modalconversion .modal-content h3 span:not(.pc.tb)::after {
    position: absolute;
  }
  #modalconversion .modal-content h3 span:not(.pc.tb)::before {
    top: 0;
    left: -0.5em;
  }
  #modalconversion .modal-content h3 span:not(.pc.tb)::after {
    right: -0.5em;
    bottom: 0;
  }
}
#modalconversion .modal-content .btn {
  margin: 1em auto 0;
}
@media screen and (max-width: 768px) {
  #modalconversion .modal-content p {
    text-align: left;
  }
}
@media screen and (max-width: 768px) {
  #modalconversion .modal-content {
    padding: 2rem;
    max-height: 80vh;
    overflow-y: scroll;
  }
  #modalconversion .modal-content::before {
    content: none;
  }
}
#modalconversion .modal-content > .mbL {
  padding-bottom: 2rem;
  border-bottom: 1px dotted black;
  margin-bottom: 2rem;
}
#modalconversion .modal-content .flex.c2 h3 {
  font-size: 3rem;
  line-height: 1.25;
  margin-bottom: 0.5em;
  font-weight: normal;
}
#modalconversion .modal-content .flex.c2 p {
  text-align: left;
}
#modalconversion .modal-content .flex.c2 .btn {
  width: 80%;
  margin: 2rem auto 0;
}
#modalconversion .modal-content .flex.c2 .btn a {
  padding-top: 0.5em;
}
#modalconversion .modal-content .flex.c2 .leftbox {
  display: flex;
  flex-direction: column;
  padding: 3rem 0 1.8rem;
}
#modalconversion .modal-content .flex.c2 .leftbox .btn.conversion {
  margin-top: auto;
}
#modalconversion .modal-content .flex.c2 .rightbox .requestbox {
  height: 60%;
  border-bottom: 1px dotted rgba(0, 0, 0, 0.3);
}
#modalconversion .modal-content .flex.c2 .requestbox,
#modalconversion .modal-content .flex.c2 .clubthehousebox {
  display: flex;
  align-items: center;
  padding: 3rem 0;
}
@media screen and (max-width: 768px) {
  #modalconversion .modal-content .flex.c2 {
    flex-wrap: wrap;
  }
  #modalconversion .modal-content .flex.c2 .leftbox {
    width: 100%;
    margin: 0 0 1rem;
  }
  #modalconversion .modal-content .flex.c2 .leftbox .btn.conversion {
    margin-top: 2rem;
  }
  #modalconversion .modal-content .flex.c2 .rightbox {
    width: 100%;
  }
  #modalconversion .modal-content .flex.c2 .rightbox .requestbox,
  #modalconversion .modal-content .flex.c2 .rightbox .clubthehousebox {
    padding: 0 0 3rem;
    border-bottom: none;
  }
}

@keyframes linedown {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}/*# sourceMappingURL=common.css.map */