@charset "UTF-8";
.owl-carousel {
  overflow: hidden;
}

/*------------------------------------------------
アポカリプスホテル
------------------------------------------------*/
#apocalypsehotel {
  display: block;
  margin: 0;
  padding: 0;
  background: #000;
  text-align: center;
  background: url("../img/bg_check2.webp") center top repeat-y;
  background-size: contain;
  /*------------------------------------------------
  メインイメージ
  ------------------------------------------------*/
  /*------------------------------------------------
  ページ内リンク
  ------------------------------------------------*/
  /*------------------------------------------------
  特典
  ------------------------------------------------*/
  /*------------------------------------------------
  ホテル一覧
  ------------------------------------------------*/
}
#apocalypsehotel .clearfix::after {
  content: "";
  display: block;
  clear: both;
}
#apocalypsehotel .wrapper {
  display: block;
  width: 86%;
  max-width: 1024px;
  margin: 0 auto;
  padding: 0;
  background: none;
}
@media (max-width: 1024px) {
  #apocalypsehotel .wrapper {
    width: 86%;
  }
}
@media (max-width: 800px) {
  #apocalypsehotel .wrapper {
    width: 90%;
  }
}
#apocalypsehotel .wrapper.wide {
  max-width: 1200px;
}
#apocalypsehotel .wrapper.nrw {
  max-width: 800px;
}
#apocalypsehotel .wrap {
  display: block;
  width: 86%;
  max-width: 800px;
  margin: 0 auto;
  padding: 0;
}
@media (max-width: 800px) {
  #apocalypsehotel .wrap {
    width: 80%;
  }
}
#apocalypsehotel .txtlist {
  text-align: left;
  margin: 0 0 5% 0;
  padding: 0;
  list-style: none;
  font-family: serif;
}
#apocalypsehotel .txtlist li {
  padding: 0 0 0 1.2em;
  position: relative;
  font-family: sans-serif;
}
#apocalypsehotel .txtlist li::before {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  position: absolute;
  top: 6px;
  left: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #eaa100 0%, #ffdc87 100%);
}
#apocalypsehotel .txtlist.lrg li {
  font-size: 24px;
  margin: 20px 0;
}
@media (max-width: 680px) {
  #apocalypsehotel .txtlist.lrg li {
    font-size: 18px;
  }
}
#apocalypsehotel .txtlist.lrg li::before {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  position: absolute;
  top: 10px;
  left: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, #eaa100 0%, #ffdc87 100%);
}
#apocalypsehotel ul.note {
  margin: 5% 0;
  padding: 0;
  list-style: none;
  text-align: left;
  color: #fff;
}
@media (max-width: 680px) {
  #apocalypsehotel ul.note {
    text-align: center;
  }
}
#apocalypsehotel ul.note li {
  padding: 0 0 5px 1.2em;
  position: relative;
  font-size: 16px;
}
#apocalypsehotel ul.note li::before {
  content: "※";
  display: inline-block;
  position: absolute;
  left: 0;
}
@media (max-width: 680px) {
  #apocalypsehotel ul.note li {
    text-align: left;
  }
  #apocalypsehotel ul.note li::before {
    content: "※";
    display: inline-block;
    position: absolute;
    left: 0;
  }
}
#apocalypsehotel .lead {
  font-size: 24px;
  line-height: 2;
  font-weight: 400;
  display: block;
  margin: 0 auto 8%;
  padding: 0;
  text-align: left;
  font-family: serif;
}
@media (max-width: 680px) {
  #apocalypsehotel .lead {
    font-size: 14px;
  }
}
#apocalypsehotel .lead.lrg {
  font-size: 38px;
  line-height: 1.5;
  text-align: center;
}
@media (max-width: 680px) {
  #apocalypsehotel .lead.lrg {
    font-size: 18px;
  }
  #apocalypsehotel .lead.lrg br {
    display: block;
  }
}
#apocalypsehotel .lead.sml {
  font-size: 18px;
  text-align: center;
}
@media (max-width: 680px) {
  #apocalypsehotel .lead.sml {
    font-size: 14px;
    text-align: left;
  }
}
#apocalypsehotel .lead.txc {
  text-align: center;
}
@media (max-width: 680px) {
  #apocalypsehotel .lead.txc {
    text-align: left;
  }
}
#apocalypsehotel .mds {
  font-size: 24px;
  line-height: 1.4;
  font-weight: 600;
  padding: 0;
  margin: 3% 0;
  position: relative;
  color: #000;
  font-family: serif;
}
#apocalypsehotel .mds span {
  display: inline-block;
  font-size: 14px;
  line-height: 1;
  font-weight: 600;
  margin: 0 10px 0 0;
  padding: 4px 10px;
  box-sizing: border-box;
  background: #efcb6b;
  color: #fff;
  vertical-align: middle;
}
@media (max-width: 680px) {
  #apocalypsehotel .mds {
    font-size: 20px;
  }
  #apocalypsehotel .mds br {
    display: block;
  }
}
@media (max-width: 680px) {
  #apocalypsehotel .note {
    text-align: left;
  }
}
#apocalypsehotel .notelist {
  margin: 0 3% 5% 3%;
  padding: 0;
  list-style: none;
  font-family: serif;
  text-align: left;
}
@media (max-width: 680px) {
  #apocalypsehotel .notelist {
    text-align: center;
  }
}
#apocalypsehotel .notelist li {
  padding: 0 0 5px 1.2em;
  position: relative;
  font-size: 14px;
}
#apocalypsehotel .notelist li::before {
  content: "※";
  display: inline-block;
}
@media (max-width: 680px) {
  #apocalypsehotel .notelist li {
    text-align: left;
  }
  #apocalypsehotel .notelist li::before {
    content: "※";
    display: inline-block;
    position: absolute;
    left: 0;
  }
}
#apocalypsehotel #mainttl {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0 0 3% 0;
  background: #492B49;
}
#apocalypsehotel .ttl {
  display: block;
  margin: 0;
  padding: 0 0 3% 0;
  text-align: center;
  box-sizing: border-box;
  color: #fff;
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #846684 0%, #846684 30%, #4d2a4d 60%);
}
#apocalypsehotel .ttl::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/bg_wallpaper.webp") center top repeat-y;
  background-size: contain;
  z-index: 0;
  position: absolute;
  top: 0;
  left: 0;
}
#apocalypsehotel .ttl .ttlimg {
  display: block;
  width: 100%;
  margin: 0;
  padding: 0;
  text-align: center;
  position: relative;
  font-size: 0;
  z-index: 1;
}
#apocalypsehotel .ttl .ttlimg img {
  width: 100%;
  height: auto;
}
#apocalypsehotel ul.tablinks {
  display: block;
  margin: 8% 0% 8% -5%;
  padding: 0;
  font-size: 0;
  position: relative;
  z-index: 2;
}
#apocalypsehotel ul.tablinks li {
  display: inline-block;
  box-sizing: border-box;
  width: 50%;
  margin: 0;
  padding: 0 0 0 5%;
  text-align: center;
  position: relative;
}
@media (max-width: 680px) {
  #apocalypsehotel ul.tablinks li {
    margin-bottom: 10px;
    width: 100%;
  }
}
#apocalypsehotel ul.tablinks li a {
  text-decoration: none;
  font-size: 24px;
  line-height: 1.4;
  font-weight: 600;
  display: block;
  padding: 4px 4px;
  position: relative;
  border: none;
  color: #000;
  margin: 0;
  border-radius: 40px;
  font-family: serif;
  background: linear-gradient(135deg, #ffcd55 0%, #eaa100 24%, #ffcd55 80%, #e59e00 100%);
  background-size: 100%;
  transition: all 0.4s ease;
}
@media (max-width: 680px) {
  #apocalypsehotel ul.tablinks li a {
    font-size: 18px;
  }
}
#apocalypsehotel ul.tablinks li a p {
  display: block;
  padding: 5px 5px;
  margin: 0;
  background: rgba(0, 0, 0, 0.1);
  border-radius: 40px;
  font-family: serif;
  transition: all 0.4s ease;
}
@media (max-width: 680px) {
  #apocalypsehotel ul.tablinks li a {
    border-width: 2px;
  }
}
#apocalypsehotel ul.tablinks li a span {
  display: block;
}
#apocalypsehotel ul.tablinks li a::after {
  display: block;
  width: 6px;
  height: 6px;
  margin: 0;
  border-left: 2px solid #fff;
  border-bottom: 2px solid #fff;
  content: "";
  z-index: 2;
  position: absolute;
  top: 50%;
  right: 15px;
  transform: rotate(-45deg) translateY(-100%);
}
#apocalypsehotel ul.tablinks li a:hover p {
  background: rgba(0, 0, 0, 0.3);
}
#apocalypsehotel .mds_cont {
  font-size: 48px;
  line-height: 1.4;
  font-weight: 500;
  padding: 0;
  margin: 0 0 20px 0;
  position: relative;
  background: #3B3B4E;
  background-size: 100%;
  font-family: serif;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
#tokuten #apocalypsehotel .mds_cont {
  background: #fff;
}
@media (max-width: 680px) {
  #apocalypsehotel .mds_cont {
    font-size: 32px;
  }
}
#apocalypsehotel .tokuten {
  display: block;
  position: relative;
  margin: 0;
  padding: 5% 0;
  text-align: center;
  background: #f5f5f5;
  overflow: hidden;
}
#apocalypsehotel .tokuten .inner {
  display: block;
  padding: 6vw;
  margin: 0 auto;
  position: relative;
  background: #3B3B4E;
  color: #fff;
  background: radial-gradient(circle at top left, transparent 30px, #3B3B4E 0) top left, radial-gradient(circle at top right, transparent 30px, #3B3B4E 0) top right, radial-gradient(circle at bottom right, transparent 30px, #3B3B4E 0) bottom right, radial-gradient(circle at bottom left, transparent 30px, #3B3B4E 0) bottom left;
  background-size: 50% 50%;
  background-repeat: no-repeat;
}
#apocalypsehotel .tokuten .inner::after {
  content: "";
  display: block;
  width: calc(100% - 6vw);
  height: calc(100% - 6vw);
  background: url("../img/bg_wallpaper2.webp") center top repeat-y #363648;
  background-size: contain;
  z-index: -1;
  position: absolute;
  top: 3vw;
  left: 3vw;
  border: 1px solid rgba(255, 255, 255, 0.18);
}
@media (max-width: 680px) {
  #apocalypsehotel .tokuten .inner {
    margin: 0 auto 5% auto;
  }
}
#apocalypsehotel .tokuten .inner .mds_cont {
  font-size: 48px;
  line-height: 1.4;
  font-weight: 500;
  padding: 0;
  margin: 0 0 10px 0;
  position: relative;
  background: linear-gradient(135deg, #ffffff 0%, #ffffff 100%);
  background-size: 100%;
  font-family: serif;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
@media (max-width: 680px) {
  #apocalypsehotel .tokuten .inner .mds_cont {
    font-size: 32px;
  }
}
#apocalypsehotel .tokuten .inner .lead {
  line-height: 1.6;
  color: #fff;
  margin: 0;
}
#apocalypsehotel .tokuten .inner .owl-carousel {
  margin: 0;
}
#apocalypsehotel .tokuten .inner .mds_tokuten {
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.2) 25%, rgba(255, 255, 255, 0.2) 75%, rgba(255, 255, 255, 0) 100%);
  padding: 20px;
  font-size: 28px;
  font-family: serif;
  margin: 5% 0;
}
@media (max-width: 680px) {
  #apocalypsehotel .tokuten .inner .mds_tokuten {
    font-size: 18px;
    padding: 10px;
  }
}
#apocalypsehotel .tokuten .inner figure {
  display: block;
  margin: 0;
}
#apocalypsehotel .tokuten .inner figure img {
  width: 100%;
  height: auto;
}
#apocalypsehotel .yoyaku {
  display: block;
  margin: 2% auto;
  padding: 5% 0;
  position: relative;
}
#apocalypsehotel .yoyaku .inner {
  display: block;
  margin: 0 auto;
  padding: 0;
  box-sizing: border-box;
}
@media (max-width: 680px) {
  #apocalypsehotel .yoyaku .inner {
    padding: 8% 0;
    width: 86%;
  }
}
#apocalypsehotel .yoyaku .inner .planttl {
  background: #bf1111;
  color: #fff;
  font-size: 24px;
  line-height: 1.3;
  font-family: serif;
  padding: 15px 0;
}
#apocalypsehotel .yoyaku .inner .planinfo {
  font-size: 24px;
  font-family: serif;
  margin: 0;
  padding: 10px 0;
}
#apocalypsehotel .yoyaku .inner .planinfo span {
  display: block;
  font-size: 14px;
}
@media (max-width: 680px) {
  #apocalypsehotel .yoyaku .inner .planinfo span {
    font-size: 12px;
  }
}
#apocalypsehotel .yoyaku .inner .planinfo br.sp {
  display: none;
}
@media (max-width: 680px) {
  #apocalypsehotel .yoyaku .inner .planinfo {
    font-size: 18px;
  }
  #apocalypsehotel .yoyaku .inner .planinfo br {
    display: block;
  }
  #apocalypsehotel .yoyaku .inner .planinfo br.sp {
    display: block;
  }
}
#apocalypsehotel .yoyaku .inner .btn_reserve {
  display: inline-block;
  background: #3B3B4E;
  padding: 10px 20px;
  font-size: 20px;
  margin: 10px auto;
  color: #fff;
  border: 2px solid transparent;
  border-radius: 30px;
  text-align: center;
  border: none;
  width: 240px;
  position: relative;
  box-sizing: border-box;
}
#apocalypsehotel .yoyaku .inner .btn_reserve.mem {
  background: #846684;
}
#apocalypsehotel .yoyaku .inner .btn_reserve.mem:hover {
  background: #846684;
  opacity: 0.8;
}
#apocalypsehotel .yoyaku .inner .btn_reserve.pc {
  display: inline-block;
}
#apocalypsehotel .yoyaku .inner .btn_reserve.sp {
  display: none;
}
@media (max-width: 680px) {
  #apocalypsehotel .yoyaku .inner .btn_reserve.pc {
    display: none;
  }
  #apocalypsehotel .yoyaku .inner .btn_reserve.sp {
    display: block;
    width: 100%;
  }
}
#apocalypsehotel .yoyaku .inner .btn_reserve:hover {
  background: #3B3B4E;
  opacity: 0.8;
}
#apocalypsehotel .yoyaku .inner .btn_reserve::after {
  display: block;
  vertical-align: middle;
  margin: 0;
  content: "";
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg) translateY(-50%);
  position: absolute;
  top: 50%;
  right: 25px;
}
#apocalypsehotel .note_col {
  display: block;
  margin: 0;
  padding: 0 0 5% 0;
}
@media (max-width: 680px) {
  #apocalypsehotel .note_col .wrap {
    width: 100%;
    padding: 0;
  }
}

/*------------------------
クラブモントレリンク
------------------------*/
.res_bnr {
  position: fixed;
  top: inherit;
  bottom: 0;
  width: 100%;
  max-width: inherit;
  margin: 0px;
  z-index: 10000;
  background-color: rgb(0, 0, 0);
}
.res_bnr .wrap {
  display: block;
  margin: 0;
  padding: 0;
  text-align: center;
}
.res_bnr .wrap a {
  display: block;
  box-sizing: border-box;
  font-size: 12px;
  margin: 0;
  padding: 10px 40px;
  color: #000;
  text-align: center;
  background-image: linear-gradient(135deg, rgb(255, 255, 255) 0%, rgb(214, 214, 214) 12%, rgb(255, 255, 255) 25%, rgb(214, 214, 214) 68%, rgb(235, 235, 235) 83%, rgb(255, 255, 255) 100%);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  vertical-align: middle;
  position: relative;
}
@media (max-width: 680px) {
  .res_bnr .wrap a {
    padding: 3%;
  }
}
.res_bnr .wrap a:hover {
  opacity: 0.9;
}
.res_bnr .wrap a::before {
  position: absolute;
  top: 50%;
  right: 15px;
  display: block;
  width: 10px;
  height: 10px;
  margin: -5px 0 0 0;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: rotate(45deg);
  content: "";
}
.res_bnr .wrap a h2 {
  font-size: 13px;
  display: inline-block;
  margin: 0;
  padding: 5px 10px;
  vertical-align: middle;
}
@media (max-width: 680px) {
  .res_bnr .wrap a h2 {
    display: block;
    margin: 0;
    background: none;
    padding: 0;
    text-align: left;
  }
}
.res_bnr .wrap a p {
  font-size: 12px;
  display: inline-block;
  margin: 0;
  padding: 5px 30px 5px 0;
  vertical-align: middle;
}
@media (max-width: 680px) {
  .res_bnr .wrap a p {
    display: block;
    margin: 5px 0 0 0;
    background: none;
    padding: 0 20% 0 0;
    text-align: left;
    line-height: 1.6;
  }
}
.res_bnr .wrap a .login {
  display: block;
  margin: 0;
  padding: 5px 0;
  vertical-align: middle;
  font-size: 12px;
  line-height: 1;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
}

/*------------------------------------------------
	SNSボタン表示スタイル
	------------------------------------------------*/
#pagebottom {
  position: relative;
  margin: 0 0 20px 0;
}

#pagebottom p {
  padding: 0;
  margin: 0;
}

#pagebottom .social {
  width: 100%;
  z-index: 100;
}

#pagebottom .social p {
  float: left;
}

#pagebottom .social p.tweet {
  margin: 0px 0 0 0;
  padding: 0 0px 0 0;
  width: 100px;
}

#pagebottom .social .mixi-btn {
  margin: 0px 15px 0 0;
  padding: 0;
}

/*-------------------------ホテル一覧------------------------*/
.special_hotellist {
  margin: 0;
  padding: 3em 0 0;
  background: #ddd;
  display: block;
}

.special_hotellist #hotellist {
  width: 880px;
  margin: 0 auto;
  padding: 0 40px 2em;
}

.special_hotellist #hotellist h2 {
  text-align: center;
  font-size: 22px;
  color: #000;
}

.special_hotellist #hotellist .flexslider a {
  font-size: 0.8em;
}

@media (max-width: 880px) {
  .special_hotellist #hotellist {
    width: 80%;
  }
}
@media (max-width: 680px) {
  .special_hotellist #hotellist {
    width: 70%;
  }
}
/*-------------------------新レイアウト調整用------------------------*/
.breadcrumb,
footer {
  background: #FFF;
  margin: 0px 0 0;
  border-top: 0 solid rgba(0, 0, 0, 0.1);
}

/*-------------------------コロナ対策------------------------*/
.coronavirus {
  width: 90%;
  margin: 30px auto !important;
  padding: 0;
}

.coronavirus li {
  width: 48% !important;
  display: inline-block;
}

.coronavirus li:first-child {
  margin: 0 20px 0 0;
}

.coronavirus li img {
  width: 100%;
}

.coronavirus li a:hover img {
  opacity: 0.6;
}

.coronavirus .pc {
  display: block;
}

.coronavirus .sp {
  display: none;
}

@media (max-width: 680px) {
  .coronavirus .pc {
    display: none;
  }
  .coronavirus .sp {
    display: block;
  }
  .coronavirus li {
    width: 100% !important;
    display: inline-block;
  }
  .coronavirus li:first-child {
    margin: 0 0 10px 0;
  }
}
/*-------------------------you tube------------------------*/
.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  margin: 0 0 2% 0;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}