@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Allura&family=Kaisei+Tokumin:wght@500;700;800&family=Noto+Sans+JP:wght@100..900&display=swap");
/* =====================

base

===================== */
* {
  min-height: 0.01px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  letter-spacing: -0.01em;
}

/* ========= メールアドレススパム対策 ========= */
.domain::before {
  content: "@";
}

body {
  font-family: var(--ffm);
  line-height: 1.71429;
  -webkit-text-size-adjust: 100%;
  font-size: clamp(1.8rem, 1.3714285714rem + 1.3392857143vw, 2.4rem);
  font-weight: 500;
  color: var(--txt);
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt"; /* 文字づめ */
  background-color: var(--bg);
}

button,
textarea,
select {
  /* デフォルトスタイルをリセット */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  /* font-familyを継承しないので、継承させる */
  font-family: inherit;
  /* iOSの角丸をリセット */
  border-radius: 0;
  /* box-size */
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 文字の大きさ iOSでズームさせないために16px以上を指定 */
  font-size: 2.4rem;
  /* 文字色を親から継承 */
  color: inherit;
  border: none;
  border-radius: 0;
  outline: none;
}

/* リンク下線を非表示位にする箇所 */
.main-nav li > a,
#footer-nav a {
  text-decoration: none !important;
}

.submit-btn {
  display: inline-block;
  font-size: 14px;
  text-align: center;
  cursor: pointer;
  padding: 0.55em 1.5em;
  background: var(--key);
  color: #ffffff;
  line-height: 1em;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  border: 1px solid var(--key);
}
.submit-btn:hover, .submit-btn:active {
  color: var(--key);
  background: #fff;
}

/* ページローディング */
#loader-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #fff;
  z-index: 5000;
}

.loader,
.loader::after {
  border-radius: 50%;
  width: 10em;
  height: 10em;
}

.loader {
  margin: 60px auto;
  font-size: 10px;
  position: absolute;
  top: calc(50% - 120px);
  left: calc(50% - 50px);
  text-indent: -9999em;
  border-top: 1.1em solid rgba(146, 146, 146, 0.2);
  border-right: 1.1em solid rgba(146, 146, 146, 0.2);
  border-bottom: 1.1em solid rgba(146, 146, 146, 0.2);
  border-left: 1.1em solid #929292;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-animation: load8 1.1s infinite linear;
  animation: load8 1.1s infinite linear;
}

@-webkit-keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes load8 {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
#frloader {
  background-color: #fff;
  width: 100vw;
  height: 100vh;
  display: grid;
  place-content: center;
  position: absolute;
  z-index: 500;
  -webkit-transition: opacity 1s ease;
  transition: opacity 1s ease;
}
#frloader .floader,
#frloader .floader:before,
#frloader .floader:after {
  background: #c9c9c9;
  -webkit-animation: load1 1s infinite ease-in-out;
  animation: load1 1s infinite ease-in-out;
  width: 1em;
  height: 4em;
}
#frloader .floader {
  color: #c9c9c9;
  text-indent: -9999em;
  margin: 88px auto;
  position: relative;
  font-size: 11px;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}
#frloader .floader:before,
#frloader .floader:after {
  position: absolute;
  top: 0;
  content: "";
}
#frloader .floader:before {
  left: -1.5em;
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}
#frloader .floader:after {
  left: 1.5em;
}

@-webkit-keyframes load1 {
  0%, 80%, 100% {
    -webkit-box-shadow: 0 0;
            box-shadow: 0 0;
    height: 4em;
  }
  40% {
    -webkit-box-shadow: 0 -2em;
            box-shadow: 0 -2em;
    height: 5em;
  }
}
@keyframes load1 {
  0%, 80%, 100% {
    -webkit-box-shadow: 0 0;
            box-shadow: 0 0;
    height: 4em;
  }
  40% {
    -webkit-box-shadow: 0 -2em;
            box-shadow: 0 -2em;
    height: 5em;
  }
}
/* =====================

header

===================== */
.mobile-logo {
  display: none;
}

/* ========================

header
トップページ

======================== */
#index {
  width: 100%;
  position: relative;
  top: 0;
  left: 0;
  margin: 0;
  padding: 0;
}
#index header {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  position: relative;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
}
#index header .h1-kc {
  width: 100%;
  position: absolute;
  top: calc(50% - 3rem);
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 2;
  color: #fff;
  text-align: center;
  margin: 0;
}
#index header .h1-kc .index-logo {
  display: block;
  width: clamp(16rem, 12rem + 12.5vw, 21.6rem);
  margin-inline: auto;
  margin-bottom: clamp(0.1rem, -0.9rem + 3.125vw, 1.5rem);
}
#index header .h1-kc .sub-catch {
  font-size: clamp(2.7rem, 0.5571428571rem + 6.6964285714vw, 5.7rem);
  -webkit-margin-after: 1rem;
          margin-block-end: 1rem;
  padding-left: 2rem;
  padding-right: 2rem;
}
#index header .h1-kc .sub-catch span.part {
  display: inline-block;
  margin: 0;
  margin-block: 0;
  white-space: nowrap;
  letter-spacing: -0.015em;
}
#index header .h1-kc .main-catch {
  font-size: clamp(4.6rem, 1.7428571429rem + 8.9285714286vw, 8.6rem);
  line-height: 0;
}
#index header .h1-kc .main-catch span.part {
  display: inline-block;
  margin-block: 0;
  white-space: nowrap;
  list-style: 1;
  margin: 0;
  margin-block: 0;
  padding: 0;
  letter-spacing: -0.015em;
}
#index header .h1-kc .main-catch span.part:first-of-type {
  margin-right: -0.3em;
}
#index header .swiper {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  min-height: 100%;
  overflow: hidden;
}
#index header .swiper::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.4);
  z-index: 2;
}
#index header .swiper-wrapper {
  position: relative;
  width: 100%;
  height: auto;
}
#index header .swiper-slide {
  position: relative;
  width: 100%;
  height: 100%;
}
#index header .swiper-slide .swiper-slide__item {
  width: 100%;
  min-height: 100%;
}
#index header .swiper-slide .swiper-slide__item img {
  width: 100%;
  height: 100vh;
  height: 100dvh;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 0;
}
@media screen and (orientation: landscape) {
  #index header {
    width: 100%;
    height: 1000px;
  }
  #index header .h1-kc {
    top: 50%;
    -webkit-transform: translate(-50%, -60%);
            transform: translate(-50%, -60%);
  }
  #index header .swiper {
    width: 100%;
    height: 1000px;
  }
  #index header .swiper .swiper-slide .swiper-slide__item img {
    width: 100%;
    height: 1000px;
  }
}
@-webkit-keyframes zoomUp {
  0% {
    -webkit-transform: scale(1.15);
            transform: scale(1.15);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes zoomUp {
  0% {
    -webkit-transform: scale(1.15);
            transform: scale(1.15);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
#index header .swiper-slide-active .swiper-slide__item,
#index header .swiper-slide-duplicate-active .swiper-slide__item,
#index header .swiper-slide-prev .swiper-slide__item {
  -webkit-animation: zoomUp 8s linear 0s normal both;
          animation: zoomUp 8s linear 0s normal both;
}
#index * a {
  text-decoration: none;
}
#index .yoyaku-tab {
  position: fixed;
  top: 50%;
  right: 0;
  z-index: 40;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  padding: 3rem 2rem 7rem;
  font-size: clamp(2.4rem, 1.8285714286rem + 1.7857142857vw, 3.2rem);
  white-space: nowrap;
  color: #fff;
  text-decoration: none;
  background-color: #da6c5b;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
  letter-spacing: -0.005em;
  border-top-left-radius: 0.6rem;
  border-bottom-left-radius: 0.6rem;
}
#index .yoyaku-tab::before {
  content: "";
  position: absolute;
  bottom: 3rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 3.2rem;
  height: 3.2rem;
  aspect-ratio: 1/1;
  border-radius: 1.6rem;
  background-color: #fff;
}
#index .yoyaku-tab::after {
  content: "";
  position: absolute;
  bottom: 4.2rem;
  left: calc(50% - 0.1rem);
  width: 0.6rem;
  height: 0.6rem;
  border-right: 0.2rem solid #da6c5b;
  border-bottom: 0.2rem solid #da6c5b;
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-transform: translateX(-50%) rotate(-45deg);
          transform: translateX(-50%) rotate(-45deg);
}
@media screen and (max-width: 1560px) {
  #index .yoyaku-tab {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    right: initial;
    top: initial;
    left: 50%;
    bottom: 3rem;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    padding: 1rem 7rem 1.5rem 2rem;
    border-top-right-radius: 0.6rem;
    border-bottom-right-radius: 0.6rem;
  }
  #index .yoyaku-tab span {
    display: none;
  }
  #index .yoyaku-tab::before {
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    bottom: initial;
    left: initial;
    top: 50%;
    right: 2.5rem;
  }
  #index .yoyaku-tab::after {
    left: initial;
    bottom: initial;
    -webkit-transform-origin: center;
            transform-origin: center;
    -webkit-transform: translate(0, -50%) rotate(-45deg);
            transform: translate(0, -50%) rotate(-45deg);
    top: 50%;
    right: 3.8rem;
  }
}

/* =====================

下層ヘッダー

===================== */
#about .yoyaku-tab,
#contact .yoyaku-tab,
#privacy-policy .yoyaku-tab,
#column .yoyaku-tab,
#reservation .yoyaku-tab {
  position: fixed;
  top: 50%;
  right: 0;
  z-index: 40;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  padding: 3rem 2rem 7rem;
  font-size: clamp(2.4rem, 1.8285714286rem + 1.7857142857vw, 3.2rem);
  white-space: nowrap;
  color: #fff;
  text-decoration: none;
  background-color: #da6c5b;
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
  letter-spacing: -0.005em;
  border-top-left-radius: 0.6rem;
  border-bottom-left-radius: 0.6rem;
}
#about .yoyaku-tab::before,
#contact .yoyaku-tab::before,
#privacy-policy .yoyaku-tab::before,
#column .yoyaku-tab::before,
#reservation .yoyaku-tab::before {
  content: "";
  position: absolute;
  bottom: 3rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 3.2rem;
  height: 3.2rem;
  aspect-ratio: 1/1;
  border-radius: 1.6rem;
  background-color: #fff;
}
#about .yoyaku-tab::after,
#contact .yoyaku-tab::after,
#privacy-policy .yoyaku-tab::after,
#column .yoyaku-tab::after,
#reservation .yoyaku-tab::after {
  content: "";
  position: absolute;
  bottom: 4.2rem;
  left: calc(50% - 0.1rem);
  width: 0.6rem;
  height: 0.6rem;
  border-right: 0.2rem solid #da6c5b;
  border-bottom: 0.2rem solid #da6c5b;
  -webkit-transform-origin: center;
          transform-origin: center;
  -webkit-transform: translateX(-50%) rotate(-45deg);
          transform: translateX(-50%) rotate(-45deg);
}
@media screen and (max-width: 1200px) {
  #about .yoyaku-tab,
  #contact .yoyaku-tab,
  #privacy-policy .yoyaku-tab,
  #column .yoyaku-tab,
  #reservation .yoyaku-tab {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
    position: fixed;
    right: initial;
    top: initial;
    left: 50%;
    bottom: 3rem;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    padding: 1rem 7rem 1.5rem 2rem;
    border-top-right-radius: 0.6rem;
    border-bottom-right-radius: 0.6rem;
  }
  #about .yoyaku-tab span,
  #contact .yoyaku-tab span,
  #privacy-policy .yoyaku-tab span,
  #column .yoyaku-tab span,
  #reservation .yoyaku-tab span {
    display: none;
  }
  #about .yoyaku-tab::before,
  #contact .yoyaku-tab::before,
  #privacy-policy .yoyaku-tab::before,
  #column .yoyaku-tab::before,
  #reservation .yoyaku-tab::before {
    -webkit-transform: translate(0, -50%);
            transform: translate(0, -50%);
    bottom: initial;
    left: initial;
    top: 50%;
    right: 2.5rem;
  }
  #about .yoyaku-tab::after,
  #contact .yoyaku-tab::after,
  #privacy-policy .yoyaku-tab::after,
  #column .yoyaku-tab::after,
  #reservation .yoyaku-tab::after {
    left: initial;
    bottom: initial;
    -webkit-transform-origin: center;
            transform-origin: center;
    -webkit-transform: translate(0, -50%) rotate(-45deg);
            transform: translate(0, -50%) rotate(-45deg);
    top: 50%;
    right: 3.8rem;
  }
}
#about main header,
#contact main header,
#privacy-policy main header,
#column main header,
#reservation main header {
  width: 100%;
  position: relative;
  top: 0;
  left: 0;
  margin: 0 0 clamp(3rem, 0.1428571429rem + 8.9285714286vw, 7rem);
  padding: 0;
}
#about main header .page-header_container,
#contact main header .page-header_container,
#privacy-policy main header .page-header_container,
#column main header .page-header_container,
#reservation main header .page-header_container {
  width: 100%;
  min-height: 25rem;
  overflow: hidden;
  position: relative;
  padding: 0;
  display: grid;
  place-items: center;
  background-size: cover;
}
@media screen and (min-width: 769px) {
  #about main header .page-header_container,
  #contact main header .page-header_container,
  #privacy-policy main header .page-header_container,
  #column main header .page-header_container,
  #reservation main header .page-header_container {
    min-height: 32rem;
  }
}
#about main header .page-header_container .h1-p_title,
#contact main header .page-header_container .h1-p_title,
#privacy-policy main header .page-header_container .h1-p_title,
#column main header .page-header_container .h1-p_title,
#reservation main header .page-header_container .h1-p_title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  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;
  gap: 0 3rem;
  margin-inline: auto;
  margin-block: auto;
  position: relative;
  z-index: 3;
  -webkit-transform: translateY(2rem);
          transform: translateY(2rem);
}
@media screen and (max-width: 768px) {
  #about main header .page-header_container .h1-p_title,
  #contact main header .page-header_container .h1-p_title,
  #privacy-policy main header .page-header_container .h1-p_title,
  #column main header .page-header_container .h1-p_title,
  #reservation main header .page-header_container .h1-p_title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0.5rem;
    margin-inline: 1.5rem;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
#about main header .page-header_container .h1-p_title .page-logo,
#contact main header .page-header_container .h1-p_title .page-logo,
#privacy-policy main header .page-header_container .h1-p_title .page-logo,
#column main header .page-header_container .h1-p_title .page-logo,
#reservation main header .page-header_container .h1-p_title .page-logo {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  aspect-ratio: 167/162;
  width: clamp(10rem, 9.2rem + 2.5vw, 14rem);
  height: auto;
}
#about main header .page-header_container .h1-p_title .page-logo img,
#contact main header .page-header_container .h1-p_title .page-logo img,
#privacy-policy main header .page-header_container .h1-p_title .page-logo img,
#column main header .page-header_container .h1-p_title .page-logo img,
#reservation main header .page-header_container .h1-p_title .page-logo img {
  width: 100%;
  height: auto;
}
#about main header .page-header_container .h1-p_title .page-title,
#contact main header .page-header_container .h1-p_title .page-title,
#privacy-policy main header .page-header_container .h1-p_title .page-title,
#column main header .page-header_container .h1-p_title .page-title,
#reservation main header .page-header_container .h1-p_title .page-title {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  mix-blend-mode: difference;
  color: #fff;
  font-weight: 500;
  margin-inline: 0;
  line-height: 1.1;
  text-align: center;
}
#about main header .page-header_container .h1-p_title .page-title *,
#contact main header .page-header_container .h1-p_title .page-title *,
#privacy-policy main header .page-header_container .h1-p_title .page-title *,
#column main header .page-header_container .h1-p_title .page-title *,
#reservation main header .page-header_container .h1-p_title .page-title * {
  font-size: clamp(3.7rem, 3.3rem + 1.25vw, 5.7rem);
}
#about main header .page-header_container .h1-p_title .page-title span.title-cut,
#contact main header .page-header_container .h1-p_title .page-title span.title-cut,
#privacy-policy main header .page-header_container .h1-p_title .page-title span.title-cut,
#column main header .page-header_container .h1-p_title .page-title span.title-cut,
#reservation main header .page-header_container .h1-p_title .page-title span.title-cut {
  display: inline-block;
  white-space: nowrap;
}
#about main header .page-header_container::before,
#contact main header .page-header_container::before,
#privacy-policy main header .page-header_container::before,
#column main header .page-header_container::before,
#reservation main header .page-header_container::before {
  content: "";
  position: absolute;
  backdrop-filter: blur(4px);
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
}
#about main header .page-header_container::after,
#contact main header .page-header_container::after,
#privacy-policy main header .page-header_container::after,
#column main header .page-header_container::after,
#reservation main header .page-header_container::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(43, 76, 91, 0.5);
  mix-blend-mode: hard-light;
  z-index: 2;
}
@media screen and (max-width: 1200px) {
  #about main header .yoyaku-tab,
  #contact main header .yoyaku-tab,
  #privacy-policy main header .yoyaku-tab,
  #column main header .yoyaku-tab,
  #reservation main header .yoyaku-tab {
    position: fixed;
  }
}
@media (orientation: landscape) and (max-width: 1280px) {
  #about main header .yoyaku-tab,
  #contact main header .yoyaku-tab,
  #privacy-policy main header .yoyaku-tab,
  #column main header .yoyaku-tab,
  #reservation main header .yoyaku-tab {
    position: fixed;
  }
}

#about .page-header_container {
  background: url(../img/header-about-bg_pc.jpg) center center no-repeat;
}

#privacy-policy .page-header_container,
#column .page-header_container {
  background: url(../img/header-privacy-policy-bg_pc.jpg) center center no-repeat;
}

#contact .page-header_container {
  background: url(../img/header-contact-bg_pc.jpg) center center no-repeat;
}

@media screen and (max-width: 768px) {
  #about .page-header_container {
    background: url(../img/header-about-bg_sp.jpg) center center no-repeat;
  }
  #privacy-policy .page-header_container {
    background: url(../img/header-privacy-policy-bg_sp.jpg) center center no-repeat;
  }
  #contact .page-header_container {
    background: url(../img/header-contact-bg_sp.jpg) center center no-repeat;
  }
}
/* =====================

グローバルナビ

===================== */
.no-scroll {
  /* when modal active */
  -ms-touch-action: none;
      touch-action: none;
  -webkit-overflow-scrolling: none;
  overflow: hidden;
  /* Other browsers */
  -ms-scroll-chaining: none;
      overscroll-behavior: contain;
}

nav#mainnav {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  padding: 3rem 1.5rem 1rem;
}
nav#mainnav .h1-mobile-logo {
  display: none;
  aspect-ratio: 216/209;
  width: 12rem;
  height: auto;
}
nav#mainnav .h1-mobile-logo a {
  display: block;
}
nav#mainnav .h1-mobile-logo a img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
nav#mainnav .main-nav {
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(3rem, 1rem + 2.6041666667vw, 6rem);
  list-style: none;
  letter-spacing: 0;
  padding: 0;
  margin: 0;
}
nav#mainnav .main-nav li a {
  font-size: clamp(1.6rem, -0.1777777778rem + 2.3148148148vw, 2.6rem);
  font-weight: 500;
  color: #fff;
  position: relative;
}
nav#mainnav .main-nav li a * {
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
nav#mainnav .main-nav li a:hover {
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
nav#mainnav .main-nav li a.current::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.5rem;
  width: 100%;
  height: 0.2rem;
  background-color: #fff;
}

@media screen and (max-width: 768px) {
  nav#mainnav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    position: fixed;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    width: 100%;
    min-height: 100%;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 10;
    background-color: #4a6c7b;
    -webkit-transform: none;
            transform: none;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
    overflow: auto;
  }
  nav#mainnav .h1-mobile-logo {
    display: block;
  }
  nav#mainnav .main-nav {
    position: absolute;
    -webkit-margin-before: 7rem;
            margin-block-start: 7rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    gap: 2rem;
    height: 100rem;
  }
  nav#mainnav .main-nav li {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  nav#mainnav .main-nav li a {
    display: block;
    width: 100%;
    font-size: clamp(1.8rem, 1.5142857143rem + 0.8928571429vw, 2.2rem);
    text-align: center;
    font-weight: 500;
    color: #fff;
  }
  nav#mainnav .main-nav li a:hover {
    color: #fff;
  }
  nav#mainnav .main-nav li a.current::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: -0.3rem;
    width: 100%;
    height: 0.2rem;
    background-color: #fff;
  }
  nav#mainnav .main-nav li.current-menu-item a {
    color: white;
  }
  nav#mainnav.open {
    opacity: 1;
    visibility: visible;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
  }
}
.mobile-btn,
.tel-btn {
  display: none;
}

@media screen and (max-width: 768px) {
  .mobile-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

@media screen and (max-width: 768px) {
  .tel-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
}

.mobile-btn {
  position: fixed;
  top: 0;
  right: 0;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 8rem;
  height: 8rem;
  background-color: var(--key);
  border-bottom-left-radius: 0.6rem;
  cursor: pointer;
  z-index: 50;
}
.mobile-btn::after {
  content: "MENU";
  position: absolute;
  top: 5.5rem;
  left: 50%;
  -webkit-transform: translate(-50%, -0.7rem);
          transform: translate(-50%, -0.7rem);
  font-family: var(--ffg);
  font-weight: 500;
  font-size: 1.2rem;
  color: #fff;
}
.mobile-btn .mobile-btn_burger {
  position: absolute;
  width: 3.4rem;
  height: 0.3rem;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -1rem);
          transform: translate(-50%, -1rem);
  background-color: #fff;
}
.mobile-btn .mobile-btn_burger::before, .mobile-btn .mobile-btn_burger::after {
  content: "";
  position: absolute;
  width: 3.4rem;
  height: 0.3rem;
  background-color: #fff;
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
.mobile-btn .mobile-btn_burger::before {
  -webkit-transform: translateY(-1rem);
          transform: translateY(-1rem);
}
.mobile-btn .mobile-btn_burger::after {
  -webkit-transform: translateY(1rem);
          transform: translateY(1rem);
}
.mobile-btn.on .mobile-btn_burger {
  background-color: transparent;
}
.mobile-btn.on .mobile-btn_burger::before {
  -webkit-transform-origin: center center;
  transform-origin: center center;
  -webkit-transform: rotate(-45deg) translate(0, 0);
  transform: rotate(-45deg) translate(0, 0);
}
.mobile-btn.on .mobile-btn_burger::after {
  -webkit-transform-origin: center;
  transform-origin: center;
  -webkit-transform: rotate(45deg) translate(0, 0);
  transform: rotate(45deg) translate(0, 0);
}

.tel-btn {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 5rem;
  height: 5rem;
  background-color: #fff;
  position: fixed;
  right: 7rem;
  top: 0;
  z-index: 50;
}
.tel-btn a {
  display: grid;
  place-items: center;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.tel-btn a img {
  margin-bottom: 0;
  width: 1.8rem;
  height: auto;
}
@media screen and (max-width: 768px) {
  .tel-btn {
    width: 5rem;
    height: 5rem;
    right: 5rem;
  }
  .tel-btn a img {
    width: 1.4rem;
    height: auto;
  }
}

/* =================================================

トップページ

================================================= */
#home #home-top {
  width: 100%;
  padding: 10rem 3rem 5rem;
  margin-bottom: 5rem;
  background: url(../img/bg_logo.png) center top no-repeat;
  background-size: auto 100%;
  text-align: center;
}
#home #service {
  width: 100%;
  margin: 0 0 clamp(4rem, -0.2857142857rem + 13.3928571429vw, 10rem);
  padding: 0;
}
#home #service .wrapper {
  width: min(calc(100% - clamp(3rem, -31.2260869565rem + 44.5652173913vw, 27.6rem)), 132rem);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 3rem;
}
#home #service .wrapper .h3_service {
  display: grid;
  place-items: center;
  font-size: clamp(2.8rem, 2.2285714286rem + 1.7857142857vw, 3.6rem);
  color: #fff;
  letter-spacing: 0;
  aspect-ratio: 1/1;
  width: clamp(26rem, 21rem + 15.625vw, 33rem);
  height: clamp(26rem, 21rem + 15.625vw, 33rem);
  border-radius: 50%;
  background-color: var(--key);
  text-align: center;
  line-height: 1.2;
}
#home #service .wrapper .service_content {
  width: calc(100% - (clamp(26rem, 21rem + 15.625vw, 33rem) + 3rem));
  letter-spacing: 0;
}
#home #service .service_wrapper {
  width: 100%;
  margin: 0;
  padding: 4rem 0;
}
#home #service .service_wrapper:first-of-type {
  background: url(../img/service01_bg_pc.jpg) 0 -19.2708333333vw no-repeat;
  background-size: cover;
}
#home #service .service_wrapper:nth-of-type(2) {
  background: url(../img/service02_bg_pc.jpg) 0 -7.03125vw no-repeat;
  background-size: cover;
}
#home #service .service_wrapper:nth-of-type(3) {
  background: url(../img/service03_bg_pc.jpg) 0 0 no-repeat;
  background-size: cover;
}
@media screen and (max-width: 992px) {
  #home #service .service_wrapper .wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  #home #service .service_wrapper .wrapper .service_content {
    width: min(calc(100% - 3rem), 76.8rem);
    margin-inline: auto;
  }
  #home #service .service_wrapper:first-of-type {
    background: url(../img/service01_bg_sp.jpg) 0 0 no-repeat;
    background-size: cover;
  }
  #home #service .service_wrapper:nth-of-type(2) {
    background: url(../img/service02_bg_sp.jpg) 0 0 no-repeat;
    background-size: cover;
  }
  #home #service .service_wrapper:nth-of-type(2) .wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  #home #service .service_wrapper:nth-of-type(3) {
    background: url(../img/service03_bg_sp.jpg) 0 0 no-repeat;
    background-size: cover;
  }
}
#home #service-flow .sf_lists {
  width: min(calc(100% - clamp(3rem, -31.2260869565rem + 44.5652173913vw, 27.6rem)), 132rem);
  margin-inline: auto;
  padding: 0;
  list-style: none;
  counter-reset: number 0;
  margin-bottom: 12rem;
}
#home #service-flow .sf_lists .sf_line_wrapper {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.6rem;
}
#home #service-flow .sf_lists .sf_line_wrapper .sf_title {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 29rem;
          flex: 0 0 29rem;
  white-space: nowrap;
  text-align: center;
  position: relative;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
#home #service-flow .sf_lists .sf_line_wrapper .sf_content {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 calc(100% - 31.6rem);
          flex: 1 1 calc(100% - 31.6rem);
  padding: 1.5em;
  background-color: #fff;
  border: 0.1rem solid var(--red);
  border-radius: 3rem;
  text-justify: inter-ideograph;
}
#home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) {
  margin-bottom: 11rem;
}
#home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) .sf_title {
  height: 23.8rem;
  background: url(../img/title_bg.svg) center center no-repeat;
  background-size: 23.7rem 23.8rem;
}
#home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) .sf_title::after {
  content: "";
  position: absolute;
  bottom: -8.6rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 0.2rem;
  height: 6rem;
  background-color: var(--red);
}
#home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) .sf_title span {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 8.2rem;
  min-width: 17.4rem;
  font-size: 3.4rem;
  color: var(--red);
  background-color: #fff;
  border-top: 0.1rem solid var(--red);
  border-bottom: 0.1rem solid var(--red);
  padding: 0.01em 0.2em 0.1em;
}
#home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) .sf_title span::before {
  counter-increment: number 1;
  content: counter(number) " ";
  font-family: "Allura", cursive;
  font-weight: 400;
  font-size: 10rem;
  position: absolute;
  color: #fff;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 2.5rem;
}
#home #service-flow .sf_lists .sf_line_wrapper:last-child .sf_title {
  height: 24rem;
}
#home #service-flow .sf_lists .sf_line_wrapper:last-child .sf_title span {
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, 2rem);
          transform: translate(-50%, 2rem);
  font-size: 4.2rem;
  color: #fff;
}
#home #service-flow .sf_lists .sf_line_wrapper:last-child .sf_title span::before {
  counter-increment: number 1;
  content: counter(number) " ";
  font-family: "Allura", cursive;
  font-weight: 400;
  font-size: 10rem;
  position: absolute;
  color: #fff;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 2.5rem;
}
#home #service-flow .sf_lists .sf_line_wrapper:last-child .sf_title::after {
  content: "";
  width: 24rem;
  height: 24rem;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: var(--red);
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: -1;
}
@media screen and (max-width: 992px) {
  #home #service-flow .sf_lists .sf_line_wrapper {
    -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;
    gap: 0;
  }
  #home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) {
    position: relative;
  }
  #home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) .sf_title {
    width: 29rem;
  }
  #home #service-flow .sf_lists .sf_line_wrapper:not(:last-child) .sf_title::after {
    display: none;
  }
  #home #service-flow .sf_lists .sf_line_wrapper:not(:last-child)::after {
    content: "";
    position: absolute;
    bottom: -11rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 0.2rem;
    height: 8.4rem;
    background-color: var(--red);
  }
  #home #service-flow .sf_lists .sf_line_wrapper .sf_content {
    width: min(100%, 76.8rem);
    margin-inline: auto;
    padding: 0.75em 1em;
    border-radius: clamp(1rem, -0.4285714286rem + 4.4642857143vw, 3rem);
  }
}
#home .wdd-st_wrapper {
  width: min(calc(100% - 3rem), 132rem);
  margin-inline: auto;
  background: url(../img/wdd-st_img.jpg) center top no-repeat;
  background-size: cover;
  border-radius: 1rem;
  border: 1rem solid #fff;
  padding: clamp(1.5rem, -0.2857142857rem + 5.5803571429vw, 4rem);
  margin-block: clamp(3rem, 0.8571428571rem + 6.6964285714vw, 6rem);
}
@media screen and (max-width: 768px) {
  #home .wdd-st_wrapper {
    background: none;
    background-color: #fff;
    border: 0.5rem solid var(--red_l);
  }
}
#home .wdd-st_wrapper .h3-wdd-st {
  font-size: clamp(2.8rem, 1.5142857143rem + 4.0178571429vw, 4.6rem);
  color: var(--red);
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0;
  padding-left: clamp(2.8rem, 1.5142857143rem + 4.0178571429vw, 4.6rem);
  position: relative;
  margin-bottom: clamp(2.4rem, 0.9714285714rem + 4.4642857143vw, 4.4rem);
}
#home .wdd-st_wrapper .h3-wdd-st::before {
  content: "";
  position: absolute;
  background-color: var(--red);
  aspect-ratio: 11/8;
  width: clamp(2.6rem, 1.3142857143rem + 4.0178571429vw, 4.4rem);
  -webkit-mask: url("../img/icon-diamond.svg");
          mask: url("../img/icon-diamond.svg");
  -webkit-mask-size: cover;
          mask-size: cover;
  left: 0;
  top: 0.4em;
}
#home .wdd-st_wrapper .h3-wdd-st > span {
  display: inline-block;
}
#home .wdd-st_wrapper .wdd-st_comp {
  border-left: 0.6rem solid var(--red);
  padding-top: 0;
  padding-left: 1rem;
  padding-bottom: 0;
  margin-bottom: 3rem;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#home .wdd-st_wrapper .wdd-st_comp:not(:last-child) {
  margin-bottom: 3rem;
}
#home .wdd-st_wrapper .wdd-st_comp .h4-wdd-st {
  font-size: clamp(2.4rem, 1.9714285714rem + 1.3392857143vw, 3rem);
  color: var(--red);
  font-weight: 900;
  padding-bottom: 0.5rem;
  border-bottom: 0.2rem solid var(--red_l);
  margin-bottom: 1rem;
  line-height: 1.3;
}
#home .wdd-st_wrapper .wdd-st_comp p {
  font-size: clamp(2rem, 1.7142857143rem + 0.8928571429vw, 2.4rem);
  margin-bottom: 0;
  line-height: 1.3;
  letter-spacing: 0;
}
#home .member-st_wrapper {
  width: min(calc(100% - 3rem), 132rem);
  margin-inline: auto;
  border-radius: 1rem;
  border: 1rem solid #fff;
  background-color: #fff;
  padding: 0 0 0 clamp(1.5rem, -0.2857142857rem + 5.5803571429vw, 4rem);
  margin-block: clamp(3rem, 0.8571428571rem + 6.6964285714vw, 6rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem clamp(3.5rem, 2.156rem + 4.2vw, 7.7rem);
}
@media screen and (max-width: 768px) {
  #home .member-st_wrapper {
    background: none;
    background-color: #fff;
    border: 0.5rem solid var(--orange_l);
  }
}
#home .member-st_wrapper .description {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 63.9rem;
          flex: 1 1 63.9rem;
  padding-top: 2.6rem;
  padding-bottom: 2.4rem;
}
#home .member-st_wrapper .description .h3-member-st {
  color: var(--orange);
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0;
  margin-bottom: clamp(1.2rem, 0.2rem + 3.125vw, 2.6rem);
  border-left: 1rem solid var(--orange);
  padding-left: 1.8rem;
}
#home .member-st_wrapper .description .h3-member-st span {
  font-size: clamp(2.8rem, 1.5142857143rem + 4.0178571429vw, 4.6rem);
  display: block;
}
#home .member-st_wrapper .description .h3-member-st small {
  display: block;
  font-size: clamp(2rem, 1.4285714286rem + 1.7857142857vw, 2.8rem);
  padding-left: 1em;
  text-indent: -1em;
  letter-spacing: 0;
}
#home .member-st_wrapper .description p {
  font-size: clamp(2rem, 1.8571428571rem + 0.4464285714vw, 2.2rem);
  line-height: 1.5;
  margin-bottom: clamp(1.2rem, 0.2rem + 3.125vw, 2.6rem);
  letter-spacing: 0;
}
#home .member-st_wrapper .description .comp_lists {
  list-style: none;
  padding: 0;
  margin: 0;
}
#home .member-st_wrapper .description .comp_lists li {
  font-size: clamp(2.4rem, 1.9714285714rem + 1.3392857143vw, 3rem);
  color: var(--red);
  font-weight: 900;
  border-bottom: 0.2rem solid var(--red);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  gap: 0 0.75em;
}
#home .member-st_wrapper .description .comp_lists li small {
  font-size: clamp(1.8rem, 1.6571428571rem + 0.4464285714vw, 2rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
#home .member-st_wrapper .description .comp_lists li small::before {
  content: "";
  display: block;
  width: 0.2rem;
  height: clamp(2rem, 1.5rem + 1.5625vw, 2.7rem);
  background-color: var(--red);
  margin-right: 0.75em;
}
#home .member-st_wrapper .description .comp_lists li:not(:last-child) {
  margin-bottom: 1.2rem;
}
#home .member-st_wrapper .description .comp_lists li:last-child {
  display: block;
  line-height: 1.3;
  padding: 0.2em 0 0.2em;
}
#home .member-st_wrapper .description .comp_lists li:last-child span {
  display: inline-block;
}
#home .member-st_wrapper .studio-img {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 62.6rem;
          flex: 1 1 62.6rem;
}
#home .member-st_wrapper .studio-img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1200px) {
  #home .member-st_wrapper {
    padding: 1.5rem;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap;
  }
}
#home #price-plan {
  padding-bottom: 22rem;
}
#home #price-plan .plan-ep {
  margin-bottom: clamp(3rem, 1.5714285714rem + 4.4642857143vw, 5rem);
}
#home #price-plan .plan-ep p {
  border: 0.1rem solid #ccc;
  text-align: left;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  letter-spacing: 0.02em;
  background-color: #fff;
  border-radius: 1.5rem;
  padding: 0.75em 1.75em;
  font-weight: bold;
  line-height: 1.5;
}
#home #price-plan .plan-ep p .red {
  font-size: clamp(2.2rem, 1.7714285714rem + 1.3392857143vw, 2.8rem);
}
#home #price-plan ul.plan_lists {
  list-style: none;
  padding: 0;
  width: min(calc(100% - 3rem), 132rem);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2rem;
  margin-bottom: clamp(2rem, -1.5714285714rem + 5.9523809524vw, 3rem);
}
#home #price-plan ul.plan_lists li.plans {
  margin-top: 6rem;
  width: calc((100% - 4rem) / 3);
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  border: 0.1rem solid;
  padding: 2.5em 1.5rem;
  border-radius: 2rem;
  background-color: #fff;
  text-align: center;
  position: relative;
}
#home #price-plan ul.plan_lists li.plans .h3_plan {
  width: calc(100% - 3rem);
  margin: 0;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  border-radius: 1.2rem;
  padding: 0.1em 1.5rem 0.3em;
  line-height: 1;
  color: #fff;
  letter-spacing: -0.01em !important;
}
#home #price-plan ul.plan_lists li.plans .h3_plan * {
  font-size: clamp(2.4rem, 1.4rem + 3.125vw, 3.8rem);
}
#home #price-plan ul.plan_lists li.plans .h3_plan span {
  display: inline-block;
  white-space: nowrap;
  margin: 0;
  margin-block: 0;
}
#home #price-plan ul.plan_lists li.plans ul.type_lists {
  list-style: none;
  width: 100%;
  margin: 0 auto 0.3em;
  padding: 0 0 0.8em;
}
#home #price-plan ul.plan_lists li.plans ul.type_lists > li {
  letter-spacing: -0.01em;
  font-size: 2.3rem;
  line-height: 1.35;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt"; /* 文字づめ */
  text-align: left;
  padding-left: 2.4rem;
  position: relative;
}
#home #price-plan ul.plan_lists li.plans ul.type_lists > li:not(:last-child) {
  margin-bottom: 0.35em;
}
#home #price-plan ul.plan_lists li.plans ul.type_lists > li::before {
  content: "";
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 1.2rem;
}
#home #price-plan ul.plan_lists li.plans .line-one {
  padding: 0 0 calc(0.8em + 0.8rem) !important;
}
#home #price-plan ul.plan_lists li.plans .fee {
  width: 100%;
  padding-bottom: 0.3em;
  border-bottom: 0.1rem solid;
}
#home #price-plan ul.plan_lists li.plans .fee:first-of-type {
  border-top: 0.1rem solid;
}
#home #price-plan ul.plan_lists li.plans .option {
  width: 100%;
  padding-bottom: -0.2em;
  border-bottom: 0.1rem solid;
}
#home #price-plan ul.plan_lists li.plans .etc {
  padding: 1.5em 1.5em 0;
  width: 100%;
  text-align: center;
  line-height: 1.35;
  letter-spacing: -0.02em;
}
#home #price-plan ul.plan_lists li.plans .etc div h5 {
  font-size: clamp(1.8rem, 1.3714285714rem + 1.3392857143vw, 2.4rem);
}
#home #price-plan ul.plan_lists li.plans .etc div:not(:last-of-type) {
  margin-block: 0 1em;
}
#home #price-plan ul.plan_lists li.plans .etc div p:not(:last-of-type) {
  margin-block: 0 0.5em;
}
#home #price-plan ul.plan_lists li.plans .h4-fee {
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 0.25em;
          margin-block-end: 0.25em;
  padding: 0.25em 0;
  font-size: 3.2rem;
  line-height: 1.1;
}
#home #price-plan ul.plan_lists li.plans .h4-fee span {
  display: inline-block;
  margin-bottom: 0;
}
#home #price-plan ul.plan_lists li.plans .price {
  font-size: 4.8rem;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  margin-top: -0.5em;
  line-height: 1.5;
}
#home #price-plan ul.plan_lists li.plans .price .tax {
  font-size: 3.2rem;
  font-weight: 500;
}
@media screen and (max-width: 500px) {
  #home #price-plan ul.plan_lists li.plans .price .tax {
    -webkit-margin-before: -0.2em;
            margin-block-start: -0.2em;
    display: block;
  }
}
#home #price-plan ul.plan_lists li.plans ul.option_lists {
  list-style: none;
  margin: 0;
  padding: 3rem clamp(1.5rem, 0.4285714286rem + 3.3482142857vw, 3rem) 0;
}
#home #price-plan ul.plan_lists li.plans ul.option_lists li {
  text-align: left;
  margin-bottom: 1em;
}
#home #price-plan ul.plan_lists li.plans ul.option_lists li .op_name {
  font-size: 2.4rem;
  font-weight: 700;
  margin-block: 0 0.25em;
  line-height: 1.2;
}
#home #price-plan ul.plan_lists li.plans ul.option_lists li .op_price {
  margin-bottom: 0;
  margin-block: 0;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.8rem;
  font-weight: 700;
  line-height: 1.2;
}
#home #price-plan ul.plan_lists li.plans ul.option_lists li .op_price span.op_tax {
  font-size: 2.4rem;
  font-weight: 500;
}
@media screen and (max-width: 1320px) {
  #home #price-plan ul.plan_lists li.plans ul.option_lists {
    padding: 3rem 0 0;
    margin-inline: auto;
    text-align: center;
  }
  #home #price-plan ul.plan_lists li.plans ul.option_lists li .op_name,
  #home #price-plan ul.plan_lists li.plans ul.option_lists li .op_price {
    text-align: center;
  }
}
#home #price-plan ul.plan_lists li.plans:first-child {
  border-color: var(--key_l);
}
#home #price-plan ul.plan_lists li.plans:first-child .h3_plan {
  background-color: var(--key);
}
#home #price-plan ul.plan_lists li.plans:first-child ul.type_lists {
  border-bottom-color: var(--key_l);
}
#home #price-plan ul.plan_lists li.plans:first-child ul.type_lists > li::before {
  background-color: var(--key);
}
#home #price-plan ul.plan_lists li.plans:first-child .fee,
#home #price-plan ul.plan_lists li.plans:first-child .option {
  border-bottom-color: var(--key_l);
}
#home #price-plan ul.plan_lists li.plans:first-child .fee:first-of-type {
  border-top-color: var(--key_l);
}
#home #price-plan ul.plan_lists li.plans:first-child::before {
  content: "";
  width: 100%;
  height: 6rem;
  background-color: var(--key_l);
  border-top-left-radius: 2rem;
  border-top-right-radius: 2rem;
  position: absolute;
  left: 0;
  top: -5rem;
  z-index: -1;
}
#home #price-plan ul.plan_lists li.plans:nth-child(2) {
  border-color: var(--orange_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(2) .h3_plan {
  background-color: var(--orange);
}
#home #price-plan ul.plan_lists li.plans:nth-child(2) ul.type_lists {
  border-bottom-color: var(--orange_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(2) ul.type_lists > li::before {
  background-color: var(--orange);
}
#home #price-plan ul.plan_lists li.plans:nth-child(2) .fee,
#home #price-plan ul.plan_lists li.plans:nth-child(2) .option {
  border-bottom-color: var(--orange_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(2) .fee:first-of-type {
  border-top-color: var(--orange_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(2)::before {
  content: "";
  width: 100%;
  height: 6rem;
  background-color: var(--orange_l);
  border-top-left-radius: 2rem;
  border-top-right-radius: 2rem;
  position: absolute;
  left: 0;
  top: -5rem;
  z-index: -1;
}
#home #price-plan ul.plan_lists li.plans:nth-child(3) {
  border-color: var(--red_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(3) .h3_plan {
  background-color: var(--red);
}
#home #price-plan ul.plan_lists li.plans:nth-child(3) ul.type_lists {
  border-bottom-color: var(--red_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(3) ul.type_lists > li::before {
  background-color: var(--red);
}
#home #price-plan ul.plan_lists li.plans:nth-child(3) .fee,
#home #price-plan ul.plan_lists li.plans:nth-child(3) .option {
  border-bottom-color: var(--red_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(3) .fee:first-of-type {
  border-top-color: var(--red_l);
}
#home #price-plan ul.plan_lists li.plans:nth-child(3)::before {
  content: "";
  width: 100%;
  height: 6rem;
  background-color: var(--red_l);
  border-top-left-radius: 2rem;
  border-top-right-radius: 2rem;
  position: absolute;
  left: 0;
  top: -5rem;
  z-index: -1;
}
@media screen and (max-width: 1320px) {
  #home #price-plan ul.plan_lists {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  #home #price-plan ul.plan_lists li.plans {
    width: min(calc(100% - 3rem), 76.8rem);
    margin-inline: auto;
  }
}
#home #price-plan #plan-options .container {
  margin-bottom: clamp(3rem, 2.2857142857rem + 2.2321428571vw, 4rem);
}
#home #price-plan #plan-options table.two-cols tr:nth-child(odd) {
  background-color: rgba(156, 195, 228, 0.3);
}
@media screen and (max-width: 575px) {
  #home #price-plan #plan-options table.two-cols tr:nth-child(odd) {
    background-color: transparent;
  }
}
#home #price-plan #plan-options table.two-cols th {
  background-color: transparent !important;
}
@media screen and (max-width: 575px) {
  #home #price-plan #plan-options table.two-cols th {
    text-align: center;
    background-color: rgba(156, 195, 228, 0.3) !important;
  }
}
#home #price-plan #plan-options table.two-cols td {
  font-weight: bold;
  text-align: center;
  background-color: transparent !important;
}
#home #price-plan #plan-options .plan--options {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  padding: 1.5em;
  border: 0.1rem solid var(--bcr);
  background-color: #fff;
  border-radius: 1.5rem;
}
#home #price-plan #plan-options .plan--options > h4 {
  padding: 0.5em;
  background-color: var(--key);
  color: #fff;
  margin-block: 0 3rem;
  border-radius: 0.8rem;
}
#home #price-plan #plan-options .plan--options .plan---options {
  line-height: 1.2;
}
#home #price-plan #plan-options .plan--options .plan---options:not(:last-of-type) {
  margin-block: 0 1.5em;
}
#home #price-plan #plan-options .plan--options .plan---options .course {
  text-align: center;
  font-size: clamp(1.8rem, 1.3714285714rem + 1.3392857143vw, 2.4rem);
  margin-block: 0 0.25em;
}
#home #price-plan #plan-options .plan--options .plan---options .price {
  display: block;
  text-align: center;
  font-weight: bold;
  padding: 0.5em;
  background-color: rgba(156, 195, 228, 0.3);
  margin-block: 0.5em;
}
#home #price-plan #plan-options .plan--options .plan---options p {
  line-height: 1.2;
}
#home #price-plan #plan-options .plan--options .plan---options p:not(:last-of-type) {
  margin-block: 0 0.5em;
}
#home #price-plan .cards {
  width: min(calc(100% - 3rem), 132rem);
  margin-inline: auto;
  margin-bottom: 2rem;
  text-align: center;
}
#home #price-plan .cards p {
  margin-bottom: 0;
  letter-spacing: 0;
  line-height: 1.3;
  margin-bottom: 0.75em;
}
#home #price-plan .cards p > span {
  display: inline-block;
}
@media screen and (max-width: 1320px) {
  #home #price-plan .cards {
    width: min(calc(100% - 3rem), 76.8rem);
  }
}
#home #plan-options h4 {
  text-align: center;
  border-bottom: none;
  margin-bottom: 0;
}
#home #plan-options table {
  margin-bottom: 1em;
}
#home #qualification .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0 3rem;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  margin-bottom: clamp(3rem, 1.5714285714rem + 4.4642857143vw, 5rem);
}
#home #qualification .inner_wrapper {
  -webkit-box-flex: 1;
      -ms-flex: 1 1 50rem;
          flex: 1 1 50rem;
}
#home #qualification h4 {
  margin-bottom: 0.8em;
}
#home #qualification ul li {
  line-height: 1.3;
  margin-bottom: 0.5em;
  -webkit-padding-end: 0;
          padding-inline-end: 0;
}
#home #spclaw * {
  line-height: 1.5;
}
#home #spclaw .spclaw {
  margin-bottom: 1em;
}
#home #spclaw .container {
  margin-bottom: clamp(3rem, 1.5714285714rem + 4.4642857143vw, 5rem);
}
#home #q-and-a {
  position: relative;
}
#home #q-and-a .illust_man,
#home #q-and-a .illust_woman {
  position: absolute;
  left: 50%;
  top: 0.75em;
}
#home #q-and-a .illust_man {
  -webkit-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-transform: translate(-27rem, -50%);
          transform: translate(-27rem, -50%);
  width: clamp(5rem, 1.1428571429rem + 12.0535714286vw, 10.4rem);
}
#home #q-and-a .illust_woman {
  -webkit-transform-origin: center bottom;
          transform-origin: center bottom;
  -webkit-transform: translate(17.2rem, -8.2rem);
          transform: translate(17.2rem, -8.2rem);
  width: clamp(4.1rem, 0.9571428571rem + 9.8214285714vw, 8.5rem);
}
@media screen and (max-width: 768px) {
  #home #q-and-a .illust_man {
    -webkit-transform: translate(-13vw, -106%);
            transform: translate(-13vw, -106%);
  }
  #home #q-and-a .illust_woman {
    -webkit-transform: translate(2.1vw, -106%);
            transform: translate(2.1vw, -106%);
  }
}
#home #q-and-a .accordion-container {
  width: min(calc(100% - 6rem), 132rem);
  margin-inline: auto;
  -webkit-margin-after: 10rem;
          margin-block-end: 10rem;
}
@media screen and (max-width: 1320px) {
  #home #q-and-a .accordion-container {
    width: min(calc(100% - 3rem), 99.2rem);
  }
}
#home #q-and-a .accordion-container .accordion-title {
  width: 100%;
  position: relative;
  margin: 0;
  padding: 0.625em 0.625em 0.625em 2em;
  background-color: var(--orange_l);
  font-size: 2.4rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--txt);
  cursor: pointer;
  -webkit-transition: background-color 0.1s linear;
  transition: background-color 0.1s linear;
}
#home #q-and-a .accordion-container .accordion-title:hover, #home #q-and-a .accordion-container .accordion-title:active {
  -webkit-transition: background-color 0.15s linear;
  transition: background-color 0.15s linear;
  background-color: var(--orange);
}
#home #q-and-a .accordion-title:not(:last-child) {
  border-bottom: 0.4rem solid var(--bg);
}
#home #q-and-a .accordion-title.open {
  background-color: var(--orange);
}
#home #q-and-a .accordion-container .accordion-title::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 25px;
  width: 15px;
  height: 2px;
  /*縦線に*/
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  background: var(--txt);
  -webkit-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}
#home #q-and-a .accordion-container .accordion-title::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 25px;
  /*横線*/
  width: 15px;
  height: 2px;
  background: var(--txt);
  -webkit-transition: all 0.2s ease-in-out;
  transition: all 0.2s ease-in-out;
}
#home #q-and-a .accordion-container .accordion-title.open::before {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}
#home #q-and-a .accordion-container .accordion-title.open::after {
  opacity: 0;
}
#home #q-and-a .accordion-content {
  padding: 0.75em 1.5em;
  background-color: #fff;
  border-bottom: 0.4rem solid var(--bg);
}
#home #q-and-a .accordion-content p {
  line-height: 1.75;
  letter-spacing: 0;
}
#home #news .news-lists {
  list-style: none;
  width: min(calc(100% - 3rem), 102.4rem);
  margin: 0 auto 10rem;
}
#home #news .news-lists li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 3rem;
}
@media screen and (max-width: 1054px) {
  #home #news .news-lists li {
    gap: 0.5em;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-margin-after: 2rem;
            margin-block-end: 2rem;
  }
}
#home #access iframe {
  vertical-align: bottom;
}

_::-webkit-full-page-media,
_:future,
:root #home #service-flow .sf_lists .sf_line_wrapper .sf_content .punctuation-adjust {
  display: initial !important;
  margin: initial !important;
}

/* =====================

Go Topボタン

===================== */
a.page-top {
  display: none;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  z-index: 5;
  padding: 0;
  width: 8rem;
  height: 8rem;
  position: fixed;
  bottom: 2rem;
  right: 1rem;
  background-color: #fff;
  border: 0.1rem solid var(--bcr);
  border-radius: 50%;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
a.page-top .go-arrow {
  width: 1.2rem;
  height: 1.2rem;
  border-top: 0.2rem solid var(--txt);
  border-right: 0.2rem solid var(--txt);
  -webkit-transform-origin: center center;
          transform-origin: center center;
  -webkit-transform: translateY(0.3rem) rotate(-45deg);
          transform: translateY(0.3rem) rotate(-45deg);
}
a.page-top:hover, a.page-top:active {
  border-color: var(--txt);
  background-color: #fff;
}
@media screen and (max-width: 834px) and (max-height: 1280px) {
  a.page-top {
    bottom: 12rem;
  }
}

/* =====================

footer

===================== */
#footer {
  width: 100%;
  border-top: 0.1rem solid var(--bcr);
  background: #fff;
  color: var(--txt);
}
#footer a {
  color: var(--txt);
  text-decoration: none;
}
#footer a:hover {
  text-decoration: underline !important;
}
#footer .footer_wrapper {
  width: min(calc(100% - 6rem), 132rem);
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 3rem;
  padding: 6rem 0;
}
#footer .logo_link {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 12rem;
  height: 11.6rem;
}
#footer .logo_link img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
#footer .f-info_wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 3rem;
}
#footer address {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-style: normal;
  margin-bottom: 0;
}
#footer address * {
  letter-spacing: 0;
}
#footer address p {
  margin: 0;
  line-height: 1.4;
}
#footer address p span {
  display: inline-block;
  white-space: nowrap;
}
#footer address .tel {
  letter-spacing: 0;
}
#footer address a {
  text-decoration: none;
}
#footer address .copyright {
  font-family: var(--ffg);
  font-weight: 400;
  letter-spacing: 0;
}
#footer .f-menus_wrapper nav .f-menus__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  gap: 2rem clamp(5rem, -10.1219512195rem + 15.243902439vw, 10rem);
}
#footer .f-menus_wrapper nav .f-menus__wrapper ul.f-nav {
  list-style: none;
  margin: 0;
  padding: 0;
}
#footer .f-menus_wrapper nav .f-menus__wrapper ul.f-nav li {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  white-space: nowrap;
  letter-spacing: 0;
  padding-left: 2rem;
  position: relative;
}
#footer .f-menus_wrapper nav .f-menus__wrapper ul.f-nav li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 1.1rem;
  height: 0.2rem;
  background-color: var(--key);
}
#footer .f-menus_wrapper nav .f-menus__wrapper ul.f-nav li:not(:last-child) {
  margin-bottom: 2rem;
}
@media screen and (max-width: 1200px) {
  #footer .footer_wrapper {
    padding-bottom: 15rem;
  }
}
@media screen and (max-width: 1060px) {
  #footer .footer_wrapper {
    -ms-flex-wrap: wrap-reverse;
        flex-wrap: wrap-reverse;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  #footer .f-menus_wrapper nav .f-menus__wrapper {
    -webkit-margin-after: 4rem;
            margin-block-end: 4rem;
  }
}
@media (orientation: landscape) and (max-width: 1280px) {
  #footer {
    padding-bottom: 15rem;
  }
}
@media screen and (max-width: 640px) {
  #footer .f-info_wrapper {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 500px) {
  #footer .f-menus_wrapper nav .f-menus__wrapper {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-flow: row wrap;
            flex-flow: row wrap;
  }
}

/* ===============

下層ページ

=============== */
#about .post {
  margin-right: 1em;
}
#about .name {
  font-size: 3.2rem;
}
#about .profile {
  width: clamp(40rem, 31.6825396825rem + 10.582010582vw, 52rem);
}
@media screen and (max-width: 768px) {
  #about .alignleft {
    float: none;
    margin-inline: auto;
  }
}
#about .about-02 {
  margin-bottom: 5rem;
}
#about .about-02 p:not(:last-child) {
  margin-bottom: 4rem;
}
#about #about_detail .catch {
  width: 100%;
  margin-bottom: 5rem;
}
#about #about_detail .catch p {
  margin: 0 auto;
  text-align: center;
}
#about #about_detail .catch p span {
  display: inline-block;
  white-space: nowrap;
}
@media screen and (max-width: 768px) {
  #about #about_detail .catch p {
    margin: 0 auto 0 0;
  }
}
#about #about_detail .banners {
  display: block;
  margin-bottom: 5rem;
}
#about dl {
  width: min(calc(100% - 3rem), 87.2rem);
  margin: 0 auto 20rem !important;
}
#about p {
  margin-bottom: 0;
}
#about p * {
  letter-spacing: 0;
}
#about p span {
  display: inline-block;
}

#column h1 {
  font-size: clamp(2.8rem, 2.352rem + 1.4vw, 4.2rem);
  line-height: 1.25;
}
#column h2 {
  font-size: clamp(2.4rem, 2.016rem + 1.2vw, 3.6rem);
  line-height: 1.25;
}
#column .main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-block: 0 5rem;
}
#column .container.column-container {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background-color: #fff;
  border-radius: 1rem;
  padding: clamp(3rem, 2.04rem + 3vw, 6rem) clamp(1.5rem, 0.06rem + 4.5vw, 6rem);
}
#column .container.column-container .column-title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  margin-block: 0 clamp(4rem, 3.36rem + 2vw, 6rem);
}

#privacy-policy p {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
#privacy-policy p span {
  display: inline-block;
  white-space: nowrap;
}
#privacy-policy ul.num {
  list-style: none;
  margin-inline: 0;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 3rem;
          margin-block-end: 3rem;
  padding: 0;
  counter-reset: number 0;
}
#privacy-policy ul.num > li {
  position: relative;
  padding: 0 0 3rem;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
  margin-inline: 0;
  border-bottom: 0.1rem solid var(--bcr);
}
#privacy-policy ul.num > li h3.list-title {
  font-size: 3.2rem;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
#privacy-policy ul.num > li h3.list-title::before {
  counter-increment: number 1;
  content: counter(number) ". ";
  font-size: 3.2rem;
}
#privacy-policy .contact_to {
  -webkit-margin-after: 10rem;
          margin-block-end: 10rem;
}
#privacy-policy .contact_to .h3-title {
  font-size: 3.2rem;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  text-align: left;
}
#privacy-policy .contact_to .h4-title {
  font-size: 2.8rem;
  text-align: left;
}
#privacy-policy .contact_to p {
  margin-block: 0;
}
#privacy-policy .contact_to a {
  text-decoration: none;
}

/* =====================

お問い合わせ

===================== */
#contact {
  /* 確認画面の内容ボックス */
  /* --------------------
  レスポンシブ対応
   -------------------- */
}
#contact .opst {
  width: min(100%, 99.2rem);
  margin-inline: auto;
}
#contact .opst .pvp_link {
  color: red;
}
#contact form {
  background: #fff;
  border-radius: 8px;
  padding: clamp(2rem, 1.5238095238rem + 1.4880952381vw, 3rem) clamp(1.2rem, -1.0857142857rem + 7.1428571429vw, 6rem);
  width: min(100%, 99.2rem);
  margin-inline: auto;
  margin-bottom: clamp(4rem, 1.1428571429rem + 8.9285714286vw, 10rem);
  border: 0.1rem solid #ccc;
}
#contact form > ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
#contact form > ul li {
  margin-bottom: 2rem;
}
#contact .confirm-box,
#contact .send-box {
  background: #fff;
  border-radius: 8px;
  padding: clamp(2rem, 1.5238095238rem + 1.4880952381vw, 3rem) clamp(1.2rem, -1.0857142857rem + 7.1428571429vw, 6rem) 7rem;
  width: min(calc(100% - 3rem), 99.2rem);
  margin-inline: auto;
  margin-block: 0 10rem;
  border: 0.1rem solid #ccc;
}
#contact .confirm-box span,
#contact .send-box span {
  display: inline-block;
  white-space: nowrap;
}
#contact .send-box p {
  margin-bottom: 0 !important;
}
#contact .btn_wrapper {
  margin-top: 5rem;
  text-align: center;
}
#contact .btn_wrapper form + form {
  margin-top: 2rem;
}
#contact .fmp-btn,
#contact .fmg-btn {
  text-align: center;
  background-color: transparent;
  border: 0;
  padding: 0;
  margin-block: 0;
  margin-inline: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#contact .fmp-btn button,
#contact .fmg-btn button {
  margin: 0;
}
#contact .confirm-inputs {
  font-weight: 700;
  color: var(--red);
}
#contact label {
  display: var(--txt);
  margin-bottom: 1rem;
}
#contact input[type=text],
#contact input[type=email],
#contact input[type=tel],
#contact textarea {
  width: 100%;
  padding: 0.8em;
  margin-top: 0.2em;
  border: 1px solid #ccc;
  border-radius: 6px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
#contact textarea {
  min-height: 10em;
  font-size: 2.4rem;
  line-height: 1.75;
  resize: vertical;
}
#contact input[type=checkbox] {
  margin-right: 0.5em;
}
#contact .required {
  color: red;
  font-weight: bold;
  margin-left: 0.5em;
}
#contact .checklists {
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}
#contact .checklists li {
  margin-bottom: 0.5rem !important;
}
#contact button {
  background: var(--key);
  color: #fff;
  padding: 0.8em 1.5em;
  border: none;
  border-radius: 6px;
  font-size: 1em;
  cursor: pointer;
  margin-top: 1em;
  display: inline-block;
  -webkit-transition: background-color 0.1s linear;
  transition: background-color 0.1s linear;
}
#contact button:hover {
  -webkit-transition: background-color 0.2s linear;
  transition: background-color 0.2s linear;
  background: var(--key_l);
}
#contact button + button {
  margin-left: 1em;
}
#contact #error,
#contact #error li,
#contact #error span,
#contact #emailError {
  color: red;
  font-size: 0.9em;
}
#contact .confirm-box p {
  margin-bottom: 1em;
  background: #f0f0f0;
  padding: 0.8em;
  border-radius: 6px;
  white-space: pre-wrap;
}
@media screen and (max-width: 768px) {
  #contact button {
    width: 100%;
    margin: 0.5em 0;
  }
  #contact button + button {
    margin-left: 0;
  }
}
#contact #mail-unlocks .def > li::before {
  background-color: var(--red);
}
#contact #mail-unlocks .def > li .situation {
  font-weight: 700;
  color: var(--red);
}
#contact #mail-unlocks .def > li .solution p {
  margin-bottom: 0 !important;
}

/* =====================

Not Found

===================== */
#notfound .notfound {
  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;
  margin-top: 3em;
  margin-bottom: 3em;
}
#notfound .notfound h2 {
  margin: 0 auto 0.5em;
  color: #ccc;
  text-align: center;
}
#notfound .notfound p {
  text-align: center;
}

.tets {
  width: clamp(3rem, -31.2260869565rem + 44.5652173913vw, 27.6rem);
}