:root {
  --color-base: #111111;
  --color-body: #fff;
  --color-beige1: #ffeddf;
  --color-beige2: #FDF8E7;
  --color-brown1: #956134;
  --color-red1: #FF645F;
  --color-orange1: #F7792A;
  --color-gray1: #e7ded9;
  --color-gray2: #F0F5F7;
  --color-green1: #005F2F;
  --color-green2: #0C8F54;
  --color-green3: #B7D450;
  --color-green4: #0C8F2B;
  --color-blue1: #1C66A3;
  --color-white_op: rgb(from #fff r g b / 0.7);
}

:root {
  --color-base: #111111;
  --color-body: #fff;
  --color-beige1: #ffeddf;
  --color-beige2: #FDF8E7;
  --color-brown1: #956134;
  --color-red1: #FF645F;
  --color-orange1: #F7792A;
  --color-gray1: #e7ded9;
  --color-gray2: #F0F5F7;
  --color-green1: #005F2F;
  --color-green2: #0C8F54;
  --color-green3: #B7D450;
  --color-green4: #0C8F2B;
  --color-blue1: #1C66A3;
  --color-white_op: rgb(from #fff r g b / 0.7);
}

/* ------------------------------------
// heading
------------------------------------ */
#pagetitle {
  position: relative;
  margin-bottom: clamp(2rem, 3.5vw, 5rem);
}
#pagetitle hgroup {
  position: absolute;
  left: 6rem;
  left: clamp(2rem, 4.2vw, 6rem);
  top: 50%;
  transform: translateY(-50%);
}
#pagetitle hgroup .category {
  color: var(--color-green1);
  font-size: clamp(2rem, 3.8vw, 5.4rem);
  letter-spacing: 0.1em;
  text-indent: -0.1em;
}
#pagetitle hgroup .sub {
  color: var(--color-green1);
  font-size: clamp(1.4rem, 1.4vw, 2rem);
  letter-spacing: 0.1em;
  text-indent: -0.1em;
}
#pagetitle {
  position: relative;
}
#pagetitle > * {
  position: relative;
  z-index: 2;
}
#pagetitle::before, #pagetitle:after {
  content: "";
  width: 25vw;
  aspect-ratio: 1;
  display: block;
  background: url(/lib/img/cmn/mori_01.webp) no-repeat 0 0/contain;
  position: absolute;
  top: 90%;
  z-index: 0;
  opacity: 0.8;
}
#pagetitle::before {
  left: 0;
}
#pagetitle::after {
  top: 110%;
  right: 0;
  transform: scaleX(-1);
}
@media screen and (max-width: 768px) {
  #pagetitle hgroup {
    padding: 1rem 2rem;
    border-radius: 5px;
    left: 0.5rem;
    right: 0.5rem;
    top: auto;
    bottom: 0.5rem;
    transform: none;
    background: rgba(255, 255, 255, 0.6);
  }
}

.mainTitle {
  text-align: center;
  color: var(--color-green2);
}
.mainTitle .en {
  font-family: "Croissant One", serif;
  font-size: clamp(2rem, 8.3vw, 12rem);
  margin-block: calc((1cap - 1lh) / 2);
  line-height: 1;
}
.mainTitle .en.en_s {
  font-size: clamp(2rem, 6.9vw, 10rem);
}
.mainTitle .title {
  font-size: clamp(2rem, 1.9vw, 2.8rem);
  margin-top: 1em;
}

/* ------------------------------------
// list
------------------------------------ */
.list_hyphen li {
  position: relative;
  padding-left: 1em;
}
.list_hyphen li + li {
  margin-top: 1em;
}
.list_hyphen li::before {
  content: "";
  width: 0.8rem;
  height: 1px;
  background: var(--color-brown1);
  position: absolute;
  left: 0;
  top: 0.8em;
}

/* ------------------------------------
// btn
------------------------------------ */
/* ------------------------------------
// text
------------------------------------ */
/* ------------------------------------
// type_treatment
------------------------------------ */