@charset "UTF-8";
/*###################################################################
※※※※ 直接編集禁止 ※※※※
このCSSファイルはSassから生成されていますので直接編集しないようご注意ください。
  編集は拡張子「.scss」ファイルを編集して当ファイルにコンパイルしてください。
  もしくは別途cssファイルを作成して読み込ませてください。
###################################################################*/
:root {
  --base: #fff;
  --base-b: #f1f3fa;
  --main: #2c3654;
  --text: #333;
  --spacing: 0.06em;
}

/*###################################################################
  base（共通設定）
###################################################################*/
* {
  letter-spacing: var(--spacing);
}

/*----------------------------------
  html
----------------------------------*/
html {
  scroll-behavior: smooth;
}

[id] {
  scroll-margin-top: 113px;
}

body {
  color: var(--text);
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.75;
  font-weight: 500;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

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

dt {
  font-weight: 400;
}

/*###################################################################
  animation（共通設定）
###################################################################*/
/*----------------------------------
  mv-title
----------------------------------*/
@-webkit-keyframes mvTitle {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
@keyframes mvTitle {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
  }
}
/*----------------------------------
  zoom
----------------------------------*/
@-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);
  }
}
@-webkit-keyframes zoomUpSp {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes zoomUpSp {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
/*###################################################################
  header（module）
###################################################################*/
.header {
  width: 100%;
  position: absolute;
  top: 0;
  z-index: 10;
}
@media (max-width: 768px) {
  .header {
    position: static;
  }
}
.header_sticky {
  position: fixed;
  background-color: rgba(44, 54, 84, 0.9);
}
@media (max-width: 768px) {
  .header_sticky {
    background: var(--base);
  }
}
.header_sticky .header__inner {
  padding-bottom: 10px;
}
@media (max-width: 768px) {
  .header_sticky .header__inner {
    padding-bottom: 0;
  }
}
.header__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  padding: 4px clamp(0.4375rem, -2.5722847358rem + 6.2622309198vw, 2.4375rem) 0 7px;
}
@media (max-width: 768px) {
  .header__inner {
    height: 56px;
    padding: 0 7px 0 10px;
  }
}
.header__logo {
  max-width: clamp(15.1875rem, -7.3689079422rem + 46.9314079422vw, 39.5625rem);
  width: 100%;
}
.header__info {
  max-width: clamp(28.125rem, 4.0556656101rem + 50.0792393027vw, 47.875rem);
  width: 100%;
}
@media (max-width: 768px) {
  .header__info {
    display: none;
  }
}
.header__box {
  max-width: clamp(24.375rem, 14.0288649706rem + 21.5264187867vw, 31.25rem);
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
  margin-left: auto;
}
.header__tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 7px;
     -moz-column-gap: 7px;
          column-gap: 7px;
  color: #f66009;
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1.25rem, 0.685665362rem + 1.1741682975vw, 1.625rem);
  font-weight: 600;
  --spacing: 0.122em;
}
.header__tel::before {
  content: "";
  min-width: clamp(1rem, 0.341609589rem + 1.3698630137vw, 1.4375rem);
  aspect-ratio: 1/1;
  background: url(../images/icon-tel-r.svg) no-repeat 0 0/contain;
}
.header__mail {
  max-width: clamp(12.5rem, 7.5150440313rem + 10.3718199609vw, 15.8125rem);
  width: 100%;
  height: clamp(2.1875rem, 1.2469422701rem + 1.9569471624vw, 2.8125rem);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.3125rem, 0.030332681rem + 0.5870841487vw, 0.5rem);
     -moz-column-gap: clamp(0.3125rem, 0.030332681rem + 0.5870841487vw, 0.5rem);
          column-gap: clamp(0.3125rem, 0.030332681rem + 0.5870841487vw, 0.5rem);
  background-color: #ffd610;
  font-size: clamp(0.875rem, 0.498776908rem + 0.782778865vw, 1.125rem);
  font-weight: 900;
  --spacing: 0.04em;
}
.header__mail::before {
  content: "";
  min-width: clamp(0.9375rem, 0.373165362rem + 1.1741682975vw, 1.3125rem);
  aspect-ratio: 21/15;
  background: url(../images/icon-mail-b.svg) no-repeat 0 0/contain;
}
.header__nav {
  margin-top: clamp(0.25rem, -0.032167319rem + 0.5870841487vw, 0.4375rem);
}

.header-nav {
  width: 100%;
}
@media (max-width: 768px) {
  .header-nav {
    display: none;
  }
}
.header-nav__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
}
.header-nav__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: clamp(0.1875rem, -0.000611546rem + 0.3913894325vw, 0.3125rem);
  color: var(--base);
  font-size: clamp(0.875rem, 0.498776908rem + 0.782778865vw, 1.125rem);
  line-height: 1;
}
.header-nav__en {
  color: #ffd0b5;
  font-size: clamp(0.8125rem, 0.342221135rem + 0.9784735812vw, 1.125rem);
  font-weight: 300;
  --spacing: 0.06em;
}

@media (hover: hover) and (pointer: fine) {
  .header-nav__link {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .header-nav__link:hover, .header-nav__link:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  footer（module）
###################################################################*/
.footer-top {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 1000px) {
  .footer-top {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
}
.footer-top__gmap {
  width: 100%;
  height: clamp(18.875rem, -5.5288461538rem + 81.3461538462vw, 45.3125rem);
}

.footer-contact {
  background-color: var(--main);
  color: var(--base);
}
.footer-contact__inner {
  max-width: 730px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-inline: auto;
  padding: clamp(2.1875rem, -0.2083333333rem + 7.9861111111vw, 3.625rem) clamp(0.9375rem, -3.809335443rem + 18.9873417722vw, 1.875rem) 73px;
}
.footer-contact__title {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.625rem, 2.2708333333rem + 4.5138888889vw, 4.4375rem);
  font-weight: 400;
  line-height: 1;
  --spacing: 0.1em;
}
.footer-contact__text {
  width: 100%;
  font-size: clamp(1.125rem, 0.7788461538rem + 1.1538461538vw, 1.5rem);
  margin-top: 16px;
}
@media (max-width: 1000px) {
  .footer-contact__text {
    margin-top: 38px;
  }
}
.footer-contact__time {
  font-size: 1.125rem;
  margin-top: clamp(1.4375rem, -2.625rem + 13.5416666667vw, 3.875rem);
}
@media (max-width: 500px) {
  .footer-contact__time {
    margin-right: auto;
  }
}
.footer-contact__button-wrapper {
  max-width: 376px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 41px;
  margin-top: clamp(1.6875rem, -3rem + 15.625vw, 4.5rem);
}
.footer-contact__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 80px;
  border: 1px solid var(--base);
  padding-left: 29px;
}
.footer-contact__link::before {
  content: "";
}
.footer-contact__link_tel {
  -webkit-column-gap: clamp(2.0625rem, -3.9501582278rem + 24.0506329114vw, 3.25rem);
     -moz-column-gap: clamp(2.0625rem, -3.9501582278rem + 24.0506329114vw, 3.25rem);
          column-gap: clamp(2.0625rem, -3.9501582278rem + 24.0506329114vw, 3.25rem);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: 2rem;
  font-weight: 400;
  --spacing: 0.07em;
}
.footer-contact__link_tel::before {
  min-width: 32px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel-w.svg) no-repeat 0 0/contain;
}
.footer-contact__link_mail {
  -webkit-column-gap: 21px;
     -moz-column-gap: 21px;
          column-gap: 21px;
  font-size: clamp(1.375rem, 0.1091772152rem + 5.0632911392vw, 1.625rem);
  font-weight: 400;
}
.footer-contact__link_mail::before {
  min-width: 32px;
  aspect-ratio: 32/23;
  background: url(../images/icon-mail-w.svg) no-repeat 0 0/contain;
}

.footer {
  position: relative;
}
.footer_pos {
  margin-top: clamp(2.75rem, 1.2916666667rem + 4.8611111111vw, 3.625rem);
}
.footer__inner {
  max-width: 934px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.footer__logo {
  max-width: 629px;
}
.footer__nav {
  margin-top: 75px;
}
.footer__info {
  font-size: 1.125rem;
  margin-top: 25px;
}
@media (max-width: 768px) {
  .footer__info {
    margin-top: 31px;
  }
}
.footer__copy {
  height: 62px;
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  --spacing: 0;
  margin-top: 38px;
}
@media (max-width: 1000px) {
  .footer__copy {
    margin-top: 96px;
  }
}

.footer-nav {
  width: 100%;
}
@media (max-width: 768px) {
  .footer-nav {
    display: none;
  }
}
.footer-nav__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.footer-nav__item {
  position: relative;
}
.footer-nav__item:not(:last-of-type)::after {
  content: "｜";
  position: absolute;
  right: calc(clamp(2.0625rem, -3.0641666667rem + 10.6666666667vw, 3.5625rem) * -1);
  font-size: 18px;
}
.footer-nav__link {
  font-size: 1.125rem;
}

.footer-page-top {
  width: clamp(4.27625rem, 2.5286937378rem + 3.6360078278vw, 5.4375rem);
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  position: absolute;
  bottom: 51px;
  right: 20px;
  z-index: 5;
  background-color: var(--main);
  border-radius: 50%;
  border: 2px solid var(--base);
}
@media (max-width: 768px) {
  .footer-page-top {
    right: 10px;
  }
}
.footer-page-top::after {
  content: "";
  width: clamp(1.625rem, 1.0110039139rem + 1.2774951076vw, 2.033rem);
  aspect-ratio: 32.528/18.382;
  background: url(../images/icon-page-top.svg) no-repeat 0 0/contain;
}

/*###################################################################
  c-link（module）
###################################################################*/
.c-link-1 {
  max-width: 233px;
  width: 100%;
  height: 53px;
  display: grid;
  place-items: center;
  position: relative;
  z-index: 1;
  overflow: hidden;
  background-color: var(--main);
  border: 2px solid var(--main);
  border-radius: 9999px;
}
.c-link-1::after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-transform: scale(0, 1);
      -ms-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
      -ms-transform-origin: right top;
          transform-origin: right top;
  background-color: var(--base);
  z-index: -1;
}
.c-link-1__text {
  color: var(--base);
  font-size: 1.5rem;
  line-height: 1;
  --spacing: 0;
  margin-top: -10px;
}
.c-link-1__arrow {
  font-size: 1rem;
}

@media (hover: hover) and (pointer: fine) {
  .c-link-1::after {
    -webkit-transition: -webkit-transform 0.5s cubic-bezier(0.8, 0, 0.2, 1) 0s;
    transition: -webkit-transform 0.5s cubic-bezier(0.8, 0, 0.2, 1) 0s;
    transition: transform 0.5s cubic-bezier(0.8, 0, 0.2, 1) 0s;
    transition: transform 0.5s cubic-bezier(0.8, 0, 0.2, 1) 0s, -webkit-transform 0.5s cubic-bezier(0.8, 0, 0.2, 1) 0s;
  }
  .c-link-1:hover::after, .c-link-1:focus::after {
    width: 100%;
    -webkit-transform-origin: left top;
        -ms-transform-origin: left top;
            transform-origin: left top;
    -webkit-transform: scale(1, 1);
        -ms-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  .c-link-1:hover .c-link-1__text, .c-link-1:focus .c-link-1__text {
    color: var(--main);
  }
  .c-link-1__text {
    -webkit-transition: color 0.5s;
    transition: color 0.5s;
  }
}
/*###################################################################
  c-title（module）
###################################################################*/
.c-title-1 {
  max-width: 637px;
}
.c-title-1__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  color: var(--main);
  line-height: 1;
}
.c-title-1__jp {
  -webkit-transform: translateY(calc(clamp(0.1875rem, 0.0516304348rem + 0.5434782609vw, 0.3125rem) * -1));
      -ms-transform: translateY(calc(clamp(0.1875rem, 0.0516304348rem + 0.5434782609vw, 0.3125rem) * -1));
          transform: translateY(calc(clamp(0.1875rem, 0.0516304348rem + 0.5434782609vw, 0.3125rem) * -1));
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.8532608696rem + 1.0869565217vw, 1.375rem);
  font-weight: 900;
  padding-right: clamp(0rem, -0.8831521739rem + 3.5326086957vw, 0.8125rem);
}
.c-title-1__en {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3rem, 0.8260869565rem + 8.6956521739vw, 5rem);
  font-weight: 600;
  --spacing: 0;
}
.c-title-1__en_ls85 {
  --spacing: 0.085em;
}
@media (max-width: 768px) {
  .c-title-1__en_ls85 {
    --spacing: 0.04em;
  }
}
.c-title-1__hr {
  border-bottom: 3px solid var(--main);
  margin-top: calc(clamp(0.5rem, 0.2282608696rem + 1.0869565217vw, 0.75rem) * -1);
}

/*###################################################################
  br（module）
###################################################################*/
.br-1000-b {
  display: none;
}
@media (max-width: 1000px) {
  .br-1000-b {
    display: block;
  }
}
.br-900-b {
  display: none;
}
@media (max-width: 900px) {
  .br-900-b {
    display: block;
  }
}
.br-800-b {
  display: none;
}
@media (max-width: 800px) {
  .br-800-b {
    display: block;
  }
}
.br-sp-b {
  display: none;
}
@media (max-width: 768px) {
  .br-sp-b {
    display: block;
  }
}
.br-700-b {
  display: none;
}
@media (max-width: 700px) {
  .br-700-b {
    display: block;
  }
}
.br-600-b {
  display: none;
}
@media (max-width: 600px) {
  .br-600-b {
    display: block;
  }
}
.br-500-b {
  display: none;
}
@media (max-width: 500px) {
  .br-500-b {
    display: block;
  }
}

/*###################################################################
  hamburger（module）
###################################################################*/
.hamburger {
  width: 42px;
  height: 42px;
  display: inline-block;
  position: relative;
  z-index: 30;
  background-color: var(--main);
}
@media (min-width: 769px) {
  .hamburger {
    display: none;
  }
}
.hamburger[aria-expanded=true] .hamburger__line {
  background-color: transparent;
}
.hamburger[aria-expanded=true] .hamburger__line::before {
  -webkit-transform: translateY(-7px) rotate(150deg);
      -ms-transform: translateY(-7px) rotate(150deg);
          transform: translateY(-7px) rotate(150deg);
}
.hamburger[aria-expanded=true] .hamburger__line::after {
  -webkit-transform: translateY(7px) rotate(-150deg);
      -ms-transform: translateY(7px) rotate(-150deg);
          transform: translateY(7px) rotate(-150deg);
}
.hamburger__line {
  width: 20px;
  height: 2px;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
  background-color: var(--base);
}
.hamburger__line::before {
  content: "";
  width: 100%;
  height: 2px;
  display: inline-block;
  position: absolute;
  top: 7px;
  left: 0;
  -webkit-transition: -webkit-transform 0.5s;
  transition: -webkit-transform 0.5s;
  transition: transform 0.5s;
  transition: transform 0.5s, -webkit-transform 0.5s;
  background-color: var(--base);
}
.hamburger__line::after {
  content: "";
  width: 100%;
  height: 2px;
  display: inline-block;
  position: absolute;
  bottom: 7px;
  left: 0;
  -webkit-transition: -webkit-transform 0.5s;
  transition: -webkit-transform 0.5s;
  transition: transform 0.5s;
  transition: transform 0.5s, -webkit-transform 0.5s;
  background-color: var(--base);
}

@media (hover: hover) and (pointer: fine) {
  .hamburger {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .hamburger:hover {
    opacity: 0.7;
  }
}
/*###################################################################
  drawer（module）
###################################################################*/
.drawer {
  width: 300px;
  height: 100vh;
  -webkit-transform: translateX(300px);
      -ms-transform: translateX(300px);
          transform: translateX(300px);
  -webkit-transition: 0.5s;
  transition: 0.5s;
  background-color: var(--base-b);
  z-index: 15;
  overflow: auto;
  overscroll-behavior-y: contain;
  visibility: hidden;
}
.drawer[aria-hidden=false] {
  -webkit-transform: translateY(0);
      -ms-transform: translateY(0);
          transform: translateY(0);
  visibility: visible;
}
.drawer_position {
  position: fixed;
  top: 0;
  right: 0;
}
.drawer__inner {
  padding-bottom: 100px;
}
.drawer__top {
  width: 100%;
  height: 56px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: var(--base-b);
  z-index: 1;
}
.drawer__item {
  border-bottom: 1px solid var(--text);
}
.drawer__item:first-of-type {
  border-top: 1px solid var(--text);
}
.drawer__link {
  height: 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  font-weight: bold;
  padding: 11px 20px;
}
.drawer__en {
  color: var(--main);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: 0.75rem;
  font-weight: bold;
  --spacing: 0.08em;
}
.drawer__bottom {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 20px;
  margin-top: 30px;
}
.drawer__tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 7px;
     -moz-column-gap: 7px;
          column-gap: 7px;
  color: #f66009;
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1;
  --spacing: 0.122em;
}
.drawer__tel::before {
  content: "";
  min-width: 23px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel-r.svg) no-repeat 0 0/contain;
}
.drawer__mail {
  max-width: 253px;
  width: 100%;
  height: 45px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
  background-color: #ffd610;
  font-size: 1.125rem;
  font-weight: 900;
  --spacing: 0.04em;
}
.drawer__mail::before {
  content: "";
  min-width: 21px;
  aspect-ratio: 21/15;
  background: url(../images/icon-mail-b.svg) no-repeat 0 0/contain;
}

.is-drawer-active {
  overflow: hidden;
}

@media (hover: hover) and (pointer: fine) {
  .drawer__link {
    -webkit-transition: background-color 0.4s, color 0.4s;
    transition: background-color 0.4s, color 0.4s;
  }
  .drawer__link:hover, .drawer__link:focus {
    background-color: var(--main);
    color: var(--base);
  }
  .drawer__link:hover .drawer__en, .drawer__link:focus .drawer__en {
    color: var(--base);
  }
  .drawer__en {
    -webkit-transition: color 0.4s;
    transition: color 0.4s;
  }
}
.drawer-bg {
  width: 100vw;
  height: 100vh;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  background-color: #000;
  visibility: hidden;
  opacity: 0;
  z-index: 5;
}

.is-drawer-active {
  height: 100%;
  overflow: hidden;
}
.is-drawer-active .drawer-bg {
  visibility: visible;
  opacity: 0.8;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

/*###################################################################
  hover（module）
###################################################################*/
@media (hover: hover) and (pointer: fine) {
  .op {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op:hover, .op:focus {
    opacity: 0.7;
  }
}
@media (hover: hover) and (pointer: fine) {
  .op-fn {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op-fn:hover {
    opacity: 0.7;
  }
}
@media (hover: hover) and (pointer: fine) {
  .op-im {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op-im:hover, .op-im:focus {
    opacity: 0.7 !important;
  }
}
@media (hover: hover) and (pointer: fine) {
  .op-fnim {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .op-fnim:hover {
    opacity: 0.7 !important;
  }
}
/*###################################################################
  lower（module）
###################################################################*/
.lower-mv {
  min-height: clamp(20rem, 9.1983695652rem + 43.2065217391vw, 29.9375rem);
  display: grid;
  place-items: center;
  background: url(../images/lower-mv.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/lower-mv.webp) 1x, url(../images/lower-mv@2x.webp) 2x);
  background-image: image-set(url(../images/lower-mv.webp) 1x, url(../images/lower-mv@2x.webp) 2x);
}
.lower-mv__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 22px;
  color: var(--base);
  line-height: 1;
  margin-top: clamp(1.25rem, -7.1209637965rem + 17.4168297456vw, 6.8125rem);
}
.lower-mv__jp {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(3.125rem, 2.7083333333rem + 1.6666666667vw, 3.75rem);
  font-weight: bold;
}
.lower-mv__en {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1.75rem, 1.5833333333rem + 0.6666666667vw, 2rem);
  font-weight: 600;
}

/*###################################################################
  WordPressテスト環境用設定
###################################################################*/
/*###################################################################
  top（page）
###################################################################*/
.top-mv {
  position: relative;
}
.top-mv__title {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  position: absolute;
  top: calc(50% + 18px);
  left: calc(50% - 0px);
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 3;
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(3rem, 1.8713307241rem + 2.3483365949vw, 3.75rem);
  font-weight: bold;
  line-height: 1.5;
  -webkit-animation: mvTitle 3.5s ease-in forwards;
          animation: mvTitle 3.5s ease-in forwards;
}
@media (max-width: 768px) {
  .top-mv__title {
    top: inherit;
    bottom: clamp(0.9375rem, -7.9166666667rem + 29.5138888889vw, 6.25rem);
    left: calc(50% - 16px);
    -webkit-transform: translate(-50%, 0);
        -ms-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
    font-size: clamp(2.75rem, 2.125rem + 2.0833333333vw, 3.125rem);
  }
}
.top-mv__space {
  display: none;
}
@media (max-width: 768px) {
  .top-mv__space {
    display: inline;
  }
}
.top-mv__img {
  min-height: 600px;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 768px) {
  .top-mv__img {
    min-height: inherit;
  }
}
.top-mv .swiper-slide-active .top-mv__img,
.top-mv .swiper-slide-duplicate-active .top-mv__img,
.top-mv .swiper-slide-prev .top-mv__img {
  -webkit-animation: zoomUp 7s linear 0s normal both;
          animation: zoomUp 7s linear 0s normal both;
}
@media (max-width: 768px) {
  .top-mv .swiper-slide-active .top-mv__img,
  .top-mv .swiper-slide-duplicate-active .top-mv__img,
  .top-mv .swiper-slide-prev .top-mv__img {
    -webkit-animation: zoomUpSp 7s linear 0s normal both;
            animation: zoomUpSp 7s linear 0s normal both;
  }
}

.top-news {
  position: relative;
  z-index: 1;
}
.top-news_pos {
  margin-top: calc(clamp(1.875rem, -8.0008561644rem + 20.5479452055vw, 8.4375rem) * -1);
}
@media (max-width: 768px) {
  .top-news_pos {
    margin-top: 32px;
  }
}
@media (max-width: 768px) {
  .top-news__inner {
    max-width: 600px;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
    margin-inline: auto;
    padding-right: 30px;
    padding-left: 30px;
  }
}
@media (max-width: 768px) and (max-width: 450px) {
  .top-news__inner {
    padding: 0 clamp(0.9375rem, -6.5625rem + 30vw, 1.875rem);
  }
}
.top-news__body {
  max-width: clamp(37.5rem, 4.768590998rem + 68.1017612524vw, 59.25rem);
  height: clamp(12.5625rem, 12.1458333333rem + 1.3888888889vw, 12.8125rem);
  position: relative;
  background-color: rgba(255, 255, 255, 0.902);
  border: clamp(0.375rem, 0.1666666667rem + 0.6944444444vw, 0.5rem) solid var(--main);
  border-radius: 6px;
  margin-left: auto;
  padding: 11px 13px 0;
}
.top-news__title {
  width: 105px;
  height: 37px;
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1;
  --spacing: 0;
  border-radius: 6px;
}
.top-news__scroll {
  max-width: 859px;
  height: 100px;
  overflow: auto;
  margin-top: 34px;
  margin-inline: auto;
}
.top-news__scroll::-webkit-scrollbar {
  width: 2px;
}
.top-news__scroll::-webkit-scrollbar-track {
  background-color: transparent;
}
.top-news__scroll::-webkit-scrollbar-thumb {
  background-color: var(--main);
}
.top-news__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 30px;
  padding-bottom: 30px;
}
.top-news__post-link {
  display: grid;
  grid-template-columns: clamp(7.9375rem, 2.7644324853rem + 10.7632093933vw, 11.375rem) 1fr;
  font-size: clamp(1rem, 0.7916666667rem + 0.6944444444vw, 1.125rem);
}
@media (max-width: 460px) {
  .top-news__post-link {
    grid-template-columns: 1fr;
    row-gap: 5px;
  }
}
.top-news__time {
  font-weight: 900;
  --spacing: 0.1em;
}
.top-news__post-title {
  --spacing: 0.1em;
}
.top-news__more {
  margin-inline: auto;
}
.top-news__no-post {
  font-size: 1.25rem;
  text-align: center;
}

.top-about {
  position: relative;
  background: url(../images/top-about-1.webp) no-repeat right 16px top/64.84375% auto, url(../images/top-about-bg.webp) no-repeat left bottom/auto 698px;
  background-image: -webkit-image-set(url(../images/top-about-1.webp) 1x, url(../images/top-about-1@2x.webp) 2x), -webkit-image-set(url(../images/top-about-bg.webp) 1x, url(../images/top-about-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-about-1.webp) 1x, url(../images/top-about-1@2x.webp) 2x), image-set(url(../images/top-about-bg.webp) 1x, url(../images/top-about-bg@2x.webp) 2x);
}
@media (max-width: 768px) {
  .top-about {
    background: url(../images/top-about-bg_sp.webp) no-repeat center bottom/100% calc(clamp(-51.6875rem, -55.75rem + 13.5416666667vw, -49.25rem) * -1);
    background-image: -webkit-image-set(url(../images/top-about-bg_sp.webp) 1x, url(../images/top-about-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-about-bg_sp.webp) 1x, url(../images/top-about-bg_sp@2x.webp) 2x);
  }
}
@media (max-width: 479px) {
  .top-about {
    background-size: 100% calc(clamp(-57.5rem, -67.1875rem + 32.2916666667vw, -51.6875rem) * -1);
  }
}
@media (min-width: 1921px) {
  .top-about {
    background: url(../images/top-about-1.webp) no-repeat right 16px top/1245px auto, url(../images/top-about-bg.webp) no-repeat left bottom/1877px auto;
    background-image: -webkit-image-set(url(../images/top-about-1.webp) 1x, url(../images/top-about-1@2x.webp) 2x), -webkit-image-set(url(../images/top-about-bg.webp) 1x, url(../images/top-about-bg@2x.webp) 2x);
    background-image: image-set(url(../images/top-about-1.webp) 1x, url(../images/top-about-1@2x.webp) 2x), image-set(url(../images/top-about-bg.webp) 1x, url(../images/top-about-bg@2x.webp) 2x);
  }
}
.top-about_pos {
  margin-top: 38px;
}
@media (max-width: 768px) {
  .top-about_pos {
    margin-top: 48px;
  }
}
.top-about__inner {
  max-width: 1530px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 16px 30px 118px;
}
@media (max-width: 768px) {
  .top-about__inner {
    padding: 0 clamp(0.9375rem, -9.4073275862rem + 41.3793103448vw, 1.6875rem) clamp(3.875rem, -1.9583333333rem + 19.4444444444vw, 7.375rem);
  }
}
.top-about__text {
  max-width: 832px;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.5rem, 0.2516233766rem + 2.5974025974vw, 1.875rem);
  font-weight: 900;
  line-height: 2.4666666667;
  --spacing: 0.1em;
  text-shadow: 2px 2px 1px #ffffff, -2px 2px 1px #ffffff, 2px -2px 1px #ffffff, -2px -2px 1px #ffffff, 2px 0px 1px #ffffff, 0px 2px 1px #ffffff, -2px 0px 1px #ffffff, 0px -2px 1px #ffffff;
}
@media (max-width: 768px) {
  .top-about__text {
    line-height: 1.75;
  }
}
.top-about__body {
  max-width: 1189px;
  position: relative;
  -webkit-transform: translateX(calc(clamp(0rem, -35.4651898734rem + 35.4430379747vw, 1.75rem) * -1));
      -ms-transform: translateX(calc(clamp(0rem, -35.4651898734rem + 35.4430379747vw, 1.75rem) * -1));
          transform: translateX(calc(clamp(0rem, -35.4651898734rem + 35.4430379747vw, 1.75rem) * -1));
  background-color: var(--base);
  margin-top: 211px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-about__body {
    margin-top: 226px;
  }
}
.top-about__body-inner {
  max-width: 1019px;
  margin-inline: auto;
  padding: clamp(5.6875rem, 2.9791666667rem + 9.0277777778vw, 7.3125rem) 34px clamp(1.75rem, -0.0208333333rem + 5.9027777778vw, 2.8125rem);
}
.top-about__title {
  position: absolute;
  top: 1px;
  left: calc(clamp(-2.1875rem, -3.3333333333rem + 3.8194444444vw, -1.5rem) * -1);
  color: var(--main);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.625rem, 1.125rem + 8.3333333333vw, 5.125rem);
  font-weight: 600;
  line-height: 1;
  --spacing: 0.04em;
}
.top-about__body-text {
  font-size: 1.375rem;
  line-height: 2.0909090909;
  --spacing: 0;
}
.top-about__more {
  -webkit-transform: translateX(clamp(0rem, -35.4651898734rem + 35.4430379747vw, 1.75rem));
      -ms-transform: translateX(clamp(0rem, -35.4651898734rem + 35.4430379747vw, 1.75rem));
          transform: translateX(clamp(0rem, -35.4651898734rem + 35.4430379747vw, 1.75rem));
  margin-top: 55px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-about__more {
    margin-top: 65px;
  }
}

.top-link_pos {
  margin-top: clamp(7.625rem, 0.2291666667rem + 24.6527777778vw, 12.0625rem);
}
.top-link__inner {
  max-width: 1522px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 29px;
  padding-left: 29px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 41px clamp(1.25rem, -49.7098765432rem + 54.3209876543vw, 4rem);
}
@media (max-width: 1000px) {
  .top-link__inner {
    max-width: 729px;
    grid-template-columns: 1fr;
  }
}
.top-link__item {
  aspect-ratio: 729/552;
  position: relative;
}
.top-link__item::after {
  content: "";
  position: absolute;
  top: 0;
  inset: 0;
  -webkit-clip-path: circle(100% at 50% 50%);
          clip-path: circle(100% at 50% 50%);
  background-color: rgba(0, 0, 0, 0.4);
}
.top-link__item_flow {
  background: url(../images/top-link-1.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-link-1.webp) 1x, url(../images/top-link-1@2x.webp) 2x);
  background-image: image-set(url(../images/top-link-1.webp) 1x, url(../images/top-link-1@2x.webp) 2x);
}
.top-link__item_contact {
  background: url(../images/top-link-2.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-link-2.webp) 1x, url(../images/top-link-2@2x.webp) 2x);
  background-image: image-set(url(../images/top-link-2.webp) 1x, url(../images/top-link-2@2x.webp) 2x);
}
.top-link__box {
  position: absolute;
  bottom: 20px;
  left: clamp(0.6875rem, -5.8320390782rem + 10.4208416834vw, 3.9375rem);
  z-index: 1;
  color: var(--base);
  margin-top: auto;
}
@media (max-width: 1000px) {
  .top-link__box {
    max-width: clamp(24.25rem, 12.1666666667rem + 40.2777777778vw, 31.5rem);
    left: clamp(1.25rem, -3.2291666667rem + 14.9305555556vw, 3.9375rem);
  }
}
@media (max-width: 479px) {
  .top-link__box {
    bottom: clamp(0.5625rem, -2.9185126582rem + 13.9240506329vw, 1.25rem);
    left: clamp(0.625rem, -2.539556962rem + 12.6582278481vw, 1.25rem);
  }
}
.top-link__title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.885625rem, 0.8616666667rem + 3.4131944444vw, 2.5rem);
  font-weight: 900;
  --spacing: 0;
  line-height: 1;
}
.top-link__text {
  min-height: clamp(2.96875rem, 1.3541666667rem + 5.3819444444vw, 3.9375rem);
  font-size: clamp(0.96875rem, 0.6553106212rem + 0.501002004vw, 1.125rem);
  --spacing: 0;
  white-space: pre-line;
  margin-top: clamp(0.8125rem, 0.1875rem + 2.0833333333vw, 1.1875rem);
}
@media (max-width: 1000px) {
  .top-link__text {
    font-size: clamp(0.84875rem, 0.3883333333rem + 1.5347222222vw, 1.125rem);
    white-space: inherit;
  }
}

@media (hover: hover) and (pointer: fine) {
  .top-link__item::after {
    -webkit-transition: -webkit-clip-path 0.5s;
    transition: -webkit-clip-path 0.5s;
    transition: clip-path 0.5s;
    transition: clip-path 0.5s, -webkit-clip-path 0.5s;
  }
  .top-link__item:hover::after, .top-link__item:focus::after {
    -webkit-clip-path: circle(0 at 50% 50%);
            clip-path: circle(0 at 50% 50%);
  }
}
.top-area {
  background-color: #ececec;
}
.top-area_pos {
  margin-top: clamp(4.25rem, -0.8269230769rem + 16.9230769231vw, 9.75rem);
}
.top-area__outer {
  max-width: 1920px;
  margin-inline: auto;
  padding: clamp(2.25rem, -1.3846153846rem + 12.1153846154vw, 6.1875rem) 0 clamp(0.5rem, -10.4615384615rem + 36.5384615385vw, 12.375rem);
}
.top-area__inner {
  max-width: 1772px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  margin-left: auto;
  padding-left: 22px;
}
@media (max-width: 1000px) {
  .top-area__inner {
    max-width: 900px;
    -webkit-box-sizing: content-box;
            box-sizing: content-box;
    margin-inline: auto;
    padding-right: 22px;
    padding-left: 22px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media (max-width: 479px) {
  .top-area__inner {
    padding: 0 clamp(0.9375rem, -1.2776898734rem + 8.8607594937vw, 1.375rem);
  }
}
.top-area__map {
  max-width: 864px;
  width: 100%;
  position: relative;
}
.top-area__main-outer {
  max-width: 847px;
  width: 100%;
}
@media (max-width: 1000px) {
  .top-area__main-outer {
    margin-top: calc(clamp(4.75rem, 1rem + 12.5vw, 8.8125rem) * -1);
    padding: 0 8px;
  }
}
@media (max-width: 479px) {
  .top-area__main-outer {
    padding: 0 clamp(0rem, -5.641025641rem + 20.5128205128vw, 0.5rem);
  }
}
.top-area__main {
  min-height: 742px;
  background-color: var(--main);
  color: var(--base);
  margin-top: 87px;
  padding-top: 80px;
  padding-left: 20px;
}
@media (max-width: 1000px) {
  .top-area__main {
    margin-top: 0;
    padding-top: clamp(6.125rem, 3.4134615385rem + 9.0384615385vw, 9.0625rem);
    padding-right: 20px;
    padding-bottom: 40px;
  }
}
.top-area__title {
  max-width: 784px;
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.75rem, 2.4807692308rem + 4.2307692308vw, 5.125rem);
  font-weight: 400;
  line-height: 1;
  --spacing: 0.05em;
  border-bottom: 2px solid var(--base);
  margin-left: auto;
  padding-bottom: clamp(0.1875rem, -0.1586538462rem + 1.1538461538vw, 0.5625rem);
  padding-left: clamp(0.375rem, -0.4903846154rem + 2.8846153846vw, 1.3125rem);
}
@media (max-width: 1000px) {
  .top-area__title {
    max-width: clamp(21.5625rem, -1.8028846154rem + 77.8846153846vw, 46.875rem);
    line-height: 1.2;
    margin-right: auto;
  }
}
.top-area__box {
  max-width: clamp(21.6875rem, 5.3605769231rem + 54.4230769231vw, 39.375rem);
  margin-top: clamp(2.6875rem, 2.3413461538rem + 1.1538461538vw, 3.0625rem);
  margin-inline: auto;
  padding-right: 15px;
}
@media (max-width: 1000px) {
  .top-area__box {
    padding-right: 0;
  }
}
.top-area__text-1 {
  font-size: 1.875rem;
  font-weight: bold;
  line-height: 1;
  --spacing: 0;
}
.top-area__text-2 {
  font-size: clamp(1.375rem, 0.7420886076rem + 2.5316455696vw, 1.5rem);
  line-height: 1;
  margin-top: 75px;
  --spacing: 0;
}
.top-area__text-3 {
  font-size: clamp(1.0625rem, 0.7460443038rem + 1.2658227848vw, 1.125rem);
  white-space: pre-line;
  --spacing: 0;
  margin-top: 12px;
}
.top-area__link {
  background-color: var(--base);
  border: 2px solid var(--base);
  margin-top: clamp(3.0625rem, 2.7740384615rem + 0.9615384615vw, 3.375rem);
  margin-left: 15px;
}
@media (max-width: 1000px) {
  .top-area__link {
    margin-left: inherit;
    margin-inline: auto;
  }
}
.top-area__link::after {
  background-color: var(--main);
}
.top-area__link-text {
  color: var(--main);
  margin-top: 1px;
}

@media (hover: hover) and (pointer: fine) {
  .top-area__link:hover .top-area__link-text, .top-area__link:focus .top-area__link-text {
    color: var(--base);
  }
}
.top-service_pos {
  margin-top: clamp(6.5625rem, 3.1586538462rem + 11.3461538462vw, 10.25rem);
}
.top-service__inner {
  max-width: 1422px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 28px;
  padding-left: 28px;
}
@media (max-width: 768px) {
  .top-service__inner {
    padding: 0 clamp(0.9375rem, -3.1764240506rem + 16.4556962025vw, 1.75rem);
  }
}
.top-service__body {
  max-width: 1351px;
}
.top-service__top {
  max-width: 1212px;
  margin-inline: auto;
}
.top-service__title {
  color: var(--main);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.75rem, 2.6041666667rem + 3.8194444444vw, 4.4375rem);
  font-weight: 600;
  line-height: 1;
  --spacing: 0;
}
.top-service__text {
  color: var(--main);
  font-size: clamp(1.625rem, 0.728046595rem + 1.4336917563vw, 1.875rem);
  white-space: pre-line;
  margin-top: clamp(2.0625rem, 1.125rem + 3.125vw, 2.625rem);
}
@media (max-width: 479px) {
  .top-service__text {
    font-size: clamp(1.375rem, 0.1091772152rem + 5.0632911392vw, 1.625rem);
  }
}
.top-service__bottom {
  position: relative;
  margin-top: clamp(3.5rem, -0.7692307692rem + 14.2307692308vw, 8.125rem);
  padding-top: 26px;
}
@media (max-width: 1000px) {
  .top-service__bottom {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    padding-top: 0;
  }
}
.top-service__box {
  max-width: clamp(33.125rem, 8.3157327586rem + 39.6551724138vw, 43.1875rem);
  width: 100%;
  background-color: var(--base);
  -webkit-box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.5);
          box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.5);
  border-radius: 50px;
  margin-left: auto;
  padding: clamp(0.6875rem, -3.8701923077rem + 15.1923076923vw, 5.625rem) clamp(0.9375rem, -0.644778481rem + 6.3291139241vw, 1.25rem) clamp(2.3125rem, -6.6458333333rem + 29.8611111111vw, 7.6875rem);
}
@media (max-width: 1000px) {
  .top-service__box {
    max-width: 691px;
    border-radius: 0;
    margin-left: inherit;
  }
}
.top-service__box-inner {
  max-width: 555px;
  color: var(--main);
  margin-inline: auto;
}
.top-service__box-title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.625rem, 0.3591772152rem + 5.0632911392vw, 1.875rem);
  font-weight: bold;
}
.top-service__box-text {
  font-size: 1.125rem;
  white-space: pre-line;
  margin-top: clamp(1.4375rem, 0.1875rem + 4.1666666667vw, 2.1875rem);
}
.top-service__more {
  margin-top: clamp(2.625rem, -2.6875rem + 17.7083333333vw, 5.8125rem);
  margin-left: 41px;
}
@media (max-width: 1000px) {
  .top-service__more {
    margin-left: inherit;
    margin-inline: auto;
  }
}
.top-service__img {
  max-width: clamp(28.8125rem, -17.4159482759rem + 73.8916256158vw, 47.5625rem);
  width: 100%;
  position: absolute;
  top: 0;
  z-index: -1;
}
@media (max-width: 1000px) {
  .top-service__img {
    max-width: 691px;
    position: static;
  }
}

.top-works {
  background-color: #ececec;
}
.top-works_pos {
  margin-top: clamp(9.1875rem, 4.0875rem + 17vw, 17.6875rem);
}
.top-works__inner {
  max-width: 1615px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 112px 30px 206px;
}
@media (max-width: 1000px) {
  .top-works__inner {
    padding: clamp(4.25rem, -0.3333333333rem + 15.2777777778vw, 7rem) clamp(0rem, -6.2418831169rem + 12.987012987vw, 1.875rem) clamp(5.1875rem, -1.9086538462rem + 23.6538461538vw, 12.875rem);
  }
}
.top-works__body {
  background-color: var(--base);
  padding: 52px clamp(1.875rem, -60rem + 100vw, 2.5rem) 114px;
}
@media (max-width: 768px) {
  .top-works__body {
    padding: clamp(1.4375rem, -1.5833333333rem + 10.0694444444vw, 3.25rem) clamp(0.1875rem, -2.625rem + 9.375vw, 1.875rem) clamp(3.3125rem, -3.0416666667rem + 21.1805555556vw, 7.125rem);
  }
}
.top-works__body-inner {
  max-width: 1497px;
  position: relative;
  margin-inline: auto;
}
.top-works__box {
  max-width: clamp(26.25rem, 0.9456521739rem + 84.347826087vw, 86.875rem);
  margin-inline: auto;
}
@media (max-width: 479px) {
  .top-works__box {
    max-width: clamp(21.25rem, -3.75rem + 100vw, 26.1875rem);
  }
}
.top-works__title {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.625rem, 2.2708333333rem + 4.5138888889vw, 4.4375rem);
  font-weight: 600;
  line-height: 1;
  text-align: right;
  --spacing: 0;
}
.top-works__text {
  position: absolute;
  top: 10px;
  right: clamp(-2.25rem, -26.2871376812rem + 24.6376811594vw, -1.1875rem);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.625rem, 1.2083333333rem + 1.3888888889vw, 1.875rem);
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
@media (max-width: 1000px) {
  .top-works__text {
    position: static;
    text-align: right;
    -webkit-writing-mode: inherit;
        -ms-writing-mode: inherit;
            writing-mode: inherit;
    margin-top: 7px;
  }
}
.top-works__items {
  max-width: clamp(26.25rem, 0.9456521739rem + 84.347826087vw, 86.875rem);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px clamp(0.9375rem, -3.2399642289rem + 6.6772655008vw, 3.5625rem);
  margin-top: clamp(4.8125rem, 4.5rem + 1.0416666667vw, 5rem);
  margin-inline: auto;
}
@media (max-width: 900px) {
  .top-works__items {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .top-works__items {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 479px) {
  .top-works__items {
    max-width: clamp(21.25rem, -3.75rem + 100vw, 26.1875rem);
  }
}
.top-works__items_no-post {
  min-height: 300px;
  place-items: center;
  background-color: var(--main);
}
.top-works__thumbnail {
  overflow: hidden;
}
.top-works__slider {
  position: relative;
  margin-top: clamp(4.8125rem, 4.5rem + 1.0416666667vw, 5rem);
  padding: 0 clamp(1.6875rem, -10.125rem + 21vw, 3rem);
}
.top-works__swiper {
  max-width: 1390px;
  margin-inline: auto;
}
.top-works__slide {
  overflow: hidden;
}
.top-works__post-link img {
  aspect-ratio: 425/321;
  -o-object-fit: cover;
     object-fit: cover;
}
.top-works__prev {
  left: 0;
}
.top-works__next {
  right: 0;
}
.top-works .swiper-button-prev,
.top-works .swiper-button-next {
  width: 48px;
  aspect-ratio: 1/1;
  z-index: 1;
}
.top-works .swiper-button-prev::after,
.top-works .swiper-button-next::after {
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  width: 100%;
  aspect-ratio: 1/1;
  margin: auto;
}
.top-works .swiper-button-prev::after {
  background-image: url(../images/icon-prev.svg);
}
.top-works .swiper-button-next::after {
  background-image: url(../images/icon-next.svg);
}
.top-works__button-wrapper {
  max-width: clamp(26.25rem, 0.9456521739rem + 84.347826087vw, 86.875rem);
  margin-top: clamp(2.5rem, 1.7708333333rem + 2.4305555556vw, 2.9375rem);
  margin-inline: auto;
}
.top-works__more {
  max-width: 317px;
  margin-left: auto;
}
@media (max-width: 768px) {
  .top-works__more {
    margin-right: auto;
  }
}
.top-works__more-text {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 1px;
}
.top-works__no-post {
  grid-area: 1/1/2/4;
  color: var(--base);
  font-size: clamp(1.5rem, 0.875rem + 2.0833333333vw, 1.875rem);
}

@media (hover: hover) and (pointer: fine) {
  .top-works__post-link img {
    -webkit-transition: -webkit-transform ease 0.4s;
    transition: -webkit-transform ease 0.4s;
    transition: transform ease 0.4s;
    transition: transform ease 0.4s, -webkit-transform ease 0.4s;
  }
  .top-works__post-link:hover img, .top-works__post-link:focus img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
  }
}
.top-recruit {
  max-width: 1920px;
  padding-bottom: clamp(4.4375rem, -2.1394230769rem + 21.9230769231vw, 11.5625rem);
}
.top-recruit_pos {
  margin-top: clamp(0rem, -22.8869047619rem + 47.619047619vw, 6.875rem);
  margin-inline: auto;
}
.top-recruit__body {
  max-width: 1719px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  margin-left: auto;
  padding-left: 30px;
}
@media (max-width: 1000px) {
  .top-recruit__body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 6px;
    padding-left: 0;
  }
}
.top-recruit__main {
  max-width: 693px;
  width: 100%;
}
@media (max-width: 1000px) {
  .top-recruit__main {
    max-width: 753px;
    padding: 0 clamp(0.9375rem, -3.809335443rem + 18.9873417722vw, 1.875rem);
  }
}
.top-recruit__title {
  max-width: 584px;
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.6875rem, 2.4375rem + 4.1666666667vw, 4.4375rem);
  font-weight: 600;
  line-height: 1;
  --spacing: 0.03em;
  border-bottom: 3px solid var(--main);
  padding-bottom: 11px;
}
.top-recruit__box {
  max-width: 596px;
  margin-top: clamp(1rem, -3.1666666667rem + 13.8888888889vw, 3.5rem);
  margin-inline: auto;
}
.top-recruit__box-title {
  font-family: "Zen Old Mincho", serif;
  font-size: 2.5rem;
  font-weight: 900;
  line-height: 1;
}
.top-recruit__text-1 {
  font-size: clamp(1.375rem, 1.1666666667rem + 0.6944444444vw, 1.5rem);
  font-weight: bold;
  margin-top: 53px;
}
.top-recruit__text-2 {
  font-size: clamp(1rem, 0.7916666667rem + 0.6944444444vw, 1.125rem);
  white-space: pre-line;
  margin-top: 3px;
}
.top-recruit__more {
  max-width: 253px;
  margin-top: clamp(3.0625rem, 2.6458333333rem + 1.3888888889vw, 3.3125rem);
  margin-inline: auto;
}
.top-recruit__more-text {
  font-size: 1.25rem;
  margin-top: 1px;
}
.top-recruit__img {
  max-width: 960px;
  width: 100%;
}
@media (max-width: 1000px) {
  .top-recruit__img {
    max-width: inherit;
  }
}

/*###################################################################
  service（page）
###################################################################*/
.service-1 {
  background-color: var(--base-b);
}
.service-1__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 158px 30px 73px;
}
@media (max-width: 768px) {
  .service-1__inner {
    padding: clamp(5rem, -0.2989130435rem + 21.1956521739vw, 9.875rem) clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) 73px;
  }
}
.service-1__en {
  --spacing: 0.02em;
}
.service-1__text {
  max-width: 1015px;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: 1.125rem;
  margin-top: clamp(3.75rem, 2.527173913rem + 4.8913043478vw, 4.875rem);
  margin-inline: auto;
}
.service-1__col {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  margin-top: clamp(3.75rem, -1.2092391304rem + 19.8369565217vw, 8.3125rem);
}
@media (max-width: 1000px) {
  .service-1__col {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 30px;
  }
}
.service-1__box {
  max-width: 630px;
  width: 100%;
  margin-top: 10px;
}
@media (max-width: 1000px) {
  .service-1__box {
    margin-top: 0;
  }
}
.service-1__col-title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 19px;
     -moz-column-gap: 19px;
          column-gap: 19px;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.375rem, 0.8315217391rem + 2.1739130435vw, 1.875rem);
  font-weight: 900;
}
.service-1__col-title::before {
  content: "";
  min-width: 13px;
  height: 54px;
  background-color: var(--main);
}
.service-1__col-text {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: clamp(1rem, 0.8641304348rem + 0.5434782609vw, 1.125rem);
  line-height: 2.2222222222;
  white-space: pre-line;
  margin-top: 15px;
  margin-left: 32px;
}
.service-1__img {
  max-width: 640px;
  width: 100%;
}

.service-2_pos {
  margin-top: 71px;
}
.service-2__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .service-2__inner {
    padding: 0 clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem);
  }
}
.service-2__col {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}
@media (max-width: 1000px) {
  .service-2__col {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 30px;
  }
}
.service-2__box {
  max-width: 630px;
  width: 100%;
  margin-top: 10px;
}
@media (max-width: 1000px) {
  .service-2__box {
    margin-top: 0;
  }
}
.service-2__col-title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 19px;
     -moz-column-gap: 19px;
          column-gap: 19px;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.375rem, 0.8315217391rem + 2.1739130435vw, 1.875rem);
  font-weight: 900;
}
.service-2__col-title::before {
  content: "";
  min-width: 13px;
  height: 54px;
  background-color: var(--main);
}
.service-2__col-text {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: clamp(1rem, 0.8641304348rem + 0.5434782609vw, 1.125rem);
  line-height: 2.2222222222;
  white-space: pre-line;
  margin-top: 15px;
  margin-left: 32px;
}
.service-2__img {
  max-width: 640px;
  width: 100%;
}
.service-2__bottom {
  max-width: 1235px;
  margin-top: 103px;
  margin-inline: auto;
}
.service-2__items {
  max-width: 1190px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 103px;
  margin-left: auto;
}
@media (max-width: 1000px) {
  .service-2__items {
    grid-template-columns: 1fr;
    row-gap: 50px;
  }
}
.service-2__item_odd {
  margin-top: 27px;
}
@media (max-width: 1000px) {
  .service-2__item_odd {
    margin-top: 0;
  }
}
.service-2__item_even {
  max-width: 575px;
  margin-left: auto;
}
.service-2__item-title {
  max-width: 400px;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.5rem;
  font-weight: 900;
  line-height: 1;
  border-bottom: 4px solid var(--main);
  border-left: 4px solid var(--main);
  padding: 10px 0 10px 14px;
}
.service-2__item-text {
  font-size: 1.125rem;
  margin-top: clamp(1.625rem, 0.6739130435rem + 3.8043478261vw, 2.5rem);
  margin-left: 21px;
}

.service-3 {
  background-color: var(--base-b);
}
.service-3_pos {
  margin-top: clamp(5rem, -1.25rem + 25vw, 8.125rem);
}
.service-3__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 170px 30px 511px;
}
@media (max-width: 1480px) {
  .service-3__inner {
    padding: clamp(4.375rem, 0.2083333333rem + 16.6666666667vw, 10.625rem) clamp(0.9375rem, -0.9375rem + 7.5vw, 1.875rem) clamp(9.375rem, 1.0185185185rem + 33.4259259259vw, 31.9375rem);
  }
}
.service-3__title {
  max-width: 637px;
  margin-left: auto;
}
.service-3__box {
  max-width: 585px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  color: var(--main);
  line-height: 1;
  margin-left: auto;
}
.service-3__jp {
  -webkit-transform: translateY(calc(clamp(0.1875rem, -0.0625rem + 1vw, 0.3125rem) * -1));
      -ms-transform: translateY(calc(clamp(0.1875rem, -0.0625rem + 1vw, 0.3125rem) * -1));
          transform: translateY(calc(clamp(0.1875rem, -0.0625rem + 1vw, 0.3125rem) * -1));
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.625rem + 2vw, 1.375rem);
  font-weight: 900;
}
.service-3__en {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3rem, -1rem + 16vw, 5rem);
  font-weight: 600;
  --spacing: 0.06em;
}
.service-3__en_ls85 {
  --spacing: 0.085em;
}
@media (max-width: 768px) {
  .service-3__en_ls85 {
    --spacing: 0.04em;
  }
}
.service-3__hr {
  border-bottom: 3px solid var(--main);
  margin-top: calc(clamp(0.5rem, 0rem + 2vw, 0.75rem) * -1);
}
.service-3__body {
  max-width: 647px;
  border: 1px solid var(--main);
  border-radius: clamp(2.1875rem, 0.625rem + 6.25vw, 3.625rem);
  margin-top: clamp(4.375rem, 2.0652173913rem + 9.2391304348vw, 6.5rem);
  margin-inline: auto;
  padding: 48px clamp(0.9375rem, 0.3125rem + 2.5vw, 1.25rem) 58px;
}
.service-3__body-inner {
  max-width: 447px;
  margin-inline: auto;
}
.service-3__items {
  max-width: 420px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 130px;
  margin-left: auto;
}
.service-3__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(1.6875rem, -4.0625rem + 23vw, 4.5625rem);
     -moz-column-gap: clamp(1.6875rem, -4.0625rem + 23vw, 4.5625rem);
          column-gap: clamp(1.6875rem, -4.0625rem + 23vw, 4.5625rem);
  position: relative;
}
.service-3__item:not(:last-of-type)::after {
  content: "";
  width: 29px;
  aspect-ratio: 29/21;
  position: absolute;
  bottom: -71px;
  left: calc(50% - clamp(0rem, -2.625rem + 10.5vw, 1.3125rem));
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  background: url(../images/icon-flow.svg) no-repeat 0 0/contain;
}
.service-3__step {
  max-width: clamp(4.625rem, -0.125rem + 19vw, 7rem);
  width: 100%;
  height: clamp(2.8125rem, 1.6875rem + 4.5vw, 3.375rem);
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1.25rem, 0.75rem + 2vw, 1.5rem);
}
.service-3__text {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-size: 1.25rem;
  font-weight: 600;
}
.service-3__note {
  font-family: "Zen Kaku Gothic Antique", sans-serif;
}

/*###################################################################
  company（page）
###################################################################*/
.company-greet {
  background-color: var(--base-b);
}
.company-greet__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 157px 30px 0px;
}
@media (max-width: 768px) {
  .company-greet__inner {
    padding: clamp(5rem, -0.2309782609rem + 20.9239130435vw, 9.8125rem) clamp(0.9375rem, -0.9375rem + 7.5vw, 1.875rem) 0;
  }
}
.company-greet__en {
  --spacing: 0.02em;
}
.company-greet__name-group {
  max-width: 1160px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 27px;
     -moz-column-gap: 27px;
          column-gap: 27px;
  margin-top: clamp(3.125rem, 0.6793478261rem + 9.7826086957vw, 5.375rem);
  margin-inline: auto;
}
@media (max-width: 650px) {
  .company-greet__name-group {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
    -webkit-align-items: flex-start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.company-greet__job {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.5rem;
  font-weight: 900;
}
.company-greet__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 27px;
     -moz-column-gap: 27px;
          column-gap: 27px;
}
.company-greet__name-jp {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.8125rem, 1.1795886076rem + 2.5316455696vw, 1.9375rem);
  font-weight: 900;
}
.company-greet__name-en {
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(1.5625rem, 0.6131329114rem + 3.7974683544vw, 1.75rem);
  --spacing: 0.025em;
}
.company-greet__message {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  position: relative;
  margin-top: calc(clamp(-19.875rem, -35.8958333333rem + 33.3333333333vw, -15.0625rem) * -1);
  padding-bottom: 117px;
}
@media (max-width: 1000px) {
  .company-greet__message {
    padding: 0 clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) clamp(5rem, 2.4864130435rem + 10.0543478261vw, 7.3125rem);
  }
}
@media (max-width: 768px) {
  .company-greet__message {
    margin-top: calc(clamp(-22.5625rem, -36rem + 43vw, -19.875rem) * -1);
  }
}
@media (max-width: 600px) {
  .company-greet__message {
    margin-top: clamp(17.125rem, -4.625rem + 87vw, 22.5625rem);
  }
}
.company-greet__message-outer {
  position: relative;
  padding: 0 clamp(1.875rem, -16.9491150442rem + 30.0884955752vw, 8.25rem);
}
@media (max-width: 1000px) {
  .company-greet__message-outer {
    padding-right: 30px;
    padding-left: clamp(0rem, -1.25rem + 5vw, 1.875rem);
  }
}
.company-greet__message-outer::after {
  content: "";
  max-width: clamp(23.25rem, 5.9705882353rem + 27.6470588235vw, 29.125rem);
  width: 100%;
  aspect-ratio: 466/731;
  position: absolute;
  bottom: calc(clamp(-22.6875rem, -44.5340909091rem + 45.4545454545vw, -16.125rem) * -1);
  right: 0;
  background: url(../images/company-greet-1.webp) no-repeat center center/contain;
  background-image: -webkit-image-set(url(../images/company-greet-1.webp) 1x, url(../images/company-greet-1@2x.webp) 2x);
  background-image: image-set(url(../images/company-greet-1.webp) 1x, url(../images/company-greet-1@2x.webp) 2x);
}
@media (max-width: 1000px) {
  .company-greet__message-outer::after {
    max-width: clamp(14.1875rem, 8.1458333333rem + 24.1666666667vw, 23.25rem);
  }
}
@media (max-width: 768px) {
  .company-greet__message-outer::after {
    bottom: calc(clamp(-37.5rem, -61.2rem + 94.8vw, -22.6875rem) * -1);
  }
}
.company-greet__message-inner {
  max-width: 956px;
  position: relative;
  z-index: 1;
  margin-inline: auto;
}
.company-greet__message-body {
  position: relative;
  z-index: 1;
  background-color: var(--base);
  padding: clamp(2.1875rem, 1.3958333333rem + 3.1666666667vw, 3.375rem) clamp(0.9375rem, 0.7291666667rem + 0.8333333333vw, 1.25rem) clamp(2.5rem, 1.9583333333rem + 2.1666666667vw, 3.3125rem);
}
.company-greet__text {
  max-width: 860px;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: clamp(0.9375rem, 0.8125rem + 0.5vw, 1.125rem);
  font-weight: bold;
  line-height: 2.2222222222;
  white-space: pre-line;
  margin-inline: auto;
}
.company-greet__deco {
  max-width: 780px;
  width: 100%;
  height: 286px;
  position: absolute;
  top: -47px;
  right: calc(clamp(1.875rem, -3.2924041298rem + 8.2595870206vw, 3.625rem) * -1);
  background: url(../images/company-greet-deco.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/company-greet-deco.webp) 1x, url(../images/company-greet-deco@2x.webp) 2x);
  background-image: image-set(url(../images/company-greet-deco.webp) 1x, url(../images/company-greet-deco@2x.webp) 2x);
}
@media (max-width: 1000px) {
  .company-greet__deco {
    right: -30px;
  }
}

.company-prof_pos {
  margin-top: 31px;
}
.company-prof__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .company-prof__inner {
    padding: 0 clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem);
  }
}
.company-prof__title {
  max-width: 1153px;
  margin-left: auto;
}
@media (max-width: 800px) {
  .company-prof__title {
    max-width: 550px;
  }
}
.company-prof__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  color: var(--main);
  line-height: 1;
}
@media (max-width: 800px) {
  .company-prof__box {
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
}
.company-prof__jp {
  -webkit-transform: translateY(calc(clamp(0.1875rem, 0.0516304348rem + 0.5434782609vw, 0.3125rem) * -1));
      -ms-transform: translateY(calc(clamp(0.1875rem, 0.0516304348rem + 0.5434782609vw, 0.3125rem) * -1));
          transform: translateY(calc(clamp(0.1875rem, 0.0516304348rem + 0.5434782609vw, 0.3125rem) * -1));
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.8532608696rem + 1.0869565217vw, 1.375rem);
  font-weight: 900;
  padding-left: clamp(0rem, -14.9732142857rem + 27.8571428571vw, 2.4375rem);
}
@media (max-width: 800px) {
  .company-prof__jp {
    -webkit-transform: translateY(-15px);
        -ms-transform: translateY(-15px);
            transform: translateY(-15px);
  }
}
.company-prof__en {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: 71px;
  font-size: clamp(3.125rem, 2.25rem + 3.5vw, 4.4375rem);
  font-weight: 600;
  --spacing: 0.02em;
}
.company-prof__hr {
  border-bottom: 3px solid var(--main);
  margin-top: calc(clamp(0.5rem, 0.2282608696rem + 1.0869565217vw, 0.75rem) * -1);
}
.company-prof__dl {
  max-width: 935px;
  display: grid;
  grid-template-columns: clamp(8.375rem, -12.2232142857rem + 42.8571428571vw, 14.5625rem) 1fr;
  row-gap: 14px;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  margin-top: 102px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .company-prof__dl {
    grid-template-columns: 1fr;
    row-gap: 0;
  }
}
.company-prof__dt {
  background-color: var(--main);
  color: var(--base);
  font-size: 1.125rem;
  font-weight: 500;
  padding: 0.546875rem 0 0.546875rem clamp(0.625rem, -2.2878787879rem + 6.0606060606vw, 1.5rem);
}
@media (max-width: 768px) {
  .company-prof__dt {
    text-align: center;
  }
}
@media (max-width: 768px) {
  .company-prof__dt:not(:first-of-type) {
    margin-top: 14px;
  }
}
.company-prof__dd {
  position: relative;
  background-color: #f8f8f8;
  font-size: clamp(1rem, 0.8641304348rem + 0.5434782609vw, 1.125rem);
  white-space: pre-line;
  padding: 0.546875rem 0 0.546875rem clamp(0.9375rem, -11.9623917749rem + 26.8398268398vw, 4.8125rem);
}
@media (max-width: 768px) {
  .company-prof__dd {
    padding: 0.546875rem 15px;
  }
}
.company-prof__dd::before {
  content: "";
  width: 15px;
  aspect-ratio: 15/21;
  -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
          clip-path: polygon(0 0, 0% 100%, 100% 50%);
  position: absolute;
  top: 50%;
  left: -1px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: var(--main);
}
@media (max-width: 768px) {
  .company-prof__dd::before {
    content: none;
  }
}

.company-area_pos {
  margin-top: clamp(6.25rem, -1.7613636364rem + 32.0454545455vw, 23.875rem);
}
.company-area__bg {
  background-color: #ececec;
}
.company-area__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 125px 30px 149px;
}
@media (max-width: 768px) {
  .company-area__inner {
    padding: clamp(5rem, 3.125rem + 7.5vw, 7.8125rem) clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) clamp(6.25rem, 4.2083333333rem + 8.1666666667vw, 9.3125rem);
  }
}
.company-area__title {
  max-width: 799px;
  margin-left: auto;
}
.company-area__title-text {
  color: var(--main);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: clamp(3.75rem, 2.7916666667rem + 3.8333333333vw, 5.1875rem);
  line-height: 1;
  text-align: right;
  --spacing: 0.02em;
}
@media (max-width: 768px) {
  .company-area__title-text {
    -moz-text-align-last: left;
         text-align-last: left;
  }
}
.company-area__hr {
  border-top: 4px solid var(--main);
  margin-top: -13px;
}
.company-area__main {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  margin-top: 45px;
}
@media (max-width: 768px) {
  .company-area__main {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 30px;
  }
}
.company-area__map {
  max-width: 716px;
  width: 100%;
}
.company-area__box {
  max-width: 440px;
  width: 100%;
  margin-top: 9px;
}
.company-area__text-1 {
  font-size: 1.875rem;
  font-weight: bold;
  --spacing: 0;
  white-space: pre-line;
}
.company-area__text-2 {
  font-size: clamp(1.375rem, 0.7420886076rem + 2.5316455696vw, 1.5rem);
  line-height: 1;
  margin-top: 64px;
  --spacing: 0;
}
.company-area__text-3 {
  font-size: clamp(1.0625rem, 0.7460443038rem + 1.2658227848vw, 1.125rem);
  line-height: 2.2;
  white-space: pre-line;
  --spacing: 0;
  margin-top: 7px;
}
.company-area__spacer {
  height: clamp(6.25rem, -1.7613636364rem + 32.0454545455vw, 23.875rem);
}

/*###################################################################
  recruit（page）
###################################################################*/
.recruit-1_pos {
  margin-top: clamp(5rem, -0.2989130435rem + 21.1956521739vw, 9.875rem);
}
.recruit-1__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .recruit-1__inner {
    padding: 0 clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem);
  }
}
.recruit-1__en {
  --spacing: 0.04em;
}
.recruit-1__text {
  max-width: 960px;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.9583333333rem + 0.6666666667vw, 1.375rem);
  font-weight: bold;
  line-height: 1.8181818182;
  white-space: pre-line;
  margin-top: clamp(3.75rem, 2.2554347826rem + 5.9782608696vw, 5.125rem);
  margin-inline: auto;
}

.recruit-2 {
  background-color: var(--base-b);
}
.recruit-2_pos {
  margin-top: clamp(5rem, 2.3505434783rem + 10.597826087vw, 7.4375rem);
}
.recruit-2__inner {
  max-width: 774px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 43px 30px 79px;
}
@media (max-width: 768px) {
  .recruit-2__inner {
    padding: 43px clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) 79px;
  }
}
.recruit-2__title {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.875rem;
  font-weight: 900;
  text-align: center;
}
.recruit-2__dl {
  display: grid;
  grid-template-columns: clamp(5.3125rem, -4.8833525346rem + 40.7834101382vw, 16.375rem) 1fr;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-size: clamp(1rem, 0.8847926267rem + 0.4608294931vw, 1.125rem);
  margin-top: clamp(2.1875rem, -0.0543478261rem + 8.9673913043vw, 4.25rem);
}
.recruit-2__dt {
  border-bottom: 1px solid var(--main);
  padding: 15px 0 15px clamp(0rem, -1.7281105991rem + 6.9124423963vw, 1.875rem);
}
.recruit-2__dd {
  white-space: pre-line;
  border-bottom: 1px solid var(--main);
  padding: 15px clamp(0rem, -0.8640552995rem + 3.4562211982vw, 0.9375rem);
}
.recruit-2__link {
  max-width: 253px;
  margin-top: clamp(5rem, 3.1657608696rem + 7.3369565217vw, 6.6875rem);
  margin-inline: auto;
}
.recruit-2__link-text {
  font-size: 1.25rem;
  margin-top: 1px;
}

.recruit-spacer {
  height: clamp(9.375rem, -1.9770408163rem + 36.3265306122vw, 31.625rem);
}

/*###################################################################
  works（page）
###################################################################*/
.works-main {
  background-color: var(--base-b);
}
.works-main__inner {
  max-width: 1310px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 141px 30px 507px;
}
@media (max-width: 1680px) {
  .works-main__inner {
    padding: clamp(5rem, 2.4583333333rem + 10.1666666667vw, 8.8125rem) clamp(0.9375rem, -0.2551775148rem + 4.4378698225vw, 1.875rem) clamp(9.375rem, 2.40234375rem + 27.890625vw, 31.6875rem);
  }
}
.works-main__text {
  max-width: 960px;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, 0.2927489177rem + 1.7316017316vw, 1.375rem);
  font-weight: bold;
  line-height: 1.8181818182;
  margin-top: clamp(2.875rem, 1.3333333333rem + 6.1666666667vw, 5.1875rem);
  margin-inline: auto;
}
.works-main__list {
  margin-top: 53px;
}

.works-list {
  max-width: 1280px;
  background-color: var(--base);
  border-radius: clamp(1.5625rem, 0.5208333333rem + 4.1666666667vw, 3.125rem);
  padding: clamp(4.375rem, 2.1331521739rem + 8.9673913043vw, 6.4375rem) 20px clamp(5rem, 2.4166666667rem + 10.3333333333vw, 8.875rem);
}
.works-list__items {
  max-width: 1204px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2.5rem, -0.9583333333rem + 13.8333333333vw, 7.6875rem) clamp(0.625rem, -1.4556277056rem + 4.329004329vw, 1.25rem);
  margin-inline: auto;
}
@media (max-width: 900px) {
  .works-list__items {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 500px) {
  .works-list__items {
    grid-template-columns: 1fr;
  }
}
.works-list__post-link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 18px;
}
.works-list__thumbnail {
  overflow: hidden;
}
.works-list__thumbnail img {
  aspect-ratio: 388/266;
  -o-object-fit: cover;
     object-fit: cover;
}
.works-list__text-box {
  max-width: 360px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 7px;
  font-weight: bold;
}
.works-list__date {
  font-size: 18px;
}
.works-list__post-title {
  font-size: clamp(1.125rem, 0.6297823219rem + 0.7915567282vw, 1.3125rem);
}
.works-list__pagination {
  font-size: 1.25rem;
  margin-top: 150px;
}
@media (max-width: 768px) {
  .works-list__pagination {
    margin-top: 80px;
  }
}
.works-list__pagination ul.page-numbers {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(1.125rem, -0.875rem + 8vw, 2.125rem);
  margin-inline: auto;
}
.works-list__pagination ul.page-numbers li {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
}
.works-list__pagination ul.page-numbers li .page-numbers {
  --spacing: 0;
}
.works-list__pagination .page-numbers.current {
  color: var(--main);
}
.works-list__no-post {
  grid-area: 1/1/2/4;
  font-size: clamp(1.375rem, 0.8315217391rem + 2.1739130435vw, 1.875rem);
  text-align: center;
  white-space: nowrap;
}

@media (hover: hover) and (pointer: fine) {
  .works-list__post-link {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .works-list__post-link:hover .works-list__thumbnail img, .works-list__post-link:focus .works-list__thumbnail img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
  }
  .works-list__post-link:hover .works-list__post-title, .works-list__post-link:focus .works-list__post-title {
    color: var(--main);
    text-decoration: underline;
  }
  .works-list__thumbnail img {
    -webkit-transition: -webkit-transform ease 0.4s;
    transition: -webkit-transform ease 0.4s;
    transition: transform ease 0.4s;
    transition: transform ease 0.4s, -webkit-transform ease 0.4s;
  }
  .works-list__post-title {
    -webkit-transition: color ease 0.4s;
    transition: color ease 0.4s;
    -webkit-text-decoration-color: var(--main);
            text-decoration-color: var(--main);
  }
  .works-list__pagination a {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .works-list__pagination a:hover, .works-list__pagination a:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  contact（page）
###################################################################*/
.contact-main {
  background-color: var(--base-b);
}
.contact-main__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 158px 30px 183px;
}
@media (max-width: 768px) {
  .contact-main__inner {
    padding: clamp(5rem, -0.2989130435rem + 21.1956521739vw, 9.875rem) clamp(0.9375rem, -0.0815217391rem + 4.0760869565vw, 1.875rem) clamp(9.375rem, 7.1331521739rem + 8.9673913043vw, 11.4375rem);
  }
}
.contact-main__en {
  --spacing: 0.085em;
}
@media (max-width: 768px) {
  .contact-main__en {
    --spacing: 0.04em;
  }
}
.contact-main__subtitle {
  font-size: clamp(2rem, 1.5244565217rem + 1.902173913vw, 2.4375rem);
  line-height: 1;
  text-align: center;
  margin-top: clamp(5rem, 2.4864130435rem + 10.0543478261vw, 7.3125rem);
}
.contact-main__text-1 {
  font-size: 1.125rem;
  line-height: 2.13;
  text-align: center;
  white-space: pre-line;
  margin-top: 57px;
}
.contact-main__red {
  color: #ff0000;
}
.contact-main__tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
  -webkit-transform: translateX(calc(clamp(0rem, -4.9332437276rem + 7.8853046595vw, 1.375rem) * -1));
      -ms-transform: translateX(calc(clamp(0rem, -4.9332437276rem + 7.8853046595vw, 1.375rem) * -1));
          transform: translateX(calc(clamp(0rem, -4.9332437276rem + 7.8853046595vw, 1.375rem) * -1));
  color: var(--main);
  font-family: "Jost", sans-serif;
  font-optical-sizing: auto;
  font-size: 2.5rem;
  line-height: 1;
  margin-top: 27px;
}
.contact-main__tel::before {
  content: "";
  min-width: 27px;
  aspect-ratio: 1/1;
  background: url(../images/icon-tel-b.svg) no-repeat 0 0/contain;
}
.contact-main__note {
  max-width: 843px;
  margin-top: clamp(3.125rem, -0.7472826087rem + 15.4891304348vw, 6.6875rem);
  margin-inline: auto;
}
.contact-main__text-2 {
  font-size: clamp(1rem, 0.8641304348rem + 0.5434782609vw, 1.125rem);
  line-height: 2.2222222222;
  text-indent: -1em;
  padding-left: 1em;
}
.contact-main__form-wrapper {
  max-width: 792px;
  margin-top: 117px;
  margin-inline: auto;
}
.contact-main__privacy {
  max-width: 1207px;
  background-color: var(--base);
  border-radius: clamp(1.625rem, 0.5833333333rem + 4.1666666667vw, 3.1875rem);
  margin-top: clamp(5rem, 1.3333333333rem + 14.6666666667vw, 10.5rem);
  margin-inline: auto;
  padding: 40px 20px 36px;
}
.contact-main__items {
  max-width: 1105px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 12px;
  margin-inline: auto;
}
.contact-main__item {
  padding-bottom: 15px;
}
.contact-main__item:not(:last-of-type) {
  border-bottom: 1px dashed rgb(216, 216, 216);
}
.contact-main__privacy-title {
  font-size: 1.5rem;
  font-weight: 900;
  line-height: 1;
}
.contact-main__privacy-subtitle {
  font-weight: 900;
}
.contact-main__privacy-text {
  white-space: pre-line;
}
.contact-main__privacy-text_top {
  margin-top: 12px;
}

.form__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 33px;
}
.form__paragraph {
  display: grid;
  grid-template-columns: 300px 1fr;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media (max-width: 768px) {
  .form__paragraph {
    grid-template-columns: 1fr;
    row-gap: 15px;
  }
}
.form__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  line-height: 1;
  margin-top: 15px;
}
@media (max-width: 768px) {
  .form__title {
    margin-top: 0;
  }
}
.form__title_term {
  -webkit-column-gap: 5px;
     -moz-column-gap: 5px;
          column-gap: 5px;
  margin-top: 7px;
}
@media (max-width: 768px) {
  .form__title_term {
    margin-top: 0;
  }
}
.form__label {
  font-size: 1.125rem;
}
.form__required {
  color: #ff0000;
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
}
.form__radio {
  max-width: 456px;
  min-height: 49px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  accent-color: var(--main);
}
.form__radio .wpcf7-list-item {
  margin-left: 0;
}
.form__radio label {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 7px;
     -moz-column-gap: 7px;
          column-gap: 7px;
}
.form__radio input {
  inline-size: 1.125rem;
  block-size: 1.125rem;
}
.form__input {
  width: 100%;
  height: 49px;
  background-color: #f4f3f3;
  border: 1px solid #757575;
  border-radius: 9px;
  padding: 5px 10px;
}
.form__input_message {
  min-height: 192px;
  resize: vertical;
}
.form__button-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 97px;
}
.form__action-button {
  width: 294px;
  height: 73px;
  background-color: #008cc8;
  color: var(--base);
  font-size: 1.5rem;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
}
.form[data-status=sent] .form__button-wrapper {
  display: none;
}

/*###################################################################
  news（page）
###################################################################*/
.news-list_pos {
  margin-top: 100px;
}
.news-list__inner {
  max-width: 1200px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  padding-bottom: 150px;
}
@media (max-width: 600px) {
  .news-list__inner {
    max-width: 400px;
  }
}
.news-list__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: clamp(1.875rem, -0.3571428571rem + 5.9523809524vw, 2.5rem);
}
@media (max-width: 600px) {
  .news-list__items {
    row-gap: 50px;
  }
}
.news-list__post-link {
  display: grid;
  grid-template-columns: clamp(11.25rem, -4.375rem + 41.6666666667vw, 15.625rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
     -moz-column-gap: clamp(0.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
          column-gap: clamp(0.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
  background-color: var(--base);
  border: 1px solid #75778d;
}
@media (max-width: 600px) {
  .news-list__post-link {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
}
.news-list__thumbnail {
  max-width: 300px;
  height: 100%;
  overflow: hidden;
}
@media (max-width: 600px) {
  .news-list__thumbnail {
    max-width: 100%;
  }
}
.news-list__thumbnail img {
  height: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 600px) {
  .news-list__text-box {
    padding-right: 10px;
    padding-left: 10px;
    padding-bottom: 20px;
  }
}
.news-list__date {
  display: block;
  color: var(--main);
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.75;
}
.news-list__post-title {
  font-size: clamp(1.125rem, 0.6785714286rem + 1.1904761905vw, 1.25rem);
  font-weight: 500;
  line-height: 1.75;
  text-align: start;
  word-break: break-all;
  padding-right: 15px;
}
@media (max-width: 600px) {
  .news-list__post-title {
    padding-right: 0;
  }
}
.news-list__no-post {
  height: 200px;
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 600;
  font-size: clamp(1.125rem, 0.9659763314rem + 0.5917159763vw, 1.25rem);
  font-weight: 500;
}
.news-list__pagination {
  font-size: 1.25rem;
  margin-top: 150px;
}
@media (max-width: 768px) {
  .news-list__pagination {
    margin-top: 80px;
  }
}
.news-list__pagination ul.page-numbers {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: clamp(1.125rem, -0.875rem + 8vw, 2.125rem);
  margin-inline: auto;
}
.news-list__pagination ul.page-numbers li {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
}
.news-list__pagination ul.page-numbers li .page-numbers {
  --spacing: 0;
}
.news-list__pagination .page-numbers.current {
  color: var(--main);
}

@media (hover: hover) and (pointer: fine) {
  .news-list__post-link {
    -webkit-transition: background-color 0.4s;
    transition: background-color 0.4s;
  }
  .news-list__post-link:hover .news-list__thumbnail img, .news-list__post-link:focus .news-list__thumbnail img {
    -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
            transform: scale(1.1);
  }
  .news-list__post-link:hover .news-list__post-title, .news-list__post-link:focus .news-list__post-title {
    color: var(--main);
    text-decoration: underline;
  }
  .news-list__thumbnail img {
    -webkit-transition: -webkit-transform ease 0.4s;
    transition: -webkit-transform ease 0.4s;
    transition: transform ease 0.4s;
    transition: transform ease 0.4s, -webkit-transform ease 0.4s;
  }
  .news-list__post-title {
    -webkit-transition: color ease 0.4s;
    transition: color ease 0.4s;
    -webkit-text-decoration-color: var(--main);
            text-decoration-color: var(--main);
  }
  .news-list__pagination a {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .news-list__pagination a:hover, .news-list__pagination a:focus {
    opacity: 0.7;
  }
}
.news-post_pos {
  margin-top: 100px;
  padding-bottom: 150px;
}
.news-post_works {
  background-color: var(--base-b);
  margin-top: 0;
  padding: 100px 0 150px;
}
.news-post__inner {
  max-width: 840px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
.news-post__bg {
  background-color: var(--base);
  border: 1px solid #75778d;
  padding: 50px 20px 100px;
}
.news-post__date {
  display: block;
  color: var(--main);
  font-size: 1.25rem;
  font-weight: 500;
}
@media (max-width: 768px) {
  .news-post__date {
    font-size: 1.125rem;
  }
}
.news-post__title {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.75;
  word-break: break-all;
  margin-top: 10px;
}
@media (max-width: 768px) {
  .news-post__title {
    font-size: 1.375rem;
    margin-top: 10px;
  }
}
.news-post__thumbnail {
  margin-top: 40px;
}
.news-post__editor {
  margin-top: 40px;
}

.news-post-pager {
  background-color: var(--base);
  border: 1px solid #75778d;
}
.news-post-pager_pos {
  max-width: 840px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px;
  margin-top: 80px;
}
@media (max-width: 768px) {
  .news-post-pager_pos {
    margin-top: 60px;
  }
}
.news-post-pager__nav {
  height: 70px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  color: var(--main);
  font-size: clamp(1rem, 0.1071428571rem + 3.8095238095vw, 1.25rem);
  padding-right: clamp(0rem, -4.4642857143rem + 19.0476190476vw, 1.25rem);
  padding-left: clamp(0rem, -4.4642857143rem + 19.0476190476vw, 1.25rem);
}
.news-post-pager__link {
  --spacing: 0;
}
.news-post-pager__blank {
  min-width: 106px;
  min-width: clamp(5.4375rem, 0.5267857143rem + 20.9523809524vw, 6.8125rem);
}

@media (hover: hover) and (pointer: fine) {
  .news-post-pager__link {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .news-post-pager__link:hover, .news-post-pager__link:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  page-404（page）
###################################################################*/
.page-404_pos {
  margin-top: 100px;
}
.page-404__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .page-404__inner {
    padding: 0 clamp(0.9375rem, -0.2551775148rem + 4.4378698225vw, 1.875rem);
  }
}
.page-404__title {
  color: var(--main);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.5rem;
  font-weight: 900;
}
.page-404__text {
  white-space: pre-line;
  margin-top: 80px;
}
.page-404__button-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 100px;
}

/*###################################################################
  js-（js制御用）
###################################################################*/