@charset "UTF-8";
.side_navi_area {
  position: relative;
}
.side_navi_area.experiences::before {
  content: '';
  position: absolute;
  bottom: -48px;
  left: 0;
  right: 0;
  width: 100%;
  height: 25.833%;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_map.jpg) no-repeat center / cover;
  z-index: -1;
}
.read {
  margin-top: 60px;
}
.read_inner {
  position: relative;
  max-width: 1150px;
  padding: 60px 0 50px;
}
.read_text_area {
  position: relative;
  width: clamp(594px, 36.458vw, 700px);
  padding-top: clamp(40px, 3.542vw, 68px);
  padding-bottom: clamp(10px, 1.25vw, 24px);
  padding-right: clamp(44px, 2.7083vw, 52px);
  padding-left: clamp(16px, 1.042vw, 20px);
  background-color: #fff;
  z-index: 5;
  box-sizing: border-box;
}
.read_text_area::before {
  content: '';
  position: absolute;
  top: -28px;
  right: -63px;
  width: 125px;
  height: 125px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/common/read_logo@2x.png) no-repeat center / cover;
}
.read_heading {
  position: relative;
  font-weight: 600;
  font-size: 30px;
  font-size: clamp(20px, 1.5625vw, 30px);
  color: #3572b7;
}
.read_heading::before {
  content: attr(data-text);
  position: absolute;
  top: -42px;
  left: -20px;
  font-weight: 600;
  font-size: 14px;
  color: #3572b7;
  letter-spacing: 0.1em;
}
.read_text {
  font-weight: 600;
  font-size: 14px;
  color: #333;
  margin-top: 34px;
}
.read_text  + .read_text  {
  margin-top: 2em;
}
.read_main_image {
  position: absolute;
  top: 0;
  left: clamp(394px, 28.906vw, 555px);
  width: clamp(841px, 53.334vw, 960px);
  height: clamp(547px, 34.444vw, 620px);
  z-index: 1;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/read@2x.jpg) no-repeat center / cover;
}
.read_main_image::before {
  content: '';
  position: absolute;
  bottom: clamp(-26px, -1.615vw, -22px);
  left: 133px;
  width: clamp(486px, 35.448vw, 623px);
  height: clamp(135px, 8.854vw, 170px);
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/text_aqua_terrace@2x.png) no-repeat center / cover;
}

.map {
  margin-top: 106px;
  margin-top: clamp(75px, 5.5208vw,106px);
}

.map .heading_tertiary{
  max-width: 1115px;
}
.map_image {
  max-width: 1000px;
  margin-left: 55px;
  margin-top: 26px;
}
.map_image img {
  width: 100%;
}

.area_list {
  display: flex;
  column-gap: 50px;
  max-width: 1190px;
  padding-top: 110px;
  margin: auto;
  box-sizing: border-box;
}
.area_list_image {
  width: 600px;
}
.area_list_image img {
  width: 100%;
}
.area_list_image img.is_fadein {
	animation: fadein .3s ease-in-out forwards;
}
@keyframes fadein {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
.area_list_text_area {
  flex: 1;
}
.area_list_name {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  column-gap: 20px;
  row-gap: 20px;
  height: 288px;
  margin-top: 24px;
  box-sizing: border-box;
}
.area_list_name li {
  display: flex;
  align-items: center;
  width: calc((100% - 28px) / 2);
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.5;
  color: #464542;
  transition: color .3s;
  cursor: pointer;
}
.area_list_name li span {
  display: grid;
  place-content: center;
  min-width: 40px;
  width: 40px;
  height: 40px;
  background: #3572b7;
  border-radius: 50%;
  margin-right: 10px;
  font-weight: normal;
  font-size: 24px;
  letter-spacing: 0;
  line-height: 1;
  color: #fff;
  transition: background-color .3s;
}
.area_list_name li.current {
  color: #3572B7;
  cursor: default;
  pointer-events: none;
}
.area_list_name li.current span {
  background-color: #73A9E5;
}
.area_list_name li:hover {
  color: #3572B7;
}
.area_list_name li:hover span {
  background-color: #73A9E5;
}

.pool {
  position: relative;
  padding-top: 86px;
  margin-top: 100px;
}
.pool::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1190px;
  height: 60px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/common/line.png) no-repeat center / cover;
}
.pool::after {
  content: '';
  position: absolute;
  top: -100px;
  left: 50%;
  transform: translateX(-50%);
  width: max(1368px, 100vw);
  height: max(624px, 45.677vw);
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_pool.jpg) no-repeat center / cover;
  z-index: -1;
}
.pool_full_image {
  display: flex;
  width: 100%;
  margin-top: 26px;
}
.pool_full_image_item {
  position: relative;
  width: 50%;
}
.pool_full_image_item img {
  width: 100%;
}
.pool_text {
  position: relative;
  max-width: 656px;
  font-weight: 600;
  font-size: 16px;
  text-align: center;
  color: #333;
  margin: 44px auto 0;
}
.pool_text::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: max(1368px, 100vw);
  height: max(1425px, 104.167vw);
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_pool_side.jpg) no-repeat center / cover;
  z-index: -2;
}

.pool_side {
  position: relative;
  max-width: 1190px;
  margin: 64px auto 0;
  padding-top: 96px;
}
.pool_side::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1190px;
  height: 60px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/common/line.png) no-repeat center / cover;
}
.pool_side_2col {
  display: flex;
  column-gap: 60px;
}
.pool_side_left {
  flex: 1;
  padding-left: 40px;
}
.pool_side_text {
  font-weight: 600;
  font-size: 16px;
  color: #333;
}
.pool_side_left .pool_side_text {
  margin-top: 39px;
}
.pool_side_left .pool_side_text:nth-of-type(2) {
  margin-top: 55px;
}
.pool_side_right .pool_side_text {
  margin-top: 20px;
}
.pool_side_left_image {
  position: relative;
  width: 520px;
  margin-top: 54px;
}
.pool_side_left_image::after {
  content: '';
  position: absolute;
  top: 30px;
  left: 30px;
  width: 520px;
  height: 260px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_tree_pool_side_large.jpg) no-repeat center / cover;
  z-index: -1;
}
.pool_side_left_image img {
  width: 100%;
}
.pool_side_right {
  width: 550px;
}
.pool_side_right_image {
  position: relative;
}
.pool_side_right_image img {
  width: 100%;
}
.pool_side_full {
  position: relative;
  margin-top: 70px;
}
.pool_side_full img {
  width: 100%;
}
.pool_side_3col {
  display: flex;
  column-gap: 60px;
  margin-top: 70px;
}
.pool_side_item {
  width: 350px;
}
.pool_side_figure {
  position: relative;
}
.pool_side_figure::after {
  content: '';
  position: absolute;
  top: 20px;
  left: 20px;
  width: 350px;
  height: 230px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_tree_pool_side.jpg) no-repeat center / cover;
  z-index: -1;
}
.pool_side_figure img {
  width: 100%;
}
.pool_side_figcaption {
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #333;
  margin-top: 35px;
}

.jet_bath {
  position: relative;
  margin-top: 70px;
  padding-top: 90px;
}
.jet_bath::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1190px;
  height: 60px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/common/line.png) no-repeat center / cover;
}
.jet_bath::after {
  content: '';
  position: absolute;
  top: 120px;
  left: 50%;
  transform: translateX(-50%);
  width: max(1368px, 100vw);
  height: max(624px, 45.677vw);
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_pool.jpg) no-repeat center / cover;
  z-index: -1;
}
.jet_bath_text {
  max-width: 800px;
  font-weight: 600;
  font-size: 16px;
  text-align: center;
  color: #333;
  margin: 40px auto 0;
}
.jet_bath_iamge {
  max-width: 1190px;
  margin: 24px auto 0;
}
.jet_bath_iamge img {
  width: 100%;
}


.bar {
  position: relative;
  margin-top: 70px;
  padding-top: 90px;
}
.bar::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1190px;
  height: 60px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/common/line.png) no-repeat center / cover;
}
.bar::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 93.879%;
  top: 140px;
  left: 50%;
  transform: translateX(-50%);
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_bar.png) no-repeat center / cover;
  z-index: -1;
}
@media screen and (min-width:1921px) {
  .bar::after {
    width: 100vw;
    height: 66.302vw;
  }
}
.bar_inner {
  position: relative;
  max-width: 1190px;
  margin: auto;
}
.bar_text {
  font-weight: 600;
  font-size: 16px;
  text-align: center;
  color: #333;
  margin-top: 39px;
}
.bar_grid {
  margin-top: 44px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: auto;
  grid-template-rows: 53px auto 69px auto 10px auto auto;
  grid-column-gap: 10px;
  padding-left: 14px;
}
.bar_description { grid-area: 2 / 1 / 3 / 2; }
.bar_image01 { grid-area: 4 / 1 / 8 / 2; }
.bar_image02 { grid-area: 1 / 2 / 5 / 3; }
.bar_image03 { grid-area: 6 / 2 / 8 / 3; }

.bar_description {
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #B8B8B8;
  box-sizing: border-box;
  max-width: 500px;
  margin-left: 25px;
}
.bar_description dt {
  width: 25%;
  font-weight: normal;
  font-size: 14px;
  color: #464542;
  padding: 11px 20px;
  border-bottom: 1px solid #B8B8B8;
  box-sizing: border-box;
}
.bar_description dd {
  width: 75%;
  font-weight: normal;
  font-size: 14px;
  color: #000;
  padding: 11px 20px;
  border-bottom: 1px solid #B8B8B8;
  box-sizing: border-box;
}
.bar_image01 {
  position: relative;
  width: 534px;
  margin-left: auto;
}
.bar_image01::before {
  content: '';
  position: absolute;
  bottom: 100px;
  right: 77px;
  width: 520px;
  height: 260px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_bar_tree.jpg) no-repeat center / cover;
  z-index: -1;
}
.bar_image01::after {
  content: '';
  position: absolute;
  bottom: 92px;
  left: -48px;
  width: 368px;
  height: 147px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/text_afternoon@2x.png) no-repeat center / cover;
}
.bar_image02 {
  position: relative;
  width: 500px;
}
.bar_image02::before {
  content: '';
  position: absolute;
  bottom: -62px;
  left: 63px;
  width: 520px;
  height: 260px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/bg_bar_tree.jpg) no-repeat center / cover;
  z-index: -1;
}
.bar_image02::after {
  content: '';
  position: absolute;
  bottom: -52px;
  right: -57px;
  width: 199px;
  height: 147px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/aqua_terrace/text_night@2x.png) no-repeat center / cover;
  z-index: 5;
}
.bar_image03 {
  position: relative;
  width: 403px;
}
.bar_image01 img,
.bar_image02 img,
.bar_image03 img {
  width: 100%;
}
.bar_button {
  width: 375px;
  margin: 50px auto 0;
}

.night_scene {
  position: relative;
  padding-top: 90px;
  margin-top: 70px;
}
.night_scene::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1190px;
  height: 60px;
  background: url(https://www.neoxone.co.jp/hotel/aquasense/rakuten/images/common/line.png) no-repeat center / cover;
}
.night_scene_full_image {
  display: flex;
  width: 100%;
  margin-top: 24px;
}
.night_scene_full_image_item {
  width: 50%;
}
.night_scene_full_image_item img {
  width: 100%;
}
.night_scene_text {
  max-width: 800px;
  font-weight: 600;
  font-size: 16px;
  text-align: center;
  color: #333;
  margin: 42px auto 0;
}
.night_scene_image {
  max-width: 1190px;
  margin: 45px auto 0;
}
.night_scene_image img {
  width: 100%;
}

.terrace_detail {
  margin-top: 66px;
  padding-bottom: 22px;
}
.terrace_description {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  max-width: 1000px;
  margin: 25px auto 0;
  box-sizing: border-box;
  border-top: 1px solid #b8b8b8;
}
.terrace_description dt {
  width: 31%;
  font-weight: normal;
  font-size: 16px;
  color: #464542;
  padding: 14px 20px;
  border-bottom: 1px solid #b8b8b8;
  box-sizing: border-box;
}
.terrace_description dd {
  width: 69%;
  font-weight: normal;
  font-size: 16px;
  color: #000;
  padding: 14px 20px;
  border-bottom: 1px solid #b8b8b8;
  box-sizing: border-box;
}


[class*="alphabet_"]::before {
  position: absolute;
  top: 16px;
  left: 20px;
  display: grid;
  place-content: center;
  width: 40px;
  height: 40px;
  background: #3572b7;
  border: 1px solid #fff;
  font-weight: normal;
  font-size: 24px;
  letter-spacing: 0;
  line-height: 1;
  color: #fff;
  border-radius: 50%;
  box-sizing: border-box;
}

.alphabet_a::before {
  content: 'A';
  top: 10px;
  left: 10px;
}
.alphabet_b::before {
  content: 'B';
  top: 14px;
  left: 10px;
}
.alphabet_c::before {
  content: 'C';
  top: 10px;
  left: 10px;
}
.alphabet_d::before {
  content: 'D';
  top: 10px;
  left: -60px;
}
.alphabet_e::before {
  content: 'E';
}
.alphabet_f::before {
  content: 'F';
  top: 14px;
  left: 10px;
}
.alphabet_g::before {
  content: 'G';
}
.alphabet_h::before {
  content: 'H';
}
.alphabet_i::before {
  content: 'I';
  top: 10px;
  left: -60px;
}
.alphabet_j::before {
  content: 'J';
  top: 10px;
  left: 10px;
}
.bar .heading_tertiary,
.jet_bath .heading_tertiary {
  position: relative;
  width: fit-content;
  margin: auto;
}