@charset "UTF-8";
@import url("/_themes/site/css/layouts/subsite-enjoy-calendar.css");

/* =========================================================
  enjoy
========================================================= */

/* site layout
----------------------------------------------- */
#pageHeader {
  position: relative;
}

#wrapper {
  border-bottom: 1px solid var(--mono-color-6);
  background: var(--mono-color-9);
}

#main {
  padding-top: 0 !important;
}

#content {
  max-width: 1000px;
}

@media only screen and (max-width: 959px) {
  #wrapper {
    padding-top: 0;
  }

  #main {
    padding-bottom: 20px !important;
  }
}

/* CKEditor templates
----------------------------------------------- */
@media only screen and (max-width: 534px) {
  .adobeReader {
    margin: 20px 0;
  }
}

/* docs more
----------------------------------------------- */
#enjoyInfo .pieceBody .more,
#enjoyGuide .pieceBody .more {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 15px 18px;
  padding-top: 18px;
  border-top: 1px dotted var(--mono-color-5);
}

#enjoyInfo .pieceBody .more > a,
#enjoyGuide .pieceBody .more > a {
  flex-grow: 1;
  padding: 6px 38px;
  border: 1px solid #3880ca;
  border-radius: 7px;
  background: url(/_themes/site/images/arrow-white.svg) right 17px center no-repeat #3880ca;
  color: var(--mono-color-9);
  font-size: 1.125rem;
  text-decoration: none;
  text-align: center;
}

#enjoyInfo .pieceBody .more a:hover,
#enjoyGuide .pieceBody .more a:hover {
  opacity: 0.6;
}

/* subsiteVisual
----------------------------------------------- */
#subsiteVisual .pieceBody h1 {
  display: block;
  position: relative;
  width: 100%;
  height: 420px;
}

#subsiteVisual .pieceBody h1 img {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  max-width: 2476px;
  height: 420px;
}

@media only screen and (max-width: 767px) {
  #subsiteVisual .pieceBody h1 {
    height: 180px;
  }

  #subsiteVisual .pieceBody h1 img {
    height: 180px;
  }
}

/* enjoyInfoTitle
----------------------------------------------- */
#enjoyInfoTitle {
  margin-top: 50px;
  margin-bottom: 20px;
}

#enjoyInfoTitle .pieceBody {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

#enjoyInfoTitle .pieceBody h2 {
  padding-left: 62px;
  background: url(/_themes/site/images/enjoy/ico_tit_info01.png) left 60% no-repeat;
  font-weight: 500;
  font-size: 2.5rem;
  font-family: "Zen Maru Gothic", sans-serif;
}

@media only screen and (max-width: 534px) {
  #enjoyInfoTitle {
    margin-top: 30px;
    margin-bottom: 10px;
  }

  #enjoyInfoTitle .pieceBody h2 {
    padding-left: 37px;
    background-size: 30px auto;
    font-size: 1.75rem;
  }
}

/* enjoyInfo
----------------------------------------------- */
#enjoyInfo {
  margin-bottom: 70px;
}

#enjoyInfo .pieceBody ul.docs {
  display: flex;
  flex-direction: column;
  gap: 26px;
  margin: 30px 0;
  overflow-x: hidden;
}

#enjoyInfo .pieceBody ul.docs li {
  display: flex;
  gap: 2px 12px;
  font-size: 1.125rem;
}

#enjoyInfo .pieceBody ul.docs li .update_date {
  flex-shrink: 0;
}

@media only screen and (max-width: 767px) {
  #enjoyInfo .pieceBody ul.docs li {
    flex-direction: column;
  }
}

@media only screen and (max-width: 534px) {
  #enjoyInfo {
    margin-bottom: 40px;
  }
}

/* enjoyMapTitle
----------------------------------------------- */
#enjoyMapTitle {
  position: relative;
  z-index: 0;
  padding: 50px 0 30px;
}

#enjoyMapTitle::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  z-index: -1;
  transform: translateX(-50%);
  width: 100vw;
  background: url(/_themes/site/images/enjoy/bg_spot-map01.png) center bottom repeat;
}

#enjoyMapTitle .pieceBody {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

#enjoyMapTitle .pieceBody h2 {
  padding-left: 78px;
  background: url(/_themes/site/images/enjoy/tit_map01.png) left 60% no-repeat;
  font-weight: 500;
  font-size: 2.5rem;
  font-family: "Zen Maru Gothic", sans-serif;
}

#enjoyMapTitle .pieceBody p a {
  display: block;
  margin-top: 14px;
  padding: 4px 30px 4px 20px;
  border-radius: 15px;
  background: url(/_themes/site/images/arrow-footer.svg) right 8px center / 14px auto no-repeat var(--mono-color-9);
  text-align: center;
}

@media only screen and (max-width: 959px) {
  #enjoyMapTitle {
    padding: 30px 0 15px;
  }
}

@media only screen and (max-width: 767px) {
  #enjoyMapTitle .pieceBody {
    margin-bottom: 10px;
  }
}

@media only screen and (max-width: 534px) {
  #enjoyMapTitle .pieceBody h2 {
    padding-left: 44px;
    background-size: 34px auto;
    font-size: 1.75rem;
  }
}

/* enjoyMap
----------------------------------------------- */
#enjoyMap {
  position: relative;
  z-index: 0;
  transform: translateX(-50%);
  width: 100vw;
  margin-left: 50%;
  padding: 0 30px 30px;
  background: url(/_themes/site/images/enjoy/bg_spot-map01.png) center center repeat;
}

@media only screen and (max-width: 959px) {
  #enjoyMap {
    transform: none;
    width: auto;
    margin-right: -16px;
    margin-left: -16px;
    padding: 0 0 15px;
  }
}

/* enjoyGuideTitle
----------------------------------------------- */
#enjoyGuideTitle {
  position: relative;
  z-index: 0;
  padding: 50px 0 30px;
}

#enjoyGuideTitle::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  z-index: -1;
  transform: translateX(-50%);
  width: 100vw;
  background: url(/_themes/site/images/enjoy/bg_guide01.png) center bottom repeat;
}

#enjoyGuideTitle .pieceBody {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

#enjoyGuideTitle .pieceBody h2 {
  padding-left: 100px;
  background: url(/_themes/site/images/enjoy/tit_guide01.png) left 60% no-repeat;
  font-weight: 500;
  font-size: 2.5rem;
  font-family: "Zen Maru Gothic", sans-serif;
}

@media only screen and (max-width: 534px) {
  #enjoyGuideTitle {
    padding: 30px 0 15px;
  }

  #enjoyGuideTitle .pieceBody h2 {
    padding-left: 50px;
    background-size: 40px auto;
    font-size: 1.75rem;
  }
}

/* enjoyGuide
----------------------------------------------- */
#enjoyGuide {
  position: relative;
  z-index: 0;
  padding: 0 0 70px;
}

#enjoyGuide::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  z-index: -1;
  transform: translateX(-50%);
  width: 100vw;
  background: url(/_themes/site/images/enjoy/bg_guide01.png) center top repeat;
}

#enjoyGuide .pieceBody ul.docs {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  margin-bottom: 30px;
}

#enjoyGuide .pieceBody ul.docs li {
  flex-basis: calc((100% - 60px) / 3);
  position: relative;
}

#enjoyGuide .pieceBody ul.docs li span {
  display: block;
}

#enjoyGuide .pieceBody ul.docs li .image {
  aspect-ratio: 3/2;
  margin-bottom: 10px;
}

#enjoyGuide .pieceBody ul.docs li .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#enjoyGuide .pieceBody ul.docs li .title_link a::before {
  content: "";
  position: absolute;
  inset: 0;
  background: none !important;
}

@media only screen and (max-width: 959px) {
  #enjoyGuide .pieceBody ul.docs li {
    flex-basis: calc((100% - 30px) / 2);
  }
}

@media only screen and (max-width: 534px) {
  #enjoyGuide {
    padding: 0 0 40px;
  }

  #enjoyGuide .pieceBody ul.docs li {
    flex-basis: 100%;
  }
}

/* enjoyCalendarTitle
----------------------------------------------- */
#enjoyCalendarTitle {
  padding: 50px 0 30px;
}

#enjoyCalendarTitle .pieceBody {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

#enjoyCalendarTitle .pieceBody h2 {
  padding-left: 80px;
  background: url(/_themes/site/images/enjoy/tit_calender01.png) left 60% no-repeat;
  font-weight: 500;
  font-size: 2.5rem;
  font-family: "Zen Maru Gothic", sans-serif;
}

@media only screen and (max-width: 534px) {
  #enjoyCalendarTitle {
    padding: 30px 0 15px;
  }

  #enjoyCalendarTitle .pieceBody h2 {
    padding-left: 48px;
    background-size: 35px auto;
    font-size: 1.75rem;
  }
}

/* enjoyCalendar
----------------------------------------------- */
#enjoyCalendar {
  padding-bottom: 30px;
}

@media only screen and (max-width: 534px) {
  #enjoyCalendar {
    padding-bottom: 0;
  }
}