@charset "UTF-8";
/* ===== module */
/* --- sns-button --- */
.sns-button {
  padding-bottom: 40px;
}
.sns-button:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}

.sns-button__list {
  margin-bottom: 40px;
  padding-left: 0;
  list-style-type: none; 
  text-align: center;
  font-size: 0;
}
@media only screen and (max-width: 37.5em) {
  .sns-button__list {
    margin-bottom: 20px;
  }
}

.sns-button__item {
  position: relative; 
  display: inline-block;
  padding: 15px 0;
  width: 140px;
}
@media only screen and (max-width: 37.5em) {
  .sns-button__item {
    max-width: 100px; 
    width: 30%;
  }
}

.sns-button-facebook {
  background-color: #3b5998;
}

.sns-button-twitter {
  background-color: #0F1419;
}

.sns-button-line {
  background-color: #00c300;
}

.sns-button__svg {
  width: 20px;
  height: 20px; 

  fill: #fff;
}

/* --- sns-button --- */
/* ===== page-module */
/* --- events-list --- */
.events-list {
  padding-bottom: 40px;
}
.events-list:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}
.home .events-list {
  background-color: #f8f8f8;
}
.home .events-list .btn {
  margin-bottom: 40px;
}

.events-list__box {
  position: relative; 
  margin-bottom: 40px;
  padding-bottom: 15px;
  width: 48%;
}
.events-list__box:nth-child(2n+1) {
  float: left;
}
.events-list__box:nth-child(2n) {
  float: right;
}
.events-list__box:before {
  position: absolute; 
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
  background-color: #e5e5e5;
  content: "";
}
.events-list__box:after {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 0;
  height: 2px;
  background-color: #000;
  content: "";
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); 
  transition-duration: 0.4s;
  transition-property: width;
}
@media only screen and (max-width: 37.5em) {
  .events-list__box:after {
    width: 100%;
  }
}
.events-list__box:hover:after {
  width: 100%;
}
@media only screen and (max-width: 37.5em) {
  .events-list__box {
    margin-bottom: 20px; 
    width: 100%;
  }
  .events-list__box:nth-child(n) {
    float: none;
  }
}

.events-list__box__bg-img {
  margin-bottom: 15px;
}

.events-list__box__date {
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1.4rem;
}

.events-list__box__title {
  margin-top: 0;
  margin-bottom: 10px; 
  font-weight: normal;
  font-size: 2rem;
}

/* --- events-list --- */
/* --- event-detail --- */
.event-detail__schedule {
  margin: auto;
  margin-bottom: 40px; 
  text-align: center;
  font-size: 1.6rem;
}
@media only screen and (max-width: 37.5em) {
  .event-detail__schedule {
    margin-bottom: 20px;
    font-size: 1.4rem;
  }
}

.event-detail__slider {
  position: relative;
}
.event-detail__slider .wrapper {
  position: relative;
}
@media only screen and (max-width: 37.5em) {
  .event-detail__slider .wrapper {
    margin: auto; 
    width: 100%;
  }
}
.event-detail__slider:before {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 220px;
  background-color: #f8f8f8; 
  content: "";
}

.event-detail__slider__inner {
  overflow: hidden; 
  margin-right: auto;
  margin-left: auto;
  max-width: 800px;
  width: 100%;
}
@media only screen and (max-width: 54.34783em) {
  .event-detail__slider__inner {
    margin-right: 4%; 
    margin-left: 4%;
    width: 92%;
  }
}
@media only screen and (max-width: 37.5em) {
  .event-detail__slider__inner {
    margin: auto; 
    width: 100%;
  }
}

.event-detail__slider__caption {
  position: relative; 
  overflow: hidden;
  margin: 20px auto 0;
  max-width: 768px;
  width: 92%;
  height: 44px;
  color: #666;
  text-align: center;
  font-size: 1.1rem;
}

.event-detail__slider__item {
  position: relative;
  z-index: 1; 
  float: left;
  outline: none;
}
.event-detail__slider__item:before {
  display: block;
  padding-top: 57.5%; 
  width: 100%;
  content: "";
}
.event-detail__slider__item img {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 2; 
  display: block;
  margin: auto;
  max-width: 100%;
  width: auto;
  height: 100%;
}

.event-detail__lead-text {
  padding-top: 40px;
  padding-bottom: 40px; 
  background-color: #f8f8f8;
}
@media only screen and (max-width: 37.5em) {
  .event-detail__lead-text {
    padding-top: 20px;
    padding-bottom: 20px;
    font-size: 1.2rem;
  }
}

.event-detail__lead-text__inner {
  margin: auto; 
  margin-right: auto;
  margin-left: auto;
  max-width: 800px;
  width: 100%;
  font-size: 1.4rem;
  font-family: "メイリオ", "Meiryo", "游ゴシック", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
}
@media only screen and (max-width: 54.34783em) {
  .event-detail__lead-text__inner {
    margin-right: 4%; 
    margin-left: 4%;
    width: 92%;
  }
}

.event-detail__description {
  padding-top: 40px;
}
@media only screen and (max-width: 37.5em) {
  .event-detail__description {
    padding-top: 20px;
  }
}

.event-detail__description__content:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}

.event-detail__description__list {
  position: relative;
  margin-top: 0;
  margin-bottom: 40px; 
  width: 48%;
}
@media only screen and (max-width: 37.5em) {
  .event-detail__description__list {
    margin-bottom: 0; 
    width: 100%;
  }
  .event-detail__description__list:nth-child(n) {
    float: none;
  }
  .event-detail__description__list:last-child {
    margin-bottom: 20px;
  }
}
.event-detail__description__list:nth-child(2n+1) {
  float: left;
}
.event-detail__description__list:nth-child(2n) {
  float: right;
}

.event-detail__description__title {
  float: left;
  padding: 15px 0; 
  width: 100px;
}

.event-detail__description__data {
  margin-top: -1px;
  margin-left: 0;
  padding: 15px 0; 
  padding-left: 120px;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}

/* --- event-detail --- */
/* --- slick-slide --- */
.event-detail__slider .slick-arrow {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 10; 
  margin: auto;
  width: 44px;
  height: 44px;
  outline: none;
  border: none;
  background-color: transparent;
  color: transparent;
}
.event-detail__slider .slick-arrow:before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0; 
  left: 0;
  display: block;
  margin: auto;
  width: 100%;
  width: 24px;
  height: 100%;
  height: 24px;
  content: "";
}
@media only screen and (max-width: 37.5em) {
  .event-detail__slider .slick-arrow {
    display: none !important;
  }
}

.event-detail__slider .slick-prev {
  left: 0;
}
.event-detail__slider .slick-prev:before {
  border-top: 2px solid #000;
  border-left: 2px solid #000;
  -ms-transform: skewX(-1deg) rotate(-44deg);
      transform: skewX(-1deg) rotate(-44deg);
}

.event-detail__slider .slick-next {
  right: 0;
}
.event-detail__slider .slick-next:before {
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  -ms-transform: skewX(-1deg) rotate(44deg);
      transform: skewX(-1deg) rotate(44deg);
}

.event-detail__slider .slick-dots {
  clear: both;
  margin: auto;
  padding-top: 20px; 
  padding-left: 0;
  list-style-type: none;
  text-align: center;
}
@media only screen and (max-width: 37.5em) {
  .event-detail__slider .slick-dots {
    padding-top: 20px;
  }
}
.event-detail__slider .slick-dots li {
  position: relative;
  display: inline-block;
  margin: 0 5px; 
  width: 30px;
  height: 30px;
}
.event-detail__slider .slick-dots li button {
  display: none;
}
.event-detail__slider .slick-dots li:before {
  position: absolute; 
  top: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 30px;
  height: 3px;
  background-color: #ddd;
  content: "";
}
.event-detail__slider .slick-dots li:hover {
  cursor: pointer;
}
.event-detail__slider .slick-dots li:hover:before {
  background-color: #000;
}
.event-detail__slider .slick-dots .slick-active:before {
  background-color: #000;
}

/* --- other-event --- */
.other-event {
  padding-top: 40px;
  padding-bottom: 40px;
}
.other-event:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}
.other-event .btn {
  margin-bottom: 40px;
}

.other-event-gray {
  background-color: #f8f8f8;
}

.other-event__list {
  overflow: hidden; 
  padding-left: 0;
  list-style-type: none;
}
.other-event__list:after {
  display: block;
  visibility: hidden; 
  clear: both;
  height: 0;
  content: "";
}

.other-event__item {
  position: relative;
  float: left;
  margin: 0 10px 40px;
  padding-bottom: 20px;
  outline: none;
}
@media only screen and (max-width: 37.5em) {
  .other-event__item {
    margin-bottom: 20px; 
    padding-bottom: 10px;
  }
}
.other-event__item:before {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 2px;
  background-color: #e6e6e6; 
  content: "";
}
.other-event__item:after {
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 0;
  height: 2px;
  background-color: #000;
  content: "";
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); 
  transition-duration: 0.4s;
  transition-property: width;
}
@media only screen and (max-width: 37.5em) {
  .other-event__item:after {
    width: 100%;
  }
}
.other-event__item:hover:after {
  width: 100%;
}
.other-event__item:hover .other-event__item__img img {
  opacity: 0.9;
}
.other-event__item:hover .other-event__item__img:before,
.other-event__item:hover .other-event__item__img:after {
  background-color: #fff;
}
.other-event__item:hover .other-event__item__img:before {
  height: calc(100% - 51px);
}
.other-event__item:hover .other-event__item__img:after {
  width: calc(100% - 96px);
}

.other-event__item__bg-img {
  position: relative; 
  margin-bottom: 10px;
}
.other-event__item__bg-img img {
  width: 100%;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1); 
  transition-duration: 0.4s;
  transition-property: opacity;
}

.other-event__item__date,
.other-event__item__title,
.other-event__item__lead-text {
  margin-top: 0;
  margin-bottom: 5px;
}

.other-event__item__title {
  font-size: 1.5rem;
}

.other-event__item__lead-text {
  color: #666;
  font-size: 1.2rem;
  line-height: 1.6;
}

/* --- other-event --- */
.other-event__list .slick-dots {
  clear: both;
  margin: auto;
  padding-top: 40px; 
  padding-left: 0;
  list-style-type: none;
  text-align: center;
}
@media only screen and (max-width: 37.5em) {
  .other-event__list .slick-dots {
    padding-top: 0;
  }
}
.other-event__list .slick-dots li {
  position: relative;
  display: inline-block;
  margin: 0 5px; 
  width: 30px;
  height: 30px;
}
.other-event__list .slick-dots li button {
  display: none;
}
.other-event__list .slick-dots li:before {
  position: absolute; 
  top: 0;
  bottom: 0;
  display: block;
  margin: auto;
  width: 30px;
  height: 3px;
  background-color: #ddd;
  content: "";
}
.other-event__list .slick-dots li:hover {
  cursor: pointer;
}
.other-event__list .slick-dots li:hover:before {
  background-color: #000;
}
.other-event__list .slick-dots .slick-active:before {
  background-color: #000;
}