@charset "UTF-8";
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝template＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  font: inherit;
  list-style: none;
  vertical-align: baseline;
  background: transparent;
}
body {
  line-height: 1;
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
nav ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote before,
blockquote after,
q before,
q after {
  content: "";
  content: none;
}
a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}
ins {
  background-color: #191919;
  color: #fff;
  text-decoration: none;
}
mark {
  background-color: #191919;
  color: #fff;
  font-style: italic;
  font-weight: bold;
}
del {
  text-decoration: line-through;
}
abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
img {
  vertical-align: bottom;
  max-width: 100%;
  width: 100%;
}
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
  padding: 0;
}
input,
select {
  vertical-align: middle;
}
button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}
a {
  text-decoration: none;
}
html {
  scroll-padding-top: 4.5rem; /* ヘッダーの高さを入力 */
  scroll-behavior: smooth;
}
:root {
  /* デザイン幅を定義 */
  --design-w: 390;
  --design-ww: 1280;
  --design-h: 844;
  --design-wh: 844;
  /* カラーを定義 */
  --primary: #22303b;
  --white: #fff;
  --neautral50: #f7f7f7;
  --neautral100: #efefef;
  --neautral300: #bfbfbf;
  --neautral700: #5f5f5f;
}
body {
  width: 100%;
  font-family:
    Shippori Mincho,
    serif;
  color: var(--primary);
  font-size: clamp(15px, calc(100vw * 15 / var(--design-ww)), 16px);
  font-weight: 500;
  line-height: 1.4;
  overflow-x: hidden;
  /* 背景設定 */
  background-color: var(--white);
  z-index: 1;
  transition: 0.7s;
  scroll-behavior: smooth;
}
a:visited {
  color: inherit;
}
/* section .inner {
  margin: 0 auto;
  width: calc(100vw * 1280 / var(--design-ww));
} */
@media only screen and (max-width: 768px) {
  body {
    font-size: clamp(12px, calc(100vw * 14 / var(--design-w)), 16px);
    line-height: 200%;
  }
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝template＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

.article {
  margin: 0 auto;
  z-index: 1;
  @media screen and (max-width: 768px) {
    width: 100vw;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ HEADER ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.header {
  position: fixed;
  top: 0;
  width: 100%;
  height: 5rem;
  background: var(--white);
  z-index: 900;
  font-family: Cormorant, serif;
  font-size: clamp(14px, calc(100vw * 15 / var(--design-ww)), 18px);
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.03em;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: calc(100vw * 20 / var(--design-ww))
    calc(100vw * 34 / var(--design-ww));
}
.logo {
  width: calc(100vw * 101 / var(--design-ww));
  min-width: 5rem;
}
.logo img:last-child {
  display: none;
}
@media screen and (max-width: 768px) {
  .header {
    width: 100vw;
    height: 4.375rem;
    padding: 0 calc(100vw * 20 / var(--design-w));
  }
  .logo {
    width: 5.187rem;
    min-width: initial;
  }
  .logo img:first-child {
    display: none;
  }
  .logo img:last-child {
    display: block;
  }
}

/* ===== PCナビ ===== */
.pc_nav {
  display: flex;
  gap: calc(100vw * 24 / var(--design-ww));
  align-items: center;
}
.pc_nav a {
  color: var(--primary);
  display: flex;
  align-items: center;
  gap: calc(100vw * 5 / var(--design-ww));
}
/* .nav_onlinestore svg {
  width: calc(100vw * 8.5 / var(--design-ww));
  min-width: calc(100vw * 8 / var(--design-ww));
  height: auto;
} */
/* .nav_onlinestore {
  border-bottom: calc(100vw * 1 / var(--design-ww)) solid var(--primary);
} */
.nav_ig svg {
  width: calc(100vw * 20 / var(--design-ww));
  min-width: calc(100vw * 16 / var(--design-ww));
  height: auto;
}
@media screen and (max-width: 768px) {
  .pc_nav {
    display: none;
  }
}

/* ===== SPハンバーガー ===== */
/* .hamburgerwrap {
  width: 100vw;
  height: 4.375rem;
  padding: calc(100vw * 20 / var(--design-w)) calc(100vw * 20 / var(--design-w));
  position: fixed;
}
.hamburgerwrap .inner {
  position: relative;
} */
.hamburger {
  position: fixed;
  width: 30px;
  height: 18px;
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  top: 35px;
  transform: translateY(-50%);
  right: 1.25rem;
  z-index: 1100;
  /* buttonはデフォルトで余白持ってることある */
  padding: 0;
}
.hamburger span {
  /* display: block; */
  width: 1.875rem;
  height: 1px;
  background: var(--primary);
  /* margin: 9px 0; */
  z-index: 999;
  position: absolute;
  left: 0;
  /* 変形 */
  transition:
    transform 0.4s ease,
    opacity 0.3s ease;
}
@media screen and (max-width: 768px) {
  .hamburger {
    display: block;
  }
}

/* 3本の配置 */
.hamburger span:nth-child(1) {
  top: 0;
}
.hamburger span:nth-child(2) {
  top: 9px;
}
.hamburger span:nth-child(3) {
  top: 18px;
}

/* open時 */
.hamburger.open span {
  background: var(--white);
}
.hamburger.open span:nth-child(1) {
  transform: translateY(9px) rotate(45deg);
}
.hamburger.open span:nth-child(2) {
  opacity: 0;
}
.hamburger.open span:nth-child(3) {
  transform: translateY(-9px) rotate(-45deg);
}

/* ===== ドロワー ===== */
.drawer {
  font-family: Cormorant, serif;
  font-size: clamp(16px, calc(100vw * 20 / var(--design-w)), 24px);
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.03em;
  position: fixed;
  top: 0;
  right: -100%;
  width: 90%;
  height: 100%;
  /* height: calc(100vh * 844 / var(--design-h)); */
  color: var(--white);
  background: var(--primary);
  transition: right 0.4s ease;
  z-index: 1001;
  padding: calc(100vw * 110 / var(--design-w))
    calc(100vw * 30 / var(--design-w));
}
.drawer.open {
  right: 0;
}
.drawer_close {
  background: none;
  border: none;
  color: var(--white);
  position: absolute;
  top: calc(100vw * 20 / var(--design-w));
  right: calc(100vw * 20 / var(--design-w));
}
.drawer_nav a {
  color: inherit;
}
.drawer_navwrap {
  display: flex;
  flex-direction: column;
  margin-bottom: calc(100vw * 56 / var(--design-w));
}
.drawer_navwrap span {
  border: solid #344350 calc(100vw * 1 / var(--design-w));
}
.drawer_navwrap a {
  padding: calc(100vw * 20 / var(--design-w)) 0;
}
.drawer_btn {
  border: solid var(--white) calc(100vw * 1 / var(--design-w));
  background: rgba(255, 255, 255, 0.03);
  padding: calc(100vw * 9 / var(--design-w)) 0;
  border-radius: calc(100vw * 40 / var(--design-w));
  text-align: center;
  display: flex;
  gap: calc(100vw * 6 / var(--design-w));
  align-items: center;
  justify-content: center;
  margin-bottom: calc(100vw * 16 / var(--design-w));
}
.drawer_btn svg {
  width: calc(100vw * 12 / var(--design-w));
  height: auto;
}
.drawer_ig {
  font-size: clamp(16px, calc(100vw * 18 / var(--design-w)), 20px);
  text-decoration: underline;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(100vw * 6 / var(--design-w));
}
.drawer_ig svg {
  width: calc(100vw * 15 / var(--design-w));
  height: auto;
}

/* 左側オーバーレイ */
.drawer_overlay {
  position: fixed;
  inset: 0;
  background: rgba(34, 48, 59, 0.5);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
  z-index: 1000;
}
.drawer_overlay.open {
  opacity: 1;
  pointer-events: auto;
}

/* 背景スクロール禁止 */
body.is-fixed {
  overflow: hidden;
}

/* ヘッダー制御 */
body.is-fixed .header {
  visibility: hidden;
}
body.is-fixed .hamburger {
  display: block;
  z-index: 99999999999999999;
}

/* ===== SPヘッダー IGアイコン ===== */
@media screen and (min-width: 769px) {
  .sp_header_ig {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .sp_header_ig {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    /* ハンバーガーの右端位置(1.25rem) ＋ ハンバーガー幅(30px) ＋ 余白(約18px) ＝ 4.25rem */
    right: 4rem; 
    z-index: 999;
  }
  .sp_header_ig svg {
    width: 1.4375rem;
    height: auto;
  }
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ HEADER ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ MV ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.mv {
  margin-top: 5rem;
}
.mv .inner {
  position: relative;
  overflow: hidden;
  width: 100%;
}
.mv_logo {
  position: absolute;
  left: calc(100vw * 80 / var(--design-ww));
  bottom: calc(100vw * 37 / var(--design-ww));
  z-index: 1;
}
.mv_logo img {
  width: calc(100vw * 250 / var(--design-ww));
  height: auto;
}
.slide-container img:last-child {
  display: none;
}
@media screen and (max-width: 768px) {
  .mv {
    margin-top: 4.375rem;
    height: calc(100vw * 691 / var(--design-w));
  }
  .mv_logo {
    left: calc(100vw * 20 / var(--design-w));
    bottom: calc(100vw * 18 / var(--design-w));
  }

  .mv_logo img {
    width: calc(100vw * 154 / var(--design-w));
  }
  .slide-container img:first-child {
    display: none;
  }
  .slide-container img:last-child {
    display: block;
  }
}

/* ＝＝＝＝＝ splide ＝＝＝＝＝ */
.mv .splide__slide {
  /* 拡大時に枠からはみ出ないようにする */
  overflow: hidden;
}
/* 画像を囲むコンテナにアニメーションを設定 */
.mv .slide-container {
  width: 100%;
  height: 100%;
  transform: scale(1.1); /* 初期状態：少し拡大しておく */
  transition: transform 6s ease-out; /* 変化する時間とイージング */
}
/* アクティブになったスライドの画像コンテナ */
.mv .splide__slide.is-active .slide-container {
  transform: scale(1); /* 縮小：アクティブになったら通常サイズに戻る */
}

/* ＝＝＝＝＝ scroll ＝＝＝＝＝ */
/* .scroll_down {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(100vw * 4.5 / var(--design-ww));
} */

/* scroll文字 */
/* .scroll_down span {
  writing-mode: vertical-rl;
  font-family: Cormorant, serif;
  font-size: clamp(14px, calc(100vw * 15 / var(--design-ww)), 20px);
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.03em;
  color: var(--primary);
} */
/* 縦線 */
/* .scroll_down::after {
  content: "";
  width: calc(100vw * 1 / var(--design-ww));
  height: calc(100vw * 50 / var(--design-ww));
  background: var(--primary);
}
@media screen and (max-width: 768px) {
  .scroll_down {
    right: calc(100vw * 11 / var(--design-w));
    bottom: calc(100vw * 20 / var(--design-w));
    gap: calc(100vw * 5 / var(--design-w));
  }
  .scroll_down span {
    font-size: clamp(10px, calc(100vw * 12 / var(--design-w)), 14px);
  }
  .scroll_down::after {
    width: calc(100vw * 1 / var(--design-w));
    height: calc(100vw * 50 / var(--design-w));
  }
} */

.scrollwrap {
  position: absolute;
  right: calc(100vw * 50 / var(--design-ww));
  bottom: calc(100vw * 40 / var(--design-ww));
  /* right: 3.125rem;
  bottom: 2.5rem; */
  z-index: 1;
}
.scroll_down {
  position: relative;
}
/* テキスト */
.scroll_down span {
  width: fit-content;
  padding-bottom: calc(100vw * 55 / var(--design-ww));
  /* padding-bottom: 3.437rem; */
  font-family: Cormorant, serif;
  font-size: clamp(14px, calc(100vw * 15 / var(--design-ww)), 20px);
  font-size: 0.937rem;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.03em;
  writing-mode: vertical-lr;
  overflow: hidden;
  margin: 0 auto;
  position: relative;
}
@media screen and (max-width: 768px) {
  .scrollwrap {
    right: calc(100vw * 11 / var(--design-w));
    bottom: calc(100vw * 20 / var(--design-w));
    /* right: 0.687rem;
    bottom: 1.25rem; */
  }
  .scroll_down span {
    width: 1.25rem;
    padding-bottom: calc(100vw * 55 / var(--design-w));
    font-size: clamp(10px, calc(100vw * 12 / var(--design-w)), 14px);
    /* padding-bottom: 3.125rem;
    font-size: 0.75rem; */
  }
}

/* 線 */
.scroll_down span:before,
.scroll_down span:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: calc(100vw * 50 / var(--design-ww));
  /* height: 3.125rem; */
}
/* 下の線 */
.scroll_down span:before {
  background: var(--neautral300);
}
/* 動く線 */
.scroll_down span:after {
  background: var(--primary);
}
@media screen and (max-width: 768px) {
  .scroll_down span:before,
  .scroll_down span:after {
    height: calc(100vw * 50 / var(--design-w));
    /* height: 3.125rem; */
  }
}

/* アニメーション指定 */
#type01 span:after {
  animation: sdl01 1.5s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl01 {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}

/* PC版 MVの高さ調整 */
@media screen and (min-width: 769px) {
  .mv .inner {
    /* 画面高さいっぱい（ヘッダー5rem分を引く） */
    height: calc(100vh - 5rem);
    /* どうしてもタテ最大1080pxまでにしたい場合は追加 */
    /* max-height: calc(1080px - 5rem); */
  }
  /* スライダー各要素を親(.inner)の高さに100%合わせる */
  .mv .splide,
  .mv .splide__track,
  .mv .splide__list,
  .mv .splide__slide,
  .mv .slide-container {
    height: 100%;
  }
  /* 画像比率を保ったまま枠いっぱいに広げる&はみ出た部分をカット */
  .mv .slide-container img {
    height: 100%;
    object-fit: cover;
    object-position: center; /* 左右中央基準表示 */
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ MV ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ CONCEPT ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.concept h3 {
  margin: 0 auto;
  text-align: center;
  margin: calc(100vw * 104 / var(--design-ww)) auto
    calc(100vw * 45 / var(--design-ww));
}
.concept h3 p:first-child {
  font-family: Cormorant, serif;
  font-size: clamp(24px, calc(100vw * 32 / var(--design-ww)), 56px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
  .concept h3 {
    margin: calc(100vw * 60 / var(--design-w)) auto
      calc(100vw * 40 / var(--design-w));
  }
  .concept h3 p:first-child {
    font-size: clamp(24px, calc(100vw * 28 / var(--design-w)), 20px);
    font-weight: 500;
    letter-spacing: 0.08em;
  }
}

/* splide */
.concept .splide img {
  width: calc(100vw * 360 / var(--design-ww));
  height: auto;
}
@media screen and (max-width: 768px) {
  .concept .splide img {
    width: calc(100vw * 200 / var(--design-w));
  }
}

/* Safari GPU対策 */
.splide__list {
  will-change: transform;
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* cssのみのスライダーにする */
/* JSを使わないのでSplideの非表示設定を強制的に上書きして表示させる */
.splide.splide_concept {
  visibility: visible !important;
}

.splide_concept .splide__list {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: scrollLoop 25s linear infinite;
}

/* Flexboxの影響で画像が潰れないよう縮むのを防止する */
.splide_concept .splide__slide {
  flex-shrink: 0;
}
.splide_concept .splide__track {
  overflow: hidden;
}

@keyframes scrollLoop {
  0% {
    transform: translateX(0);
  }
  100% {
    /* 画像6枚分＋gapの半分(10px)を引く */
    transform: translateX(calc(-50% - 10px));
  }
}

@media screen and (max-width: 768px) {
  .splide_concept .splide__list {
    animation: scrollLoop 15s linear infinite;
  }
}

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ CONCEPT ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ ABOUT ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.about {
  /* display: flex;
  align-items: start;
  margin: calc(100vw * 140 / var(--design-ww)) auto
    calc(100vw * 225 / var(--design-ww)); */
  position: relative; /* テキストを重ねるための基準 */
  margin: calc(100vw * 140 / var(--design-ww)) auto
    calc(100vw * 225 / var(--design-ww));
}
.about .imgwrap {
  /* position: relative;
  width: 50%; */
  width: 100%; /* 画像を全幅に広げる */
}
.about_l {
  /* width: calc(100vw * 639 / var(--design-ww)); */
  width: 100%;
  height: auto;
}
.about_l img {
  width: 100%;
  height: auto;
  display: block; /* 画像の下の謎の隙間を消す */
}
.about_l img:last-child {
  display: none;
}
@media screen and (max-width: 768px) {
  .about {
    flex-direction: column;
    align-items: center;
    margin: calc(100vw * 110 / var(--design-w)) auto;
  }
  .about .imgwrap {
    width: 100%;
  }
  .about_l img:first-child {
    display: none;
  }
  .about_l img:last-child {
    display: block;
  }
  .about_l {
    width: 100%;
    height: auto;
  }
}

/* ーーーーー 【PC】画像の上にテキストを重ねる ーーーーー */
.about .textwrap {
  /* width: 50%;
  padding: calc(100vw * 95 / var(--design-ww))
    calc(100vw * 130 / var(--design-ww)) 0 calc(100vw * 110 / var(--design-ww)); */
  position: absolute;
  top: 50%; /* 上下中央揃え */
  transform: translateY(-50%); /* 上下中央揃え */
  right: calc(100vw * 130 / var(--design-ww));
  width: calc(100vw * 400 / var(--design-ww)); /* テキストエリアの幅 */
  color: var(--white); /* 白文字に変更！ */
  line-height: calc(100vw * 40 / var(--design-ww));
  padding: 0;
  z-index: 2; /* 画像より上に持ってくる */
}
.about h3 {
  font-family: Cormorant, serif;
  font-size: clamp(20px, calc(100vw * 26 / var(--design-ww)), 56px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
  display: flex;
  gap: calc(100vw * 8 / var(--design-ww));
  align-items: center;
  margin-bottom: calc(100vw * 18 / var(--design-ww));
}
.about .text {
  font-size: clamp(13px, calc(100vw * 15 / var(--design-ww)), 16px);
  font-weight: 500;
  letter-spacing: 0.09rem;
}
.about h3 img {
  width: calc(100vw * 159 / var(--design-ww));
  height: auto;
  /* SVGを白に反転させる */
  filter: brightness(0) invert(1);
  margin-top: calc(100vw * -1 / var(--design-ww));
}
.about h3 img:last-child {
  display: none;
}
/* ーーーーー End 【PC】画像の上にテキストを重ねる ーーーーー */

/* ーーーーー 【SP】重ねるのを解除して縦並び＆黒文字に戻す ーーーーー */
@media screen and (max-width: 768px) {
  .about {
    display: flex;
    flex-direction: column; /* 縦並び */
    margin: calc(100vw * 110 / var(--design-w)) auto;
  }
  .about_l img:first-child {
    display: none;
  }
  .about_l img:last-child {
    display: block;
  }
  .about .textwrap {
    position: static; /* 重ねる設定を解除！ */
    transform: none;
    width: 100%;
    line-height: 2;
    color: var(--primary); /* 黒文字に戻す */
    /* padding: calc(100vw * 82 / var(--design-w))
      calc(100vw * 40 / var(--design-w)) 0; */
    padding: calc(100vw * 85 / var(--design-w))
      calc(100vw * 40 / var(--design-w)) 0; /* 元々の余白 */
  }
  .about h3 {
    font-size: clamp(18px, calc(100vw * 20 / var(--design-w)), 56px);
    gap: calc(100vw * 8 / var(--design-w));
    margin-bottom: calc(100vw * 20 / var(--design-w));
    letter-spacing: 0.08em;
  }
  .about .text {
    font-size: clamp(12px, calc(100vw * 14 / var(--design-w)), 16px);
  }
  .about h3 img {
    width: calc(100vw * 140 / var(--design-w));
    /* SPは黒文字なので、ロゴを黒に戻す */
    filter: none;
    margin-top: calc(100vw * -1 / var(--design-w));
  }
  .about h3 img:first-of-type {
    display: none;
  }
  .about h3 img:last-child {
    display: block;
  }
}
/* ーーーーー End 【SP】重ねるのを解除して縦並び＆黒文字に戻す ーーーーー */
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ End ABOUT ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ End ABOUT ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ ANCHOR ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.anchor {
  display: flex;
  gap: calc(100vw * 20 / var(--design-ww));
  padding: 0 calc(100vw * 80 / var(--design-ww))
    calc(100vw * 186 / var(--design-ww));
}
.anchor .textwrap {
  display: flex;
  gap: calc(100vw * 12 / var(--design-ww));
  align-items: center;
  color: var(--white);
  align-items: baseline;
}
.anchor_alma,
.anchor_scudo {
  display: flex;
  align-items: end;
}
.anchor_alma .flexwrap,
.anchor_scudo .flexwrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: inherit;
  z-index: 1;
}
.anchor .title {
  font-family: Cormorant, serif;
  font-size: clamp(20px, calc(100vw * 28 / var(--design-ww)), 40px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
.anchor .title span {
  font-size: clamp(20px, calc(100vw * 24 / var(--design-ww)), 40px);
}
.anchor_alma,
.anchor_scudo {
  background-size: cover;
  width: calc(100vw * 550 / var(--design-ww));
  height: calc(100vw * 550 / var(--design-ww));
  padding: calc(100vw * 26 / var(--design-ww))
    calc(100vw * 40 / var(--design-ww));
}
@media screen and (max-width: 768px) {
  .anchor {
    flex-direction: column;
    gap: calc(100vw * 20 / var(--design-w));
    padding: 0 calc(100vw * 20 / var(--design-w))
      calc(100vw * 110 / var(--design-w));
  }
  .anchor .textwrap {
    gap: calc(100vw * 10 / var(--design-w));
  }
  .anchor .title {
    font-size: clamp(20px, calc(100vw * 24 / var(--design-w)), 40px);
    letter-spacing: 0.08em;
  }
  .anchor .title span {
    font-size: clamp(18px, calc(100vw * 20 / var(--design-w)), 40px);
  }
  .anchor .sub {
    font-size: clamp(12px, calc(100vw * 12 / var(--design-w)), 16px);
  }
  .anchor_alma,
  .anchor_scudo {
    width: 100%;
    height: calc(100vw * 350 / var(--design-w));
    padding: calc(100vw * 12 / var(--design-w))
      calc(100vw * 20 / var(--design-w));
  }
}

/* 背景 */
.anchor_alma .bg {
  position: absolute;
  inset: 0;
  background-image: url(../images/anchor_alma.jpg);
  background-size: cover;
  background-position: center;
  transition: transform 0.6s ease;
  z-index: 0;
}
.anchor_scudo .bg {
  position: absolute;
  inset: 0;
  background-image: url(../images/anchor_scudo.jpg);
  background-size: cover;
  background-position: center;
  transition: transform 0.6s ease;
  z-index: 0;
}
/* ホバーで背景画像拡大 */
.anchor_alma,
.anchor_scudo {
  position: relative;
  overflow: hidden; /* はみ出し防止 */
}
.anchor_alma:hover .bg,
.anchor_scudo:hover .bg {
  transform: scale(1.2);
}
@media screen and (max-width: 768px) {
  .anchor_alma .bg,
  .anchor_scudo .bg {
    transition: initial;
  }
  .anchor_alma:hover .bg,
  .anchor_scudo:hover .bg {
    transform: initial;
  }
}

/* 矢印 */
.anchor .arrow_right {
  background-color: rgba(255, 255, 255, 0.1);
  width: calc(100vw * 34 / var(--design-ww));
  height: calc(100vw * 34 / var(--design-ww));
  border-radius: 50%;
  border: solid var(--white) calc(100vw * 0.85 / var(--design-ww));
  text-decoration: none;
  position: relative;
  /* 上下左右中央 */
  display: flex;
  align-items: center;
  justify-content: center;
}
.anchor .arrow_right svg {
  width: calc(100vw * 9.31 / var(--design-ww));
  height: auto;
}
@media screen and (max-width: 768px) {
  .anchor .arrow_right {
    width: calc(100vw * 30 / var(--design-w));
    height: calc(100vw * 30 / var(--design-w));
    border: solid var(--white) calc(100vw * 0.78 / var(--design-w));
  }
  .anchor .arrow_right svg {
    width: calc(100vw * 9 / var(--design-w));
  }
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ ANCHOR ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ ALMA ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ＝＝＝＝＝ ALMA HEAD ＝＝＝＝＝ */
.series .head {
  background-image: url(../images/almaseries_bg.svg);
  background-size: cover;
  background-position: center;
  height: calc(100vw * 650 / var(--design-ww));
  padding: 0 calc(100vw * 160 / var(--design-ww));
  display: flex;
  align-items: center;
}
.series_bg_sp {
  display: none;
}
.series .head .textwrap {
  width: calc(100vw * 455 / var(--design-ww));
}
.series .head .titlewrap {
  display: flex;
  gap: calc(100vw * 12 / var(--design-ww));
  align-items: baseline;
}
.series .head .title {
  font-family: Cormorant, serif;
  font-size: clamp(20px, calc(100vw * 32 / var(--design-ww)), 40px);
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.1em;
}
.series .head .title span {
  font-size: clamp(20px, calc(100vw * 28 / var(--design-ww)), 40px);
}
.series .head p {
  font-size: clamp(13px, calc(100vw * 15 / var(--design-ww)), 18px);
  line-height: 2.67;
  margin-top: calc(100vw * 20 / var(--design-ww));
}
@media screen and (max-width: 768px) {
  .series .head {
    background-image: none;
    height: initial;
    padding: 0 calc(100vw * 40 / var(--design-w));
    flex-direction: column;
  }
  .series_bg_sp {
    display: block;
    margin: 0 calc(50% - 50vw);
    width: 100vw;
  }
  .series .head .textwrap {
    width: 100%;
    margin: calc(100vw * 40 / var(--design-w)) auto;
  }
  .series .head .titlewrap {
    gap: calc(100vw * 10 / var(--design-w));
  }
  .series .head .title {
    font-size: clamp(24px, calc(100vw * 28 / var(--design-w)), 48px);
    letter-spacing: 0.08em;
  }
  .series .head .title span {
    font-size: clamp(20px, calc(100vw * 24 / var(--design-w)), 40px);
  }
  .series .head p {
    font-size: clamp(14px, calc(100vw * 14 / var(--design-w)), 16px);
    margin-top: calc(100vw * 14 / var(--design-w));
    line-height: 2;
  }
}

/* ＝＝＝＝＝ ALMA DEATAILS ＝＝＝＝＝ */
.details {
  padding: calc(100vw * 94 / var(--design-ww))
    calc(100vw * 160 / var(--design-ww)) calc(100vw * 110 / var(--design-ww));
}
.details ol {
  display: flex;
  flex-wrap: wrap;
  column-gap: calc(100vw * 40 / var(--design-ww)); /* 横の余白 */
  row-gap: calc(100vw * 48 / var(--design-ww)); /* ← 上段と下段の余白 */
}
.details li {
  display: flex;
  flex-direction: column;
  gap: calc(100vw * 24 / var(--design-ww));
  /* width: calc(100vw * 460 / var(--design-ww)); */
  /* Windows 表示崩れ防止 */
  /* 50%から「column-gap(40)の半分の20」を引く（自動でピッタリ2列になる） */
  width: calc(50% - calc(100vw * 20 / var(--design-ww)));
}
.details .imgwrap img:last-child {
  display: none;
}
.details .no {
  font-family: Cormorant, serif;
  font-size: clamp(16px, calc(100vw * 24 / var(--design-ww)), 40px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.03em;
  color: var(--neautral300);
  border-bottom: solid var(--neautral100) calc(100vw * 1 / var(--design-ww));
}
.details .title {
  font-size: clamp(16px, calc(100vw * 20 / var(--design-ww)), 40px);
  margin-bottom: calc(100vw * 12 / var(--design-ww));
}
@media screen and (max-width: 768px) {
  .details {
    padding: 0 calc(100vw * 40 / var(--design-w))
      calc(100vw * 60 / var(--design-w));
  }
  .details ol {
    flex-direction: column;
    flex-wrap: nowrap;
    gap: calc(100vw * 24 / var(--design-w));
  }
  .details li {
    gap: calc(100vw * 16 / var(--design-w));
    width: 100%;
  }
  .details .imgwrap img:first-child {
    display: none;
  }
  .details .imgwrap img:last-child {
    display: block;
  }
  .details .no {
    font-size: clamp(16px, calc(100vw * 16 / var(--design-w)), 32px);
    border-bottom: solid var(--neautral100) calc(100vw * 1 / var(--design-w));
  }
  .details .title {
    font-size: clamp(16px, calc(100vw * 16 / var(--design-w)), 40px);
    margin-bottom: calc(100vw * 8 / var(--design-w));
  }
}

/* ＝＝＝＝＝ ALMA LINE UP ＝＝＝＝＝ */
.series .lineup {
  background-color: var(--neautral50);
  padding: calc(100vw * 120 / var(--design-ww))
    calc(100vw * 80 / var(--design-ww)) calc(100vw * 180 / var(--design-ww));
}
.series .lineup ul {
  display: flex;
  gap: calc(100vw * 20 / var(--design-ww));
}
.series .lineup li {
  display: flex;
  flex-direction: column;
  gap: calc(100vw * 14 / var(--design-ww));
  width: calc(100vw * 360 / var(--design-ww));
}
.series .lineup .imgwrap_sp {
  display: block;
}
.series .lineup .textwrap {
  display: flex;
  flex-direction: column;
  gap: calc(100vw * 3 / var(--design-ww));
}
.series .lineup .titlewrap {
  display: flex;
  align-items: baseline;
  gap: calc(100vw * 8 / var(--design-ww));
}
.series .lineup .title,
.series .lineup .price {
  font-size: clamp(12px, calc(100vw * 18 / var(--design-ww)), 40px);
  font-weight: 600;
  line-height: 1.6;
}
.series .lineup .titlewrap span {
  font-size: clamp(8px, calc(100vw * 12 / var(--design-ww)), 16px);
  font-weight: 500;
}
.series .lineup .price {
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .series .lineup {
    padding: calc(100vw * 80 / var(--design-w))
      calc(100vw * 40 / var(--design-w)) calc(100vw * 110 / var(--design-w));
  }
  .series .lineup ul {
    flex-direction: column;
    gap: calc(100vw * 40 / var(--design-w));
  }
  .series .lineup li {
    gap: calc(100vw * 10 / var(--design-w));
    width: 100%;
  }
  .series .lineup .imgwrap {
    display: none;
  }
  .series .lineup .imgwrap_sp {
    display: block;
    position: relative;
  }
  .series .lineup .textwrap {
    gap: calc(100vw * 3 / var(--design-w));
  }
  .series .lineup .titlewrap {
    gap: calc(100vw * 10 / var(--design-w));
  }
  .series .lineup .title,
  .series .lineup .price {
    font-size: clamp(14px, calc(100vw * 16 / var(--design-w)), 20px);
  }
  .series .lineup .titlewrap span {
    font-size: clamp(8px, calc(100vw * 12 / var(--design-w)), 16px);
  }
}

/* ーーーーー カラードット ーーーーー */
.colorwrap {
  display: flex;
  gap: calc(100vw * 6 / var(--design-ww));
  margin-top: calc(100vw * 10 / var(--design-ww));
}
.color-dot {
  width: calc(100vw * 18 / var(--design-ww));
  height: calc(100vw * 18 / var(--design-ww));
  border-radius: 50%;
  border: solid calc(100vw * 1 / var(--design-ww)) var(--neautral700);
  cursor: default !important;
}
/* 色指定 */
.color-dot[data-color="black"] {
  background: #0e0e0e;
}
.color-dot[data-color="beige"] {
  background: #c8ab8b;
}
.color-dot[data-color="khaki"] {
  background: #5b5441;
}
/* 選択中 */
.color-dot.active {
  outline: solid calc(100vw * 1 / var(--design-ww)) var(--primary);
  outline-offset: calc(100vw * 2 / var(--design-ww));
}
@media screen and (max-width: 768px) {
  .colorwrap {
    gap: calc(100vw * 6 / var(--design-w));
    margin-top: calc(100vw * 10 / var(--design-w));
  }
  .color-dot {
    width: calc(100vw * 18 / var(--design-w));
    max-width: 1.5rem;
    height: calc(100vw * 18 / var(--design-w));
    max-height: 1.5rem;
    border: solid calc(100vw * 1 / var(--design-w)) var(--neautral700);
  }
  /* 選択中 */
  .color-dot.active {
    outline: solid calc(100vw * 1 / var(--design-w)) var(--primary);
    outline-offset: calc(100vw * 2 / var(--design-w));
  }
}

/* ーーーーー 画像切り替え ーーーーー */
.series .lineup .imgwrap {
  position: relative;
}
.series .lineup .productimg {
  display: none;
  width: 100%;
  cursor: pointer;
}
.series .lineup .productimg.active {
  display: block;
  opacity: 1;
}

/* ーーーーー SPスライダーーーーーー */
@media screen and (max-width: 768px) {
  .lineup.splide {
    visibility: visible !important;
  }
}
/* ーーー 矢印 ーーー */
.sp-arrow,
.sp-pagination {
  visibility: hidden;
}
@media screen and (max-width: 768px) {
  .sp-arrow,
  .sp-pagination {
    visibility: visible;
  }
}
/* 背景 */
.sp-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: calc(100vw * 30 / var(--design-w));
  height: calc(100vw * 30 / var(--design-w));
  background: rgba(34, 48, 59, 0.3);
  border: none;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sp-arrow.prev {
  left: calc(100vw * 14 / var(--design-w));
}
.sp-arrow.next {
  right: calc(100vw * 14 / var(--design-w));
}
/* アイコン（三角） */
.sp-arrow.prev svg,
.sp-arrow.next svg {
  width: calc(100vw * 3 / var(--design-w));
  height: auto;
}

/* ーーー ページネーション ーーー */
.sp-pagination {
  position: absolute;
  bottom: calc(100vw * 10 / var(--design-w));
  left: calc(100vw * 27 / var(--design-w));
  transform: translateX(-50%);
  display: flex;
  gap: calc(100vw * 6 / var(--design-w));
}
.sp-pagination .dot {
  width: calc(100vw * 10 / var(--design-w));
  height: calc(100vw * 10 / var(--design-w));
  background: rgba(34, 48, 59, 0.2);
  border-radius: 50%;
  border: solid rgba(255, 255, 255, 0.5) 1px;
}
.sp-pagination .dot.active {
  background: rgba(34, 48, 59, 0.6);
  border: solid var(--white) 1px;
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ ALMA ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝SCUDO ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
/* ＝＝＝＝＝ SCUDO HEAD ＝＝＝＝＝ */
.scudo .head {
  background-image: url(../images/scudoseries_bg.svg);
}

@media screen and (max-width: 768px) {
  .scudo .head {
    background-image: none;
  }
  .scudo .head .textwrap p br:last-child {
    display: none;
}
}
/* ＝＝＝＝＝ SCUDO DEATAILS ＝＝＝＝＝ */
/* ーーー カラードット ーーー */
/* 色指定 */
.color-dot[data-color="navy"] {
  background: #414956;
}

/* ＝＝＝＝＝ SCUDO LINE UP ＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝SCUDO ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ CTA ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.cta {
  display: flex;
}
.cta .imgwrap {
  width: 50%;
}
.cta .btnwrap {
  background-color: var(--neautral100);
  width: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: calc(100vw * 20 / var(--design-ww));
  padding: 0 calc(100vw * 80 / var(--design-ww));
}
.cta .btnwrap a {
  background-color: var(--white);
  color: inherit;
  border-radius: calc(100vw * 6 / var(--design-ww));
  border: solid var(--primary) calc(100vw * 1 / var(--design-ww));
  height: calc(100vw * 70 / var(--design-ww));
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(100vw * 16 / var(--design-ww))
    calc(100vw * 24 / var(--design-ww));
  /* 初期ボックスシャドウ（右下） */
  box-shadow: calc(100vw * 5 / var(--design-ww))
    calc(100vw * 5 / var(--design-ww)) 0 0 rgba(0, 0, 0, 0.2);
  /* なめらかホバー */
  transition: all 0.2s;
}
.cta .btnwrap img {
  width: calc(100vw * 38 / var(--design-ww));
  height: auto;
}
.cta .btnwrap img:last-of-type {
  display: none;
}
.cta .btnwrap p {
  width: -webkit-fill-available;
  text-align: center;
}
.cta .online {
  font-size: clamp(16px, calc(100vw * 18 / var(--design-ww)), 24px);
  font-family: Cormorant, serif;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.03em;
}
.cta .ig {
  font-size: clamp(16px, calc(100vw * 20 / var(--design-ww)), 24px);
  font-family: Cormorant, serif;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.03em;
}
.cta .contact {
  font-size: clamp(16px, calc(100vw * 17 / var(--design-ww)), 24px);
  font-weight: 600;
}
@media screen and (max-width: 768px) {
  .cta {
    flex-direction: column;
  }
  .cta .imgwrap {
    width: 100%;
  }
  .cta .btnwrap {
    width: 100%;
    gap: calc(100vw * 12 / var(--design-w));
    padding: calc(100vw * 60 / var(--design-w))
      calc(100vw * 40 / var(--design-w));
  }
  .cta .btnwrap a {
    border-radius: calc(100vw * 6 / var(--design-w));
    border: solid var(--primary) calc(100vw * 0.82 / var(--design-w));
    height: calc(100vw * 54 / var(--design-w));
    padding: 0 calc(100vw * 16 / var(--design-w));
    box-shadow: calc(100vw * 4 / var(--design-w))
      calc(100vw * 4 / var(--design-w)) 0 0 rgba(0, 0, 0, 0.2);
    transition: initial;
  }
  .cta .btnwrap img {
    width: calc(100vw * 24 / var(--design-w));
  }
  .cta .btnwrap img:first-of-type {
    display: none;
  }
  .cta .btnwrap img:last-of-type {
    display: block;
  }
  .cta .online {
    font-size: clamp(14px, calc(100vw * 15 / var(--design-w)), 24px);
  }
  .cta .ig {
    font-size: clamp(14px, calc(100vw * 16 / var(--design-w)), 24px);
  }
  .cta .contact {
    font-size: clamp(14px, calc(100vw * 14 / var(--design-w)), 24px);
  }
}

/* ＝＝＝＝＝ ホバーできる端末だけ＝＝＝＝＝ */
@media (hover: hover) and (pointer: fine) {
  .cta .btnwrap a:hover {
    box-shadow: none;
    /* 右下へ押し込む */
    transform: translate(
      calc(100vw * 5 / var(--design-ww)),
      calc(100vw * 5 / var(--design-ww))
    );
  }
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ CTA ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ FOOTER ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
footer {
  background-color: var(--white);
  padding: calc(100vw * 30 / var(--design-ww)) 0;
  text-align: center;
  font-size: clamp(10px, calc(100vw * 12 / var(--design-ww)), 16px);
  font-family: Cormorant, serif;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 768px) {
  footer {
    padding: calc(100vw * 22 / var(--design-w)) 0;
    font-size: clamp(10px, calc(100vw * 10 / var(--design-w)), 12px);
  }
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ FOOTER ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */

/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ スクロールでふわっと出現アニメーション ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
.advanced {
  --ease-out-quint: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out-cubic: cubic-bezier(0.33, 1, 0.68, 1);

  opacity: 0;
  translate: 0 13%;

  &.isActive {
    opacity: 1;
    translate: 0;
    transition-timing-function:
      opacity var(--ease-out-cubic),
      translate var(--ease-out-quint);
    transition-duration: 1.8s;
  }
}
/* ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ スクロールでふわっと出現アニメーション ＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝＝ */
