@charset "UTF-8";

@font-face {
  font-family: "Noto Sans JP";
  src: url("/common/fonts/NotoSansJP/NotoSansJP-Regular.otf") format("opentype"),
    url("/common/fonts/NotoSansJP/NotoSansJP-Medium.otf") format("opentype"),
    url("/common/fonts/NotoSansJP/NotoSansJP-Bold.otf") format("opentype");
}

* {
  font-family: "Noto Sans JP", "Noto Sans CJK JP", Arial, "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, "メイリオ", "ＭＳ Ｐゴシック", sans-serif !important;
}

p {
  margin: 0;
}


/*** common ***/

.cinemagift_wrap {
  color: #000;
  font-size: 16px;
  text-align: left;
}

.cinemagift_block {
  max-width: 950px;
  padding: 50px 20px 0;
  margin: 0 auto;
}

.cinemagift_block h2 {
  font-size: 26px;
  font-weight: bold;
  border-bottom: 1px solid #000;
  padding-bottom: 5px;
  margin: 0 0 20px;
}


@media screen and (min-width:640px) {

  .cinemagift_block {
    max-width: 950px;
    padding: 70px 20px 0;
  }

  .cinemagift_block h2 {
    font-size: 32px;
    margin: 0 0 30px;
  }

}


/***** mv *****/

.mv img {
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
}


/***** list *****/

.appeal__box__list {
  padding: 0;
  margin: 0;
}

.appeal__box__list li {
  position: relative;
  font-size: 15px;
  font-weight: bold;
  padding-left: 25px;
  list-style: none;
}

.appeal__box__list li:not(:last-child) {
  margin-bottom: 1.2em;
}

.appeal__box__list li::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: solid 4px #b60081;
  position: absolute;
  top: 0;
  left: 0;
}

.appeal__box__list li span {
  display: block;
  font-size: 12px;
  text-indent: -1em;
  margin-top: 5px;
  margin-left: 1em;
}


@media screen and (min-width:640px) {

  .appeal__box__list li {
    font-size: 24px;
    padding-left: 50px;
  }

  .appeal__box__list li::before {
    width: 20px;
    height: 20px;
    border: solid 5px #b60081;
    top: 4px;
    left: 0;
  }

  .appeal__box__list li span {
    font-size: 16px;
  }

}


/***** example *****/

ul.example {
  margin: 0;
}

ul.example li {
  text-indent: -1em;
  margin-left: 1em;
}

ul.example li:not(:last-child) {
  margin-bottom: 1em;
}


@media screen and (min-width:640px) {

  ul.example {
    display: flex;
    flex-wrap: wrap;
  }

  ul.example li {
    width: calc(50% - 2em);
  }

  ul.example li:nth-child(odd) {
    margin-right: 2em;
  }

}


/***** use *****/

.use_box img.ticket-image {
  display: block;
  width: 102px;
  height: auto;
  border-radius: 6px;
  border: 1px solid #ccc;
  margin: 0 auto 20px;
}

.use_btn {
  text-align: center;
}

.use_btn .btn:first-child {
  margin-bottom: 20px;
}

.use_btn a {
  position: relative;
  display: block;
  background-color: #fff;
  color: #000;
  text-align: center;
  text-decoration: none;
  border: 1px solid #707070;
  border-radius: 7px;
  padding: 1em 0;
}

.use_btn a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-top: 2px;
  border-left: 2px solid #b60081;
  border-top: 2px solid #b60081;
  transform: translateY(-50%) rotate(135deg);
}

@media screen and (min-width:640px) {

  .use_box {
    display: flex;
  }

  .use_box img.ticket-image {
    width: 144px;
    border-radius: 8px;
    margin: 0 50px 0 0;
  }

  .use_btn a {
    width: 430px;
  }

  .use_btn a:hover {
    background-color: #cc45a3;
    color: #fff;
  }

  .use_btn a:hover::after {
    border-left: 2px solid #fff;
    border-top: 2px solid #fff;
  }

}


/***** theater_guidance *****/

.theater_guidance {
  background-color: #E8F1FA;
  padding: 20px;
}

.theater_guidance p {
  font-weight: bold;
}

.pc_br {
  display: none;
}

.theater_guidance a {
  position: relative;
  display: block;
  background-color: #cc45a3;
  color: #fff;
  text-align: center;
  text-decoration: none;
  border: 1px solid #707070;
  border-radius: 7px;
  padding: 1em 0;
  margin-top: 20px;
}

.theater_guidance a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 15px;
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-top: 2px;
  border-left: 2px solid #fff;
  border-top: 2px solid #fff;
  transform: translateY(-50%) rotate(135deg);
}


@media screen and (min-width:640px) {

  .theater_guidance {
    padding: 30px;
  }

  .theater_guidance p {
    text-align: center;
  }

  .pc_br {
    display: block;
  }

  .theater_guidance a {
    width: 430px;
    margin: 30px auto 0;
  }

  .theater_guidance a:hover {
    background-color: #fff;
    color: #000;
  }

  .theater_guidance a:hover::after {
    border-left: 2px solid #b60081;
    border-top: 2px solid #b60081;
  }

}


/***** caution *****/

ul.caution {
  font-size: 14px;
  padding: 0 0 70px;
  margin: 0;
}

ul.caution li {
  list-style: none;
  line-height: 1.5;
  text-indent: -1em;
  margin-left: 1em;
}