/**
 * GBU Modal Plugin Styles (BEM Methodology)
 * Version: 1.0.0
 * Author: GBU Dev Team
 * 
 * BEM Structure:
 * .modal (Block)
 * .modal__overlay (Element)
 * .modal__container (Element)
 * .modal__content (Element)
 * .modal__close (Element)
 * .modal--show (Modifier)
 * .modal--image (Modifier)
 * .modal--iframe (Modifier)
 * .modal--inline (Modifier)
 * .modal--ajax (Modifier)
 * .modal--loading (Modifier)
 */
.modal-open {
  position: fixed;
  width: 100%;
  overflow: hidden;
}

.modal {
  --modal-overlay-opacity: 0;
  --modal-container-opacity: 0;
  --modal-container-transform: none;
}
@media (min-width: 751px) {
  .modal {
    --scale-factor: 1.47;
  }
}
.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 9999;
  display: none;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  opacity: var(--modal-overlay-opacity);
  -webkit-transition: opacity 0.3s ease-out;
  transition: opacity 0.3s ease-out;
}
.modal__container {
  position: relative;
  max-width: calc(100vw - 4.6875rem * var(--scale-factor, 1));
  max-height: 90vh;
  margin: calc(1.25rem * var(--scale-factor, 1));
  opacity: var(--modal-container-opacity);
  -webkit-transform: var(--modal-container-transform);
          transform: var(--modal-container-transform);
  -webkit-transition: opacity 0.3s ease-out, -webkit-transform 0.3s ease-out;
  transition: opacity 0.3s ease-out, -webkit-transform 0.3s ease-out;
  transition: opacity 0.3s ease-out, transform 0.3s ease-out;
  transition: opacity 0.3s ease-out, transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
.modal__container:focus {
  outline: none;
}
.modal__content {
  padding: calc(1.25rem * var(--scale-factor, 1)) 0;
  max-height: calc(90vh - 2.5rem * var(--scale-factor, 1));
  background-color: #fff;
  border: 1px solid #000078;
  border-radius: calc(1.25rem * var(--scale-factor, 1));
}
.modal__content::-webkit-scrollbar {
  width: calc(0.375rem * var(--scale-factor, 1));
}
.modal__content::-webkit-scrollbar-track {
  background: #f1f1f1;
  border-radius: calc(0.1875rem * var(--scale-factor, 1));
}
.modal__content::-webkit-scrollbar-thumb {
  background: #c1c1c1;
  border-radius: calc(0.1875rem * var(--scale-factor, 1));
}
.modal__content::-webkit-scrollbar-thumb:hover {
  background: #a8a8a8;
}
.modal__close {
  position: absolute;
  top: calc(1.125rem * var(--scale-factor, 1));
  right: calc(1.125rem * var(--scale-factor, 1));
  width: calc(1.4375rem * var(--scale-factor, 1));
  height: calc(1.4375rem * var(--scale-factor, 1));
  background: url("/assets/common/img/modal-close.png") no-repeat center center/100% auto;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  z-index: 99;
  border: none;
  font-size: 0;
}
.modal__close:hover, .modal__close:focus {
  -webkit-transform: scale(1.1);
          transform: scale(1.1);
  outline: none;
}
.modal__close:active {
  -webkit-transform: scale(0.95);
          transform: scale(0.95);
}
.modal__image {
  display: block;
  max-width: 100%;
  max-height: 95vh;
  height: auto;
  border-radius: calc(1.25rem * var(--scale-factor, 1));
}
.modal__iframe {
  width: 100%;
  height: 80vh;
  min-height: calc(25rem * var(--scale-factor, 1));
  border: none;
  border-radius: calc(1.25rem * var(--scale-factor, 1));
}
.modal__error {
  color: #d32f2f;
  text-align: center;
  padding: calc(1.25rem * var(--scale-factor, 1));
}
.modal--show {
  --modal-overlay-opacity: 1;
  --modal-container-opacity: 1;
}
.modal--closing {
  --modal-overlay-opacity: 0;
  --modal-container-opacity: 0;
}
.modal--blur .modal__overlay {
  backdrop-filter: blur(calc(0.1875rem * var(--scale-factor, 1)));
  -webkit-backdrop-filter: blur(calc(0.1875rem * var(--scale-factor, 1)));
}
.modal--image .modal__container {
  background: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
  max-width: 95vw;
  max-height: 95vh;
}
.modal--image .modal__content {
  padding: 0;
  background: transparent;
}
.modal--iframe .modal__container {
  max-width: 95vw;
  max-height: 95vh;
}
.modal--iframe .modal__content {
  padding: 0;
}
.modal--inline .modal__container {
  width: calc(100vw - 4.6875rem * var(--scale-factor, 1));
}
.modal--ajax .modal__container {
  max-width: calc(56.25rem * var(--scale-factor, 1));
  width: 90vw;
}
.modal--loading .modal__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-height: calc(12.5rem * var(--scale-factor, 1));
}
.modal--loading .modal__content::after {
  content: "";
  width: calc(2.5rem * var(--scale-factor, 1));
  height: calc(2.5rem * var(--scale-factor, 1));
  border: calc(0.25rem * var(--scale-factor, 1)) solid #f3f3f3;
  border-top: calc(0.25rem * var(--scale-factor, 1)) solid #3498db;
  border-radius: 50%;
  -webkit-animation: modal-spin 1s linear infinite;
          animation: modal-spin 1s linear infinite;
}

.js-slider {
  width: calc(12.0625rem * var(--scale-factor, 1));
  margin: 0 auto;
  position: relative;
}
.js-slider .slick-arrow {
  position: absolute;
  top: calc(8rem * var(--scale-factor, 1));
  width: calc(1.625rem * var(--scale-factor, 1));
  height: calc(2.125rem * var(--scale-factor, 1));
  font-size: 0;
  border: none;
}
.js-slider .slick-arrow.slick-next {
  left: calc(100% + 1.5625rem * var(--scale-factor, 1));
  background: url("/assets/common/img/btn_R-pink.png");
  background-size: 100% 100%;
}
.js-slider .slick-arrow.slick-prev {
  right: calc(100% + 1.5625rem * var(--scale-factor, 1));
  background: url("/assets/common/img/btn_L-pink.png");
  background-size: 100% 100%;
}
.js-slider .slick-dots {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: calc(1.9375rem * var(--scale-factor, 1));
}
.js-slider .slick-dots li {
  padding: 0 calc(0.40625rem * var(--scale-factor, 1));
  line-height: 0;
}
.js-slider .slick-dots li button {
  width: calc(1.0625rem * var(--scale-factor, 1));
  height: calc(1.125rem * var(--scale-factor, 1));
  border: none;
  font-size: 0;
  background: #000;
  background: url("/assets/common/img/icon-heart-w.svg") no-repeat center;
  background-size: 100% 100%;
  padding: 0;
}
.js-slider .slick-dots li.slick-active button {
  background: url("/assets/common/img/icon-heart-r.svg") no-repeat center;
  background-size: 100% 100%;
}

.txt-center {
  text-align: center;
}

.txt-underline span {
  display: inline-block;
  position: relative;
}
.txt-underline span:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: calc(0.125rem * var(--scale-factor, 1));
  background: url("/assets/common/img/path-underline.png") 12% repeat;
  background-size: auto 100%;
  border-radius: 1000px;
  overflow: hidden;
}

.header__yuid {
  display: none;
}

.section {
  position: relative;
  text-align: center;
}
.section-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
}
.section-bg:before {
  content: "";
  position: absolute;
  top: calc(14.375rem * var(--scale-factor, 1));
  left: 0;
  right: 0;
  bottom: 0;
}
.section-bg.bg-pink {
  background: url("/assets/letter/img/bg-heart-pink.png") no-repeat center top;
  background-size: 100%;
}
.section-bg.bg-pink:before {
  background: -webkit-gradient(linear, left top, left bottom, from(#ffcef1), to(var(--white)));
  background: linear-gradient(to bottom, #ffcef1, var(--white));
}
.section-bg.bg-blue {
  background: url("/assets/letter/img/bg-heart-blue.png") no-repeat center top;
  background-size: 100%;
}
.section-bg.bg-blue:before {
  background: -webkit-gradient(linear, left top, left bottom, from(#3ed3ff), to(var(--white)));
  background: linear-gradient(to bottom, #3ed3ff, var(--white));
}
.section-bg.bg-yellow {
  background: url("/assets/letter/img/bg-heart-yellow.png") no-repeat center top;
  background-size: 100%;
}
.section-bg.bg-yellow:before {
  background: -webkit-gradient(linear, left top, left bottom, from(var(--yellow)), to(var(--white)));
  background: linear-gradient(to bottom, var(--yellow), var(--white));
}
.section-content {
  position: relative;
  z-index: 2;
}
.section--ttl {
  line-height: 0;
}
.section--ttl span {
  display: inline-block;
  font-size: calc(0.875rem * var(--scale-factor, 1));
  line-height: calc(1.75rem * var(--scale-factor, 1));
  padding: 0 calc(0.625rem * var(--scale-factor, 1));
  background: #FF87FF;
  color: #000078;
  border-radius: 10000px;
  margin-bottom: calc(1rem * var(--scale-factor, 1));
  position: relative;
  letter-spacing: -0.05em;
}
.section--ttl span:before {
  content: "";
  position: absolute;
  top: calc(100% - 0.0625rem * var(--scale-factor, 1));
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  width: calc(1.1875rem * var(--scale-factor, 1));
  height: calc(0.6875rem * var(--scale-factor, 1));
  background: #FF87FF;
  -webkit-mask-image: url("/assets/common/img/title-arrow.svg");
          mask-image: url("/assets/common/img/title-arrow.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
.section-txt-intro {
  font-size: calc(0.8125rem * var(--scale-factor, 1));
  color: #000078;
  line-height: calc(1.5rem * var(--scale-factor, 1));
  margin-top: calc(1.5rem * var(--scale-factor, 1));
  margin-bottom: calc(1.4375rem * var(--scale-factor, 1));
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.section01 {
  padding: calc(2.5rem * var(--scale-factor, 1)) 0 0;
}
.section01 .section--ttl img {
  width: calc(19.625rem * var(--scale-factor, 1));
}
.section01 .section--ttl span {
  margin-bottom: calc(1.6875rem * var(--scale-factor, 1));
}
.section01 .section-txt-intro {
  margin-bottom: calc(1.6875rem * var(--scale-factor, 1));
}

.js-slider {
  width: calc(12.125rem * var(--scale-factor, 1));
}

.section02 {
  position: relative;
}
.section02 .icon {
  position: absolute;
}
.section02 .icon.icon1 {
  top: calc(2.625rem * var(--scale-factor, 1));
  left: calc(1.125rem * var(--scale-factor, 1));
  width: calc(3.5625rem * var(--scale-factor, 1));
}
.section02 .icon.icon2 {
  top: calc(4.1875rem * var(--scale-factor, 1));
  right: calc(2.1875rem * var(--scale-factor, 1));
  width: calc(1.125rem * var(--scale-factor, 1));
}
.section02 .icon.icon3 {
  top: calc(21.1875rem * var(--scale-factor, 1));
  left: calc(2rem * var(--scale-factor, 1));
  width: calc(1.125rem * var(--scale-factor, 1));
}
.section02 .icon.icon4 {
  top: calc(21.3125rem * var(--scale-factor, 1));
  right: calc(0.8125rem * var(--scale-factor, 1));
  width: calc(3.4375rem * var(--scale-factor, 1));
}
.section02 .icon.icon5 {
  top: calc(32.5rem * var(--scale-factor, 1));
  left: calc(0rem * var(--scale-factor, 1));
  width: calc(4.8125rem * var(--scale-factor, 1));
}
.section02 .icon.icon6 {
  top: calc(37.8125rem * var(--scale-factor, 1));
  right: calc(0.9375rem * var(--scale-factor, 1));
  width: calc(1.5625rem * var(--scale-factor, 1));
}
.section02 .section--ttl {
  line-height: 0;
  display: inline-block;
  position: relative;
  margin-bottom: calc(1.6875rem * var(--scale-factor, 1));
}
.section02 .section--ttl span {
  display: inline-block;
  font-size: calc(0.875rem * var(--scale-factor, 1));
  line-height: calc(1.75rem * var(--scale-factor, 1));
  padding: 0 calc(0.625rem * var(--scale-factor, 1));
  background: #fff;
  color: #000078;
  border-radius: 10000px;
  margin-bottom: calc(1rem * var(--scale-factor, 1));
  position: relative;
  letter-spacing: -0.05em;
}
.section02 .section--ttl span:before {
  content: "";
  position: absolute;
  top: calc(100% - 0.0625rem * var(--scale-factor, 1));
  left: 50%;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
  width: calc(1.1875rem * var(--scale-factor, 1));
  height: calc(0.6875rem * var(--scale-factor, 1));
  background: #fff;
  -webkit-mask-image: url("/assets/common/img/title-arrow.svg");
          mask-image: url("/assets/common/img/title-arrow.svg");
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
}
.section02 .section--ttl span {
  font-size: calc(0.875rem * var(--scale-factor, 1));
  line-height: calc(1.375rem * var(--scale-factor, 1));
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-weight: 700;
  font-style: normal;
  padding: calc(0.375rem * var(--scale-factor, 1)) calc(1.125rem * var(--scale-factor, 1)) calc(0.4375rem * var(--scale-factor, 1));
  margin-bottom: 0;
  letter-spacing: -0.05em;
}
.section02 .section--ttl span:before {
  border-top-width: calc(0.9375rem * var(--scale-factor, 1));
  border-bottom-width: calc(0.9375rem * var(--scale-factor, 1));
  border-left-width: calc(0.5rem * var(--scale-factor, 1));
  border-right-width: calc(0.5rem * var(--scale-factor, 1));
}
.section02 .txt-underline {
  font-size: calc(1rem * var(--scale-factor, 1));
  font-family: "fot-tsukuardgothic-std", sans-serif;
  font-weight: 700;
  font-style: normal;
  color: #000078;
  margin-bottom: calc(1.8125rem * var(--scale-factor, 1));
}
.section02 .txt-underline span {
  padding-bottom: calc(0.1875rem * var(--scale-factor, 1));
}
.section02 .txt-underline span:before {
  background-image: url("/assets/common/img/path-underline-dotted.png");
  background-position: center 0;
  background-repeat: space;
}
.section02 .js-slider {
  width: calc(12.1875rem * var(--scale-factor, 1));
}
.section02 .js-slider .slick-list {
  border: 1px solid #000078;
}
.section02 .slick-dots {
  margin-top: calc(1.625rem * var(--scale-factor, 1));
}
.section02 .list-btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: calc(2.4375rem * var(--scale-factor, 1));
}
.section02 .list-btn .btn-action + .btn-action {
  margin-top: calc(0.875rem * var(--scale-factor, 1));
}
.section02 .list-btn .btn-term {
  margin-top: calc(1.5rem * var(--scale-factor, 1));
}
.section02 .list-btn .btn-term a {
  font-size: calc(0.75rem * var(--scale-factor, 1));
}

.section05 {
  padding: 0;
}
.section05 .btn-backpagetop {
  margin: calc(3.8125rem * var(--scale-factor, 1)) 0 calc(3.625rem * var(--scale-factor, 1));
}
.section05 .btn-backpagetop a {
  padding-inline: calc(0.9375rem * var(--scale-factor, 1));
  font-size: calc(0.875rem * var(--scale-factor, 1));
  line-height: calc(1.25rem * var(--scale-factor, 1));
  letter-spacing: -0.05em;
}
.section05 .btn-backpagetop.btn-shadow:before {
  background: #E51200;
  border: 1px solid #000078;
}