@charset "UTF-8";
* {
  font-family: "Noto Sans", sans-serif;
}

@font-face {
  font-family: "Noto Sans JP";
  font-weight: 400;
  src: url("../assets/font/Noto_Sans_JP/static/NotoSansJP-Regular.woff") format("woff");
}
@font-face {
  font-family: "Noto Sans JP";
  font-weight: 700;
  src: url("../assets/font/Noto_Sans_JP/static/NotoSansJP-Bold.woff") format("woff");
}
/* base */
.forSp {
  display: none !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

@media (max-width: 767px) {
  .forSp {
    display: block !important;
  }
}
.forPc {
  display: block !important;
}

@media (max-width: 767px) {
  .forPc {
    display: none !important;
  }
}
.linkTxt a {
  font-family: "Noto Sans JP";
}

main {
  background-color: #fff;
  overflow: hidden;
}

h2 {
  align-self: stretch;
  color: #281409;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 48px;
  font-style: normal;
  font-weight: 900;
  line-height: 150%;
  margin-bottom: 40px;
}

h2.head_deco {
  position: relative;
  margin-bottom: 60px;
}

h2.head_deco::after {
  position: absolute;
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  left: 50%;
  transform: translate(-50%);
  bottom: -12px;
  width: 60px;
  height: 9px;
  background-image: url(/campaign/xprice/20251001_cp/img/head_deco.svg);
}

@media (max-width: 767px) {
  h2 {
    font-size: 32px;
    margin-bottom: 40px;
  }
  h2.head_deco {
    position: relative;
    margin-bottom: 40px;
  }
}
.note {
  width: 100%;
  text-align: left;
}

.note li {
  flex: 1 0 0;
  color: #676767;
  font-family: "Noto Sans JP";
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 160%;
  position: relative;
  padding-left: 16px;
}

.note li:not(:first-of-type) {
  margin-top: 4px;
}

@media (max-width: 767px) {
  .note li {
    font-size: 11px;
    padding-left: 14px;
  }
}
.note li::before {
  position: absolute;
  left: 0;
  content: "※";
}

.blank {
  padding-left: 4px;
}

.blank::before {
  content: "";
  display: inline-block;
  width: 11px;
  height: 11px;
  background: url(/campaign/xprice/20251001_cp/img/icon_link.svg) no-repeat;
}

.btn_store {
  display: flex;
  width: 400px;
  padding: 14px 0 16px 0;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 10px;
  background: #343434;
  box-shadow: 0 -4px 0 0 rgba(0, 0, 0, 0.15) inset;
  text-decoration: none;
  margin: 0 auto;
}

.btn_store .btn_store_inner {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 150%;
  position: relative;
  padding-right: 16px;
}

.btn_store .btn_store_inner::after {
  position: absolute;
  content: "";
  display: inline-block;
  width: 11px;
  height: 11px;
  background: url(/campaign/kohnan/img/icon_link_white.svg) no-repeat;
  right: -2px;
  top: 50%;
  transform: translateY(-50%);
}

@media (max-width: 767px) {
  .btn_store {
    width: 310px;
  }
  .btn_store .btn_store_inner {
    font-size: 13px;
  }
}
.header {
  width: 97%;
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translate(-50%);
  z-index: 10;
}

.headerArea {
  display: flex;
  padding: 12px 40px;
  justify-content: space-between;
  align-items: center;
  align-self: stretch;
  border-radius: 15px;
  background: #fff;
  box-shadow: 0 3px 20px 0 rgba(0, 0, 0, 0.1);
}

.headerAnchor {
  width: 100%;
}

.headerArea ul {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  gap: 32px;
}

.headerArea ul li a {
  display: flex;
  padding: 16px 0;
  justify-content: center;
  align-items: center;
  align-self: stretch;
  color: var(--B-MAIN-BLACK, #2c3131);
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 900;
  line-height: 150%;
  text-decoration: none;
}

.headerLogo {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  margin-right: 16px;
}
.headerLogo a {
  position: relative;
}
.headerLogo a:nth-child(1) {
  width: 75px;
}
.headerLogo a:nth-of-type(2)::before {
  position: absolute;
  top: 50%;
  left: -12px;
  content: "";
  width: 1px;
  height: 24px;
  background-color: #b3b3b3;
  transform: translate(-50%, -50%);
}

@media (max-width: 1100px) {
  .header {
    width: 100%;
    height: 100%;
    top: auto;
    display: none;
  }
  .header.open {
    display: block;
  }
  .headerArea {
    height: 100%;
    padding: 64px;
    flex-direction: column;
    border-radius: 0;
    box-shadow: none;
    background: rgba(249, 250, 250, 0.9);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
  }
  .headerLogo {
    display: none;
  }
  .headerArea ul {
    flex-direction: column;
    gap: 0;
  }
}
.menuBtn {
  display: none;
}

@media (max-width: 1100px) {
  .menuBtn {
    display: block;
    position: fixed;
    top: 12px;
    right: 12px;
    z-index: 11;
  }
  .menuBtn a {
    display: flex;
    width: 40px;
    height: 40px;
    padding: 14px 12px 15px 12px;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    border-radius: 500px;
    background: #ffeffa;
    box-shadow: 0 5px 4px 0 rgba(0, 0, 0, 0.15);
  }
}
.campaign_area {
  background-color: #68c4b1;
}

.campaign_area_term {
  display: flex;
  padding: 24px 16px 0 16px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  align-self: stretch;
  background-color: #68c4b1;
}

.campaign_area_term_inner {
  display: flex;
  max-width: 800px;
  padding: 40px 64px;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  flex: 1 0 0;
  border-radius: 30px;
  border: 1px solid rgba(40, 20, 9, 0.1);
  background-color: #fcf5ed;
  background-image: radial-gradient(rgba(211, 211, 211, 0.3) 10%, transparent 10%), radial-gradient(rgba(211, 211, 211, 0.3) 10%, transparent 10%);
  background-size: 40px 40px;
  background-position: 0 0, 20px 20px;
  box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.05);
}

.campaign_area_case {
  border-radius: 0 0 60px 60px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.4) 15%, #fff 100%);
  text-align: center;
  padding: 54px 0 75px;
}

.campaign_area_case_bubble {
  display: flex;
  padding: 7.5px 24px;
  justify-content: center;
  align-items: center;
  gap: 15px;
  border-radius: 150px;
  background: #281409;
  width: 168px;
  margin: 0 auto 18px;
}

.campaign_area_case_bubble span {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 30px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  position: relative;
}

.campaign_area_case_bubble span::after {
  content: "";
  position: absolute;
  bottom: -16px;
  right: 0;
  left: 0;
  width: 0;
  height: 0;
  margin: auto;
  border-style: solid;
  border-color: #281409 transparent transparent transparent;
  border-width: 9px 6px 0 6px;
  z-index: 1;
}

.campaign_area_case_text {
  color: #281409;
  text-align: center;
  font-feature-settings: "halt" on;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
  font-family: "Noto Sans JP";
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  margin-bottom: 27px;
}

.campaign_area_case_text span {
  font-family: "Noto Sans JP";
}

.campaign_area_case_image {
  max-width: 573px;
  margin: 0 auto;
}

@media (max-width: 767px) {
  .campaign_area_term_inner {
    padding: 24px 0 4px;
  }
  .campaign_area_term_inner_img {
    width: calc(100% + 20px);
    margin: 0 -10px;
  }
  .campaign_area_case {
    padding: 48px 24px;
    border-radius: 0 0 60px 60px;
  }
  .campaign_area_case_bubble {
    padding: 5px 16px;
    gap: 10px;
    border-radius: 100px;
    background: #281409;
    width: 112px;
    margin: 0 auto 14px;
  }
  .campaign_area_case_bubble span {
    font-size: 20px;
  }
  .campaign_area_case_bubble span::after {
    bottom: -11px;
    border-width: 7px 5px 0 5px;
  }
  .campaign_area_case_text {
    font-size: 16px;
    margin-bottom: 24px;
  }
}
.campaign_area_content {
  padding: 80px 16px 48px;
  background-color: #68c4b1;
}

.campaign_area_content h2 {
  color: #fff;
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.15);
}

.campaign_area_content h2.head_deco::after {
  background-image: url(/campaign/xprice/20251001_cp/img/head_deco_02.svg);
}

.campaign_area_content_inner {
  display: flex;
  padding: 40px 64px;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  align-self: stretch;
  border-radius: 30px;
  border: 1px solid rgba(40, 20, 9, 0.1);
  background: #fcf6ee;
  box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.05);
  max-width: 800px;
  margin: 0 auto 32px;
}

.campaign_area_content_inner_item {
  text-align: left;
  width: 100%;
}

.campaign_area_content_inner_item_head {
  color: #281409;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  position: relative;
  padding-left: 20px;
}

.campaign_area_content_inner_item_head::before {
  position: absolute;
  content: "";
  background-image: url(/campaign/xprice/20251001_cp/img/dot.svg);
  background-repeat: no-repeat;
  background-size: contain;
  width: 16px;
  height: 16px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

.campaign_area_content_inner_item_text {
  align-self: stretch;
  color: #363636;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 160%;
  margin-top: 4px;
}

@media (max-width: 767px) {
  .campaign_area_content {
    padding: 40px 16px 24px;
    background-color: #68c4b1;
  }
  .campaign_area_content_inner {
    padding: 32px 24px;
    gap: 16px;
  }
  .campaign_area_content_inner_item_head {
    font-size: 14px;
    padding-left: 16px;
  }
  .campaign_area_content_inner_item_head::before {
    width: 12px;
    height: 12px;
  }
  .campaign_area_content_inner_item_text {
    font-size: 14px;
    margin-top: 4px;
  }
}
/* appReg */
.appRegBg {
  background-image: url(/campaign/xprice/20251001_cp/img/pattern_stripe_atokara.svg);
  background-repeat: repeat;
  display: flex;
  padding: 48px 16px;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  align-self: stretch;
}

.appRegBg .btn_store {
  display: flex;
  max-width: 400px;
  padding: 10px 8px 14px 24px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 10px;
  background: var(--Gradation_orange, linear-gradient(180deg, #fbdc68 0%, #fac000 100%));
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25), 0 -4px 0 0 rgba(0, 0, 0, 0.2) inset;
}

.appRegBg .btn_store span {
  color: #fff;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 135%;
  letter-spacing: -0.32px;
}

.appRegBg .btn_store span span {
  text-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  font-size: 20px;
  letter-spacing: -0.2px;
}

.appRegBg .btn_store .btn_store_inner::after {
  width: 16px;
  height: 16px;
  background: url(/campaign/xprice/20251001_cp/img/icon.svg) no-repeat;
  right: -60px;
}

.appReg_text {
  color: #363534;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  margin-bottom: 8px;
}

@media (max-width: 767px) {
  .appRegBg {
    padding: 32px 16px;
    gap: 24px;
  }
  .appRegBg .btn_store span {
    font-size: 12px;
  }
  .appRegBg .btn_store span span {
    font-size: 16px;
  }
  .appRegBg .btn_store .btn_store_inner::after {
    right: -30px;
  }
  .appReg_text {
    font-size: 12px;
  }
}
/* about_atokara */
.about_atokara {
  display: flex;
  padding: 80px 16px 48px;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  align-self: stretch;
  background: #fafaf5;
}

.about_atokara_inner {
  display: flex;
  max-width: 800px;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  align-self: stretch;
  margin: 0 auto;
}

.about_atokara_inner h2 {
  margin-bottom: 0;
}

.about_atokara_text {
  align-self: stretch;
  color: #281409;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 180%;
}

.about_atokara_detail {
  display: flex;
  padding: 0 16px;
  align-items: flex-start;
  gap: 32px;
  align-self: stretch;
}

.about_atokara_detail_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1 0 0;
}

.about_atokara_detail_item_head {
  align-self: stretch;
  color: #281409;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 100%;
  letter-spacing: 0.42px;
  margin-top: 16px;
}

.about_atokara_detail_item_head_bold {
  align-self: stretch;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 900;
  line-height: 160%;
  letter-spacing: 0.48px;
  background: var(--Gradation_green, linear-gradient(180deg, #00b6c7 0.01%, #87c8aa 100.01%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-top: 8px;
}

.about_atokara_detail_item_text {
  align-self: stretch;
  color: #363534;
  font-family: "Noto Sans JP";
  font-size: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 180%;
  margin-top: 12px;
}

.about_atokara_detail_item_text + .appLink {
  margin-top: 12px;
}

.about_atokara_detail_item_text + .appLink .linkBtn {
  margin-top: 12px;
}
@media (min-width: 768px) {
  .about_atokara_detail_item_text + .appLink .linkBtn {
    margin-top: 0;
  }
}
.about_atokara_detail_item_text + .appLink .linkBtn a {
  display: flex;
  padding: 16px 0 16px 16px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 700;
  line-height: 150%;
  text-align: center;
  text-decoration: none;
  border-radius: 10px;
  background: #676767;
  box-shadow: 0 -4px 0 0 rgba(0, 0, 0, 0.30) inset;
  color: #FFF;
}

.about_atokara_detail_item_text + .appLink .linkBtn a .blank::before {
  width: 10px;
  height: 10px;
  background: url(/campaign/xprice/20251001_cp/img/icon_link_white.svg) no-repeat;
}

.about_atokara_detail_item_text + .appLink .note {
  position: relative;
  padding-left: 16px;
  margin-top: 0;
  font-size: 11px;
  color: #676767;
}
@media (min-width: 768px) {
  .about_atokara_detail_item_text + .appLink .note {
    margin-top: 12px;
    font-size: 12px;
  }
}
.about_atokara_detail_item_text + .appLink .note + .note {
  margin-top: 4px;
}
.about_atokara_detail_item_text + .appLink .note::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}

.about_atokara_payment {
  display: flex;
  padding: 40px 64px;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  align-self: stretch;
  border-radius: 30px;
  border: 1px solid rgba(40, 20, 9, 0.1);
  background: #fff;
  box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.05);
}

.about_atokara_payment_head {
  align-self: stretch;
  color: #281409;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 24px;
  font-style: normal;
  font-weight: 900;
  line-height: 150%;
}

.about_atokara_payment_text {
  align-self: stretch;
  color: #281409;
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 180%;
}

.about_atokara_payment img {
  width: 500px;
}

@media (max-width: 767px) {
  .about_atokara {
    padding: 64px 16px 40px;
    gap: 24px;
  }
  .about_atokara_inner {
    gap: 24px;
  }
  .about_atokara_text {
    font-size: 14px;
    text-align: left;
  }
  .about_atokara_detail {
    flex-direction: column;
  }
  .about_atokara_detail_item {
    width: 100%;
    text-align: center;
  }
  .about_atokara_detail_item_head_bold {
    font-size: 22px;
    letter-spacing: 0.66px;
  }
  .about_atokara_detail_item_text {
    font-size: 14px;
    margin-top: 12px;
  }
  .about_atokara_payment {
    padding: 32px 24px;
    gap: 16px;
  }
  .about_atokara_payment_head {
    font-size: 22px;
  }
  .about_atokara_payment_text {
    text-align: left;
  }
  .about_atokara_payment img {
    width: 100%;
  }
}
/* how_to_use */
.how_to_useBg {
  background: #fcf6ee;
}

.how_to_useInner {
  display: flex;
  max-width: 1440px;
  width: 100%;
  padding: 5.5em 0;
  flex-direction: column;
  align-items: center;
}

.how_to_useTabArea {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3.5em;
  margin: 0 auto 6.4vw;
}

@media (max-width: 767px) {
  .how_to_useTabArea {
    gap: 8px;
  }
}
.tabButton {
  height: 73px;
}

.howToUse-tabs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.howToUse-tabs li {
  color: var(--BRAND_ATOKARA, linear-gradient(180deg, #00a1b0 0%, #86c9ab 100%));
  border: 2px solid var(--BRAND_ATOKARA, #00a1b0);
  border-radius: 100px;
  background: #fff;
  width: 332px;
  display: flex;
  padding: 1.25em 2.5em;
  text-align: center;
  justify-content: center;
  align-items: center;
  gap: 0.625em;
  align-self: stretch;
  position: relative;
  cursor: pointer;
}

.howToUse-tabs li .tabText {
  font-family: "Noto Sans JP";
  font-size: 1em;
  font-style: normal;
  font-weight: 700;
  line-height: 115%;
  letter-spacing: 0.8px;
  background: var(--BRAND_ATOKARA, linear-gradient(180deg, #00a1b0 0%, #86c9ab 100%));
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.howToUse-tabs li.-current .tabText {
  color: #fff;
  background: #fff;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.howToUse-tabs li.-current {
  color: #fff;
  border: none;
  background: var(--BRAND_ATOKARA, linear-gradient(180deg, #00a1b0 0%, #86c9ab 100%));
  pointer-events: none;
  z-index: 1;
}

.howToUse-tabs li:first-child {
  margin-right: -4em;
}

.howToUse-tabs li.-current::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 47%;
  width: 0;
  height: 0;
  border-top: 15px solid #84c9ab;
  border-left: 8.5px solid transparent;
  border-right: 8.5px solid transparent;
}

li::after {
  transition: 0.3s;
}

.howToUse-tabContents {
  margin: 0 auto 2.1875em;
}

@media (max-width: 767px) {
  .howToUse-tabContents {
    width: 91%;
  }
}
.howToUse-tabContents > div.-current {
  display: block;
}

.howToUse-tabContents > div {
  display: none;
}

.howToUse-slider {
  padding-top: 0.625em;
  margin: 2em -1.25em 0;
}

.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  display: flex;
  max-width: 800px;
  align-items: flex-start;
}

.swiper-slideContents {
  display: flex;
  max-width: 260px;
  width: auto;
  flex-direction: column;
  align-items: inherit;
  flex-shrink: 0;
}

.swiper-imgeArea img {
  width: 200px;
  margin: 16px auto 24px auto;
}

.swiper-slide-text {
  display: flex;
  align-items: center;
}
@media (min-width: 768px) {
  .swiper-slide-text {
    align-items: flex-start;
  }
}

.swiper-slide-text img {
  padding-top: 4px;
  display: block;
  margin: 0 auto;
}

@media (max-width: 767px) {
  .swiper-slide-text img {
    padding-top: 0;
  }
}
.swiper-container-buy,
.swiper-container-register {
  margin: 0 auto 2em;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  z-index: 1;
}

.swiper-container-buy + .note {
  text-align: center;
  margin-bottom: 32px;
}

@media (max-width: 767px) {
  .swiper-container-buy + .note {
    text-align: left;
  }
}
.swiper-container-buy + .note li {
  display: inline-block;
}

.swiper-container-autoheight .swiper-wrapper {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-transition-property: height, -webkit-transform;
  transition-property: height, -webkit-transform;
  transition-property: transform, height;
  transition-property: transform, height, -webkit-transform;
}

.swiper-container-register .swiper-slide,
.swiper-wrapper {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 567.21px;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition-property: -webkit-transform;
  transition-property: -webkit-transform;
  transition-property: transform, -webkit-transform;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  transform: translate3d(0, 0, 0);
}

.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
  height: auto;
}

.howToUse-swiper {
  max-width: 410px;
  height: 64px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 32px;
}

.howToUse-swiper .swiper-button-buy-right {
  cursor: pointer;
}

.howToUse-swiper .swiper-button-register-right {
  cursor: pointer;
}

.howToUse-swiper .swiper-button-buy-left {
  cursor: pointer;
}

.howToUse-swiper .swiper-button-register-left {
  cursor: pointer;
}

.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  max-width: 169px;
  margin: 0;
  justify-content: center;
  color: #363534;
}
@media (min-width: 768px) {
  .swiper-horizontal > .swiper-pagination-bullets,
  .swiper-pagination-bullets.swiper-pagination-horizontal,
  .swiper-pagination-custom,
  .swiper-pagination-fraction {
    font-size: 28px;
  }
}

.howToUse-swiper .swiper-buy-pagenation .swiper-pagination-bullet {
  background-color: #d9d9d9;
  width: 8px;
  height: 8px;
  border-radius: 10px;
  cursor: pointer;
}

.howToUse-swiper .swiper-buy-pagenation .swiper-pagination-bullet-active {
  background: var(--BRAND_ATOKARA, linear-gradient(180deg, #00a1b0 0%, #86c9ab 100%));
}

.howToUse-swiper .swiper-register-pagenation .swiper-pagination-bullet {
  background-color: #d9d9d9;
  width: 8px;
  height: 8px;
  border-radius: 10px;
  cursor: pointer;
}

.howToUse-swiper .swiper-register-pagenation .swiper-pagination-bullet-active {
  background: var(--BRAND_ATOKARA, linear-gradient(180deg, #00a1b0 0%, #86c9ab 100%));
}

.howToUse-swiper .swiper-button-disabled {
  opacity: 0.5;
  pointer-events: none;
}

@media screen and (max-width: 850px) and (min-width: 768px) {
  .swiper-slideContents {
    width: 23.5vw;
    max-width: unset;
  }
  .swiper-autoheight .swiper-wrapper {
    max-width: 700px;
  }
}


/* banner */
.banner {
  background: #FAFAF5;
}
.bannerContents {
  margin: 0 auto;
  padding: 48px 0;
}
.bannerContents h2 {
  position: relative;
  width: fit-content;
  margin: 0 auto;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 130%;
  text-align: center;
  letter-spacing: 1px;
  color: #343434;
}
.bannerContents h2::before,
.bannerContents h2::after {
  content: "";
  position: absolute;
  bottom: 0;
  height: 15px;
  width: 2px;
  border-radius: 2px;
  background: #343434;
}
.bannerContents h2::before {
  left: -15px;
  transform: rotate(-30deg);
}
.bannerContents h2::after {
  right: -15px;
  transform: rotate(30deg);
}
.bannerlist {
  margin: 16px auto 0;
  text-align: center;
}
.bannerlist img {
  margin: 0 auto;
}
@media (max-width: 767px) {
  .bannerContents {
    margin: 0 16px;
    padding: 40px 0;
  }
  .bannerContents h2 {
    font-size: 16px;
    letter-spacing: 0.8px;
  }
  .bannerContents h2::before,
  .bannerContents h2::after {
    height: 12px;
  }
  .bannerContents h2::before {
    left: -8px;
  }
  .bannerContents h2::after {
    right: -8px;
  }
}


/* faq */
.faq {
  max-width: 800px;
  margin: 0 auto;
  background: #fff;
}

.faqContents {
  margin: 0;
  max-width: 800px;
}

.faqInner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  align-self: stretch;
  padding: 80px 0 0;
}

.faqItem {
  border-top: 2px solid #ccc8c6;
  border-bottom: 2px solid #ccc8c6;
  background: var(--WHITE, #fff);
}

.faqItem:last-child {
  border-top: none;
}

.qaList dl {
  position: relative;
  margin: 0;
  padding: 32px 32px 32px 40px;
  cursor: pointer;
  border-bottom: 1px solid #ccc8c6;
}

.accordionArea:first-of-type .qaList dl {
  border-top: 1px solid #ccc8c6;
}

.qaList dl .plus {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  display: block;
  width: 16px;
  height: 16px;
  margin: auto;
  content: "";
  transition: 0.3s ease all;
}

.qaList dl .plus:before,
.qaList dl .plus:after {
  position: absolute;
  content: "";
  display: block;
  transition: all 0.4s;
  background: #4f433a;
  left: 10%;
  top: 50%;
  width: 100%;
  height: 2px;
  transform: translate(-50%, -50%);
}

.qaList dl .plus:before {
  transform: translate(-50%, -50%) rotate(90deg);
}

.qaList dl.open .plus::before {
  transform: translate(-50%, -50%) rotate(0deg);
}

.qaList dl dt {
  font-family: "Noto Sans JP";
  color: #343434;
  position: relative;
  font-weight: 600;
  margin: 0;
  padding: 0 56px;
  line-height: 180%;
}

.qaList dl dt::before {
  position: absolute;
  content: "";
  background-image: url(/campaign/ms-lab/img/icon_q.svg);
  width: 32px;
  height: 32px;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  background-size: contain;
  background-repeat: no-repeat;
}

.qaList dl dd::before {
  font-size: 1.375em;
  line-height: 1;
  position: absolute;
  top: 3px;
  left: 2px;
  display: block;
  font-weight: bold;
}

.qaList dl dd {
  position: relative;
  height: 0;
  overflow: hidden;
  opacity: 0;
  line-height: 0;
  transition-duration: 0.3s;
  padding: 0 70px 0 56px;
}

.qaList dl.open dd {
  position: relative;
  height: auto;
  opacity: 1;
  margin: 16px 0 0;
}

.qaList dl dd p {
  margin: 1.875em 0 0;
  font-family: "Noto Sans JP";
}

.qaList dl dd p:first-child {
  margin-top: 0;
}

.accordionContent .txtLink,
.accordionContent .notesList {
  padding-top: 8px;
}

.faqNote {
  margin-top: 8px;
  font-size: 14px;
  font-weight: 300;
  line-height: 160%;
}

.accordionArea p {
  color: #343434;
  font-style: normal;
  font-weight: 300;
  line-height: 180%;
}

.accordionContent ul {
  line-height: 160%;
}

.accordionContent .infoNote {
  margin: 8px 0 0;
  color: #4f433a;
}

.accordionContent p:nth-of-type(2) {
  margin-top: 8px;
}

.noteInfo {
  margin-top: 0;
}

.faqNote .linkTxt a {
  font-size: 12px;
  color: #3e3a2a;
  text-underline-offset: 0.3ex;
}

.qaList .faqAnnotation {
  position: relative;
  padding-left: 16px;
  margin-top: 4px;
  font-size: 11px;
  color: #676767;
}
@media (min-width: 768px) {
  .qaList .faqAnnotation {
    font-size: 12px;
  }
}
.qaList .faqAnnotation::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}

.qaList .faqAnnotationNum {
  counter-reset: listnum;
	list-style: none;
  margin-top: 8px;
}
.qaList .faqAnnotationNum p {
  position: relative;
  padding-left: 24px;
  margin-top: 4px;
  font-size: 11px;
  color: #676767;
}
@media (min-width: 768px) {
  .qaList .faqAnnotationNum p {
    font-size: 12px;
  }
}
.qaList .faqAnnotationNum p::before {
  counter-increment: listnum;
	content: "※" counter(listnum);
  position: absolute;
  top: 0;
  left: 0;
}

.qaList .faqAnnotationNum + .faqAnnotation {
  margin-top: 4px;
  padding-left: 24px;
}

@media (max-width: 767px) {
  .faq {
    padding: 40px 16px 24px;
    gap: 32px;
  }
  .faqContents {
    margin: 0 8px;
  }
  .qaList dl {
    position: relative;
    padding: 24px 16px 16px 16px;
  }
  .qaList dl::before {
    top: 20px;
    right: 20px;
    width: 7px;
    height: 7px;
  }
  .qaList dl dt {
    font-size: 14px;
    padding: 0 4em 0 2.9em;
  }
  .qaList dl dd {
    padding: 0;
    font-size: 14px;
  }
  .qaList dl dd p {
    margin: 30px 0 0;
  }
  .qaList dl dd p:first-child {
    margin-top: 0;
  }
  .qaList dl .plus {
    right: 0;
    width: 16px;
    height: 16px;
    top: 50%;
    transform: translateY(-50%);
  }
  .qaList dl dt::before {
    top: 14px;
    width: 24px;
    height: 24px;
  }
  .faqNote .faqAnnotation {
    margin-top: 8px;
    font-size: 12px;
    color: #3e3a2a;
    text-underline-offset: 0.3ex;
  }
}
/* caution */
.caution {
  padding-top: 80px;
  padding-bottom: 40px;
  margin-top: 48px;
  background: #fafaf5;
}
.caution_container {
  max-width: 800px;
  margin: 0 auto;
}

.caution img {
  margin: 40px auto 32px auto;
}

.cautionNote {
  color: #343434;
  font-size: 12px;
  font-style: normal;
  font-weight: 300;
  line-height: 160%;
}

.cautionNote .noteItem:not(:last-child) {
  margin-bottom: 4px;
}

@media (max-width: 767px) {
  .caution {
    padding: 40px 16px 24px;
  }
  .caution img {
    width: 167px;
    margin: 40px auto 32px auto;
  }
  .cautionNote li {
    font-size: 11px;
  }
}
.contentWidth800 {
  max-width: 800px;
  margin: 0 auto;
}

.contentWidth700 {
  max-width: 700px;
  margin: 0 auto;
}

.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.detailText {
  display: flex;
  align-items: center;
  flex: 1 0 0;
  color: #363534;
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 180%;
  padding-left: 8px;
}

.textLarge {
  font-size: 16px;
}

.textSmall {
  font-size: 16px;
  line-height: 180%;
}

/* details */
/* how to use */
.useSlider .detailText {
  color: #141210;
}

.featuresText .detailText {
  text-align: left;
  font-size: 14px;
}

.featuresText .linkText {
  justify-content: center;
}

.aboutHeadText .detailText {
  text-align: center;
}

.featuresText .notesList {
  width: auto;
  display: flex;
  justify-content: center;
}

/* faq */
.question.detailText {
  font-weight: 600;
}

/* link */
.linkText {
  font-family: "Noto Sans JP";
  color: #4f433a;
  font-size: 12px;
  font-style: normal;
  font-weight: 300;
  line-height: 130%;
  text-decoration-line: underline;
  display: flex;
  align-items: center;
  gap: 4px;
}

.linkText-text {
  font-size: 12px;
  font-family: "Noto Sans JP";
}

.linkText .blank,
.accLinkText .blank {
  position: relative;
  padding-left: 4px;
}

.linkText .blank::before,
.accLinkText .blank::before {
  position: absolute;
  content: "";
  display: inline-block;
  width: 10px;
  height: 11px;
  bottom: -6px;
  background: url(/campaign/kohnan/img/icon_link.svg) no-repeat;
}

.about_atokaraContents .linkText .blank::before,
.caution .linkText .blank::before,
.app_dl .linkText .blank::before {
  background: url(/campaign/kohnan/img/icon_link_brown.svg) no-repeat;
}

.linkText .anchor {
  height: 16px;
}

.linkText .anchor::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url(/campaign/kohnan/img/icon_arrow_bottom.svg) no-repeat;
}

@media (max-width: 767px) {
  .linkText {
    font-size: 11px;
  }
}
.app_dlContents .linkText {
  justify-content: center;
  color: var(--Brown, #4f433a);
  font-size: 11px;
}

.caution .linkText {
  display: inline-block;
}

.mvContentsIntroText {
  text-align: center;
  color: #000;
  font-family: "Noto Sans JP";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: 130%;
}

footer .linkText {
  color: #000;
}

@media screen and (min-width: 1100px) {
  a:hover {
    opacity: 50%;
    transition: 0.4s ease-out;
  }
  .howToUse-tabs li:hover {
    opacity: 0.5;
    transition: 0.4s ease-out;
  }
}
button:hover {
  opacity: 0.5;
  transition: 0.4s ease-out;
}

/* note */
.notesList {
  display: table;
  width: 100%;
  margin: 0;
  padding-left: 0;
}

.notesList li {
  list-style: none;
}

.noteHead {
  display: table-cell;
  font-size: 0.875em;
  line-height: 160%;
  white-space: nowrap;
  padding-right: 4px;
  color: #000;
}

.noteText {
  font-family: "Noto Sans JP";
  color: #4f433a;
  font-size: 12px;
  font-style: normal;
  font-weight: 300;
  line-height: 140%;
  display: table-cell;
}

.flowContents .noteText,
.flowContents .noteHead {
  font-size: 12px;
}

.detailsContents .noteText,
.detailsContents .noteHead {
  color: #141210;
}

/* footer */
footer {
  display: flex;
  flex-flow: column;
  width: 100%;
  padding: 2em 0;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
  background: #363534;
}

footer .linkText {
  color: #fff;
  font-size: 11px;
  text-decoration: none;
}

footer .linkText .blank::before {
  background: url(/campaign/kohnan/img/icon_link_white.svg) no-repeat;
}

footer .CopyrightText {
  font-family: "Noto Sans JP";
  font-size: 11px;
  color: #fff;
}

.footerBtn {
  position: relative;
  transition: 0.2s;
  opacity: 0;
  z-index: -1;
}

.footerBtnPop {
  position: absolute;
  transform: translate(-50%, -50%);
  left: 50%;
  top: 0;
  border-radius: 8px;
  border: 1px solid #00a1b0;
  background: linear-gradient(90deg, #00a1b0 0%, #86c9ab 100%);
  display: flex;
  padding: 2px 12px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  color: #fff;
  text-align: center;
  font-family: "Hiragino Kaku Gothic Pro";
  font-size: 12px;
  font-style: normal;
  font-weight: 600;
  line-height: 200%;
}

.footerBtn .mvCvContentsBtn .linkArrowWhite::before {
  display: none;
}

.footerBtn .mvCvContentsBtn .linkArrowGreen::before {
  display: none;
}

.footerBtnInner {
  width: 100%;
  height: 80px;
  line-height: 80px;
  background-color: rgba(79, 73, 66, 0.5);
  color: #fff;
  display: inline-block;
  text-align: center;
  position: fixed; /* 画面に固定する */
  bottom: 0;
  right: 0;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.footerBtnInner .mvCvContentsBtnList {
  max-width: 720px;
  margin: 0 auto;
  justify-content: center;
  padding: 14px 0;
}

@media screen and (max-width: 767px) {
  footer p {
    font-size: 2.667vw;
    font-family: "Noto Sans JP";
  }
}
.sticky_btn .appRegBg {
  padding: 0;
}

.sticky_btn .appRegBg .btn_store {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  width: 100%;
  max-width: 500px;
  padding: 10px 8px 14px 24px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 0 0;
  box-shadow: none;
}
@media (min-width: 768px) {
  .sticky_btn .appRegBg .btn_store {
    border-radius: 10px 10px 0 0;
  }
}

.sticky_btn .appRegBg .btn_store .btn_store_inner {
  padding-right: 0;
  font-size: 16px;
  color: #343434;
}
@media (min-width: 768px) {
  .sticky_btn .appRegBg .btn_store .btn_store_inner {
    font-size: 20px;
  }
}

.sticky_btn .appRegBg .btn_store .btn_store_inner::after {
  content: none;
}

@media screen and (max-width: 767px) {
  .sticky_btn .appRegBg .btn_store {
    width: 100%;
    padding: 7px 16px 7px 24px;
  }
}
/* モーダル */
.mvCvContentsBtnAppModal {
  position: relative;
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: 0.3s;
  box-sizing: border-box;
  z-index: 9999;
  pointer-events: none;
}

.mvCvContentsBtnAppModal.is-active {
  position: fixed;
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.mvCvContentsBtnAppModalInner {
  position: absolute;
  margin: 0 auto;
  width: 880px;
  height: auto;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  padding: 40px 40px;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  border-radius: 10px;
  background: url(<path-to-image>) #fff 0% 0%/50px 50px repeat;
  background-image: url(/campaign/kohnan/img/pattern_stripe_atokara.svg);
  background-repeat: repeat;
  background-size: cover;
  background-clip: border-box;
}

.mvCvContentsBtnAppModalClose {
  transform: translate(-50%, -50%);
  position: absolute;
  align-items: center;
  justify-content: center;
  top: -5%;
  left: 97%;
  width: 32px;
  height: 32px;
  color: #fff;
  border-radius: 50%;
  cursor: pointer;
  z-index: 900;
  font-size: 30px;
}

.atokaraMain {
  max-width: 460px;
  margin: 0 auto 32px;
  display: flex;
  justify-content: center;
}

.atokaraiIcon {
  margin-right: 15px;
}

.atokaraText {
  color: var(--TEXT-BASE, #4f433a);
  font-family: "DNP ShueiMGoStd";
  font-size: 32px;
  font-style: normal;
  font-weight: 700;
  line-height: 150%;
  text-align: left;
}

.atokraAppDl {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin: 16px 0 24px;
}

.atokraAppDlTitle {
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  color: #23272C;
}

.atokraAppDlText {
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
  color: #23272C;
}

.atokraAppDlText span {
  font-size: 20px;
  color: #004097;
}

.atokraAppDlApple,
.atokraAppDlGoogle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 16px;
  border-radius: 10px;
  background: #FFF;
  box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.15);
}

.atokraAppDlIcon {
  margin-right: 20px;
  display: flex;
  align-items: center;
}

.atokraAppDlAppleIconQR,
.atokraAppDlGoogleIconQR {
  width: 105px;
}

/* SP */
@media (max-width: 900px) {
  .mvCvContentsBtnAppModalInner {
    width: 93.6vw;
    padding: 10.667vw 4.267vw;
  }
}
@media (max-width: 767px) {
  .mvCvContentsBtnAppModalClose {
    bottom: -5.6vw;
    right: 5.333vw;
    width: 4.267vw;
    height: 4.267vw;
  }
  .atokaraTextWrap {
    display: flex;
    align-items: center;
    font-family: "DNP ShueiMGoStd";
  }
  .atokraAppDl {
    justify-content: center;
  }
  .atokaraText {
    font-family: "DNP ShueiMGoStd";
    font-size: 4.8vw;
  }
  .atokaraMain {
    margin-bottom: 6.4vw;
  }
  .atokraAppDlApple {
    margin-right: 4vw;
  }
  .atokraAppDlIcon {
    margin-right: 0;
  }
}
/* backTopBtn */
.backTopBtn {
  position: relative;
  transition: 0.2s;
  opacity: 0;
  z-index: -1;
}

.backTopBtn img {
  position: fixed;
  width: 60px;
  transform: translate(-40%, -40%);
  right: 0;
  bottom: 0;
}

/* SP */
@media (max-width: 767px) {
  .backTopBtn img {
    width: 40px;
    right: -4px;
    bottom: 52px;
  }
}
@media (max-width: 767px) {
  /* br */
  .br-sp::before {
    content: "\a";
    white-space: pre;
  }
  /* headline */
  h3 {
    font-size: 16px;
  }
  h3 .dots {
    content: url(/campaign/kohnan/img/logo_h3_dot.svg);
    width: 8px;
    height: 8px;
  }
  /* text */
  .detailText {
    color: #4f433a;
    font-size: 14px;
    font-style: normal;
    font-weight: 300;
    line-height: 200%;
  }
  .textLarge {
    font-size: 14px;
  }
  .textSmall {
    font-size: 14px;
    line-height: 180%;
  }
  /* details */
  .detailsContents .detailText {
    text-align: center;
    color: #141210;
  }
  /* how to use */
  .useSlider .detailText {
    text-align: left;
    color: #141210;
  }
  .swiper-slide-text .detailText {
    text-align: left;
    font-size: 14px;
    font-weight: 400;
    line-height: 180%;
  }
  .featuresText {
    margin: 0 auto;
  }
  .featuresText .linkText {
    font-size: 11px;
  }
  .featuresText .notesList {
    margin: 0 auto;
  }
  .featuresText > .txtLink > .notesList > li > .noteText {
    font-size: 11px;
  }
  .txtLink .noteText,
  .txtLink .noteHead {
    font-size: 16px;
  }
  /* faq */
  .question.detailText {
    font-weight: 600;
  }
  /* notelist */
  .noteHead {
    font-size: 16px;
    line-height: 180%;
    padding-right: 4px;
  }
  .noteText {
    padding-bottom: 1.067vw;
    color: #4f433a;
    font-size: 11px;
    line-height: 140%; /* 22.4px */
  }
  .flowContents .noteText,
  .flowContents .noteHead {
    font-size: 12px;
  }
  /* floatbtn */
  .fix-btn {
    width: 72px;
    bottom: 12px;
  }
  .mvContents {
    gap: 16px;
    padding: 160px 0 151px;
  }
  .mvContentsIntro {
    padding: 12px;
    border-top: 3px solid #00a0af;
    border-bottom: 3px solid #00a0af;
  }
  .mvContentsIntroText {
    text-align: center;
    color: #000;
    font-family: "Noto Sans JP";
    font-size: 12px;
    font-style: normal;
    font-weight: 600;
    line-height: 130%;
  }
  .mvContentsIntroTextLarge {
    font-family: "Noto Sans JP";
    font-size: 18px;
  }
  /* mvCv */
  .mvCvContents {
    padding: 0 19px 55px;
  }
  .mvCvContentsInner {
    display: flex;
    padding: 32px 8px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 30px;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 1.999px 10px 0 rgba(0, 0, 0, 0.1);
  }
  .mvCvContentsInner h2 {
    width: 45.067vw;
  }
  .mvCvContentsInner h2 img {
    width: 45.067vw;
  }
  .mvCvContentsItemWrap {
    display: flex;
    width: 77.333vw;
    justify-content: center;
    gap: 4.267vw;
    padding: 4.267vw 0 8.533vw;
  }
  .mvCvContentsItem {
    width: auto;
  }
  .mvCvContentsItem .linkText {
    margin-top: 2.133vw;
  }
  .mvCvContentsItem:nth-of-type(2) {
    border-left: dashed 0.533vw rgba(79, 67, 58, 0.2);
    padding-left: 2.667vw;
  }
  .mvCvContentsItemMain {
    width: 30.667vw;
  }
  .mvCvContentsBtnList {
    max-width: 327px;
    width: 100%;
  }
  .mvCvContents .mvCvContentsBtnList {
    align-items: flex-start;
    flex-flow: column;
    gap: 2.133vw;
  }
  .mvCvContentsBtn {
    width: 100%;
    padding: 0;
    border: 0.533vw solid transparent;
  }
  .mvCvContentsBtnApp {
    border-radius: 27px;
  }
  .mvCvContentsBtnText {
    text-align: center;
    font-family: "Noto Sans JP";
    font-size: 0.85em;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
  }
  .mvCvContentsBtn .linkArrowWhite::before {
    right: -90px;
  }
  .mvCvContentsBtn .linkArrowGreen::before {
    bottom: 10px;
    right: -70px;
  }
  .present {
    padding: 4.267vw 0;
  }
  .presentText {
    color: #000;
    text-align: center;
    font-size: 3.733vw;
    font-style: normal;
    font-weight: 700;
    line-height: 6.933vw; /* 130% */
    letter-spacing: 0.16vw;
  }
  .presentText:nth-of-type(3) {
    margin-left: 14.667vw;
  }
  .presentTextBig {
    font-size: 10.667vw;
    line-height: 10.667vw;
    letter-spacing: 0.32vw;
  }
  .atokara-color {
    background: linear-gradient(180deg, #00a1b0 12.75%, #86c9ab 47.06%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  .xprice-color {
    color: #f075a9;
  }
  /* about */
  .about_atokaraInner {
    max-width: 229.333vw;
    margin: 0 1.25em;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2em;
    padding-top: 10.667vw;
    padding-bottom: 10.667vw;
  }
  .aboutHeadArea {
    flex-direction: column;
    gap: 2em;
  }
  .aboutFeaturesArea {
    flex-direction: column;
    gap: 32px;
  }
  .aboutHeadText .detailText {
    font-size: 14px;
  }
  .featuresImageArea {
    display: flex;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
  }
  .featuresImageArea img {
    margin: 0 auto 4.267vw;
  }
  .featuresImageArea img:first-child {
    width: 200px;
    height: 200px;
  }
  .featuresItem {
    display: flex;
    width: 100%;
    flex-direction: column;
    align-items: flex-start;
  }
  /* app_dl */
  .app_dlContents {
    padding: 40px 16px;
  }
  .signUpItem {
    max-width: 327px;
    width: 100%;
  }
  .signUpWebLinkText {
    font-size: 15px;
    font-weight: 700;
    padding-right: 4px;
  }
  .signUpKohnan {
    width: 100%;
  }
  .signUpKohnanLinkText {
    font-size: 15px;
    font-weight: 700;
    padding-right: 4px;
  }
  .linkArrowWhite {
    position: relative;
  }
  .linkArrowWhite::before {
    width: 15px;
    position: absolute;
    top: 50%;
    right: -30px;
    transform: translateY(-50%) translateX(-50%);
  }
  .linkArrowGreen {
    position: relative;
  }
  .linkArrowGreen::before {
    width: 15px;
    position: absolute;
    top: 50%;
    right: -20px;
    transform: translateY(-50%) translateX(-50%);
  }
  .appQr {
    width: 24vw;
    height: 24vw;
  }
  /* flow */
  .flowInner {
    display: flex;
    padding: 17.067vw 5.067vw;
    flex-direction: column;
    align-items: center;
    gap: 8.533vw;
    align-self: stretch;
  }
  .flowStepContents {
    flex-direction: column-reverse;
    gap: 4.267vw;
    padding: 0;
    padding-top: 12.8vw;
  }
  .flowStepContentsBg {
    margin-top: 8.533vw;
  }
  .flowStepContents img:first-child {
    width: 53.333vw;
  }
  .stepTextArea {
    align-items: center;
    gap: 4.267vw;
  }
  .flowStepHead {
    width: 22.933vw;
    height: 17.398vw;
  }
  .flowStepInner {
    gap: 6.4vw;
  }
  /* datails */
  .detailsInner {
    padding: 17.067vw 5.067vw;
  }
  /* how_to_use */
  .how_to_useInner {
    padding: 40px 0 0;
  }
  .howToUse-tabs li {
    color: var(--BRAND_ATOKARA, linear-gradient(180deg, #00a1b0 0%, #86c9ab 100%));
    border: 1.999px solid var(--BRAND_ATOKARA, #00a1b0);
    border-radius: 0 100.001px 100.001px 0;
    background: #fff;
    width: 190px;
    display: flex;
    padding: 15px 40.001px;
    justify-content: center;
    align-items: center;
    gap: 10.001px;
    align-self: stretch;
    position: relative;
  }
  .howToUse-tabs li:first-child {
    border-radius: 100.001px 0 0 100.001px;
  }
  .howToUse-tabs li.-current {
    border-radius: 100.001px;
  }
  .howToUse-tabs li .tabText {
    font-size: 13.999px;
    letter-spacing: 0.799px;
  }
  .swiper-autoheight .swiper-wrapper {
    width: 96vw;
  }
  .howToUse-swiper {
    max-width: 767px;
    height: auto;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .howToUse-swiper .swiper-register-pagenation .swiper-pagination-bullet {
    width: 2.133vw;
    height: 2.133vw;
  }
  .howToUse-swiper .swiper-buy-pagenation .swiper-pagination-bullet {
    width: 2.133vw;
    height: 2.133vw;
  }
  .swiper-horizontal > .swiper-pagination-bullets,
  .swiper-pagination-bullets.swiper-pagination-horizontal,
  .swiper-pagination-custom,
  .swiper-pagination-fraction {
    display: flex;
    align-items: flex-start;
    gap: 1em;
    max-width: 103.999px;
    margin: 0;
    justify-content: center;
  }
  .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
  .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0;
    flex-shrink: 0;
  }
  .swiper-slideContents {
    max-width: 64vw;
    gap: 4.267vw;
    display: block;
    margin: 0 auto;
  }
  .swiper-slideContents {
    max-width: 260px;
    gap: 4.267vw;
  }
  .swiper-imgeArea {
    gap: 2.133vw;
    display: block;
    margin: 0 auto;
  }
  .swiper-container-buy,
  .swiper-container-register {
    margin: 0 auto 6.4vw;
  }
  .howToUse-tabs li:first-child {
    margin-right: -36px;
  }
  .faqInner {
    padding: 0;
  }
  .faqInner h2 img {
    width: 100%;
  }
  .qaList dl {
    position: relative;
    padding: 24px 0 24px 0;
  }
  .qaList dl::before {
    top: 20px;
    right: 5.333vw;
    width: 1.867vw;
    height: 1.867vw;
  }
  .qaList dl dt {
    padding: 0 24px 0 28px;
    font-size: 14px;
  }
  .qaList dl dd {
    padding: 0 28px 0 28px;
    font-size: 13px;
  }
  .qaList dl dd p {
    margin: 30px 0 0;
  }
  .qaList dl dd p:first-child {
    margin-top: 0;
  }
  .cautionInner {
    display: flex;
    padding: 64px 19px;
    flex-direction: column;
    align-items: center;
    gap: 2em;
    align-self: stretch;
  }
  .cautionInner h2 {
    width: 100vw;
  }
  .cautionInner h2 img {
    margin: 0 auto;
  }
  .cautionContents .notesList {
    gap: 0;
  }
  .cautionContents .notesText {
    font-size: 11px;
  }
  /* footer */
  .footerBtnPop {
    width: 67vw;
    border-radius: 2.133vw;
    border: 1px solid #00a1b0;
    background: linear-gradient(90deg, #00a1b0 0%, #86c9ab 100%);
    padding: 0.533vw 3.2vw;
    gap: 2.667vw;
    font-family: "Hiragino Kaku Gothic Pro";
    font-size: 12px;
    font-style: normal;
    font-weight: 600;
    line-height: 200%;
  }
  .footerBtnInner .mvCvContentsBtnList {
    max-width: none;
    justify-content: center;
    padding: 14px 11px;
  }
  footer .linkText {
    font-size: 11px;
  }
  footer .CopyrightText {
    font-size: 11px;
  }
  /* campaign */
  .campaignInner {
    padding-top: 40px;
    padding-left: 16px;
    padding-right: 16px;
    margin: 0 auto;
  }
  .campaignTable {
    margin-top: 8.533vw;
  }
  .campaignTh {
    font-size: 16px;
    padding: 12px 8px;
  }
  .campaignTd {
    font-size: 14px;
    line-height: 150%;
  }
  .campaignTd:first-child img {
    width: 150px;
  }
  .campaignInfo {
    margin-top: 24px;
  }
  .campaignInfoTtl {
    font-size: 16px;
    margin-bottom: 2.133vw;
  }
  .campaignInfoMainText {
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: 180%; /* 25.2px */
  }
  .campaignTdSub {
    font-size: 14px;
  }
  .campaign .noteText {
    font-size: 11px;
  }
  /* campaignFlow */
  .campaignFlowBG {
    padding: 10.667vw 4.267vw;
  }
  .campaignFlowMain {
    margin: 10.667vw auto 0;
  }
  .campaignFlowMainList {
    box-shadow: 0 0 5.333vw 0 rgba(0, 0, 0, 0.1);
  }
  .campaignFlowMainListTtl {
    padding: 7.067vw 2.8vw;
  }
  .campaignFlowMainListData {
    padding: 16px;
    gap: 8px;
    border-radius: 0 1.333vw 1.333vw 0;
  }
  .campaignFlowMainListDataText {
    font-size: 12px;
  }
  .campaignFlowMainListDataTextStrong {
    font-size: 14px;
  }
  .campaignFlowMainListDataTextPrice {
    font-size: 16px;
  }
}
@media (max-width: 500px) {
  .howToUse-swiper .swiper-button-buy-right {
    width: 48px;
    height: 48px;
  }
  .howToUse-swiper .swiper-button-register-right {
    width: 48px;
    height: 48px;
  }
  .howToUse-swiper .swiper-button-buy-left {
    width: 48px;
    height: 48px;
  }
  .howToUse-swiper .swiper-button-register-left {
    width: 48px;
    height: 48px;
  }
}
@media (max-width: 550px) {
  .linkText {
    font-size: 11px;
  }
  .noteText {
    padding-bottom: 1.067vw;
    color: #4f433a;
    font-size: 11px;
    line-height: 140%;
  }
  .txtLink .noteText,
  .txtLink .noteHead {
    font-size: 11px;
  }
  .noteHead {
    font-size: 12px;
  }
  .signUpArea .blank::before {
    width: 12px;
    height: 12px;
  }
}
.js-scrollAnimation {
  opacity: 0;
}

.areaCenter {
  display: flex;
  justify-content: center;
}

.pat16 {
  padding-top: 16px;
}

.paB0 {
  padding-bottom: 0 !important;
}

/** xprice **/
.headline_title {
  position: relative;
  font-size: 32px;
  font-weight: bold;
  color: #00a1b0;
}
@media (min-width: 768px) {
  .headline_title {
    font-size: 46px;
  }
}
.headline_title::before {
  position: absolute;
  bottom: -10px;
  left: 50%;
  content: "";
  width: 40px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(180deg, rgba(0, 161, 176, 0.5) 0%, rgba(134, 201, 171, 0.5) 100%);
  transform: translateX(-50%);
}
@media (min-width: 768px) {
  .headline_title::before {
    width: 60px;
  }
}

.header_link {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 11;
  display: flex;
  padding: 16px 24px;
  background-color: #fff;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.15);
  border-radius: 0 0 10px 0;
}
.header_link.is-hidden {
  display: none;
}
@media (min-width: 1100px) {
  .header_link {
    display: none;
  }
}
.header_linkBox {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.header_linkBox:nth-of-type(2) {
  margin-left: 32px;
}
.header_linkBox:nth-of-type(2)::before {
  position: absolute;
  top: 50%;
  left: -16px;
  content: "";
  width: 1px;
  height: 24px;
  background-color: #b3b3b3;
  transform: translate(-50%, -50%);
}
.header_linkLogo {
  display: block;
}
.header_linkLogo.xprice {
  width: 60px;
}
.header_linkLogo.atokara {
  width: 72px;
}

.mvContentsImage {
  padding-top: 32px;
  background-color: #fafaf5;
}
@media (max-width: 767px) {
  .mvContentsImage {
    padding-top: 0;
  }
}

.mvIntro {
  padding-bottom: 40px;
  background-color: #fafaf5;
}
@media (min-width: 768px) {
  .mvIntro {
    padding-top: 40px;
  }
}
@media (min-width: 768px) {
  .mvIntro_container {
    max-width: 800px;
    margin: 0 auto;
  }
}
.mvIntro_popTitle {
  text-align: center;
  color: #343434;
}
.mvIntro_popTitleInner {
  position: relative;
  display: inline-block;
  font-size: 16px;
}
@media (min-width: 768px) {
  .mvIntro_popTitleInner {
    font-size: 20px;
  }
}
.mvIntro_popTitleInner::before, .mvIntro_popTitleInner::after {
  position: absolute;
  bottom: 2px;
  content: "";
  width: 1.5px;
  height: 14px;
  background-color: #343434;
}
.mvIntro_popTitleInner::before {
  left: -12px;
  transform: rotate(-25deg);
}
.mvIntro_popTitleInner::after {
  right: -12px;
  transform: rotate(25deg);
}
.mvIntro_flow {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  padding: 0 8px;
  margin-top: 8px;
}
@media (min-width: 768px) {
  .mvIntro_flow {
    padding: 0;
  }
}
.mvIntro_flowItem {
  position: relative;
  width: 100%;
  padding: 2px;
  background: linear-gradient(to bottom, #00a1b0, #86c9ab);
  border-radius: 50vh;
}
@media (min-width: 768px) {
  .mvIntro_flowItem {
    display: flex;
    width: calc((100% - 50px) / 2);
  }
}
.mvIntro_flowItem:nth-of-type(2) {
  margin-top: 8px;
  background: linear-gradient(to bottom, #ff82d3, #ff29b4);
}
@media (min-width: 768px) {
  .mvIntro_flowItem:nth-of-type(2) {
    margin-top: 0;
    margin-left: 50px;
  }
}
.mvIntro_flowItem:nth-of-type(2)::before {
  position: absolute;
  top: -20px;
  left: 50%;
  width: 25px;
  height: 25px;
  content: "";
  background-image: url(/campaign/xprice/20251001_cp/img/add/icon_flow_plus.png);
  background-size: 100%;
  background-repeat: no-repeat;
}
@media (min-width: 768px) {
  .mvIntro_flowItem:nth-of-type(2)::before {
    top: 50%;
    left: -42px;
    width: 35px;
    height: 35px;
    transform: translateY(-50%);
  }
}
.mvIntro_flowItem:nth-of-type(2) .mvIntro_flowImgBox {
  background-color: #fbd9f1;
}
.mvIntro_flowItemContents {
  display: flex;
  width: 100%;
  background: #ffffff;
  border-radius: 50vh;
  overflow: hidden;
}
@media (min-width: 768px) {
  .mvIntro_flowItemContents {
    align-items: center;
  }
}
.mvIntro_flowImgBox {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 21.1111111111%;
  background-color: #daeaea;
  border-radius: 50vh 0 0 50vh;
}
@media (min-width: 768px) {
  .mvIntro_flowImgBox {
    height: 100%;
  }
}
.mvIntro_flowImgBox img {
  width: 78.9473684211%;
}
.mvIntro_flowTextBox {
  width: 74.4444444444%;
  padding: 20px 20px 20px 0;
  margin-left: 16px;
}
.mvIntro_flowTitle {
  line-height: 1.15;
  font-size: 20px;
  font-weight: bold;
  color: #343434;
}
.mvIntro_flowTitle + .mvIntro_flowText {
  margin-top: 8px;
}
.mvIntro_flowTitle .size-s {
  font-size: 11px;
}
.mvIntro_flowTitle .size-m {
  font-size: 14px;
}
.mvIntro_flowText {
  position: relative;
  padding-left: 16px;
  font-size: 11px;
  color: #676767;
}
.mvIntro_flowText::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}
.mvIntro_flowLink {
  position: relative;
  font-size: 12px;
  color: #343434;
}
.mvIntro_flowLink::before {
  position: absolute;
  top: 50%;
  right: -16px;
  width: 10px;
  height: 11px;
  content: "";
  background-image: url(/campaign/xprice/20251001_cp/img/icon_link.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}
.mvIntro_cbTitle {
  margin-top: 32px;
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .mvIntro_cbTitle {
    max-width: 594px;
    margin: 0 auto;
    margin-top: 24px;
  }
}
.mvIntro_cbTitle img {
  width: 100%;
}
.mvIntro_cbImage {
  padding: 0 8px;
  margin-top: 10px;
}
@media (min-width: 768px) {
  .mvIntro_cbImage {
    max-width: 477px;
    margin: 0 auto;
    margin-top: 24px;
  }
}
.mvIntro_cbImage img {
  width: 100%;
}

.campaignDetail {
  padding: 40px 16px;
  background: linear-gradient(135deg, #e9f8f8 0%, #daeaea 100%);
}
@media (min-width: 768px) {
  .campaignDetail {
    padding: 80px 16px 48px;
  }
}
@media (min-width: 768px) {
  .campaignDetail_container {
    max-width: 800px;
    margin: 0 auto;
  }
}
.campaignDetail_item:not(:first-of-type) {
  margin-top: 8px;
}
@media (min-width: 768px) {
  .campaignDetail_item:not(:first-of-type) {
    margin-top: 16px;
  }
}
.campaignDetail_itemTitle {
  position: relative;
  padding-left: 20px;
  font-size: 14px;
  font-weight: bold;
  color: #343434;
}
@media (min-width: 768px) {
  .campaignDetail_itemTitle {
    font-size: 16px;
  }
}
.campaignDetail_itemTitle::before {
  position: absolute;
  top: 3px;
  left: 0;
  width: 14px;
  height: 14px;
  content: "";
  background-image: url(/campaign/xprice/20251001_cp/img/add/icon_title_triangle.png);
  background-size: contain;
  background-repeat: no-repeat;
}
.campaignDetail_itemBox {
  margin-top: 4px;
}
.campaignDetail_itemText {
  font-size: 14px;
  color: #343434;
}
@media (min-width: 768px) {
  .campaignDetail_itemText {
    font-size: 16px;
  }
}
.campaignDetail_itemNoteNum {
  position: relative;
  padding-left: 20px;
  margin-top: 4px;
  font-size: 11px;
  color: #676767;
}
@media (min-width: 768px) {
  .campaignDetail_itemNoteNum {
    font-size: 12px;
  }
}
.campaignDetail_itemNoteNum::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※1";
}
.campaignDetail_itemNote {
  position: relative;
  padding-left: 16px;
  margin-top: 4px;
  font-size: 11px;
  color: #676767;
}
@media (min-width: 768px) {
  .campaignDetail_itemNote {
    font-size: 12px;
  }
}
.campaignDetail_itemNote::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}
.campaignDetail_itemNoteNum + .campaignDetail_itemNote {
  padding-left: 20px;
}

.swiper-note {
  position: relative;
  padding-left: 16px;
  margin-top: 16px;
  font-size: 11px;
  color: #676767;
}
@media (min-width: 768px) {
  .swiper-note {
    margin-top: 24px;
    font-size: 12px;
  }
}
.swiper-note + .swiper-note {
  margin-top: 4px;
}
.swiper-note::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}

.mvContentsImage{
  position: relative;
}

.mv_grayout{
  position: absolute;
  top: 96px;
  left: 0;
  background-color: rgba(52, 52, 52, 0.9);
  width: 100%;
  height: calc(100% - 96px);
}

.mv_grayoutInner{
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 1155px;
  height: 100%;
  margin: 0 auto;
}

.mv_grayoutTextbox{
  text-align: center;
  color: #FFFFFF;
  padding: 0 20px;
}

.grayout_text{
  display: inline-block;
  font-size: 40px;
  font-weight: 700;
  line-height: 160%;
  margin-bottom: 16px;
}

.grayout_highlight{
  display: inline;
  font-size: 48px;
  padding-left: 16px;
  padding-right: 16px;
  margin-right: 8px;
  color:#000000;
  background-color: #FFFFFF;
}

.grayout_highlight_small{
  font-size: 24px;
}

.grayout_highlight_middle{
  font-size: 38px;
}

.highlight_space{
  margin-top: 10px;
}

.grayout_ano{
  font-size: 24px;
  font-weight: 100;
  margin-top: 8px;
}

.grayout_breakSp{
  display: none;
}

@media (max-width: 860px) {
  .grayout_text{
    font-size: 32px;
  }
  .grayout_ano{
    font-size: 20px;
  }
}

@media (max-width: 767px) {
  .grayout_breakSp{
    display: contents;
  }

  .mv_grayout{
    top: 52px;
    left: 0;
    width: 100vw;
    height: calc(100% - 60px);
  }
  
  .mv_grayoutInner{
    max-width: 92.5vw;
    height: 100%;
    margin: 0 auto;
  }
  
  .mv_grayoutTextbox{
    padding: 0 10px;
  }
  
  .grayout_text{
    display: block;
    font-size: 20px;
    margin-bottom: 16px;
  }
  
  .grayout_highlight{
    font-size: 30px;
    padding-left: 8px;
    padding-right: 8px;
  }
  
  .grayout_highlight_small{
    font-size: 12px;
  }
  
  .grayout_highlight_middle{
    font-size: 20px;
  }
  
  .grayout_ano{
    font-size: 10px;
    font-weight: 100;
    margin-top: -16px;
  }

  .highlight_space{
    margin-top: 8px;
  }

}

/* appArea start */
.appArea {
  padding: 48px 0;
  background: url(/campaign/xprice/20251001_cp/img/pattern_stripe_atokara.svg);
  background-repeat: repeat;
  background-position: center;
}
.appArea_title img {
  margin: 0 auto;
}
.appArea_item_title {
  margin-top: 32px;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 150%;
  text-align: center;
  -webkit-text-stroke-width: 0.2px;
  -webkit-text-stroke-color: #23272C;
  color: #23272C;
}
.appArea_item {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin: 16px auto 0;
}
.appArea_item_contents {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 16px;
  border-radius: 10px;
  background: #FFFFFF;
  box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.15);
}
.appArea_item_contents .text {
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
  color: #23272C;
}
.appArea_item_contents .text span {
  font-size: 20px;
  color: #004097;
}
.appArea_download {
  display: none;
}
.appArea_link {
  margin-top: 24px;
  text-align: center;
}
.appArea_link a {
  position: relative;
  padding-right: 14px;
  font-size: 12px;
  font-style: normal;
  font-weight: 400;
  line-height: 160%;
  text-decoration: underline;
  color: #676767;
}
.appArea_link a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 10px;
  height: 10px;
  background: url(/campaign/xprice/20251001_cp/img/icon_link.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  background-position: center;
  transform: translate(0, -50%);
}
@media screen and (max-width: 767px) {
  .appArea {
    padding: 40px 16px;
  }
  .appArea_item_title {
    display: none;
  }
  .appArea_item {
    display: none
  }
  .appArea_download {
    display: block;
    margin-top: 24px;
  }
  .appArea_download img {
    margin: 0 auto;
  }
}
/* appArea end */