@charset "UTF-8";

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

.c-innerPcScroll--child {
  margin-top: 0;
  background-color: var(--white, #FFFFFF);
}

.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, #FFFFFF);
  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, #414358);
  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, #FFFFFF);
  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: var(--accent_pink, #F62A7E);
  opacity: 0.2;
}

.enrollment-delivery-card .p1 {
  color: var(--text, #414358);
  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: 0rem;
}

.hero__image .img1 {
  width: 8.4rem;
  top: 38.7rem;
}

.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: #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: var(--text, #414358);
  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: 0rem;
  padding-top: 0;
}

.hero__image .img2 {
  width: 10rem;
  height: 10rem;
  right: -0.4rem;
  left: unset;
  top: 37rem;
  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, #FFFFFF);
  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;
}

.hero__btnArea {
  background: linear-gradient(180deg, #ffd1e4 0%, #ffeaf3 29.81%, #feede7 100%);
  padding: 0 2.4rem 3.2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.6rem;
}

.hero__presentsImg {
  width: 100%;
  max-width: 34.2rem;
  height: auto;
}

.friendCtaBox--pink {
  background: var(--accent_pink, #f62a7e);
  margin: 0;
  width: 100%;
  max-width: 34.2rem;
  height: 6rem;
  padding: 1.6rem 4.5rem 1.6rem 3rem;
  position: relative;
}

.friendCtaBox--pink .friendCtaBox__p {
  font-size: 2.4rem;
  font-weight: 900;
}

.friendCtaBox--pink .friendCtaBox__p::after {
  background: url(/common_2025/img/svg/arrowDown--pink.svg);
  background-size: contain;
  position: absolute;
  right: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  margin: 0;
}

.c-friendLead {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  padding: 3.2rem 2.4rem;
  align-items: center;
}

.c-friendLead__no1 {
  display: flex;
  align-items: center;
  gap: 1rem;
  width: 100%;
  position: relative;
}

.c-friendLead__no1Img {
  width: 8.6rem;
  height: auto;
  flex-shrink: 0;
}

.c-friendLead__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
}

.c-friendLead__textSub {
  color: var(--text, #414358);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 130%;
  margin: 0;
}

.c-friendLead__textMain {
  color: var(--text, #414358);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2.5rem;
  font-weight: 900;
  line-height: 130%;
  margin: 0;
}

.c-friendLead__textLink {
  color: #9B9B9B;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1rem;
  font-weight: 400;
  line-height: 130%;
  text-decoration: underline;
  margin: 0.2rem 0 0 0;
  cursor: pointer;
}

.c-friendLead__korasho {
  width: 9.4rem;
  height: auto;
  position: absolute;
  right: -2.1rem;
  top: 50%;
  transform: translateY(-50%);
}

.c-friendLead__message {
  background: var(--white, #FFFFFF);
  width: 100%;
  text-align: center;
}

.c-friendLead__messageText {
  color: var(--3, #34BBD8);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 130%;
  margin: 0;
}

.c-friendLead__messageCta {
  color: var(--accent_pink, #f62a7e);
  background-image: url(/friend/img/hero_wave.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom;
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2rem;
  font-weight: 700;
  line-height: 200%;
  margin: 1rem 0 0 0;
}

.c-featuredItem {
  background: var(--3, #34BBD8);
  display: flex;
  flex-direction: column;
  gap: 2.4rem;
  align-items: center;
  padding: 4.8rem 1.4rem;
}

.c-featuredItem__title {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.c-featuredItem__titleSub {
  color: var(--3, #34BBD8);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2.4rem;
  font-weight: 900;
  line-height: 130%;
  margin: 0;
  -webkit-text-stroke: 0.5rem var(--white, #FFFFFF);
  paint-order: stroke fill;
}

.c-featuredItem__titleMain {
  color: var(--3, #34BBD8);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 3.4rem;
  font-weight: 900;
  line-height: 130%;
  margin: 0;
  -webkit-text-stroke: 0.5rem var(--white, #FFFFFF);
  paint-order: stroke fill;
}

.c-featuredItem__titleAccent {
  color: var(--accent_pink, #F62A7E);
}

.c-featuredItem__container {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 36.4rem;
}

.c-featuredItem__banner {
  width: 32.5rem;
  height: auto;
}

.c-featuredItem__goodsBox {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.c-featuredItem__goodsImg {
  width: 100%;
  max-width: 36.4rem;
  height: auto;
}

.c-featuredItem__present {
  background: var(--white, #FFFFFF);
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  align-items: center;
  padding: 3.2rem 1.6rem;
  margin: 0 2.4rem;
  border-radius: 0 0 1.2rem 1.2rem;
}

.c-featuredItem__campaign {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 1.6rem;
  position: relative;
}

.c-featuredItem__campaignLabel {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  background: var(--white, #FFFFFF);
  border: 0.1rem solid var(--3, #34BBD8);
  border-radius: 10rem;
  padding: 0.3rem 1.2rem;
  color: var(--3, #34BBD8);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 130%;
  white-space: nowrap;
}

.c-featuredItem__campaignLabel::after {
  content: "";
  position: absolute;
  bottom: -0.6rem;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 0.45rem solid transparent;
  border-right: 0.45rem solid transparent;
  border-top: 0.6rem solid var(--3, #34BBD8);
}

.c-featuredItem__campaignBox {
  border: 0.2rem solid var(--3, #34BBD8);
  border-radius: 0.8rem;
  overflow: hidden;
  width: 31rem;
}

.c-featuredItem__campaignTitle {
  background: var(--3, #34BBD8);
  color: var(--white, #FFFFFF);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2.4rem;
  font-weight: 900;
  line-height: 130%;
  text-align: center;
  padding: 1.2rem 0 0.6rem;
}

.c-featuredItem__campaignDate {
  color: var(--3, #34BBD8);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-weight: 700;
  text-align: center;
  padding: 1.6rem 0rem 2rem;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  flex-wrap: wrap;
}

.c-featuredItem__campaignDate * {
  font-weight: inherit;
  line-height: 1;
}

.c-featuredItem__dateGroup {
  display: flex;
  align-items: baseline;
  flex-direction: column;
  gap: 0.2rem;
}

.c-featuredItem__dateNum {
  font-size: 4rem;
}

.c-featuredItem__dateDay {
  font-size: 1.8rem;
}

.c-featuredItem__dateSep {
  font-size: 3.6rem;
  margin: 0;
}

.c-featuredItem__noteList {
  list-style: none;
  padding: 0;
  margin: 0;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  text-align: left;
}

.c-featuredItem__noteList li {
  color: var(--sub3, #9A9BA5);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 150%;
  padding-left: 1em;
  text-indent: -1em;
}

.c-featuredItem__noteList li::before {
  content: "※";
}

.c-featuredItem__noteList li span {
  color: var(--Primary_red, #FF3D4D);
}

.c-featuredItem__designer {
  background: var(--BG_blue, #E7F2FE);
  border-radius: 1.2rem;
  padding: 2.4rem;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  align-items: center;
  justify-content: center;
}

.c-featuredItem__designerName {
  color: var(--3, #34BBD8);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 130%;
  text-align: center;
  margin: 0;
}

.c-featuredItem__designerText {
  color: var(--sub2, #676979);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 150%;
  margin: 0;
}

.c-featuredItem__otherLink {
  display: block;
}

.c-featuredItem__otherLink img {
  width: 34.2rem;
  max-width: 100%;
  height: auto;
}

.c-featuredItem__present.c-featuredItem__present--02 .c-featuredItem__campaignLabel {
  border: 1px solid var(--1, #3399FF);
  color: var(--1, #3399FF);
}

.c-featuredItem__present.c-featuredItem__present--02 .c-featuredItem__campaignBox {
  border: 2px solid var(--1, #3399FF);
}

.c-featuredItem__present.c-featuredItem__present--02 .c-featuredItem__campaignTitle {
  background-color: var(--1, #3399FF);
}

.c-featuredItem__present.c-featuredItem__present--02 .c-featuredItem__campaignDate {
  color: var(--1, #3399FF);
}

.c-featuredItem__present.c-featuredItem__present--03 .c-featuredItem__campaignLabel {
  border: 1px solid var(--1, #00ADEA);
  color: var(--2, #00ADEA);
}

.c-featuredItem__present.c-featuredItem__present--03 .c-featuredItem__campaignBox {
  border: 2px solid var(--2, #00ADEA);
}

.c-featuredItem__present.c-featuredItem__present--03 .c-featuredItem__campaignTitle {
  background-color: var(--2, #00ADEA);
}

.c-featuredItem__present.c-featuredItem__present--03 .c-featuredItem__campaignDate {
  color: var(--2, #00ADEA);
}

.c-featuredItem__present.c-featuredItem__present--04 .c-featuredItem__campaignLabel {
  border: 1px solid var(--1, #34BBD8);
  color: var(--3, #34BBD8);
}

.c-featuredItem__present.c-featuredItem__present--04 .c-featuredItem__campaignBox {
  border: 2px solid var(--3, #34BBD8);
}

.c-featuredItem__present.c-featuredItem__present--04 .c-featuredItem__campaignTitle {
  background-color: var(--3, #34BBD8);
}

.c-featuredItem__present.c-featuredItem__present--04 .c-featuredItem__campaignDate {
  color: var(--3, #34BBD8);
}

.c-friendCta {
  background: var(--white, #FFFFFF);
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  align-items: center;
  padding: 3.2rem 0 4.2rem;
  border-radius: 3rem;
}

.c-friendCta__group {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

.c-friendCta__lead {
  display: flex;
  gap: 0.2rem;
  margin-bottom: -0.8rem;
  align-items: center;
  justify-content: center;
}

.c-friendCta__leadDeco {
  width: 2.2rem;
  height: 2.6rem;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.c-friendCta__leadDeco--pink {
  background-image: url("data:image/svg+xml,%3Csvg width='23' height='26' viewBox='0 0 23 26' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 2C7 8 12 14 21 24' stroke='%23F62A7E' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E");
}

.c-friendCta__leadDeco--blue {
  background-image: url("data:image/svg+xml,%3Csvg width='23' height='26' viewBox='0 0 23 26' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 2C7 8 12 14 21 24' stroke='%2334BBD8' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E");
}

.c-friendCta__leadDeco--right {
  transform: scaleX(-1);
}

.c-friendCta__leadText {
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  color: white;
  font-size: 2rem;
  font-weight: 700;
  line-height: 130%;
  padding: 0 0.6rem 0 0.6rem;
}

.c-friendCta__leadText--pink {
  -webkit-text-stroke-width: 0.5rem;
  -webkit-text-stroke-color: var(--accent_pink, #F62A7E);
  paint-order: stroke fill;
}

.c-friendCta__leadText--blue {
  -webkit-text-stroke-width: 0.5rem;
  -webkit-text-stroke-color: var(--3, #34BBD8);
  paint-order: stroke fill;
}

.c-friendCta__btnArea {
  width: 100%;
  padding: 0 2.4rem;
}

.c-friendCta__btnImg {
  display: block;
  width: 100%;
}

.c-friendCta__btnImg img {
  width: 100%;
  height: auto;
}

.c-friendCta__btn {
  display: flex;
  height: 5.8rem;
  align-items: center;
  justify-content: center;
  padding: 1.6rem 3rem 1.6rem 4.4rem;
  border-radius: 4.6rem;
  position: relative;
  text-decoration: none;
  width: 100%;
}

.c-friendCta__btn--pink {
  background: var(--accent_pink, #F62A7E);
}

.c-friendCta__btn--blue {
  background: var(--3, #34BBD8);
}

.c-friendCta__btnIcon {
  position: absolute;
  left: -0.7rem;
  top: 50%;
  transform: translateY(-50%);
  width: 6.8rem;
  height: 6.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.c-friendCta__btnIcon img {
  width: 6.4rem;
  height: 6.4rem;
  border-radius: 50%;
  object-fit: cover;
}

.c-friendCta__btnText {
  color: var(--white, #FFFFFF);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 2.4rem;
  font-weight: 900;
  line-height: 130%;
  text-align: center;
}

.c-friendCta__btnArrow {
  position: absolute;
  right: 1.8rem;
  top: 50%;
  transform: translateY(-50%) rotate(-90deg);
  width: 2.4rem;
  height: 2.4rem;
  background: url(/common_2025/img/svg/arrowDown--white.svg) no-repeat center;
  background-size: contain;
}

.c-friendCta__note {
  color: var(--sub3, #9A9BA5);
  font-feature-settings: "palt" on;
  font-family: "Noto Sans JP";
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 150%;
  padding: 0 2.4rem;
  margin: 0;
}

.presentCampaign h2 {
  font-size: 3.6rem;
  color: var(--white, #FFFFFF);
  text-align: center;
  font-weight: 900;
  line-height: 120%;
}

.preset__lead {
  font-size: 2.4rem;
  color: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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--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.5rem;
  color: #999;
  font-size: 1rem;
}

.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: var(--white, #FFFFFF);
  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: 3.2rem;
  height: 3.2rem;
  background-image: url(/friend/img/carousel_btn_next.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(/friend/img/carousel_btn_back.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: var(--white, #FFFFFF);
  width: 100%;
  max-width: 34rem;
  border-radius: 1rem;
  padding: 3.2rem;
  position: relative;
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.3);
}

.modalContent__closeBtn {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: #e0e0e0;
  color: var(--sub2, #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: var(--white, #FFFFFF);
  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);
}

.sectionDivider--blue .sectionDivider__icon {
  color: var(--white, #FFFFFF);
  background-color: #0099EB;
}

.sectionDivider--01 .sectionDivider__icon {
  background-color: white;
  color: var(--2, #00ADEA);
}

.c-bonusPresent {
  background-color: #0099EB;
  padding: 4.8rem 1.4rem;
  text-align: center;
  color: var(--white, #FFFFFF);
}

.c-bonusPresent--02 {
  background-color: var(--1, #3399FF);
}

.c-bonusPresent--03 {
  background-color: var(--2, #00ADEA);
}

.c-bonusPresent--04 {
  background-color: var(--3, #34BBD8);
}

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

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

.ticketBox {
  background-color: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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;
}

.c-bonusPresent__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;
}

.c-bonusPresent__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: var(--white, #FFFFFF);
  padding: 0.8rem;
  position: relative;
}

.campaignInfo__tag {
  display: inline-block;
  background-color: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  width: 8.2rem;
  height: 8.2rem;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border: 0.2rem solid var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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;
  color: #00B4F6;
  margin-bottom: 2rem;
}

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

.referralFlow__tabBtn {
  flex: 1;
  background-color: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
}

.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: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 1.6rem;
}

.flowStep__stepLabel {
  background-color: #00BFFF;
  color: var(--white, #FFFFFF);
  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: var(--text, #414358);
  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;
  color: #00B4F6;
}

.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;
  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: var(--text, #414358);
  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: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  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: var(--white, #FFFFFF);
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0;
  line-height: 120%;
}

.faqCard__body {
  padding: 1.6rem;
  background-color: var(--white, #FFFFFF);
}

.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: var(--0-guide, #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: 4rem;
  transform: translate(0, -50%);
  display: flex;
  width: 26rem;
  flex-direction: column;
  align-items: center;
}

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

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

.cta_interest {
  color: var(--white, #FFFFFF);
  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: var(--white, #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;
}

.ctaBoxInte .c-friendCta__lead {
  margin-bottom: -0.3rem;
}

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

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

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

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