@charset "UTF-8";
/* --------------------
		設定
-------------------- */
/* ----px → vw---- 書き方：vw(px値) */
/* ----px → vw (pc)---- 書き方：vw-pc(px値)　*/
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@100;300&display=swap");
@import url("https://use.typekit.net/pce0slx.css");
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP&display=swap");
@media screen and (max-width: 999px) {
  .pc-only {
    display: none !important;
  }
}

@media screen and (min-width: 1000px) {
  .sp-only {
    display: none !important;
  }
}

:root {
  --c-txt: #38362F;
  --c-bg: #F3F2F0;
}

/* -----------------------------
   全体
----------------------------- */
#content a {
  display: block;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

/* TOPボタン */
.page-top {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 18px;
  color: var(--c-txt);
  position: fixed;
  right: 8%;
  bottom: 3%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  border: 0;
  background: none;
  -webkit-transition: .2s;
  transition: .2s;
  z-index: 9999;
}

@media screen and (min-width: 1000px) {
  .page-top {
    right: 3%;
    font-size: 18px;
  }
  .page-top p {
    height: 85px;
  }
}

@media screen and (max-width: 999px) {
  .page-top {
    right: 8%;
    bottom: 5%;
    font-size: 14px;
  }
  .page-top p {
    height: 60px;
    letter-spacing: 1px;
  }
  .page-top p::after {
    height: 60px;
  }
  .page-top p::before {
    bottom: 60px;
  }
}

.page-top p {
  position: relative;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  text-decoration: none;
  text-transform: uppercase;
  height: 85px;
  margin: 0;
  padding-right: 5px;
  letter-spacing: 2px;
  text-align: right;
}

.page-top p::before {
  content: "";
  position: absolute;
  bottom: 80px;
  right: 0;
  width: 2px;
  height: 20px;
  background: var(--c-txt);
  -webkit-transform: rotate(145deg);
          transform: rotate(145deg);
  -webkit-transform-origin: bottom center;
          transform-origin: bottom center;
}

.page-top p::after {
  content: "";
  position: absolute;
  bottom: 0px;
  right: 0;
  width: 2px;
  height: 80px;
  background: var(--c-txt);
}

.page-top.is-active {
  opacity: 1;
  visibility: visible;
}

/* -----------------------------
	メインビジュアル
  ----------------------------- */
.mv {
  position: top;
  top: 0;
  left: 0;
  width: 100%;
  overflow: hidden;
  background-color: var(--c-bg);
}

@media screen and (min-width: 1000px) {
  .mv {
    position: -webkit-sticky;
    position: sticky;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.mv-left {
  position: relative;
  background: url(/special/250916_onlinestore-w_pre-order/common/img/mv.jpg) no-repeat;
  width: 100%;
  height: 70vh;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}

@media screen and (min-width: 1000px) {
  .mv-left {
    height: 100vh;
  }
}

.mv-left img {
  height: 40vh;
}

@media screen and (min-width: 1000px) {
  .mv-left img {
    height: 60vh;
  }
}

.mv-left .ttl-left {
  position: absolute;
  bottom: 6%;
  left: 4%;
}

.mv-left .ttl-right {
  position: absolute;
  top: 6%;
  right: 4%;
}

.mv-right {
  width: 100%;
  padding-bottom: 10.66667vw;
}

@media screen and (min-width: 1000px) {
  .mv-right {
    padding-bottom: 0;
  }
}

.mv-right p {
  width: 80%;
  margin: 13.33333vw auto;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 3.46667vw;
}

@media screen and (min-width: 1000px) {
  .mv-right p {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
    text-align: left;
    font-size: 0.87rem;
    margin-bottom: 7.8125vw;
  }
}

.top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
}

.bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  margin: 10px;
}

/* 画像リンクの見た目 */
.scroll-btn a {
  display: block;
}

.scroll-btn img {
  width: 24vw;
  height: auto;
  display: block;
  -webkit-transition: -webkit-transform .1s ease;
  transition: -webkit-transform .1s ease;
  transition: transform .1s ease;
  transition: transform .1s ease, -webkit-transform .1s ease;
}

@media screen and (min-width: 1000px) {
  .scroll-btn img {
    width: 7.8125vw;
  }
}

.scroll-btn a:hover {
  opacity: 0.5;
  -webkit-transform: scale(1.03);
          transform: scale(1.03);
}

/* -----------------------------
	 セクション 左カラム（PC用）
  ----------------------------- */
.sec__wrapper {
  position: relative;
  height: 100%;
  margin: 0;
  scroll-behavior: smooth;
  background-color: var(--c-bg);
}

.sec {
  width: 100%;
  position: relative;
  color: var(--c-txt);
}

.sec__left {
  width: 50%;
  height: 100vh;
  position: -webkit-sticky;
  position: sticky;
  top: 0px;
  left: 0px;
  overflow: hidden;
}

.sec__left-inner {
  position: relative;
  height: 100%;
  overflow-y: auto;
}

.sec__left-styling {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
}

.sec__left-styling-items {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 3.46667vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-top: 5.33333vw;
}

.sec__left-styling-items li:not(:last-child) {
  margin-right: 15px;
}

@media screen and (min-width: 1000px) {
  .sec__left-styling-items {
    font-size: 0.87rem;
    padding-top: 2.34375vw;
  }
}

/* Swiper1 */
.swiper1 {
  width: 100%;
}

.swiper1 .swiper-slide img {
  display: block;
  width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

/* -----------------------------
	 セクション 右カラム
  ----------------------------- */
.sec__right {
  margin-top: -100vh;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.sec__right-inner {
  margin-top: 13.33333vw;
  width: 50%;
}

@media screen and (min-width: 1000px) {
  .sec__right-inner {
    margin-top: 4.6875vw;
  }
}

.sec__right-main {
  margin: 0 auto;
}

@media screen and (min-width: 1000px) {
  .sec__right-main {
    width: 30vw;
  }
}

.sec__right-main h2 {
  font-family: "aktiv-grotesk", sans-serif;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-align: center;
  font-size: 5.86667vw;
  margin-bottom: 8vw;
}

@media screen and (min-width: 1000px) {
  .sec__right-main h2 {
    font-size: 1.71875vw;
    margin-bottom: 2.34375vw;
  }
}

.sec__right-main img {
  width: 90%;
  height: auto;
  display: block;
  margin: 0 auto;
  margin-bottom: 10.66667vw;
}

@media screen and (min-width: 1000px) {
  .sec__right-main img {
    width: 100%;
    margin-bottom: 3.125vw;
  }
}

.sec__right-main-desc {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 3.46667vw;
  text-align: left;
  width: 80%;
  margin: 0 auto 8vw;
}

@media screen and (min-width: 1000px) {
  .sec__right-main-desc {
    font-size: 0.87rem;
    width: 25vw;
    margin: 0 auto 3.125vw;
  }
}

.sec__right-main-detail {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 3.46667vw;
  margin: 0 auto;
  text-align: center;
  margin: 0 auto 26.66667vw;
  width: 80%;
}

@media screen and (min-width: 1000px) {
  .sec__right-main-detail {
    width: 25vw;
    font-size: 0.87rem;
    margin-bottom: 7.8125vw;
  }
}

.sec__right-main-price {
  margin-bottom: 8vw;
}

@media screen and (min-width: 1000px) {
  .sec__right-main-price {
    margin-bottom: 1.5625vw;
  }
}

.sec__right-main-btn {
  width: 80%;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 3.73333vw;
  height: 14.13333vw;
  color: #fff;
  background-color: var(--c-txt);
  border: 1px solid transparent;
  cursor: pointer;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

@media screen and (min-width: 1000px) {
  .sec__right-main-btn {
    font-size: 0.88rem;
    width: 25vw;
    height: 4.14062vw;
  }
}

.sec__right-main-btn:hover {
  opacity: 0.5;
}

.sec__right-main-btn a {
  color: inherit;
  text-decoration: none;
  width: 100%;
  line-height: 14.13333vw;
}

@media screen and (min-width: 1000px) {
  .sec__right-main-btn a {
    line-height: 4.14062vw;
  }
}

/* Pick Up */
.pick-up {
  margin-top: 21.33333vw;
  margin-left: 5.33333vw;
  margin-bottom: 26.66667vw;
}

@media screen and (min-width: 1000px) {
  .pick-up {
    margin-top: 0;
    margin-left: 20%;
    margin-bottom: 7.8125vw;
  }
}

.pick-up a:hover {
  opacity: 0.5;
}

.pick-up h2 {
  font-family: "aktiv-grotesk", sans-serif;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
  font-size: 4.8vw;
  margin-bottom: 5.33333vw;
}

@media screen and (min-width: 1000px) {
  .pick-up h2 {
    font-size: 1.40625vw;
    margin-bottom: 1.5625vw;
  }
}

.pick-up img {
  width: 100%;
  margin-bottom: 2.13333vw;
}

@media screen and (min-width: 1000px) {
  .pick-up img {
    margin-bottom: 0.78125vw;
  }
}

.pick-up-price {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  font-size: 3.46667vw;
  text-align: left;
}

@media screen and (min-width: 1000px) {
  .pick-up-price {
    font-size: 0.87rem;
  }
}

.swiper2 {
  width: 100%;
  overflow: visible;
}

.swiper2 .swiper-slide {
  width: 37.33333vw;
}

@media screen and (min-width: 1000px) {
  .swiper2 .swiper-slide {
    width: 15.625vw;
  }
}

.swiper2 .swiper-wrapper {
  margin-left: 0 !important;
}

/* -----------------------------
	 セクション スマホ用切替（999px以下）
  ----------------------------- */
.left-swiper-pc {
  display: block;
}

.left-swiper-mobile {
  display: none;
}

@media (max-width: 999px) {
  .sec {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
  }
  .sec__left {
    display: none;
  }
  .sec__right {
    margin-top: 0;
    width: 100%;
    height: auto;
    overflow: visible;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .sec__right-inner {
    width: 100%;
  }
  /* スマホ用左Swiper表示 */
  .left-swiper-mobile {
    display: block;
    margin: 10.66667vw 0;
    /* メインとPick Upの間 */
  }
}

/* --------------------
		aside
-------------------- */
aside {
  overflow: hidden;
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: 26.66667vw 0 26.66667vw;
  background-color: #fff;
}

aside img {
  width: 100%;
  height: auto;
}

@media screen and (min-width: 1000px) {
  aside {
    width: 100%;
    margin: 0 auto;
    padding: 7.8125vw 0 7.8125vw;
    margin: 0 auto;
  }
}

aside p {
  line-height: 2;
  font-size: 3.2vw;
  letter-spacing: 0.1em;
}

@media screen and (min-width: 1000px) {
  aside p {
    font-size: 12px;
  }
}

aside a {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

aside a:hover {
  opacity: 0.5;
}

aside .swiper-wrapper {
  width: 80%;
}

@media screen and (min-width: 1000px) {
  aside .swiper-wrapper {
    width: 100%;
  }
}

aside .swiper-wrapper .swiper-slide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 60vw;
  margin-right: 2.66667vw;
}

@media screen and (min-width: 1000px) {
  aside .swiper-wrapper .swiper-slide {
    width: 225px;
    margin-right: 10px;
  }
}

@media screen and (min-width: 1000px) {
  .aside__wrap {
    width: 600px;
    margin: 0 auto;
    overflow: hidden;
  }
}

.aside__wrap:not(:last-child)::after {
  content: "";
  display: block;
  width: 80%;
  height: 1px;
  background-color: #EFEFEF;
  margin: 100px auto;
}

@media screen and (min-width: 1000px) {
  .aside__wrap:not(:last-child)::after {
    width: 100%;
  }
}

.aside__wrap .aside__ttl {
  font-family: "aktiv-grotesk", sans-serif;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
  margin-bottom: 5.33333vw;
  text-align: center;
  font-size: 5.86667vw;
}

@media screen and (min-width: 1000px) {
  .aside__wrap .aside__ttl {
    font-size: 1.71875vw;
    margin-bottom: 20px;
  }
}

.aside__wrap .aside__cap {
  margin-bottom: 13.33333vw;
  text-align: center;
}

@media screen and (min-width: 1000px) {
  .aside__wrap .aside__cap {
    margin-bottom: 50px;
  }
}

.aside-list li a {
  width: 60vw;
  margin-bottom: 0;
}

@media screen and (min-width: 1000px) {
  .aside-list li a {
    width: 225px;
  }
}

.aside-list__img {
  margin-bottom: 2.66667vw;
}

@media screen and (min-width: 1000px) {
  .aside-list__img {
    margin-bottom: 10px;
  }
}

.aside-list__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0.05em;
  text-align: left;
  margin-bottom: 0;
}

@media screen and (min-width: 1000px) {
  .aside-list__txt {
    margin-bottom: 0;
  }
}

.aside__btn {
  font-family: "aktiv-grotesk", sans-serif;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.05em;
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 60vw;
  margin: 0 auto;
  text-align: center;
  font-size: 5.86667vw;
}

@media screen and (min-width: 1000px) {
  .aside__btn {
    font-size: 1.71875vw;
    height: 360px;
  }
}

.aside__btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url(/special/250916_onlinestore-w_pre-order/common/img/all_btn.jpg) no-repeat center/cover;
  -webkit-transition: -webkit-transform 0.8s ease-in-out;
  transition: -webkit-transform 0.8s ease-in-out;
  transition: transform 0.8s ease-in-out;
  transition: transform 0.8s ease-in-out, -webkit-transform 0.8s ease-in-out;
}

.aside__btn:hover::before {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

.aside__btn a {
  position: relative;
  display: block;
  color: #fff;
  -webkit-transition: color 0.5s ease;
  transition: color 0.5s ease;
  line-height: 60vw;
}

@media screen and (min-width: 1000px) {
  .aside__btn a {
    line-height: 360px;
    height: 360px;
  }
}

.sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 26.66667vw 0 auto;
}

.sns img {
  vertical-align: middle;
}

@media screen and (min-width: 1000px) {
  .sns {
    margin: 7.8125vw auto;
  }
}

.sns a {
  display: block;
}

.sns__x {
  width: 6.66667vw;
  margin-right: 6.93333vw;
}

@media screen and (min-width: 1000px) {
  .sns__x {
    width: 1.95312vw;
    margin-right: 2.03125vw;
  }
}

.sns__insta {
  width: 6.93333vw;
  margin-right: 6.93333vw;
}

@media screen and (min-width: 1000px) {
  .sns__insta {
    width: 2.03125vw;
    margin-right: 2.03125vw;
  }
}

.sns__youtube {
  width: 8vw;
}

@media screen and (min-width: 1000px) {
  .sns__youtube {
    width: 2.34375vw;
  }
}

/* --------------------
		footer
-------------------- */
.footer {
  padding: 16vw 0;
  background-color: var(--c-txt);
}

@media screen and (min-width: 1000px) {
  .footer {
    padding: 3.90625vw 0;
  }
}

.footer img {
  width: 100%;
  height: auto;
}

.footer__logo {
  width: 29.33333vw;
  margin: 0 auto 4.26667vw;
}

@media screen and (min-width: 1000px) {
  .footer__logo {
    width: 130px;
    margin: 0 auto 1.25vw;
  }
}

.footer__logo a {
  display: block;
}

@media screen and (min-width: 1000px) {
  .footer__logo a {
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
  }
  .footer__logo a:hover {
    opacity: 0.5;
  }
}

.footer__copyright {
  text-align: center;
  color: #fff;
  font-family: 'Lato', sans-serif;
  font-weight: 300;
  letter-spacing: 0.05em;
  font-size: 2.93333vw;
}

@media screen and (min-width: 1000px) {
  .footer__copyright {
    font-size: 1.01562vw;
  }
}
/*# sourceMappingURL=250916_onlinestore-w_pre-order_style.css.map */