@charset "utf-8";
/* top_mainvisual ========*/
#top_mainvisual {
  position: relative;
}
#top_mainvisual img {
  width: 100%;
}
#top_mainvisual h2.mainvisual_txt {
  color: #ffffff;
  font-size: clamp(16px, 5.6vw, 50px);
  letter-spacing: 0.2em;
  line-height: 1.4;
  text-align: center;
  text-shadow: 0 0 10px rgba(0, 0, 0, 1), 0 0 10px rgba(0, 0, 0, 1);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  inset-block-start: calc(6vh + 110px);
  transition: opacity 0.1s ease-out;
}
#top_mainvisual h2.mainvisual_txt small {
  display: block;
}
#top_mainvisual .cap {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 1;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  font-size: 11px;
  padding: 3px;
}
.layer_01 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.layer_01 .copy {
  position: absolute;
  top: 50%;
  left: 5vw;
  transform: translateY(-50%);
  width: 36vw;
}
@media screen and (max-width: 960px) {
  #top_mainvisual {
    margin-top: 60px;
  }
}
@media screen and (max-width: 640px) {
  #top_mainvisual h2.mainvisual_txt {
    letter-spacing: 0.1em;
    margin-block-start: 24%;
    inset-block-start: 0;
  }
  .layer_01 .copy {
    top: 6%;
    left: 50%;
    transform: translateX(-50%);
    width: 80vw;
  }
}
/* top_price ========*/
.top_price {
  position: relative;
  background: #fff url("../../../img/pages/top2/action_contents_back.png")no-repeat top center;
  background-size: cover;
  padding: 30px 0;
  text-align: center;
  z-index: 0;
}
.top_price a {
  transition: .4s
}
.top_price a:hover {
  opacity: 0.7;
}
.top_price ul li {
  display: inline-block;
  padding: 0 .3%;
  vertical-align: middle;
}
.top_price ul li:nth-child(4) {
  margin: 0 -16px 0 -14px;
}
.top_price ul li:nth-child(4)::before {
  content: "";
  height: 1px;
  width: 40px;
  background-color: #505050;
  transform: rotate(-70deg);
  display: block;
}
.top_price p {
  font-size: clamp(22px, 2vw, 24px);
  color: #505050;
  letter-spacing: 0.04em;
}
.top_price p.mt-10 {
  margin-top: -10px;
  margin-top: -21px;
}
.top_price b {
  display: inline-block;
  font-size: clamp(36px, 4vw, 48px);
  line-height: 1.2;
  background: linear-gradient(0deg, rgba(115, 97, 59, 1) 0%, rgba(159, 142, 106, 1) 50%, rgba(115, 97, 59, 1) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.top_price b.f-big {
  font-size: clamp(40px, 5vw, 70px);
}
.top_price p b {
  display: inline-block;
  font-size: clamp(32px, 4vw, 40px);
  line-height: 1.2;
  background: none;
  -webkit-background-clip: inherit;
  -webkit-text-fill-color: #505050;
}
.top_price p b.f-big {
  font-size: clamp(40px, 5vw, 40px);
  background: linear-gradient(0deg, rgba(115, 97, 59, 1) 0%, rgba(159, 142, 106, 1) 50%, rgba(115, 97, 59, 1) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.top_price p small {
  font-size: clamp(10px, 5vw, 16px);
}
.top_price .box {
  font-size: clamp(13px, 1.3vw, 17px);
  border: 1px solid #505050;
  padding: 3px 15px;
  line-height: 1.2;
}
.top_price .top_price_caps {
  font-size: 12px;
  margin-top: 5px;
}
.top_price .pc_only_inline {
  display: inline;
}
.top_price p a {
  display: inline-block;
  background: #907C56;
  color: #fff;
  font-size: clamp(10px, 1.4vw, 16px);
  letter-spacing: 0.1em;
  text-align: center;
  padding: 2px 30px 3px;
  transition: .3s;
  transform: translateY(-5px);
}
.top_price p a:hover {
  filter: brightness(1.2);
  opacity: 1;
}
@media screen and (max-width: 640px) {
  /*.top_price::before {
		content: "";
    position: absolute;
    bottom: 10px;
    right: 15px;
    width: 40px;
    height: 1px;
    background-color: #000;
    z-index: 99;
	}
	.top_price::after {
		content: "";
    position: absolute;
    bottom: 10px;
    right: 15px;
    transform-origin: right bottom;
    width: 10px;
    height: 1px;
    background-color: #000;
    transform: rotate(45deg);
    z-index: 99;
	}*/
  .top_price ul {
    line-height: 1.2;
  }
  .top_price ul li:nth-child(4) {
    width: 100%;
  }
  .top_price ul li:nth-child(4)::before {
    display: none;
  }
  .top_price p {
    font-size: clamp(18px, 2vw, 24px);
  }
  .top_price b {
    display: inline-block;
    font-size: clamp(24px, 4vw, 48px);
  }
  .top_price b.f-big {
    font-size: clamp(36px, 4vw, 60px);
  }
  .top_price p b {
    font-size: clamp(26px, 4vw, 40px);
  }
  .top_price p b.f-big {
    font-size: clamp(30px, 5vw, 40px);
  }
  .top_price p small {
    font-size: clamp(10px, 2.4vw, 16px);
  }
  .top_price .box {
    font-size: clamp(10px, 1.3vw, 17px);
    border: 1px solid #505050;
    padding: 3px 8px;
    line-height: 1.2;
  }
  .top_price .top_price_caps {
    font-size: 11px;
    margin-top: 15px;
  }
  .top_price .pc_only_inline {
    display: none;
  }
}
/* meritBox ========*/
.meritBox {}
.merit_flex {
  display: flex;
  flex-wrap: wrap;
}
.merit_flex li {
  position: relative;
  width: calc(100% / 4);
  padding: 35px 15px;
  z-index: 0;
}
.merit_flex li a {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 10;
}
.merit_flex li:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: -1;
}
.merit_flex li.merit01 {
  background: #fff url("../../../img/pages/top2/meritbox_img01.jpg")no-repeat top center;
  background-size: cover;
}
.merit_flex li.merit02 {
  background: #fff url("../../../img/pages/top2/meritbox_img02.jpg")no-repeat top center;
  background-size: cover;
}
.merit_flex li.merit03 {
  background: #fff url("../../../img/pages/top2/meritbox_img03.jpg")no-repeat top center;
  background-size: cover;
}
.merit_flex li.merit04 {
  background: #fff url("../../../img/pages/top2/meritbox_img04.jpg")no-repeat top center;
  background-size: cover;
}
.merit_flex li .textArea {
  transition: .4s
}
.merit_flex li:hover .textArea {
  opacity: 0.7
}
.merit_flex li .textArea span {
  color: #D7BE8C;
}
.merit_flex li .textArea b {
  font-size: 40px;
  line-height: 1;
  display: inline-block;
}
.merit_flex li .textArea .txt01 {
  font-size: clamp(25px, 1.4vw, 25px);
  color: #fff;
  letter-spacing: 0.04em;
  line-height: 1.4;
  text-align: center;
}
.merit_flex li .textArea .txt02 {
  font-size: 12px;
  color: #fff;
  letter-spacing: 0.04em;
  line-height: 1.4;
  text-align: center;
}
.merit_flex li .textArea .txt03 {
  font-size: 30px;
  color: #fff;
  letter-spacing: 0.2em;
  line-height: 1.4;
  text-align: center;
}
.merit_flex li .textArea .merit01_b {
  font-size: 80px;
}
.merit_flex li .textArea .merit04_txt {
  font-size: clamp(25px, 1.4vw, 25px);
  color: #fff;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 960px) {
  .merit_flex li {
    width: 100%;
  }
}
@media screen and (max-width: 640px) {
  .merit_flex li a::before {
    content: "";
    position: absolute;
    bottom: 25px;
    right: 15px;
    width: 40px;
    height: 1px;
    background-color: #fff;
    z-index: 99;
  }
  .merit_flex li a::after {
    content: "";
    position: absolute;
    bottom: 25px;
    right: 15px;
    transform-origin: right bottom;
    width: 10px;
    height: 1px;
    background-color: #fff;
    transform: rotate(45deg);
    z-index: 99;
  }
}
/* top_cvArea ========*/
.top_cvArea {}
.top_cvAreaBtn {
  max-width: 500px;
  margin: 30px auto 0;
}
.top_cvAreaBtn a {
  display: block;
  color: #fff;
  font-size: clamp(18px, 2vw, 20px);
  padding: 10px;
  transition: .3s;
}
.top_cvAreaBtn a.gold {
  background: rgb(255, 255, 255);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(144, 124, 86, 1) 20%, rgba(144, 124, 86, 1) 80%, rgba(255, 255, 255, 0) 100%);
}
@media(hover: hover) {
  .top_cvAreaBtn a:hover {
    filter: brightness(1.2);
  }
}
/* action_contents ========*/
.action_contents {
  position: relative;
  background: #fff url("../../../img/pages/top2/action_contents_back.png")no-repeat top center;
  background-size: cover;
  /*padding: 50px 0;*/
  padding: 0 0 50px;
}
.action_contents_item01 {
  border-top: 2px solid #907C56;
  border-bottom: 2px solid #907C56;
  padding: 30px 0;
  text-align: center;
}
.actionTitle {
  font-size: clamp(20px, 4vw, 45px);
  line-height: 1.4;
  color: #505050;
}
.actionTitle small {
  display: block;
}
.actionMiddleTitle {
  font-size: clamp(28px, 4vw, 50px);
  line-height: 1.4;
  color: #505050;
}
.actionMiddleTitle.bgGold {
  font-size: clamp(18px, 4vw, 36px);
  color: #fff;
  padding: 0.1em 0 0.2em;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(144, 124, 86, 1) 20%, rgba(144, 124, 86, 1) 80%, rgba(255, 255, 255, 0) 100%);
  width: 100%;
}
.actionMiddleTitle + p {
  font-size: clamp(20px, 2.6vw, 36px);
  line-height: 1.4;
  color: #505050;
  margin-top: 15px;
}
.actionMiddleTitle + p.fs16 {
  font-size: clamp(14px, 2vw, 16px);
}
.actionMiddleTitle + p span {
  font-size: clamp(22px, 3vw, 40px);
  background: linear-gradient(0deg, rgba(115, 97, 59, 1) 0%, rgba(159, 142, 106, 1) 50%, rgba(115, 97, 59, 1) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
/* onlineReserve ========*/
.onlineReserve {
  position: relative;
  background: linear-gradient(rgba(80, 80, 80, 0.8), rgba(80, 80, 80, 0.8)), url("../../../img/pages/top2/onlinereserve_back.jpg")no-repeat center;
  background-size: cover;
  padding: 60px 0 70px;
  text-align: center;
  z-index: 0;
}
.onlineReserveTitle {
  font-size: 40px;
  font-size: clamp(25px, 3vw, 40px);
  line-height: 1.4;
  color: #fff;
}
@media screen and (max-width: 640px) {
  .onlineReserve {
    padding: 40px 0;
  }
}
/* quietTopic ========*/
.quietTopic {
  position: relative;
  background: #505050;
  height: 300px;
}
.quietTopic:before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 100px;
  background: #fff;
}
@media screen and (max-width: 960px) {
  .quietTopic {
    height: 150px;
  }
  .quietTopic:before {
    height: 50px;
  }
}
/* top_contentsList ========*/
.top_contentsList {}
.top_contentsList_box01 {
  background: linear-gradient(180deg, rgba(71, 117, 136, 1) 0%, rgba(168, 196, 208, 1) 100%);
}
.top_contentsList_box02 {
  background: linear-gradient(180deg, rgba(128, 128, 128, 1) 0%, rgba(195, 195, 195, 1) 100%);
}
.top_contentsList_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 40px 70px;
}
.top_contentsList_flex .flex_item {
  position: relative;
}
.top_contentsList_flex .textArea {
  width: 40%;
}
.top_contentsList_flex .textArea h3 {
  position: absolute;
  width: 100vw;
  top: 30px;
  color: #fff;
  font-size: clamp(15px, 8vw, 165px);
  font-weight: 300;
  line-height: 1;
  letter-spacing: 0.12em;
  z-index: 2;
}
.top_contentsList_flex .textArea h3 span {
  display: block;
  font-size: clamp(12px, 2.8vw, 40px);
  line-height: 1.4;
  letter-spacing: 0.09em;
  margin-top: 5px;
}
.top_contentsList_flex .photoArea {
  width: 60%;
  position: relative;
  margin-left: auto;
}
.top_contentsList_flex .photoArea figure img {
  opacity: 0.7;
}
.top_contentsList_flex .viewmore {
  position: absolute;
  bottom: 0;
}
.top_contentsList_flex .viewmore a {
  display: block;
  background: #907C56;
  color: #fff;
  font-size: clamp(10px, 1.4vw, 18px);
  letter-spacing: 0.1em;
  text-align: center;
  padding: 2px 30px;
  transition: .3s;
}
/* reverse */
.top_contentsList_flex.reverse {
  flex-direction: row-reverse;
}
.top_contentsList_flex.reverse .flex_item h3 {
  text-align: right;
  right: 0;
}
.top_contentsList_flex.reverse .photoArea {
  margin-left: inherit;
  margin-right: auto;
}
.top_contentsList_flex.reverse .viewmore {
  right: 0;
}
@media(hover: hover) {
  .top_contentsList .viewmore a:hover {
    filter: brightness(1.2);
  }
}
/* 動き */
.top_contentsList_flex .photoArea .target {
  opacity: 0;
  clip-path: inset(0 50% 0 0);
  transition: opacity 1.5s ease 0s, clip-path 1.5s ease 0s, transform 2.5s ease 0s;
}
.top_contentsList_flex .photoArea .target.is-view {
  opacity: 1;
  clip-path: inset(0 0 0 0);
}
@media screen and (max-width: 640px) {
  .top_contentsList_flex {
    padding: 0;
  }
  .top_contentsList_flex .textArea {
    width: 45%;
    padding-left: 10px;
    margin-bottom: 10px;
  }
  .top_contentsList_flex .textArea h3 {
    top: 10px;
  }
  .top_contentsList_flex .photoArea {
    width: 55%;
  }
  /* reverse */
  .top_contentsList_flex.reverse .textArea {
    padding-left: 0;
  }
  .top_contentsList_flex.reverse .flex_item h3 {
    right: 10px;
  }
  .top_contentsList_flex.reverse .viewmore {
    right: 10px;
  }
}
/* privateResidence ========*/
.privateResidence {
  position: relative;
  background: #505050;
  padding-top: 400px;
}
.privateResidence_copy {
  position: absolute;
  top: 15px;
  left: 0;
  width: 11.8vw;
  height: 100%;
  z-index: 2;
}
.privateResidence_photo img {
  width: 100%;
}
.privateResidence_concept {
  position: relative;
  background: rgb(80, 80, 80);
  background: linear-gradient(180deg, rgba(80, 80, 80, 1) 0%, rgba(20, 20, 20, 1) 100%);
  padding: 170px 20px;
  text-align: center;
  z-index: 0;
}
.privateResidence_concept:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url("../../../img/pages/top2/privateresidence_img_back.png")no-repeat top center;
  background-size: cover;
  mix-blend-mode: multiply;
  z-index: -1;
}
.privateResidence_concept h3 {
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.4;
  color: #fff;
}
.privateResidence_concept p {
  font-size: clamp(14px, 2vw, 20px);
  line-height: 2.5;
  color: #fff;
  padding-top: 30px;
}
@media screen and (max-width: 960px) {
  .privateResidence {
    padding-top: 175px;
  }
}
@media screen and (max-width: 640px) {
  .privateResidence_copy {
    width: 15vw;
  }
  .privateResidence_concept {
    padding: 70px 20px;
  }
}
/* top_contentsList_txtNav ========*/
.top_contentsList_txtNav {
  position: relative;
  background: #505050;
  padding-top: 180px;
  padding-bottom: 90px;
}
.top_contentsList_txtNav .flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.content_all_link {
  width: 48%;
}
.content_all_link li {
  border-bottom: 1px solid #fff;
}
.content_all_link li:first-child {
  border-top: 1px solid #fff;
}
.content_all_link li a {
  color: #fff;
  font-size: clamp(12px, 1.3vw, 14px);
  display: block;
  padding: 22px 40px;
  position: relative;
}
.content_all_link li a span {
  display: block;
  position: relative;
  z-index: 2;
}
.content_all_link li a b {
  font-size: clamp(20px, 2vw, 24px);
  padding-right: 20px;
}
.content_all_link li a::before {
  content: "";
  width: 0;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: linear-gradient(rgba(144, 124, 86, 1) 0, rgba(144, 124, 86, 1) 100%);
  transition: 0.3s ease;
}
.content_all_link li a::after {
  content: "";
  display: block;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid #fff;
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%);
  transition: 0.3s ease;
}
.content_all_link li a span::before {
  content: "";
  display: block;
  width: 26px;
  height: 1px;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%);
  transition: 0.3s ease;
}
.content_all_link li a span::after {
  content: "";
  display: block;
  width: 8px;
  height: 1px;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translateY(-50%) rotate(30deg);
  transform-origin: right;
  transition: 0.3s ease;
}
.content_all_link li a:hover:before {
  width: 100%;
}
.content_all_link li.link_none a {
  pointer-events: none;
  color: #888;
}
.content_all_link li.link_none a::after {
  content: "Coming Soon";
  width: auto;
  height: auto;
  border: none;
}
.content_all_link li.link_none a span::before, .content_all_link li.link_none a span::after {
  display: none;
}
@media screen and (max-width: 960px) {
  .top_contentsList_txtNav {
    padding-top: 60px;
    padding-bottom: 45px;
  }
  .content_all_link {
    width: 100%;
  }
  .content_all_link + .content_all_link li:first-child {
    border-top: none;
  }
  .content_all_link li a {
    padding: 15px 15px 15px 0;
  }
  .content_all_link li a::after {
    width: 32px;
    height: 32px;
    right: 15px;
  }
  .content_all_link li a span::before {
    width: 16px;
  }
}
/* pageBottom_cvArea ========*/
.pageBottom_cvArea {
  position: relative;
  background: #505050;
  padding-top: 60px;
  padding-bottom: 180px;
}
.cvBtn_flex {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.cvBtn_flex .flex_item {
  width: 48%;
  margin: 30px 1% 0;
  background: #000;
  padding: 15px;
}
.cvBtn_flex .flex_item a {
  border: 1px solid #907C56;
  color: #fff;
  text-align: center;
  height: 320px;
  display: flex;
  align-items: center;
  transition: .3s;
}
.cvBtn_flex .flex_item a .innerBox {
  width: 100%;
}
.cvBtn_flex .flex_item a .innerBox h3 {
  font-size: clamp(25px, 3vw, 40px);
  line-height: 1.2;
}
.cvBtn_flex .flex_item a .innerBox .btn {
  max-width: 400px;
  margin: 30px auto 0;
  background: rgb(255, 255, 255);
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(144, 124, 86, 1) 20%, rgba(144, 124, 86, 1) 80%, rgba(255, 255, 255, 0) 100%);
  font-size: clamp(18px, 2vw, 20px);
  padding: 10px;
}
@media(hover: hover) {
  .cvBtn_flex .flex_item a:hover {
    filter: brightness(1.2);
  }
}
@media screen and (max-width: 960px) {
  .pageBottom_cvArea {
    padding-top: 30px;
    padding-bottom: 90px;
  }
  .cvBtn_flex .flex_item {
    width: 100%;
  }
  .cvBtn_flex .flex_item a {
    height: auto;
    padding: 30px 15px;
  }
}
/* top_movie ========*/
.top_movie .inner {
  max-width: 680px;
  background: #ddd;
  padding: 20px;
}
.top_movie .top_movie_wrap {
  position: relative;
  aspect-ratio: 16 / 9;
}
.top_movie iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100% !important;
  height: 100% !important;
}
@media screen and (max-width: 640px) {}
/* 2024.10.16 */
.action_contents_item01 ul {
  max-width: 1000px;
  /*max-width: 1400px;*/
  width: 100%;
  gap: calc(20 / 1000 * 100%);
  /*gap: calc(20 / 1400 * 100%);*/
  justify-content: center;
  margin: 30px auto 50px;
}
.action_contents_item01 ul li {
  width: calc(320 / 1000 * 100%);
  /*width: calc(335 / 1400 * 100%);*/
  margin-left: 0 !important;
  text-indent: 0 !important;
  line-height: 1 !important;
}
.action_contents_item01 ul li.full {
  width: 100%;
  margin-top: calc(20 / 1000 * 100%);
}
.action_contents_item01 ul li a {
  display: block;
  position: relative;
  z-index: 1;
  transition: 0.4s;
}
.action_contents_item01 ul li a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 640px) {
  .action_contents_item01 ul {
    margin-bottom: 0;
  }
  .action_contents_item01 ul li.commonCvWrap ul li:nth-of-type(1) {
    width: 100%;
    padding-top: calc(30 / 320 * 100%);
    margin-bottom: calc(30 / 320 * 100%);
  }
  .action_contents_item01 ul li {
    position: relative;
    width: 100%;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .action_contents_item01 ul li:nth-of-type(n+3), .action_contents_item01 ul li.full {
    margin-top: calc(17 / 320 * 100%);
  }
}
.mv-wrap {
  position: relative;
}
.mv-wrap .scene01 {
  opacity: 0;
  filter: blur(5px);
  animation-delay: 1s;
  animation-duration: 2s;
  animation-name: scene01;
  animation-fill-mode: forwards;
}
.mv-wrap .scene02 {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  animation-delay: 5.5s;
  animation-duration: 2s;
  animation-name: scene02;
  animation-fill-mode: forwards;
}
.mv-wrap .scene03 {
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  animation-delay: 6.5s;
  animation-duration: 1.5s;
  animation-name: scene02;
  animation-fill-mode: forwards;
}
.mv-wrap .mv_caption01 {
  top: 0;
  bottom: auto;
  text-align: right;
  text-shadow: 0 0 10px #000000, 0 0 10px #000000;
  background: none;
}
.mv-wrap .mv_caption02 {
  bottom: 16%;
  left: 0;
  right: auto;
  text-shadow: 0 0 10px #000000, 0 0 10px #000000;
  background: none;
}
.mv-wrap .mv_caption03 {
  right: 53%;
  text-shadow: 0 0 10px #000000, 0 0 10px #000000;
  background: none;
}
@media screen and (max-width: 640px) {
  .mv-wrap .scene02 {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    animation-delay: 4.5s;
    animation-duration: 1.5s;
    animation-name: scene02;
    animation-fill-mode: forwards;
  }
  .mv-wrap .scene03 {
    position: absolute;
    left: 0;
    top: 0;
    opacity: 0;
    animation-delay: 12.5s;
    animation-duration: 1.5s;
    animation-name: scene02;
    animation-fill-mode: forwards;
  }
}
@keyframes scene01 {
  0% {
    opacity: 0;
    filter: blur(5px);
  }
  100% {
    opacity: 1;
    filter: blur(0);
  }
}
@keyframes scene02 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.top_price .maintenance {
  font-size: 12px;
  margin-bottom: 40px;
  padding: 0 10px;
}
.top_price .maintenance strong {
  font-size: 14px;
  font-weight: 600;
}
.top_price .maintenance span {
  width: 582px;
  display: inline-block;
  border: 1px solid;
  padding: 1em 2em;
}
.top_price .maintenance dl {
  display: flex;
  justify-content: center;
  gap: 1em;
}
.top_price .maintenance dl dd {
  text-align: left;
}
@media screen and (max-width: 640px) {
  .top_price .maintenance span {
    width: 100%;
  }
  .top_price p.maintenance {
    font-size: 11px;
    margin-bottom: 30px;
    letter-spacing: 0;
  }
  .top_price p.maintenance strong {
    font-size: 13px;
  }
  .top_price p.maintenance span {
    padding: 1em;
  }
  .top_price p.maintenance span .sp_only {
    display: inline-block
  }
  .top_price .maintenance dl {
    display: block;
  }
}
/*TOPリニューアル*/
/*共用*/
.top_r {
  p, dl, h2, h3, h4, h5, figure {
    margin: 0;
  }
  a {
    text-decoration: none;
  }
  ul {
    list-style: none;
  }
  font-family: "Shippori Mincho", serif;
}
img {
  width: 100%;
  max-width: 100%;
}
.header-property-logo-title img {
  max-width: none;
}
.jp {
  font-family: "Shippori Mincho", serif;
}
.en {
  font-family: "Inter", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
}
.en02 {
  font-family: "Cormorant Infant", serif;
  font-optical-sizing: auto;
  font-style: normal;
}
/* メインビジュアル */
.l-mv {
  position: relative;
  z-index: 0;
  overflow: hidden;
  background-image: url("../../../img/pages/top2/re/bi_mv.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  aspect-ratio: 1920 / 856;
  height: auto;
  &.is-active {
    .inner02 {
      .box_img02 {
        img {
					opacity: 1;
          /*transform: translateY(-29.8%);*/
        }
      }
    }
  }
  @media screen and (min-width: 1920px) {
    aspect-ratio: unset;
    height: 856px;
    .inner02 {
      font-size: 10px;
      .mv_text {
        h2 {
          font-size: 50px;
        }
      }
      .box_img02 {
        height: 856px;
      }
    }
  }
  .inner02 {
    mix-blend-mode: screen;
    position: relative;
    z-index: 0;
    margin: 0 auto;
    width: 1452px;
    max-width: 75.625%;
    display: flex;
    font-size: calc(10 / 1920 * 100vw);
    &.adjust_img {
      mix-blend-mode: normal;
      position: absolute;
      z-index: 1;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
      justify-content: flex-end
    }
    .mv_text {
      width: 56.61%;
      height: 100%;
      padding: 5.8em 0 7.5em;
      display: flex;
      flex-flow: column;
      .box_img01 {
        figcaption {
          background: unset;
          right: 15%;
        }
      }
      h2 {
        margin: 0 auto;
        width: fit-content;
        font-size: calc(50 / 1920 * 100vw);
        text-align: center;
        color: rgb(201, 185, 147);
        background: linear-gradient(315deg, #c2a17f 20%, #d6c0a9 30%, #e6d9cb 40%, #ede3d9 50%, #e4d5c6 30%, #cdb296 80%, #c2a17f 100%);
        background-clip: border-box;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        box-decoration-break: clone;
        -webkit-box-decoration-break: clone;
        filter: drop-shadow(0 0 10px rgba(255, 242, 164, 0.5)) drop-shadow(0 0 30px rgba(255, 242, 164, 0.1));
      }
    }
    .box_img02 {
      isolation: isolate;
      overflow: hidden;
      height: 44.58vw;
      width: 43.39%;
      display: flex;
      flex-flow: column;
      align-self: stretch;
      img {
        /*transform: translateY(100%);*/
				transform: translateY(-29.8%);
				opacity: 0;
        transition: 4s ease-in-out;
      }
      figcaption {
        background: unset;
				bottom: 5px;
      }
    }
  }
  @media screen and (max-width: 1200px) {
    .inner02 {
      .mv_text {
        padding: 12.8em 0 2.5em;
      }
    }
  }
  @media screen and (max-width: 640px) {
    background-image: url("../../../img/pages/top2/re/bi_mv_sp.png");
    aspect-ratio: unset;
    display: flex;
    flex-flow: column-reverse;
    .inner02 {
      /*height: 148.68vw;*/
			height: auto;
      mix-blend-mode: screen;
      max-width: 100%;
      display: block;
      font-size: calc(10 / 380 * 100vw);
      &.adjust_img {
        pointer-events: none;
				img {
					transform: translateY(0);
				}
      }
      .mv_text {
        width: 100%;
        height: auto;
        padding: 3em 0 0;
        display: flex;
        flex-flow: column-reverse;
        .box_img01 {
          opacity: 0;
          figcaption {
            background: unset;
            right: 0;
          }
        }
        h2 {
          opacity: 0;
          font-size: 2.8em;
          line-height: 1.3;
        }
      }
      .box_img02 {
        /*height: 148.68vw;*/
				height: auto;
        width: 100%;
        display: flex;
        flex-flow: column;
      }
    }
    &.is-active {
      .inner02 {
        &.adjust_img {
					position: relative;
					padding-top: 9rem;
          /*transition: opacity 1s 4s;
          opacity: 0;*/
          img {
            /*transition-delay: transform 0;
            transform: translateY(-23%);*/
            /*transform: translateY(0);*/
          }
        }
        h2, .box_img01 {
          /*transition: opacity 1s 4s;*/
          opacity: 1;
        }
      }
    }
  }
}
/* メリット */
.l-merit {
  font-size: calc(10 / 1920 * 100vw);
  @media screen and (min-width: 1920px) {
    font-size: 10px;
  }
  padding: 6rem 0;
  background: #333;
  color: #fff;
  .inner02 {
    margin: 0 auto;
    max-width: 1680px;
    display: flex;
    justify-content: center;
    /*  align-items: center;*/
    list-style: none;
    li {
      padding: 0 4.5em;
      line-height: 1;
      letter-spacing: 0;
      border-right: 1px solid #666;
		
      &:last-of-type {
        border-right: none;
      }
      .wrapper02 {
        display: flex;
        flex-flow: column;
        justify-content: center;
		  height: 100%;
      }
      .size_xs {
        margin-top: .76em;
        font-size: 1.2em;
        text-align: right;
      }
      .size_s {
        font-size: 1.7em;
        margin-bottom: -.42em;
      }
      .size_m {
        margin-bottom: .68em;
      }
      /*.size_m02 {
        font-size: 2.2em;
      }*/
      .size_m02 {
        font-size: 2.5em;
      }
      .size_l {
        font-size: 3.4em;
      }
      .size_l02 {
        font-size: 4.0em;
      }
      .size_xl {
        font-size: 5.0em;
      }
      .dec_weight {
        font-weight: bold
      }
      .dec_ls {
        letter-spacing: 0
      }
      .dec_grad_s {
        display: inline-block;
        background: linear-gradient(315deg, #ffffff 10%, #fefefe 10%, #f2f2f2 27%, gray 43%, #ffffff 50%, #ececec 51%, #bcbcbc 55%, gray 56%, #ffffff 73%, #f2f2f2 100%);
        background-clip: border-box;
        background-clip: border-box;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        box-decoration-break: clone;
        -webkit-box-decoration-break: clone;
      }
    }
    .merit01 {}
    .merit02 {}
    .merit03 {
      text-align: center;
      line-height: 1.3;
    }
    .merit04 {
      text-align: center;
      line-height: 1.3;
    }
  }
  @media screen and (max-width:960px) {
    font-size: 10px;
    padding: 3.3rem 0;
    .inner02 {
      max-width: calc(100% - 6em);
      flex-flow: column;
      li {
        padding: 3.6em 3em;
        line-height: 1;
        letter-spacing: 0;
        border-bottom: 1px solid #b3b3b3;
        border-right: 0;
        &:last-of-type {
          border-right: none;
        }
        .wrapper02 {
          margin: 0 auto;
          width: fit-content;
        }
        .size_xs {
          margin-top: .76em;
          font-size: 1.2em;
          text-align: right;
        }
        .size_s {
          font-size: 1.4em;
          margin-bottom: 0;
        }
        .size_m {
          margin-bottom: .68em;
        }
        .size_m02 {
          font-size: 1.7em;
        }
        .size_l {
          font-size: 2.8em;
        }
        .size_l02 {
          font-size: 3.2em;
        }
        .size_xl {
          font-size: 4.0em;
        }
        .dec_weight {
          font-weight: bold
        }
        .dec_ls {
          letter-spacing: 0
        }
      }
      .merit01 {
        padding: 3.2em 0em;
      }
      .merit02 {
        padding: 3.2em 0;
      }
      .merit03 {
        padding: 3.2em 0;
        .wrapper {
          text-align: center;
          line-height: 1.3;
        }
      }
      .merit04 {
        text-align: center;
        line-height: 1.3;
        padding: 3.2em 0;
      }
    }
  }
	@media screen and (max-width:768px) {

font-size:calc(10 / 380* 100vw);


}
}
/* インフォメーション */
.l-info {
  background-image: url("../../../img/pages/top2/re/bi_info.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding: 150px 0;
  .inner02 {
    h2 {
      /*position: absolute;*/
      top: -.7em;
      left: 0;
      font-size: 16px;
			margin-bottom: 1em;
    }
    position: relative;
    z-index: 0;
    margin:0 auto;
    max-width:980px;
    .box_info {
			.box_info_copy {
				font-size: 44px;
				text-align: center;
				border-bottom: 1px solid rgba(51,51,51,0.80);
				margin-bottom: 3rem;
				b {
					font-size: 1.5em;
					font-weight: 300;
					vertical-align: -3px;
					padding: 0 .1em;
				}
				span {
					font-size: 1.2em;
					vertical-align: -2px;
					padding: 0 0 0 .15em;
				}
			}
      .text_info {
        display: flex;
        gap: 105px;
        .ttl_sub {
          width: 437.5px;
          font-size: 24px;
        }
        .size_l {
          font-size: 50px;
        }
      }
      .box_btn {
        width: 437.5px;
        display: flex;
        flex-flow: column;
        gap: 20px;
        .btn00 {
          filter: drop-shadow(0px 10px 15px rgba(0, 0, 0, 0.4));
          background: linear-gradient(105deg, #7a5f2a 0%, #a8905e 45%, #6d5526 100%);
          width: 440px;
          height: 90px;
          display: flex;
          justify-content: center;
          align-items: center;
          color: #fff;
          font-size: 20px;
          letter-spacing: .15em;
          transition: .3s;
          .dec00 {
            position: relative;
            z-index: 0;
            &::after {
              content: "";
              display: block;
              position: absolute;
              z-index: 0;
              background-image: url("../../../img/pages/top2/re/icon_arrow.svg");
              background-repeat: no-repeat;
              background-size: cover;
              background-position: center center;
              top: 50%;
              right: -36px;
              transform: translate(0, -50%);
              width: 18px;
              aspect-ratio: 3 / 1;
            }
          }
          &:hover {
            opacity: .7;
          }
        }
      }
    }
  }
  @media screen and (max-width:1200px) {
    font-size: calc(10 / 1200 * 100vw);
    padding: 15em 0;
    .inner02 {
      h2 {
        font-size: 1.6em;
      }
      position: relative;
      z-index: 0;
      margin:0 auto;
      max-width:98em;
      .box_info {
        .text_info {
          display: flex;
          gap: 10.5em;
          .ttl_sub {
            width: 43.75em;
            font-size: 2.4em;
          }
          .size_l {
            font-size: 2em;
          }
        }
        .box_btn {
          width: 43.75em;
          gap: 2em;
          .btn00 {
            width: 22em;
            height: 4.5em;
            font-size: 2em;
            .dec00 {
              &::after {
                right: -1.8em;
                width: 0.9em;
              }
            }
          }
        }
      }
    }
  }
  @media screen and (max-width:960px) {
    font-size: 10px;
    padding: 5em 0 6em;
    .inner02 {
      h2 {
        position: static;
        font-size: 1.6em;
        text-align: center;
        /*margin-bottom: 4em;*/
      }
      position: relative;
      z-index: 0;
      margin:0 auto;
      max-width:calc(100% - 60px);
      .box_info {
				.box_info_copy {
					font-size: 3em;
					margin-bottom: 2rem;
					b {
						vertical-align: -2px;
					}
				}
        .text_info {
          flex-flow: column;
          align-items: center;
          gap: 3.0em;
          .ttl_sub {
            width: fit-content;
            font-size: 2.0em;
          }
          .size_l {
            font-size: 1.7em;
          }
        }
        .box_btn {
          width: fit-content;
          gap: 2em;
          .btn00 {
            filter: drop-shadow(0px .6em 1.2em rgba(0, 0, 0, 0.3));
            width: 20em;
            height: 5.4em;
            font-size: 1.4em;
            .dec00 {
              &::after {
                right: -1.284em;
                width: .785em;
              }
            }
            &:hover {
              opacity: .7;
            }
          }
        }
      }
    }
  }
  @media screen and (max-width:640px) {
    font-size: calc(10 / 380 * 100vw) padding: 5em 0;
    .inner02 {
      h2 {
        position: static;
        font-size: 1.4em;
        text-align: center;
        margin-bottom: 1.5em;
      }
      position: relative;
      z-index: 0;
      margin:0 auto;
      max-width:calc(100% - 40px);
      .box_info {
				.box_info_copy {
					font-size: 2.4em;
					margin-bottom: 1.5rem;
				}
        .text_info {
          flex-flow: column;
          align-items: center;
          gap: 1.8em;
          .ttl_sub {
            width: fit-content;
            font-size: 2.0em;
          }
          .size_l {
            font-size: 1.4em;
          }
        }
        .box_btn {
          width: fit-content;
          gap: 2em;
          .btn00 {
            filter: drop-shadow(0px .6em 1.2em rgba(0, 0, 0, 0.3));
            width: 20em;
            height: 4.0em;
            font-size: 1.4em;
            .dec00 {
              &::after {
                right: -1.284em;
                width: .785em;
              }
            }
            &:hover {
              opacity: .7;
            }
          }
        }
      }
    }
  }
}
/* ピックアッププラン */
.l-pickplan {
  background-image: url("../../../img/pages/top2/re/bi_pickup.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  font-family: "Cormorant Infant", "Shippori Mincho", serif;
  font-optical-sizing: auto;
  font-style: normal;
  padding: 200px 0;
  .inner02 {
    margin: 0 auto;
    width: 1200px;
    max-width: calc(100% - 60px);
    h2 {
      margin: 0 auto 32px;
      width: fit-content;
      font-size: 70px;
      font-weight: normal;
      line-height: 1;
      color: rgb(201, 185, 147);
      background: linear-gradient(316deg, #c2a17f 20%, #d6c0a9 40%, #e6d9cb 45%, #ede3d9 50%, #e4d5c6 45%, #cdb296 80%, #c2a17f 100%);
      background-clip: border-box;
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      box-decoration-break: clone; /*iphoneで複数行でグラデの際必要*/
      -webkit-box-decoration-break: clone; /*iphoneで複数行でグラデの際必要*/
    }
    .list_pickup {
      display: flex;
      flex-flow: column;
      align-items: center;
      gap: 40px;
			li {
				position: relative;
			}
      .cap {
        display: block;
        font-size: 12px;
        letter-spacing: .0em;
        color:#fff;
        text-align: center;
      }
			.pickup_label {
				/*position: absolute;
				right: 0;
				top: 0;*/
				transform: translateY(-50%);
				z-index: 2;
				color: #FFF;
				font-size: 16px;
				letter-spacing: 0.05em;
				background: linear-gradient(105deg, #7a5f2a 0%, #a8905e 45%, #6d5526 100%);
				padding: .7em 1em 0.5em;
				margin-left: 30px;
				vertical-align: 7px;
			}
      .btn01 {
        position: relative;
        z-index: 1;
        /*background: url("../../../img/pages/top2/re/bi_pickup.svg");
        background-repeat: no-repeat;
        background-size: cover;
        background-position: center center;*/
        display: block;
        padding: 0 32px;
        margin: 0 auto;
        /*width: 650px;
        max-width: 90%;*/
        color: #FFF;
        font-size: 34px;
        text-align: center;
        transition: .3s;
				line-height: 1.4;
				border-bottom: 2px solid rgba(255,255,255,.6);
        .size_xl {
					color: #F6E5C9;
          font-size: 80px;
          /*margin-left: -.8em;*/
        }
        .size_l {
					color: #F6E5C9;
          font-size: 60px;
          /*margin-left: -.8em;*/
        }
        .size_m {
					color: #F6E5C9;
          font-size: 46px;
          /*margin-left: -.8em;*/
        }
        .size_s {
          font-size: 28px;
          /*margin-left: -.8em;*/
        }
       /* &:hover {
          opacity: .7;
          color: #ff9323;
        }*/
      }
			.btn01_list {
				display: flex;
				justify-content: center;
				gap: 0 10px;
				margin: 25px 0 0;
				span {
					color: #fff;
					font-size: 18px;
					font-weight: 500;
					border: 2px solid #fff;
					padding: .4em .8em .2em;
				}
			}
			.btn01_price {
				color: #fff;
				font-size: 30px;
				line-height: 1.6;
				display: block;
				text-align: center;
				margin-top: 20px;
        .size_xl {
					color: #F6E5C9;
          font-size: 80px;
					line-height: 1.2;
          /*margin-left: -.8em;*/
        }
        .size_s {
          font-size: 26px;
          /*margin-left: -.8em;*/
        }
			}
      .btn02 {
        display: flex;
        justify-content: center;
        align-items: center;
        width: 440px;
        height: 90px;
        background: rgba(255, 255, 255, .4);
        font-size: 21px;
        color: #fff;
        background-blend-mode: soft-light;
        filter: drop-shadow(0 10px 20px rgba(0, 0, 0, .4));
        transition: .3s;
        .dec00 {
          position: relative;
          z-index: 0;
          &::after {
            content: "";
            display: block;
            position: absolute;
            z-index: 0;
            background-image: url("../../../img/pages/top2/re/icon_arrow.svg");
            background-repeat: no-repeat;
            background-size: cover;
            background-position: center center;
            top: 50%;
            right: -36px;
            transform: translate(0, -50%);
            width: 18px;
            aspect-ratio: 3 / 1;
          }
        }
        &:hover {
          filter: drop-shadow(0 5px 5px rgba(0, 0, 0, .8));
          opacity: .7;
          .dec00 {
            filter: invert(100%);
          }
        }
      }
    }
    .btn03 {
      filter: drop-shadow(0 10px 20px rgba(0, 0, 0, .3));
      transition: .3s;
      &:hover {
        filter: drop-shadow(0 1px 5px rgba(0, 0, 0, .8));
        opacity: .7;
        .dec00 {
          filter: invert(100%);
        }
      }
    }
    li:has(.btn03) {
      margin-top: 80px;
    }
  }
  @media screen and (max-width:1200px) {
    font-size: calc(10 / 1200 * 100vw);
    padding: 20em 0;
    .inner02 {
      h2 {
        margin: 0 auto 32px;
        font-size: 8em;
      }
    }
  }
  @media screen and (max-width:640px) {
    font-size: calc(10 / 380 * 100vw);
    background-image: url("../../../img/pages/top2/re/bi_pickup_sp.png");
    padding: 6.4em 0;
    .inner02 {
      max-width: calc(100% - 4em);
      h2 {
        margin: 0 auto 60px;
        width: fit-content;
        font-size: 3.2em;
        letter-spacing: .06em;
      }
      .list_pickup {
        gap: 2.3em;
        li {
          width: 100%;
        }
				.pickup_label {
					position: absolute;
					right: 0;
					top: 0;
					font-size: .6em;
					transform: translateY(-70%);
					margin: 0;
				}
        .cap {
          font-size: .8em;
        }
        .btn01 {
          position: relative;
          z-index: 1;
          /*background: url("../../../img/pages/top2/re/bi_pickup.svg");
          background-repeat: no-repeat;
          background-size: cover;
          background-position: center center;*/
          display: block;
          padding: 0 .4em;
					max-width: 100%;
          width: 100%;
          font-size: 2em;
          text-align: center;
					border-width: 1px;
          .size_xl {
            font-size: 2em;
            /*margin-left: -.8em;*/
          }
          .size_l {
            font-size: 1.6em;
            /*margin-left: -.8em;*/
          }
          .size_m {
            font-size: 1.2em;
            /*margin-left: -.8em;*/
          }
          .size_s {
            font-size: .7em;
            /*margin-left: -.8em;*/
          }
        }
				.btn01_list {
					gap: 0 .5em;
					margin: 1.4em 0 0;
					span {
						font-size: .8em;
						letter-spacing: 0;
						border: 1px solid #fff;
						padding: .4em .6em .1em;
					}
				}
				.btn01_price {
					font-size: 1.4em;
					margin-top: .5em;
					.size_xl {
						font-size: 2.6em;
					}
					.size_s {
						font-size: .8em;
					}
				}
        .btn02 {
          display: flex;
          justify-content: center;
          align-items: center;
          margin: 0 auto;
          width: 88%;
          height: 3.857em;
          font-size: 1.4em;
          filter: drop-shadow(0 .42em .85em rgba(0, 0, 0, .4));
          .dec00 {
            &::after {
              right: -1.571em;
              width: .785em;
            }
          }
          &:hover {
            filter: drop-shadow(0 .35em .35em rgba(0, 0, 0, .8));
            opacity: .7;
            .dec00 {
              filter: invert(100%);
            }
          }
        }
      }
      .btn03 {
        display: block;
        margin: 1.7em auto 0;
        width: 88%;
        filter: drop-shadow(0 .42em .85em rgba(0, 0, 0, .4));
        transition: .3s;
        &:hover {
          filter: drop-shadow(0 0px .35em rgba(0, 0, 0, .8));
          opacity: .7;
          .dec00 {
            filter: invert(100%);
          }
        }
      }
      li:has(.btn03) {
        margin-top: 0;
      }
    }
  }
}
.l-cont {
  h2 {
    margin-bottom: 40px;
    opacity: .5;
    font-size: 80px;
    letter-spacing: .1em;
    /*writing-mode: sideways-rl;*/
    background: linear-gradient(200deg, #333 0%, #a08d68 25%, #333 50%, #a08d68 75%, #333 100%);
    background-clip: border-box;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
		writing-mode: vertical-rl;
    text-orientation: mixed;
    /*position: absolute;
    right: 40px;
    top: 50%;*/
    transform: rotate(360deg);
  }
  &.set01 {
	  position: relative;
	  z-index: 0;
    background: #cccbc9;
    margin: 0 auto;
    max-width: 100%;
    .inner02 {
      margin: 0 auto;
      max-width: 1920px;
      display: flex;
      align-items: center;
    }
    .box_text {
      width: 441px;
      h2 {}
      p {
        font-size: 24px;
        line-height: 2;
        letter-spacing: .08em;
        .dec01 {
          font-size: 1.5em;
          font-weight: bold;
          background: linear-gradient(315deg, #6c4f15 0%, #745923 5%, #97835a 26%, #ac9d7c 42%, #b5a78a 50%, #a99977 60%, #8b7547 81%, #6c4f15 100%);
          background-clip: border-box;
          -webkit-background-clip: text;
          -webkit-text-fill-color: transparent;
          box-decoration-break: clone;
          -webkit-box-decoration-break: clone;
        }
      }
    }
    figure {
      position: relative;
      z-index: 0;
      width: calc(100% - 441px);
      picture {
        height: 856px;
        img {
          object-fit: cover;
          object-position: left bottom;
          height: 100%;
          width: 100%;
					box-shadow: 5px 5px 15px rgba(0, 0, 0, .2);
        }
      }
      figcaption {
        position: absolute;
        z-index: 1;
        bottom: 0;
        right: 0;
        color: #fff;
        font-size: 11px;
        line-height: 1.36;
        letter-spacing: .05em;
        background: transparent;
      }
    }
    &.l-view {
      padding: 235px 0 144px;
      .inner02 {
        flex-flow: row-reverse;
      }
      .box_text {
        padding-left: 100px;
      }
		&::before{
				content: "";
	display: block;
	position: absolute;
	z-index:-1;
	background-image: url("../../../img/pages/top2/re/dec_light.svg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	top: 0;
	right: 0;
	width: 430px;
	aspect-ratio: 1;
		}
    }
    &.l-equipment {
      padding: 0 0 144px;
      .box_text {
        padding: 0 100px;
        display: flex;
        flex-flow: column;
        align-items: flex-end;
        h2 {
          margin-left: auto;
        }
      }
      figure {
        img {
          object-position: center bottom;
					box-shadow: 5px 5px 15px rgba(0, 0, 0, .2);
          ;
        }
      }
				&::before{
				content: "";
	display: block;
	position: absolute;
	z-index:-1;
	background-image: url("../../../img/pages/top2/re/dec_light.svg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	bottom:  0;
	left: 0;
	width: 430px;
	aspect-ratio: 1;
					transform: scale(-1,-1)
		}

    }
  }
  &.set02 {
	  position: relative;
	  z-index: 0;
    background: #cccbc9;
    margin: 0 auto;
    width: 100%;
    padding: 0 0 200px 0;
	  		&::before{
				content: "";
	display: block;
	position: absolute;
	z-index:-1;
	background-image: url("../../../img/pages/top2/re/dec_light.svg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	top: -144px;
	right: 0;
	width: 430px;
	aspect-ratio: 1;
		}

	  				&::after{
				content: "";
	display: block;
	position: absolute;
	z-index:-1;
	background-image: url("../../../img/pages/top2/re/dec_light.svg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	bottom:  0;
	left: 0;
	width: 430px;
	aspect-ratio: 1;
					transform: scale(-1,-1)
		}

    .wrapper {
      margin: 0 auto;
      max-width: 1920px;
    }
    .inner02 {
      max-width: 90%;
      padding: 73px 146px;
      background-image: url("../../../img/pages/top2/re/bi_location.png");
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center center;
      display: flex;
      justify-content: space-between;
      flex-flow: row-reverse;
      align-items: center;
    }
    .box_text {
      /*width: 29.94%;*/
      width: 430px;
      display: flex;
      justify-content: space-between;
      align-items: flex-end;
      flex-flow: row-reverse;
      h2 {
        margin-bottom: 0;
      }
      .in_text {
        width: 69.13%;
        color: #fff;
        p {
          display: flex;
          flex-flow: column;
          font-size: 14px;
          line-height: 1;
          letter-spacing: .08em;
          .size_s {
            margin-bottom: .5em;
          }
          .size_xs {
            margin-top: .5em;
            font-size: .78em;
            text-align: right;
          }
          .size_l {
            font-size: 1.7em;
            letter-spacing: 0;
          }
          .size_xl {
            font-size: 1.7em;
          }
        }
        dl {
          margin-top: 1em;
          font-size: 24px;
          line-height: 1.7;
          letter-spacing: .08em;
          div {
            display: flex;
            align-items: baseline;
            justify-content: space-between;
            dt {}
            dd {
              .size_l {
                font-size: 1.5em;
              }
            }
          }
        }
      }
    }
    figure {
      position: relative;
      z-index: 0;
      width: 55%;
      mix-blend-mode: screen;
      picture {
        display: block;
        img {
          object-fit: cover;
          width: 100%;
          height: 100%;
        }
      }
      figcaption {
        position: absolute;
        z-index: 1;
        bottom: 0;
        right: 0;
        color: #fff;
        font-size: 11px;
        line-height: 1.36;
        letter-spacing: .05em;
      }
    }
  }
  @media screen and (max-width:1500px) {
    &.set02 {
      font-size: 10px;
      .inner02 {
        padding: 7.3em 3.3em 7.3em 7.3em;
        flex-flow: column-reverse;
        align-items: flex-start;
      }
      .box_text {
        width: 430px;
        margin-left: auto;
      }
      figure {
        width: 80%;
        margin-bottom: -170px;
      }
    }
  }
  @media screen and (max-width:960px) {
    &.set01 {
      font-size: 10px;
      background: #cccbc9;
      margin: 0 auto;
      max-width: 100%;
      .inner02 {
        align-items: flex-start;
        flex-flow: column-reverse;
      }
      .box_text {
        width: 100%;
        display: flex;
        flex-flow: row-reverse;
        align-items: flex-end;
        p {
          font-size: 24px;
          line-height: 2;
          letter-spacing: .08em;
          .dec01 {
            font-size: 1.5em;
            font-weight: bold;
            background: linear-gradient(315deg, #6c4f15 0%, #745923 5%, #97835a 26%, #ac9d7c 42%, #b5a78a 50%, #a99977 60%, #8b7547 81%, #6c4f15 100%);
            background-clip: border-box;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            box-decoration-break: clone;
            -webkit-box-decoration-break: clone;
          }
        }
      }
      figure {
        position: relative;
        z-index: 0;
        width: 76.31%;
        picture {
          height: auto;
          img {
            object-fit: cover;
            object-position: left bottom;
            height: 100%;
            width: 100%;
						box-shadow: 5px 5px 15px rgba(0, 0, 0, .2);
          }
        }
        figcaption {
          right: auto;
          left: 0;
        }
      }
      &.l-view {
        padding: 70px 0 100px;
        .inner02 {
          flex-flow: column-reverse;
        }
        .box_text {
          margin-top: -6em;
          padding-left: 0;
          h2 {
            margin-bottom: 0;
            margin-left: .3em;
          }
        }
      }
      &.l-equipment {
        padding: 0 0 100px;
        .box_text {
          margin: -31em 0 0;
          padding: 0;
          flex-flow: row;
          align-items: flex-end;
          h2 {
            margin: 0 .2em 0 0;
          }
        }
        figure {
          margin-left: auto;
        }
      }
    }
    &.set02 {
		   &::before {
      top: -316px;
    }
      .inner02 {
        padding: 4.8em 0 4.8em 3.2em;
        flex-flow: column-reverse;
        align-items: flex-start;
      }
      .box_text {
        width: 430px;
        margin-left: auto;
      }
      figure {
        width: 80%;
        margin-bottom: -170px;
      }
    }
  }
  @media screen and (max-width:640px) {
    font-size: calc(10 / 380 * 100vw);
    h2 {
      font-size: 4em;
      letter-spacing: .1em;
    }
    &.set01 {
		    font-size: calc(10 / 380 * 100vw);
      background: #cccbc9;
      margin: 0 auto;
      max-width: 100%;
      .inner02 {}
      .box_text {
        p {
          font-size: 2em;
          line-height: 1.8;
          letter-spacing: 0;
        }
      }
      figure {
        figcaption {
          font-size: .9em;
        }
      }
      &.l-view {
        padding: 70px 0 100px;
				&::before {
					width: 20em;
				}
        .box_text {
          margin-top: 1.5em;
          padding-right: 1em;
          transform: translateY(.2em);
        }
				&.set01 {
					& figure {
						width: 92.1%;
					}
				}
				
      }
      &.l-equipment {
        padding: 0 0 9.4em;
		  		  		  &::before {
        width: 20em;

      }

        .box_text {
          margin: -11.5em 0 0;
          padding-left: 1.2em;
        }
      }
    }
    &.set02 {
		    font-size: calc(10 / 380 * 100vw);
      background: #cccbc9;
      margin: 0 auto;
      width: 100%;
      padding: 0 0 7em 0;
				  		  &::before {
							  top: -24.2em;
        width: 20em;

      }
		  		  &::after {
        width: 20em;

      }

      .wrapper {}
      .inner02 {
        max-width: 92.1%;
        padding: 4em 0 5em;
        background-image: url("../../../img/pages/top2/re/bi_location_sp.png");
      }
      .box_text {
        display: block;
        width: 100%;
        padding: 0 5.6em;
        h2 {
          writing-mode: rl;
        }
        .in_text {
          width: 100%;
          p {
            display: flex;
            flex-flow: column;
            font-size: 1.0em;
            line-height: 1;
            letter-spacing: .08em;
            .size_s {
              margin-bottom: 0em;
            }
            .size_xs {
              margin-top: .5em;
              font-size: .98em;
              text-align: right;
            }
            .size_l {
              font-size: 1.95em;
              letter-spacing: 0;
            }
            .size_xl {
              font-size: 1.7em;
            }
          }
          dl {
            margin-top: .9em;
            font-size: 2em;
            line-height: 1.3;
            letter-spacing: .08em;
            div {
              display: flex;
              align-items: baseline;
              justify-content: space-between;
              dt {}
              dd {
                font-size: .8em;
                .size_l {
                  font-size: 2.0em;
                }
              }
            }
          }
        }
      }
      figure {
        width: 100%;
        margin-bottom: 0px;
        figcaption {
          font-size: .9em;
          right: 1em;
        }
      }
    }
  }
}
/* リンクエリア */
.l-link {
  background: #333;
  padding: 144px 0;
  .inner02 {
    margin: 0 auto;
    width: 1580px;
    max-width: 82.29%;
    display: flex;
    justify-content: space-between;
    a {
      position: relative;
      z-index: 0;
      width: 31.64%;
      background-repeat: no-repeat;
      background-size: cover;
      background-position: center center;
      aspect-ratio: 100 / 66;
      display: flex;
      flex-flow: column;
      justify-content: center;
      align-items: center;
      &.modelroom {
        background: linear-gradient(rgba(59, 75, 87, .9), rgba(59, 75, 87, .9)), url("../../../img/pages/top2/re/bi_link01.png");
      }
      &.online {
        background-image: linear-gradient(rgba(63, 75, 75, .9), rgba(63, 75, 75, .9)), url("../../../img/pages/top2/re/bi_link02.png");
      }
      &.entry {
        background-image: linear-gradient(rgba(84, 81, 74, .9), rgba(84, 81, 74, .9)), url("../../../img/pages/top2/re/bi_link03.png");
      }
      h2 {
        margin: 0 auto;
        widht: fit-content;
        font-size: 28px;
        line-height: calc(50 / 28);
        letter-spacing: .08em;
        color: rgb(201, 185, 147);
        background: linear-gradient(316deg, #c2a17f 20%, #d6c0a9 40%, #e6d9cb 45%, #ede3d9 50%, #e4d5c6 45%, #cdb296 80%, #c2a17f 100%);
        background-clip: border-box;
        background-clip: border-box;
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        box-decoration-break: clone;
        -webkit-box-decoration-break: clone;
      }
      p {
        color: #fff;
        font-size: 16px;
        line-height: calc(34 / 16);
        letter-spacing: .08em;
        text-align: center;
      }
      .dec_btn {
        margin-top: 1.42em;
        background: linear-gradient(-80deg, #6f7979 0%, #a6acac 23%, #c8cccc 41%, #d6d9d9 50%, #c3c7c7 61%, #939b9b 84%, #6f7979 100%);
        width: 130px;
        aspect-ratio: 130 / 40;
        display: flex;
        justify-content: center;
        align-items: center;
        gap: .9em;
        font-size_14px;
        letter-spacing: .15em;
        transform-origin: top center;
        transition: .3s;
        &::before {
          content: "";
          display: block;
          background-image: url("../../../img/pages/top2/re/icon_arrow_b.svg");
          background-repeat: no-repeat;
          background-size: cover;
          background-position: center center;
          right: -36px;
          width: 18px;
          aspect-ratio: 300 / 108;
          align-self: center;
        }
      }
      .cap {
        position: absolute;
        bottom: 0;
        left: 0;
        color: #fff;
        font-size: 11px;
        line-height: 1.36;
        letter-spacing: .05em;
        opacity: .6;
        padding: .5em;
      }
      &:hover {
        .dec_btn {
          transform: scale(1.1);
        }
      }
    }
  }
  @media screen and (max-width:1500px) {
    font-size: calc(10 / 1500 *100vw);
    padding: 14.4em 0;
    .inner02 {
      max-width: 90%;
      display: flex;
      justify-content: space-between;
      a {
        h2 {
          font-size: 2.8em;
        }
        p {
          font-size: 1.6em;
        }
        .dec_btn {
          width: 13em;
        }
        .cap {
          font-size: 1.1em;
        }
      }
    }
  }
  @media screen and (max-width:960px) {
    font-size: 10px;
    padding: 5em 0;
    .inner02 {
      margin: 0 auto;
      width: 1580px;
      max-width: calc(100% - 6em);
      flex-flow: column;
      align-items: center;
      gap: 3em;
      a {
        width: 600px;
        aspect-ratio: 100 / 40;
      }
    }
  }
  @media screen and (max-width:640px) {
	    font-size: calc(10 / 380 * 100vw);
    .inner02 {
      a {
        width: 100%;
        height: auto;
        aspect-ratio: 320 / 210;
        h2 {
          font-size: 2em;
        }
        p {
          font-size: 1.2em;
        }
        .dec_btn {
          width: 11em;
        }
        .cap {
          font-size: .9em;
        }
      }
    }
  }
}

/* 2026.04.27 */
@media screen and (max-width: 640px){

.wrapper{
  overflow: visible !important;
}
body{
  overflow-x: hidden;
}
.l-mv-wrap{
  position: relative;
  height: 290vh;
}

.l-mv{
  position: relative;
  z-index: 1;
}
.l-merit{
  position: relative;
  z-index: 2;
  transform: translateY(-15vh);
  padding-top: 15vh;
  opacity: 0;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
}