@charset "UTF-8";

.wrapper {
  max-width: 124rem;
  display: flex;
  justify-content: center;
  position: relative;
  flex-direction: column;
  align-items: center;
}

.c-innerPcScroll--child {
  margin-top: 0;
  background-color: #fff;
}

.c-fixedCta__boxOuter {
  padding-top: 1.6rem;
  right: 0;
}

.c-requestButton__cta .cta-button-text {
  padding-right: 5.6rem;
}

.cta-button-text span {
  font-size: 1.4rem;
  line-height: 130%;
  font-weight: 700;
}

.enrollment-delivery-section .p1 {
  color: var(--white, #fff);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
  margin: 2rem 0 0.5rem 0;
}

.enrollment-payment-bg h3 {
  color: var(--accent_pink, #f62a7e);
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 4rem;
  font-style: normal;
  font-weight: 700;
}

.enrollment-payment-bg p {
  margin: 0;
  color: var(--text, #333442);
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
}

.enrollment-payment-bg a {
  display: inline-flex;
  padding: 1.1rem 0.8rem;
  justify-content: center;
  align-items: center;
  gap: 0.8rem;
  border-radius: 4.8rem;
  background: var(--accent_pink, #f62a7e);
  color: var(--white, #fff);
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
}

.learning-choice__title .span--red {
  display: inline-block;
  color: var(--accent_pink, #f62a7e);
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2.8rem;
  font-style: normal;
  font-weight: 900;
  line-height: 130%;
  margin-bottom: 0.5rem;
}

.learning-choice__title .span--underline {
  position: relative;
  display: inline-block;
}

.learning-choice__title .span--underline::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.05em;
  width: 100%;
  height: 0.4em;
  background-color: #f62a7e;
  opacity: 0.2;
}

.enrollment-delivery-card .p1 {
  color: var(--text, #333442);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-style: normal;
  font-weight: 400;
  line-height: 130%;
  margin: 1rem 0 0 0;
}

.hero__image {
  margin-bottom: 0.2rem;
}

.hero__image .img1 {
  width: 8.4rem;
  top: 34.7rem;
  left: 1rem;
}

.hero__text {
  width: 19.4rem;
  margin: 0 auto;
}

.hero__text p {
  font-size: 1.2rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
  margin-bottom: 0;
}

.hero__text .p3 {
  color: var(--text, #9B9B9B);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1rem;
  font-style: normal;
  font-weight: 400;
  line-height: 120%;
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
  margin: 0.4rem 0 0 0;
}

.hero__text h2 {
  color: #333442;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2.5rem;
  font-style: normal;
  font-weight: 900;
  line-height: 130%;
  margin-bottom: 0;
}

.hero__container {
  display: block;
  background: none;
  padding-bottom: 0.8rem;
  padding-top: 0;
}

.hero__image .img2 {
  width: 10rem;
  height: 10rem;
  right: 0rem;
  left: unset;
  top: 33.5rem;
  bottom: 0;
}

.friendCtaBox {
  display: flex;
  height: 7rem;
  padding: 2.2rem 0.8rem 2.2rem 1.8rem;
  justify-content: center;
  align-items: center;
  gap: 0.8rem;
  align-self: stretch;
  border-radius: 4.6rem;
  background: #006FE6;
  margin: 2.4rem 2rem 0;
}

.friendCtaBox__p {
  color: var(--white, #FFF);
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
}

.friendCtaBox__p::after {
  content: "";
  display: inline-block;
  width: 2.2rem;
  height: 2.2rem;
  background: url(/common_2025/img/svg/arrowDown--blue.svg);
  background-repeat: no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin-bottom: 0.2rem;
  margin-left: 1rem;
}

.presentCampaign h2 {
  font-size: 3.6rem;
  color: #FFF;
  text-align: center;
  font-weight: 900;
  line-height: 120%;
}

.preset__lead {
  font-size: 2.4rem;
  color: #FFF;
  text-align: center;
  font-weight: 900;
  line-height: 120%;
}

.present__icon {
  width: 4rem;
  height: 4rem;
  display: inline-block;
  vertical-align: text-top;
}

.presentCampaign {
  padding: 2.4rem 2.4rem 4rem;
  max-width: 60rem;
  margin: 0 auto;
  text-align: center;
  background: #00B4F6;
}

.presentCampaign__mainTitle {
  margin: 0 0 2rem;
  display: flex;
  justify-content: center;
}

.presentCampaign__container {
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  margin-top: 2.4rem;
}

.giftCard {
  background-color: #fff;
  border-radius: 1.5rem;
  padding: 2rem 1.6rem 2.4rem;
  box-sizing: border-box;
  overflow: hidden;
}

.giftCard__header {
  margin-bottom: 1.5rem;
  padding: 0 1rem;
}

.giftCard__visual {
  margin-bottom: 2rem;
}

.giftCard__body {
  text-align: left;
  font-size: 1.4rem;
}

.giftCard__description {
  margin: 0 0 1.2rem;
  font-size: 1.4rem;
  font-feature-settings: "palt" on;
  font-weight: 400;
}

.giftCard__noteList {
  color: #9B9B9B;
  font-size: 1.2rem;
  line-height: 150%;
}

.giftCard__noteItem {
  text-indent: -1em;
  padding-left: 1em;
}

.giftCard__noteItem span {
  color: #D53A35;
}

.giftCard--other .giftCard__linkText {
  text-align: center;
  color: #0099EB;
  font-weight: bold;
  margin-bottom: 1.5rem;
}

.giftCard--other .giftCard__carousel {
  margin-bottom: 2rem;
  text-align: center;
}

.giftCard__footerNotes {
  padding-top: 1.2rem;
  color: #999;
  font-size: 1rem;
  margin: 0 2.4rem;
  padding-bottom: 8rem;
}

.giftCard__footerNoteItem {
  margin-bottom: 0.8rem;
  text-align: left;
}

.carousel {
  position: relative;
}

.carousel__viewport {
  width: 100%;
  overflow: visible;
  padding: 1rem 0;
}

.carousel__track {
  display: flex;
  width: max-content;
  will-change: transform;
  cursor: grab;
}

.carousel__track:active {
  cursor: grabbing;
}

.carousel__item {
  width: 12rem;
  max-width: 26rem;
  flex-shrink: 0;
  margin: 0 0.8rem;
  position: relative;
  overflow: hidden;
  background: #fff;
  box-sizing: border-box;
  transition: transform 0.3s, box-shadow 0.3s;
  user-select: none;
}

.carousel__img {
  width: 100%;
  height: auto;
  display: block;
}

.carousel__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.4rem;
  height: 2.4rem;
  background-image: url(/new1/introduce/img/arrow_right.svg);
  background-size: contain;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s, background-color 0.2s;
}

.carousel__btn--prev {
  left: 2%;
  background-image: url(/new1/introduce/img/arrow_left.svg);
}

.carousel__btn--next {
  right: 2%;
}

.carousel__btn.is-disabled {
  opacity: 0;
  pointer-events: none;
}

.giftCard__footerNoteItem {
  font-size: 1rem;
  color: #999;
  margin-bottom: 0.5rem;
  line-height: 1.5;
  text-indent: -1em;
  padding-left: 1em;
}

.giftCard__footerNoteItem:last-child {
  margin-bottom: 0;
}

.modalOverlay {
  position: fixed;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: flex-start;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s;
  padding: 2rem;
  overflow: scroll;
}

.modalOverlay.isActive {
  opacity: 1;
  visibility: visible;
}

.modalContent {
  background: #fff;
  width: 100%;
  max-width: 34rem;
  border-radius: 1rem;
  padding: 3.2rem;
  position: relative;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
  top: 20%;
}

.modalContent__closeBtn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: #e0e0e0;
  color: #676979;
  border: none;
  border-radius: 50%;
  width: 2.4rem;
  height: 2.4rem;
  font-size: 2.4rem;
  cursor: pointer;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.modalContent__image {
  margin-bottom: 1.2rem;
}

.modalContent__image img {
  border-radius: 0.5rem;
}

.modalContent__title {
  font-size: 1.6rem;
  font-weight: bold;
  color: #333;
}

.modalContent__description {
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  margin-top: 0.4rem;
}

.modalContent__notes {
  font-size: 1rem;
  color: #888;
  list-style: none;
  padding: 0;
}

.modalContent__noteItem {
  margin-bottom: 0.4rem;
  text-indent: -1em;
  padding-left: 1em;
}

.text--red {
  color: #ff5555;
}

.sectionDivider {
  position: relative;
  height: 0;
  text-align: center;
  z-index: 10;
}

.sectionDivider__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  background-color: #fff;
  color: #0099EB;
  font-size: 3rem;
  font-weight: bold;
  border-radius: 50%;
  line-height: 1;
  transform: translateY(-50%);
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
}

.chanse_select_section {
  border-left: 2.4rem solid #F6F3EE;
  border-right: 2.4rem solid #F6F3EE;
  border-radius: 1.2rem 1.2rem 0 0;
}

.doubleChance {
  background-color: #0099EB;
  padding: 4.8rem 2.4rem 6rem;
  text-align: center;
  color: #fff;
  border-radius: 1.2rem;
}

.doubleChance--02 {
  background-color: #107DF3;
  border-radius: 0 0 1.2rem 1.2rem;
}

.doubleChance__subHeader {
  font-size: 2.2rem;
  font-weight: bold;
  margin: 0 0 1rem;
}

.doubleChance__header {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2rem;
}

.ticketBox {
  background-color: #fff;
  color: #0099EB;
  padding: 0.6rem 0.8rem;
  border-radius: 0.4rem;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.2;
  box-shadow: 0 2px 0 rgba(0, 0, 0, 0.1);
  width: 14rem;
}

.ticketBox__label {
  font-size: 1.1rem;
  font-weight: bold;
  background: #0099EB;
  color: #fff;
  padding: 0.2rem 0.8rem;
  margin-bottom: 0.2rem;
  width: 100%;
}

.ticketBox__price {
  font-size: 3.9rem;
  font-weight: bold;
  font-family: Arial, sans-serif;
  letter-spacing: -0.2rem;
}

.ticketBox__unit {
  font-size: 1.2rem;
  margin-left: 0.2rem;
  letter-spacing: 0.1rem;
}

.doubleChance__title {
  font-size: 2.8rem;
  font-weight: bold;
  margin: 0;
  line-height: 1.3;
  text-align: left;
  font-feature-settings: "palt" on;
}

.giftCard--chance {
  overflow: hidden;
}

.doubleChance__visual {
  margin: 0px 0rem 2rem;
  padding: 0rem;
  text-align: center;
}

.campaignInfo {
  margin-bottom: 2rem;
  border: 2px solid #0099EB;
  border-radius: 1rem;
  overflow: hidden;
  margin-left: 1rem;
  margin-right: 1rem;
}

.campaignInfo__header {
  background-color: #0099EB;
  color: #fff;
  padding: 0.8rem;
  position: relative;
}

.campaignInfo__tag {
  display: inline-block;
  background-color: #fff;
  color: #0099EB;
  font-size: 1rem;
  font-weight: bold;
  padding: 0.2rem 1rem;
  border-radius: 1rem;
  position: absolute;
  top: -1rem;
  left: 50%;
  transform: translateX(-50%);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.campaignInfo__title {
  margin: 0.5rem 0 0;
  font-size: 1.6rem;
  font-weight: bold;
}

.campaignInfo__dateBox {
  background-color: #fff;
  padding: 1rem;
}

.campaignInfo__date {
  font-size: 2.4rem;
  font-weight: bold;
  color: #0099EB;
  font-family: Arial, sans-serif;
}

.campaignInfo__date small {
  font-size: 1.4rem;
  margin: 0 0.2rem;
}

.presentBadge {
  background-color: #FF4090;
  color: #fff;
  width: 8.2rem;
  height: 8.2rem;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border: 0.2rem solid #fff;
  box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.2);
  flex-shrink: 0;
  line-height: 1.1;
}

.presentBadge__count {
  font-size: 2.5rem;
  font-weight: bold;
  font-family: Arial, sans-serif;
}

.presentBadge__unit {
  font-size: 1rem;
}

.presentBadge__label {
  font-size: 1rem;
  margin-top: 0.2rem;
}

.entryCta {
  background-color: #fff;
  padding: 3rem 1.5rem 2.4rem;
  text-align: center;
}

.entryCta__container {
  margin: 0 auto;
  max-width: 34.2rem;
}

.entryCta__header {
  margin-bottom: 0rem;
}

.entryCta__subLabel {
  font-size: 1.5rem;
  font-weight: bold;
  color: #333;
  margin: 0;
  margin-bottom: -0.5rem;
  line-height: 1.4;
}

.entryCta__mainLabel {
  font-size: 2.6rem;
  font-weight: bold;
  color: #FF4050;
  margin: 0;
  line-height: 1.4;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
}

.entryCta__decoLine {
  display: block;
  width: 0.4rem;
  height: 4rem;
  background-color: #FF4050;
  border-radius: 0.2rem;
}

.entryCta__decoLine--left {
  transform: rotate(-25deg);
}

.entryCta__decoLine--right {
  transform: rotate(25deg);
}

.entryCta__action {
  margin-bottom: 0.5rem;
}

.entryCta__btnLink {
  display: inline-block;
  transition: opacity 0.3s;
}

.entryCta__btnLink:hover {
  opacity: 0.8;
}

.entryCta__btnImg {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

.entryCta__note {
  font-size: 1.2rem;
  color: #FF4050;
  line-height: 1.5;
  margin: 0;
  text-indent: -1rem;
  padding-left: 2rem;
  text-align: left;
  display: inline-block;
}

.referralFlow {
  background-color: #E0F0FF;
  padding: 3.2rem 2.4rem 4.8rem;
  color: #333;
  line-height: 1.5;
}

.referralFlow__title {
  text-align: center;
  font-size: 2.8rem;
  font-weight: bold;
  margin-bottom: 2rem;
}

.referralFlow__tabs {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
  margin: 0 auto;
}

.referralFlow__tabBtn {
  flex: 1;
  background-color: #fff;
  border: none;
  border-radius: 1rem 1rem 0 0;
  padding: 1.2rem 0.8rem 0.8rem;
  font-size: 1.4rem;
  font-weight: bold;
  color: #00B4F6;
  cursor: pointer;
  line-height: 1.3;
  position: relative;
}

.referralFlow__tabBtn span {
  font-size: 1.6rem;
  border-bottom: solid 1px #00B4F6;
}

.referralFlow__tabBtn.is-active {
  background-color: #00B4F6;
  color: #fff;
}

.referralFlow__tabBtn.is-active span {
  border-color: white;
}

.referralFlow__tabBtn br {
  display: block;
}

.referralFlow__contentContainer {
  background-color: #00B4F6;
  padding: 1.6rem;
  border-radius: 0 0 1rem 1rem;
  max-width: 60rem;
  margin: 0 auto;
  position: relative;
  top: -0.1rem;
  z-index: 1;
}

.referralFlow__panel {
  display: none;
}

.referralFlow__panel.is-show {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.flowStep {
  background-color: #fff;
  border: 1px solid #E0F0FF;
  border-radius: 1rem;
  padding: 2rem 1.6rem;
  margin-bottom: 1.2rem;
  overflow: hidden;
  box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.05);
}

.flowStep:last-child {
  margin-bottom: 0;
}

.flowStep__header {
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 1.6rem;
}

.flowStep__stepLabel {
  background-color: #00BFFF;
  color: #fff;
  font-size: 1.4rem;
  font-weight: bold;
  padding: 0.3rem 2.3rem 0.3rem 0.4rem;
  position: relative;
  line-height: 120%;
  clip-path: polygon(0% 0%, calc(100% - 1rem) 0%, 100% 50%, calc(100% - 1rem) 100%, 0% 100%);
}

.flowStep__stepLabel::after {
  content: "";
  position: absolute;
  right: -0.6rem;
  top: 50%;
  transform: translateY(-50%);
  border-top: 0.4rem solid transparent;
  border-bottom: 0.4rem solid transparent;
  border-left: 0.6rem solid #00BFFF;
}

.flowStep__stepTitle {
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0;
  color: #333;
}

.flowStep__visual {
  text-align: center;
  margin: 0 0 1.6rem;
}

.flowStep__visual img {
  max-width: 100%;
  height: auto;
}

.flowStep__desc {
  font-size: 1.4rem;
  color: #333442;
  margin: 0 0 1.6rem;
  line-height: 1.6;
}

.flowStep__btnArea {
  text-align: center;
}

.flowStep__btnLink {
  display: inline-block;
  transition: opacity 0.3s;
}

.flowStep__btnLink:hover {
  opacity: 0.8;
}

.flowStep__note,
.flowStep__noteList {
  font-size: 1.2rem;
  color: #9B9B9B;
  line-height: 150%;
  margin-top: 1.6rem;
  margin-bottom: 0;
}

.flowStep__noteList {
  padding: 0;
  list-style: none;
}

.flowStep__noteItem {
  margin-bottom: 0rem;
  padding-left: 1em;
  text-indent: -1em;
}

.flowStep__note--red,
.flowStep__noteItem--red {
  color: #FF4050;
}

.referralAbout {
  background-color: var(--color-bg-white);
  border-radius: 1rem;
  margin-bottom: 4rem;
  border: 0.2rem solid var(--color-primary-blue);
}

.referralAbout__title {
  text-align: center;
  font-size: 2.8rem;
  font-weight: bold;
}

.referralAbout__body {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  padding: 2rem 1.6rem 2.4rem;
  margin-top: 1.6rem;
  background: white;
  border-radius: 1.2rem;
}

.referralAbout__lead {
  color: #00B4F6;
  font-feature-settings: "palt";
  font-weight: bold;
  text-align: center;
  font-size: 1.4rem;
  margin: 0;
}

.referralAbout__visual {
  margin-bottom: 1.5rem;
  text-align: center;
}

.referralAbout__noteList {
  list-style: none;
  padding: 0;
  margin: 0;
}

.referralAbout__noteList li {
  font-size: 1.2rem;
  color: #9B9B9B;
  margin-bottom: 0.5rem;
  line-height: 150%;
  padding-left: 1rem;
  text-indent: -1rem;
  font-feature-settings: "palt" on;
}

.lineReferral {
  background-color: #EBFBEB;
  padding: 3.2rem 2.4rem 4.8rem;
}

.lineReferral__container {
  max-width: 60rem;
  margin: 0 auto;
}

.lineReferral__header {
  text-align: center;
  margin-bottom: 1.6rem;
}

.lineReferral__subTitle {
  font-size: 2.2rem;
  font-weight: bold;
  margin-bottom: 0rem;
  margin-top: 0;
}

.lineReferral__title {
  font-size: 2.8rem;
  line-height: 120%;
  font-weight: bold;
  margin: 0;
}

.lineReferral__card {
  text-align: center;
  margin-bottom: 0;
  padding: 2rem 1.6rem 2.4rem;
  background: white;
  border-radius: 12px;
}

.lineReferral__cardTitle {
  color: #17C917;
  font-size: 1.8rem;
  font-weight: bold;
}

.lineReferral__cardText {
  font-size: 1.4rem;
  color: #333442;
  text-align: left;
  display: inline-block;
  margin: 0;
}

.sliderWrapper {
  position: relative;
  max-width: 60rem;
  margin: 2.4rem auto 0;
  padding: 0;
}

.cardSlider {
  overflow-x: auto;
  overflow-y: hidden;
  -ms-overflow-style: none;
  scrollbar-width: none;
  cursor: grab;
  scroll-behavior: smooth;
}

.cardSlider::-webkit-scrollbar {
  display: none;
}

.cardSlider.is-active {
  cursor: grabbing;
  scroll-behavior: auto;
}

.cardSlider__track {
  display: flex;
  gap: 1.5rem;
  width: max-content;
  padding-bottom: 0rem;
}

.cardSlider .flowStep {
  background-color: #E6F6E6;
  border-radius: 1rem;
  padding: 2rem 1.6rem;
  width: 28rem;
  flex-shrink: 0;
  box-shadow: 0 0.2rem 0.5rem rgba(0, 0, 0, 0.05);
  user-select: none;
  margin-bottom: 0;
}

.cardSlider .flowStep__header {
  background-color: #E6F6E6;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

.cardSlider .flowStep__stepLabel {
  background-color: #32CD32;
  color: #fff;
  font-size: 1.4rem;
  font-weight: bold;
  padding: 0.3rem 1.5rem 0.3rem 0.8rem;
  clip-path: polygon(0% 0%, 85% 0%, 100% 50%, 85% 100%, 0% 100%);
}

.cardSlider .flowStep__stepTitle {
  font-size: 1.8rem;
  font-weight: bold;
  color: #333;
}

.cardSlider .flowStep__visual {
  padding: 0;
  text-align: center;
}

.cardSlider .flowStep__desc {
  font-size: 1.4rem;
  margin: 0;
  line-height: 1.5;
  text-align: left;
}

.cardSlider .flowStep__note {
  font-size: 1rem;
  color: #888;
  display: block;
  margin-top: 0.5rem;
}

.carouselBtn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.4rem;
  height: 2.4rem;
  background-image: url(/friend/img/carousel_btn_next_gr.svg);
  background-size: contain;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
  display: flex;
  justify-content: center;
  align-items: center;
}

.carouselBtn:hover {
  background-color: #00A01A;
}

.carouselBtn--prev {
  left: -1rem;
  transform: rotate(-180deg) translateY(-50%);
  top: calc(50% - 2.4rem);
}

.carouselBtn--prev::after {
  margin-left: 0.3rem;
}

.carouselBtn--next {
  right: -1rem;
}

.carouselBtn.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.lineReferral__cta {
  text-align: center;
  margin-bottom: 3rem;
}

.lineReferral__ctaLabel {
  font-weight: bold;
  font-size: 1.5rem;
  margin-top: 2.4rem;
  margin-bottom: 1rem;
}

.btn--blueFull {
  display: block;
  background-color: #0070E0;
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  font-size: 1.6rem;
  padding: 1.5rem;
  border-radius: 3rem;
  box-shadow: 0 0.4rem 0 rgba(0, 0, 0, 0.1);
  transition: opacity 0.2s;
  position: relative;
}

.btn--blueFull:hover {
  opacity: 0.9;
}

.btn--blueFull .arrow {
  position: absolute;
  right: 2rem;
  font-family: sans-serif;
}

.cautionBox {
  background-color: #E6F2FF;
  padding: 0.8rem;
  border-radius: 0.4rem;
  margin-bottom: 2.4rem;
}

.cautionBox__list {
  list-style: none;
  text-align: left;
  padding: 0;
  margin: 0;
}

.cautionBox__list li {
  font-size: 1.2rem;
  color: #333;
  margin-bottom: 0.5rem;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.4;
}

.cautionNotes {
  list-style: none;
  text-align: left;
  padding: 0;
  margin: 0;
}

.cautionNotes li {
  font-size: 1rem;
  color: #999;
  margin-bottom: 0.4rem;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.4;
}

.faqSection {
  background-color: #E0F5FF;
  padding: 3.2rem 2.4rem 4.8rem;
}

.faqSection__container {
  margin: 0 auto;
}

.faqSection__title {
  text-align: center;
  font-size: 2.8rem;
  font-weight: bold;
  color: #333;
  margin: 0 0 1.6rem;
}

.faqList {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.faqCard {
  background-color: #fff;
  border: 0.2rem solid #00B4F6;
  border-radius: 1rem;
  overflow: hidden;
}

.faqCard__header {
  background-color: #00B4F6;
  padding: 1.5rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.faqCard__icon {
  background-color: #fff;
  color: #00B4F6;
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  font-size: 2.4rem;
  flex-shrink: 0;
  line-height: 1;
}

.faqCard__question {
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0;
  line-height: 120%;
}

.faqCard__body {
  padding: 1.6rem;
  background-color: #fff;
}

.faqCard__answer {
  font-size: 1.4rem;
  color: #333;
  margin: 0;
  line-height: 140%;
}

.faqCard__note {
  font-size: 1.1rem;
  color: #888;
  margin: 1.6rem 0 0;
  line-height: 1.4;
  padding-left: 1em;
  text-indent: -1em;
}

.secHero {
  background: #008ED8;
  padding: 2rem 0 3.8rem;
}

.secHero .c-mainNav__h2 {
  color: white;
}

.btnViewMore {
  margin-top: 3.6rem;
  margin-bottom: 5.6rem;
}

.breadcrumb {
  margin: 0 auto;
  padding: 1.5rem 1.5rem;
  box-sizing: border-box;
}

.breadcrumb__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.5;
}

.breadcrumb__item {
  display: flex;
  align-items: center;
  color: #333;
}

.breadcrumb__item:not(:last-child)::after {
  content: "＞";
  font-size: 1rem;
  margin: 0 0.8rem;
  color: #333;
  font-weight: bold;
}

.breadcrumb__link {
  color: #333;
  text-decoration: underline;
  transition: opacity 0.3s;
}

.breadcrumb__link:hover {
  opacity: 0.7;
  text-decoration: none;
}

.breadcrumb__current {
  color: #333;
  font-weight: 700;
  text-decoration: none;
}

.c-mainNav__img2 {
  box-shadow: unset;
}

.fixedBox {
  position: fixed;
  top: 40%;
  left: 4.5rem;
  transform: translate(0, -50%);
  display: flex;
  width: 26rem;
  height: 16rem;
  flex-direction: column;
  align-items: center;
}

.fixedBox .img1 {
  width: 41.6rem;
  margin-bottom: 4.4rem;
}

.ctaBoxInte {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.cta_interest {
  color: var(--white, #fff);
  text-align: center;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.8rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
}

.sp-ctaButton {
  font-size: 2.4rem;
  font-weight: 900;
  color: #FFFFFF;
  text-align: center;
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}

.sp-ctaButton span {
  font-size: 1.4rem;
  font-weight: 700;
}

.c-requestButton__a {
  margin-top: 0rem;
}

.bg_fixed {
  background: var(--cocha_primary, #008ED8);
  width: 100vw;
  height: 100vh;
  position: fixed;
}

.c-requestButton__a .cta-button-text {
  padding-right: 3.75rem;
}

.presentTitleSection {
  background-color: #F6F3EE;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 4rem 0 2rem;
  position: relative;
}

.presentTitleSection img {
  width: 27.2rem;
  display: flex;
}

.presentTitleSection::after {
  content: "";
  display: inline-block;
  background-image: url(../img/tama1.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 5rem;
  position: absolute;
  bottom: -4.9rem;
  left: 0;
  z-index: 0;
}

.select_present1 {
  background-color: #CFE188;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.select_item_head {
  width: 31.9rem;
  padding: 7rem 0 1.6rem;
}

.select_item_title {
  width: 29.2rem;
  padding-bottom: 2.5rem;
}

.select_item_img {
  padding-bottom: 2rem;
}

.select_item1_note {
  color: #326616;
  font-size: 1.6rem;
  line-height: 130%;
  font-weight: 700;
  padding: 3.2rem 2.4rem;
  margin: 0;
}

.select_item1_note a {
  text-decoration: underline;
  text-align: center;
}

.profile_area {
  width: 34.2rem;
  margin-bottom: 6.2rem;
}

.present_select_section1 {
  position: relative;
}

.present_select_section1::after {
  content: "";
  display: inline-block;
  background-image: url(../img/tama2.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 5rem;
  position: absolute;
  bottom: -4.9rem;
  left: 0;
  z-index: 0;
}

.present_select_section2 {
  margin-top: 2rem;
  position: relative;
}

.present_select_section2::after {
  content: "";
  display: inline-block;
  background-image: url(../img/tama3.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 5rem;
  position: absolute;
  bottom: -4.9rem;
  left: 0;
  z-index: 0;
}

.select_present2 {
  background-color: #FAC2B8;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.select_item2_note {
  color: #923E3E;
  font-size: 1.6rem;
  line-height: 130%;
  font-weight: 700;
  padding: 3.2rem 2.4rem;
  margin: 0;
}

.select_item2_note a {
  text-decoration: underline;
  text-align: center;
}

.present_select_section3 {
  margin-top: 4rem;
  position: relative;
}

.select_present3 {
  background-color: #C1E4E7;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.select_item3_note {
  color: #32858C;
  font-size: 1.6rem;
  line-height: 130%;
  font-weight: 700;
  padding: 3.2rem 2rem;
  margin: 0;
}

.select_item3_note a {
  text-decoration: underline;
  text-align: center;
}

.present_select_section3::after {
  content: "";
  display: inline-block;
  background-image: url(../img/tama4.png);
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  width: 100%;
  height: 5rem;
  position: absolute;
  bottom: -4.9rem;
  left: 0;
  z-index: 0;
}

.othera_select_section {
  margin-top: 4rem;
  background-color: #F6F3EE;
  box-sizing: border-box;
  overflow: hidden;
}

.othera_present {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.othera_select_section .giftCard__linkText {
  font-size: 1.4rem;
  color: #DE6662;
  font-weight: 700;
  line-height: 120%;
  text-align: center;
}

.friend_explanation_section {
  background-color: #F6F3EE;
  padding-bottom: 4.2rem;
}

.friend_explanation .title {
  width: 33.5rem;
}

.friend_explanation .text {
  width: 35.8rem;
  margin: 2.4rem 0 4rem;
}

.friend_explanation {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.friend_osusume_img {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  padding: 0 2.4rem;
}

.friend_osusume_img {
  margin-top: 4.8rem;
}

.friend_osusume_img img {
  width: 34.2rem;
  padding-bottom: 3.2rem;
}

.nagare_Section {
  padding: 0 2.4rem;
}

.nagare_Section .title_img {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 4.8rem;
  margin-bottom: 4rem;
}

.nagare_Section .title_img img {
  width: 27.6rem;
}

@media screen and (max-width: 471px) {
  .hero__image .img1 {
    top: 34.7rem;
    left: 0.9rem;
  }

  .hero__image .img2 {
    top: 33.5rem;
  }
}