.detail-btn {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 88px;
  height: 55px;
  background-image: url(../../assets/img/point.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 10;
  pointer-events: auto;
}
.detail-btn.opt {
  width: 93px;
  background-image: url(../../assets/img/option.png);
}

.detail-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(71, 70, 69, 0.9);
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  display: none;
}
.detail-modal__panel {
  position: relative;
  width: 638px;
  max-height: 90vh;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
  box-sizing: border-box;
  background-color: #FFF;
}
@media screen and (max-width: 768px) {
  .detail-modal__panel {
    width: 315px;
    max-height: 80vh;
  }
}
.detail-modal__scroll-wrapper {
  width: 100%;
  max-height: 90vh;
  overflow: auto;
}
@media screen and (max-width: 768px) {
  .detail-modal__scroll-wrapper {
    max-height: 80vh;
  }
}
.detail-modal__scroll-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  box-sizing: border-box;
  padding: 80px 0;
}
@media screen and (max-width: 768px) {
  .detail-modal__scroll-container {
    padding: 51px 0 32px;
  }
}
.detail-modal__title {
  box-sizing: border-box;
  font-size: 30px;
  line-height: 1.5;
  color: #DC000C;
  margin-bottom: 44px;
  text-align: left;
  padding: 0 114px;
}
.detail-modal__title > span {
  font-size: 15px;
}
@media screen and (max-width: 768px) {
  .detail-modal__title {
    font-size: 22px;
    line-height: 30px;
    margin-bottom: 30px;
    padding: 0 26px;
  }
  .detail-modal__title > span {
    font-size: 11px;
  }
}
.detail-modal__body {
  box-sizing: border-box;
  width: 100%;
  font-size: 20px;
  line-height: 34px;
  text-align: left;
  padding: 0 114px;
}
@media screen and (max-width: 768px) {
  .detail-modal__body {
    font-size: 14px;
    line-height: 28px;
    margin-bottom: 40px;
    padding: 0 26px;
  }
}
.detail-modal__img {
  box-sizing: border-box;
  width: 100%;
  padding: 30px 35px 0;
}
.detail-modal__img > img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .detail-modal__img {
    padding: 0px 26px 40px;
  }
}
.detail-modal__table {
  box-sizing: border-box;
  width: 100%;
  padding: 0 114px;
}
@media screen and (max-width: 768px) {
  .detail-modal__table {
    padding: 0 26px;
  }
}
.detail-modal__table--before {
  margin-bottom: 30px;
}
@media screen and (max-width: 768px) {
  .detail-modal__table--before {
    margin-bottom: 20px;
  }
}
.detail-modal__table--after {
  margin-top: 30px;
}
@media screen and (max-width: 768px) {
  .detail-modal__table--after {
    margin-top: -20px;
    margin-bottom: 40px;
  }
}
.detail-modal__table > table {
  width: 100%;
  border-collapse: collapse;
}
.detail-modal__table > table td {
  font-size: 20px;
  line-height: 34px;
  border: solid 1px black;
  padding: 0 18px;
}
@media screen and (max-width: 768px) {
  .detail-modal__table > table td {
    font-size: 14px;
    line-height: 28px;
    padding: 0 10px;
  }
}
.detail-modal__table > table td.plan {
  text-align: left;
  width: 329px;
}
@media screen and (max-width: 768px) {
  .detail-modal__table > table td.plan {
    width: 180px;
  }
}
.detail-modal__close-btn-sp {
  box-sizing: border-box;
  width: 263px;
  height: 52px;
  margin: 0 auto;
  border: 1px solid #707070;
  -moz-border-radius: 26px;
  -webkit-border-radius: 26px;
  border-radius: 26px;
  font-size: 20px;
  line-height: 52px;
  color: #000;
  text-align: center;
  text-decoration: none;
}
.detail-modal__close-btn-sp:visited {
  color: #000;
  text-decoration: none;
}
.detail-modal__close-btn-sp:hover {
  text-decoration: none;
}
@media screen and (min-width: 769px) {
  .detail-modal__close-btn-sp {
    display: none;
  }
}
.detail-modal__close-btn-pc {
  box-sizing: border-box;
  position: absolute;
  top: 0;
  right: 0;
  line-height: 9999px;
  text-indent: -1000%;
  white-space: nowrap;
  overflow: hidden;
  width: 78px;
  height: 78px;
  background-image: url(../../assets/img/closeBtn.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 27px 27px;
}
@media screen and (max-width: 768px) {
  .detail-modal__close-btn-pc {
    display: none;
  }
}

.point-container {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 100;
}

@media screen and (min-width: 769px) {
  .previewContainer .premium-banner {
    width: 955px;
    height: 200px;
    margin: 0 auto 40px;
  }
}
@media screen and (max-width: 768px) {
  .previewContainer .premium-banner {
    box-sizing: border-box;
    width: 100%;
    padding: 0px 20px 20px;
  }
}
.previewContainer .premium-banner > img {
  width: 100%;
  height: auto;
}

.pc-only {
  display: block;
}
@media screen and (max-width: 768px) {
  .pc-only {
    display: none;
  }
}

.sp-only {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp-only {
    display: block;
  }
}
