@charset "UTF-8";

.content-top {
  padding-bottom: 39px;
}

.content {
  background-color: #FFF;
}

.content__wrapper,
.event__inner {
  margin: 0 auto;
}


/* section class="main-visual"
----------------------------------------------- */
.main-Visual {
  margin: 0 auto;
}

.visual__image,
.visual__image--period {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  margin: 0;
}

.visual-lead__text {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1.125rem; /*18px*/
  line-height: 1.72;
  letter-spacing: 0.01em;
  text-align: center;
  padding: 21px 0 20px;
  color: #585957;
}

/*-------------------------
  認証ボタン表示 (未認証時表示)
-------------------------*/
.registration {
  margin-top: -9px;
}

.registration-warning {
  padding-top: 8px;
  padding-bottom: 21px;
}

/*-------------------------
  キャンペーンサイト一覧はこちら
-------------------------*/
.warning-site-link {
  padding: 19px 0 32px;
}

/*-------------------------
東海道新幹線車内限定コンテンツ
-------------------------*/
.ride-content {
  padding-bottom: 10px;
}

.event-heading {
  background-color: #F0A52D;
  text-align: center;
  align-items: center;
  justify-content: center;
  height: 112px;
  position: relative;
}

.event-heading__title {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1.125rem; /*18px*/
  line-height: 1.44;
  letter-spacing: 0.05em;
  text-align: center;
  color: #fff;
  top: 27px;
  position: relative;
}

.event-heading__title::before,
.event-heading__title::after {
  position: absolute;
  content: '';
  top: 0;
  bottom: 0;
  margin: auto 0;
  right: 43%;
  width: 100%;
  height: 22px;
  background-image: url(../images/star.svg);
  transform: translateX(50%);
  background-size: contain;
  background-repeat: no-repeat;
}

.event-heading__title::after {
  left: 36.3%;
}

.description-shinkansen--img {
  display: block;
  width: 99%;
  position: absolute;
  top: 71px;
  right: 0;
}

/*オリジナルボイスドラマ*/
.decoration {
  position: relative;
}

.decoration::before {
  position: absolute;
  content: "";
  top: 50%;
  width: 100%;
  height: 40px;
  left: 7%;
  background-image: url(../images/fork.webp);
  transform: translateY(-50%);
  background-size: contain;
  background-repeat: no-repeat;
}

.decoration::after {
  position: absolute;
  content: "";
  top: 50%;
  width: 100%;
  height: 40px;
  left: 88%;
  background-image: url(../images/knife.webp);
  transform: translateY(-50%);
  background-size: contain;
  background-repeat: no-repeat;
}

.benefits__wrapper {
  margin: 43px 0 0;
  background-color: #FFF5C0;
  padding: 18px 0;
}

.benefits__title {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1.44rem; /*23.06px*/
  line-height: 1.19;
  letter-spacing: 0.05em;
  text-align: center;
  color: #E18C05;
}

.description__title {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1rem; /*16px*/
  line-height: 1.6875;
  letter-spacing: 0.01em;
  text-align: center;
  padding: 16px 0 18px;
  color: #585957;
}

.color-orange {
  color: #E18C05;
}

.warning.original-voice {
  padding: 10px 0 0px;
}

.section-space {
  padding: 19px 0 11px;
}

.btn-list.side-story {
  padding: 7px 0 10px;
}

.period__text {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1.125rem; /*18px*/
  line-height: 1.66;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 4px 0 7px;
  color: #585957;
}

/* 五つ子と五教科クイズに挑戦*/
.quintuplets-quiz .benefits__wrapper {
  margin: 0;
  background-color: #d9ecf9;
  padding: 16px 0;
}

.quintuplets-quiz .benefits__title {
  color: #42A1DF;
}

.quintuplets-quiz .decoration::before {
  left: 13%;
}

.quintuplets-quiz .decoration::after {
  left: 82%;
}

.quintuplets-quiz .period__text {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1.3125rem; /*21px*/
  line-height: 0.952;
  letter-spacing: 0.05em;
  text-align: center;
  color: #42A1DF;
  padding: 15px 0 0;
}

.quintuplets-quiz .description__title {
  padding: 13px 0 19px;
}

.color-light-blue {
  color: #42A1DF;
}

.warning-list.participation {
  padding: 10px 0 28px;
}

.warning-list.participation .warning-list__item {
  font-family: Noto Sans JP;
  font-weight: 350;
  font-size: 0.6875rem; /*11px*/
  line-height: 1.818;
  letter-spacing: 0.05em;
}

.wallpaper-present {
  background-color: #d9ecf9;
  margin-bottom: 23px;
}

.sub-title {
  background-color: #42A1DF;
  position: relative;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 1.31rem; /*21px*/
  line-height: 1;
  letter-spacing: 0.05em;
  text-align: center;
  color: #fff;
  padding: 16px 0;
}

.sub-title::before,
.sub-title::after {
  position: absolute;
  content: '';
  top: 0;
  bottom: 0;
  margin: auto 0;
  right: 26.5%;
  width: 100%;
  height: 17px;
  background-image: url(../images/star.svg);
  transform: translateX(50%);
  background-size: contain;
  background-repeat: no-repeat;
}

.sub-title::after {
  left: 21.9%;
}

.wallpaper-present__text {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
  font-size: 0.9375rem; /*15px*/
  line-height: 1.33;
  letter-spacing: 0.05em;
  text-align: center;
  color: #585957;
  padding: 36px 0 43px;
}

.cards {
  display: grid;
  gap: 2.8%;
  grid-template-columns: repeat(5, 1fr);
  padding: 0 5.5% 0;
  margin: 0;
}

.card__img {
  width: 100%;
  aspect-ratio: 56 / 123;
  object-fit: contain;
}

.secret-wallpaper {
  padding: 18px 5.7% 26px;
}

.warning-list.secret-wallpaper {
    padding: 15px 0 50px;
}

.warning-list.secret-wallpaper .warning-list__item {
  font-family: Noto Sans JP;
  font-weight: 350;
  font-size: 0.6875rem; /*11px*/
  line-height: 1.818;
  letter-spacing: 0.05em;
}

/*東海道新幹線乗車特典*/
.riding-benefits .benefits__wrapper {
    margin: 0;
    background-color: #eadff3;
    padding: 16px 0;
}

.riding-benefits .benefits__title {
    color: #9761C4;
}

.riding-benefits .decoration::before {
  left: 22%;
}

.riding-benefits .decoration::after {
  left: 73%;
}

.color-light-purple {
  color: #9761C4;
}

.riding-benefits .description__title {
    padding: 20px 0 26px;
}

/*特典引換場所*/
.board {
  margin: 0 auto;
  color: #000;
  padding: 23px 0;
}

table {
  text-align: center;
  border: 1px solid #9761C4;
  width: 100%;
}

th {
  font-family: Noto Sans JP;
  font-weight: 900;
  font-size: 1.25rem; /*20px*/
  line-height: 1.25;
  letter-spacing: 0.05em;
  text-align: center;
  color: #9761C4;
  border-bottom: 1px solid #9761C4;
  padding: 10px;
}

tbody td {
  font-family: Noto Sans JP;
  font-weight: 700;
  font-size: 1.25rem; /*20px*/
  line-height: 1.35;
  letter-spacing: 0.06em;
  text-align: center;
  padding-top: 16px;
}

.line1 {
  padding-top: 19px;
}

tbody td > span {
  font-size: 1rem; /*16px*/
  line-height: 1;
}

tfoot td {
  font-family: Noto Sans JP;
  font-weight: 400;
  font-size: 0.75rem; /*12px*/
  line-height: 1.66;
  letter-spacing: 0.05em;
  text-align: left;
  padding: 22px 0 12px;
}

.warning-list.warning-riding-benefits {
  padding: 14px 0 35px;
}

.warning-list.warning-riding-benefits .warning-list__item {
  font-family: Noto Sans JP;
  font-weight: 350;
  font-size: 0.6875rem; /*11px*/
  line-height: 1.818;
  letter-spacing: 0.05em;
}

.link.link-bottom {
  padding: 36px 0 30px;
}

.date-of-expiry {
  font-family: Noto Sans JP;
  font-weight: 900;
  font-size: 0.9375rem; /*15px*/
  line-height: 1.66;
  letter-spacing: 0.05em;
  text-align: center;
  padding: 4px 0 10px;
  color: #000;
}

.btn-list:has(.btn__normal--on) .date-of-expiry {
  display: block;
  margin-top: -12px;
  margin-bottom: -11px;
}

.date-of-expiry {
  display: none;
}
