@charset "UTF-8";

/* ===== CSS変数定義 ===== */
:root {
  /* color */
  --color-white: #ffffff;
  --color-black: #221815;
  --color-beige: #EBE6DF;
  --color-hiblue: #2D17FF;
  --color-higray: #C8C8C8;
  --color-gray: #6E6E6E;
  --color-pink: #E6CCBE;
  --color-pink-dark: #CFA38E;
  --color-blue: #C5CEE1;
  --color-blue-dark: #7F93BD;
  --color-green: #BDC3C3;
  --color-green-dark: #9DA6A6;
  --color-orange: #E0C59C;
  --color-orange-dark: #CCA05C;
  --color-yellow: #E4DEB6;
  --color-yellow-dark: #B6A539;

  /* font */
  --font-noto: "Noto Sans JP", sans-serif;/*400*/
  --font-corm: "Cormorant Garamond", serif;/*300-700,normal,italic*/
  --font-shippori: "Shippori Mincho B1", serif;/*500-800*/

  /* font-size */
  --fs-70: clamp(6.2rem, 7vw, 7rem);
  --fs-60: clamp(5.2rem, 6vw, 6rem);
  --fs-55: clamp(4.7rem, 5.5vw, 5.5rem);
  --fs-45: clamp(3.7rem, 4.5vw, 4.5rem);
  --fs-40: clamp(3.2rem, 4vw, 4rem);
  --fs-36: clamp(2.8rem, 3.6vw, 3.6rem);
  --fs-32: clamp(2.4rem, 3.2vw, 3.2rem);
  --fs-30: clamp(2.1rem, 3.2vw, 3rem);
  --fs-26: clamp(2.2rem, 2.6vw, 2.6rem);
  --fs-24: clamp(2rem, 2.4vw, 2.4rem);
  --fs-22: clamp(2rem, 2.2vw, 2.2rem);
  --fs-20: clamp(1.8rem, 2vw, 2rem);
  --fs-19: clamp(1.7rem, 1.9vw, 1.9rem);
  --fs-18: clamp(1.6rem, 1.8vw, 1.8rem);
  --fs-17: clamp(1.5rem, 1.7vw, 1.7rem);
  --fs-16: clamp(1.4rem, 1.6vw, 1.6rem);
  --fs-15: clamp(1.3rem, 1.5vw, 1.5rem);
  --fs-14: clamp(1.2rem, 1.4vw, 1.4rem);
  --fs-12: clamp(1rem, 1.2vw, 1.2rem);

  /* 余白 */
  --space-40: clamp(24px, 4vw, 40px);
  --space-64: clamp(32px, 6.4vw, 64px);
  --space-80: clamp(40px, 8vw, 80px);
  --space-100: clamp(64px, 10vw, 100px);
  --space-120: clamp(80px, 12vw, 120px);
  --space-140: clamp(100px, 14vw, 140px);
  --space-160: clamp(100px, 16vw, 160px);
  --space-180: clamp(120px, 18vw, 180px);
  --space-200: clamp(120px, 20vw, 200px);
}

@media screen and (max-width: 600px) {
  :root {
    --space-100: clamp(2rem, 10vw, 5rem); /* 最大 80px に */
    --space-120: clamp(2.5rem, 12vw, 6rem); /* 最大 96px に */
  }
}

@media screen and (min-width: 1200px) {
  :root {
    --space-40: clamp(1.25rem, 4vw, 2.5rem);
    --space-64: clamp(2rem, 6.4vw, 4rem);
  }
}

/* ===== 基本スタイル ===== */
body {
  color: var(--color-black);
  font-family: var(--font-noto);
  font-weight: 400;
  font-size: var(--fs-15);
  letter-spacing: 0.14em;
  line-height: 1.8;
  background: var(--color-beige);
}

/* セクション要素の余白リセット */
.container-1300 {
  width: 100%;
  max-width: 1300px;
  margin-right: auto;
  margin-left: auto;
}
.container-1200 {
  width: 100%;
  max-width: 1200px;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 1300px) {
  .container-1200 {
    padding-right: 5%;
    padding-left: 5%;
  }
}
.container-1050 {
  width: 100%;
  max-width: 1050px;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 1150px) {
  .container-1050 {
    padding-right: 5%;
    padding-left: 5%;
  }
}
.container-730 {
  width: 100%;
  max-width: 730px;
  margin-right: auto;
  margin-left: auto;
}
@media screen and (max-width: 830px) {
  .container-730 {
    padding-right: 5%;
    padding-left: 5%;
  }
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 70px;
  font-size: 62.5%;
  overflow-x: hidden;
  margin: 0 !important;
}
.main {
  margin-top: 70px;
}
/*@media screen and (max-width: 1300px) {
  .main {
    margin-top: 125px;
  }
  html {
    scroll-padding-top: 125px;
  }
}
@media screen and (max-width: 1200px) {
  html {
    scroll-padding-top: 109px;
  }
  .main {
    margin-top: 109px;
  }
}
@media screen and (max-width: 960px) {
  .main {
    margin-top: 62px;
  }
  html {
    scroll-padding-top: 63px;
  }
}*/
a {
  transition: all 0.3s ease;
  display: block;
}
a:hover {
  transform: translateY(5px);
}
p {
  text-align: justify;
}
.relative {
  position: relative;
}
/* 余白　 */
/* マージン */
.mb-40 {
  margin-bottom: var(--space-40);
}
.mb-64 {
  margin-bottom: var(--space-64);
}
.mb-80 {
  margin-bottom: var(--space-80);
}
.mb-100 {
  margin-bottom: var(--space-100);
}
.mb-120 {
  margin-bottom: var(--space-120);
}
.mb-140 {
  margin-bottom: var(--space-140);
}
.mb-160 {
  margin-bottom: var(--space-160);
}
.mb-200 {
  margin-bottom: var(--space-200);
}
.mt-40 {
  margin-top: var(--space-40);
}
.mt-64 {
  margin-top: var(--space-64);
}
.mt-80 {
  margin-top: var(--space-80);
}
.mt-100 {
  margin-top: var(--space-100);
}
.mt-120 {
  margin-top: var(--space-120);
}
.mt-140 {
  margin-top: var(--space-140);
}
.mt-160 {
  margin-top: var(--space-160);
}
.mt-200 {
  margin-top: var(--space-200);
}

/* パディング */
.pb-40 {
  padding-bottom: var(--space-40);
}
.pb-64 {
  padding-bottom: var(--space-64);
}
.pb-80 {
  padding-bottom: var(--space-80);
}
.pb-100 {
  padding-bottom: var(--space-100);
}
.pb-120 {
  padding-bottom: var(--space-120);
}
.pb-140 {
  padding-bottom: var(--space-140);
}
.pb-160 {
  padding-bottom: var(--space-160);
}
.pb-200 {
  padding-bottom: var(--space-200);
}
.pt-40 {
  padding-top: var(--space-40);
}
.pt-64 {
  padding-top: var(--space-64);
}
.pt-80 {
  padding-top: var(--space-80);
}
.pt-100 {
  padding-top: var(--space-100);
}
.pt-120 {
  padding-top: var(--space-120);
}
.pt-140 {
  padding-top: var(--space-140);
}
.pt-160 {
  padding-top: var(--space-160);
}
.pt-200 {
  padding-top: var(--space-200);
}

/*  配置  */
.flex-nml {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
}
.flex-btw {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
.flex-cnt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.flex-end {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
.row-reverse {
  -webkit-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.items-center {
  -webkit-align-items: center;
  align-items: center;
}
.items-start {
  -webkit-align-items: flex-start;
  align-items: flex-start;
}
.items-end {
  -webkit-align-items: flex-end;
  align-items: flex-end;
}
/* 縦書 */
.v-txt {
  writing-mode: vertical-rl;
  text-orientation: upright;
}
/* 背景色 */
.bg-white {
  background-color: var(--color-white);
}
/* 改行 */
.pc-only {
  display: inline-block;
}
.sp-only {
  display: none;
}
@media screen and (max-width: 960px) {
  .pc-only {
    display: none;
  }
  .sp-only {
    display: inline-block;
  }
}
