@charset "UTF-8";
.hotelHeader {
  margin-top: 170px;
  margin-bottom: 84px;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 14px;
  position: relative;
  background-image: url(../images/header_bg.jpg);
  background-position: center;
  background-size: cover;
}
.hotelHeader span {
  font-size: clamp(17px, 2.33vw, 28px);
  font-family: "Poppins", sans-serif;
  letter-spacing: 0.2em;
  text-align: center;
  color: #ffffff;
}
.hotelHeader h1 {
  font-size: clamp(14px, 1.67vw, 20px);
  letter-spacing: 0.2em;
  text-align: center;
  color: #ffffff;
  line-height: 1.3em;
}
.hotelHeader:after {
  content: "";
  display: block;
  width: calc(100% - 16px);
  height: 100%;
  border: 2px solid #9f72d3;
  position: absolute;
  top: 8px;
  left: 0;
  right: 0;
  margin: auto;
  pointer-events: none;
}

@media only screen and (max-width: 767px) {
  .hotelHeader {
    height: 26svh;
    margin-top: 100px;
    margin-bottom: 32px;
  }
  .hotelHeader span {
    font-size: clamp(14px, 6.15vw, 24px);
  }
  .hotelHeader h1 {
    font-size: clamp(14px, 3.85vw, 15px);
  }
}
@media print, screen and (min-width: 768px) {
  .hotelHeader {
    height: 50svh;
  }
}
.hotelMds {
  color: #d72e77;
  letter-spacing: 0.2em;
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .hotelMds {
    padding-bottom: 24px;
    font-size: clamp(14px, 5.13vw, 20px);
  }
}
@media print, screen and (min-width: 768px) {
  .hotelMds {
    padding-bottom: 32px;
    font-size: clamp(14px, 2vw, 24px);
  }
}
#pageTop.kanazawa .hotelHeader {
  background-image: url(../images/header_bg_kanazawa.jpg);
}
#pageTop.kanazawa .hotelHeader:after {
  border: 2px solid #9f72d3;
}
#pageTop.kanazawa .hotelAccess .wrap {
  background-color: #e6deef;
}
#pageTop.kanazawa .hotelAccess .wrap .txt .nameEn {
  color: #9f72d3;
}
#pageTop.riverside .hotelHeader {
  background-image: url(../images/header_bg_riverside.jpg);
}
#pageTop.riverside .hotelHeader:after {
  border: 2px solid #5ac0e8;
}
#pageTop.riverside .hotelAccess .wrap {
  background-color: #e8f2f6;
}
#pageTop.riverside .hotelAccess .wrap .txt .nameEn {
  color: #5ac0e8;
}
#pageTop.morimoto .hotelHeader {
  background-image: url(../images/header_bg_morimoto.jpg);
}
#pageTop.morimoto .hotelHeader:after {
  border: 2px solid #4bce74;
}
#pageTop.morimoto .hotelAccess .wrap {
  background-color: #e8f9ed;
}
#pageTop.morimoto .hotelAccess .wrap .txt .nameEn {
  color: #4bce74;
}

.hotelAccess {
  padding: 30px 0 60px;
}
.hotelAccess .wrap {
  background-color: #e6deef;
  border-radius: 10px;
  padding: 36px 24px;
  max-width: 900px;
  width: 90vw;
  margin: auto;
  display: grid;
  grid-template-columns: 2fr 3fr;
  gap: 4%;
  align-items: center;
  position: relative;
}
.hotelAccess .wrap iframe {
  border-radius: 10px;
  aspect-ratio: 20/16;
  display: block;
  width: 100%;
}
.hotelAccess .wrap .txt .nameEn {
  font-family: "Poppins", sans-serif;
  font-size: clamp(17px, 2.33vw, 28px);
  line-height: 1.4em;
  letter-spacing: 0.2em;
  color: #9f72d3;
}
.hotelAccess .wrap .txt .name {
  font-size: clamp(14px, 1.67vw, 20px);
  letter-spacing: 0.2em;
}
.hotelAccess .wrap .txt .list {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-top: 14px;
}
.hotelAccess .wrap .txt .list .listContent {
  display: grid;
  grid-template-columns: 19px 1fr;
  gap: 2px;
  align-items: center;
  font-size: clamp(14px, 1.25vw, 15px);
}
.hotelAccess .wrap .illust {
  position: absolute;
  pointer-events: none;
  bottom: -10px;
  left: calc(100% - 32px);
  max-width: 220px;
  width: 30%;
}

@media print, screen and (max-width: 1400px) {
  .hotelAccess .wrap {
    grid-template-columns: 1fr 1fr;
    padding: 36px 12vw 36px 24px;
  }
  .hotelAccess .wrap .illust {
    position: absolute;
    pointer-events: none;
    bottom: -10px;
    left: auto;
    right: -5vw;
    max-width: 220px;
    width: 30%;
  }
}
@media only screen and (max-width: 767px) {
  .hotelAccess .wrap {
    display: flex;
    flex-direction: column;
    gap: 24px;
    padding: 24px 12px;
  }
  .hotelAccess .wrap .illust {
    position: absolute;
    pointer-events: none;
    bottom: auto;
    top: 60%;
    left: auto;
    right: -5vw;
    max-width: 200px;
    width: 42%;
  }
  .hotelAccess .wrap .txt {
    width: 100%;
  }
}
/* セレクター */
.roomSelector .ttl {
  color: #d72e77;
  letter-spacing: 0.2em;
  text-align: center;
  margin-bottom: 40px;
}
.roomSelector .wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px 2%;
  max-width: 1100px;
  width: 90%;
  margin: auto;
}
.roomSelector .wrap .room-btn {
  background-color: #ffffff;
  padding: 10px 20px 8px;
  border-radius: 60px;
  border: 2px solid #d72e77;
  display: flex;
  flex-direction: column;
  gap: 2px;
  justify-content: center;
  cursor: pointer;
}
.roomSelector .wrap .room-btn p {
  font-size: clamp(14px, 1.67vw, 20px);
  letter-spacing: 0.05em;
  line-height: 1.4em;
  color: #d72e77;
}
.roomSelector .wrap .room-btn span {
  font-size: 13px;
  letter-spacing: 0.2em;
  line-height: 1.4em;
  color: #d72e77;
}
.roomSelector .wrap .room-btn svg {
  stroke: #d72e77;
  margin: auto;
}
.roomSelector .wrap .room-btn.is-active {
  background-color: #d72e77;
  cursor: initial;
}
.roomSelector .wrap .room-btn.is-active p {
  color: #ffffff;
}
.roomSelector .wrap .room-btn.is-active span {
  color: #ffffff;
}
.roomSelector .wrap .room-btn.is-active svg {
  stroke: #ffffff;
}

.innerWrap {
  background: #f5e6e5;
}

@media print, screen and (min-width: 768px) {
  .roomSelector {
    padding: 60px 0 120px;
  }
  .roomSelector .ttl {
    font-size: clamp(15px, 2.08vw, 25px);
  }
  .innerWrap {
    padding: 80px 0;
  }
}
@media only screen and (max-width: 767px) {
  .roomSelector {
    padding: 120px 0 60px;
  }
  .roomSelector .ttl {
    font-size: clamp(14px, 5.64vw, 22px);
  }
  .roomSelector .wrap {
    gap: 8px;
  }
  .roomSelector .wrap .room-btn p {
    font-size: clamp(14px, 4.62vw, 18px);
  }
  .innerWrap {
    padding: 40px 0 80px;
  }
}
@media only screen and (max-width: 400px) {
  .roomSelector {
    padding: 30px 0 40px;
  }
}
.day-tabs {
  max-width: 1100px;
  width: 90%;
  margin: auto;
  display: flex;
  gap: 16px;
  align-items: flex-end;
  justify-content: space-between;
  border-bottom: 2px solid #d72e77;
}
.day-tabs button {
  width: 100%;
  text-align: center;
  border: 2px solid #d72e77;
  border-bottom: 0;
  padding: 10px 0;
  line-height: 1.4em;
  color: #d72e77;
  font-size: clamp(14px, 1.67vw, 20px);
  border-radius: 10px 10px 0 0;
  letter-spacing: 0em;
  cursor: pointer;
}
.day-tabs button.is-active {
  background: #d72e77;
  color: #ffffff;
  cursor: initial;
}

@media print, screen and (min-width: 768px) {
  .day-tabs {
    gap: 16px;
  }
  .day-tabs button {
    font-size: clamp(14px, 1.67vw, 20px);
    padding: 10px 0;
  }
}
@media only screen and (max-width: 800px) {
  .day-tabs {
    gap: 4px;
  }
  .day-tabs button {
    font-size: clamp(14px, 1.67vw, 20px);
    padding: 10px 0;
  }
}
@media only screen and (max-width: 767px) {
  .day-tabs {
    gap: 4px 0px;
    flex-wrap: wrap;
    border-bottom: 0px solid #d72e77;
  }
  .day-tabs button {
    font-size: clamp(14px, 4vw, 16px);
    padding: 10px 0;
    width: 33%;
    border: 2px solid #d72e77;
    border-radius: 10px;
  }
}
.price-tables {
  position: relative;
  margin: auto;
  max-width: 1100px;
  width: 90%;
}
.price-tables .hotelMds {
  padding-top: 60px;
  padding-bottom: 40px;
}
.price-tables .wrap {
  padding: 0px 0 0px;
  position: relative;
}
.price-tables .wrap .price-table-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
  z-index: 1;
}
.price-tables .wrap .price-table-wrapper.is-selected {
  opacity: 1;
  visibility: visible;
  z-index: 2;
  position: relative;
}
.price-tables .wrap .price-table-wrapper table {
  width: 100%;
  margin: auto;
  border-collapse: separate;
  border-spacing: 3px;
  table-layout: fixed;
}
.price-tables .wrap .price-table-wrapper table thead tr th:last-of-type {
  border-radius: 0 10px 0 0;
}
.price-tables .wrap .price-table-wrapper table thead tr th:first-of-type {
  border-radius: 10px 0 0 0;
}
.price-tables .wrap .price-table-wrapper table tbody tr:last-of-type td:last-of-type {
  border-radius: 0 0 10px 0;
}
.price-tables .wrap .price-table-wrapper table tbody tr:last-of-type td:first-of-type {
  border-radius: 0 0 0 10px;
}
.price-tables .wrap .price-table-wrapper table tr th {
  background: #ffffff;
  font-size: clamp(14px, 1.42vw, 17px);
  word-break: break-all;
  box-sizing: border-box;
  line-height: 1.4em;
  height: 68px;
  vertical-align: middle;
  color: #d72e77;
}
.price-tables .wrap .price-table-wrapper table tr th:not(.colttl) {
  width: auto;
}
.price-tables .wrap .price-table-wrapper table tr td {
  background: #ffffff;
  font-size: clamp(14px, 1.67vw, 20px);
  word-break: break-all;
  box-sizing: border-box;
  text-align: center;
  line-height: 1.4em;
  height: 68px;
  vertical-align: middle;
  color: #d72e77;
}
.price-tables .wrap .price-table-wrapper table tr td:not(.colttl) {
  width: auto;
}
.price-tables .wrap .price-table-wrapper table tr td.coltxt {
  font-size: 12px;
}
.price-tables .wrap .price-table-wrapper table tr td.colttl {
  font-size: clamp(14px, 1.42vw, 17px);
  width: 146px;
}
.price-tables .btnRound {
  margin: 24px auto 40px;
  border: 2px solid #d72e77;
  color: #d72e77;
  display: block;
  padding: 4px 16px 3px;
  border-radius: 32px;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(14px, 1.5vw, 18px);
}
.price-tables .btnRound:hover {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables .attention {
  margin: auto;
  font-size: 12px;
  line-height: 1.4em;
  margin-top: 24px;
}

@media only screen and (max-width: 767px) {
  /* 料金表 */
  .price-tables {
    margin: auto;
  }
  .price-tables .hotelMds {
    padding-top: 40px;
    padding-bottom: 20px;
  }
  .price-tables .wrap .price-table-wrapper table {
    width: 90%;
  }
  .price-tables .wrap .price-table-wrapper table tr th {
    font-size: clamp(14px, 4.1vw, 16px);
  }
  .price-tables .wrap .price-table-wrapper table tr td {
    font-size: clamp(14px, 4.62vw, 18px);
  }
  .price-tables .wrap .price-table-wrapper table tr td:not(.colttl) {
    width: auto;
  }
  .price-tables .wrap .price-table-wrapper table tr td.coltxt {
    font-size: 12px;
  }
  .price-tables .wrap .price-table-wrapper table tr td.colttl {
    font-size: clamp(14px, 4.1vw, 16px);
    width: 146px;
  }
  .price-tables .btnRound {
    font-size: clamp(14px, 4.62vw, 18px);
  }
  .wrap .price-table-wrapper th,
  .wrap .price-table-wrapper td {
    display: none;
  }
  .wrap .price-table-wrapper .colttl,
  .wrap .price-table-wrapper .coltxt,
  .price-tables.active-room-room_1 .wrap .price-table-wrapper th.col-room_1,
  .price-tables.active-room-room_1 .wrap .price-table-wrapper td.col-room_1,
  .price-tables.active-room-room_2 .wrap .price-table-wrapper th.col-room_2,
  .price-tables.active-room-room_2 .wrap .price-table-wrapper td.col-room_2,
  .price-tables.active-room-room_3 .wrap .price-table-wrapper th.col-room_3,
  .price-tables.active-room-room_3 .wrap .price-table-wrapper td.col-room_3,
  .price-tables.active-room-room_4 .wrap .price-table-wrapper th.col-room_4,
  .price-tables.active-room-room_4 .wrap .price-table-wrapper td.col-room_4,
  .price-tables.active-room-room_5 .wrap .price-table-wrapper th.col-room_5,
  .price-tables.active-room-room_5 .wrap .price-table-wrapper td.col-room_5,
  .price-tables.active-room-room_6 .wrap .price-table-wrapper th.col-room_6,
  .price-tables.active-room-room_6 .wrap .price-table-wrapper td.col-room_6,
  .price-tables.active-room-room_7 .wrap .price-table-wrapper th.col-room_7,
  .price-tables.active-room-room_7 .wrap .price-table-wrapper td.col-room_7 {
    display: table-cell;
  }
  .price-tables.active-room-room_1 .wrap .price-table-wrapper th.col-room_1,
  .price-tables.active-room-room_2 .wrap .price-table-wrapper th.col-room_2,
  .price-tables.active-room-room_3 .wrap .price-table-wrapper th.col-room_3,
  .price-tables.active-room-room_4 .wrap .price-table-wrapper th.col-room_4,
  .price-tables.active-room-room_5 .wrap .price-table-wrapper th.col-room_5,
  .price-tables.active-room-room_6 .wrap .price-table-wrapper th.col-room_6,
  .price-tables.active-room-room_7 .wrap .price-table-wrapper th.col-room_7 {
    border-radius: 0 10px 0 0;
  }
  tbody tr:last-of-type td {
    border-radius: 0 0 10px 0;
  }
  tbody tr:last-of-type .coltxt {
    border-radius: 0;
  }
}
/* ハイライトロジック */
/* 親要素に active-room-room_1 があれば、col-room_1 クラスを持つ要素をハイライト */
.price-tables.active-room-room_1 .wrap .price-table-wrapper th.col-room_1 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_1 .wrap .price-table-wrapper td.col-room_1 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.price-tables.active-room-room_2 .wrap .price-table-wrapper th.col-room_2 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_2 .wrap .price-table-wrapper td.col-room_2 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.price-tables.active-room-room_3 .wrap .price-table-wrapper th.col-room_3 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_3 .wrap .price-table-wrapper td.col-room_3 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.price-tables.active-room-room_4 .wrap .price-table-wrapper th.col-room_4 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_4 .wrap .price-table-wrapper td.col-room_4 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.price-tables.active-room-room_5 .wrap .price-table-wrapper th.col-room_5 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_5 .wrap .price-table-wrapper td.col-room_5 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.price-tables.active-room-room_6 .wrap .price-table-wrapper th.col-room_6 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_6 .wrap .price-table-wrapper td.col-room_6 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.price-tables.active-room-room_7 .wrap .price-table-wrapper th.col-room_7 {
  background-color: #d72e77;
  color: #ffffff;
}
.price-tables.active-room-room_7 .wrap .price-table-wrapper td.col-room_7 {
  background-color: #f4dbe6;
  color: #d72e77;
}

.timetable {
  padding: 30px 0 80px;
  margin-bottom: 64px;
  position: relative;
}
.timetable:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  max-width: 1100px;
  height: 2px;
  background-color: #d72e77;
}
.timetable .hotelMds {
  padding-bottom: 40px;
}
.timetable .timetableWrap {
  max-width: 1100px;
  width: 100%;
  margin: auto;
}
.timetable .timetableWrap .timetable-image {
  width: 100%;
}
.timetable .timetableWrap .timetable-image img {
  width: 100%;
  border-radius: 10px;
}

@media only screen and (max-width: 767px) {
  .timetable {
    padding: 30px 0 40px;
    margin-bottom: 40px;
  }
  .timetable .hotelMds {
    padding-bottom: 24px;
  }
  .timetable .timetableWrap {
    width: 100%;
    margin: auto;
    padding-bottom: 0;
    overflow-x: scroll;
  }
  .timetable .timetableWrap .timetable-image {
    margin-left: 5%;
    margin-right: 5%;
    width: 240vw;
  }
  .timetable .timetableWrap .timetable-image img {
    border-radius: 10px;
  }
}
#pageTop.kanazawa .innerWrap {
  background-color: #e6deef;
}
#pageTop.riverside .innerWrap {
  background-color: #e8f2f6;
}
#pageTop.morimoto .innerWrap {
  background-color: #e8f9ed;
}/*# sourceMappingURL=hotel.css.map */