@charset "UTF-8";

.bg_area01 {
  background: url(../images/top_bg01.png) no-repeat center top / cover;
  padding: 0px 0 130px;
  margin-top: 30px;
  position: relative;
}

#room .head_mv img {
  width: 100%;
}

#room .common_side_nav_insert_area {
  width: 1360px;
}

#room .common_side_nav_insert_area {
  width: 1360px;
}

#room .bg_area01::after,
#room .bg_area02::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 130px;
  background: linear-gradient(
    0deg,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 0) 100%
  );
}

#room .bg_area02 {
  background: url(../images/room/room_bg.png) no-repeat center top / cover;
  padding: 70px 0 120px;
}

#standard .bg_area02::after {
  height: 30px;
}

#standard .bg_area02 {
  padding: 70px 0 30px;
}

.room_main {
  width: 1340px;
  /* padding-left: 220px; */
  margin: 0px auto 0;
  box-sizing: border-box;
}

.room_main img {
  width: 100%;
}

#room .room_head {
  display: flex;
  justify-content: center;
  gap: 40px;
  padding-bottom: 30px;
}

.room_head div {
  width: 38.5%;
}

.room_head p {
  line-height: 1.8;
}

.room_head h2 {
  font-size: 20px;
  margin: 50px 0 36px;
  line-height: 1.8;
  font-family: "TsukuBRdGothic-Regular", "Zen Maru Gothic", sans-serif;
}

#room .head_images {
  position: relative;
  margin-bottom: 140px;
}

#room .head_images p {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0);
  font-size: 100px;
  color: #fff;
  font-family: "Oswald", "游ゴシック体", "Yu Gothic", YuGothic,
    "ヒラギノ角ゴ Pro", sans-serif;
  line-height: 1em;
  margin: 0 0 -5px 0;
  letter-spacing: 0.1em;
}

#room .head_images p::after {
  content: "ROOMS";
  color: #00479d;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translate(-50%, 0) scale(1, -1);
  opacity: 0.1;
  margin: -10px 0 0;
}

#room .kurasi_img {
  position: relative;
}

#room .kurasi_img img {
  position: relative;
  z-index: 1;
}

#room .kurasi_img::after {
  content: "";
  position: absolute;
  bottom: calc(0% - 30px);
  right: calc(0% - 30px);
  z-index: 0;
  width: 560px;
  height: 333px;
  background-color: #00479d;
  opacity: 0.1;
}

/* ナビゲーション */
#room .room_navi {
  display: flex;
  gap: 2%;
  padding: 0 20px 0;
  margin: 60px auto;
  text-align: center;
  align-items: baseline;
  width: clamp(980px, 90%, 1588px);
  align-items: flex-start;
}

#room .room_navi li {
  width: 19%;
  position: relative;
}

#room .room_navi a {
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro",
    "Hiragino Kaku Gothic Pro", sans-serif;
  box-sizing: border-box;
  display: block;
  max-width: 260px;
  height: clamp(198px, 16.63866vw, 260px);
  text-decoration: none;
  color: #fff;
  font-weight: bold;
  position: relative;
  background-size: cover;
  overflow: hidden;
  border-radius: 50%;
}

#room .room_navi li img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.6s ease, filter 0.6s ease;
}

#room .room_navi li img:hover {
  transform: translate(-50%, -50%) scale(1.2);
  filter: brightness(1.2);
}

#room .room_navi a p {
  font-size: 24px;
  font-size: min(24 / 1920 * 100vw, 24px);
  font-weight: bold;
  position: absolute;
  width: 100%;
  top: 60%;
  left: 50%;
  z-index: 1;
  line-height: 1.2;
  transform: translate(-50%, -10%);
  pointer-events: none;
}

#room .room_navi a span {
  font-size: 14px;
  font-size: min(14 / 1920 * 100vw, 14px);
}

#room .room_navi li:nth-child(even) {
  margin-top: 90px;
}

#room .room_navi a::after {
  content: "";
  position: absolute;
  top: 85%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  background-color: #fcd64a;
  pointer-events: none;
}

#room .room_navi li::after {
  content: "";
  position: absolute;
  z-index: 3;
  pointer-events: none;
  top: -2%;
  left: 42%;
  /* top: 12%;
  left: 46%; */
  transform: translatex(-50%);
}

#room .room_navi .button01::after {
  background: url(../images/room/btntext01.svg) no-repeat center / contain;
  width: min(375 / 1920 * 100vw, 375px);
  height: min(145 / 1920 * 100vw, 145px);
}

#room .room_navi .button02::after {
  background: url(../images/room/btntext02.svg) no-repeat center / contain;
  width: min(336 / 1920 * 100vw, 336px);
  height: min(135 / 1920 * 100vw, 135px);
}

#room .room_navi .button03::after {
  background: url(../images/room/btntext03.svg) no-repeat center / contain;
  width: min(283 / 1920 * 100vw, 283px);
  height: min(139 / 1920 * 100vw, 139px);
}

#room .room_navi .button04::after {
  background: url(../images/room/btntext04.svg) no-repeat center / contain;
  width: min(19.32vw, 375px);
  height: min(8.12vw, 159px);
}

#room .room_navi .button05::after {
  background: url(../images/room/btntext05.svg) no-repeat center / contain;
  width: min(11.75vw, 228px);
  height: min(6.44vw, 125px);
}

#room .room_title {
  background: url(../images/room/title_bg.png) repeat-x;
  background-position: left bottom;
  display: flex;
}

#room .room_title h2 {
  font-family: "Oswald", "游ゴシック体", "Yu Gothic", YuGothic,
    "ヒラギノ角ゴ Pro", sans-serif;
  font-size: 150px;
  line-height: 1em;
  padding-left: 46px;
  position: relative;
  margin: 30px 0 -6px 9vw;
  vertical-align: bottom;
  background: url(../images/room/title_icon.png) no-repeat 0px 28px;
  letter-spacing: 0.05em;
}

#room .wrapbox {
  position: relative;
}

#room .concept .concept_text {
  position: absolute;
  top: 300px;
  left: 16%;
  writing-mode: vertical-rl;
  background-color: #fff;
  font-size: 18px;
  padding: 0.5em 0.5em;
  min-height: 360px;
  font-weight: bold;
  letter-spacing: 0.4em;
}

#room .room_cover_top {
  display: flex;
  gap: 25px;
  margin-bottom: 26px;
  justify-content: center;
}

#room .room_cover_top.reverse {
  flex-direction: row-reverse;
}

.room_cover_top img {
  border-radius: 10px;
  position: relative;
  z-index: 1;
}

.room_cover_top .room01_box .img_cover,
.room_cover_top .room01_box .img_cover02 {
  position: relative;
}

.room_cover_top .room01_box .img_cover::after {
  content: "";
  position: absolute;
  bottom: calc(0% - 30px);
  left: calc(0% - 30px);
  z-index: 0;
  width: 250px;
  height: 250px;
  background-color: #00479d;
  border-radius: 10px;
}

.reverse .room01_box .img_cover::after {
  left: auto;
  bottom: calc(0% - 30px);
  right: calc(0% - 30px);
  z-index: 0;
  width: 250px;
  height: 250px;
  background-color: #00479d;
  border-radius: 10px;
}

#room .room_incontents {
  max-width: 1220px;
  margin: 0px auto;
}

#room .room_incontents .room_block_main {
  text-align: center;
}

#room .room_incontents .room_block_main img {
  border-radius: 10px;
}

#room .room_text {
  width: 330px;
  margin: -46px auto 30px;
  background: #fff url(../images/room/deco01.png) no-repeat 0 0;
  padding: 36px 30px;
  border-radius: 5px;
  position: relative;
}

#room .room_text h3 {
  border-bottom: 2px solid #00479d;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 16px;
  text-align: center;
}

#room .room_text p {
  font-size: 14px;
}

#room .cover_button a {
  text-align: center;
  display: block;
  padding: 12px 10px 8px;
  width: 230px;
  color: #f5f5ed;
  font-weight: bold;
  border-radius: 30px;
  background-color: #00479d;
  box-shadow: 0 0.3em 0 #033169;
  margin: 2em auto 0.2em auto;
  /*アニメーションの指定*/
  transition: all 0.3s ease;
}

#room .cover_button a:hover {
  box-shadow: 0 0.1em 0 #033169;
  text-decoration: none;
  transform: translateY(0.2em);
  color: #ffffff;
}

#room .room02_box {
  margin-top: 70px;
}

#room .room02_box li {
  width: fit-content;
}

#room .room02_box li:last-of-type {
  margin: -32px -152px 0 auto;
  /* border: 14px solid #FFF; */
  border-radius: 10px;
  position: relative;
  z-index: 1;
}

#room .room02_box li:last-of-type:after {
  content: "";
  position: absolute;
  top: calc(0% - 14px);
  left: calc(0% - 14px);
  z-index: 0;
  width: 270px;
  height: 300px;
  background-color: #fff;
  border-radius: 10px;
}

#room .reverse .room02_box li:last-of-type {
  margin: -32px auto 0 -152px;
}

#room .reverse .room02_box li:last-of-type:after {
  left: auto;
  right: calc(0% - 14px);
}

/* スライダー */
#room .room_cover_bottom {
  display: flex;
  gap: min(5vw, 80px);
  margin-bottom: 40px;
  justify-content: center;
}

#standard .room_cover_bottom {
  margin-bottom: 0px;
}

#room .room_slider {
  box-sizing: border-box;
  padding: 25px;
  border-radius: 10px;
  background-color: #f5f5ed;
  width: clamp(450px, 45.01vw, 550px);
}

#room .room_slider img {
  border-radius: 10px;
}

#room .room_slider .slick-dots {
  position: absolute;
  bottom: -20px;
  right: 0;
  text-align: right;
}

#room .room_slider .slick-dots li {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #f5f5ed;
  position: relative;
  display: inline-block;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}

#room .room_slider .slick-dots li.slick-active {
  background-color: #00479d;
}

#room .room_about {
  width: 541px;
  background-color: #f5f5ed;
  border-radius: 10px 10px 10px 10px;
}

#room .room_about dl {
  min-height: 64px;
  display: flex;
  padding: 10px 0;
  overflow: hidden;
}

#room .room_about dt {
  width: 30%;
  text-align: center;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
  background: url(../images/about_line.svg) repeat-y top right;
  position: relative;
}

#room .room_about dd {
  box-sizing: border-box;
  padding: 0 20px 0 20px;
  font-size: 14px;
  width: 70%;
  display: flex;
  align-items: center;
}

#room .room_about dl:nth-child(even) {
  background-color: #e6e6df;
}

#room .room_about dl:last-of-type {
  border-radius: 0 0 10px 10px;
}

/*Junior Suite01*/
#room .concept .right_concept {
  right: 16%;
  left: auto;
}

#room .right_h2 {
  justify-content: flex-end;
  padding-right: 5%;
}

/*カメ追加*/
#room .room_text {
  position: relative;
}

#room .room_text::after {
  content: "";
  position: absolute;
  top: 34%;
  right: max(calc(100% - 92px), 84%);
  background: url(../images/icon_umigame01.png) no-repeat center / contain;
  width: min(19vw, 343px);
  height: min(10.69vw, 193px);
  z-index: 1;
}

#room .reverse .room_text::after {
  content: "";
  position: absolute;
  top: 48%;
  left: calc(100% - 48px);
  background: url(../images/icon_umigame02.png) no-repeat center / contain;
  z-index: 1;
  width: min(19vw, 343px);
  height: min(10.69vw, 193px);
}

.room_text .sky_span {
  font-weight: bold;
}
