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

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

html {
  scroll-behavior: smooth;
}

body {
  color: var(--text);
  font-family: "Zen Old Mincho", serif;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

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

/*###################################################################
  animation（共通設定）
###################################################################*/
/*----------------------------------
  背景色が伸びて出現
----------------------------------*/
@-webkit-keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes bgextendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
@keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
/*###################################################################
  header（module）
###################################################################*/
.header {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  background-color: var(--main);
  border: 1px solid #707070;
  border-radius: 0px 0px 30px 30px;
  -webkit-box-shadow: 0px 8px 30px rgba(0, 0, 0, 0.97);
          box-shadow: 0px 8px 30px rgba(0, 0, 0, 0.97);
}
.header_sticky {
  position: -webkit-sticky;
  position: sticky;
}
.header__inner {
  height: clamp(5.5rem, 1.4095744681rem + 8.5106382979vw, 8.75rem);
  display: grid;
  grid-template-columns: clamp(11.875rem, -0.8682487725rem + 26.5139116203vw, 22rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: clamp(0.9375rem, 0.5441898527rem + 0.8183306056vw, 1.25rem);
     -moz-column-gap: clamp(0.9375rem, 0.5441898527rem + 0.8183306056vw, 1.25rem);
          column-gap: clamp(0.9375rem, 0.5441898527rem + 0.8183306056vw, 1.25rem);
  padding-right: clamp(0.9375rem, -1.4223608838rem + 4.9099836334vw, 2.8125rem);
  padding-left: clamp(0.9375rem, -1.7370090016rem + 5.5646481178vw, 3.0625rem);
}
@media (max-width: 768px) {
  .header__inner {
    padding-right: 24px;
    padding-left: 21px;
  }
}
.header__logo {
  max-width: 352px;
  z-index: 30;
}
.header__nav {
  margin-left: auto;
}
.header__hamburger {
  margin-left: auto;
}

.header-nav {
  max-width: 844px;
  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-column-gap: clamp(0.5rem, 0.3426759411rem + 0.3273322422vw, 0.625rem);
     -moz-column-gap: clamp(0.5rem, 0.3426759411rem + 0.3273322422vw, 0.625rem);
          column-gap: clamp(0.5rem, 0.3426759411rem + 0.3273322422vw, 0.625rem);
}
.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: 10px;
  color: var(--base);
  font-size: clamp(0.875rem, 0.5603518822rem + 0.6546644845vw, 1.125rem);
}
.header-nav__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(0.75rem, 0.4353518822rem + 0.6546644845vw, 1rem);
}

@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-contact_normal {
  margin-top: clamp(3.625rem, -3.6900887574rem + 27.2189349112vw, 9.375rem);
}
.footer-contact_gray {
  background-color: #ebebeb;
}
.footer-contact__inner {
  max-width: 1192px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .footer-contact__inner {
    padding-right: 0;
    padding-left: 0;
  }
}
.footer-contact__inner_gray {
  padding-bottom: clamp(3.25rem, -3.1904585799rem + 23.9644970414vw, 8.3125rem);
}
.footer-contact__body {
  min-height: 498px;
  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;
  background: url(../images/footer-contact-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/footer-contact-bg.webp) 1x, url(../images/footer-contact-bg@2x.webp) 2x);
  background-image: image-set(url(../images/footer-contact-bg.webp) 1x, url(../images/footer-contact-bg@2x.webp) 2x);
  color: var(--base);
  padding: 40px 10px 50px;
  padding: calc(clamp(-3.4375rem, -4.6301775148rem + 4.4378698225vw, -2.5rem) * -1) clamp(0.625rem, -0.1701183432rem + 2.9585798817vw, 1.25rem) 50px;
}
.footer-contact__title {
  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;
  row-gap: calc(clamp(-0.875rem, -1.3520710059rem + 1.775147929vw, -0.5rem) * -1);
}
.footer-contact__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
}
.footer-contact__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.footer-contact__tel {
  font-size: clamp(1.5rem, 1.0229289941rem + 1.775147929vw, 1.875rem);
  line-height: 1;
  margin-top: clamp(2.0625rem, 1.0288461538rem + 3.8461538462vw, 2.875rem);
}
.footer-contact__text {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  line-height: 2.2;
  text-align: center;
  white-space: pre-line;
  margin-top: 12px;
}
@media (max-width: 768px) {
  .footer-contact__text {
    line-height: 2.5;
    margin-top: 11px;
  }
}
.footer-contact__link {
  width: clamp(17.1875rem, 14.4840976331rem + 10.0591715976vw, 19.3125rem);
  height: 83px;
  display: grid;
  place-items: center;
  background-color: var(--base);
  color: var(--main);
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1.25rem, 1.0909763314rem + 0.5917159763vw, 1.375rem);
  border: 1px solid #707070;
  border-radius: 40px;
  margin-top: calc(clamp(-3.5rem, -6.3624260355rem + 10.650887574vw, -1.25rem) * -1);
}

.footer-map_normal {
  margin-top: clamp(3.25rem, -3.1904585799rem + 23.9644970414vw, 8.3125rem);
}
.footer-map__gmap {
  width: 100%;
  height: 500px;
}

.footer {
  position: relative;
  background-color: var(--main);
  color: var(--base);
  border: 1px solid #707070;
}
.footer__inner {
  max-width: 1528px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 66px 30px 50px;
  min-height: 246px;
}
@media (max-width: 768px) {
  .footer__inner {
    min-height: calc(clamp(-32.3125rem, -38.037352071rem + 21.3017751479vw, -27.8125rem) * -1);
    padding-top: clamp(3rem, 1.5687869822rem + 5.325443787vw, 4.125rem);
  }
}
.footer__body {
  max-width: 1510px;
  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;
}
@media (max-width: 900px) {
  .footer__body {
    -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: 40px;
  }
}
.footer__group {
  max-width: 355px;
  width: 100%;
}
.footer__logo {
  max-width: 352px;
  display: inline-block;
}
.footer__info {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  line-height: 1.4444444444;
  white-space: pre-line;
  text-shadow: 0px 0px 0px #000;
  margin-top: 18px;
}
@media (max-width: 768px) {
  .footer__info {
    line-height: 1.5;
    margin-top: 25px;
  }
}
.footer__nav {
  margin-top: 19px;
}
.footer__copy {
  font-size: calc(clamp(-1rem, -1.1885964912rem + 0.701754386vw, -0.75rem) * -1);
  text-align: center;
  padding-bottom: 20px;
}

.footer-nav {
  max-width: 844px;
  width: 100%;
}
@media (max-width: 1280px) {
  .footer-nav {
    max-width: 580px;
  }
}
.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;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
}
@media (max-width: 1280px) {
  .footer-nav__items {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    row-gap: 40px;
  }
}
@media (max-width: 600px) {
  .footer-nav__items {
    grid-template-columns: repeat(2, 1fr);
  }
}
.footer-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: 14px;
  font-size: 1.125rem;
}
.footer-nav__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: 1rem;
}

.footer-page-top {
  width: clamp(4.1875rem, 0.739978903rem + 7.1729957806vw, 7.375rem);
  aspect-ratio: 1/1;
  position: absolute;
  bottom: 50px;
  right: 20px;
  z-index: 5;
  background-color: var(--base);
  color: #000;
  font-size: clamp(0.5625rem, -0.0458860759rem + 1.2658227848vw, 1.125rem);
  line-height: 1.5;
  text-align: center;
  white-space: pre-line;
  border: 1px solid var(--main);
  border-radius: 50%;
  padding-top: 22px;
}

/*###################################################################
  c-link（module）
###################################################################*/
.c-link-more {
  width: 309px;
  height: 83px;
  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;
  background-color: var(--base);
  color: var(--main);
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: 1.375rem;
  border: 1px solid #707070;
  border-radius: 40px;
  padding: 0 39px;
}
.c-link-more::before {
  content: "";
  width: 3.135rem;
  aspect-ratio: 50.16/41.5;
  background: url(../images/icon-home.svg) no-repeat 0 0/contain;
}

/*###################################################################
  c-title（module）
###################################################################*/
.c-title-1 {
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  row-gap: 10px;
  position: relative;
  color: var(--main);
  line-height: 1.4;
  border-left: 6px solid var(--main);
  padding-left: clamp(1.0625rem, -1.0048076923rem + 7.6923076923vw, 2.6875rem);
}
.c-title-1__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
}
.c-title-1__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}

/*###################################################################
  br（module）
###################################################################*/
.br-sp-b {
  display: none;
}
@media (max-width: 768px) {
  .br-sp-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: 49px;
  height: 49px;
  display: inline-block;
  position: relative;
  z-index: 30;
  background-color: var(--base);
  border: 1px solid #707070;
}
@media (min-width: 769px) {
  .hamburger {
    display: none;
  }
}
.hamburger[aria-expanded=true] .hamburger__line {
  width: 35px;
  background-color: transparent;
}
.hamburger[aria-expanded=true] .hamburger__line::before {
  -webkit-transform: translateY(-10px) rotate(135deg);
      -ms-transform: translateY(-10px) rotate(135deg);
          transform: translateY(-10px) rotate(135deg);
}
.hamburger[aria-expanded=true] .hamburger__line::after {
  -webkit-transform: translateY(12px) rotate(-135deg);
      -ms-transform: translateY(12px) rotate(-135deg);
          transform: translateY(12px) rotate(-135deg);
}
.hamburger__line {
  width: 26px;
  height: 1px;
  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(--main);
}
.hamburger__line::before {
  content: "";
  width: 100%;
  height: 1px;
  display: inline-block;
  position: absolute;
  top: 11px;
  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(--main);
}
.hamburger__line::after {
  content: "";
  width: 100%;
  height: 1px;
  display: inline-block;
  position: absolute;
  bottom: 11px;
  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(--main);
}

@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: 100%;
  height: 100vh;
  -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: 0.5s;
  transition: 0.5s;
  background-color: var(--main);
  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: 88px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: var(--main);
  z-index: 1;
}
.drawer__nav {
  margin-top: 55px;
}
.drawer__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: 41px;
}
.drawer__link {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  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: 13px;
  color: var(--base);
  font-size: 1.125rem;
  margin-inline: auto;
}
.drawer__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
}

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

.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 {
  display: grid;
  place-items: center;
  aspect-ratio: 16/5;
  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);
}
@media (max-width: 1280px) {
  .lower-mv {
    min-height: 400px;
    aspect-ratio: inherit;
  }
}
@media (max-width: 768px) {
  .lower-mv {
    min-height: inherit;
    aspect-ratio: 192/125;
    background: url(../images/lower-mv_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/lower-mv_sp.webp) 1x, url(../images/lower-mv_sp@2x.webp) 2x);
    background-image: image-set(url(../images/lower-mv_sp.webp) 1x, url(../images/lower-mv_sp@2x.webp) 2x);
  }
}
@media (max-width: 550px) {
  .lower-mv {
    min-height: 350px;
    aspect-ratio: inherit;
  }
}
.lower-mv__title {
  color: var(--base);
  font-size: clamp(2.25rem, 1.7065217391rem + 2.1739130435vw, 2.75rem);
  font-weight: 900;
  text-shadow: 0px 3px 10px #000;
  margin-top: clamp(7.5rem, -1.5rem + 11.25vw, 10.3125rem);
}
@media (max-width: 768px) {
  .lower-mv__title {
    margin-top: 80px;
  }
}

/*###################################################################
  WordPressテスト環境用設定
###################################################################*/
/*###################################################################
  top（page）
###################################################################*/
.top-mv {
  position: relative;
}
.top-mv__box {
  position: absolute;
  top: calc(50% + 17px);
  left: clamp(3.75rem, -3.5157471764rem + 15.1172893136vw, 14.625rem);
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: 3;
  color: var(--base);
}
@media (min-width: 1921px) {
  .top-mv__box {
    left: 12.3%;
  }
}
@media (max-width: 768px) {
  .top-mv__box {
    top: calc(50% - 27px);
    left: clamp(1.25rem, -1.4673913043rem + 10.8695652174vw, 3.75rem);
  }
}
.top-mv__title {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(3.75rem, 2.9148566464rem + 1.7376194613vw, 5rem);
  line-height: 1.3625;
  --spacing: 0;
  white-space: pre-line;
  text-shadow: 9px 9px 20px rgba(16, 16, 16, 0.94);
}
@media (max-width: 768px) {
  .top-mv__title {
    font-size: clamp(2.8125rem, 1.7934782609rem + 4.0760869565vw, 3.75rem);
    line-height: 1.3555555556;
  }
}
.top-mv__text {
  font-size: clamp(1rem, 0.5923913043rem + 1.6304347826vw, 1.375rem);
  font-weight: 900;
  line-height: 1.5;
  white-space: pre-line;
  text-shadow: 10px 10px 20px var(--text);
  margin-top: clamp(2rem, 0.1657608696rem + 7.3369565217vw, 3.6875rem);
}
@media (max-width: 768px) {
  .top-mv__text {
    --spacing: 0.1em;
  }
}
.top-mv__img {
  height: 100%;
  min-height: 600px;
  aspect-ratio: 191/108;
  -o-object-fit: cover;
     object-fit: cover;
}
@media (max-width: 768px) {
  .top-mv__img {
    min-height: 500px;
    aspect-ratio: 430/770;
  }
}

.top-msg {
  position: relative;
  background: var(--main) url(../images/top-message-bg.webp) repeat-x left -10px bottom 28px/auto 215px;
  background-image: -webkit-image-set(url(../images/top-message-bg.webp) 1x, url(../images/top-message-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-message-bg.webp) 1x, url(../images/top-message-bg@2x.webp) 2x);
  color: var(--base);
}
@media (max-width: 768px) {
  .top-msg {
    background-position: left -80px bottom 39px;
  }
}
.top-msg__inner {
  max-width: 1680px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 233px 30px 258px;
}
@media (max-width: 1280px) {
  .top-msg__inner {
    padding: clamp(4.1875rem, -1.0610294118rem + 19.5294117647vw, 14.5625rem) clamp(1.3125rem, 0.5968934911rem + 2.6627218935vw, 1.875rem) clamp(14.0625rem, 11.4386094675rem + 9.7633136095vw, 16.125rem);
  }
}
.top-msg__main {
  max-width: 1517px;
  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: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
}
@media (max-width: 1000px) {
  .top-msg__main {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: clamp(2.25rem, 1.1368343195rem + 4.1420118343vw, 3.125rem);
  }
}
.top-msg__title {
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  width: 100%;
  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-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  row-gap: clamp(0.875rem, 0.7159763314rem + 0.5917159763vw, 1rem);
  margin-top: 15px;
}
.top-msg__jp {
  font-size: clamp(2.125rem, 0.5625rem + 2.5vw, 2.75rem);
  font-weight: 900;
}
@media (max-width: 768px) {
  .top-msg__jp {
    font-size: clamp(1.5rem, 0.7048816568rem + 2.9585798817vw, 2.125rem);
  }
}
.top-msg__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.top-msg__box {
  max-width: 830px;
  width: 100%;
}
.top-msg__box-title {
  font-size: clamp(1.125rem, 0.8069526627rem + 1.1834319527vw, 1.375rem);
  font-weight: 900;
  line-height: 1.5;
}
@media (max-width: 429px) {
  .top-msg__box-title {
    font-size: clamp(1.0625rem, 0.2004310345rem + 3.4482758621vw, 1.125rem);
  }
}
.top-msg__text {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: 900;
  line-height: 1.4444444444;
  white-space: pre-line;
  text-shadow: 0px 0px 0px #000;
  margin-top: clamp(2.125rem, 0.6142751479rem + 5.6213017751vw, 3.3125rem);
}
@media (max-width: 768px) {
  .top-msg__text {
    line-height: 1.375;
  }
}
@media (max-width: 768px) {
  .top-msg__br {
    display: none;
  }
}
.top-msg__link {
  margin-top: clamp(4.3125rem, -4.5133136095rem + 32.8402366864vw, 11.25rem);
}
@media (max-width: 768px) {
  .top-msg__link {
    margin-inline: auto;
  }
}

.top-service_pos {
  margin-top: clamp(3.4375rem, -0.6176035503rem + 15.0887573964vw, 6.625rem);
}
.top-service__inner {
  max-width: 1759px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-service__inner {
    padding: 0 clamp(1rem, -0.1131656805rem + 4.1420118343vw, 1.875rem);
  }
}
.top-service__title {
  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;
  row-gap: clamp(0.375rem, -0.4201183432rem + 2.9585798817vw, 1rem);
  color: var(--main);
}
.top-service__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
}
.top-service__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.top-service__text {
  max-width: 1059px;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: bold;
  line-height: 1.4444444444;
  text-align: center;
  white-space: pre-line;
  margin-top: clamp(1.5625rem, 0.8468934911rem + 2.6627218935vw, 2.125rem);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-service__text {
    font-weight: bold;
    line-height: 1.5;
    padding: 0 calc(clamp(-0.875rem, -1.9881656805rem + 4.1420118343vw, 0rem) * -1);
  }
}
.top-service__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 47px clamp(1.25rem, -22.1875rem + 25vw, 5.9375rem);
  margin-top: clamp(2.6875rem, 1.3357988166rem + 5.0295857988vw, 3.75rem);
}
@media (max-width: 1000px) {
  .top-service__items {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .top-service__items {
    max-width: 500px;
    grid-template-columns: 1fr;
    margin-inline: auto;
  }
}
.top-service__item {
  border-radius: 30px;
}
@media (max-width: 768px) {
  .top-service__item {
    aspect-ratio: 396/307;
  }
}
.top-service__item-link {
  position: relative;
}
.top-service__img {
  border-radius: 30px;
  -webkit-box-shadow: 0px 14px 20px #000;
          box-shadow: 0px 14px 20px #000;
}
@media (max-width: 768px) {
  .top-service__img {
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.top-service__item-text {
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  position: absolute;
  bottom: 47px;
  left: 50%;
  -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
  color: var(--base);
  font-size: clamp(1.9375rem, 0.3076152305rem + 2.6052104208vw, 2.75rem);
  font-weight: 900;
}
@media (max-width: 768px) {
  .top-service__item-text {
    font-size: clamp(1.5rem, -0.0677083333rem + 5.8333333333vw, 1.9375rem);
  }
}
.top-service__more {
  margin-top: clamp(3.0625rem, -1.6286982249rem + 17.4556213018vw, 6.75rem);
  margin-inline: auto;
}

@media (hover: hover) and (pointer: fine) {
  .top-service__item-link:hover .top-service__img, .top-service__item-link:focus .top-service__img {
    scale: 1.05;
  }
  .top-service__img {
    -webkit-transition: scale 0.3s;
    transition: scale 0.3s;
  }
}
.top-flow_pos {
  margin-top: clamp(0.9375rem, -8.2858727811rem + 34.3195266272vw, 8.1875rem);
}
.top-flow__inner {
  max-width: 1032px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .top-flow__inner {
    padding: 0 clamp(1.25rem, 0.4548816568rem + 2.9585798817vw, 1.875rem);
  }
}
.top-flow__body {
  min-height: clamp(32.25rem, 30.4212278107rem + 6.8047337278vw, 33.6875rem);
  background: url(../images/top-flow-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-flow-bg.webp) 1x, url(../images/top-flow-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-flow-bg.webp) 1x, url(../images/top-flow-bg@2x.webp) 2x);
  padding: clamp(2.875rem, 1.2052514793rem + 6.2130177515vw, 4.1875rem) clamp(0.625rem, -0.1701183432rem + 2.9585798817vw, 1.25rem) 50px;
}
.top-flow__body-inner {
  max-width: 875px;
  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;
}
.top-flow__title {
  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;
  row-gap: clamp(0.375rem, -0.4201183432rem + 2.9585798817vw, 1rem);
  color: var(--base);
}
.top-flow__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
}
.top-flow__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.top-flow__text {
  color: var(--base);
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: 900;
  line-height: 1.4444444444;
  text-align: center;
  white-space: pre-line;
  margin-top: clamp(2.8125rem, 2.0173816568rem + 2.9585798817vw, 3.4375rem);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-flow__text {
    font-weight: bold;
    line-height: 1.5;
  }
}
.top-flow__more {
  margin-top: 57px;
}
@media (max-width: 768px) {
  .top-flow__more {
    margin-top: 64px;
  }
}

.top-works {
  background: url(../images/top-works-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-works-bg.webp) 1x, url(../images/top-works-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-works-bg.webp) 1x, url(../images/top-works-bg@2x.webp) 2x);
}
.top-works_pos {
  margin-top: clamp(5.5625rem, 1.3483727811rem + 15.6804733728vw, 8.875rem);
}
.top-works__inner {
  max-width: 1519px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 70px 30px 72px;
}
@media (max-width: 768px) {
  .top-works__inner {
    padding: clamp(2rem, -1.0214497041rem + 11.2426035503vw, 4.375rem) 30px clamp(3.125rem, 1.375739645rem + 6.5088757396vw, 4.5rem);
  }
}
.top-works__title {
  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;
  row-gap: calc(clamp(-1.25rem, -1.5680473373rem + 1.1834319527vw, -1rem) * -1);
  color: var(--main);
}
.top-works__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
}
.top-works__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.top-works__text {
  max-width: 670px;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: bold;
  line-height: 1.4444444444;
  text-align: center;
  white-space: pre-line;
  margin-top: calc(clamp(-3.25rem, -4.6812130178rem + 5.325443787vw, -2.125rem) * -1);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-works__text {
    font-weight: bold;
    line-height: 1.5;
  }
}
.top-works__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -webkit-column-gap: clamp(1.25rem, -47.7132107023rem + 61.2040133779vw, 12.6875rem);
     -moz-column-gap: clamp(1.25rem, -47.7132107023rem + 61.2040133779vw, 12.6875rem);
          column-gap: clamp(1.25rem, -47.7132107023rem + 61.2040133779vw, 12.6875rem);
  margin-top: clamp(3.75rem, 3.2729289941rem + 1.775147929vw, 4.125rem);
}
@media (max-width: 1000px) {
  .top-works__items {
    max-width: 762px;
    grid-template-columns: repeat(2, 1fr);
    row-gap: 30px;
    margin-inline: auto;
  }
}
@media (max-width: 768px) {
  .top-works__items {
    max-width: 372px;
    grid-template-columns: 1fr;
  }
}
.top-works__items_no-post {
  max-width: 100%;
  min-height: clamp(9.375rem, -5.1469298246rem + 54.0350877193vw, 28.625rem);
  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;
}
@media (max-width: 768px) {
  .top-works__post:nth-of-type(2) {
    display: none;
  }
}
@media (max-width: 1000px) {
  .top-works__post:nth-of-type(3) {
    display: none;
  }
}
.top-works__outer {
  position: relative;
  margin-top: clamp(3.75rem, 3.2729289941rem + 1.775147929vw, 4.125rem);
}
@media (max-width: 1000px) {
  .top-works__outer {
    max-width: 762px;
    margin-inline: auto;
  }
}
@media (max-width: 768px) {
  .top-works__outer {
    max-width: 372px;
  }
}
.top-works__slide {
  max-width: clamp(18.75rem, -2.2025353774rem + 33.4905660377vw, 23.1875rem);
  margin-right: clamp(1.25rem, -47.7132107023rem + 61.2040133779vw, 12.6875rem);
}
@media (max-width: 1000px) {
  .top-works__slide {
    max-width: clamp(21.5rem, -2.9846698113rem + 50.9433962264vw, 23.1875rem);
  }
}
@media (max-width: 768px) {
  .top-works__slide {
    max-width: 371px;
  }
}
.top-works__prev {
  left: calc(clamp(1.875rem, -23.125rem + 25vw, 3.125rem) * -1);
}
.top-works__next {
  right: calc(clamp(1.875rem, -23.125rem + 25vw, 3.125rem) * -1);
}
.top-works__post-link {
  height: 100%;
  display: block;
  overflow: hidden;
  background-color: var(--base);
  border-radius: 30px;
}
.top-works__thumbnail {
  aspect-ratio: 371/229;
  overflow: hidden;
}
.top-works__thumbnail img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.top-works__box {
  min-height: 229px;
  padding: 33px 15px 30px;
}
.top-works__box-inner {
  max-width: 279px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-works__box-inner {
    max-width: 100%;
  }
}
.top-works__time {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
}
.top-works__post-title {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: 900;
  line-height: 1.5;
  margin-top: 26px;
}
.top-works__no-post {
  width: 100%;
  background-color: var(--main);
  color: var(--base);
  font-size: clamp(1.375rem, -0.0562130178rem + 5.325443787vw, 2.5rem);
  text-align: center;
  padding: 15px 0;
}
.top-works__more {
  margin-top: clamp(1.6875rem, -1.7315088757rem + 12.7218934911vw, 4.375rem);
  margin-inline: auto;
}

@media (hover: hover) and (pointer: fine) {
  .top-works__post-link:hover .top-works__thumbnail img, .top-works__post-link:focus .top-works__thumbnail img {
    scale: 1.1;
  }
  .top-works__thumbnail img {
    -webkit-transition: scale 0.3s;
    transition: scale 0.3s;
  }
}
.top-recruit {
  background: url(../images/top-recruit-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-recruit-bg.webp) 1x, url(../images/top-recruit-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-recruit-bg.webp) 1x, url(../images/top-recruit-bg@2x.webp) 2x);
  color: var(--base);
}
.top-recruit__inner {
  max-width: 1518px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 229px 30px 303px;
}
@media (max-width: 1000px) {
  .top-recruit__inner {
    padding: clamp(5.8125rem, -0.5997807018rem + 23.8596491228vw, 14.3125rem) clamp(1.25rem, 0.4548816568rem + 2.9585798817vw, 1.875rem) clamp(5.5rem, -4.6370614035rem + 37.7192982456vw, 18.9375rem);
  }
}
.top-recruit__title {
  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: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  row-gap: calc(clamp(-1.5rem, -2.6926775148rem + 4.4378698225vw, -0.5625rem) * -1);
  white-space: pre-line;
}
.top-recruit__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
  line-height: 1.4545454545;
}
@media (max-width: 768px) {
  .top-recruit__jp {
    line-height: 1.4583333333;
  }
}
.top-recruit__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.top-recruit__text {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: 900;
  line-height: 1.4444444444;
  white-space: pre-line;
  margin-top: clamp(1.75rem, 1.3524408284rem + 1.4792899408vw, 2.0625rem);
  margin-inline: auto;
}
@media (max-width: 768px) {
  .top-recruit__text {
    font-weight: bold;
    line-height: 1.5;
  }
}
.top-recruit__more {
  margin-top: clamp(3.9375rem, 2.3472633136rem + 5.9171597633vw, 5.1875rem);
}
@media (max-width: 600px) {
  .top-recruit__more {
    margin-inline: auto;
  }
}

.top-news {
  background-color: var(--main);
  color: var(--base);
}
.top-news__inner {
  max-width: 1686px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 144px 30px 50px;
}
@media (max-width: 1000px) {
  .top-news__inner {
    padding: clamp(3.1875rem, -1.1973684211rem + 16.3157894737vw, 9rem) 30px 50px;
  }
}
.top-news__body {
  max-width: 1593px;
  display: grid;
  grid-template-columns: clamp(14.0625rem, -9.9375rem + 30vw, 21rem) 1fr;
}
@media (max-width: 768px) {
  .top-news__body {
    grid-template-columns: 1fr;
    justify-items: center;
    row-gap: 50px;
  }
}
.top-news__title {
  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-pack: end;
  -webkit-justify-content: flex-end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
      -ms-flex-align: start;
          align-items: flex-start;
  row-gap: 15px;
}
@media (max-width: 768px) {
  .top-news__title {
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.top-news__jp {
  font-size: clamp(1.5rem, -0.0902366864rem + 5.9171597633vw, 2.75rem);
  font-weight: 900;
}
.top-news__en {
  font-family: "Noto Sans", serif;
  font-optical-sizing: auto;
  font-variation-settings: "wdth" 100;
  font-size: clamp(1rem, 0.5229289941rem + 1.775147929vw, 1.375rem);
}
.top-news__items {
  min-height: clamp(12.375rem, 11.0232988166rem + 5.0295857988vw, 13.4375rem);
  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;
}
@media (max-width: 768px) {
  .top-news__items {
    width: 100%;
  }
}
.top-news__items_no-post {
  display: grid;
  place-items: center;
}
.top-news__post-link {
  display: grid;
  grid-template-columns: clamp(9.625rem, -3.8293010753rem + 21.5053763441vw, 13.375rem) 1fr;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  line-height: 1.4444444444;
  border-bottom: 2px solid var(--base);
  padding: 0 12px 20px;
}
@media (max-width: 1000px) {
  .top-news__post-link {
    grid-template-columns: 1fr;
    border-bottom: none;
    padding: 0;
  }
}
@media (max-width: 768px) {
  .top-news__post-link {
    line-height: 1.5;
  }
}
@media (max-width: 1000px) {
  .top-news__time {
    border-bottom: 2px solid var(--base);
    padding: 0 clamp(0.5rem, -0.25rem + 2.4vw, 1.25rem) clamp(0.25rem, -0.0680473373rem + 1.1834319527vw, 0.5rem);
  }
}
@media (max-width: 1000px) {
  .top-news__post-title {
    padding: clamp(0rem, -0.6360946746rem + 2.3668639053vw, 0.5rem) clamp(0.5rem, -0.25rem + 2.4vw, 1.25rem) 0;
  }
}
.top-news__no-post {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: clamp(1.25rem, 0.8423913043rem + 1.6304347826vw, 1.625rem);
  font-weight: 900;
}
.top-news__more {
  margin-inline: auto;
  margin-top: 30px;
}

/*###################################################################
  flow（page）
###################################################################*/
.flow-main_pos {
  margin-top: clamp(5rem, 0.0407608696rem + 19.8369565217vw, 9.5625rem);
}
.flow-main__inner {
  max-width: 1480px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
.flow-main__br {
  display: none;
}
@media (max-width: 1000px) {
  .flow-main__br {
    display: block;
  }
}
.flow-main__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(3.125rem, 1.902173913rem + 4.8913043478vw, 4.25rem);
  margin-top: clamp(3.75rem, 0.7608695652rem + 11.9565217391vw, 6.5rem);
}
.flow-main__item-top {
  height: clamp(4.6875rem, 2.9891304348rem + 6.7934782609vw, 6.25rem);
  display: grid;
  grid-template-columns: clamp(8.125rem, 5.4076086957rem + 10.8695652174vw, 10.625rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: var(--main);
  color: var(--base);
  font-size: 1.125rem;
}
.flow-main__step {
  padding-left: 27px;
}
.flow-main__item-bottom {
  min-height: 153px;
  background-color: #ececec;
  padding: 23px clamp(0.75rem, 0.2065217391rem + 2.1739130435vw, 1.25rem) 40px;
}
.flow-main__text {
  max-width: 1400px;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: bold;
  line-height: 1.4444444444;
  white-space: pre-line;
  margin-inline: auto;
}

/*###################################################################
  service（page）
###################################################################*/
.service-menu_pos {
  margin-top: clamp(5rem, 0.0407608696rem + 19.8369565217vw, 9.5625rem);
}
.service-menu__items {
  max-width: 1759px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 47px clamp(1.25rem, -22.1875rem + 25vw, 5.9375rem);
}
@media (max-width: 1000px) {
  .service-menu__items {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .service-menu__items {
    max-width: 500px;
    grid-template-columns: 1fr;
    margin-inline: auto;
    padding: 0 clamp(1rem, -0.1131656805rem + 4.1420118343vw, 1.875rem);
  }
}

.service-main_pos {
  margin-top: 19px;
}
.service-main__inner {
  max-width: 1480px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 85px 30px 99px;
  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: calc(clamp(-5rem, -16.6163141994rem + 24.16918429vw, 0rem) * -1);
}
@media (max-width: 768px) {
  .service-main__inner {
    max-width: 600px;
    margin-inline: auto;
  }
}
.service-main__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-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  margin-top: 68px;
}
@media (max-width: 768px) {
  .service-main__box {
    -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;
    margin-top: 40px;
  }
}
.service-main__text {
  max-width: 660px;
  width: 100%;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: bold;
  line-height: 1.4444444444;
  white-space: pre-line;
}
.service-main__img {
  max-width: 674px;
  width: 100%;
}

/*###################################################################
  work（page）
###################################################################*/
.work-list {
  background-color: #ebebeb;
}
.work-list__inner {
  max-width: 1486px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 153px 30px 181px;
}
@media (max-width: 1000px) {
  .work-list__inner {
    padding: clamp(5rem, -0.8043639053rem + 21.5976331361vw, 9.5625rem) 30px 181px;
  }
}
.work-list__items {
  max-width: 1371px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2.5rem, 0.0953947368rem + 8.9473684211vw, 5.6875rem) clamp(1.25rem, -56.8833333333rem + 72.6666666667vw, 8.0625rem);
  margin-top: 83px;
  margin-inline: auto;
}
@media (max-width: 1000px) {
  .work-list__items {
    max-width: 762px;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 768px) {
  .work-list__items {
    max-width: 372px;
    grid-template-columns: 1fr;
  }
}
.work-list__items_no-post {
  max-width: 100%;
  min-height: clamp(9.375rem, -5.1469298246rem + 54.0350877193vw, 28.625rem);
  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;
}
.work-list__post-link {
  height: 100%;
  display: block;
  overflow: hidden;
  background-color: var(--base);
  border-radius: 30px;
}
.work-list__thumbnail {
  aspect-ratio: 371/229;
  overflow: hidden;
}
.work-list__thumbnail img {
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.work-list__box {
  min-height: 229px;
  padding: 33px 15px 30px;
}
.work-list__box-inner {
  max-width: 279px;
  margin-inline: auto;
}
@media (max-width: 768px) {
  .work-list__box-inner {
    max-width: 100%;
  }
}
.work-list__time {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
}
.work-list__post-title {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: 900;
  line-height: 1.5;
  margin-top: 26px;
}
.work-list__no-post {
  width: 100%;
  background-color: var(--main);
  color: var(--base);
  font-size: clamp(1.375rem, -0.0562130178rem + 5.325443787vw, 2.5rem);
  text-align: center;
  padding: 15px 0;
}

@media (hover: hover) and (pointer: fine) {
  .work-list__post-link:hover .work-list__thumbnail img, .work-list__post-link:focus .work-list__thumbnail img {
    scale: 1.1;
  }
  .work-list__thumbnail img {
    -webkit-transition: scale 0.3s;
    transition: scale 0.3s;
  }
}
/*###################################################################
  company（page）
###################################################################*/
.company-msg {
  position: relative;
  background: var(--main) url(../images/top-message-bg.webp) repeat-x left bottom 28px/auto 215px;
  background-image: -webkit-image-set(url(../images/top-message-bg.webp) 1x, url(../images/top-message-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-message-bg.webp) 1x, url(../images/top-message-bg@2x.webp) 2x);
  color: var(--base);
}
@media (max-width: 768px) {
  .company-msg {
    background-position: left bottom 39px;
  }
}
.company-msg__inner {
  max-width: 1486px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 153px 30px 419px;
}
@media (max-width: 1280px) {
  .company-msg__inner {
    padding: clamp(4.1875rem, 0.1326754386rem + 15.0877192982vw, 9.5625rem) clamp(1.3125rem, 0.5968934911rem + 2.6627218935vw, 1.875rem) clamp(14.0625rem, 4.9155701754rem + 34.0350877193vw, 26.1875rem);
  }
}
.company-msg__main {
  max-width: 1218px;
}
.company-msg__title {
  min-width: 201px;
  color: var(--base);
  border-color: var(--base);
}
.company-msg__box {
  max-width: 967px;
  width: 100%;
  margin-top: 26px;
  margin-left: auto;
}
.company-msg__box-title {
  font-size: clamp(1.125rem, 0.8069526627rem + 1.1834319527vw, 1.375rem);
  font-weight: 900;
  line-height: 1.5;
}
@media (max-width: 429px) {
  .company-msg__box-title {
    font-size: clamp(1.0625rem, 0.2004310345rem + 3.4482758621vw, 1.125rem);
  }
}
.company-msg__text {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: 900;
  line-height: 1.4444444444;
  white-space: pre-line;
  text-shadow: 0px 0px 0px #000;
  margin-top: 28px;
}
@media (max-width: 768px) {
  .company-msg__text {
    line-height: 1.375;
  }
}
.company-msg__name {
  font-size: 1.125rem;
  font-weight: 900;
  text-align: right;
  margin-top: 58px;
}
@media (max-width: 768px) {
  .company-msg__br {
    display: none;
  }
}

.company-concept {
  background: url(../images/company-concept-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/company-concept-bg.webp) 1x, url(../images/company-concept-bg@2x.webp) 2x);
  background-image: image-set(url(../images/company-concept-bg.webp) 1x, url(../images/company-concept-bg@2x.webp) 2x);
}
.company-concept__inner {
  max-width: 1480px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 85px 30px 99px;
}
.company-concept__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: 64px;
}
@media (max-width: 768px) {
  .company-concept__items {
    max-width: 600px;
    row-gap: 80px;
    margin-inline: auto;
  }
}
.company-concept__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-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  margin-top: 68px;
}
@media (max-width: 768px) {
  .company-concept__box {
    -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;
    margin-top: 40px;
  }
}
.company-concept__text {
  max-width: 660px;
  width: 100%;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: bold;
  line-height: 1.4444444444;
  white-space: pre-line;
}
.company-concept__img {
  max-width: 674px;
  width: 100%;
}

.company-outline_pos {
  margin-top: 50px;
}
.company-outline__inner {
  max-width: 1480px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
.company-outline__main {
  display: grid;
  grid-template-columns: 1fr clamp(25rem, -15.9119928401rem + 65.3937947494vw, 42.125rem);
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  margin-top: 64px;
}
@media (max-width: 1000px) {
  .company-outline__main {
    max-width: 700px;
    grid-template-columns: 1fr;
    row-gap: 40px;
    margin-inline: auto;
  }
}
.company-outline__dl {
  display: grid;
  grid-template-columns: clamp(9.75rem, 0.3432279236rem + 15.0357995227vw, 13.6875rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 25px;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  line-height: 1.4444444444;
}
@media (max-width: 600px) {
  .company-outline__dl {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
}
.company-outline__dt {
  max-width: clamp(8.75rem, 1.5829355609rem + 11.4558472554vw, 11.75rem);
  height: 50px;
  display: grid;
  place-items: center;
  background-color: var(--main);
  color: var(--base);
  font-weight: 400;
}
@media (max-width: 600px) {
  .company-outline__dt {
    max-width: 100%;
  }
}
.company-outline__dd {
  white-space: pre-line;
}
@media (max-width: 600px) {
  .company-outline__dd {
    padding-bottom: 20px;
  }
}

.company-recruit_pos {
  margin-top: 189px;
}
.company-recruit__top {
  background: url(../images/company-recruit-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/company-recruit-bg.webp) 1x, url(../images/company-recruit-bg@2x.webp) 2x);
  background-image: image-set(url(../images/company-recruit-bg.webp) 1x, url(../images/company-recruit-bg@2x.webp) 2x);
}
.company-recruit__top-inner {
  max-width: 1480px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 44px 30px 81px;
}
.company-recruit__title {
  color: var(--base);
  border-color: var(--base);
}
.company-recruit__top-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: 68px;
}
@media (max-width: 768px) {
  .company-recruit__top-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;
    margin-top: 40px;
  }
}
.company-recruit__text {
  max-width: 660px;
  width: 100%;
  color: var(--base);
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  font-weight: bold;
  line-height: 1.4444444444;
  white-space: pre-line;
}
.company-recruit__img {
  max-width: 674px;
  width: 100%;
}
.company-recruit__bottom {
  margin-top: 49px;
}
.company-recruit__bottom-inner {
  max-width: 1213px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
.company-recruit__bottom-title {
  font-size: 2.1875rem;
  text-align: center;
  --spacing: 0;
}
.company-recruit__dl {
  display: grid;
  grid-template-columns: clamp(5.625rem, -0.625rem + 25vw, 15rem) 1fr;
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  line-height: 1.4444444444;
  margin-top: 54px;
}
.company-recruit__dt {
  font-weight: 400;
  padding: clamp(1.875rem, 1.0416666667rem + 3.3333333333vw, 3.125rem) 0 clamp(1.875rem, 1.0416666667rem + 3.3333333333vw, 3.125rem) clamp(0rem, -2.0416666667rem + 8.1666666667vw, 3.0625rem);
}
.company-recruit__dt:not(:last-of-type) {
  border-bottom: 2px solid #ccc;
}
.company-recruit__dd {
  white-space: pre-line;
  padding: clamp(1.875rem, 1.0416666667rem + 3.3333333333vw, 3.125rem) clamp(0rem, -0.625rem + 2.5vw, 0.9375rem) clamp(1.875rem, 1.0416666667rem + 3.3333333333vw, 3.125rem) 0;
}
.company-recruit__dd:not(:last-of-type) {
  border-bottom: 2px solid #ccc;
}

/*###################################################################
  contact（page）
###################################################################*/
.contact-main {
  background-color: #f0f0f0;
}
.contact-main__inner {
  max-width: 1486px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding: 155px 30px 69px;
}
@media (max-width: 768px) {
  .contact-main__inner {
    padding: clamp(5rem, -0.963387574rem + 22.1893491124vw, 9.6875rem) clamp(0.75rem, -1.348880597rem + 6.7164179104vw, 1.875rem) 69px;
  }
}
.contact-main__items {
  max-width: 1378px;
  margin-top: 16px;
  margin-inline: auto;
}
.contact-main__item {
  font-size: clamp(1rem, 0.8409763314rem + 0.5917159763vw, 1.125rem);
  line-height: 1.4444444444;
  text-indent: -1em;
  padding-left: 1em;
}
.contact-main__form-wrapper {
  max-width: 1280px;
  margin-top: 87px;
  margin-inline: auto;
}

.form__body {
  background-color: #f8f8f8;
  padding: 31px clamp(1.25rem, -11.3253768844rem + 20.1005025126vw, 3.75rem) 84px 20px;
}
@media (max-width: 768px) {
  .form__body {
    padding: 31px clamp(0.625rem, -0.5410447761rem + 3.7313432836vw, 1.25rem) 84px;
  }
}
.form__body-inner {
  max-width: 1025px;
  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: 31px;
  margin-left: auto;
}
.form__paragraph {
  display: grid;
  grid-template-columns: clamp(13.75rem, -2.0627705628rem + 32.9004329004vw, 18.5rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 768px) {
  .form__paragraph {
    grid-template-columns: 1fr;
    row-gap: 10px;
  }
}
.form__paragraph_region .wpcf7-form-control-wrap {
  max-width: 272px;
  position: relative;
}
.form__paragraph_region .wpcf7-form-control-wrap::after {
  content: "";
  width: 1.140625rem;
  aspect-ratio: 18.25/8.63;
  position: absolute;
  top: 50%;
  right: 18px;
  -webkit-transform: translateY(-50%);
      -ms-transform: translateY(-50%);
          transform: translateY(-50%);
  background: url(../images/icon-select.svg) no-repeat 0 0/contain;
  pointer-events: none;
}
.form__paragraph_email {
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
}
.form__paragraph_message {
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
}
.form__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 21px;
     -moz-column-gap: 21px;
          column-gap: 21px;
  font-size: 1.125rem;
}
.form__title_email {
  margin-top: 20px;
}
.form__required {
  color: #ff0000;
}
.form__input {
  width: 100%;
  height: 62px;
  background-color: var(--base);
  font-size: 1.125rem;
  border: 2px solid #c6c6c6;
  padding: 5px 11px;
}
.form__input::-webkit-input-placeholder {
  color: #9c9c9c;
}
.form__input::-moz-placeholder {
  color: #9c9c9c;
}
.form__input:-ms-input-placeholder {
  color: #9c9c9c;
}
.form__input::-ms-input-placeholder {
  color: #9c9c9c;
}
.form__input::placeholder {
  color: #9c9c9c;
}
.form__input_l {
  max-width: 493px;
}
.form__input_m {
  max-width: 401px;
}
.form__input_s {
  max-width: 272px;
}
.form__input_email-confirm {
  margin-top: 34px;
}
.form__input_message {
  height: 243px;
  line-height: 1.5;
  resize: vertical;
}
.form__select {
  max-width: 272px;
  width: 100%;
  height: 62px;
  background-color: var(--base);
  font-size: 1.125rem;
  border: 2px solid #c6c6c6;
  cursor: pointer;
  padding: 5px 17px;
}
.form__caution {
  font-size: 1.125rem;
  margin-top: 10px;
  margin-left: 15px;
}
.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: 67px;
}
.form__action-button {
  width: clamp(16.875rem, 7.5rem + 37.5vw, 21.5625rem);
  height: 85px;
  background-color: var(--main);
  color: var(--base);
  font-size: 1.5625rem;
  text-align: center;
  vertical-align: middle;
}
.form[data-status=sent] .form__button-wrapper {
  display: none;
}

/*###################################################################
  news（page）
###################################################################*/
.news-list_pos {
  margin-top: clamp(5rem, -0.8043639053rem + 21.5976331361vw, 9.5625rem);
}
.news-list__inner {
  max-width: 1200px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
@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);
  margin-top: 100px;
}
@media (max-width: 600px) {
  .news-list__items {
    row-gap: 50px;
    margin-top: 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%;
}
@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.125rem;
  line-height: 1.75;
}
.news-list__post-title {
  font-size: 1.125rem;
  font-weight: 900;
  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-size: 1.25rem;
  font-weight: 900;
}
.news-list__pagination {
  font-size: 1.25rem;
  font-weight: 900;
  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__post-link:focus {
    background-color: #d6dbd6;
  }
  .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: clamp(5rem, -0.8043639053rem + 21.5976331361vw, 9.5625rem);
}
.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: bold;
}
@media (max-width: 768px) {
  .news-post__date {
    font-size: 1.125rem;
  }
}
.news-post__title {
  font-size: 1.5rem;
  font-weight: 900;
  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);
  font-weight: 900;
  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: 80px;
}
.page-404__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
  margin-inline: auto;
  padding-right: 30px;
  padding-left: 30px;
}
.page-404__title {
  color: var(--main);
  font-size: 1.5rem;
  font-weight: 900;
  line-height: 1.5;
}
.page-404__text {
  font-size: 1.125rem;
  line-height: 1.75;
  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;
}

@media (hover: hover) and (pointer: fine) {
  .page-404__button {
    -webkit-transition: opacity 0.5s;
    transition: opacity 0.5s;
  }
  .page-404__button:hover, .page-404__button:focus {
    opacity: 0.7;
  }
}
/*###################################################################
  js-（js制御用）
###################################################################*/