@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/camera_kitamura/20251014_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/camera_kitamura/20251014_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: linear-gradient(180deg, #05A1AE 0%, #78BDA4 100%);
  box-shadow: 0 -4px 0 0 #00646D inset;
  text-decoration: none;
  margin: 0 auto;
}
.btn_store.btn_store--secondary {
  background: #ffffff;
  box-shadow: 0 -3px 0 0 #00646D inset;
  border: 2px solid #00646D;
}
@media (min-width: 768px) {
  .btn_store.btn_store--secondary {
    padding-block: 13px;
  }
}
.btn_store.btn_store--secondary .btn_store_inner {
  color: #008367 !important;
}
@media (min-width: 768px) {
  .btn_store.btn_store--secondary .btn_store_inner {
    font-size: 14px;
  }
}
.btn_store.btn_store--secondary .btn_store_inner::after {
  mask-image: url(/campaign/kohnan/img/icon_link_white.svg);
  background: #008367 !important;
}
.btn_store.btn_store--app .btn_store_inner::after {
  width: 14px;
  height: 14px;
  background: url(/campaign/camera_kitamura/20251014_cp/img/icon_download.svg) no-repeat !important;
}

.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 48px;
  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;
  max-width: 275px;
  margin-right: 16px;
}
@media (min-width: 768px) {
  .headerLogo {
    gap: 46px;
  }
}
.headerLogo a {
  position: relative;
  width: 45%;
}
@media (min-width: 768px) {
  .headerLogo a {
    display: flex;
    align-items: center;
  }
}
.headerLogo a:nth-of-type(2)::before {
  position: absolute;
  top: 50%;
  left: -24px;
  content: "";
  width: 1px;
  height: 100%;
  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: 4px;
    right: 12px;
    z-index: 11;
    transition: top 0.3s ease-in-out;
  }
  .menuBtn.is-float {
    top: 12px;
  }
  .menuBtn.is-float a {
    background-color: #fff;
    box-shadow: 0 0 8px 0 rgba(0, 0, 0, 0.1);
  }
  .menuBtn a {
    display: flex;
    width: 40px;
    height: 40px;
    padding: 14px 12px 15px 12px;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    border-radius: 4px;
    background-color: transparent;
    box-shadow: none;
  }
}
.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/camera_kitamura/20251014_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/camera_kitamura/20251014_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: rgba(255, 255, 255, 0.5);
  background-repeat: repeat;
  display: flex;
  padding: 52px 16px;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  align-self: stretch;
}

.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: 36px 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: #F4FFFA;
}

.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;
}
@media (min-width: 768px) {
  .about_atokara_detail_item {
    width: calc((100% - 64px) / 3);
  }
}
.about_atokara_detail_item .btn_store--secondary {
  margin-top: 12px;
}
@media (min-width: 768px) {
  .about_atokara_detail_item .btn_store--secondary {
    width: 100%;
    margin-top: 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;
}
@media (min-width: 768px) {
  .about_atokara_detail_item_text + .appLink {
    display: flex;
    flex-direction: column-reverse;
    width: 100%;
  }
}

.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_useTitle {
  padding: 0 8px;
  margin-bottom: 10px;
}
@media (min-width: 768px) {
  .how_to_useTitle {
    margin-bottom: 32px;
  }
}

.how_to_useBg {
  background: #fcf6ee;
}

.how_to_useInner {
  display: flex;
  max-width: 1440px;
  width: 100%;
  padding: 52px 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: 58px;
}

.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);
  background: #fff;
  width: 336px;
  display: flex;
  padding: 11px 40px;
  justify-content: center;
  align-items: center;
  gap: 0.625em;
  align-self: stretch;
  position: relative;
  cursor: pointer;
  transition: none;
}
.howToUse-tabs li:nth-child(1) {
  border-radius: 100px 0 0 100px;
}
.howToUse-tabs li:nth-child(2) {
  border-radius: 0 100px 100px 0;
}

.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;
  border-radius: 100px;
}

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

.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;
  width: auto;
  flex-direction: column;
  align-items: inherit;
  flex-shrink: 0;
}

.swiper-imgeArea img {
  width: 270px;
  margin: 24px auto 24px auto;
}
@media (min-width: 768px) {
  .swiper-imgeArea img {
    width: 200px;
    margin: 16px auto 24px auto;
  }
}

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

.swiper-slide-text img {
  display: block;
  width: 128px;
}
.swiper-slide-text img + .detailText {
  margin-top: 8px;
}

.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: #E7E7E7;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  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: #E7E7E7;
  width: 12px;
  height: 12px;
  border-radius: 999px;
  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;
  }
}
/* appDl */
.appDlBg {
  background-image: url(/campaign/camera_kitamura/20251014_cp/img/pattern_stripe_atokara.svg);
  background-repeat: repeat;
}

.appContents {
  margin: 0 auto;
  padding: 40px 0;
}

.appContents h2 {
  margin-bottom: 0;
}

.appContents h2 img {
  width: 540px;
  margin: 0 auto;
}

.dwArea {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  padding: 24px 0;
}

.appLink {
  text-align: center;
}

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

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

.dwArea .dwQr {
  width: 110px;
}

.appArea,
.googleArea {
  display: flex;
  align-items: center;
  gap: 24px;
}

@media (max-width: 767px) {
  .appContents {
    margin: 0 16px;
  }
  .appContents h2 img {
    width: 336px;
  }
  .dwArea {
    gap: 24px;
    padding: 24px 0 0 0;
  }
  .appLink a {
    font-size: 12px;
  }
  .appDlDwArea {
    padding: 24px 0;
  }
}
/* 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;
}
@media (min-width: 768px) {
  .faqInner {
    padding: 52px 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 {
  font-size: 13px;
  font-weight: 300;
  line-height: 1.5;
}

.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: 16px;
}

.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 .faqAnnotation.-num-1 {
  padding-left: 22px;
}
.qaList .faqAnnotation.-num-1::before {
  content: "※1";
}

@media (max-width: 767px) {
  .faq {
    padding: 12px 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: 8px 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: 16px;
}
@media (min-width: 768px) {
  .caution {
    padding-bottom: 80px;
  }
}
.caution_container {
  max-width: 800px;
  margin: 0 auto;
}
.caution h2 {
  margin-bottom: 12px;
}
@media (min-width: 768px) {
  .caution h2 {
    margin-bottom: 32px;
  }
}

.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: 0 16px 40px;
  }
  .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: 14px;
  font-style: normal;
  font-weight: 400;
  line-height: 180%;
}

.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: 1em;
  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 {
  position: fixed;
  bottom: 0;
  width: 100%;
}

.sticky_btn .appRegBg .btn_store {
  position: fixed;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  width: 90%;
  max-width: 500px;
  padding: 12px 8px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 10px;
  box-shadow: none;
}
@media (min-width: 768px) {
  .sticky_btn .appRegBg .btn_store {
    bottom: 16px;
    border-radius: 8px;
  }
}
.sticky_btn .appRegBg .btn_store img {
  width: 36px;
  height: 36px;
}
@media (min-width: 768px) {
  .sticky_btn .appRegBg .btn_store img {
    width: 48px;
    height: 48px;
  }
}
@media (max-width: 767px) {
  .sticky_btn .appRegBg .btn_store.forSp {
    display: flex !important;
  }
}
@media (min-width: 768px) {
  .sticky_btn .appRegBg .btn_store.forPc {
    display: flex !important;
  }
}

.sticky_btn .appRegBg .btn_store .btn_store_inner {
  padding-right: 0;
  font-size: 14px;
}
@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: 95%;
    padding: 8px 16px 8px 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: 80px 120px;
  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;
}

.atokraAppDlApple {
  display: flex;
  margin-right: 24px;
}

.atokraAppDlGoogle {
  display: flex;
}

.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: 76px;
  }
}
@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;
  }
  /* 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: 14px 0 40px;
  }
  .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: 3.2vw;
    height: 3.2vw;
  }
  .howToUse-swiper .swiper-buy-pagenation .swiper-pagination-bullet {
    width: 3.2vw;
    height: 3.2vw;
  }
  .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 {
    gap: 4.267vw;
    display: block;
    margin: 0 auto;
  }
  .swiper-slideContents {
    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 {
    margin-bottom: 12px;
  }
  .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: 8px 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;
}

/** kitamura **/
.header_link {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 11;
  width: 100%;
  display: flex;
  padding: 8px 16px;
  background-color: #fff;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.15);
  box-sizing: border-box;
}
.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.kitamura {
  width: 30px;
}
.header_linkLogo.atokara {
  width: 70px;
}

.mvContentsImage {
  padding-top: 47px;
}
@media (min-width: 768px) {
  .mvContentsImage {
    padding-top: 0;
  }
}

@media (min-width: 768px) {
  .mvIntro {
    padding-top: 0;
  }
}
@media (min-width: 768px) {
  .mvIntro_container {
    max-width: 800px;
    margin: 0 auto;
  }
}
.mvIntro_flow {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  padding: 0 16px;
  margin-top: 32px;
}
@media (min-width: 768px) {
  .mvIntro_flow {
    padding: 0;
    margin-top: 40px;
  }
}
.mvIntro_flowItem {
  position: relative;
  width: 100%;
  border: 1px solid rgba(0, 168, 132, 0.6);
  border-radius: 8px;
}
@media (min-width: 768px) {
  .mvIntro_flowItem {
    display: flex;
    width: calc((100% - 16px) / 2);
  }
}
.mvIntro_flowItem:nth-of-type(2) {
  margin-top: 8px;
  border-color: rgba(221, 61, 54, 0.6);
}
@media (min-width: 768px) {
  .mvIntro_flowItem:nth-of-type(2) {
    margin-top: 0;
    margin-left: 16px;
  }
}
.mvIntro_flowItem:nth-of-type(2)::before {
  position: absolute;
  top: -20px;
  left: 50%;
  width: 25px;
  height: 25px;
  content: "";
  background-image: url(/campaign/camera_kitamura/20251014_cp/img/icon_flow_plus.png);
  background-size: 100%;
  background-repeat: no-repeat;
  z-index: 1;
}
@media (min-width: 768px) {
  .mvIntro_flowItem:nth-of-type(2)::before {
    top: 50%;
    left: -28px;
    width: 35px;
    height: 35px;
    transform: translateY(-50%);
  }
}
.mvIntro_flowItem:nth-of-type(2) .mvIntro_flowItemContents {
  background: #FFF1F2;
}
.mvIntro_flowItem:nth-of-type(2) .mvIntro_flowItemContents::before {
  background-color: #DD3D36;
}
@media (min-width: 768px) {
  .mvIntro_flowItem:nth-of-type(2) .mvIntro_flowTitle {
    font-size: 14px;
  }
}
.mvIntro_flowItemContents {
  position: relative;
  display: flex;
  gap: 12px;
  width: 100%;
  padding: 20px 16px;
  background: #E0FFF9;
  border-radius: inherit;
  overflow: hidden;
}
@media (min-width: 768px) {
  .mvIntro_flowItemContents {
    padding: 32px 24px;
    align-items: center;
  }
}
.mvIntro_flowItemContents:before {
  position: absolute;
  top: 0;
  left: -64%;
  content: "";
  width: 100%;
  height: 50%;
  background-color: #00A884;
  transform: rotate(-45deg);
  pointer-events: none;
}
.mvIntro_flowImgBox {
  width: 29.1262135922%;
}
@media (min-width: 768px) {
  .mvIntro_flowImgBox {
    width: 22.2891566265%;
  }
}
.mvIntro_flowTextBox {
  width: 67.6375404531%;
}
@media (min-width: 768px) {
  .mvIntro_flowTextBox {
    width: 77.7108433735%;
  }
}
.mvIntro_flowTitle {
  line-height: 1.3;
  font-size: 12px;
  font-weight: bold;
  color: #000000;
}
@media (min-width: 768px) {
  .mvIntro_flowTitle {
    font-size: 20px;
  }
}
.mvIntro_flowTitle + .mvIntro_flowText {
  margin-top: 2px;
}
.mvIntro_flowTitle .size-s {
  font-size: 10px;
}
@media (min-width: 768px) {
  .mvIntro_flowTitle .size-s {
    font-size: 10px;
  }
}
.mvIntro_flowTitle .size-l {
  font-size: 18px;
  line-height: 1;
}
@media (min-width: 768px) {
  .mvIntro_flowTitle .size-l {
    font-size: 20px;
  }
}
.mvIntro_flowTitle .mt-4 {
  display: inline-block;
  margin-top: 4px;
}
.mvIntro_flowTitle .color-red {
  color: #D2000A;
}
.mvIntro_flowText {
  position: relative;
  padding-left: 16px;
  font-size: 11px;
  color: #676767;
  line-height: 1.4;
}
.mvIntro_flowText::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "※";
}
.mvIntro_flowText + .mvIntro_flowText {
  margin-top: 2px;
}
.mvIntro_flowText.-ast-none {
  padding-left: 0;
}
.mvIntro_flowText.-ast-none::before {
  display: none;
}
.mvIntro_flowLink {
  position: relative;
  padding-left: 14px;
  font-size: 12px;
  color: #343434;
}
.mvIntro_flowLink::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 10px;
  height: 11px;
  content: "";
  background-image: url(/campaign/camera_kitamura/20251014_cp/img/icon_link.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}
.mvIntro_cbTitle {
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .mvIntro_cbTitle {
    margin: 0 auto;
    margin-top: 24px;
  }
}
.mvIntro_cbTitle img {
  width: 100%;
}
.mvIntro_cbImage {
  padding: 0 16px;
  margin-top: -32px;
}
@media (min-width: 768px) {
  .mvIntro_cbImage {
    padding: 0;
    margin: 0 auto;
    margin-top: 16px;
  }
}
.mvIntro_cbImage img {
  width: 100%;
}

.campaignDetail {
  padding: 12px 16px 40px;
}
@media (min-width: 768px) {
  .campaignDetail {
    padding: 92px 16px 48px;
  }
}
@media (min-width: 768px) {
  .campaignDetail_container {
    max-width: 800px;
    margin: 0 auto;
  }
}
@media (min-width: 768px) {
  .campaignDetail_title {
    margin-bottom: 0;
  }
}
.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: 18px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.6;
  color: #343434;
}
@media (min-width: 768px) {
  .campaignDetail_itemTitle {
    font-size: 16px;
  }
}
.campaignDetail_itemTitle::before {
  position: absolute;
  top: 4px;
  left: 0;
  width: 10px;
  height: 10px;
  content: "";
  border-radius: 999px;
  background-color: #212121;
  background-size: contain;
  background-repeat: no-repeat;
}
@media (min-width: 768px) {
  .campaignDetail_itemTitle::before {
    top: 6px;
    width: 12px;
    height: 12px;
  }
}
.campaignDetail_itemBox {
  margin-top: 4px;
}
.campaignDetail_itemText {
  font-size: 14px;
  line-height: 1.6;
  color: #343434;
}
@media (min-width: 768px) {
  .campaignDetail_itemText {
    font-size: 16px;
  }
}
.campaignDetail_itemListItem {
  position: relative;
  padding-left: 18px;
  font-size: 14px;
  line-height: 1.6;
  color: #343434;
}
@media (min-width: 768px) {
  .campaignDetail_itemListItem {
    font-size: 16px;
  }
}
.campaignDetail_itemListItem::before {
  position: absolute;
  top: 0;
  left: 0;
}
.campaignDetail_itemListItem:nth-of-type(1)::before {
  content: "①";
}
.campaignDetail_itemListItem:nth-of-type(2)::before {
  content: "②";
}
.campaignDetail_itemListItem:nth-of-type(3)::before {
  content: "③";
}
.campaignDetail_itemListItem sup {
  vertical-align: top;
}
.campaignDetail_itemNote {
  position: relative;
  padding-left: 22px;
  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_itemNote.-num-1::before {
  content: "※1";
}

.swiper-note {
  position: relative;
  padding-left: 16px;
  margin-top: 8px;
  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: "※";
}
.swiper-buyNote {
  margin: 20px 0;
  font-size: 12px;
  color: #363534;
  text-align: center;
}

.otherCp {
  padding: 40px 18px;
  background-color: #F0F0F0;
  text-align: center;
}
@media (min-width: 768px) {
  .otherCp {
    padding: 48px 16px;
  }
}
.otherCp_title {
  position: relative;
  display: inline-block;
  font-size: 16px;
  line-height: 1.3;
  color: #343434;
  text-align: center;
}
@media (min-width: 768px) {
  .otherCp_title {
    font-size: 20px;
  }
}
.otherCp_title::before, .otherCp_title::after {
  position: absolute;
  bottom: 2px;
  content: "";
  width: 1.5px;
  height: 14px;
  background-color: #343434;
}
.otherCp_title::before {
  left: -12px;
  transform: rotate(-25deg);
}
.otherCp_title::after {
  right: -12px;
  transform: rotate(25deg);
}
.otherCp_link {
  margin-top: 16px;
  display: block;
}
@media (min-width: 768px) {
  .otherCp_link {
    max-width: 800px;
    margin: 16px auto 0;
  }
}
.otherCp_link img {
  width: 100%;
}

.atokraAppDl {
  margin-top: 16px;
}/*# sourceMappingURL=styles.css.map */