@charset "UTF-8";
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 2.5641025641vw;
}
@media screen and (min-width:768px) {
  html {
    font-size: 0.5208333333vw;
  }
}

body {
  color: #000;
  font-family: "Yu Gothic Medium", "YuGothic", "游ゴシック Medium", "Yu Gothic", sans-serif;
  background: #eee;
  position: relative;
}

body {
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  font-style: normal;
  font-synthesis: none;
}

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

a {
  text-decoration: none;
  transition: 0.3s;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

a[x-apple-data-detectors] {
  color: inherit !important;
  text-decoration: none !important;
  border-bottom: none !important;
}

a,
button,
input,
textarea,
select {
  outline: none !important;
  box-shadow: none !important;
}

.btn {
  display: inline-block;
}

.c-section-label {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.1em;
  color: #888;
}
@media screen and (min-width:768px) {
  .c-section-label {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6875;
  }
}

.c-section-title {
  position: relative;
  font-size: 28px;
  font-weight: 700;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  line-height: 2;
  z-index: 1;
}
@media screen and (min-width:768px) {
  .c-section-title {
    font-size: 3.2rem;
    letter-spacing: 0.04em;
    line-height: 2;
  }
}
.c-section-title::after {
  content: "";
  position: absolute;
  bottom: -2rem;
  left: 50%;
  transform: translate(-50%, 0);
  height: 0.1rem;
  width: 100%;
}
@media screen and (min-width:768px) {
  .c-section-title::after {
    bottom: -2.7rem;
    width: 42rem;
  }
}

.c-subheading-label {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #1C1107;
}
@media screen and (min-width:768px) {
  .c-subheading-label {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}

.c-subheading-title {
  position: relative;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  color: #1C1107;
  z-index: 1;
}
@media screen and (min-width:768px) {
  .c-subheading-title {
    font-size: 3.2rem;
    line-height: 1.875;
  }
}

.c-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  font-size: 1.4rem;
  line-height: 1.21;
  letter-spacing: 0.1em;
  font-weight: 700;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  width: 15rem;
  transition: 0.2s ease-out;
}
@media screen and (min-width:768px) {
  .c-btn {
    font-size: 1.6rem;
    line-height: 1.1875;
    width: 15rem;
  }
}
.c-btn--white {
  color: #EAE7DF;
  --btn-color: #EAE7DF;
  border-bottom: 0.1rem solid #EAE7DF;
  padding-bottom: 1rem;
}
.c-btn--white::after {
  content: "";
  display: block;
  background: url(../../assets/img/common/i-arrow-w.png) no-repeat center center/contain;
  height: 0.8rem;
  width: 0.8rem;
  transition: transform 0.2s ease-out;
}
.c-btn--black {
  color: #323232;
  --btn-color: #323232;
  border-bottom: 0.1rem solid #323232;
  padding-bottom: 1rem;
}
.c-btn--black::after {
  content: "";
  display: block;
  background: url(../../assets/img/common/i-arrow-b.png) no-repeat center center/contain;
  height: 0.8rem;
  width: 0.8rem;
  transition: transform 0.2s ease-out;
}
.c-btn:hover::after {
  transform: translateX(4px);
}
.c-btn .hovscroll {
  display: inline-block;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--btn-color), 0 0 0 var(--btn-color);
  transition: text-shadow 0.3s;
}
.c-btn:hover .hovscroll {
  text-shadow: 0 0 0 var(--btn-color), 0 -1.5em 0 var(--btn-color);
}

.inner, .inner-s {
  width: 100%;
  height: 100%;
  max-width: 1280px;
  margin: auto;
}
@media screen and (min-width:768px) {
  .inner, .inner-s {
    width: min(66.6666666667vw, 1280px);
  }
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 7rem;
  z-index: 99;
}
@media screen and (min-width:768px) {
  .header {
    height: 10rem;
  }
}
.header__inner {
  max-width: 172rem;
  width: 89.7%;
  margin: auto;
  padding: 0.7rem 1.2rem 0;
}
@media screen and (min-width:768px) {
  .header__inner {
    width: 100%;
    padding: 1.3rem 0 0 0;
  }
}
.header__content {
  display: flex;
  align-items: center;
}
.header__logo {
  margin-left: -2rem;
}
@media screen and (min-width:768px) {
  .header__logo {
    margin-left: 0;
  }
}
.header__logo img {
  width: 12.8rem;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (min-width:768px) {
  .header__logo img {
    width: 25rem;
  }
}
.header__nav {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin: 0 0 0 auto;
}
.header__nav-menu {
  display: none;
}
@media screen and (min-width:768px) {
  .header__nav-menu {
    display: flex;
    align-items: center;
    margin-right: 3.5rem;
  }
}
.header__nav-item a {
  display: block;
  --nav-color: #E2DED5;
}
@media screen and (min-width:768px) {
  .header__nav-item a {
    font-size: 1.6rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    line-height: 1.1875;
    color: #E2DED5;
    font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
    padding: 1rem 3.8rem;
  }
}
.header__contact-btn {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.1875;
  color: #E2DED5;
  --navhc-color: #E2DED5;
  margin-right: 1rem;
  background: rgba(0, 0, 0, 0.1882352941);
  padding: 1rem 3.3rem;
  border-radius: 3rem;
  z-index: 10;
  transition: background 0.2s ease;
  /* ▼ hover：背景色だけ濃くする */
}
@media screen and (min-width:768px) {
  .header__contact-btn {
    font-size: 1.6rem;
    line-height: 1.1875;
    font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
    margin-right: 2.5rem;
    padding: 1rem 5.5rem;
  }
}
.header__contact-btn:hover {
  background: rgba(0, 0, 0, 0.5019607843);
}
.header__contact-btn.active {
  color: #E2DED5;
}
.header.is-dark .header__nav-item a {
  color: #323232;
  --nav-color: #323232;
}
.header .hovscroll {
  display: inline-block;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--nav-color), 0 0 0 var(--nav-color);
  transition: text-shadow 0.3s;
}
.header .header__nav-item a:hover .hovscroll {
  text-shadow: 0 0 0 var(--nav-color), 0 -1.5em 0 var(--nav-color);
}
.header .hovscroll2 {
  display: inline-flex;
  align-items: center;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--navhc-color), 0 0 0 var(--navhc-color);
  transition: text-shadow 0.3s;
}
.header__contact-btn:hover .hovscroll2 {
  text-shadow: 0 0 0 var(--navhc-color), 0 -1.5em 0 var(--navhc-color);
}

.footer-info {
  position: relative;
  width: 100%;
}
.footer-info--syosai {
  background: #EAE7DF;
}
.footer-info .logo-bg {
  display: flex;
  align-items: center;
  justify-content: center;
  background: url(../../assets/img/common/footer-info_bg_sp.jpg) no-repeat center center/cover;
  height: 26rem;
  width: 100%;
}
@media screen and (min-width:768px) {
  .footer-info .logo-bg {
    background: url(../../assets/img/common/footer-info_bg_pc.jpg) no-repeat center center/cover;
    height: 57rem;
  }
}
.footer-info__logo img {
  width: 18.7rem;
  margin: auto;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (min-width:768px) {
  .footer-info__logo img {
    width: 40rem;
  }
}
.footer-info__inner {
  position: relative;
  height: 100%;
  width: 84%;
  margin: auto;
}
@media screen and (min-width:768px) {
  .footer-info__inner {
    width: 100%;
    padding: 15rem 0;
  }
}
.footer-info__inner::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  height: 0.06rem;
  width: 100%;
  background: #323232;
}
@media screen and (min-width:768px) {
  .footer-info__inner::before {
    height: 32rem;
    width: 0.06rem;
  }
}
.footer-info__flex {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width:768px) {
  .footer-info__flex {
    flex-direction: row;
    gap: 56.7rem;
  }
}
.footer-info__box {
  text-align: center;
  width: 100%;
  padding: 9.5rem 0 10rem;
}
@media screen and (min-width:768px) {
  .footer-info__box {
    width: auto;
    padding: 0;
  }
}
.footer-info .c-section-label--company,
.footer-info .c-section-label--contact {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.666;
  color: #323232;
  text-align: center;
}
@media screen and (min-width:768px) {
  .footer-info .c-section-label--company,
  .footer-info .c-section-label--contact {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.footer-info .c-section-title--company,
.footer-info .c-section-title--contact {
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #323232;
  text-align: center;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-bottom: 4rem;
}
@media screen and (min-width:768px) {
  .footer-info .c-section-title--company,
  .footer-info .c-section-title--contact {
    font-size: 3.2rem;
    margin-bottom: 6.5rem;
  }
}
.footer-info .c-section-title--company::after,
.footer-info .c-section-title--contact::after {
  display: none;
}
.footer-info .c-btn--footer {
  color: #323232;
}

.footer {
  position: relative;
  width: 100%;
  background: #1C1107;
}
.footer__inner {
  height: 100%;
  width: 89.7%;
  margin: auto;
  padding: 8rem 0 1rem 1.2rem;
}
@media screen and (min-width:768px) {
  .footer__inner {
    width: 120rem;
    padding: 7rem 0 1rem;
  }
}
.footer__logo {
  width: 26.4rem;
  margin: 0;
  margin-left: -2rem;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (min-width:768px) {
  .footer__logo {
    width: 32rem;
    margin: auto auto 0.5rem -2rem;
  }
}
.footer__top {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media screen and (min-width:768px) {
  .footer__top {
    flex-direction: row;
    align-items: center;
    gap: 10rem;
  }
}
.footer__company, .footer__address, .footer__tel {
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #EAE7DF;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .footer__company, .footer__address, .footer__tel {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.footer__address {
  margin: 0.6rem 0 0.5rem;
}
@media screen and (min-width:768px) {
  .footer__address {
    margin: 1rem 0 3.5rem;
  }
}
.footer__nav {
  display: flex;
  flex-direction: column-reverse;
  width: 100%;
  gap: 3rem;
  margin-top: 2.6rem;
  margin-bottom: 12.7rem;
}
@media screen and (min-width:768px) {
  .footer__nav {
    flex-direction: row;
    justify-content: space-between;
    gap: 2rem;
    margin-top: 2rem;
    margin-bottom: 0;
  }
}
.footer__nav-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media screen and (min-width:768px) {
  .footer__nav-list {
    grid-template-columns: 1fr;
    gap: 0 5rem;
  }
}
.footer__nav-list a {
  display: block;
  --navf-color: #EAE7DF;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.42;
  color: #EAE7DF;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  white-space: nowrap;
}
@media screen and (min-width:768px) {
  .footer__nav-list a {
    font-size: 1.6rem;
    line-height: 1.1875;
    padding: 1rem 0.5rem;
  }
}
.footer__nav-group {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media screen and (min-width:768px) {
  .footer__nav-group {
    grid-template-columns: 15rem 15rem 1fr;
    gap: 0;
  }
}
.footer__contact-btn {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.41;
  color: #1C1107;
  --navfc-color: #1C1107;
  text-align: center;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  transition: color 0.2s ease;
  padding: 0.6rem 1rem;
  border: 0.06rem solid #EAE7DF;
  border-radius: 3rem;
  background: #EAE7DF;
  height: 3rem;
  width: 14rem;
}
@media screen and (min-width:768px) {
  .footer__contact-btn {
    font-size: 1.6rem;
    line-height: 1.1875;
    margin-top: 1rem;
    padding: 1rem;
    height: 4rem;
    width: 20.6rem;
  }
}
.footer__bottom {
  position: relative;
  margin-right: 1.2rem;
}
@media screen and (min-width:768px) {
  .footer__bottom {
    margin-top: 7rem;
  }
}
.footer__bottom::before {
  content: "";
  position: absolute;
  top: -1.2rem;
  left: 50%;
  transform: translateX(-50%);
  height: 0.06rem;
  width: 100%;
  background: #EAE7DF;
}
@media screen and (min-width:768px) {
  .footer__bottom::before {
    display: none;
  }
}
.footer__copy {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #F2F1EE;
  text-align: center;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .footer__copy {
    font-size: 1.4rem;
    line-height: 2;
  }
}
.footer .hovscroll {
  display: inline-block;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--navf-color), 0 0 0 var(--navf-color);
  transition: text-shadow 0.3s;
}
.footer__nav-list a:hover .hovscroll {
  text-shadow: 0 0 0 var(--navf-color), 0 -1.5em 0 var(--navf-color);
}
.footer .hovscroll2 {
  display: inline-flex;
  align-items: center;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--navfc-color), 0 0 0 var(--navfc-color);
  transition: text-shadow 0.3s;
}
.footer__contact-btn:hover .hovscroll2 {
  text-shadow: 0 0 0 var(--navfc-color), 0 -1.5em 0 var(--navfc-color);
}

.hamburger {
  position: relative;
  min-width: 3rem;
  height: 3rem;
  margin-right: -1.7rem;
  transition: 0.5s;
  z-index: 10;
  cursor: pointer;
}
@media screen and (min-width:768px) {
  .hamburger {
    min-width: 4rem;
    height: 4rem;
    margin-right: 0;
  }
}
.hamburger div {
  width: 2.2rem;
  height: 0.1rem;
  background: #E2DED5;
  position: absolute;
  left: 50%;
  margin-right: -2rem;
  transform: translate(-50%, -50%);
  transition: 0.3s;
}
@media screen and (min-width:768px) {
  .hamburger div {
    width: 4rem;
    height: 0.1rem;
  }
}
.hamburger div:nth-child(1) {
  top: 30%;
}
.hamburger div:nth-child(2) {
  top: 60%;
}
.hamburger .close {
  display: none;
}

.hamburger.active div:nth-child(1) {
  top: 50%;
  transform: translate(-50%, -50%) rotate(-45deg);
  transform-origin: 50% 50%;
  background: #323232;
  transition: 0.3s;
}
@media screen and (min-width:768px) {
  .hamburger.active div:nth-child(1) {
    transform: translate(-50%, -50%) rotate(-45deg);
  }
}

.hamburger.active div:nth-child(2) {
  top: 50%;
  transform: translate(-50%, -50%) rotate(45deg);
  transform-origin: 50% 50%;
  background: #323232;
  transition: 0.3s;
}
@media screen and (min-width:768px) {
  .hamburger.active div:nth-child(2) {
    transform: translate(-50%, -50%) rotate(45deg);
  }
}

.hamburger.active .close {
  display: block;
}

.hamburger.active .open {
  display: none;
}

.header.is-dark .hamburger div {
  background: #323232;
}

.hamburger__menu {
  display: block;
  position: fixed;
  top: 0;
  right: 0;
  width: 72%;
  height: 100vh;
  background: #EAE7DF;
  box-shadow: 5px 0px 26px rgba(0, 0, 0, 0.2);
  overflow-y: auto;
  overflow-x: hidden;
  /* ★右側へ押し出して非表示にする★ */
  transform: translateX(100%);
  transition: transform 0.35s ease;
}
@media screen and (min-width:768px) {
  .hamburger__menu {
    width: 32.8%;
    height: 100vh;
    padding: 18rem 0 0 7.3%;
  }
}
.hamburger__menu.active {
  transform: translateX(0);
}
.hamburger__menu-list {
  display: flex;
  flex-direction: column;
  width: -moz-max-content;
  width: max-content;
  margin: 12rem auto 5rem;
}
@media screen and (min-width:768px) {
  .hamburger__menu-list {
    margin: 0;
  }
}
.hamburger__menu-item a {
  display: flex;
  flex-direction: column;
  padding: 2rem 0;
}
@media screen and (min-width:768px) {
  .hamburger__menu-item a {
    padding: 2rem 0;
  }
}
.hamburger__menu-item .en {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.6875;
  color: #323232;
}
@media screen and (min-width:768px) {
  .hamburger__menu-item .en {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6875;
  }
}
.hamburger__menu-item .jp {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #323232;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .hamburger__menu-item .jp {
    font-size: 2.2rem;
    letter-spacing: 0.04em;
  }
}

.subfv {
  position: relative;
  background: #EAE7DF;
}
.subfv::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  opacity: 1;
  z-index: 1;
}
.subfv--about {
  background: url(../img/about/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--about {
    background: url(../img/about/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv--company {
  background: url(../img/company/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--company {
    background: url(../img/company/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv--house {
  background: url(../img/house/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--house {
    background: url(../img/house/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv--category {
  background: url(../img/news/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--category {
    background: url(../img/news/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv--faq {
  background: url(../img/faq/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--faq {
    background: url(../img/faq/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv--privacypolicy {
  background: url(../img/privacypolicy/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--privacypolicy {
    background: url(../img/privacypolicy/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv--contact {
  background: url(../img/contact/fv_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .subfv--contact {
    background: url(../img/contact/fv_pc.jpg) no-repeat center center/cover;
  }
}
.subfv__inner {
  position: relative;
  z-index: 3;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 50rem;
  width: 84%;
  margin: auto;
  z-index: 2;
}
@media screen and (min-width:768px) {
  .subfv__inner {
    justify-content: flex-start;
    max-width: 120rem;
    height: 70rem;
  }
}
.subfv__title {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.66;
  color: #EAE7DF;
  text-align: center;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .subfv__title {
    font-size: 3.2rem;
    line-height: 2.3;
    text-align: left;
  }
}
.subfv__subtitle {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #EAE7DF;
  text-align: center;
  margin-top: 1.5rem;
}
@media screen and (min-width:768px) {
  .subfv__subtitle {
    font-size: 1.6rem;
    line-height: 2;
    text-align: left;
    margin-top: 2rem;
  }
}
.subfv__label {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  text-align: center;
  color: #EAE7DF;
}
@media screen and (min-width:768px) {
  .subfv__label {
    font-size: 1.6rem;
    line-height: 1.6875;
    text-align: left;
  }
}

.breadcrumb {
  width: 100%;
  padding: 1rem 0;
  position: absolute;
  bottom: -5em;
  left: 0;
}
.breadcrumb__list {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  white-space: nowrap;
  font-size: 1rem;
  line-height: 1.71;
  letter-spacing: 0.1em;
  font-weight: 500;
  color: #323232;
}
@media screen and (min-width:768px) {
  .breadcrumb__list {
    gap: 2rem;
    font-size: 1.4rem;
    line-height: 1.71;
  }
}
.breadcrumb__item--current {
  white-space: normal !important;
  overflow-wrap: anywhere;
  word-break: break-word;
  max-width: calc(100% - 8rem);
}
.breadcrumb__item {
  display: flex;
  align-items: center;
}
.breadcrumb__link {
  font-size: 1rem;
  line-height: 1.71;
  letter-spacing: 0.1em;
  font-weight: 500;
  color: #323232;
  text-decoration: none;
}
@media screen and (min-width:768px) {
  .breadcrumb__link {
    font-size: 1.4rem;
    line-height: 1.71;
  }
}
.breadcrumb__link:hover {
  text-decoration: underline;
}
.breadcrumb__item--current {
  font-weight: 500;
}
.breadcrumb__sep {
  opacity: 0.6;
}

.fv {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  opacity: 0;
  transition: opacity 300ms ease-out;
  /* ← ふわっと表示 */
  /* 背景画像を inner に移動 */
}
.fv.is-loaded {
  opacity: 1;
}
.fv__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.fv__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.3);
  opacity: 1;
  z-index: 2;
}
.fv__inner {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: flex-start;
  height: 100%;
  width: 83.3%;
  margin: auto;
  padding-top: 25.7rem;
}
@media screen and (min-width:768px) {
  .fv__inner {
    align-items: center;
    height: 100vh;
    max-width: 150rem;
    padding-top: 0;
  }
}
.fv__title {
  font-size: 3.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.625;
  color: #E2DED5;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-bottom: 2.2rem;
}
@media screen and (min-width:768px) {
  .fv__title {
    font-size: 5rem;
    font-weight: 500;
    line-height: 1.52;
    margin-bottom: 2rem;
  }
}
.fv__subtitle {
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #E2DED5;
}
@media screen and (min-width:768px) {
  .fv__subtitle {
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 2.22;
  }
}
.fv .fv-slide {
  position: relative;
  overflow: hidden;
}
.fv .fv-slide__inner {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transform: scale(1.12);
  /* 初期値（拡大） */
  transform-origin: 50% 50%;
  /* ランダムの基点が安定 */
  transition: transform 9000ms linear;
  /* ゆったり縮小 */
}
.fv .fv-slide--1 .fv-slide__inner {
  background-image: url("../../assets/img/fv_slide/fv01_sp.jpg");
}
@media screen and (min-width:768px) {
  .fv .fv-slide--1 .fv-slide__inner {
    background-image: url("../../assets/img/fv_slide/fv01_pc.jpg");
  }
}
.fv .fv-slide--2 .fv-slide__inner {
  background-image: url("../../assets/img/fv_slide/fv02_sp.jpg");
}
@media screen and (min-width:768px) {
  .fv .fv-slide--2 .fv-slide__inner {
    background-image: url("../../assets/img/fv_slide/fv02_pc.jpg");
  }
}
.fv .fv-slide--3 .fv-slide__inner {
  background-image: url("../../assets/img/fv_slide/fv03_sp.jpg");
}
@media screen and (min-width:768px) {
  .fv .fv-slide--3 .fv-slide__inner {
    background-image: url("../../assets/img/fv_slide/fv03_pc.jpg");
  }
}
.fv .fv-slide--4 .fv-slide__inner {
  background-image: url("../../assets/img/fv_slide/fv04_sp.jpg");
}
@media screen and (min-width:768px) {
  .fv .fv-slide--4 .fv-slide__inner {
    background-image: url("../../assets/img/fv_slide/fv04_pc.jpg");
  }
}

/* FV ニュース全体 */
.fv-news {
  position: absolute;
  bottom: 2.5rem;
  right: auto;
  left: 0;
  width: 100%;
  max-width: 28rem;
  padding-bottom: 2.5rem;
  /* 1スライド */
  /* メタ情報（日付＋カテゴリ 横並び） */
}
@media screen and (min-width:768px) {
  .fv-news {
    position: absolute;
    bottom: 0;
    right: 0;
    left: auto;
    bottom: 9rem;
    padding-bottom: 2.5rem;
  }
}
.fv-news__item a {
  display: block;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.5;
  color: #E2DED5;
  cursor: pointer;
}
@media screen and (min-width:768px) {
  .fv-news__item a {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.fv-news__meta {
  display: flex;
  gap: 1.6rem;
  margin-bottom: 1rem;
}
@media screen and (min-width:768px) {
  .fv-news__meta {
    margin-bottom: 1.5rem;
  }
}
.fv-news__date {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.5;
  color: #E2DED5;
}
@media screen and (min-width:768px) {
  .fv-news__date {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.fv-news__cat {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2;
  color: #E2DED5;
  background: rgba(0, 0, 0, 0.1882352941);
  padding: 0 1rem;
}
@media screen and (min-width:768px) {
  .fv-news__cat {
    font-size: 1.2rem;
    line-height: 2;
    padding: 0 1rem;
  }
}
.fv-news__title {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.5;
  color: #E2DED5;
}
@media screen and (min-width:768px) {
  .fv-news__title {
    font-size: 1.6rem;
    line-height: 1.5;
  }
}
.fv-news__title span {
  border-bottom: 0.06rem solid #E2DED5;
}
.fv-news a:hover span {
  border-bottom: none;
}
.fv-news .fv-news__pagination {
  position: relative;
  background: transparent !important;
  margin-top: 2rem;
  text-align: left;
}
@media screen and (min-width:768px) {
  .fv-news .fv-news__pagination {
    margin-top: 2.5rem;
  }
}
.fv-news .fv-news__pagination .swiper-pagination-bullet {
  width: 4rem;
  height: 0.3rem;
  border-radius: 0;
  background: #E2DED5;
  border-radius: 0;
  opacity: 0.3;
  margin: 0 6px 0 0 !important;
  transition: opacity 0.3s, background 0.3s;
}
@media screen and (min-width:768px) {
  .fv-news .fv-news__pagination .swiper-pagination-bullet {
    height: 0.4rem;
  }
}
.fv-news .fv-news__pagination .swiper-pagination-bullet-active {
  background: rgba(0, 0, 0, 0.1882352941);
  opacity: 1;
}

.about {
  position: relative;
  width: 100%;
  height: 100%;
  background: url(../../assets/img/index/about_bg_sp.jpg) no-repeat center center/cover;
  overflow: hidden;
}
@media screen and (min-width:768px) {
  .about {
    height: 88.8rem;
    background: url(../../assets/img/index/about_bg_pc.jpg) no-repeat center center/cover;
  }
}
.about::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  background: linear-gradient(to right, rgba(51, 30, 9, 0.5) 0%, rgba(51, 30, 9, 0) 100%);
  z-index: 1;
}
.about__inner {
  height: 100%;
  margin: auto;
  padding: 18rem 0 26rem;
}
@media screen and (min-width:768px) {
  .about__inner {
    padding: 0;
  }
}
.about__content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  height: 100%;
}
@media screen and (min-width:768px) {
  .about__content {
    justify-content: center;
  }
}
.about .c-section-label--about {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.666;
  color: #EAE7DF;
  text-align: center;
}
@media screen and (min-width:768px) {
  .about .c-section-label--about {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.about .c-section-title--about {
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #EAE7DF;
  text-align: center;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .about .c-section-title--about {
    font-size: 3.2rem;
    padding-left: 2.5rem;
  }
}
.about .c-section-title--about::after {
  background: #EAE7DF;
}
.about__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #EAE7DF;
  text-align: center;
  margin: 6.3rem 0 3rem;
}
@media screen and (min-width:768px) {
  .about__text {
    font-size: 1.6rem;
    line-height: 2;
    margin: 8rem 0 4rem;
  }
}

.house {
  /* 進行バー部分 */
  /* 共通ボタンレイアウト */
  /* 角度の浅いシャープな矢印 */
  /* ← (prev) */
  /* → (next) */
  /* PCでは左だけ */
  /* SPでは左右どちらも表示 */
}
.house__inner {
  height: 100%;
  width: 89.7%;
  margin: auto;
  padding: 12rem 1.2rem;
}
@media screen and (min-width:768px) {
  .house__inner {
    width: 100%;
    padding: 12rem 0 12rem 18.75%;
  }
}
.house__flex {
  position: relative;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width:768px) {
  .house__flex {
    flex-direction: row;
    align-items: center;
  }
}
.house__content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  height: 100%;
  min-width: auto;
}
@media screen and (min-width:768px) {
  .house__content {
    min-width: 42rem;
    margin-bottom: 3.5rem;
  }
}
.house .c-section-label--house {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.666;
  color: #323232;
  text-align: left;
}
@media screen and (min-width:768px) {
  .house .c-section-label--house {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.house .c-section-title--house {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #323232;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .house .c-section-title--house {
    font-size: 3.2rem;
  }
}
.house .c-section-title--house::after {
  background: #323232;
  left: 0;
  transform: translate(0, 0);
  width: 20rem;
}
@media screen and (min-width:768px) {
  .house .c-section-title--house::after {
    width: 15rem;
  }
}
.house .c-btn--house-pc {
  display: none;
}
@media screen and (min-width:768px) {
  .house .c-btn--house-pc {
    display: flex;
    color: #323232;
  }
}
.house .c-btn--house-sp {
  color: #323232;
  margin: 3.3rem auto 0;
}
@media screen and (min-width:768px) {
  .house .c-btn--house-sp {
    display: none;
  }
}
.house__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #323232;
  text-align: left;
  margin: 6rem 0 4.5rem;
}
@media screen and (min-width:768px) {
  .house__text {
    font-size: 1.6rem;
    line-height: 2;
    margin: 8rem 0 4rem;
  }
}
.house .swiper__content {
  position: relative;
}
.house__slider {
  position: relative;
  overflow: hidden;
  margin-left: 0;
  padding-bottom: 3rem;
}
@media screen and (min-width:768px) {
  .house__slider {
    margin-left: 13rem;
    padding-bottom: 3.5rem;
  }
}
.house .house-slide {
  width: 100%;
  height: 48.8rem;
  overflow: hidden;
  background-size: cover;
  background-position: center;
  position: relative;
  margin-right: 2rem;
  transition: background-size 0.6s ease;
  /* 画像レイヤーを疑似要素で配置 */
  /* hoverで滑らか拡大 */
  /* グラデーションオーバーレイ（既存） */
}
@media screen and (min-width:768px) {
  .house .house-slide {
    width: 69.4rem !important;
    height: 69.4rem;
    margin-right: 6rem;
  }
}
.house .house-slide img {
  -o-object-fit: cover;
     object-fit: cover;
}
.house .house-slide:hover {
  background-size: 105%;
}
.house .house-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: inherit;
  background-size: cover;
  background-position: center;
  transition: transform 0.6s ease;
  z-index: 0;
}
.house .house-slide:hover::before {
  transform: scale(1.05);
}
.house .house-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgb(51, 30, 9) 0%, rgba(51, 30, 9, 0) 60%);
  opacity: 0.7;
  z-index: 1;
  pointer-events: none;
}
.house .house-slide__link {
  display: flex;
  height: 100%;
  align-items: flex-end;
  padding: 0 2rem 3rem;
  position: relative;
  z-index: 3;
}
@media screen and (min-width:768px) {
  .house .house-slide__link {
    padding: 0 6rem 10rem;
  }
}
.house .house-slide__content {
  position: relative;
  display: flex;
  flex-direction: column;
}
@media screen and (min-width:768px) {
  .house .house-slide__content {
    display: block;
  }
}
.house .house-slide__num {
  position: relative;
  z-index: 4;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #EAE7DF;
  text-align: left;
}
@media screen and (min-width:768px) {
  .house .house-slide__num {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.house .house-slide__title {
  position: relative;
  z-index: 4;
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.6;
  color: #EAE7DF;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-bottom: 1rem;
}
@media screen and (min-width:768px) {
  .house .house-slide__title {
    font-size: 3.2rem;
    line-height: 2;
    margin-bottom: 2rem;
  }
}
.house .house-slide__text {
  position: relative;
  z-index: 4;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #EAE7DF;
  text-align: left;
  font-family: "Yu Gothic Medium", "YuGothic", "游ゴシック Medium", "Yu Gothic", sans-serif;
}
@media screen and (min-width:768px) {
  .house .house-slide__text {
    font-size: 1.6rem;
    line-height: 2;
    margin-bottom: 3.3rem;
  }
}
.house .house-slide__more {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 4;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #EAE7DF;
  --btn-color: #EAE7DF;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  padding-bottom: 1rem;
  width: 50%;
  max-width: 15rem;
  border-bottom: 0.06rem solid #EAE7DF;
  transition: 0.2s ease-out;
}
@media screen and (min-width:768px) {
  .house .house-slide__more {
    font-size: 1.6rem;
    line-height: 1.1875;
    width: 15rem;
  }
}
.house .house-slide__more::after {
  content: "";
  display: block;
  background: url(../../assets/img/common/i-arrow-w.png) no-repeat center center/contain;
  height: 0.8rem;
  width: 0.8rem;
  transition: transform 0.2s ease-out;
}
.house .house-slide:hover .house-slide__more::after {
  transform: translateX(4px);
}
.house .house-slide .house-slide__more .hovscroll {
  display: inline-block;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--btn-color), 0 0 0 var(--btn-color);
  transition: text-shadow 0.3s;
}
.house .house-slide:hover .hovscroll {
  text-shadow: 0 0 0 var(--btn-color), 0 -1.5em 0 var(--btn-color);
}
.house .house-next {
  display: block;
}
@media screen and (min-width:768px) {
  .house .house-next {
    display: none;
  }
}
@media screen and (min-width:768px) {
  .house .house-prev {
    display: block;
  }
}
.house .swiper-pagination {
  position: absolute;
  top: auto;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: auto;
}
@media screen and (min-width:768px) {
  .house .swiper-pagination {
    left: 0;
    transform: translateX(0%);
  }
}
.house .swiper-pagination-bullet {
  width: 4rem;
  height: 0.2rem;
  background: #F2F1EE;
  margin: 0 6px !important;
  transition: opacity 0.3s, background 0.3s;
  border-radius: 0;
}
@media screen and (min-width:768px) {
  .house .swiper-pagination-bullet {
    width: 7rem;
    transform: translateX(0%);
  }
}
.house .swiper-pagination-bullet-active {
  background: rgba(0, 0, 0, 0.1882352941);
  opacity: 1;
}
.house .house-prev,
.house .house-next {
  width: 40px;
  height: 40px;
  cursor: pointer;
  position: absolute;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
}
.house .house-prev::before {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-left: 2px solid #000;
  border-bottom: 2px solid #000;
  transform: rotate(45deg);
}
.house .house-next::before {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  transform: rotate(-45deg);
}
@media (min-width: 768px) {
  .house .house-prev {
    top: 50%;
    left: 50rem;
    transform: translateY(-50%);
  }
  .house .house-next {
    display: none;
  }
}
@media (max-width: 767px) {
  .house .house-prev {
    top: 58.5%;
    left: -3rem;
    transform: translateY(-50%);
  }
  .house .house-next {
    top: 58.5%;
    right: -3rem;
    transform: translateY(-50%);
  }
}

.faq {
  background: #E2DED5;
  /* FAQリスト */
  /* FAQアイテム */
}
.faq__inner {
  text-align: center;
  height: 100%;
  margin: auto;
  width: 89.7%;
  padding: 11.7rem 1.2rem 12rem;
}
@media screen and (min-width:768px) {
  .faq__inner {
    width: 120rem;
    padding: 12rem 0;
  }
}
.faq .c-section-label--faq {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.666;
  color: #323232;
  text-align: left;
}
@media screen and (min-width:768px) {
  .faq .c-section-label--faq {
    font-size: 1.6rem;
    line-height: 1.6875;
    text-align: center;
  }
}
.faq .c-section-title--faq {
  font-size: 2.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #323232;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .faq .c-section-title--faq {
    font-size: 3.2rem;
    line-height: 2.8125;
    text-align: center;
  }
}
.faq .c-section-title--faq::after {
  display: none;
}
.faq .c-btn--faq {
  margin: 5rem auto 0;
  color: #323232;
}
.faq .faq__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 1rem;
}
@media screen and (min-width:768px) {
  .faq .faq__list {
    gap: 1.6rem;
    margin-top: 4rem;
  }
}
.faq .faq-item {
  border-bottom: 0.1rem solid #323232;
  padding-bottom: 0;
  /* 質問部分（クリックする行） */
  /* SVG プラス／マイナスアイコン */
  /* 開いている時（縦線を消す → マイナスへ） */
  /* 回答部分（スムーズ開閉） */
  /* 開いたときの余白 */
}
@media screen and (min-width:768px) {
  .faq .faq-item {
    padding-bottom: 1.6rem;
  }
}
.faq .faq-item__question {
  width: 100%;
  display: flex;
  gap: 2rem;
  background: none;
  border: none;
  padding: 2.7rem 0 2rem;
  cursor: pointer;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: left;
  color: #222222;
}
@media screen and (min-width:768px) {
  .faq .faq-item__question {
    gap: 3rem;
    padding: 1.6rem 2.3rem 1.6rem 0;
  }
}
.faq .faq-item__q, .faq .faq-item__a {
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  line-height: 1;
  font-weight: 700;
  color: rgba(50, 50, 50, 0.2509803922);
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .faq .faq-item__q, .faq .faq-item__a {
    font-size: 2.6rem;
  }
}
.faq .faq-item__answer-inner {
  display: flex;
  justify-content: space-between;
  gap: 2rem;
  padding-right: 3.5rem;
}
@media screen and (min-width:768px) {
  .faq .faq-item__answer-inner {
    gap: 3rem;
  }
}
.faq .faq-item__question-text, .faq .faq-item__answer-text {
  flex: 1;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: left;
  color: #222222;
}
@media screen and (min-width:768px) {
  .faq .faq-item__question-text, .faq .faq-item__answer-text {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.faq .faq-item__icon {
  width: 1.5rem;
  height: 1.5rem;
}
@media screen and (min-width:768px) {
  .faq .faq-item__icon {
    width: 2rem;
    height: 2rem;
  }
}
.faq .faq-item__icon-svg {
  width: 100%;
  height: 100%;
}
.faq .faq-item .faq-icon-line {
  stroke: #323232;
  stroke-width: 0.2rem;
  stroke-linecap: round;
  transition: opacity 0.25s ease;
}
.faq .faq-item.is-open .faq-icon-line--v {
  opacity: 0;
}
.faq .faq-item__answer {
  max-height: 0;
  overflow: hidden;
  padding: 0;
  transition: max-height 0.4s ease;
}
.faq .faq-item.is-open {
  padding-bottom: 2rem;
}
.faq .faq-item.is-open .faq .faq-item__answer {
  padding-bottom: 1.6rem;
  padding-bottom: 2.4rem;
}

.faq-all .faq__inner {
  text-align: center;
  height: 100%;
  margin: auto;
  width: 89.7%;
  padding: 11.7rem 1.2rem 12rem;
}
@media screen and (min-width:768px) {
  .faq-all .faq__inner {
    width: 120rem;
    padding: 9.2rem 0 12rem;
  }
}

.message {
  position: relative;
  /* PC：横並び */
  /* 左テキスト */
  /* 右画像 */
  /* テキスト */
}
.message__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 10.7rem 0 7.2rem;
}
@media screen and (min-width:768px) {
  .message__inner {
    max-width: 120rem;
    padding: 15rem 4.5rem 8rem 11rem;
  }
}
.message__flex {
  display: flex;
  flex-direction: column;
  gap: 4rem;
}
@media screen and (min-width:768px) {
  .message__flex {
    flex-direction: row;
    justify-content: space-between;
    gap: 6rem;
  }
}
@media screen and (min-width:768px) {
  .message__content {
    padding-top: 3.5rem;
  }
}
@media screen and (min-width:768px) {
  .message__image {
    flex: 0 0 51.3rem;
  }
}
@media screen and (min-width:768px) {
  .message__body {
    margin-top: 3rem;
  }
}
.message__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #1C1107;
  margin-top: 1.7rem;
  margin-bottom: 2.2rem;
}
@media screen and (min-width:768px) {
  .message__text {
    font-size: 1.6rem;
    line-height: 2;
    margin: 0;
  }
}
.message__name {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2.2;
  color: #323232;
}
@media screen and (min-width:768px) {
  .message__name {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6875;
    margin-top: 3.3rem;
  }
}
.message__name span {
  font-size: 1.8rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #1C1107;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-left: 1.6rem;
}
@media screen and (min-width:768px) {
  .message__name span {
    font-size: 2.4rem;
    line-height: 1.9;
    margin-left: 0;
  }
}

.company-detail {
  position: relative;
  background: #E2DED5;
  /* 行 */
  /* 左：項目名 */
  /* 右：内容 */
}
.company-detail__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 8.8rem 0 9.8rem;
}
@media screen and (min-width:768px) {
  .company-detail__inner {
    max-width: 120rem;
    padding: 12rem 0 19rem;
  }
}
.company-detail__table {
  margin-top: 2.4rem;
}
@media screen and (min-width:768px) {
  .company-detail__table {
    margin-top: 5.7rem;
  }
}
.company-detail .company-detail__row {
  display: flex;
  flex-direction: column;
  border-bottom: 0.06rem solid #323232;
  gap: 1rem;
  padding: 1.4rem 0 1.2rem;
}
@media screen and (min-width:768px) {
  .company-detail .company-detail__row {
    flex-direction: row;
    gap: 0;
    padding: 1.5rem 0 1.1rem;
  }
}
.company-detail .company-detail__row dt {
  flex-shrink: 0;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.71;
  color: rgba(50, 50, 50, 0.2509803922);
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  width: 100%;
}
@media screen and (min-width:768px) {
  .company-detail .company-detail__row dt {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6875;
    color: #323232;
    width: 15rem;
  }
}
.company-detail .company-detail__row dd {
  flex: 1;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
}
@media screen and (min-width:768px) {
  .company-detail .company-detail__row dd {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 2;
  }
}
@media screen and (max-width:767px) {
  .company-detail .company-detail__row dd span {
    letter-spacing: 0em;
  }
}

.about-main {
  position: relative;
  background: #E2DED5;
}
.about-main__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 6rem 0 7.2rem;
}
@media screen and (min-width:768px) {
  .about-main__inner {
    max-width: 120rem;
    padding: 13rem 0 15.7rem;
  }
}
.about-main__logo {
  text-align: center;
}
.about-main__logo img {
  width: 19rem;
}
@media screen and (min-width:768px) {
  .about-main__logo img {
    max-width: 28.8rem;
  }
}
.about-main__catch {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #323232;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin: 2rem -0.6rem 1.5rem 0;
}
@media screen and (min-width:768px) {
  .about-main__catch {
    font-size: 3.2rem;
    line-height: 1.75;
    text-align: center;
    margin: 3.8rem 0 2.7rem;
  }
}
.about-main__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #1C1107;
}
@media screen and (min-width:768px) {
  .about-main__text {
    font-size: 1.6rem;
    line-height: 2.625;
    text-align: center;
  }
}

.about-vision {
  position: relative;
  background: url(../../assets/img/about/about-vision_bg_sp.jpg) no-repeat center center/cover;
}
@media screen and (min-width:768px) {
  .about-vision {
    background: url(../../assets/img/about/about-vision_bg_pc.jpg) no-repeat center center/cover;
  }
}
.about-vision__inner {
  height: 45.4rem;
  width: 84%;
  margin: auto;
}
@media screen and (min-width:768px) {
  .about-vision__inner {
    max-width: 120rem;
    height: 66.5rem;
  }
}
.about-vision__content {
  display: flex;
  align-items: center;
  flex-direction: column;
  height: 100%;
  padding-top: 8rem;
}
@media screen and (min-width:768px) {
  .about-vision__content {
    padding-top: 18.5rem;
  }
}
.about-vision__text {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #EAE7DF;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-bottom: 1.6rem;
}
@media screen and (min-width:768px) {
  .about-vision__text {
    font-size: 3.2rem;
    line-height: 1.875;
    text-align: center;
    margin-bottom: 4rem;
  }
}
.about-vision__text--small {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #EAE7DF;
}
@media screen and (min-width:768px) {
  .about-vision__text--small {
    font-size: 1.6rem;
    line-height: 2;
    text-align: center;
  }
}

.about-mission {
  position: relative;
}
.about-mission__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 8rem 0 6.5rem;
}
@media screen and (min-width:768px) {
  .about-mission__inner {
    max-width: 120rem;
    padding: 19.5rem 0 12rem;
  }
}
.about-mission__circles {
  margin-top: 4.5rem;
}
@media screen and (min-width:768px) {
  .about-mission__circles {
    margin-top: 9rem;
  }
}
@media screen and (max-width:767px) {
  .about-mission span.sp {
    letter-spacing: -0.045em;
  }
}

.about-promise {
  position: relative;
  background: linear-gradient(to top, #E2DED5, #EAE7DF);
  overflow: hidden;
}
.about-promise__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 9rem 0 11.5rem;
}
@media screen and (min-width:768px) {
  .about-promise__inner {
    max-width: 120rem;
    padding: 12rem 0 19.7rem;
  }
}
.about-promise .c-subheading-label {
  text-align: center;
}
.about-promise .c-subheading-title {
  text-align: center;
}
.about-promise__list {
  display: flex;
  flex-direction: column;
  gap: 5.2rem;
  margin-top: 5rem;
}
@media screen and (min-width:768px) {
  .about-promise__list {
    gap: 9.2rem;
    padding: 0 5rem 0 9rem;
    margin-top: 11rem;
  }
}
.about-promise .promise-item {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item {
    flex-direction: row;
    justify-content: space-between;
    gap: 12.7rem;
  }
}
.about-promise .promise-item__img {
  max-height: 240px;
  overflow: hidden;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item__img {
    width: 44rem;
    max-height: none;
  }
}
.about-promise .promise-item__img img {
  aspect-ratio: 357/238;
  -o-object-fit: contain;
     object-fit: contain;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item__img img {
    aspect-ratio: 440/294;
  }
}
@media screen and (max-width:767px) {
  .about-promise .promise-item__img--right {
    margin-right: calc(50% - 50vw);
    width: 100vw;
  }
}
@media screen and (max-width:767px) {
  .about-promise .promise-item__img--left {
    margin-left: calc(50% - 50vw);
  }
}
.about-promise .promise-item__content {
  flex: 1;
  padding-top: 4rem;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item__content {
    padding-top: 0.8rem;
  }
}
.about-promise .promise-item__label {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  text-align: left;
  color: #1C1107;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item__label {
    font-size: 1.6rem;
    line-height: 1.6875;
    color: #323232;
  }
}
.about-promise .promise-item__title {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #1C1107;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border-bottom: 0.06rem solid #323232;
  padding-bottom: 2.2rem;
  margin-bottom: 2.2rem;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item__title {
    font-size: 2.4rem;
    line-height: 2;
    color: #323232;
    padding-bottom: 2rem;
    margin-bottom: 2.2rem;
    margin-top: 0.7rem;
  }
}
.about-promise .promise-item__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: left;
  color: #222222;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .about-promise .promise-item__text {
    font-size: 1.6rem;
    line-height: 1.6875;
    color: #323232;
  }
}

.facility-list {
  position: relative;
  background: #EAE7DF;
}
.facility-list__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 10rem 0 5rem;
}
@media screen and (min-width:768px) {
  .facility-list__inner {
    max-width: 120rem;
    padding: 15rem 0 12rem;
  }
}
.facility-list__flex {
  display: flex;
  flex-direction: column;
  margin-bottom: 8rem;
}
@media screen and (min-width:768px) {
  .facility-list__flex {
    flex-direction: row;
    align-items: center;
    margin-bottom: 12rem;
  }
}
.facility-list__flex:last-child {
  margin-bottom: 0;
}
.facility-list .facility-slider {
  width: 100%;
}
@media screen and (min-width:768px) {
  .facility-list .facility-slider {
    width: 60rem;
  }
}
.facility-list .facility-slider img {
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 326/264;
}
@media screen and (min-width:768px) {
  .facility-list .facility-slider img {
    aspect-ratio: 600/400;
  }
}
.facility-list__content {
  flex: 1;
  margin-top: 3rem;
}
@media screen and (min-width:768px) {
  .facility-list__content {
    padding: 0 5rem 0 6rem;
    margin-top: -3rem;
  }
}
.facility-list__number {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  text-align: left;
  color: #1C1107;
}
@media screen and (min-width:768px) {
  .facility-list__number {
    font-size: 1.6rem;
    line-height: 1.6875;
    color: #323232;
  }
}
.facility-list__title {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #1C1107;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border-bottom: 0.06rem solid #323232;
  padding-bottom: 2.2rem;
  margin-bottom: 2rem;
}
@media screen and (min-width:768px) {
  .facility-list__title {
    font-size: 2.4rem;
    line-height: 2;
    color: #323232;
    padding-bottom: 1rem;
    margin-bottom: 2rem;
  }
}
.facility-list__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  text-align: left;
  color: #222222;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-bottom: 3.2rem;
}
@media screen and (min-width:768px) {
  .facility-list__text {
    font-size: 1.6rem;
    line-height: 1.6875;
    color: #323232;
    margin-bottom: 5rem;
  }
}
.facility-list .c-btn--facility-list {
  color: #323232;
}
.facility-list .facility-slider {
  padding-bottom: 3rem;
}
.facility-list .facility-pagination {
  position: absolute;
  top: auto;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: auto;
}
@media screen and (min-width:768px) {
  .facility-list .facility-pagination {
    left: 0;
    transform: translateX(0);
  }
}
.facility-list .facility-pagination .swiper-pagination-bullet {
  width: 4rem;
  height: 0.3rem;
  background: #F2F1EE;
  border-radius: 0;
  opacity: 0.3;
  margin: 0 6px !important;
  transition: opacity 0.3s, background 0.3s;
}
@media screen and (min-width:768px) {
  .facility-list .facility-pagination .swiper-pagination-bullet {
    width: 7rem;
    height: 0.3rem;
  }
}
.facility-list .facility-pagination .swiper-pagination-bullet-active {
  background: rgba(0, 0, 0, 0.1882352941);
  /* アクティブの色 */
  opacity: 1;
}

.house-info {
  position: relative;
  background: #EAE7DF;
  /* 行 */
  /* 左：項目名 */
  /* 右：内容 */
}
.house-info__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 8rem 0 9.5rem;
}
@media screen and (min-width:768px) {
  .house-info__inner {
    max-width: 120rem;
    padding: 11.5rem 0 13rem;
  }
}
.house-info__table {
  margin-top: 2.4rem;
}
@media screen and (min-width:768px) {
  .house-info__table {
    margin-top: 5.7rem;
  }
}
.house-info__row {
  display: flex;
  flex-direction: column;
  border-bottom: 0.06rem solid #323232;
  gap: 1rem;
  padding: 1.4rem 0 1.2rem;
}
@media screen and (min-width:768px) {
  .house-info__row {
    flex-direction: row;
    gap: 0;
    padding: 1.8rem 0 1.3rem;
  }
}
.house-info__row dt {
  flex-shrink: 0;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.71;
  color: rgba(50, 50, 50, 0.2509803922);
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  width: 100%;
}
@media screen and (min-width:768px) {
  .house-info__row dt {
    font-size: 1.6rem;
    letter-spacing: 0.04em;
    line-height: 1.6875;
    color: #323232;
    width: 21rem;
  }
}
.house-info__row dd {
  flex: 1;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
}
@media screen and (min-width:768px) {
  .house-info__row dd {
    font-size: 1.6rem;
    letter-spacing: 0.1em;
    line-height: 1.6875;
  }
}
@media screen and (max-width:767px) {
  .house-info__row dd span {
    letter-spacing: 0em;
  }
}

.house-point {
  position: relative;
}
.house-point__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 8rem 0 7.5rem;
}
@media screen and (min-width:768px) {
  .house-point__inner {
    max-width: 120rem;
    padding: 12rem 0 11.5rem;
  }
}
.house-point__grid {
  display: grid;
  gap: 7.2rem;
}
@media screen and (min-width:768px) {
  .house-point__grid {
    grid-template-columns: 1fr 1fr;
    gap: 7rem;
  }
}
.house-point__img img {
  display: block;
  aspect-ratio: 326/264;
  -o-object-fit: cover;
     object-fit: cover;
  margin-bottom: 3rem;
}
@media screen and (min-width:768px) {
  .house-point__img img {
    margin-bottom: 1.2rem;
    aspect-ratio: 560/373;
  }
}
.house-point__number {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
  text-align: left;
}
@media screen and (min-width:768px) {
  .house-point__number {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.house-point__title {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #323232;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border-bottom: 0.06rem solid #323232;
  margin-bottom: 2.3rem;
  padding-bottom: 2.1rem;
}
@media screen and (min-width:768px) {
  .house-point__title {
    font-size: 2.4rem;
    line-height: 2;
    margin-top: 0.7rem;
    margin-bottom: 2rem;
    padding-bottom: 1.8rem;
  }
}
.house-point__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
  text-align: left;
}
@media screen and (min-width:768px) {
  .house-point__text {
    font-size: 1.6rem;
    line-height: 2;
  }
}

.house-detail-hero {
  position: relative;
  background: #EAE7DF;
  /* =========================
      スライダー
  ========================== */
  /* Swiper：1枚表示 & 中央配置（追加） */
  /* =========================
      📝 テキスト配置
  ========================== */
  /* テキストの既存スタイルを変更しない */
}
.house-detail-hero__inner {
  position: relative;
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 16rem 0 7.3rem;
}
@media screen and (min-width:768px) {
  .house-detail-hero__inner {
    max-width: 120rem;
    padding: 27.5rem 0 11.3rem;
  }
}
.house-detail-hero .breadcrumb {
  position: absolute;
  top: 7rem;
  bottom: auto;
  left: 0;
}
@media screen and (min-width:768px) {
  .house-detail-hero .breadcrumb {
    top: 12rem;
    left: 0;
    bottom: auto;
  }
}
.house-detail-hero__flex {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}
@media screen and (min-width:768px) {
  .house-detail-hero__flex {
    flex-direction: row;
    gap: 6rem;
    align-items: center;
    position: relative;
  }
}
.house-detail-hero__slider {
  width: 100%;
  position: relative;
}
.house-detail-hero__slider img {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 326/264;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width:768px) {
  .house-detail-hero__slider img {
    aspect-ratio: 1200/700;
  }
}
.house-detail-hero .swiper-wrapper {
  display: flex;
  align-items: center;
}
.house-detail-hero .swiper-slide {
  display: flex;
  justify-content: center;
  align-items: center;
}
.house-detail-hero .house-detail-pagination {
  position: relative;
  text-align: center;
  margin-top: 3rem;
}
.house-detail-hero .house-detail-pagination .swiper-pagination-bullet {
  width: 4rem;
  height: 0.3rem;
  background: #F2F1EE;
  border-radius: 0;
  opacity: 0.3;
  margin: 0 6px !important;
  transition: opacity 0.3s, background 0.3s;
}
@media screen and (min-width:768px) {
  .house-detail-hero .house-detail-pagination .swiper-pagination-bullet {
    width: 7rem;
    height: 0.3rem;
  }
}
.house-detail-hero .house-detail-pagination .swiper-pagination-bullet-active {
  background: rgba(0, 0, 0, 0.1882352941);
  opacity: 1;
}
.house-detail-hero__content {
  margin-top: 1rem;
}
@media screen and (min-width:768px) {
  .house-detail-hero__content {
    width: 70%;
    position: absolute;
    bottom: 10rem;
    left: 4rem;
    z-index: 5;
    background: rgba(234, 231, 223, 0.4392156863);
    padding: 1rem;
  }
}
.house-detail-hero__label {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
  text-align: left;
}
@media screen and (min-width:768px) {
  .house-detail-hero__label {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.house-detail-hero__title {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #323232;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border-bottom: 0.06rem solid #323232;
  padding-bottom: 2.2rem;
  margin-bottom: 2.3rem;
}
@media screen and (min-width:768px) {
  .house-detail-hero__title {
    font-size: 3.2rem;
    line-height: 1.875;
    margin-bottom: 3rem;
  }
}
.house-detail-hero__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
  text-align: left;
}
@media screen and (min-width:768px) {
  .house-detail-hero__text {
    font-size: 1.6rem;
    line-height: 2;
  }
}

.reserve__inner {
  margin: auto;
  width: 84%;
  padding: 8rem 0 8rem;
}
@media screen and (min-width:768px) {
  .reserve__inner {
    max-width: 120rem;
    padding: 11rem 0 12rem;
    text-align: center;
  }
}
.reserve .c-subheading-title,
.reserve .c-subheading-label {
  text-align: center;
}
.reserve__list {
  display: flex;
  flex-direction: column;
  gap: 3rem;
  margin-top: 4.3rem;
}
@media screen and (min-width:768px) {
  .reserve__list {
    flex-direction: row;
    justify-content: space-between;
    margin-top: 7rem;
  }
}
.reserve__list--center {
  justify-content: center;
}

/* 予約バナー */
.reserve-item {
  position: relative;
  width: 100%;
  overflow: hidden;
  /* ======================================
     画像（ホバーで拡大）
  ====================================== */
  /* ホバー時に画像をズーム */
  /* ======================================
     テキストオーバーレイ
  ====================================== */
  /* ======================================
     MORE ボタン（ホバーで矢印スライド）
  ====================================== */
  /* ホバーで矢印が右にスライド */
}
@media screen and (min-width:768px) {
  .reserve-item {
    max-width: 55.9rem;
  }
}
.reserve-item__img {
  overflow: hidden;
}
.reserve-item__img img {
  aspect-ratio: 324/216;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.6s ease;
  transform: scale(1);
}
@media screen and (min-width:768px) {
  .reserve-item__img img {
    aspect-ratio: 559/373;
  }
}
.reserve-item:hover .reserve-item__img img {
  transform: scale(1.05);
}
.reserve-item__content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  z-index: 2;
}
.reserve-item__label {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #EAE7DF;
}
@media screen and (min-width:768px) {
  .reserve-item__label {
    font-size: 1.6rem;
    line-height: 1.6875;
  }
}
.reserve-item__title {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #EAE7DF;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin-bottom: 1rem;
}
@media screen and (min-width:768px) {
  .reserve-item__title {
    font-size: 3.2rem;
    margin-bottom: 4rem;
  }
}
.reserve-item__more {
  position: relative;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #EAE7DF;
  --btn-color: #EAE7DF;
  text-align: left;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  padding-bottom: 1rem;
  width: 15rem;
}
@media screen and (min-width:768px) {
  .reserve-item__more {
    font-size: 1.6rem;
    line-height: 1.1875;
    width: 15rem;
  }
}
.reserve-item__more::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 15rem;
  height: 0.06rem;
  background: #EAE7DF;
}
.reserve-item__more::after {
  content: "";
  display: block;
  background: url(../../assets/img/common/i-arrow-w.png) no-repeat center center/contain;
  height: 0.8rem;
  width: 0.8rem;
  transition: transform 0.2s ease-out;
}
.reserve-item:hover .reserve-item__more::after {
  transform: translateX(4px);
}
.reserve-item__more .hovscroll {
  display: inline-block;
  overflow: hidden;
  color: transparent;
  text-shadow: 0 1.5em 0 var(--btn-color), 0 0 0 var(--btn-color);
  transition: text-shadow 0.3s;
}
.reserve-item:hover .hovscroll {
  text-shadow: 0 0 0 var(--btn-color), 0 -1.5em 0 var(--btn-color);
}

.news-list {
  position: relative;
  background: #EAE7DF;
}
.news-list__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 6.7rem 0 5rem;
}
@media screen and (min-width:768px) {
  .news-list__inner {
    max-width: 120rem;
    padding: 13.5rem 0 7.4rem;
  }
}
.news-list .news-item {
  position: relative;
  display: block;
  border-bottom: 0.06rem solid #323232;
  margin-bottom: 1.6rem;
  transition: background-color 0.2s ease-out;
}
@media screen and (min-width:768px) {
  .news-list .news-item {
    display: grid;
    grid-template-columns: 14rem auto 1fr;
    align-items: center;
    padding: 1.1rem 7rem 1.2rem 0;
    margin-bottom: 0;
  }
}
.news-list .news-item::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 3rem;
  transform: translate(-50%, 0);
  background: url(../../assets/img/common/i-arrow-b.png) no-repeat center center/contain;
  height: 0.8rem;
  width: 0.8rem;
  transition: transform 0.2s ease-out;
}
.news-list .news-item:hover {
  background-color: rgba(0, 0, 0, 0.031372549);
}
.news-list .news-item:hover::after {
  transform: translateX(4px);
}
.news-list .news-item__date, .news-list .news-item__cat {
  display: inline-block;
}
.news-list .news-item__date {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: rgba(50, 50, 50, 0.2509803922);
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .news-list .news-item__date {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.news-list .news-item__cat {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  text-align: center;
  color: #323232;
  background: #E2DED5;
  min-width: auto;
  padding: 0.2rem 1rem;
  margin: 0 0 0 0.8rem;
}
@media screen and (min-width:768px) {
  .news-list .news-item__cat {
    font-size: 1.6rem;
    line-height: 1.6875;
    color: #323232;
    min-width: 11rem;
    margin: 0 2rem 0 0;
    padding: 0.5rem 0.5rem;
  }
}
.news-list .news-item__title {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.75;
  text-align: left;
  color: #323232;
  margin: 1rem 0 1.3rem 0;
}
@media screen and (min-width:768px) {
  .news-list .news-item__title {
    font-size: 1.6rem;
    line-height: 1.6875;
    margin: 0;
  }
}

.news-pagination {
  text-align: center;
  padding-bottom: 8rem;
}
@media screen and (min-width:768px) {
  .news-pagination {
    padding-bottom: 12rem;
  }
}
.news-pagination a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #323232;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border: 0.06rem solid #323232;
  height: 3.2rem;
  width: 3.2rem;
  margin: 0 0.5rem;
}
@media screen and (min-width:768px) {
  .news-pagination a {
    font-size: 2.2rem;
    border: 0.06rem solid #323232;
    height: 5rem;
    width: 5rem;
    margin: 0 0.7rem;
  }
}
.news-pagination span {
  font-size: 3rem;
  margin: 0 0.8rem;
}
.news-pagination span.current {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
  text-align: center;
  color: #EAE7DF;
  background: #323232;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border: 0.06rem solid #323232;
  height: 3.2rem;
  width: 3.2rem;
  margin: 0 0.5rem;
}
@media screen and (min-width:768px) {
  .news-pagination span.current {
    font-size: 2.2rem;
    border: 0.06rem solid #323232;
    height: 5rem;
    width: 5rem;
    margin: 0 0.7rem;
  }
}
.news-pagination a.next.page-numbers,
.news-pagination a.prev.page-numbers {
  display: none;
}

.news-detail {
  position: relative;
  background: #EAE7DF;
}
.news-detail__inner {
  position: relative;
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 16rem 0 7.3rem;
}
@media screen and (min-width:768px) {
  .news-detail__inner {
    max-width: 120rem;
    padding: 27.5rem 0 11.3rem;
  }
}
.news-detail .breadcrumb {
  position: absolute;
  top: 7rem;
  bottom: auto;
  left: 0;
}
@media screen and (min-width:768px) {
  .news-detail .breadcrumb {
    top: 12rem;
    left: 0;
    bottom: auto;
  }
}
.news-detail__cat {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  text-align: left;
  color: #323232;
  background: #E2DED5;
  min-width: auto;
  padding: 0.2rem 1rem;
  margin: 0 1rem 0 0;
}
@media screen and (min-width:768px) {
  .news-detail__cat {
    font-size: 1.6rem;
    line-height: 1.6875;
    min-width: 11rem;
    margin: 0 2rem 0 0;
    padding: 0.5rem 2rem;
  }
}
.news-detail__title {
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  text-align: left;
  color: #323232;
  margin: 0 0 1rem 0;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
}
@media screen and (min-width:768px) {
  .news-detail__title {
    font-size: 3.2rem;
    line-height: 2;
    margin: 0 0 1.5rem 0;
  }
}
.news-detail__date {
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.66;
  text-align: left;
  color: rgba(50, 50, 50, 0.2509803922);
  margin: 0 0 3rem 0;
}
@media screen and (min-width:768px) {
  .news-detail__date {
    font-size: 1.6rem;
    line-height: 1.6875;
    color: rgba(50, 50, 50, 0.2509803922);
    margin: 0 0 5rem 0;
  }
}
.news-detail__back {
  text-align: center;
  margin-top: 7rem;
}
@media screen and (min-width:768px) {
  .news-detail__back {
    margin-top: 5rem;
  }
}
.news-detail__btn--black {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1.6rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 2;
  color: #323232;
  border: 0.06rem solid #222222;
  margin: auto;
  width: 12rem;
  height: 4rem;
}
@media screen and (min-width:768px) {
  .news-detail__btn--black {
    font-size: 2rem;
    line-height: 1;
    font-weight: 500;
    width: 14.4rem;
    height: 6rem;
  }
}
.news-detail__content {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
  /* マーカー種類を明示 */
  /* ネスト時の見た目（任意） */
  /* 項目間の間隔（任意） */
}
@media screen and (min-width:768px) {
  .news-detail__content {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.news-detail__content h1 {
  position: relative;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  background: #E2DED5;
  border-left: 0.8rem solid rgba(50, 50, 50, 0.2509803922);
  margin: 1em 0;
  padding: 0 2rem;
}
@media screen and (min-width:768px) {
  .news-detail__content h1 {
    font-size: 2.4rem;
    line-height: 2;
    border-left: 1rem solid rgba(50, 50, 50, 0.2509803922);
    margin: 1.5em 0;
    padding: 0 2.5rem;
  }
}
.news-detail__content h2 {
  position: relative;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  border-left: 0.8rem solid rgba(50, 50, 50, 0.2509803922);
  margin: 1em 0;
  padding: 0 2rem;
}
@media screen and (min-width:768px) {
  .news-detail__content h2 {
    font-size: 2.4rem;
    line-height: 2;
    border-left: 1rem solid rgba(50, 50, 50, 0.2509803922);
    margin: 1.5em 0;
    padding: 0 2.5rem;
  }
}
.news-detail__content h3 {
  position: relative;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin: 1em 0;
  padding: 0 2rem;
}
@media screen and (min-width:768px) {
  .news-detail__content h3 {
    font-size: 2.4rem;
    line-height: 2;
    margin: 1.5em 0;
    padding: 0 2.5rem;
  }
}
.news-detail__content h4,
.news-detail__content h5 {
  position: relative;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  margin: 1em 0;
  padding: 0 2rem;
}
@media screen and (min-width:768px) {
  .news-detail__content h4,
  .news-detail__content h5 {
    font-size: 2.4rem;
    line-height: 2;
    margin: 1.5em 0;
    padding: 0 2.5rem;
  }
}
.news-detail__content p {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
  margin: 1em 0;
}
@media screen and (min-width:768px) {
  .news-detail__content p {
    font-size: 1.6rem;
    line-height: 2;
    margin: 1.5em 0;
  }
}
.news-detail__content a {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
  margin: 1em 0;
  text-decoration: underline;
}
@media screen and (min-width:768px) {
  .news-detail__content a {
    font-size: 1.6rem;
    line-height: 2;
    margin: 1.5em 0;
  }
}
.news-detail__content a:hover {
  text-decoration: none;
}
.news-detail__content ul,
.news-detail__content ol {
  margin: 1em 0;
  padding-left: 1.2em;
  list-style-position: inside;
}
@media screen and (min-width:768px) {
  .news-detail__content ul,
  .news-detail__content ol {
    margin: 1.5em 0;
  }
}
.news-detail__content ul {
  list-style-type: disc;
}
.news-detail__content ol {
  list-style-type: decimal;
}
.news-detail__content ul ul {
  list-style-type: circle;
}
.news-detail__content ul ul ul {
  list-style-type: square;
}
.news-detail__content ol ol {
  list-style-type: lower-alpha;
}
.news-detail__content ol ol ol {
  list-style-type: lower-roman;
}
.news-detail__content li + li {
  margin-top: 0.3em;
}
.news-detail__content li {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #323232;
}
@media screen and (min-width:768px) {
  .news-detail__content li {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.news-detail__content table th,
.news-detail__content table td {
  padding: 1em;
}
.news-detail__content img {
  width: auto;
  height: auto;
  max-width: 100%;
  margin-bottom: 1em;
}
@media screen and (min-width:768px) {
  .news-detail__content img {
    margin-bottom: 1.5em;
  }
}

.privacypolicy {
  position: relative;
  background: #EAE7DF;
}
.privacypolicy__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 6.5rem 0 8.5rem;
}
@media screen and (min-width:768px) {
  .privacypolicy__inner {
    max-width: 120rem;
    padding: 14.2rem 0 11.5rem;
  }
}
.privacypolicy__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #222222;
  text-align: left;
}
@media screen and (min-width:768px) {
  .privacypolicy__text {
    font-size: 1.6rem;
    line-height: 2;
  }
}

.contact {
  position: relative;
  background: #EAE7DF;
  /* ---------------------------------------------
     Form Base
  --------------------------------------------- */
}
.contact__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 7rem 0 6rem;
}
@media screen and (min-width:768px) {
  .contact__inner {
    max-width: 120rem;
    padding: 15rem 0 8.7rem;
  }
}
.contact .contact-form {
  width: 100%;
  /* ---------------------------------------------
     Inputs / Select / Textarea
  --------------------------------------------- */
  /* placeholder（通常状態） */
  /* ▼ 初期表示（最初の option）のみ薄い色にする */
  /* ---------------------------------------------
     Error Message
  --------------------------------------------- */
  /* ---------------------------------------------
     Radio Buttons
  --------------------------------------------- */
  /* ラジオボタンのベースを非表示（見た目だけ隠す） */
  /* 選択時の中の丸（●） */
  /* 選択された時に丸が出る */
  /* ---------------------------------------------
     Privacy Checkbox
  --------------------------------------------- */
  /* チェックボックスの見た目をカスタム */
  /* チェックマーク（✓） */
  /* チェックされた時に ✓ を表示 */
  /* ---------------------------------------------
     Submit Button
  --------------------------------------------- */
}
.contact .contact-form__row {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
  margin-bottom: 2.3rem;
}
@media screen and (min-width:768px) {
  .contact .contact-form__row {
    flex-direction: row;
    gap: 0;
    margin-bottom: 3.5rem;
  }
}
.contact .contact-form__label {
  display: block;
  font-size: 1.4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 2;
  font-family: "Shippori Mincho", "游明朝 Medium", "Yu Mincho Medium", "YuMincho", serif;
  color: #323232;
}
@media screen and (min-width:768px) {
  .contact .contact-form__label {
    font-size: 1.6rem;
    line-height: 2;
    min-width: 31.5rem;
  }
}
.contact .contact-form__required {
  display: inline-block;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.5;
  color: #323232;
  background: #E2DED5;
  padding: 0 0.8rem;
  margin-left: 0.7rem;
}
@media screen and (min-width:768px) {
  .contact .contact-form__required {
    font-size: 1.4rem;
    margin-left: 1rem;
    padding: 0 1rem;
  }
}
.contact .contact-form__field {
  width: 100%;
}
.contact .contact-form .contact-form__input,
.contact .contact-form .contact-form__select,
.contact .contact-form .contact-form__textarea {
  width: 100%;
  background: #fff;
  border: none;
  border-radius: 0.4rem;
  padding: 1rem 2rem;
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}
@media screen and (min-width:768px) {
  .contact .contact-form .contact-form__input,
  .contact .contact-form .contact-form__select,
  .contact .contact-form .contact-form__textarea {
    font-size: 1.6rem;
    padding: 1.4rem 2rem;
  }
}
.contact .contact-form .contact-form__textarea {
  height: 15.6rem;
  resize: vertical;
}
@media screen and (min-width:768px) {
  .contact .contact-form .contact-form__textarea {
    height: 14rem;
  }
}
.contact .contact-form .contact-form__input:focus,
.contact .contact-form .contact-form__select:focus,
.contact .contact-form .contact-form__textarea:focus {
  outline: none;
}
.contact .contact-form__input::-moz-placeholder, .contact .contact-form__textarea::-moz-placeholder {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
  opacity: 0.4;
}
.contact .contact-form__input::placeholder, .contact .contact-form__textarea::placeholder {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
  opacity: 0.4;
}
@media screen and (min-width:768px) {
  .contact .contact-form__input::-moz-placeholder, .contact .contact-form__textarea::-moz-placeholder {
    font-size: 1.6rem;
  }
  .contact .contact-form__input::placeholder, .contact .contact-form__textarea::placeholder {
    font-size: 1.6rem;
  }
}
.contact .contact-form__input:focus::-moz-placeholder, .contact .contact-form__textarea:focus::-moz-placeholder {
  color: #323232;
  opacity: 0.4;
}
.contact .contact-form__input:focus::placeholder, .contact .contact-form__textarea:focus::placeholder {
  color: #323232;
  opacity: 0.4;
}
.contact .contact-form .contact-form__select > option {
  color: rgba(50, 50, 50, 0.2509803922);
}
.contact .contact-form .wpcf7-form-control-wrap {
  position: relative;
  width: 100%;
}
.contact .contact-form .wpcf7-not-valid-tip {
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.66;
  letter-spacing: 0.1em;
  color: #323232;
  margin-top: 1.1rem;
}
.contact .contact-form__row--radio {
  display: flex;
  flex-direction: column;
  gap: 1.2rem;
}
@media screen and (min-width:768px) {
  .contact .contact-form__row--radio {
    flex-direction: row;
    gap: 0;
  }
}
.contact .contact-form .wpcf7-list-item {
  margin: 0;
}
.contact .contact-form__radio {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: 1rem;
}
@media screen and (min-width:768px) {
  .contact .contact-form__radio {
    align-items: center;
  }
}
.contact .contact-form__radio span {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
}
@media screen and (min-width:768px) {
  .contact .contact-form__radio span {
    font-size: 1.6rem;
  }
}
.contact .contact-form__radio input[type=radio] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 2.6rem;
  height: 2.6rem;
  border: 1px solid #323232;
  /* 未選択枠の色 */
  border-radius: 50%;
  display: inline-block;
  position: relative;
  cursor: pointer;
  background: #fff;
  vertical-align: middle;
  margin: 0;
}
@media screen and (min-width:768px) {
  .contact .contact-form__radio input[type=radio] {
    width: 3rem;
    height: 3rem;
  }
}
.contact .contact-form__radio input[type=radio]::after {
  content: "";
  width: 1.8rem;
  height: 1.8rem;
  background: #323232;
  /* ← チェック色（サイトのブラウンに合わせる） */
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(0);
  transition: 0.2s ease;
}
.contact .contact-form__radio input[type=radio]:checked::after {
  transform: translate(-50%, -50%) scale(1);
}
.contact .contact-form__row--privacy {
  margin-top: 3rem;
  margin-bottom: 4.5rem;
  padding-left: 0;
}
@media screen and (min-width:768px) {
  .contact .contact-form__row--privacy {
    margin-top: 0;
    margin-bottom: 0;
    padding-left: 31.5rem;
  }
}
.contact .contact-form__row--privacy .contact-form__checkbox {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.66;
  color: #323232;
}
@media screen and (min-width:768px) {
  .contact .contact-form__row--privacy .contact-form__checkbox {
    justify-content: flex-start;
    font-size: 1.6rem;
  }
}
.contact .contact-form__checkbox input[type=checkbox] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 2.3rem;
  height: 2.3rem;
  border: none;
  background: #fff;
  cursor: pointer;
  display: inline-block;
  position: relative;
  border-radius: 0.2rem;
}
@media screen and (min-width:768px) {
  .contact .contact-form__checkbox input[type=checkbox] {
    width: 3rem;
    height: 3rem;
  }
}
.contact .contact-form__checkbox input[type=checkbox]::after {
  content: "";
  position: absolute;
  width: 0.8rem;
  height: 1.4rem;
  border-right: 0.2rem solid #323232;
  /* マーク色 */
  border-bottom: 0.2rem solid #323232;
  transform: rotate(45deg) scale(0);
  top: 0.5rem;
  left: 1.1rem;
  transition: 0.2s ease;
}
.contact .contact-form__checkbox input[type=checkbox]:checked::after {
  transform: rotate(45deg) scale(1);
}
.contact .contact-form .contact-form__row--submit {
  text-align: center;
  padding-left: 0;
}
@media screen and (min-width:768px) {
  .contact .contact-form .contact-form__row--submit {
    padding-left: 31.5rem;
  }
}
.contact .contact-form .contact-form__submit {
  display: inline-block;
  background: #2e2e2e;
  color: #fff;
  font-weight: 500;
  padding: 1.2rem 3.5rem;
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: 0.05em;
  width: 14rem;
  margin: auto;
  border: none;
  cursor: pointer;
  transition: opacity 0.2s;
}
@media screen and (min-width:768px) {
  .contact .contact-form .contact-form__submit {
    font-size: 2rem;
    padding: 1.6rem 3.6rem;
    margin: 4rem 0 0;
    width: 15.7rem;
  }
}
.contact .contact-form .contact-form__submit:hover {
  opacity: 0.8;
}

.thanks {
  position: relative;
  background: #EAE7DF;
}
.thanks__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 6.7rem 0 7.2rem;
}
@media screen and (min-width:768px) {
  .thanks__inner {
    max-width: 120rem;
    padding: 14.3rem 0 11.5rem;
  }
}
.thanks__text,
.thanks a {
  position: relative;
  z-index: 4;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #222222;
  text-align: left;
}
@media screen and (min-width:768px) {
  .thanks__text,
  .thanks a {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.thanks__text {
  margin-bottom: 1.5rem;
}
@media screen and (min-width:768px) {
  .thanks__text {
    margin-bottom: 3.4rem;
  }
}
.thanks a {
  text-decoration: underline;
  transition: 0.2s;
}
.thanks a:hover {
  text-decoration: none;
}

/* select のカスタム（アイコン追加） */
.select-wrap {
  position: relative;
  width: 100%;
}
.select-wrap::before {
  content: "";
  display: block;
  position: absolute;
  top: 1rem;
  right: 2rem;
  background: url(../img/common/select-arrow.svg) no-repeat center center/contain;
  width: 2rem;
  height: 2rem;
  z-index: 3;
}
@media screen and (min-width:768px) {
  .select-wrap::before {
    top: 1.5rem;
    width: 3rem;
    height: 3rem;
  }
}

section {
  position: relative;
}

#gradient-canvas {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
  z-index: 0;
  /* お好みの色を設定 */
  --gradient-color-1: #e2ded5;
  --gradient-color-2: #e9e7df;
  --gradient-color-3: #ccc7bd;
  --gradient-color-4: #e2ded5;
}

.notfound__inner {
  height: 100%;
  width: 84%;
  margin: auto;
  padding: 6.5rem 0 8.5rem;
}
@media screen and (min-width:768px) {
  .notfound__inner {
    max-width: 120rem;
    padding: 14.2rem 0 11.5rem;
  }
}
.notfound__text {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #222222;
  text-align: left;
}
@media screen and (min-width:768px) {
  .notfound__text {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.notfound__btn-area {
  margin-top: 3rem;
}
@media screen and (min-width:768px) {
  .notfound__btn-area {
    margin-top: 5rem;
  }
}
.notfound__btn {
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 2;
  color: #222222;
  text-align: left;
  text-decoration: underline;
}
@media screen and (min-width:768px) {
  .notfound__btn {
    font-size: 1.6rem;
    line-height: 2;
  }
}
.notfound__btn:hover {
  text-decoration: none;
}

@media screen and (min-width:768px) {
  .sp-inlineblock {
    display: inline-block !important;
  }
}
@media screen and (max-width:767px) {
  .sp-inlineblock {
    display: none !important;
  }
}

@media screen and (max-width:767px) {
  .pc-only {
    display: none !important;
  }
}
@media screen and (min-width:768px) {
  .pc-only {
    display: block !important;
  }
}

@media screen and (max-width:767px) {
  .sp-inlineblocknone {
    display: inline-block !important;
  }
}
@media screen and (min-width:768px) {
  .sp-inlineblocknone {
    display: none !important;
  }
}

@media screen and (max-width:767px) {
  .sp-only {
    display: block !important;
  }
}
@media screen and (min-width:768px) {
  .sp-only {
    display: none !important;
  }
}/*# sourceMappingURL=style.css.map */